# wallet_propose [[ソース]](https://github.com/XRPLF/rippled/blob/master/src/ripple/rpc/handlers/WalletPropose.cpp) `wallet_propose`メソッドを使用して、キーペアとXRP Ledgerアドレスを生成します。このコマンドは単にキーとアドレス値を生成し、XRP Ledger自体には何ら影響しません。レジャー上で資金供給済みのアドレスになるには、そのアドレスで、[必要準備金](/ja/docs/concepts/accounts/reserves)を満たすのに十分なXRPの[Paymentトランザクションを受け取る](/ja/docs/concepts/accounts#%E3%82%A2%E3%82%AB%E3%82%A6%E3%83%B3%E3%83%88%E3%81%AE%E4%BD%9C%E6%88%90)必要があります。 *`wallet_propose`メソッドは、権限のないユーザは実行できない[管理メソッド](/ja/docs/references/http-websocket-apis/admin-api-methods)です。*(このコマンドは、アカウントの機密情報を求めてネットワーク上の伝送情報をスニッフィングする人々から守るためにadminコマンドとされています。adminコマンドは通常、外部ネットワーク上で伝送されることはありません。) 更新: rippled 0.31.0 ### リクエストのフォーマット リクエストのフォーマットの例: WebSocket(キータイプあり) ```json { "command": "wallet_propose", "seed": "snoPBrXtMeMyMHUVTgbuqAfg1SUTb", "key_type": "secp256k1" } ``` WebSocket(キータイプなし) ```json { "command": "wallet_propose", "passphrase": "masterpassphrase" } ``` JSON-RPC(キータイプあり) ```json { "method": "wallet_propose", "params": [ { "seed": "snoPBrXtMeMyMHUVTgbuqAfg1SUTb", "key_type": "secp256k1" } ] } ``` JSON-RPC(キータイプなし) ```json { "method": "wallet_propose", "params": [ { "passphrase": "snoPBrXtMeMyMHUVTgbuqAfg1SUTb" } ] } ``` コマンドライン ```sh #Syntax: wallet_propose [passphrase] rippled wallet_propose masterpassphrase ``` リクエストには以下のパラメーターを含めることができます。 | `Field` | 型 | 説明 | | --- | --- | --- | | `key_type` | 文字列 | このキーペアの導出に使用する[署名アルゴリズム](/ja/docs/concepts/accounts/cryptographic-keys#%E7%BD%B2%E5%90%8D%E3%82%A2%E3%83%AB%E3%82%B4%E3%83%AA%E3%82%BA%E3%83%A0)。有効な値は`ed25519`と`secp256k1`(すべて小文字)です。デフォルトは`secp256k1`です。 | | `passphrase` | 文字列 | *(省略可)* このシード値からキーペアとアドレスを生成します。この値は、[16進数](https://en.wikipedia.org/wiki/Hexadecimal)、XRP Ledgerの[base58](/ja/docs/references/protocol/data-types/base58-encodings)フォーマット、[RFC-1751](https://tools.ietf.org/html/rfc1751)、または任意の文字列でフォーマットできます。`seed`または`seed_hex`とともに使用することはできません。 | | `seed` | 文字列 | *(省略可能)* このシード値からXRP Ledgerの[base58](/ja/docs/references/protocol/data-types/base58-encodings)エンコードフォーマットでキーペアとアドレスを生成します。`passphrase`または`seed_hex`とともに使用することはできません。 | | `seed_hex` | 文字列 | *(省略可能)* このシード値から[16進数](https://en.wikipedia.org/wiki/Hexadecimal)形式でキーペアとアドレスを生成します。`passphrase`または`seed`とともに使用することはできません。 | 以下のフィールドのうち**1つ**を指定する必要があります。`passphrase`、`seed`、または`seed_hex`。3つすべてを省略すると、`rippled`によってランダムシードが使用されます。 このコマンドのコマンドラインバージョンでは[Ed25519](https://ed25519.cr.yp.to/)キーを生成できません。 #### シードの指定 ほとんどの場合、強力な乱数ソースから生成されたシード値を使用する必要があります。あるアドレスのシード値を知っている人は、[そのアドレスで署名されたトランザクションを送信する](/ja/docs/concepts/transactions#%E3%83%88%E3%83%A9%E3%83%B3%E3%82%B6%E3%82%AF%E3%82%B7%E3%83%A7%E3%83%B3%E3%81%AE%E6%89%BF%E8%AA%8D)すべての権限を持っています。一般的に、ランダムシードの生成には、このコマンドにパラメーターを指定しないで実行する方法が適しています。 以下の場合には、既知のシードを指定します。 * アドレスに関連するシードのみを知っていて、アドレスを再計算する * `rippled`の機能をテストする シードは、以下のどのフォーマットでも指定できます。 * XRP Ledgerの[base58](/ja/docs/references/protocol/data-types/base58-encodings)フォーマットのシークレットキー文字列。例: `snoPBrXtMeMyMHUVTgbuqAfg1SUTb`。 * [RFC-1751](https://tools.ietf.org/html/rfc1751)フォーマット文字列(secp256k1キーペアのみ)。例: `I IRE BOND BOW TRIO LAID SEAT GOAL HEN IBIS IBIS DARE`。 * 128ビットの[16進数](https://en.wikipedia.org/wiki/Hexadecimal)文字列。例: `DEDCE9CE67B451D852FD4E846FCDE31C`。 * シード値として使用する任意の文字列。例: `masterpassphrase`。 ### レスポンスのフォーマット 処理が成功したレスポンスの例: WebSocket ```json { "id": 2, "status": "success", "type": "response", "result": { "account_id": "rHb9CJAWyB4rj91VRWn96DkukG4bwdtyTh", "key_type": "secp256k1", "master_key": "I IRE BOND BOW TRIO LAID SEAT GOAL HEN IBIS IBIS DARE", "master_seed": "snoPBrXtMeMyMHUVTgbuqAfg1SUTb", "master_seed_hex": "DEDCE9CE67B451D852FD4E846FCDE31C", "public_key": "aBQG8RQAzjs1eTKFEAQXr2gS4utcDiEC9wmi7pfUPTi27VCahwgw", "public_key_hex": "0330E7FC9D56BB25D6893BA3F317AE5BCF33B3291BD63DB32654A313222F7FD020" } } ``` JSON-RPC ```json { "result": { "account_id": "rHb9CJAWyB4rj91VRWn96DkukG4bwdtyTh", "key_type": "secp256k1", "master_key": "I IRE BOND BOW TRIO LAID SEAT GOAL HEN IBIS IBIS DARE", "master_seed": "snoPBrXtMeMyMHUVTgbuqAfg1SUTb", "master_seed_hex": "DEDCE9CE67B451D852FD4E846FCDE31C", "public_key": "aBQG8RQAzjs1eTKFEAQXr2gS4utcDiEC9wmi7pfUPTi27VCahwgw", "public_key_hex": "0330E7FC9D56BB25D6893BA3F317AE5BCF33B3291BD63DB32654A313222F7FD020", "status": "success" } } ``` コマンドライン ```json Loading: "/etc/rippled.cfg" Connecting to 127.0.0.1:5005 { "result" : { "account_id" : "rHb9CJAWyB4rj91VRWn96DkukG4bwdtyTh", "key_type" : "secp256k1", "master_key" : "I IRE BOND BOW TRIO LAID SEAT GOAL HEN IBIS IBIS DARE", "master_seed" : "snoPBrXtMeMyMHUVTgbuqAfg1SUTb", "master_seed_hex" : "DEDCE9CE67B451D852FD4E846FCDE31C", "public_key" : "aBQG8RQAzjs1eTKFEAQXr2gS4utcDiEC9wmi7pfUPTi27VCahwgw", "public_key_hex" : "0330E7FC9D56BB25D6893BA3F317AE5BCF33B3291BD63DB32654A313222F7FD020", "status" : "success" } } ``` レスポンスは[標準フォーマット](/ja/docs/references/http-websocket-apis/api-conventions/response-formatting)に従い、正常に終了した場合、新しい(可能性がある)アカウントについての重要な各種情報を含みます。以下のフィールドを含みます。 | `Field` | 型 | 説明 | | --- | --- | --- | | `key_type` | 文字列 | このキーペアの導出に使用された[署名アルゴリズム](/ja/docs/concepts/accounts/cryptographic-keys#%E7%BD%B2%E5%90%8D%E3%82%A2%E3%83%AB%E3%82%B4%E3%83%AA%E3%82%BA%E3%83%A0)。有効な値は`ed25519`と`secp256k1`(すべて小文字)です。 | | `master_seed` | 文字列 | これはキーペアの秘密鍵です。このアカウントに関するその他のあらゆる情報が、マスターシードからXRP Ledgerの[base58](/ja/docs/references/protocol/data-types/base58-encodings)エンコード文字列フォーマットで引き出されます。通常、このフォーマットのキーを使用してトランザクションに署名します。 | | `master_seed_hex` | 文字列 | 16進数形式のマスターシード。単純で広く支持されている秘密鍵表示法。トランザクションの署名に使用できます。 | | `master_key` | 文字列 | **廃止予定** [RFC-1751](https://tools.ietf.org/html/rfc1751)形式のマスターシード。覚えやすく書き留めやすい秘密鍵。トランザクションの署名に使用できます。**注記:** `rippled`の実装では、RFC-1751からデコードした後、RFC-1751にエンコードする前に、キーのバイト順序が逆になります。別のRFC-1751実装を使用して、XRP Ledgerで使用するキーの読み書きを行う場合は、同様にして、`rippled`のRFC-1751エンコーディングとの互換性を保つ必要があります。 | | `account_id` | 文字列 | XRP Ledgerの[base58](/ja/docs/references/protocol/data-types/base58-encodings)フォーマットで作成されたアカウントの[アドレス](/ja/docs/references/protocol/data-types/basic-data-types#%E3%82%A2%E3%83%89%E3%83%AC%E3%82%B9)。これは公開鍵ではありませんが、公開鍵を2回ハッシュ化したものです。チェックサムも持っているため、タイプミスした場合はほぼ間違いなく無効なアドレスとみなされ、有効だが異なるアドレスとはみなされません。これはXRP LedgerのアカウントのプライマリIDです。支払いを受けるときにこれを人に伝えたり、トランザクションにおいて、自身や、支払先、委託先識別するのに使用します。[マルチシグリスト](/ja/docs/concepts/accounts/multi-signing)でもこれを使用して、他の署名者を識別します。 | | `public_key` | 文字列 | XRP Ledgerの[base58](/ja/docs/references/protocol/data-types/base58-encodings)エンコード文字列フォーマットで作成された、キーペアの公開鍵。`master_seed`から生成されます。 | | `public_key_hex` | 文字列 | これは16進数で作成されたキーペアの公開鍵です。`master_seed`から生成されます。トランザクションの署名を検証する場合、`rippled`にはこの公開鍵が必要です。そのため、署名されたトランザクションのフォーマットの`SigningPubKey`フィールドには公開鍵が入力されています。 | | `warning` | 文字列 | (削除される可能性あり)リクエストにシード値を指定した場合、このフィールドに安全でない可能性があるという警告が表示されます。新規: rippled 0.32.0 | このメソッドを使用してキーペアを生成し、アカウントのレギュラーキーペアとして使用することもできます。アカウントにレギュラーキーペアを割り当てて、それを使用してほとんどのトランザクションに署名し、マスターキーペアをできるだけオフラインにしておくことも可能です。 レギュラーキーペアとして使用するほかに、マルチシグのリスト(SignerList)のメンバーとして使用することもできます。 マスターキーペアとレギュラーキーペアの詳細は、[暗号鍵](/ja/docs/concepts/accounts/cryptographic-keys)をご覧ください。 マルチシグの詳細は、[マルチシグ](/ja/docs/concepts/accounts/multi-signing)をご覧ください。 ### 考えられるエラー * いずれかの[汎用エラータイプ](/ja/docs/references/http-websocket-apis/api-conventions/error-formatting#%E6%B1%8E%E7%94%A8%E3%82%A8%E3%83%A9%E3%83%BC)。 * `invalidParams` - 1つ以上のフィールドが不正に指定されています。 * `badSeed` - リクエストには、空の文字列やXRP Ledgerアドレスに似た文字列などの許可されないシード値が(`passphrase`、`seed`、または`seed_hex`フィールド内に)指定されています。