diff --git a/src/transactionsFactories/delegationTransactionsFactory.ts b/src/transactionsFactories/delegationTransactionsFactory.ts index a77ecacc..9e389ab6 100644 --- a/src/transactionsFactories/delegationTransactionsFactory.ts +++ b/src/transactionsFactories/delegationTransactionsFactory.ts @@ -6,6 +6,7 @@ import { Address } from "../address"; import { DELEGATION_MANAGER_SC_ADDRESS } from "../constants"; import { Err } from "../errors"; import { TransactionNext } from "../transaction"; + interface Config { chainID: string; minGasLimit: BigNumber.Value; @@ -18,14 +19,18 @@ interface Config { additionalGasLimitPerValidatorNode: BigNumber.Value; additionalGasLimitForDelegationOperations: BigNumber.Value; } + interface IValidatorPublicKey { hex(): string; } + export class DelegationTransactionsFactory { private readonly config: Config; + constructor(config: Config) { this.config = config; } + createTransactionForNewDelegationContract(options: { sender: IAddress; totalDelegationCap: BigNumber.Value; @@ -37,9 +42,11 @@ export class DelegationTransactionsFactory { numberToPaddedHex(options.totalDelegationCap.toString()), numberToPaddedHex(options.serviceFee.toString()), ]; + const executionGasLimit = new BigNumber(this.config.gasLimitCreateDelegationContract).plus( this.config.additionalGasLimitForDelegationOperations, ); + return new TransactionNextBuilder({ config: this.config, sender: options.sender, @@ -50,6 +57,7 @@ export class DelegationTransactionsFactory { amount: options.amount, }).build(); } + createTransactionForAddingNodes(options: { sender: IAddress; delegationContract: IAddress; @@ -59,11 +67,14 @@ export class DelegationTransactionsFactory { if (options.publicKeys.length !== options.signedMessages.length) { throw new Err("The number of public keys should match the number of signed messages"); } + const numNodes = options.publicKeys.length; const dataParts = ["addNodes"]; + for (let i = 0; i < numNodes; i++) { dataParts.push(...[options.publicKeys[i].hex(), byteArrayToHex(options.signedMessages[i])]); } + return new TransactionNextBuilder({ config: this.config, sender: options.sender, @@ -73,15 +84,18 @@ export class DelegationTransactionsFactory { addDataMovementGas: true, }).build(); } + createTransactionForRemovingNodes(options: { sender: IAddress; delegationContract: IAddress; publicKeys: IValidatorPublicKey[]; }): TransactionNext { const dataParts = ["removeNodes"]; + for (const key of options.publicKeys) { dataParts.push(key.hex()); } + const numNodes = options.publicKeys.length; return new TransactionNextBuilder({ config: this.config, @@ -92,22 +106,27 @@ export class DelegationTransactionsFactory { addDataMovementGas: true, }).build(); } + createTransactionForStakingNodes(options: { sender: IAddress; delegationContract: IAddress; publicKeys: IValidatorPublicKey[]; }): TransactionNext { let dataParts = ["stakeNodes"]; + for (const key of options.publicKeys) { dataParts = dataParts.concat(key.hex()); } + const numNodes = options.publicKeys.length; const additionalGasForAllNodes = new BigNumber(numNodes).multipliedBy( this.config.additionalGasLimitPerValidatorNode, ); + const executionGasLimit = additionalGasForAllNodes .plus(this.config.gasLimitStake) .plus(this.config.gasLimitDelegationOperations); + return new TransactionNextBuilder({ config: this.config, sender: options.sender, @@ -117,20 +136,24 @@ export class DelegationTransactionsFactory { addDataMovementGas: true, }).build(); } + createTransactionForUnbondingNodes(options: { sender: IAddress; delegationContract: IAddress; publicKeys: IValidatorPublicKey[]; }): TransactionNext { let dataParts = ["unBondNodes"]; + for (const key of options.publicKeys) { dataParts = dataParts.concat(key.hex()); } + const numNodes = options.publicKeys.length; const executionGasLimit = new BigNumber(numNodes) .multipliedBy(this.config.additionalGasLimitPerValidatorNode) .plus(this.config.gasLimitUnbond) .plus(this.config.gasLimitDelegationOperations); + return new TransactionNextBuilder({ config: this.config, sender: options.sender, @@ -140,20 +163,24 @@ export class DelegationTransactionsFactory { addDataMovementGas: true, }).build(); } + createTransactionForUnstakingNodes(options: { sender: IAddress; delegationContract: IAddress; publicKeys: IValidatorPublicKey[]; }): TransactionNext { let dataParts = ["unStakeNodes"]; + for (const key of options.publicKeys) { dataParts = dataParts.concat(key.hex()); } + const numNodes = options.publicKeys.length; const executionGasLimit = new BigNumber(numNodes) .multipliedBy(this.config.additionalGasLimitPerValidatorNode) .plus(this.config.gasLimitUnstake) .plus(this.config.gasLimitDelegationOperations); + return new TransactionNextBuilder({ config: this.config, sender: options.sender, @@ -163,15 +190,18 @@ export class DelegationTransactionsFactory { addDataMovementGas: true, }).build(); } + createTransactionForUnjailingNodes(options: { sender: IAddress; delegationContract: IAddress; publicKeys: IValidatorPublicKey[]; }): TransactionNext { const dataParts = ["unJailNodes"]; + for (const key of options.publicKeys) { dataParts.push(key.hex()); } + const numNodes = options.publicKeys.length; return new TransactionNextBuilder({ config: this.config, @@ -182,104 +212,123 @@ export class DelegationTransactionsFactory { addDataMovementGas: true, }).build(); } + createTransactionForChangingServiceFee(options: { sender: IAddress; delegationContract: IAddress; serviceFee: BigNumber.Value; }): TransactionNext { const dataParts = ["changeServiceFee", numberToPaddedHex(options.serviceFee)]; + const gasLimit = new BigNumber(this.config.gasLimitDelegationOperations).plus( + this.config.additionalGasLimitForDelegationOperations, + ); + return new TransactionNextBuilder({ config: this.config, sender: options.sender, receiver: options.delegationContract, dataParts: dataParts, - gasLimit: new BigNumber(this.config.gasLimitDelegationOperations).plus( - this.config.additionalGasLimitForDelegationOperations, - ), + gasLimit: gasLimit, addDataMovementGas: true, }).build(); } + createTransactionForModifyingDelegationCap(options: { sender: IAddress; delegationContract: IAddress; delegationCap: BigNumber.Value; }): TransactionNext { const dataParts = ["modifyTotalDelegationCap", numberToPaddedHex(options.delegationCap)]; + const gasLimit = new BigNumber(this.config.gasLimitDelegationOperations).plus( + this.config.additionalGasLimitForDelegationOperations, + ); + return new TransactionNextBuilder({ config: this.config, sender: options.sender, receiver: options.delegationContract, dataParts: dataParts, - gasLimit: new BigNumber(this.config.gasLimitDelegationOperations).plus( - this.config.additionalGasLimitForDelegationOperations, - ), + gasLimit: gasLimit, addDataMovementGas: true, }).build(); } + createTransactionForSettingAutomaticActivation(options: { sender: IAddress; delegationContract: IAddress; }): TransactionNext { const dataParts = ["setAutomaticActivation", utf8ToHex("true")]; + const gasLimit = new BigNumber(this.config.gasLimitDelegationOperations).plus( + this.config.additionalGasLimitForDelegationOperations, + ); + return new TransactionNextBuilder({ config: this.config, sender: options.sender, receiver: options.delegationContract, dataParts: dataParts, - gasLimit: new BigNumber(this.config.gasLimitDelegationOperations).plus( - this.config.additionalGasLimitForDelegationOperations, - ), + gasLimit: gasLimit, addDataMovementGas: true, }).build(); } + createTransactionForUnsettingAutomaticActivation(options: { sender: IAddress; delegationContract: IAddress; }): TransactionNext { const dataParts = ["setAutomaticActivation", utf8ToHex("false")]; + const gasLimit = new BigNumber(this.config.gasLimitDelegationOperations).plus( + this.config.additionalGasLimitForDelegationOperations, + ); + return new TransactionNextBuilder({ config: this.config, sender: options.sender, receiver: options.delegationContract, dataParts: dataParts, - gasLimit: new BigNumber(this.config.gasLimitDelegationOperations).plus( - this.config.additionalGasLimitForDelegationOperations, - ), + gasLimit: gasLimit, addDataMovementGas: true, }).build(); } + createTransactionForSettingCapCheckOnRedelegateRewards(options: { sender: IAddress; delegationContract: IAddress; }): TransactionNext { const dataParts = ["setCheckCapOnReDelegateRewards", utf8ToHex("true")]; + const gasLimit = new BigNumber(this.config.gasLimitDelegationOperations).plus( + this.config.additionalGasLimitForDelegationOperations, + ); + return new TransactionNextBuilder({ config: this.config, sender: options.sender, receiver: options.delegationContract, dataParts: dataParts, - gasLimit: new BigNumber(this.config.gasLimitDelegationOperations).plus( - this.config.additionalGasLimitForDelegationOperations, - ), + gasLimit: gasLimit, addDataMovementGas: true, }).build(); } + createTransactionForUnsettingCapCheckOnRedelegateRewards(options: { sender: IAddress; delegationContract: IAddress; }): TransactionNext { const dataParts = ["setCheckCapOnReDelegateRewards", utf8ToHex("false")]; + const gasLimit = new BigNumber(this.config.gasLimitDelegationOperations).plus( + this.config.additionalGasLimitForDelegationOperations, + ); + return new TransactionNextBuilder({ config: this.config, sender: options.sender, receiver: options.delegationContract, dataParts: dataParts, - gasLimit: new BigNumber(this.config.gasLimitDelegationOperations).plus( - this.config.additionalGasLimitForDelegationOperations, - ), + gasLimit: gasLimit, addDataMovementGas: true, }).build(); } + createTransactionForSettingMetadata(options: { sender: IAddress; delegationContract: IAddress; @@ -293,21 +342,26 @@ export class DelegationTransactionsFactory { utf8ToHex(options.website), utf8ToHex(options.identifier), ]; + + const gasLimit = new BigNumber(this.config.gasLimitDelegationOperations).plus( + this.config.additionalGasLimitForDelegationOperations, + ); + return new TransactionNextBuilder({ config: this.config, sender: options.sender, receiver: options.delegationContract, dataParts: dataParts, - gasLimit: new BigNumber(this.config.gasLimitDelegationOperations).plus( - this.config.additionalGasLimitForDelegationOperations, - ), + gasLimit: gasLimit, addDataMovementGas: true, }).build(); } + private computeExecutionGasLimitForNodesManagement(numNodes: number): BigNumber.Value { const additionalGasForAllNodes = new BigNumber(this.config.additionalGasLimitPerValidatorNode).multipliedBy( numNodes, ); + return new BigNumber(this.config.gasLimitDelegationOperations).plus(additionalGasForAllNodes); } } diff --git a/src/transactionsFactories/relayedTransactionsFactory.spec.ts b/src/transactionsFactories/relayedTransactionsFactory.spec.ts index 50be725c..daa36d93 100644 --- a/src/transactionsFactories/relayedTransactionsFactory.spec.ts +++ b/src/transactionsFactories/relayedTransactionsFactory.spec.ts @@ -62,11 +62,11 @@ describe("test relayed v1 transaction builder", function () { assert.equal( Buffer.from(relayedTransaction.data).toString(), - "relayedTx@7b226e6f6e6365223a3139382c2273656e646572223a2267456e574f65576d6d413063306a6b71764d354241707a61644b46574e534f69417643575163776d4750673d222c227265636569766572223a22414141414141414141414141415141414141414141414141414141414141414141414141414141432f2f383d222c2276616c7565223a302c226761735072696365223a313030303030303030302c226761734c696d6974223a36303030303030302c2264617461223a225a3256305132397564484a68593352446232356d6157633d222c227369676e6174757265223a2272525455544858677a4273496e4f6e454b6b7869642b354e66524d486e33534948314673746f577352434c434b3258514c41614f4e704449346531476173624c5150616130566f364144516d4f2b52446b6f364a43413d3d222c22636861696e4944223a2256413d3d222c2276657273696f6e223a327d" + "relayedTx@7b226e6f6e6365223a3139382c2273656e646572223a2267456e574f65576d6d413063306a6b71764d354241707a61644b46574e534f69417643575163776d4750673d222c227265636569766572223a22414141414141414141414141415141414141414141414141414141414141414141414141414141432f2f383d222c2276616c7565223a302c226761735072696365223a313030303030303030302c226761734c696d6974223a36303030303030302c2264617461223a225a3256305132397564484a68593352446232356d6157633d222c227369676e6174757265223a2272525455544858677a4273496e4f6e454b6b7869642b354e66524d486e33534948314673746f577352434c434b3258514c41614f4e704449346531476173624c5150616130566f364144516d4f2b52446b6f364a43413d3d222c22636861696e4944223a2256413d3d222c2276657273696f6e223a327d", ); assert.equal( Buffer.from(relayedTransaction.signature).toString("hex"), - "128e7cdc14c2b9beee2f3ff7a7fa5d1f5ef31a654a0c92e223c90ab28265fa277d306f23a06536248cf9573e828017004fb639617fade4d68a37524aafca710d" + "128e7cdc14c2b9beee2f3ff7a7fa5d1f5ef31a654a0c92e223c90ab28265fa277d306f23a06536248cf9573e828017004fb639617fade4d68a37524aafca710d", ); }); @@ -96,11 +96,11 @@ describe("test relayed v1 transaction builder", function () { assert.equal( Buffer.from(relayedTransaction.data).toString(), - "relayedTx@7b226e6f6e6365223a3230382c2273656e646572223a227371455656633553486b6c45344a717864556e59573068397a536249533141586f3534786f32634969626f3d222c227265636569766572223a2241546c484c76396f686e63616d433877673970645168386b77704742356a6949496f3349484b594e6165453d222c2276616c7565223a313030303030303030303030303030303030302c226761735072696365223a313030303030303030302c226761734c696d6974223a35303030302c2264617461223a22222c227369676e6174757265223a226a33427a6469554144325963517473576c65707663664a6f75657a48573063316b735a424a4d6339573167435450512b6870636759457858326f6f367a4b5654347464314b4b6f79783841526a346e336474576c44413d3d222c22636861696e4944223a2256413d3d222c2276657273696f6e223a322c22736e64557365724e616d65223a22593246796232773d222c22726376557365724e616d65223a22595778705932553d227d" + "relayedTx@7b226e6f6e6365223a3230382c2273656e646572223a227371455656633553486b6c45344a717864556e59573068397a536249533141586f3534786f32634969626f3d222c227265636569766572223a2241546c484c76396f686e63616d433877673970645168386b77704742356a6949496f3349484b594e6165453d222c2276616c7565223a313030303030303030303030303030303030302c226761735072696365223a313030303030303030302c226761734c696d6974223a35303030302c2264617461223a22222c227369676e6174757265223a226a33427a6469554144325963517473576c65707663664a6f75657a48573063316b735a424a4d6339573167435450512b6870636759457858326f6f367a4b5654347464314b4b6f79783841526a346e336474576c44413d3d222c22636861696e4944223a2256413d3d222c2276657273696f6e223a322c22736e64557365724e616d65223a22593246796232773d222c22726376557365724e616d65223a22595778705932553d227d", ); assert.equal( Buffer.from(relayedTransaction.signature).toString("hex"), - "3787d640e5a579e7977a4a1bcdd435ad11855632fa4a414a06fbf8355692d1a58d76ef0adbdd6ccd6bd3c329f36bd53c180d4873ec1a6c558e659aeb9ab92d00" + "3787d640e5a579e7977a4a1bcdd435ad11855632fa4a414a06fbf8355692d1a58d76ef0adbdd6ccd6bd3c329f36bd53c180d4873ec1a6c558e659aeb9ab92d00", ); }); @@ -130,11 +130,11 @@ describe("test relayed v1 transaction builder", function () { assert.equal( Buffer.from(relayedTransaction.data).toString(), - "relayedTx@7b226e6f6e6365223a3230382c2273656e646572223a227371455656633553486b6c45344a717864556e59573068397a536249533141586f3534786f32634969626f3d222c227265636569766572223a2241546c484c76396f686e63616d433877673970645168386b77704742356a6949496f3349484b594e6165453d222c2276616c7565223a313939393939393030303030303030303030303030303030302c226761735072696365223a313030303030303030302c226761734c696d6974223a35303030302c2264617461223a22222c227369676e6174757265223a22594661677972512f726d614c7333766e7159307657553858415a7939354b4e31725738347a4f764b62376c7a3773576e2f566a546d68704378774d682b7261314e444832574d6f3965507648304f79427453776a44773d3d222c22636861696e4944223a2256413d3d222c2276657273696f6e223a322c22736e64557365724e616d65223a22593246796232773d222c22726376557365724e616d65223a22595778705932553d227d" + "relayedTx@7b226e6f6e6365223a3230382c2273656e646572223a227371455656633553486b6c45344a717864556e59573068397a536249533141586f3534786f32634969626f3d222c227265636569766572223a2241546c484c76396f686e63616d433877673970645168386b77704742356a6949496f3349484b594e6165453d222c2276616c7565223a313939393939393030303030303030303030303030303030302c226761735072696365223a313030303030303030302c226761734c696d6974223a35303030302c2264617461223a22222c227369676e6174757265223a22594661677972512f726d614c7333766e7159307657553858415a7939354b4e31725738347a4f764b62376c7a3773576e2f566a546d68704378774d682b7261314e444832574d6f3965507648304f79427453776a44773d3d222c22636861696e4944223a2256413d3d222c2276657273696f6e223a322c22736e64557365724e616d65223a22593246796232773d222c22726376557365724e616d65223a22595778705932553d227d", ); assert.equal( Buffer.from(relayedTransaction.signature).toString("hex"), - "c0fb5cf8c0a413d6988ba35dc279c63f8849572c5f23b1cab36dcc50952dc3ed9da01068d6ac0cbde7e14167bfc2eca5164d5c2154c89eb313c9c596e3f8b801" + "c0fb5cf8c0a413d6988ba35dc279c63f8849572c5f23b1cab36dcc50952dc3ed9da01068d6ac0cbde7e14167bfc2eca5164d5c2154c89eb313c9c596e3f8b801", ); }); @@ -166,11 +166,11 @@ describe("test relayed v1 transaction builder", function () { assert.equal( Buffer.from(relayedTransaction.data).toString(), - "relayedTx@7b226e6f6e6365223a3139382c2273656e646572223a2267456e574f65576d6d413063306a6b71764d354241707a61644b46574e534f69417643575163776d4750673d222c227265636569766572223a22414141414141414141414146414b565841323879704877692f79693741364c64504b704f68464d386958513d222c2276616c7565223a302c226761735072696365223a313030303030303030302c226761734c696d6974223a36303030303030302c2264617461223a225a3256305132397564484a68593352446232356d6157633d222c227369676e6174757265223a224b4b78324f33383655725135416b4f465258307578327933446a384853334b373038487174344668377161557669424550716c45614e746e6158706a6f2f333651476d4a456934784435457a6c6f4f677a634d4442773d3d222c22636861696e4944223a2256413d3d222c2276657273696f6e223a322c226f7074696f6e73223a322c22677561726469616e223a22486f714c61306e655733766843716f56696c70715372744c5673774939535337586d7a563868477450684d3d222c22677561726469616e5369676e6174757265223a222b5431526f4833625a792f54423177342b6a365155477258645637457577553073753948646551626453515269463953757a686d634b705463526d58595252366c534c6652394931624d7134674730436538363741513d3d227d" + "relayedTx@7b226e6f6e6365223a3139382c2273656e646572223a2267456e574f65576d6d413063306a6b71764d354241707a61644b46574e534f69417643575163776d4750673d222c227265636569766572223a22414141414141414141414146414b565841323879704877692f79693741364c64504b704f68464d386958513d222c2276616c7565223a302c226761735072696365223a313030303030303030302c226761734c696d6974223a36303030303030302c2264617461223a225a3256305132397564484a68593352446232356d6157633d222c227369676e6174757265223a224b4b78324f33383655725135416b4f465258307578327933446a384853334b373038487174344668377161557669424550716c45614e746e6158706a6f2f333651476d4a456934784435457a6c6f4f677a634d4442773d3d222c22636861696e4944223a2256413d3d222c2276657273696f6e223a322c226f7074696f6e73223a322c22677561726469616e223a22486f714c61306e655733766843716f56696c70715372744c5673774939535337586d7a563868477450684d3d222c22677561726469616e5369676e6174757265223a222b5431526f4833625a792f54423177342b6a365155477258645637457577553073753948646551626453515269463953757a686d634b705463526d58595252366c534c6652394931624d7134674730436538363741513d3d227d", ); assert.equal( Buffer.from(relayedTransaction.signature).toString("hex"), - "39cff9d5100e290fbc7361cb6e2402261caf864257b4116f150e0c61e7869155dff8361fa5449431eb7a8ed847c01ba9b3b5ebafe5fac1a3d40c64829d827e00" + "39cff9d5100e290fbc7361cb6e2402261caf864257b4116f150e0c61e7869155dff8361fa5449431eb7a8ed847c01ba9b3b5ebafe5fac1a3d40c64829d827e00", ); }); @@ -205,11 +205,11 @@ describe("test relayed v1 transaction builder", function () { assert.equal( Buffer.from(relayedTransaction.data).toString(), - "relayedTx@7b226e6f6e6365223a3139382c2273656e646572223a2267456e574f65576d6d413063306a6b71764d354241707a61644b46574e534f69417643575163776d4750673d222c227265636569766572223a22414141414141414141414146414b565841323879704877692f79693741364c64504b704f68464d386958513d222c2276616c7565223a302c226761735072696365223a313030303030303030302c226761734c696d6974223a36303030303030302c2264617461223a225957526b546e5674596d5679222c227369676e6174757265223a223469724d4b4a656d724d375174344e7635487633544c44683775654779487045564c4371674a3677652f7a662b746a4933354975573452633458543451533433475333356158386c6a533834324a38426854645043673d3d222c22636861696e4944223a2256413d3d222c2276657273696f6e223a322c226f7074696f6e73223a322c22677561726469616e223a22486f714c61306e655733766843716f56696c70715372744c5673774939535337586d7a563868477450684d3d222c22677561726469616e5369676e6174757265223a2270424754394e674a78307539624c56796b654d78786a454865374269696c37764932324a46676f32787a6e2f496e3032463769546563356b44395045324f747065386c475335412b532f4a36417762576834446744673d3d227d" + "relayedTx@7b226e6f6e6365223a3139382c2273656e646572223a2267456e574f65576d6d413063306a6b71764d354241707a61644b46574e534f69417643575163776d4750673d222c227265636569766572223a22414141414141414141414146414b565841323879704877692f79693741364c64504b704f68464d386958513d222c2276616c7565223a302c226761735072696365223a313030303030303030302c226761734c696d6974223a36303030303030302c2264617461223a225957526b546e5674596d5679222c227369676e6174757265223a223469724d4b4a656d724d375174344e7635487633544c44683775654779487045564c4371674a3677652f7a662b746a4933354975573452633458543451533433475333356158386c6a533834324a38426854645043673d3d222c22636861696e4944223a2256413d3d222c2276657273696f6e223a322c226f7074696f6e73223a322c22677561726469616e223a22486f714c61306e655733766843716f56696c70715372744c5673774939535337586d7a563868477450684d3d222c22677561726469616e5369676e6174757265223a2270424754394e674a78307539624c56796b654d78786a454865374269696c37764932324a46676f32787a6e2f496e3032463769546563356b44395045324f747065386c475335412b532f4a36417762576834446744673d3d227d", ); assert.equal( Buffer.from(relayedTransaction.signature).toString("hex"), - "8ede1bbeed96b102344dffeac12c2592c62b7313cdeb132e8c8bf11d2b1d3bb8189d257a6dbcc99e222393d9b9ec77656c349dae97a32e68bdebd636066bf706" + "8ede1bbeed96b102344dffeac12c2592c62b7313cdeb132e8c8bf11d2b1d3bb8189d257a6dbcc99e222393d9b9ec77656c349dae97a32e68bdebd636066bf706", ); }); @@ -272,7 +272,7 @@ describe("test relayed v1 transaction builder", function () { assert.equal(relayedTransaction.gasLimit.toString(), "60414500"); assert.equal( Buffer.from(relayedTransaction.data).toString(), - "relayedTxV2@000000000000000000010000000000000000000000000000000000000002ffff@0f@676574436f6e7472616374436f6e666967@fc3ed87a51ee659f937c1a1ed11c1ae677e99629fae9cc289461f033e6514d1a8cfad1144ae9c1b70f28554d196bd6ba1604240c1c1dc19c959e96c1c3b62d0c" + "relayedTxV2@000000000000000000010000000000000000000000000000000000000002ffff@0f@676574436f6e7472616374436f6e666967@fc3ed87a51ee659f937c1a1ed11c1ae677e99629fae9cc289461f033e6514d1a8cfad1144ae9c1b70f28554d196bd6ba1604240c1c1dc19c959e96c1c3b62d0c", ); }); }); diff --git a/src/transactionsFactories/relayedTransactionsFactory.ts b/src/transactionsFactories/relayedTransactionsFactory.ts index 898c9e8b..8893ccd3 100644 --- a/src/transactionsFactories/relayedTransactionsFactory.ts +++ b/src/transactionsFactories/relayedTransactionsFactory.ts @@ -36,7 +36,7 @@ export class RelayedTransactionsFactory { const data = `relayedTx@${Buffer.from(serializedTransaction).toString("hex")}`; const additionalGasForDataLength = new BigNumber(this.config.gasLimitPerByte).multipliedBy( - new BigNumber(data.length) + new BigNumber(data.length), ); const gasLimit = new BigNumber(this.config.minGasLimit) .plus(additionalGasForDataLength) @@ -74,7 +74,7 @@ export class RelayedTransactionsFactory { const data = `relayedTxV2@${argumentsString}`; const additionalGasForDataLength = new BigNumber(this.config.gasLimitPerByte).multipliedBy( - new BigNumber(data.length) + new BigNumber(data.length), ); const gasLimit = new BigNumber(options.innerTransactionGasLimit) .plus(new BigNumber(this.config.minGasLimit)) diff --git a/src/transactionsFactories/smartContractTransactionsFactory.ts b/src/transactionsFactories/smartContractTransactionsFactory.ts index d784cc89..e64e2e77 100644 --- a/src/transactionsFactories/smartContractTransactionsFactory.ts +++ b/src/transactionsFactories/smartContractTransactionsFactory.ts @@ -145,9 +145,7 @@ export class SmartContractTransactionsFactory { const metadata = new CodeMetadata(isUpgradeable, isReadable, isPayable, isPayableBySmartContract); let parts = ["upgradeContract", byteArrayToHex(options.bytecode), metadata.toString()]; - const preparedArgs = this.argsToDataParts(args, this.abiRegistry?.constructorDefinition); - parts = parts.concat(preparedArgs); return new TransactionNextBuilder({ diff --git a/src/transactionsFactories/tokenTransfersDataBuilder.ts b/src/transactionsFactories/tokenTransfersDataBuilder.ts index 512cd2eb..7804e7bd 100644 --- a/src/transactionsFactories/tokenTransfersDataBuilder.ts +++ b/src/transactionsFactories/tokenTransfersDataBuilder.ts @@ -27,7 +27,7 @@ export class TokenTransfersDataBuilder { numberToPaddedHex(token.nonce), numberToPaddedHex(transfer.amount), addressToHex(receiver), - ] + ], ); return args; } @@ -38,7 +38,7 @@ export class TokenTransfersDataBuilder { for (let transfer of transfers) { const identifier = this.tokenComputer.extractIdentifierFromExtendedIdentifier(transfer.token.identifier); args.push( - ...[utf8ToHex(identifier), numberToPaddedHex(transfer.token.nonce), numberToPaddedHex(transfer.amount)] + ...[utf8ToHex(identifier), numberToPaddedHex(transfer.token.nonce), numberToPaddedHex(transfer.amount)], ); }