本文へスキップ
このページは英語からの機械翻訳を使用しており、誤りや不明瞭な表現が含まれている可能性があります。最も正確な情報については、オリジナルの英語版をご覧ください。頻繁な更新のため、一部のコンテンツはオリジナルの英語になっている可能性があります。Crowdinでの取り組みに参加して、このページの翻訳改善にご協力ください。 (Crowdin translation page, Contributing guide)

価値移転メモ

TxTypeValueTransferMemoは、ユーザーがKAIAに特定のメッセージを送りたいときに使用する。

web3 と @kaiachain/web3js-ext パッケージをインポートして、web3 に Kaia の機能を追加します。

senderfee payerのアドレスと秘密鍵を定義する。

指定されたkairos testnet URLでプロバイダを設定します。 Web3 のプロバイダーは、ブロックチェーンデータにアクセスするための読み取り専用の抽象です。

また、プロバイダのURLをkairosからquicknodeに変更することができます。

web3.eth.account.privateKeyToAccountを使用して、秘密鍵で送信者のウォレットを作成する。

web3.eth.account.privateKeyToAccountを使用して、秘密鍵で料金支払者のウォレットを作成する。

トランザクションオブジェクトを定義する。

手数料支払者付きのメモ付き価値転送トランザクションを送信するために、type: TxType.FeeDelegatedValueTransferMemo を設定します。

value:toPeb("0.01")を設定して転送する値を定義し、toPebを使用してKlayをPebに変換する。

データを設定する:"0x1234567890"` を設定して、トランザクションに付随するメモの値を定義する。

fromtoなどのパラメータを設定する。

signTransactionを使ってsenderアカウントでトランザクションに署名する。

signTransactionAsFeePayerを使用して、fee payerアカウントでトランザクションに署名する。

トランザクションをブロックチェーンに送信する。 取引レシートを返します。

TxTypeFeeDelegatedValueTransferMemo.js

const { Web3, TxType, toPeb } = require("@kaiachain/web3js-ext");
const senderAddr = "0xa2a8854b1802d8cd5de631e690817c253d6a9153";
const senderPriv = "0x0e4ca6d38096ad99324de0dde108587e5d7c600165ae4cd6c2462c597458c2b8";
const feePayerPriv = "0x9435261ed483b6efa3886d6ad9f64c12078a0e28d8d80715c773e16fc000cff4";
const recieverAddr = "0xc40b6909eb7085590e1c26cb3becc25368e249e9";
const provider = new Web3.providers.HttpProvider("https://public-en-kairos.node.kaia.io");
const web3 = new Web3(provider);
const senderAccount = web3.eth.accounts.privateKeyToAccount(senderPriv);
const feePayerAccount = web3.eth.accounts.privateKeyToAccount(feePayerPriv);
async function main() {
const tx = {
type: TxType.FeeDelegatedValueTransferMemo,
from: senderAddr,
to: recieverAddr,
value: toPeb("0.01"),
data: "0x1234567890",
};
// Sign transaction by sender
const signResult1 = await senderAccount.signTransaction(tx);
console.log("senderTxHashRLP", signResult1.rawTransaction);
// Sign and send transaction by fee payer
const signResult2 = await feePayerAccount.signTransactionAsFeePayer(signResult1.rawTransaction);
console.log("signedTx", signResult2.transactionHash);
const receipt = await web3.eth.sendSignedTransaction(signResult2.rawTransaction);
console.log("receipt", receipt);
}
main();

output

❯ node TxTypeFeeDelegatedValueTransferMemo.js
senderTxHashRLP 0x11f88d8203b7850ba43b740082d1f694c40b6909eb7085590e1c26cb3becc25368e249e9872386f26fc1000094a2a8854b1802d8cd5de631e690817c253d6a9153851234567890f847f8458207f5a0fbd13725c0e913f564469d43e6e928514caca92ca5d5fcc18c493445d2bd3f00a065980c9c0ea0bcfa4324c23b21d45acaa8a64d1d47d45a6730774756be794e86
signedTx 0xb17d3bc44eb466cf0870926eb4b7a8e90a3ca348df1e32227ab1eaf2bd7f98c8
receipt {
blockHash: '0x51586607f9d282deede4a9325d6ecdb2abb675fca0350ac6778549f2e7bfed73',
blockNumber: 148744817n,
cumulativeGasUsed: 31500n,
effectiveGasPrice: 25000000000n,
from: '0xa2a8854b1802d8cd5de631e690817c253d6a9153',
gasUsed: 31500n,
logs: [],
logsBloom: '0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000',
status: 1n,
to: '0xc40b6909eb7085590e1c26cb3becc25368e249e9',
transactionHash: '0xb17d3bc44eb466cf0870926eb4b7a8e90a3ca348df1e32227ab1eaf2bd7f98c8',
transactionIndex: 0n,
type: 0n
}

ページを改善してください。