Documentation Index
Fetch the complete documentation index at: https://injectivelabs-mintlify-jp-native-developers-first-half.mintlify.app/llms.txt
Use this file to discover all available pages before exploring further.
Ledgerを使用したInjective上のトランザクション署名
このドキュメントでは、Ledgerを使用してInjective上のトランザクションへ署名し、チェーンへブロードキャストする方法について説明します。Injectiveは鍵にEthereumのECDSA secp256k1曲線を使用する独自のカスタムAccount型を定義しているため、実装はCosmos SDKネイティブチェーンのデフォルトのアプローチとは異なります。実装
実装方法を理解するため、いくつかの概念を順を追って確認し、これから取るアプローチが理解しやすいようにしましょう。背景
導出パス(Derivation path)は、Hierarchical Deterministic (HD)ウォレットに鍵のツリー内で特定の鍵を導出する方法を伝えるデータです。導出パスは標準として使用されており、HDウォレットの一部としてBIP32で導入されました。Hierarchical Deterministic Walletとは、シードを使用して多くの公開鍵と秘密鍵を導出するウォレットを指す用語です。 導出パスは次のような形をしています:m/purpose'/coin_type'/account'/change/address_index
シーケンスの各部分にはそれぞれ役割があり、それぞれが秘密鍵、公開鍵、アドレスを変更します。HDパスの各部分の意味について詳細な解説は行いませんが、coin_typeについて簡単に説明します。各ブロックチェーンには、それを表す番号(coin_type)があります。Bitcoinは0、Ethereumは60、Cosmosは118です。
Injective固有のコンテキスト
InjectiveはEthereumと同じcoin_type、すなわち60を使用します。これは、Ledgerを使用してInjective上のトランザクションに署名するには、Ledger上のEthereumアプリを使用する必要があることを意味します。
Ledgerは1つのcoin_typeにつき1つのアプリケーションしかインストールできません。Ethereumアプリを使用してInjective上のトランザクションに署名する必要があるため、有効な署名を取得するために利用可能なオプションを探る必要があります。利用可能なオプションの1つは、typed structured dataのハッシュと署名のためのEIP712手順です。LedgerはsignEIP712HashedMessageを公開しており、これを使用します。
EIP712 typed dataに署名したら、通常のCosmos-SDKのアプローチを使用してトランザクションをパックし、ブロードキャストします。SIGN_MODE_LEGACY_AMINO_JSONモードの使用やCosmosトランザクションへのWeb3Exensionの付加など、いくつかの細かな違いがあり、本ドキュメントで説明します。
EIP712 Typed Data
EIP 712はtyped structured dataのハッシュと署名のための標準です。あらゆるEIP712 typed dataについて、ユーザーが渡す各値(署名が必要なもの)には、その特定の値の正確な型を説明する型表現があります。ユーザーが署名したい値とその型(EIP712 typedDataのPrimaryType)に加えて、すべてのEIP712 typed dataにはトランザクションのソースに関するコンテキストを提供するEIP712Domainが含まれている必要があります。
トランザクションフロー
実装自体はいくつかのステップで構成されます:- Ledger上のEthereumアプリを使用して署名するためのトランザクションを準備する
- Ledger上でトランザクションを準備して署名する
- ブロードキャスト用のトランザクションを準備する
- トランザクションをブロードキャストする
トランザクションの準備(署名用)
前述のとおり、トランザクションはLedger上のEthereumアプリを使用して署名する必要があります。これは、署名段階に到達したら、ユーザーにLedger上のEthereumアプリへ切り替える(または開く)よう促す必要があることを意味します。 各Cosmosトランザクションは、ユーザーがチェーン上で実行したい命令を表すメッセージで構成されることがわかっています。あるアドレスから別のアドレスに資金を送りたい場合は、MsgSendメッセージをトランザクションにパックし、チェーンにブロードキャストします。
これを踏まえて、Injectiveチームはこれらのメッセージの抽象化を作成し、トランザクションへのパック方法を簡略化しました。各メッセージは、メッセージをインスタンス化するために必要な特定のパラメータセットを受け取ります。これが完了すると、抽象化は選択した署名/ブロードキャスト方法に基づいて使用できる便利なメソッドをいくつか公開します。例えば、MessageはtoDirectSignメソッドを公開しており、これによりメッセージの型とproto表現が返され、デフォルトのCosmosアプローチを使用してトランザクションをパック、privateKeyで署名、チェーンにブロードキャストできます。
この特定の実装で重要なのは、toEip712TypesとtoEip712メソッドです。最初のものをMessageのインスタンスで呼び出すと、EIP712 typed dataのMessageの型が返され、2つ目はEIP712 dataのMessageの値を返します。これら2つのメソッドを組み合わせることで、署名プロセスに渡せる有効なEIP712 typed dataを生成できます。
これらのメソッドの使用例と、メッセージからEIP712 typedDataを生成する方法のコードスニペットを見てみましょう:
Ledger上の署名プロセスの準備
eip712TypedDataが手に入ったので、Ledgerを使用して署名する必要があります。まず、ブラウザでサポートされているLedgerのtransportを取得し、@ledgerhq/hw-app-ethを使用してそのtransportを持つLedgerインスタンスを作成し、ユーザーのアクション(トランザクションの確認)の実行にLedgerデバイス上のEthereumアプリを使用させます。ステップ1でeip712TypedDataを取得した後、EthereumApp上のsignEIP712HashedMessageを使用してこのtypedDataに署名し、署名を返します。
ブロードキャスト用のトランザクションを準備する
署名が手に入ったので、デフォルトのCosmosアプローチを使用してトランザクションを準備できます。トランザクションのブロードキャスト
トランザクションがTxRawにパックされたので、デフォルトのCosmosアプローチを使用してノードへブロードキャストできます。
