@1inch/solidity-utils 2.1.3 → 2.2.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/contracts/libraries/SafeERC20.sol +9 -7
- package/dist/src/asserts.d.ts +3 -1
- package/dist/src/asserts.js +21 -14
- package/dist/src/asserts.js.map +1 -1
- package/dist/src/permit.d.ts +23 -8
- package/dist/src/permit.js +26 -28
- package/dist/src/permit.js.map +1 -1
- package/dist/src/prelude.d.ts +14 -8
- package/dist/src/prelude.js +20 -10
- package/dist/src/prelude.js.map +1 -1
- package/dist/src/profileEVM.d.ts +0 -1
- package/dist/src/profileEVM.js +38 -31
- package/dist/src/profileEVM.js.map +1 -1
- package/dist/src/utils.d.ts +8 -7
- package/dist/src/utils.js +20 -13
- package/dist/src/utils.js.map +1 -1
- package/package.json +5 -5
|
@@ -99,15 +99,17 @@ library SafeERC20 {
|
|
|
99
99
|
|
|
100
100
|
/// @dev Calls either ERC20 or Dai `permit` for `token`, if unsuccessful forwards revert from external call.
|
|
101
101
|
function safePermit(IERC20 token, bytes calldata permit) internal {
|
|
102
|
-
|
|
102
|
+
if (!tryPermit(token, permit)) RevertReasonForwarder.reRevert();
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
function tryPermit(IERC20 token, bytes calldata permit) internal returns(bool) {
|
|
103
106
|
if (permit.length == 32 * 7) {
|
|
104
|
-
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
revert SafePermitBadLength();
|
|
107
|
+
return _makeCalldataCall(token, IERC20Permit.permit.selector, permit);
|
|
108
|
+
}
|
|
109
|
+
if (permit.length == 32 * 8) {
|
|
110
|
+
return _makeCalldataCall(token, IDaiLikePermit.permit.selector, permit);
|
|
109
111
|
}
|
|
110
|
-
|
|
112
|
+
revert SafePermitBadLength();
|
|
111
113
|
}
|
|
112
114
|
|
|
113
115
|
function _makeCall(
|
package/dist/src/asserts.d.ts
CHANGED
|
@@ -1 +1,3 @@
|
|
|
1
|
-
|
|
1
|
+
import BN from 'bn.js';
|
|
2
|
+
export declare function toBNExtended(value: string | number | BN): BN;
|
|
3
|
+
export declare function assertRoughlyEqualValues(expected: string | number | BN, actual: string | number | BN, relativeDiff: number): void;
|
package/dist/src/asserts.js
CHANGED
|
@@ -1,25 +1,32 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.assertRoughlyEqualValues = void 0;
|
|
3
|
+
exports.assertRoughlyEqualValues = exports.toBNExtended = void 0;
|
|
4
4
|
const prelude_1 = require("./prelude");
|
|
5
|
+
function toBNExtended(value) {
|
|
6
|
+
if (typeof value === 'string' || typeof value === 'number') {
|
|
7
|
+
return (0, prelude_1.toBN)(value);
|
|
8
|
+
}
|
|
9
|
+
return value;
|
|
10
|
+
}
|
|
11
|
+
exports.toBNExtended = toBNExtended;
|
|
5
12
|
function assertRoughlyEqualValues(expected, actual, relativeDiff) {
|
|
6
|
-
let expectedBN =
|
|
7
|
-
let actualBN =
|
|
8
|
-
(
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
+
let expectedBN = toBNExtended(expected);
|
|
14
|
+
let actualBN = toBNExtended(actual);
|
|
15
|
+
if (expectedBN.isNeg() !== actualBN.isNeg()) {
|
|
16
|
+
(0, prelude_1.expect)(actualBN).to.be.bignumber.equal(expectedBN, 'Values are of different sign');
|
|
17
|
+
}
|
|
18
|
+
expectedBN = expectedBN.abs();
|
|
19
|
+
actualBN = actualBN.abs();
|
|
13
20
|
let multiplerNumerator = relativeDiff;
|
|
14
|
-
let multiplerDenominator =
|
|
21
|
+
let multiplerDenominator = (0, prelude_1.toBN)('1');
|
|
15
22
|
while (!Number.isInteger(multiplerNumerator)) {
|
|
16
|
-
multiplerDenominator = multiplerDenominator
|
|
23
|
+
multiplerDenominator = multiplerDenominator.mul((0, prelude_1.toBN)('10'));
|
|
17
24
|
multiplerNumerator *= 10;
|
|
18
25
|
}
|
|
19
|
-
const diff = expectedBN
|
|
20
|
-
const treshold = (
|
|
21
|
-
if (diff
|
|
22
|
-
(0, prelude_1.expect)(actualBN).to.be.equal(expectedBN, `${actual} != ${expected} with ${relativeDiff} precision`);
|
|
26
|
+
const diff = expectedBN.sub(actualBN).abs();
|
|
27
|
+
const treshold = expectedBN.mul((0, prelude_1.toBN)(multiplerNumerator.toString())).div(multiplerDenominator);
|
|
28
|
+
if (!diff.lte(treshold)) {
|
|
29
|
+
(0, prelude_1.expect)(actualBN).to.be.bignumber.equal(expectedBN, `${actual} != ${expected} with ${relativeDiff} precision`);
|
|
23
30
|
}
|
|
24
31
|
}
|
|
25
32
|
exports.assertRoughlyEqualValues = assertRoughlyEqualValues;
|
package/dist/src/asserts.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"asserts.js","sourceRoot":"","sources":["../../src/asserts.ts"],"names":[],"mappings":";;;AAAA,
|
|
1
|
+
{"version":3,"file":"asserts.js","sourceRoot":"","sources":["../../src/asserts.ts"],"names":[],"mappings":";;;AAAA,uCAAyC;AAGzC,SAAgB,YAAY,CAAE,KAA2B;IACrD,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;QACxD,OAAO,IAAA,cAAI,EAAC,KAAK,CAAC,CAAC;KACtB;IACD,OAAO,KAAK,CAAC;AACjB,CAAC;AALD,oCAKC;AAED,SAAgB,wBAAwB,CAAE,QAA8B,EAAE,MAA4B,EAAE,YAAoB;IACxH,IAAI,UAAU,GAAG,YAAY,CAAC,QAAQ,CAAC,CAAC;IACxC,IAAI,QAAQ,GAAG,YAAY,CAAC,MAAM,CAAC,CAAC;IACpC,IAAI,UAAU,CAAC,KAAK,EAAE,KAAK,QAAQ,CAAC,KAAK,EAAE,EAAE;QACzC,IAAA,gBAAM,EAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,SAAS,CAAC,KAAK,CAAC,UAAU,EAAE,8BAA8B,CAAC,CAAC;KACtF;IAED,UAAU,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC;IAC9B,QAAQ,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC;IAE1B,IAAI,kBAAkB,GAAG,YAAY,CAAC;IACtC,IAAI,oBAAoB,GAAG,IAAA,cAAI,EAAC,GAAG,CAAC,CAAC;IACrC,OAAO,CAAC,MAAM,CAAC,SAAS,CAAC,kBAAkB,CAAC,EAAE;QAC1C,oBAAoB,GAAG,oBAAoB,CAAC,GAAG,CAAC,IAAA,cAAI,EAAC,IAAI,CAAC,CAAC,CAAC;QAC5D,kBAAkB,IAAI,EAAE,CAAC;KAC5B;IACD,MAAM,IAAI,GAAG,UAAU,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,CAAC;IAC5C,MAAM,QAAQ,GAAG,UAAU,CAAC,GAAG,CAAC,IAAA,cAAI,EAAC,kBAAkB,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,oBAAoB,CAAC,CAAC;IAC/F,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE;QACrB,IAAA,gBAAM,EAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,SAAS,CAAC,KAAK,CAAC,UAAU,EAAE,GAAG,MAAM,OAAO,QAAQ,SAAS,YAAY,YAAY,CAAC,CAAC;KACjH;AACL,CAAC;AArBD,4DAqBC"}
|
package/dist/src/permit.d.ts
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
import { MessageTypes, SignTypedDataVersion, TypedMessage } from '@metamask/eth-sig-util';
|
|
3
|
+
import { Token } from './utils';
|
|
4
4
|
export declare const TypedDataVersion = SignTypedDataVersion.V4;
|
|
5
|
-
export declare const defaultDeadline:
|
|
5
|
+
export declare const defaultDeadline: string;
|
|
6
6
|
export declare const EIP712Domain: {
|
|
7
7
|
name: string;
|
|
8
8
|
type: string;
|
|
@@ -15,11 +15,16 @@ export declare const DaiLikePermit: {
|
|
|
15
15
|
name: string;
|
|
16
16
|
type: string;
|
|
17
17
|
}[];
|
|
18
|
-
export declare function trim0x(bigNumber:
|
|
18
|
+
export declare function trim0x(bigNumber: BN | string): string;
|
|
19
19
|
export declare function cutSelector(data: string): string;
|
|
20
20
|
export declare function domainSeparator(name: string, version: string, chainId: string, verifyingContract: string): string;
|
|
21
21
|
export declare function buildData(name: string, version: string, chainId: number, verifyingContract: string, owner: string, spender: string, value: string, nonce: string, deadline?: string): {
|
|
22
|
+
readonly primaryType: "Permit";
|
|
22
23
|
readonly types: {
|
|
24
|
+
readonly EIP712Domain: {
|
|
25
|
+
name: string;
|
|
26
|
+
type: string;
|
|
27
|
+
}[];
|
|
23
28
|
readonly Permit: {
|
|
24
29
|
name: string;
|
|
25
30
|
type: string;
|
|
@@ -40,7 +45,12 @@ export declare function buildData(name: string, version: string, chainId: number
|
|
|
40
45
|
};
|
|
41
46
|
};
|
|
42
47
|
export declare function buildDataLikeDai(name: string, version: string, chainId: number, verifyingContract: string, holder: string, spender: string, nonce: string, allowed: boolean, expiry?: string): {
|
|
48
|
+
readonly primaryType: "Permit";
|
|
43
49
|
readonly types: {
|
|
50
|
+
readonly EIP712Domain: {
|
|
51
|
+
name: string;
|
|
52
|
+
type: string;
|
|
53
|
+
}[];
|
|
44
54
|
readonly Permit: {
|
|
45
55
|
name: string;
|
|
46
56
|
type: string;
|
|
@@ -60,6 +70,11 @@ export declare function buildDataLikeDai(name: string, version: string, chainId:
|
|
|
60
70
|
readonly allowed: boolean;
|
|
61
71
|
};
|
|
62
72
|
};
|
|
63
|
-
export
|
|
64
|
-
|
|
65
|
-
|
|
73
|
+
export interface PermittableToken extends Token {
|
|
74
|
+
nonces(owner: string, txDetails?: Truffle.TransactionDetails): Promise<BN>;
|
|
75
|
+
name(txDetails?: Truffle.TransactionDetails): Promise<string>;
|
|
76
|
+
}
|
|
77
|
+
export declare function signWithPk<T extends MessageTypes>(privateKey: Buffer | string, data: TypedMessage<T>): string;
|
|
78
|
+
export declare function getPermit(owner: string, ownerPrivateKey: string, permitContract: PermittableToken, tokenVersion: string, chainId: number, spender: string, value: string, deadline?: string): Promise<string>;
|
|
79
|
+
export declare function getPermitLikeDai(holder: string, holderPrivateKey: string, permitContract: PermittableToken, tokenVersion: string, chainId: number, spender: string, allowed: boolean, expiry?: string): Promise<string>;
|
|
80
|
+
export declare function withTarget(target: BN | string, data: BN | string): string;
|
package/dist/src/permit.js
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.withTarget = exports.getPermitLikeDai = exports.getPermit = exports.buildDataLikeDai = exports.buildData = exports.domainSeparator = exports.cutSelector = exports.trim0x = exports.DaiLikePermit = exports.Permit = exports.EIP712Domain = exports.defaultDeadline = exports.TypedDataVersion = void 0;
|
|
3
|
+
exports.withTarget = exports.getPermitLikeDai = exports.getPermit = exports.signWithPk = exports.buildDataLikeDai = exports.buildData = exports.domainSeparator = exports.cutSelector = exports.trim0x = exports.DaiLikePermit = exports.Permit = exports.EIP712Domain = exports.defaultDeadline = exports.TypedDataVersion = void 0;
|
|
4
4
|
const eth_sig_util_1 = require("@metamask/eth-sig-util");
|
|
5
|
+
const ethereumjs_util_1 = require("ethereumjs-util");
|
|
5
6
|
const prelude_1 = require("./prelude");
|
|
6
|
-
const utils_1 = require("ethers/lib/utils");
|
|
7
7
|
exports.TypedDataVersion = eth_sig_util_1.SignTypedDataVersion.V4;
|
|
8
8
|
exports.defaultDeadline = prelude_1.constants.MAX_UINT256;
|
|
9
9
|
exports.EIP712Domain = [
|
|
@@ -40,57 +40,55 @@ function cutSelector(data) {
|
|
|
40
40
|
}
|
|
41
41
|
exports.cutSelector = cutSelector;
|
|
42
42
|
function domainSeparator(name, version, chainId, verifyingContract) {
|
|
43
|
-
return
|
|
44
|
-
eth_sig_util_1.TypedDataUtils.hashStruct('EIP712Domain', { name, version, chainId, verifyingContract }, { EIP712Domain: exports.EIP712Domain }, exports.TypedDataVersion).toString('hex'));
|
|
43
|
+
return '0x' + eth_sig_util_1.TypedDataUtils.hashStruct('EIP712Domain', { name, version, chainId, verifyingContract }, { EIP712Domain: exports.EIP712Domain }, exports.TypedDataVersion).toString('hex');
|
|
45
44
|
}
|
|
46
45
|
exports.domainSeparator = domainSeparator;
|
|
47
|
-
function buildData(name, version, chainId, verifyingContract, owner, spender, value, nonce, deadline = exports.defaultDeadline
|
|
46
|
+
function buildData(name, version, chainId, verifyingContract, owner, spender, value, nonce, deadline = exports.defaultDeadline) {
|
|
48
47
|
return {
|
|
49
|
-
|
|
48
|
+
primaryType: 'Permit',
|
|
49
|
+
types: { EIP712Domain: exports.EIP712Domain, Permit: exports.Permit },
|
|
50
50
|
domain: { name, version, chainId, verifyingContract },
|
|
51
51
|
message: { owner, spender, value, nonce, deadline },
|
|
52
52
|
};
|
|
53
53
|
}
|
|
54
54
|
exports.buildData = buildData;
|
|
55
|
-
function buildDataLikeDai(name, version, chainId, verifyingContract, holder, spender, nonce, allowed, expiry = exports.defaultDeadline
|
|
55
|
+
function buildDataLikeDai(name, version, chainId, verifyingContract, holder, spender, nonce, allowed, expiry = exports.defaultDeadline) {
|
|
56
56
|
return {
|
|
57
|
-
|
|
57
|
+
primaryType: 'Permit',
|
|
58
|
+
types: { EIP712Domain: exports.EIP712Domain, Permit: exports.DaiLikePermit },
|
|
58
59
|
domain: { name, version, chainId, verifyingContract },
|
|
59
60
|
message: { holder, spender, nonce, expiry, allowed },
|
|
60
61
|
};
|
|
61
62
|
}
|
|
62
63
|
exports.buildDataLikeDai = buildDataLikeDai;
|
|
64
|
+
function signWithPk(privateKey, data) {
|
|
65
|
+
const buffer = Buffer.isBuffer(privateKey) ? privateKey : Buffer.from(trim0x(privateKey), 'hex');
|
|
66
|
+
return (0, eth_sig_util_1.signTypedData)({ privateKey: buffer, data, version: exports.TypedDataVersion });
|
|
67
|
+
}
|
|
68
|
+
exports.signWithPk = signWithPk;
|
|
63
69
|
/*
|
|
64
70
|
* @param permitContract The contract object with ERC20Permit type and token address for which the permit creating.
|
|
65
71
|
*/
|
|
66
|
-
async function getPermit(owner, permitContract, tokenVersion, chainId, spender, value, deadline = exports.defaultDeadline
|
|
67
|
-
const nonce = await permitContract.nonces(owner
|
|
72
|
+
async function getPermit(owner, ownerPrivateKey, permitContract, tokenVersion, chainId, spender, value, deadline = exports.defaultDeadline) {
|
|
73
|
+
const nonce = await permitContract.nonces(owner);
|
|
68
74
|
const name = await permitContract.name();
|
|
69
|
-
const data = buildData(name, tokenVersion, chainId, permitContract.address, owner
|
|
70
|
-
const signature =
|
|
71
|
-
const { v, r, s } = (0,
|
|
72
|
-
const permitCall = permitContract.
|
|
73
|
-
owner.address,
|
|
74
|
-
spender,
|
|
75
|
-
value,
|
|
76
|
-
deadline,
|
|
77
|
-
v,
|
|
78
|
-
r,
|
|
79
|
-
s,
|
|
80
|
-
]);
|
|
75
|
+
const data = buildData(name, tokenVersion, chainId, permitContract.address, owner, spender, value, nonce.toString(), deadline);
|
|
76
|
+
const signature = signWithPk(ownerPrivateKey, data);
|
|
77
|
+
const { v, r, s } = (0, ethereumjs_util_1.fromRpcSig)(signature);
|
|
78
|
+
const permitCall = permitContract.contract.methods.permit(owner, spender, value, deadline, v, r, s).encodeABI();
|
|
81
79
|
return cutSelector(permitCall);
|
|
82
80
|
}
|
|
83
81
|
exports.getPermit = getPermit;
|
|
84
82
|
/*
|
|
85
83
|
* @param permitContract The contract object with ERC20PermitLikeDai type and token address for which the permit creating.
|
|
86
84
|
*/
|
|
87
|
-
async function getPermitLikeDai(holder, permitContract, tokenVersion, chainId, spender, allowed, expiry = exports.defaultDeadline
|
|
88
|
-
const nonce = await permitContract.nonces(holder
|
|
85
|
+
async function getPermitLikeDai(holder, holderPrivateKey, permitContract, tokenVersion, chainId, spender, allowed, expiry = exports.defaultDeadline) {
|
|
86
|
+
const nonce = await permitContract.nonces(holder);
|
|
89
87
|
const name = await permitContract.name();
|
|
90
|
-
const data = buildDataLikeDai(name, tokenVersion, chainId, permitContract.address, holder
|
|
91
|
-
const signature =
|
|
92
|
-
const { v, r, s } = (0,
|
|
93
|
-
const permitCall = permitContract.
|
|
88
|
+
const data = buildDataLikeDai(name, tokenVersion, chainId, permitContract.address, holder, spender, nonce.toString(), allowed, expiry);
|
|
89
|
+
const signature = signWithPk(holderPrivateKey, data);
|
|
90
|
+
const { v, r, s } = (0, ethereumjs_util_1.fromRpcSig)(signature);
|
|
91
|
+
const permitCall = permitContract.contract.methods.permit(holder, spender, nonce, expiry, allowed, v, r, s).encodeABI();
|
|
94
92
|
return cutSelector(permitCall);
|
|
95
93
|
}
|
|
96
94
|
exports.getPermitLikeDai = getPermitLikeDai;
|
package/dist/src/permit.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"permit.js","sourceRoot":"","sources":["../../src/permit.ts"],"names":[],"mappings":";;;AAAA,
|
|
1
|
+
{"version":3,"file":"permit.js","sourceRoot":"","sources":["../../src/permit.ts"],"names":[],"mappings":"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"}
|
package/dist/src/prelude.d.ts
CHANGED
|
@@ -1,14 +1,20 @@
|
|
|
1
1
|
import { Assertion, AssertionError, assert, expect, config, should } from 'chai';
|
|
2
|
-
import
|
|
2
|
+
import 'chai-bn';
|
|
3
|
+
import BN from 'bn.js';
|
|
4
|
+
export declare function toBN(num: string | number, base?: number | 'hex'): BN;
|
|
3
5
|
export declare const constants: {
|
|
4
6
|
readonly ZERO_ADDRESS: "0x0000000000000000000000000000000000000000";
|
|
5
7
|
readonly EEE_ADDRESS: "0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE";
|
|
6
8
|
readonly ZERO_BYTES32: "0x0000000000000000000000000000000000000000000000000000000000000000";
|
|
7
|
-
readonly MAX_UINT256:
|
|
8
|
-
readonly MAX_INT256:
|
|
9
|
-
readonly MIN_INT256:
|
|
10
|
-
readonly MAX_UINT128: bigint;
|
|
9
|
+
readonly MAX_UINT256: string;
|
|
10
|
+
readonly MAX_INT256: string;
|
|
11
|
+
readonly MIN_INT256: string;
|
|
11
12
|
};
|
|
12
|
-
export {
|
|
13
|
-
export declare
|
|
14
|
-
|
|
13
|
+
export { BN, };
|
|
14
|
+
export declare type Time = {
|
|
15
|
+
increaseTo: (target: string | number | BN) => Promise<BN>;
|
|
16
|
+
latest: () => Promise<BN>;
|
|
17
|
+
};
|
|
18
|
+
export declare const time: Time;
|
|
19
|
+
export declare function ether(n: string): BN;
|
|
20
|
+
export { Assertion, AssertionError, assert, expect, config, should, };
|
package/dist/src/prelude.js
CHANGED
|
@@ -1,27 +1,37 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.should = exports.config = exports.expect = exports.assert = exports.AssertionError = exports.Assertion = exports.ether = exports.time = exports.constants = void 0;
|
|
4
|
-
const
|
|
3
|
+
exports.should = exports.config = exports.expect = exports.assert = exports.AssertionError = exports.Assertion = exports.ether = exports.time = exports.BN = exports.constants = exports.toBN = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const chai_1 = tslib_1.__importStar(require("chai"));
|
|
5
6
|
Object.defineProperty(exports, "Assertion", { enumerable: true, get: function () { return chai_1.Assertion; } });
|
|
6
7
|
Object.defineProperty(exports, "AssertionError", { enumerable: true, get: function () { return chai_1.AssertionError; } });
|
|
7
8
|
Object.defineProperty(exports, "assert", { enumerable: true, get: function () { return chai_1.assert; } });
|
|
8
9
|
Object.defineProperty(exports, "expect", { enumerable: true, get: function () { return chai_1.expect; } });
|
|
9
10
|
Object.defineProperty(exports, "config", { enumerable: true, get: function () { return chai_1.config; } });
|
|
10
11
|
Object.defineProperty(exports, "should", { enumerable: true, get: function () { return chai_1.should; } });
|
|
11
|
-
|
|
12
|
-
const
|
|
13
|
-
|
|
12
|
+
require("chai-bn");
|
|
13
|
+
const chai_as_promised_1 = tslib_1.__importDefault(require("chai-as-promised"));
|
|
14
|
+
const web3_utils_1 = require("web3-utils");
|
|
15
|
+
const bn_js_1 = tslib_1.__importDefault(require("bn.js"));
|
|
16
|
+
exports.BN = bn_js_1.default;
|
|
17
|
+
chai_1.default.use(chai_as_promised_1.default);
|
|
18
|
+
// eslint-disable-next-line @typescript-eslint/no-var-requires
|
|
19
|
+
const { time: timeImpl } = require('@openzeppelin/test-helpers');
|
|
20
|
+
function toBN(num, base) {
|
|
21
|
+
return new bn_js_1.default(num, base);
|
|
22
|
+
}
|
|
23
|
+
exports.toBN = toBN;
|
|
14
24
|
exports.constants = {
|
|
15
25
|
ZERO_ADDRESS: '0x0000000000000000000000000000000000000000',
|
|
16
26
|
EEE_ADDRESS: '0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE',
|
|
17
27
|
ZERO_BYTES32: '0x0000000000000000000000000000000000000000000000000000000000000000',
|
|
18
|
-
MAX_UINT256:
|
|
19
|
-
MAX_INT256:
|
|
20
|
-
MIN_INT256: -(
|
|
21
|
-
MAX_UINT128: 2n ** 128n - 1n,
|
|
28
|
+
MAX_UINT256: toBN('2').pow(toBN('256')).sub(toBN('1')).toString(),
|
|
29
|
+
MAX_INT256: toBN('2').pow(toBN('255')).sub(toBN('1')).toString(),
|
|
30
|
+
MIN_INT256: toBN('2').pow(toBN('255')).mul(toBN('-1')).toString(),
|
|
22
31
|
};
|
|
32
|
+
exports.time = timeImpl;
|
|
23
33
|
function ether(n) {
|
|
24
|
-
return (0,
|
|
34
|
+
return toBN((0, web3_utils_1.toWei)(n, 'ether'));
|
|
25
35
|
}
|
|
26
36
|
exports.ether = ether;
|
|
27
37
|
//# sourceMappingURL=prelude.js.map
|
package/dist/src/prelude.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"prelude.js","sourceRoot":"","sources":["../../src/prelude.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"prelude.js","sourceRoot":"","sources":["../../src/prelude.ts"],"names":[],"mappings":";;;;AAAA,qDAAuF;AAyCnF,0FAzCW,gBAAS,OAyCX;AACT,+FA1CsB,qBAAc,OA0CtB;AACd,uFA3CsC,aAAM,OA2CtC;AACN,uFA5C8C,aAAM,OA4C9C;AACN,uFA7CsD,aAAM,OA6CtD;AACN,uFA9C8D,aAAM,OA8C9D;AA7CV,mBAAiB;AACjB,gFAA8C;AAC9C,2CAAmC;AACnC,0DAAuB;AAoBnB,aApBG,eAAE,CAoBH;AAnBN,cAAI,CAAC,GAAG,CAAC,0BAAc,CAAC,CAAC;AACzB,8DAA8D;AAC9D,MAAM,EAAE,IAAI,EAAE,QAAQ,EAAE,GAAG,OAAO,CAAC,4BAA4B,CAAC,CAAC;AAEjE,SAAgB,IAAI,CAAE,GAAoB,EAAE,IAAqB;IAC7D,OAAO,IAAI,eAAE,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;AAC7B,CAAC;AAFD,oBAEC;AAEY,QAAA,SAAS,GAAG;IACrB,YAAY,EAAE,4CAA4C;IAC1D,WAAW,EAAE,4CAA4C;IACzD,YAAY,EAAE,oEAAoE;IAClF,WAAW,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,QAAQ,EAAE;IACjE,UAAU,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,QAAQ,EAAE;IAChE,UAAU,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,QAAQ,EAAE;CAC3D,CAAC;AAaE,QAAA,IAAI,GAAS,QAAQ,CAAC;AAEnC,SAAgB,KAAK,CAAE,CAAS;IAC5B,OAAO,IAAI,CAAC,IAAA,kBAAK,EAAC,CAAC,EAAE,OAAO,CAAC,CAAC,CAAC;AACnC,CAAC;AAFD,sBAEC"}
|
package/dist/src/profileEVM.d.ts
CHANGED
package/dist/src/profileEVM.js
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.gasspectEVM = exports.profileEVM = exports.gasspectOptionsDefault = void 0;
|
|
4
|
-
require("
|
|
4
|
+
const util_1 = require("util");
|
|
5
5
|
const fs_1 = require("fs");
|
|
6
|
-
const
|
|
6
|
+
const prelude_1 = require("./prelude");
|
|
7
7
|
exports.gasspectOptionsDefault = {
|
|
8
8
|
minOpGasCost: 300,
|
|
9
9
|
args: false,
|
|
@@ -12,21 +12,16 @@ exports.gasspectOptionsDefault = {
|
|
|
12
12
|
function _normalizeOp(ops, i) {
|
|
13
13
|
if (ops[i].op === 'STATICCALL') {
|
|
14
14
|
ops[i].gasCost = ops[i].gasCost - ops[i + 1].gas;
|
|
15
|
-
if (ops[i].stack.length > 8 &&
|
|
16
|
-
ops[i].stack[ops[i].stack.length - 8] === '0000000000000000000000000000000000000000000000000000000000000001') {
|
|
15
|
+
if (ops[i].stack.length > 8 && ops[i].stack[ops[i].stack.length - 8] === '0000000000000000000000000000000000000000000000000000000000000001') {
|
|
17
16
|
ops[i].op = 'STATICCALL-ECRECOVER';
|
|
18
17
|
}
|
|
19
|
-
else if (ops[i].stack.length > 8 &&
|
|
20
|
-
ops[i].stack[ops[i].stack.length - 8] <= '00000000000000000000000000000000000000000000000000000000000000FF') {
|
|
18
|
+
else if (ops[i].stack.length > 8 && ops[i].stack[ops[i].stack.length - 8] <= '00000000000000000000000000000000000000000000000000000000000000FF') {
|
|
21
19
|
ops[i].op = 'STATICCALL-' + ops[i].stack[ops[i].stack.length - 8].substr(62, 2);
|
|
22
20
|
}
|
|
23
21
|
else {
|
|
24
22
|
ops[i].args = [
|
|
25
|
-
'0x' + ops[i].stack[ops[i].stack.length - 2].
|
|
26
|
-
'0x' +
|
|
27
|
-
(ops[i].memory || [])
|
|
28
|
-
.join('')
|
|
29
|
-
.substr(2 * Number(ops[i].stack[ops[i].stack.length - 3]), 2 * Number(ops[i].stack[ops[i].stack.length - 4])),
|
|
23
|
+
'0x' + ops[i].stack[ops[i].stack.length - 2].substr(24),
|
|
24
|
+
'0x' + (ops[i].memory || []).join('').substr(2 * (0, prelude_1.toBN)(ops[i].stack[ops[i].stack.length - 3]).toNumber(), 2 * (0, prelude_1.toBN)(ops[i].stack[ops[i].stack.length - 4]).toNumber()),
|
|
30
25
|
];
|
|
31
26
|
if (ops[i].gasCost === 100) {
|
|
32
27
|
ops[i].op += '_R';
|
|
@@ -35,11 +30,8 @@ function _normalizeOp(ops, i) {
|
|
|
35
30
|
}
|
|
36
31
|
if (['CALL', 'DELEGATECALL', 'CALLCODE'].indexOf(ops[i].op) !== -1) {
|
|
37
32
|
ops[i].args = [
|
|
38
|
-
'0x' + ops[i].stack[ops[i].stack.length - 2].
|
|
39
|
-
'0x' +
|
|
40
|
-
(ops[i].memory || [])
|
|
41
|
-
.join('')
|
|
42
|
-
.substr(2 * Number(ops[i].stack[ops[i].stack.length - 4]), 2 * Number(ops[i].stack[ops[i].stack.length - 5])),
|
|
33
|
+
'0x' + ops[i].stack[ops[i].stack.length - 2].substr(24),
|
|
34
|
+
'0x' + (ops[i].memory || []).join('').substr(2 * (0, prelude_1.toBN)(ops[i].stack[ops[i].stack.length - 4]).toNumber(), 2 * (0, prelude_1.toBN)(ops[i].stack[ops[i].stack.length - 5]).toNumber()),
|
|
43
35
|
];
|
|
44
36
|
ops[i].gasCost = ops[i].gasCost - ops[i + 1].gas;
|
|
45
37
|
ops[i].res = ops[i + 1].stack[ops[i + 1].stack.length - 1];
|
|
@@ -51,14 +43,16 @@ function _normalizeOp(ops, i) {
|
|
|
51
43
|
ops[i].gasCost = 3;
|
|
52
44
|
}
|
|
53
45
|
if (['SSTORE', 'SLOAD'].indexOf(ops[i].op) !== -1) {
|
|
54
|
-
ops[i].args = [
|
|
46
|
+
ops[i].args = [
|
|
47
|
+
'0x' + ops[i].stack[ops[i].stack.length - 1],
|
|
48
|
+
];
|
|
55
49
|
if (ops[i].op === 'SSTORE') {
|
|
56
50
|
ops[i].args.push('0x' + ops[i].stack[ops[i].stack.length - 2]);
|
|
57
51
|
}
|
|
58
52
|
if (ops[i].gasCost === 100) {
|
|
59
53
|
ops[i].op += '_R';
|
|
60
54
|
}
|
|
61
|
-
if (ops[i].gasCost
|
|
55
|
+
if (ops[i].gasCost === 20000) {
|
|
62
56
|
ops[i].op += '_I';
|
|
63
57
|
}
|
|
64
58
|
if (ops[i].op.startsWith('SLOAD')) {
|
|
@@ -66,25 +60,43 @@ function _normalizeOp(ops, i) {
|
|
|
66
60
|
}
|
|
67
61
|
}
|
|
68
62
|
if (ops[i].op === 'EXTCODESIZE') {
|
|
69
|
-
ops[i].args = [
|
|
63
|
+
ops[i].args = [
|
|
64
|
+
'0x' + ops[i].stack[ops[i].stack.length - 1].substr(24),
|
|
65
|
+
];
|
|
70
66
|
ops[i].res = ops[i + 1].stack[ops[i + 1].stack.length - 1];
|
|
71
67
|
}
|
|
72
68
|
}
|
|
73
69
|
async function profileEVM(txHash, instruction, optionalTraceFile) {
|
|
74
|
-
|
|
70
|
+
if (!web3.currentProvider || typeof web3.currentProvider === 'string' || !web3.currentProvider.send) {
|
|
71
|
+
throw new Error('Unsupported provider');
|
|
72
|
+
}
|
|
73
|
+
const trace = await (0, util_1.promisify)(web3.currentProvider.send.bind(web3.currentProvider))({
|
|
74
|
+
jsonrpc: '2.0',
|
|
75
|
+
method: 'debug_traceTransaction',
|
|
76
|
+
params: [txHash, {}],
|
|
77
|
+
id: new Date().getTime(),
|
|
78
|
+
});
|
|
75
79
|
const str = JSON.stringify(trace);
|
|
76
80
|
if (optionalTraceFile) {
|
|
77
81
|
await fs_1.promises.writeFile(optionalTraceFile, str);
|
|
78
82
|
}
|
|
79
|
-
return instruction.map(
|
|
83
|
+
return instruction.map(instr => {
|
|
80
84
|
return str.split('"' + instr.toUpperCase() + '"').length - 1;
|
|
81
85
|
});
|
|
82
86
|
}
|
|
83
87
|
exports.profileEVM = profileEVM;
|
|
84
88
|
async function gasspectEVM(txHash, gasspectOptions = {}, optionalTraceFile) {
|
|
85
89
|
const options = { ...exports.gasspectOptionsDefault, ...gasspectOptions };
|
|
86
|
-
|
|
87
|
-
|
|
90
|
+
if (!web3.currentProvider || typeof web3.currentProvider === 'string' || !web3.currentProvider.send) {
|
|
91
|
+
throw new Error('Unsupported provider');
|
|
92
|
+
}
|
|
93
|
+
const trace = await (0, util_1.promisify)(web3.currentProvider.send.bind(web3.currentProvider))({
|
|
94
|
+
jsonrpc: '2.0',
|
|
95
|
+
method: 'debug_traceTransaction',
|
|
96
|
+
params: [txHash, {}],
|
|
97
|
+
id: new Date().getTime(),
|
|
98
|
+
});
|
|
99
|
+
const ops = trace === null || trace === void 0 ? void 0 : trace.result.structLogs;
|
|
88
100
|
const traceAddress = [0, -1];
|
|
89
101
|
for (const [i, op] of ops.entries()) {
|
|
90
102
|
op.traceAddress = traceAddress.slice(0, traceAddress.length - 1);
|
|
@@ -97,17 +109,12 @@ async function gasspectEVM(txHash, gasspectOptions = {}, optionalTraceFile) {
|
|
|
97
109
|
traceAddress.pop();
|
|
98
110
|
}
|
|
99
111
|
}
|
|
100
|
-
const result = ops
|
|
101
|
-
.filter((op) => op.gasCost > options.minOpGasCost)
|
|
102
|
-
.map((op) => op.traceAddress.join('-') +
|
|
103
|
-
'-' +
|
|
104
|
-
op.op +
|
|
112
|
+
const result = ops.filter(op => op.gasCost > options.minOpGasCost).map(op => op.traceAddress.join('-') + '-' + op.op +
|
|
105
113
|
(options.args ? '(' + (op.args || []).join(',') + ')' : '') +
|
|
106
114
|
(options.res ? (op.res ? ':0x' + op.res : '') : '') +
|
|
107
|
-
' = ' +
|
|
108
|
-
op.gasCost);
|
|
115
|
+
' = ' + op.gasCost);
|
|
109
116
|
if (optionalTraceFile) {
|
|
110
|
-
await fs_1.promises.writeFile(optionalTraceFile, JSON.stringify(
|
|
117
|
+
await fs_1.promises.writeFile(optionalTraceFile, JSON.stringify(result));
|
|
111
118
|
}
|
|
112
119
|
return result;
|
|
113
120
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"profileEVM.js","sourceRoot":"","sources":["../../src/profileEVM.ts"],"names":[],"mappings":";;;AAAA
|
|
1
|
+
{"version":3,"file":"profileEVM.js","sourceRoot":"","sources":["../../src/profileEVM.ts"],"names":[],"mappings":"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"}
|
package/dist/src/utils.d.ts
CHANGED
|
@@ -1,13 +1,14 @@
|
|
|
1
|
-
|
|
1
|
+
/// <reference types="bn.js" />
|
|
2
2
|
import { constants } from './prelude';
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
3
|
+
export declare function timeIncreaseTo(seconds: number | string | BN): Promise<void>;
|
|
4
|
+
export interface Token extends Truffle.ContractInstance {
|
|
5
|
+
balanceOf(account: string, txDetails?: Truffle.TransactionDetails): Promise<BN>;
|
|
6
|
+
}
|
|
7
|
+
export declare function trackReceivedTokenAndTx<T extends unknown[], U extends Truffle.AnyEvent>(token: Token | {
|
|
7
8
|
address: typeof constants.ZERO_ADDRESS;
|
|
8
9
|
} | {
|
|
9
10
|
address: typeof constants.EEE_ADDRESS;
|
|
10
|
-
}, wallet: string, txPromise: (...args: T) => Promise<
|
|
11
|
+
}, wallet: string, txPromise: (...args: T) => Promise<Truffle.TransactionResponse<U>>, ...args: T): Promise<readonly [import("bn.js"), Truffle.TransactionResponse<U>]>;
|
|
11
12
|
export declare function fixSignature(signature: string): string;
|
|
12
|
-
export declare function signMessage(signer:
|
|
13
|
+
export declare function signMessage(signer: string, messageHex?: string): Promise<string>;
|
|
13
14
|
export declare function countInstructions(txHash: string, instructions: string[]): Promise<number[]>;
|
package/dist/src/utils.js
CHANGED
|
@@ -1,25 +1,23 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.countInstructions = exports.signMessage = exports.fixSignature = exports.trackReceivedTokenAndTx = exports.timeIncreaseTo = void 0;
|
|
4
|
-
require("
|
|
5
|
-
const
|
|
6
|
-
const hardhat_1 = require("hardhat");
|
|
4
|
+
const util_1 = require("util");
|
|
5
|
+
const prelude_1 = require("./prelude");
|
|
7
6
|
async function timeIncreaseTo(seconds) {
|
|
8
7
|
const delay = 1000 - new Date().getMilliseconds();
|
|
9
|
-
await new Promise(
|
|
10
|
-
await
|
|
8
|
+
await new Promise(resolve => setTimeout(resolve, delay));
|
|
9
|
+
await prelude_1.time.increaseTo(seconds);
|
|
11
10
|
}
|
|
12
11
|
exports.timeIncreaseTo = timeIncreaseTo;
|
|
13
12
|
async function trackReceivedTokenAndTx(token, wallet, txPromise, ...args) {
|
|
14
13
|
const [balanceFunc, isETH] = 'balanceOf' in token
|
|
15
14
|
? [() => token.balanceOf(wallet), false]
|
|
16
|
-
: [async () => await
|
|
15
|
+
: [async () => (0, prelude_1.toBN)(await web3.eth.getBalance(wallet)), true];
|
|
17
16
|
const preBalance = await balanceFunc();
|
|
18
17
|
const txResult = await txPromise(...args);
|
|
19
|
-
const
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
: 0n;
|
|
18
|
+
const txFees = (wallet.toLowerCase() === txResult.receipt.from.toLowerCase() && isETH)
|
|
19
|
+
? (0, prelude_1.toBN)(txResult.receipt.gasUsed).mul((0, prelude_1.toBN)(txResult.receipt.effectiveGasPrice))
|
|
20
|
+
: (0, prelude_1.toBN)('0');
|
|
23
21
|
const postBalance = await balanceFunc();
|
|
24
22
|
return [postBalance.sub(preBalance).add(txFees), txResult];
|
|
25
23
|
}
|
|
@@ -36,14 +34,23 @@ function fixSignature(signature) {
|
|
|
36
34
|
return signature.slice(0, 130) + vHex;
|
|
37
35
|
}
|
|
38
36
|
exports.fixSignature = fixSignature;
|
|
37
|
+
// signs message in node (ganache auto-applies "Ethereum Signed Message" prefix)
|
|
39
38
|
async function signMessage(signer, messageHex = '0x') {
|
|
40
|
-
return fixSignature(await
|
|
39
|
+
return fixSignature(await web3.eth.sign(messageHex, signer));
|
|
41
40
|
}
|
|
42
41
|
exports.signMessage = signMessage;
|
|
43
42
|
async function countInstructions(txHash, instructions) {
|
|
44
|
-
|
|
43
|
+
if (!web3.currentProvider || typeof web3.currentProvider === 'string' || !web3.currentProvider.send) {
|
|
44
|
+
throw new Error('Unsupported provider');
|
|
45
|
+
}
|
|
46
|
+
const trace = await (0, util_1.promisify)(web3.currentProvider.send.bind(web3.currentProvider))({
|
|
47
|
+
jsonrpc: '2.0',
|
|
48
|
+
method: 'debug_traceTransaction',
|
|
49
|
+
params: [txHash, {}],
|
|
50
|
+
id: new Date().getTime(),
|
|
51
|
+
});
|
|
45
52
|
const str = JSON.stringify(trace);
|
|
46
|
-
return instructions.map(
|
|
53
|
+
return instructions.map(instr => {
|
|
47
54
|
return str.split('"' + instr.toUpperCase() + '"').length - 1;
|
|
48
55
|
});
|
|
49
56
|
}
|
package/dist/src/utils.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../src/utils.ts"],"names":[],"mappings":";;;AAAA
|
|
1
|
+
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../src/utils.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@1inch/solidity-utils",
|
|
3
|
-
"version": "2.1
|
|
3
|
+
"version": "2.2.1",
|
|
4
4
|
"main": "dist/src/index.js",
|
|
5
5
|
"types": "dist/src/index.d.ts",
|
|
6
6
|
"repository": {
|
|
@@ -30,14 +30,15 @@
|
|
|
30
30
|
},
|
|
31
31
|
"dependencies": {
|
|
32
32
|
"@metamask/eth-sig-util": "4.0.1",
|
|
33
|
+
"@nomicfoundation/hardhat-network-helpers": "1.0.6",
|
|
34
|
+
"@nomiclabs/hardhat-ethers": "2.1.1",
|
|
33
35
|
"@openzeppelin/contracts": "4.7.3",
|
|
34
36
|
"ethereumjs-util": "7.1.5",
|
|
35
|
-
"ethers": "5.7.1"
|
|
37
|
+
"ethers": "5.7.1",
|
|
38
|
+
"hardhat": "2.11.2"
|
|
36
39
|
},
|
|
37
40
|
"devDependencies": {
|
|
38
41
|
"@nomicfoundation/hardhat-chai-matchers": "1.0.3",
|
|
39
|
-
"@nomicfoundation/hardhat-network-helpers": "1.0.6",
|
|
40
|
-
"@nomiclabs/hardhat-ethers": "2.1.1",
|
|
41
42
|
"@typechain/hardhat": "6.1.3",
|
|
42
43
|
"@typechain/ethers-v5": "10.1.0",
|
|
43
44
|
"@types/chai": "4.3.3",
|
|
@@ -60,7 +61,6 @@
|
|
|
60
61
|
"eslint-plugin-promise": "6.0.1",
|
|
61
62
|
"eslint-plugin-standard": "5.0.0",
|
|
62
63
|
"ethereumjs-wallet": "1.0.2",
|
|
63
|
-
"hardhat": "2.11.2",
|
|
64
64
|
"hardhat-gas-reporter": "1.0.9",
|
|
65
65
|
"prettier": "2.7.1",
|
|
66
66
|
"prettier-plugin-solidity": "1.0.0-beta.24",
|