【完全保存版】Banana Walletについて学ぼう!
1 Banana Walletの概要について
Banana Walletは、アプリケーション向けのプラグイン可能なSDKです。
アプリケーションに、ユーザーにとって安全でシームレスな体験を提供するための基盤を提供することがビジョンです。
Banana Walletを使用すると、アプリケーションユーザーはアプリケーション内に使いやすく、非預託型で安全なウォレットを作成できます。
このウォレットはERC-4337(アカウントの抽象化)とゼロ知識証明(ZKPs)を利用しています。
2 ウォレットのデプロイ
ユーザーがTouch-IDを使用して認証すると、ウォレットがデプロイされます。
大まかな流れは、次のようになります。
フロントから「Banana Wallet」による接続を試みます。
Touch IDによる認証を行います。
なお、Touch IDではない方法による認証も可能です。
このようにしばらく待ちます。
しばらくすると、ウォレットがデプロイされます。
3 ウォレットデプロイ時の内部処理について
バックエンドではスマートコントラクトウォレットがチェーン上にデプロイされ、Secure Enclave内でキーペアが生成されます。
プライベートキーに対応する公開キーは、すべての署名付きトランザクションを検証するためにウォレットに格納されます。
詳しくは、こちらの記事をご確認ください。
4 トランザクションの実行について
以下のような流れになります。
「Touch ID」により、トランザクションの署名を行います。
なお、Touch IDではない方法による署名も可能です。
すると、このようにトランザクションが無事、送られます。
5 トランザクション実行時の内部処理について
ユーザーがトランザクションを開始すると、トランザクションはWebAuthnを介してデバイスのSecure Enclaveに署名のために送信されます。
署名されたトランザクションはその後、スマートコントラクトウォレットに送信され、対応する公開キーによって検証されます。
詳細は、こちらの記事をご確認ください。
サポートをしていただけたらすごく嬉しいです😄 いただけたサポートを励みに、これからもコツコツ頑張っていきます😊