クロスアプリEcosystemウォレット
Sequence Ecosystem Walletsを使うことで、エコシステム全体でユーザーが利用できる統合ウォレットを作成できます。
Sequenceのクロスアプリソリューションにより、ユーザーはエコシステムのEmbedded Walletを、同じウォレットアドレスでどのアプリでも利用できます。これは、エコシステム外のアプリや、wagmiなどの一般的なウォレットコネクタを使ってSequenceと統合されたアプリにも対応しています。対象例:
- 外部マーケットプレイス
- 外部DEX
- 外部アプリケーション
クロスアプリEmbedded Walletコネクタのデモはこちらでご覧いただけます。
クロスアプリEmbedded Walletは、外部アプリケーションとウォレットアプリケーション間の通信フローを実装しています:
- 外部アプリは、Wagmi用のクロスアプリEmbedded Walletコネクタを通じてウォレットと通信します
- コネクタはProviderTransportを使って通信を管理します
- ProviderTransportとWalletTransport間でメッセージが送受信されます
- Walletコンポーネントは主に以下の3つの機能を担当します:
- ユーザー認証
- トランザクション署名
- メッセージ署名
ウォレットは開かれ、トランスポートレイヤーを通じて外部アプリケーションにメッセージを返すことができ、安全なクロスアプリケーション通信を実現します。特にクロスアプリ統合の場合、ユーザーはすべての操作を確認する必要があります。
クロスアプリEmbedded Walletアプリ&コネクタをクローンする
Wallet Transportを自分の設定で更新する
エコシステムEmbedded Walletの変数を.env
ファイルに入力します。その後、pnpm build
でウォレットアプリケーションをビルドし、Cloudflare PagesなどのパブリックURLでアクセスできるサービスにデプロイしてください。
外部アプリケーションの設定例
次に、ウォレットコネクタのURLをwagmiに渡す外部アプリケーションの設定例を紹介します。
サンプルアプリケーションに移動し、特にsequence cross-app connectorパッケージ @sequence-wallet/cross-app-connector
の依存関係をインストールします:
次に、プロジェクトアクセスキーと先ほどデプロイしたウォレットURLで環境変数を更新します:
Wagmiコネクタを更新する
最後に、src/wagmiConfig.ts
にある wagmi コネクタの設定を、お使いのウォレットに合わせて編集できます。以下は外部アプリケーションに提供できる設定例です。
これで、ウォレットコネクタの設定を他のアプリに共有し、ユーザーが同じウォレットアドレスを使って、そのアプリケーション内でもエコシステムウォレットを活用できるようになります。