Migration to 11.0.0
This guide describes all breaking changes introduced with v11.0.0
.
Changes to decodeEvents
method
- Removed
decodeEvents
from contract ACI methods (a84d781).
rewrite
cInstance.methods.emitEvents.decodeEvents(log)
cInstance.decodeEvents(log)
-
Removed raw fields from the
decodeEvents
response (45bae5f) use processed fields for the same. -
Renamed decoded events response field
decoded
toargs
old response
// events emitted by contract calls are automatically decoded
const tx = await contractInstance.methods.emitEvents(1337, "this message is not indexed")
console.log(tx.decodedEvents)
/*
[
{
address: 'ct_6y3N9KqQb74QsvR9NrESyhWeLNiA9aJgJ7ua8CvsTuGot6uzh',
data: 'cb_dGhpcyBtZXNzYWdlIGlzIG5vdCBpbmRleGVkdWmUpw==',
topics: [
'101640830366340000167918459210098337687948756568954742276612796897811614700269',
'39519965516565108473327470053407124751867067078530473195651550649472681599133'
],
name: 'AnotherEvent',
decoded: [
'fUq2NesPXcYZ1CcqBcGC3StpdnQw3iVxMA3YSeCNAwfN4myQk',
'this message is not indexed'
]
},
{
address: 'ct_6y3N9KqQb74QsvR9NrESyhWeLNiA9aJgJ7ua8CvsTuGot6uzh',
data: 'cb_Xfbg4g==',
topics: [
'59505622142252318624300825714684802559980671551955787864303522023309554554980',
1337
],
name: 'FirstEvent',
decoded: [ '1337' ]
}
]
*/
// events emitted by contract calls are automatically decoded
const tx = await contractInstance.methods.emitEvents(1337, "this message is not indexed")
console.log(tx.decodedEvents)
/*
[
{
name: 'AnotherEvent',
args: [
'fUq2NesPXcYZ1CcqBcGC3StpdnQw3iVxMA3YSeCNAwfN4myQk',
'this message is not indexed'
],
contract: {
name: 'EventEmitter',
address: 'ct_6y3N9KqQb74QsvR9NrESyhWeLNiA9aJgJ7ua8CvsTuGot6uzh'
}
},
{
name: 'FirstEvent',
args: [1337n],
contract: {
name: 'EventEmitter',
address: 'ct_6y3N9KqQb74QsvR9NrESyhWeLNiA9aJgJ7ua8CvsTuGot6uzh'
}
}
]
*/
Removed allowUnsynced
option of poll
method (6baa15d)
Transaction poll
method now checks if Tx is in the node pool (690db5b)
The default polling interval of 5000
is replaced by a method which calculates the default interval using expected mine rate and micro block cycle (d9c6cf9)
Following contract instance methods are dropped(#1368)
topBlock
- use
aeSdk.api.getTopHeader()
instead
- use
contractCall
- replace
await aeSdk.contractCall(identityContract, contractId, 'getArg', [42])
- with
(await aeSdk.getContractInstance({ source, contractAddress: contractId })).methods.getArg(42)
- replace
contractCompile
- replace
await aeSdk.contractCompile(CONTRACT_SOURCE)
- with
(await aeSdk.getContractInstance({ source: CONTRACT_SOURCE })).compile()
- replace
contractDeploy
- replace
await aeSdk.contractDeploy(bytecode, identityContract)
- with
(await aeSdk.getContractInstance({ bytecode, source: identityContract })).deploy()
- replace
contractCallStatic
- replace
await aeSdk.contractCallStatic(identityContract, null, 'init', [], { bytecode })
- with
await contract.deploy([], { callStatic: true })
- replace
- Removed property
createdAt
fromcontract.deploy
method response call/callStatic
- removed
call
andcallStatic
methods from deploy response
- removed
rewrite
deployed = await contract.deploy([], { onAccount })
await deployed.call('getArg', [42])
await deployed.callStatic('getArg', [42])
await contract.deploy()
await contract.methods.getArg(42, { callStatic: false })
await contract.methods.getArg(42, { callStatic: true })
The default gas
of 25000 limit has been dropped. Instead, SDK attempts to estimate the gas using dry-run feature (#1367)
See documentation on transaction-options.md for detailed explanation.
Removed Wrappers around CompilerApi
(#1363)
-
Removed
getBytecodeCompilerVersion
method. -
Removed
encodeCall
method fromcontractCompile
response. -
Removed
getCompilerVersion
method, useaeSdk. sdk.compilerVersion
instead. -
Removed
contractDecodeCallDataByCodeAPI
method. -
Removed
contractDecodeCallResultAPI
method. -
Removed
getFateAssembler
method. -
Removed
compileContractAPI
method.
rewrite
const code = await aeSdk.compileContractAPI(identityContract)
const callData = await aeSdk.contractEncodeCallDataAPI(identityContract, 'init', [])
const result = await initiatorCh.createContract({
code,
callData,
deposit: 1000,
vmVersion: 5,
abiVersion: 3,
amount,
gas,
gasPrice,
})
contract = await aeSdk.getContractInstance({ source: contractSource })
await contract.compile()
const result = await aeSdk.createContract({
code: contract.bytecode,
callData: contract.calldata.encode('Identity', 'init', []),
deposit: 1000,
vmVersion: 5,
abiVersion: 3,
amount,
gas,
gasPrice,
})
//or
bytecode = (await aeSdk.compilerApi.compileContract({ code: contractSource })).bytecode
- Removed
contractEncodeCallDataAPI
:
rewrite
await aeSdk.contractEncodeCallDataAPI(contractSource, 'getArg', ['42'])
contract = await aeSdkInitiator.getContractInstance({ source: contractSource })
await contract.compile()
contract.calldata.encode('Identity', 'getArg', [42])
- Removed
contractGetACI
:
rewrite
const aci = await aeSdk.contractGetACI(contractSource)
const aci = await aeSdk.compilerApi.generateACI({ code: contractSource })
- Removed
validateByteCodeAPI
:
rewrite
aeSdk.validateByteCodeAPI(bytecode, identityContract)
await aeSdk.compilerApi.validateByteCode({ bytecode, source: identityContract })
Native build of claim tx now accepts unencoded name
instead of encoded name (eea92be)
rewrite
const name = 'test123test.chain'
const nameHash = `nm_${encodeBase58Check(Buffer.from(name))}`
const params = { accountId: senderId, nonce, name: nameHash, nameSalt: _salt, nameFee }
const txFromAPI = await aeSdk.nameClaimTx(params)
const name = 'test123test.chain'
const params = { accountId: senderId, nonce, name, nameSalt: _salt, nameFee }
const txFromAPI = await aeSdk.nameClaimTx(params)
Removed forceValidation
flag from aepp-rpc
and wallet-rpc
stamps. (9f958c3)
Renamed hd-wallet
methods (f6243ad)
- Renamed
generateSaveHDWallet
togenerateSaveHDWalletFromSeed
- Renamed
getHdWalletAccountFromMnemonic
togetHdWalletAccountFromSeed