Skip to main content

Legacy Account Key

AccountKeyLegacy

Import extend from web3py_ext to extend web3 to kaia web3

Import necessary utils from eth_account, web3py_ext and cytools

Create a Web3 instance with the specified kaia Baobab testnet URL

Also, you can change the provider URL from baobab to allthatnode.

Load an account from private key

Creating an empty transaction of type TxType.ACCOUNT_UPDATE. You can use empty_tx util to get a tx with default fields filled.

Merge additional fields like sender and keys into the empty tx by using the merge util.

In this case, the account key to update is the legacy key.

Use fill_transaction to add more params to transaction object like gas limit...

You can use the to_pretty util to print the formatted tx.

Sign the account update tx type. You must sign it with the loaded account

Sending the signed transaction to the network and waiting receipt until it is completely executed in the blockchain

web3_account_update_legacy.py

from web3py_ext import extend
from web3 import Web3
from eth_account import Account
from web3py_ext.klaytn_account.utils import compressed_key
from web3py_ext.klaytn_account.account_key import KeyType
from web3py_ext.transaction.transaction import (
empty_tx,
fill_transaction,
TxType
)
from web3py_ext.utils.klaytn_utils import (
to_pretty,
bytes_to_hex_str
)
from cytoolz import merge
w3 = Web3(Web3.HTTPProvider(
'https://public-en-kairos.node.kaia.io'
))
def web3_account_update_legacy():
user = Account.from_key('0x0e4ca6d38096ad99324de0dde108587e5d7c600165ae4cd6c2462c597458c2b8')
account_update_tx = empty_tx(TxType.ACCOUNT_UPDATE)
account_update_tx = merge(account_update_tx, {
'from' : user.address,
'key' : {
'type': KeyType.LEGACY,
'key': {}
}
})
account_update_tx = fill_transaction(account_update_tx, w3)
print(to_pretty(account_update_tx))
# sign the kaia specific transaction type with web3py
signed_tx = Account.sign_transaction(account_update_tx, user.key)
print('\nrawTransaction:', bytes_to_hex_str(signed_tx.rawTransaction))
tx_hash = w3.eth.send_raw_transaction(signed_tx.rawTransaction)
tx_receipt = w3.eth.wait_for_transaction_receipt(tx_hash)
print('tx hash: ', tx_hash, 'receipt: ', tx_receipt)
web3_account_update_legacy()

output

❯ py web3_account_update_legacy.py
# {
# "from": "0xA2a8854b1802D8Cd5De631E690817c253d6a9153",
# "gas": 159000,
# "gasPrice": 50000000000,
# "nonce": 990,
# "chainId": 1001,
# "type": 32,
# "key": {
# "type": 1,
# "key": "0x03dc9dccbd788c00fa98f7f4082f2f714e799bc0c29d63f04d48b54fe6250453cd"
# }
# }
# rawTransaction: 20f86e8203de850ba43b740083026d1894a2a8854b1802d8cd5de631e690817c253d6a91538201c0f847f8458207f5a0a37fa3b1882109cab6d565b869d217a80bae7ac6dd1b8361729f81925520d48ca0049b1ebfbe19a7b57d8ff0ea965581f6b02c4b5ac0c08b3c1925e030d05d1444
# tx hash: 0x2e1b5ccc12057297db5bac624085532e302ff75b20fb36fe3728efe7a7904ef1 receipt: AttributeDict({'blockHash': HexBytes('0xbb9fc21ef1793f4c03492e2293dfdcc6d4392cd40a781a33fbebf96bbf032490'), 'blockNumber': 150553739, 'contractAddress': None, 'cumulativeGasUsed': 21000, 'effectiveGasPrice': 25000000000, 'from': '0xA2a8854b1802D8Cd5De631E690817c253d6a9153', 'gasUsed': 21000, 'logs': [], 'logsBloom': HexBytes('0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000'), 'status': 1, 'to': '0xA2a8854b1802D8Cd5De631E690817c253d6a9153', 'transactionHash': HexBytes('0x2e1b5ccc12057297db5bac624085532e302ff75b20fb36fe3728efe7a7904ef1'), 'transactionIndex': 0, 'type': 0})