Twilioサブアカウントの使用にあたり把握しておくべきこと
本投稿では、サブアカウントを使用するメリットと、サブアカウントを介してメッセージを送信する方法について説明します。サブアカウントを使用すると、メインアカウントと残高を共有しながら、使用状況、番号、設定を区分できます。これは、Twilioの使用量を区分するのに最適な方法です。
本投稿で扱う主な項目は次のとおりです。
- 技術要件
- Twilioサブアカウントとは?それらを使用すべき理由は?
- サブアカウントを使用したメッセージの送信
技術要件
- 無料のTwilioアカウント - こちらのリンクからご登録いただくと、アップグレード時に$10の追加クレジットを差し上げます。
- Twilio電話番号。
- 認証済みの携帯電話番号(SMSメッセージの受信用)。
- REST APIリクエストの送信に関する知識。ここでは、bashやzshからcURLを実行したり、Postmanなどのツールを使用したりする際に役立つヒントを紹介します。
Twilioサブアカウントとは?それらを使用すべき理由は?
サブアカウントは、Twilioプロジェクト(親)に属するリソースを分離するコンテナです。たとえば、架空の会社Owlie Notificationsについて考えてみましょう。Owlie Notificationsは、顧客が電話をかけることのできるSaaSプラットフォームを提供しています。Owlie Notificationsは約50件の顧客を抱えています。
Owlie NotificationsがTwilioアカウント構造を作成する際には、以下の2つの選択肢があります。
- Twilioアカウントを作成します。これはアカウントに固有のアカウントSIDと呼ばれる識別子(必ず「AC」が先頭に追加される)に関連付けられます。Owlie NotificationsがAPIリクエストを行う際には、必ずそのアカウントのアカウントSIDを使用します。たとえば、アカウントSIDはAC123などとなります。
- 選択肢1と同じ方法でTwilioアカウント(アカウントSID = AC123、親アカウント)を作成しますが、50件の顧客のそれぞれについて、サブアカウントも作成します。50件の各サブアカウントに、固有のアカウントSIDが割り当てられます。そのため、Owlie Notificationsが顧客のAPIリクエストを行う場合、親アカウントのアカウントSIDではなく、該当するサブアカウントのアカウントSIDが使用されます。
選択肢2を選ぶのが最適な理由をご説明します。
サブアカウントの主なメリット
請求プロセスを区分できる
Owlie Notificationsがサブアカウントを使用しないことを選択した場合、各顧客の使用状況をすべて追跡する必要があります。これには余計な手間がかかり、ミスをする可能性もあります。サブアカウントはコンテナとして機能するため、Twilio Usage APIを使用してサブアカウントの特定の請求データを取得できます。そのため、個々の顧客の追跡に必要なビジネスロジックを減らすことができます。
リソースのプロビジョニングが可能
サブアカウントを使用すると、リソース(電話番号など)を特定のサブアカウントに追加できます。ただし、ほとんどのリソースは同時に1つのサブアカウントにしか所属できません。アカウント間で常に番号を移動している場合、これは悩ましい問題です。たとえば、あるサブアカウントを閉じても電話番号は保持したい場合には、このロジックを処理する必要があります。幸い、Twilioを使用するとアカウント間で電話番号を移動できます。
同じプロジェクトの複数アカウントの管理を強化: サブアカウントを使用すると、顧客のニーズに基づいてサブアカウントを一時停止、閉鎖、再アクティブ化することが可能です。
サブアカウントへ移行する前の考慮事項
Twilioを使用してメッセージを送信しているお客様にとって、Twilioは、エンドユーザーがメッセージにSTOPと返信した場合など、顧客のオプトアウトを管理するのに役立ちます。Twilioでは、このオプトアウトリストをアカウントレベルで管理できます。
つまり、エンドユーザーが電話番号に対してSTOPと返信し、その電話番号がプロジェクトから(一意のアカウントSIDを持つ)サブアカウントへ移動されていた場合、そのオプトアウトのマッピングは壊れてしまうということです。オプトアウトを追跡していない場合は今すぐ開始し、最新の購読者リストを入手しましょう。
サブアカウントを使用したメッセージの送信
「サブアカウントをまだ使用していない場合はどうすればよいのだろう。移行はどの程度難しいのか?」とお考えかもしれません。
Owlie Notificationsが50件すべての顧客に対して1つのアカウントを使用していたとします。現在、SMSメッセージを送信したい顧客がいます。Owlie Notificationsが実行する必要がある可能性の高い手順は、次のとおりです。
これをプログラムで行うにはサブアカウントREST APIを使用しますが、必要に応じてサーバー側ヘルパーライブラリーを使用することもできます。
まず、Twilio Consoleにログインします。アカウントに割り当てられたアカウントSIDと認証トークンの値がダッシュボードに表示されます。
以下の例では、作成またはコピーしたTwilioアカウントのアカウントSIDと認証トークンを使用します。以下のすべてのプレースホルダーについて、これらを置き換えてください。
サブアカウントの作成
引き続き、Owlie Notificationsの顧客(Falcon Flights)のサブアカウントを作成しましょう。
リクエスト
ターミナルまたはコマンドプロンプトで次のコマンドを実行し、リクエストを作成します。プレースホルダー値を親アカウントのアカウントSIDと認証トークンに置き換えてください。
レスポンス
コマンドを実行すると、次のようなレスポンスが表示されます。
このレスポンスには、いくつかの重要な情報が含まれています。
独自のアカウントSIDと認証トークンを持つ、FalconFlightsという名前の新しいアカウントがあります。
owner_account_sid
は、プロジェクト(親)アカウントのSID(Owlie Notifications)と一致している必要があります。
後で使用できるように、サブアカウントのアカウントSIDと認証トークンを追跡してください。
電話番号の転送
先ほど、電話番号を転送する場合について説明しました。ここではその方法を説明します。Twilio電話番号をお持ちでない場合は、Twilio ConsoleまたはREST APIから1つ購入できます。
親アカウントとサブアカウントの間でTwilio電話番号の転送を開始するには、Consoleの[Active Numbers](アクティブな番号)セクションに移動します。番号をクリックすると、設定オプションが表示されます。
ここにはお使いの電話番号SID(PNxxx)が記載されています。
電話番号を別のアカウントに移動すると、音声とSMSのURLが保持される点に注意してください。
レスポンス
メッセージングサービスを作成する
新たに作成したサブアカウントでメッセージングサービスを作成します。メッセージングサービスは電話番号のコンテナとして機能するリソースであり、大規模なメッセージ送信を簡素化するソフトウェアを提供します。
このリクエストでは、サブアカウントに関連付けられたアカウントSIDと認証トークンを使用します。
リクエスト
レスポンス
レスポンスではメッセージングサービスのSID(MGxxxx)が提供されます。これは次のステップで使用するため、すぐに利用できるようにしてください。
レスポンスオブジェクトにはさまざまな属性がかなり含まれていることに気付くでしょう。メッセージングサービスの全機能について詳しくは、メッセージングサービスのドキュメントを参照してください。
レスポンス
これで、メッセージングサービスに電話番号が正常に追加されました。
メッセージの送信
新しいサブアカウントが作成されました。メッセージングサービスと電話番号でメッセージを送信できます。
メッセージングサービスを介してメッセージを送信するには、リクエストでメッセージングサービスのSID(MGxxx)を使用します。
To
の電話番号が認証済みであることを確認してください。番号が認証されていない場合は、Twilio Consoleから検証済みの電話番号を追加できます。
リクエスト
成功すると、次のようなテキストが表示されます。
成功しました。
まとめ: 強力なサブアカウント
これまでの操作をまとめましょう。
- サブアカウントを作成
- 親アカウントからサブアカウントへ電話番号を転送
- サブアカウントでメッセージングサービスを作成
- メッセージングサービスに電話番号を追加
- サブアカウントのメッセージングサービスを介してメッセージを送信
サブアカウントが強力であることを実感していただけたでしょうか。この記事の内容は、ほんの始まりに過ぎません。このブログに関心がある方には、以下もお勧めします。
- Usage APIを使用したサブアカウントの使用量の追跡
- Usage Triggerのセットアップ
- ISV向けのメッセージングのアーキテクチャ
- ISV向けの音声アーキテクチャ
JoshはTwilioのシニアソリューションエンジニアであり、独立系ソフトウェアベンダー(ISV)パートナーがTwilio上でスケーラブルなアーキテクチャとビジネスを構築できるよう支援しています。連絡先はjsiverson [at] twilio.comです。