はじめに
セットアップのプロンプトをコピーして、インストールの手順とこのプラグインのフルマークダウンガイドを含む。
Set up this Capacitor plugin in the project.
Use the package manager already used by the project.
Install these package(s): `@capgo/capacitor-twilio-voice`
Run the required Capacitor sync/update step after installation.
Read this markdown guide for the full setup steps: https://raw.githubusercontent.com/Cap-go/website/refs/heads/main/apps/docs/src/content/docs/docs/plugins/twilio-voice/getting-started.mdx
Use that guide for platform-specific steps, native file edits, permissions, config changes, imports, and usage setup.
If that guide references other docs pages, read them too.
インストール
「インストール」のセクションbun add @capgo/capacitor-twilio-voicebunx cap syncインポート
「インポート」セクションimport { CapacitorTwilioVoice } from '@capgo/capacitor-twilio-voice';API オーバービュー
「API オーバービュー」セクションlogin
「ログイン」セクションTwilio Voiceを使用したユーザーの認証にアクセストークンを使用します。
アクセストークンは、Twilioのクレデンシャルを使用してバックエンドサーバーで生成する必要があります。 Twilio Voiceを使用して呼び出しを行うか受信するには、このトークンが必要です。
import { CapacitorTwilioVoice } from '@capgo/capacitor-twilio-voice';
const result = await CapacitorTwilioVoice.login({ accessToken: 'eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9...'});console.log('Login successful:', result.success);logout
「ログアウト」セクション現在のユーザーをログアウトし、Twilio Voiceからアンレジスターします。
これにより、現在の呼び出しを切断し、受信する新しい呼び出し通知を受信しなくなります。
import { CapacitorTwilioVoice } from '@capgo/capacitor-twilio-voice';
const result = await CapacitorTwilioVoice.logout();console.log('Logout successful:', result.success);isLoggedIn
ログイン状態の確認ユーザーが現在ログインしているか、有効なアクセストークンを持っているかを確認します。
import { CapacitorTwilioVoice } from '@capgo/capacitor-twilio-voice';
const status = await CapacitorTwilioVoice.isLoggedIn();if (status.isLoggedIn && status.hasValidToken) { console.log('User identity:', status.identity);} else { // Re-authenticate the user}makeCall
セクション「電話呼び出し」電話番号またはクライアントへの出発電話呼び出しを開始します。
電話呼び出しを行うには、ユーザーはログインしている必要があります。電話呼び出しは、Twilioのバックエンド設定を通じてルーティングされます。
import { CapacitorTwilioVoice } from '@capgo/capacitor-twilio-voice';
// Call a phone numberconst result = await CapacitorTwilioVoice.makeCall({ to: '+1234567890'});console.log('Call SID:', result.callSid);
// Call another Twilio client with a readable name for CallKit Recentsawait CapacitorTwilioVoice.makeCall({ to: 'client:alice', displayName: 'Alice Smith'});
// Call a PSTN number using a specific caller IDawait CapacitorTwilioVoice.makeCall({ to: '+1234567890', callerId: '+10987654321'});acceptCall
セクション「電話受付」着信電話を受け入れます。
この関数は、'callInviteReceived' イベントに応答して呼び出されるべきです。
import { CapacitorTwilioVoice } from '@capgo/capacitor-twilio-voice';
CapacitorTwilioVoice.addListener('callInviteReceived', async (data) => { console.log('Incoming call from:', data.from); const result = await CapacitorTwilioVoice.acceptCall({ callSid: data.callSid }); console.log('Call accepted:', result.success);});rejectCall
セクション「電話拒否」着信を拒否する。
呼び出しを受け取ったときに呼び出す必要があります。
import { CapacitorTwilioVoice } from '@capgo/capacitor-twilio-voice';
CapacitorTwilioVoice.addListener('callInviteReceived', async (data) => { if (shouldRejectCall(data.from)) { await CapacitorTwilioVoice.rejectCall({ callSid: data.callSid }); }});endCall
コピー「endCall」セクション
現在進行中の通話を終了します。
import { CapacitorTwilioVoice } from '@capgo/capacitor-twilio-voice';
// End the current active callawait CapacitorTwilioVoice.endCall({});
// End a specific callawait CapacitorTwilioVoice.endCall({ callSid: 'CA1234567890abcdef'});muteCall
コピー「muteCall」セクション
通話中のマイクをミュートまたはアンミュートします。
import { CapacitorTwilioVoice } from '@capgo/capacitor-twilio-voice';
// Mute the microphoneawait CapacitorTwilioVoice.muteCall({ muted: true});
// Unmute the microphoneawait CapacitorTwilioVoice.muteCall({ muted: false});setSpeaker
コピースピーカーモードを有効または無効にします。
有効にすると、音声はデバイスのスピーカー経由でルーティングされ、イヤピースではなくなる。
import { CapacitorTwilioVoice } from '@capgo/capacitor-twilio-voice';
// Enable speakerphoneawait CapacitorTwilioVoice.setSpeaker({ enabled: true});
// Disable speakerphoneawait CapacitorTwilioVoice.setSpeaker({ enabled: false});getCallStatus
セクション “getCallStatus”現在のアクティブな通話の状態を取得します。
この機能は、通話の状態、ミュート状態、ホールド状態、通話識別子についてリアルタイムの情報を提供します。
import { CapacitorTwilioVoice } from '@capgo/capacitor-twilio-voice';
const status = await CapacitorTwilioVoice.getCallStatus();if (status.hasActiveCall) { console.log('Call SID:', status.callSid); console.log('Call State:', status.callState); console.log('Is Muted:', status.isMuted); console.log('Is On Hold:', status.isOnHold);}checkMicrophonePermission
セクション “checkMicrophonePermission”マイクの許可が既に付与されているかどうかを確認します。
許可を求めるのではなく、現在の許可状態を確認します。
import { CapacitorTwilioVoice } from '@capgo/capacitor-twilio-voice';
const result = await CapacitorTwilioVoice.checkMicrophonePermission();if (!result.granted) { console.log('Microphone permission not granted');}requestMicrophonePermission
セクション “requestMicrophonePermission”マイクの許可をユーザーから要求します。
iOS と Android の場合、許可がまだ与えられていない場合はシステムの許可ダイアログが表示されます。許可が以前拒否された場合は、ユーザーはシステム設定で許可を与える必要があります。
import { CapacitorTwilioVoice } from '@capgo/capacitor-twilio-voice';
const result = await CapacitorTwilioVoice.requestMicrophonePermission();if (result.granted) { console.log('Microphone permission granted');} else { console.log('Microphone permission denied');}タイプ リファレンス
タイプ リファレンスCallInvite
「コール インヴィテ」Capacitor プラグインは、Twilio Voice 機能をモバイル アプリケーションに統合するために使用されます。
export interface CallInvite { /** Unique identifier for the incoming call invitation */ callSid: string; /** Phone number or client identifier of the caller (may include custom caller name) */ from: string; /** Phone number or client identifier being called */ to: string; /** Custom parameters passed with the call invitation */ customParams: Record<string, string>;}真実の源
「真実の源」__CAPGO_KEEP_0__ のアップストリームでの変更を再度同步するには、上記の手順を実行してください。 src/definitions.ts. Re-run the sync when the public API changes upstream.