基於角色的賬戶密鑰
AccountKeyRoleBased 表示基於角色的密鑰。 如果賬戶有一個基於賬戶密鑰角色的對象,且交易類型為除賬戶更新外的,那麼驗證過程將根據每個角色進行,如下所示:
導入**@kaiachain/web3js-ext**軟件包,在 web3 上添加 kaia 功能
定義要更改的發件人地址、發件人私人密鑰和新的基於角色的私人密鑰
使用指定的 kairos 測試網 URL 設置提供程序。 web3js 中的提供者是訪問區塊鏈數據的只讀抽象。
此外,您還可以將提供商 URL 從 kairos 更改為 quicknode
使用提供程序定義Web3 實例
使用更新者角色私鑰和提供者創建發送者錢包
根據新的role-based私鑰計算public keys
在** keys字段中使用計算出的基於role-based public keys**聲 明一個事務
用發件人的錢包簽署交易
向區塊鏈發送已簽名的 tx。 它將返回交易的收據
AccountUpdateWithRoleBased.js
const { Web3, TxType, AccountKeyType, getPublicKeyFromPrivate } = require("@kaiachain/web3js-ext");const senderAddr = "0x334b4d3c775c45c59de54e9f0408cba25a1aece7";const senderRoleTransactionPriv = "0xc9668ccd35fc20587aa37a48838b48ccc13cf14dd74c8999dd6a480212d5f7ac";const senderRoleAccountUpdatePriv = "0x9ba8cb8f60044058a9e6f815c5c42d3a216f47044c61a1750b6d29ddc7f34bda";const senderRoleFeePayerPriv = "0x0e4ca6d38096ad99324de0dde108587e5d7c600165ae4cd6c2462c597458c2b8";const provider = new Web3.providers.HttpProvider("https://public-en-kairos.node.kaia.io");const web3 = new Web3(provider);const updaterAccount = web3.eth.accounts.privateKeyToAccount(senderRoleAccountUpdatePriv);async function main() { const pub1 = getPublicKeyFromPrivate(senderRoleTransactionPriv); const pub2 = getPublicKeyFromPrivate(senderRoleAccountUpdatePriv); const pub3 = getPublicKeyFromPrivate(senderRoleFeePayerPriv); console.log({ pub1, pub2, pub3 }); const tx = { type: TxType.AccountUpdate, from: senderAddr, gasLimit: 100_000, key: { type: AccountKeyType.RoleBased, keys: [ { type: AccountKeyType.Public, key: pub1 }, // RoleTransaction { type: AccountKeyType.Public, key: pub2 }, // RoleAccountUpdate { type: AccountKeyType.Public, key: pub3 }, // RoleFeePayer ] } }; const signResult = await updaterAccount.signTransaction(tx); console.log("signedTx", signResult.transactionHash); const receipt = await web3.eth.sendSignedTransaction(signResult.rawTransaction); console.log("receipt", receipt);}main().catch(console.error);
output
❯ js AccountUpdateWithRoleBased.js{ pub1: '0x03f26489914098c5da51f0f646e3000da4d6197217df082b4f7ce1530f0a0cbf2a', pub2: '0x0263021199702b9fefca617bdcb2a9ed4a810dfa8d270d4e804a1e778450e63ec3', pub3: '0x03dc9dccbd788c00fa98f7f4082f2f714e799bc0c29d63f04d48b54fe6250453cd'}sentTx 0xcb8e1fc03088f2a00d44c31ce1c5f4913d3cf11403d60014a245ae44aa4c2a2freceipt { to: '0x5bD2fb3c21564C023A4A735935a2B7A238C4cCEA', from: '0x5bD2fb3c21564C023A4A735935a2B7A238C4cCEA', contractAddress: null, transactionIndex: 1, gasUsed: BigNumber { _hex: '0x013c68', _isBigNumber: true }, logsBloom: '0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000', blockHash: '0xb9145a53ef85bc4b375de828d9c3387cadc6bcd8f81a8d8eaf4f0331a2d7a5c0', transactionHash: '0xcb8e1fc03088f2a00d44c31ce1c5f4913d3cf11403d60014a245ae44aa4c2a2f', logs: [], blockNumber: 152203576, confirmations: 2, cumulativeGasUsed: BigNumber { _hex: '0x0377d6', _isBigNumber: true }, effectiveGasPrice: BigNumber { _hex: '0x05d21dba00', _isBigNumber: true }, status: 1, type: 0, byzantium: true}