zerc20-client-sdk 0.3.1 → 0.3.3
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/LICENSE +21 -0
- package/README.md +13 -0
- package/dist/assets/abi/Blocklist.json +178 -0
- package/dist/index.d.ts +2 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +2 -2
- package/dist/index.js.map +1 -1
- package/dist/onchain/__tests__/contracts.test.js +6 -1
- package/dist/onchain/__tests__/contracts.test.js.map +1 -1
- package/dist/onchain/__tests__/tokenReads.test.js +21 -1
- package/dist/onchain/__tests__/tokenReads.test.js.map +1 -1
- package/dist/onchain/contracts.d.ts +2 -1
- package/dist/onchain/contracts.d.ts.map +1 -1
- package/dist/onchain/contracts.js +2 -1
- package/dist/onchain/contracts.js.map +1 -1
- package/dist/onchain/tokenReads.d.ts +8 -0
- package/dist/onchain/tokenReads.d.ts.map +1 -1
- package/dist/onchain/tokenReads.js +17 -0
- package/dist/onchain/tokenReads.js.map +1 -1
- package/dist/operations/__tests__/privateSendTransfer.test.js +1 -0
- package/dist/operations/__tests__/privateSendTransfer.test.js.map +1 -1
- package/dist/operations/privateSend.js +1 -1
- package/dist/operations/privateSend.js.map +1 -1
- package/dist/operations/receive/__tests__/submitRedeem.test.js +3 -1
- package/dist/operations/receive/__tests__/submitRedeem.test.js.map +1 -1
- package/dist/operations/receive/submitRedeem.js +1 -1
- package/dist/operations/receive/submitRedeem.js.map +1 -1
- package/package.json +5 -5
package/LICENSE
ADDED
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
MIT License
|
|
2
|
+
|
|
3
|
+
Copyright (c) 2025-2026 zERC20
|
|
4
|
+
|
|
5
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
6
|
+
of this software and associated documentation files (the "Software"), to deal
|
|
7
|
+
in the Software without restriction, including without limitation the rights
|
|
8
|
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
9
|
+
copies of the Software, and to permit persons to whom the Software is
|
|
10
|
+
furnished to do so, subject to the following conditions:
|
|
11
|
+
|
|
12
|
+
The above copyright notice and this permission notice shall be included in all
|
|
13
|
+
copies or substantial portions of the Software.
|
|
14
|
+
|
|
15
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
16
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
17
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
18
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
19
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
20
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
21
|
+
SOFTWARE.
|
package/README.md
CHANGED
|
@@ -204,6 +204,19 @@ await submitRelaySwap("https://relay.example", {
|
|
|
204
204
|
});
|
|
205
205
|
```
|
|
206
206
|
|
|
207
|
+
### Blocklist
|
|
208
|
+
|
|
209
|
+
Check whether an address is on the OFAC sanctions blocklist before executing a private send. This prevents funds from being permanently locked when the recipient cannot redeem:
|
|
210
|
+
|
|
211
|
+
```typescript
|
|
212
|
+
import { isBlockedAddress } from "zerc20-client-sdk";
|
|
213
|
+
|
|
214
|
+
const blocked = await isBlockedAddress(readProvider, blocklistAddress, recipientAddress);
|
|
215
|
+
if (blocked) {
|
|
216
|
+
throw new Error("Recipient is on the OFAC sanctions blocklist");
|
|
217
|
+
}
|
|
218
|
+
```
|
|
219
|
+
|
|
207
220
|
### Adaptor Withdraw (Stuck Fund Recovery)
|
|
208
221
|
|
|
209
222
|
When a cross-chain unwrap fails (e.g. due to Stargate liquidity shortage), user funds may remain in the destination chain's Adaptor contract. The SDK provides functions to detect and recover these stuck funds:
|
|
@@ -0,0 +1,178 @@
|
|
|
1
|
+
{
|
|
2
|
+
"abi": [
|
|
3
|
+
{
|
|
4
|
+
"type": "constructor",
|
|
5
|
+
"inputs": [
|
|
6
|
+
{
|
|
7
|
+
"name": "initialOwner",
|
|
8
|
+
"type": "address",
|
|
9
|
+
"internalType": "address"
|
|
10
|
+
}
|
|
11
|
+
],
|
|
12
|
+
"stateMutability": "nonpayable"
|
|
13
|
+
},
|
|
14
|
+
{
|
|
15
|
+
"type": "function",
|
|
16
|
+
"name": "blockAddress",
|
|
17
|
+
"inputs": [
|
|
18
|
+
{
|
|
19
|
+
"name": "account",
|
|
20
|
+
"type": "address",
|
|
21
|
+
"internalType": "address"
|
|
22
|
+
}
|
|
23
|
+
],
|
|
24
|
+
"outputs": [],
|
|
25
|
+
"stateMutability": "nonpayable"
|
|
26
|
+
},
|
|
27
|
+
{
|
|
28
|
+
"type": "function",
|
|
29
|
+
"name": "blockAddresses",
|
|
30
|
+
"inputs": [
|
|
31
|
+
{
|
|
32
|
+
"name": "accounts",
|
|
33
|
+
"type": "address[]",
|
|
34
|
+
"internalType": "address[]"
|
|
35
|
+
}
|
|
36
|
+
],
|
|
37
|
+
"outputs": [],
|
|
38
|
+
"stateMutability": "nonpayable"
|
|
39
|
+
},
|
|
40
|
+
{
|
|
41
|
+
"type": "function",
|
|
42
|
+
"name": "isBlocked",
|
|
43
|
+
"inputs": [
|
|
44
|
+
{
|
|
45
|
+
"name": "account",
|
|
46
|
+
"type": "address",
|
|
47
|
+
"internalType": "address"
|
|
48
|
+
}
|
|
49
|
+
],
|
|
50
|
+
"outputs": [
|
|
51
|
+
{
|
|
52
|
+
"name": "",
|
|
53
|
+
"type": "bool",
|
|
54
|
+
"internalType": "bool"
|
|
55
|
+
}
|
|
56
|
+
],
|
|
57
|
+
"stateMutability": "view"
|
|
58
|
+
},
|
|
59
|
+
{
|
|
60
|
+
"type": "function",
|
|
61
|
+
"name": "owner",
|
|
62
|
+
"inputs": [],
|
|
63
|
+
"outputs": [
|
|
64
|
+
{
|
|
65
|
+
"name": "",
|
|
66
|
+
"type": "address",
|
|
67
|
+
"internalType": "address"
|
|
68
|
+
}
|
|
69
|
+
],
|
|
70
|
+
"stateMutability": "view"
|
|
71
|
+
},
|
|
72
|
+
{
|
|
73
|
+
"type": "function",
|
|
74
|
+
"name": "renounceOwnership",
|
|
75
|
+
"inputs": [],
|
|
76
|
+
"outputs": [],
|
|
77
|
+
"stateMutability": "nonpayable"
|
|
78
|
+
},
|
|
79
|
+
{
|
|
80
|
+
"type": "function",
|
|
81
|
+
"name": "transferOwnership",
|
|
82
|
+
"inputs": [
|
|
83
|
+
{
|
|
84
|
+
"name": "newOwner",
|
|
85
|
+
"type": "address",
|
|
86
|
+
"internalType": "address"
|
|
87
|
+
}
|
|
88
|
+
],
|
|
89
|
+
"outputs": [],
|
|
90
|
+
"stateMutability": "nonpayable"
|
|
91
|
+
},
|
|
92
|
+
{
|
|
93
|
+
"type": "function",
|
|
94
|
+
"name": "unblockAddress",
|
|
95
|
+
"inputs": [
|
|
96
|
+
{
|
|
97
|
+
"name": "account",
|
|
98
|
+
"type": "address",
|
|
99
|
+
"internalType": "address"
|
|
100
|
+
}
|
|
101
|
+
],
|
|
102
|
+
"outputs": [],
|
|
103
|
+
"stateMutability": "nonpayable"
|
|
104
|
+
},
|
|
105
|
+
{
|
|
106
|
+
"type": "event",
|
|
107
|
+
"name": "AddressBlocked",
|
|
108
|
+
"inputs": [
|
|
109
|
+
{
|
|
110
|
+
"name": "account",
|
|
111
|
+
"type": "address",
|
|
112
|
+
"indexed": true,
|
|
113
|
+
"internalType": "address"
|
|
114
|
+
}
|
|
115
|
+
],
|
|
116
|
+
"anonymous": false
|
|
117
|
+
},
|
|
118
|
+
{
|
|
119
|
+
"type": "event",
|
|
120
|
+
"name": "AddressUnblocked",
|
|
121
|
+
"inputs": [
|
|
122
|
+
{
|
|
123
|
+
"name": "account",
|
|
124
|
+
"type": "address",
|
|
125
|
+
"indexed": true,
|
|
126
|
+
"internalType": "address"
|
|
127
|
+
}
|
|
128
|
+
],
|
|
129
|
+
"anonymous": false
|
|
130
|
+
},
|
|
131
|
+
{
|
|
132
|
+
"type": "event",
|
|
133
|
+
"name": "OwnershipTransferred",
|
|
134
|
+
"inputs": [
|
|
135
|
+
{
|
|
136
|
+
"name": "previousOwner",
|
|
137
|
+
"type": "address",
|
|
138
|
+
"indexed": true,
|
|
139
|
+
"internalType": "address"
|
|
140
|
+
},
|
|
141
|
+
{
|
|
142
|
+
"name": "newOwner",
|
|
143
|
+
"type": "address",
|
|
144
|
+
"indexed": true,
|
|
145
|
+
"internalType": "address"
|
|
146
|
+
}
|
|
147
|
+
],
|
|
148
|
+
"anonymous": false
|
|
149
|
+
},
|
|
150
|
+
{
|
|
151
|
+
"type": "error",
|
|
152
|
+
"name": "OwnableInvalidOwner",
|
|
153
|
+
"inputs": [
|
|
154
|
+
{
|
|
155
|
+
"name": "owner",
|
|
156
|
+
"type": "address",
|
|
157
|
+
"internalType": "address"
|
|
158
|
+
}
|
|
159
|
+
]
|
|
160
|
+
},
|
|
161
|
+
{
|
|
162
|
+
"type": "error",
|
|
163
|
+
"name": "OwnableUnauthorizedAccount",
|
|
164
|
+
"inputs": [
|
|
165
|
+
{
|
|
166
|
+
"name": "account",
|
|
167
|
+
"type": "address",
|
|
168
|
+
"internalType": "address"
|
|
169
|
+
}
|
|
170
|
+
]
|
|
171
|
+
},
|
|
172
|
+
{
|
|
173
|
+
"type": "error",
|
|
174
|
+
"name": "ZeroAddress",
|
|
175
|
+
"inputs": []
|
|
176
|
+
}
|
|
177
|
+
]
|
|
178
|
+
}
|
package/dist/index.d.ts
CHANGED
|
@@ -5,9 +5,9 @@ export { AGGREGATION_TREE_HEIGHT, TRANSFER_TREE_HEIGHT, GLOBAL_TRANSFER_TREE_HEI
|
|
|
5
5
|
export * from "./decider/prover.js";
|
|
6
6
|
export * from "./ic/connections.js";
|
|
7
7
|
export * from "./ic/index.js";
|
|
8
|
-
export { AdaptorArtifact, HubArtifact, LiquidityManagerArtifact, VerifierArtifact, Zerc20Artifact, } from "./onchain/contracts.js";
|
|
8
|
+
export { AdaptorArtifact, BlocklistArtifact, HubArtifact, LiquidityManagerArtifact, VerifierArtifact, Zerc20Artifact, } from "./onchain/contracts.js";
|
|
9
9
|
export * from "./onchain/decode.js";
|
|
10
|
-
export { readTokenBalance, readTokenDecimals, readDecimalConversionRate, } from "./onchain/tokenReads.js";
|
|
10
|
+
export { isBlockedAddress, readTokenBalance, readTokenDecimals, readDecimalConversionRate, } from "./onchain/tokenReads.js";
|
|
11
11
|
export * from "./operations/invoice.js";
|
|
12
12
|
export * from "./operations/layerzeroScan.js";
|
|
13
13
|
export * from "./operations/liquidityManager.js";
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,YAAY,EAAE,GAAG,EAAE,GAAG,IAAI,MAAM,EAAE,eAAe,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAC5F,YAAY,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAC;AAC/C,cAAc,kBAAkB,CAAC;AACjC,OAAO,EACL,uBAAuB,EACvB,oBAAoB,EACpB,2BAA2B,EAC3B,kBAAkB,GACnB,MAAM,gBAAgB,CAAC;AACxB,cAAc,qBAAqB,CAAC;AACpC,cAAc,qBAAqB,CAAC;AACpC,cAAc,eAAe,CAAC;AAC9B,OAAO,EACL,eAAe,EACf,WAAW,EACX,wBAAwB,EACxB,gBAAgB,EAChB,cAAc,GACf,MAAM,wBAAwB,CAAC;AAChC,cAAc,qBAAqB,CAAC;AACpC,OAAO,EACL,gBAAgB,EAChB,iBAAiB,EACjB,yBAAyB,GAC1B,MAAM,yBAAyB,CAAC;AACjC,cAAc,yBAAyB,CAAC;AACxC,cAAc,+BAA+B,CAAC;AAC9C,cAAc,kCAAkC,CAAC;AACjD,cAAc,6BAA6B,CAAC;AAC5C,cAAc,yBAAyB,CAAC;AACxC,cAAc,6BAA6B,CAAC;AAC5C,cAAc,yBAAyB,CAAC;AACxC,cAAc,0BAA0B,CAAC;AACzC,cAAc,+BAA+B,CAAC;AAC9C,cAAc,sBAAsB,CAAC;AACrC,cAAc,UAAU,CAAC;AACzB,YAAY,EACV,cAAc,EACd,gBAAgB,EAChB,aAAa,EACb,mBAAmB,EACnB,iBAAiB,EACjB,uBAAuB,EACvB,qBAAqB,EACrB,mBAAmB,EACnB,oBAAoB,EACpB,mBAAmB,EACnB,4BAA4B,EAC5B,YAAY,EACZ,uBAAuB,EACvB,oBAAoB,EACpB,eAAe,EACf,gBAAgB,EAChB,WAAW,EACX,qBAAqB,EACrB,oBAAoB,EACpB,kBAAkB,EAClB,wBAAwB,GACzB,MAAM,YAAY,CAAC;AACpB,cAAc,oBAAoB,CAAC;AACnC,cAAc,iBAAiB,CAAC;AAChC,cAAc,gBAAgB,CAAC;AAC/B,OAAO,EAAE,wBAAwB,EAAE,gCAAgC,EAAE,MAAM,qBAAqB,CAAC;AACjG,YAAY,EACV,0BAA0B,EAC1B,4BAA4B,EAC5B,2BAA2B,EAC3B,uBAAuB,EACvB,qBAAqB,GACtB,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EACL,sBAAsB,EACtB,eAAe,EACf,oBAAoB,EACpB,oBAAoB,EACpB,wBAAwB,EACxB,sBAAsB,EACtB,qBAAqB,EACrB,UAAU,EACV,kBAAkB,EAClB,mBAAmB,EACnB,mBAAmB,EACnB,yBAAyB,EACzB,8BAA8B,EAC9B,mBAAmB,EACnB,kBAAkB,EAClB,kCAAkC,EAClC,cAAc,EACd,2BAA2B,GAC5B,MAAM,iBAAiB,CAAC;AACzB,YAAY,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;AACzD,YAAY,EAAE,kBAAkB,EAAE,gBAAgB,EAAE,MAAM,kCAAkC,CAAC;AAC7F,cAAc,gBAAgB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,YAAY,EAAE,GAAG,EAAE,GAAG,IAAI,MAAM,EAAE,eAAe,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAC5F,YAAY,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAC;AAC/C,cAAc,kBAAkB,CAAC;AACjC,OAAO,EACL,uBAAuB,EACvB,oBAAoB,EACpB,2BAA2B,EAC3B,kBAAkB,GACnB,MAAM,gBAAgB,CAAC;AACxB,cAAc,qBAAqB,CAAC;AACpC,cAAc,qBAAqB,CAAC;AACpC,cAAc,eAAe,CAAC;AAC9B,OAAO,EACL,eAAe,EACf,iBAAiB,EACjB,WAAW,EACX,wBAAwB,EACxB,gBAAgB,EAChB,cAAc,GACf,MAAM,wBAAwB,CAAC;AAChC,cAAc,qBAAqB,CAAC;AACpC,OAAO,EACL,gBAAgB,EAChB,gBAAgB,EAChB,iBAAiB,EACjB,yBAAyB,GAC1B,MAAM,yBAAyB,CAAC;AACjC,cAAc,yBAAyB,CAAC;AACxC,cAAc,+BAA+B,CAAC;AAC9C,cAAc,kCAAkC,CAAC;AACjD,cAAc,6BAA6B,CAAC;AAC5C,cAAc,yBAAyB,CAAC;AACxC,cAAc,6BAA6B,CAAC;AAC5C,cAAc,yBAAyB,CAAC;AACxC,cAAc,0BAA0B,CAAC;AACzC,cAAc,+BAA+B,CAAC;AAC9C,cAAc,sBAAsB,CAAC;AACrC,cAAc,UAAU,CAAC;AACzB,YAAY,EACV,cAAc,EACd,gBAAgB,EAChB,aAAa,EACb,mBAAmB,EACnB,iBAAiB,EACjB,uBAAuB,EACvB,qBAAqB,EACrB,mBAAmB,EACnB,oBAAoB,EACpB,mBAAmB,EACnB,4BAA4B,EAC5B,YAAY,EACZ,uBAAuB,EACvB,oBAAoB,EACpB,eAAe,EACf,gBAAgB,EAChB,WAAW,EACX,qBAAqB,EACrB,oBAAoB,EACpB,kBAAkB,EAClB,wBAAwB,GACzB,MAAM,YAAY,CAAC;AACpB,cAAc,oBAAoB,CAAC;AACnC,cAAc,iBAAiB,CAAC;AAChC,cAAc,gBAAgB,CAAC;AAC/B,OAAO,EAAE,wBAAwB,EAAE,gCAAgC,EAAE,MAAM,qBAAqB,CAAC;AACjG,YAAY,EACV,0BAA0B,EAC1B,4BAA4B,EAC5B,2BAA2B,EAC3B,uBAAuB,EACvB,qBAAqB,GACtB,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EACL,sBAAsB,EACtB,eAAe,EACf,oBAAoB,EACpB,oBAAoB,EACpB,wBAAwB,EACxB,sBAAsB,EACtB,qBAAqB,EACrB,UAAU,EACV,kBAAkB,EAClB,mBAAmB,EACnB,mBAAmB,EACnB,yBAAyB,EACzB,8BAA8B,EAC9B,mBAAmB,EACnB,kBAAkB,EAClB,kCAAkC,EAClC,cAAc,EACd,2BAA2B,GAC5B,MAAM,iBAAiB,CAAC;AACzB,YAAY,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;AACzD,YAAY,EAAE,kBAAkB,EAAE,gBAAgB,EAAE,MAAM,kCAAkC,CAAC;AAC7F,cAAc,gBAAgB,CAAC"}
|
package/dist/index.js
CHANGED
|
@@ -3,9 +3,9 @@ export { AGGREGATION_TREE_HEIGHT, TRANSFER_TREE_HEIGHT, GLOBAL_TRANSFER_TREE_HEI
|
|
|
3
3
|
export * from "./decider/prover.js";
|
|
4
4
|
export * from "./ic/connections.js";
|
|
5
5
|
export * from "./ic/index.js";
|
|
6
|
-
export { AdaptorArtifact, HubArtifact, LiquidityManagerArtifact, VerifierArtifact, Zerc20Artifact, } from "./onchain/contracts.js";
|
|
6
|
+
export { AdaptorArtifact, BlocklistArtifact, HubArtifact, LiquidityManagerArtifact, VerifierArtifact, Zerc20Artifact, } from "./onchain/contracts.js";
|
|
7
7
|
export * from "./onchain/decode.js";
|
|
8
|
-
export { readTokenBalance, readTokenDecimals, readDecimalConversionRate, } from "./onchain/tokenReads.js";
|
|
8
|
+
export { isBlockedAddress, readTokenBalance, readTokenDecimals, readDecimalConversionRate, } from "./onchain/tokenReads.js";
|
|
9
9
|
export * from "./operations/invoice.js";
|
|
10
10
|
export * from "./operations/layerzeroScan.js";
|
|
11
11
|
export * from "./operations/liquidityManager.js";
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAEA,cAAc,kBAAkB,CAAC;AACjC,OAAO,EACL,uBAAuB,EACvB,oBAAoB,EACpB,2BAA2B,EAC3B,kBAAkB,GACnB,MAAM,gBAAgB,CAAC;AACxB,cAAc,qBAAqB,CAAC;AACpC,cAAc,qBAAqB,CAAC;AACpC,cAAc,eAAe,CAAC;AAC9B,OAAO,EACL,eAAe,EACf,WAAW,EACX,wBAAwB,EACxB,gBAAgB,EAChB,cAAc,GACf,MAAM,wBAAwB,CAAC;AAChC,cAAc,qBAAqB,CAAC;AACpC,OAAO,EACL,gBAAgB,EAChB,iBAAiB,EACjB,yBAAyB,GAC1B,MAAM,yBAAyB,CAAC;AACjC,cAAc,yBAAyB,CAAC;AACxC,cAAc,+BAA+B,CAAC;AAC9C,cAAc,kCAAkC,CAAC;AACjD,cAAc,6BAA6B,CAAC;AAC5C,cAAc,yBAAyB,CAAC;AACxC,cAAc,6BAA6B,CAAC;AAC5C,cAAc,yBAAyB,CAAC;AACxC,cAAc,0BAA0B,CAAC;AACzC,cAAc,+BAA+B,CAAC;AAC9C,cAAc,sBAAsB,CAAC;AACrC,cAAc,UAAU,CAAC;AAwBzB,cAAc,oBAAoB,CAAC;AACnC,cAAc,iBAAiB,CAAC;AAChC,cAAc,gBAAgB,CAAC;AAC/B,OAAO,EAAE,wBAAwB,EAAE,gCAAgC,EAAE,MAAM,qBAAqB,CAAC;AAQjG,OAAO,EACL,sBAAsB,EACtB,eAAe,EACf,oBAAoB,EACpB,oBAAoB,EACpB,wBAAwB,EACxB,sBAAsB,EACtB,qBAAqB,EACrB,UAAU,EACV,kBAAkB,EAClB,mBAAmB,EACnB,mBAAmB,EACnB,yBAAyB,EACzB,8BAA8B,EAC9B,mBAAmB,EACnB,kBAAkB,EAClB,kCAAkC,EAClC,cAAc,EACd,2BAA2B,GAC5B,MAAM,iBAAiB,CAAC;AAGzB,cAAc,gBAAgB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAEA,cAAc,kBAAkB,CAAC;AACjC,OAAO,EACL,uBAAuB,EACvB,oBAAoB,EACpB,2BAA2B,EAC3B,kBAAkB,GACnB,MAAM,gBAAgB,CAAC;AACxB,cAAc,qBAAqB,CAAC;AACpC,cAAc,qBAAqB,CAAC;AACpC,cAAc,eAAe,CAAC;AAC9B,OAAO,EACL,eAAe,EACf,iBAAiB,EACjB,WAAW,EACX,wBAAwB,EACxB,gBAAgB,EAChB,cAAc,GACf,MAAM,wBAAwB,CAAC;AAChC,cAAc,qBAAqB,CAAC;AACpC,OAAO,EACL,gBAAgB,EAChB,gBAAgB,EAChB,iBAAiB,EACjB,yBAAyB,GAC1B,MAAM,yBAAyB,CAAC;AACjC,cAAc,yBAAyB,CAAC;AACxC,cAAc,+BAA+B,CAAC;AAC9C,cAAc,kCAAkC,CAAC;AACjD,cAAc,6BAA6B,CAAC;AAC5C,cAAc,yBAAyB,CAAC;AACxC,cAAc,6BAA6B,CAAC;AAC5C,cAAc,yBAAyB,CAAC;AACxC,cAAc,0BAA0B,CAAC;AACzC,cAAc,+BAA+B,CAAC;AAC9C,cAAc,sBAAsB,CAAC;AACrC,cAAc,UAAU,CAAC;AAwBzB,cAAc,oBAAoB,CAAC;AACnC,cAAc,iBAAiB,CAAC;AAChC,cAAc,gBAAgB,CAAC;AAC/B,OAAO,EAAE,wBAAwB,EAAE,gCAAgC,EAAE,MAAM,qBAAqB,CAAC;AAQjG,OAAO,EACL,sBAAsB,EACtB,eAAe,EACf,oBAAoB,EACpB,oBAAoB,EACpB,wBAAwB,EACxB,sBAAsB,EACtB,qBAAqB,EACrB,UAAU,EACV,kBAAkB,EAClB,mBAAmB,EACnB,mBAAmB,EACnB,yBAAyB,EACzB,8BAA8B,EAC9B,mBAAmB,EACnB,kBAAkB,EAClB,kCAAkC,EAClC,cAAc,EACd,2BAA2B,GAC5B,MAAM,iBAAiB,CAAC;AAGzB,cAAc,gBAAgB,CAAC"}
|
|
@@ -1,12 +1,17 @@
|
|
|
1
1
|
import { describe, expect, test } from "vitest";
|
|
2
|
-
import { AdaptorArtifact, HubArtifact, LiquidityManagerArtifact, VerifierArtifact, Zerc20Artifact, } from "../contracts.js";
|
|
2
|
+
import { AdaptorArtifact, BlocklistArtifact, HubArtifact, LiquidityManagerArtifact, VerifierArtifact, Zerc20Artifact, } from "../contracts.js";
|
|
3
3
|
describe("onchain/contracts", () => {
|
|
4
4
|
test("exports artifacts with ABI present", () => {
|
|
5
5
|
expect(AdaptorArtifact).toHaveProperty("abi");
|
|
6
|
+
expect(BlocklistArtifact).toHaveProperty("abi");
|
|
6
7
|
expect(HubArtifact).toHaveProperty("abi");
|
|
7
8
|
expect(LiquidityManagerArtifact).toHaveProperty("abi");
|
|
8
9
|
expect(VerifierArtifact).toHaveProperty("abi");
|
|
9
10
|
expect(Zerc20Artifact).toHaveProperty("abi");
|
|
10
11
|
});
|
|
12
|
+
test("BlocklistArtifact contains isBlocked function", () => {
|
|
13
|
+
const isBlockedEntry = BlocklistArtifact.abi.find((entry) => entry.type === "function" && entry.name === "isBlocked");
|
|
14
|
+
expect(isBlockedEntry).toBeDefined();
|
|
15
|
+
});
|
|
11
16
|
});
|
|
12
17
|
//# sourceMappingURL=contracts.test.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"contracts.test.js","sourceRoot":"","sources":["../../../src/onchain/__tests__/contracts.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AAChD,OAAO,EACL,eAAe,EACf,WAAW,EACX,wBAAwB,EACxB,gBAAgB,EAChB,cAAc,GACf,MAAM,iBAAiB,CAAC;AAEzB,QAAQ,CAAC,mBAAmB,EAAE,GAAG,EAAE;IACjC,IAAI,CAAC,oCAAoC,EAAE,GAAG,EAAE;QAC9C,MAAM,CAAC,eAAe,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QAC9C,MAAM,CAAC,WAAW,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QAC1C,MAAM,CAAC,wBAAwB,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QACvD,MAAM,CAAC,gBAAgB,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QAC/C,MAAM,CAAC,cAAc,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;IAC/C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
1
|
+
{"version":3,"file":"contracts.test.js","sourceRoot":"","sources":["../../../src/onchain/__tests__/contracts.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AAChD,OAAO,EACL,eAAe,EACf,iBAAiB,EACjB,WAAW,EACX,wBAAwB,EACxB,gBAAgB,EAChB,cAAc,GACf,MAAM,iBAAiB,CAAC;AAEzB,QAAQ,CAAC,mBAAmB,EAAE,GAAG,EAAE;IACjC,IAAI,CAAC,oCAAoC,EAAE,GAAG,EAAE;QAC9C,MAAM,CAAC,eAAe,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QAC9C,MAAM,CAAC,iBAAiB,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QAChD,MAAM,CAAC,WAAW,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QAC1C,MAAM,CAAC,wBAAwB,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QACvD,MAAM,CAAC,gBAAgB,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QAC/C,MAAM,CAAC,cAAc,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;IAC/C,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,+CAA+C,EAAE,GAAG,EAAE;QACzD,MAAM,cAAc,GAAG,iBAAiB,CAAC,GAAG,CAAC,IAAI,CAC/C,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,IAAI,KAAK,UAAU,IAAI,KAAK,CAAC,IAAI,KAAK,WAAW,CACnE,CAAC;QACF,MAAM,CAAC,cAAc,CAAC,CAAC,WAAW,EAAE,CAAC;IACvC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { describe, expect, test, vi } from "vitest";
|
|
2
|
-
import { readTokenBalance, readTokenDecimals, readDecimalConversionRate } from "../tokenReads.js";
|
|
2
|
+
import { isBlockedAddress, readTokenBalance, readTokenDecimals, readDecimalConversionRate, } from "../tokenReads.js";
|
|
3
3
|
function mockProvider(returnValue) {
|
|
4
4
|
return {
|
|
5
5
|
readContract: vi.fn().mockResolvedValue(returnValue),
|
|
@@ -42,6 +42,26 @@ describe("readTokenDecimals", () => {
|
|
|
42
42
|
expect(decimals).toBe(18);
|
|
43
43
|
});
|
|
44
44
|
});
|
|
45
|
+
describe("isBlockedAddress", () => {
|
|
46
|
+
test("returns true when address is blocked", async () => {
|
|
47
|
+
const provider = mockProvider(true);
|
|
48
|
+
const result = await isBlockedAddress(provider, "0xBlocklist", "0xBlocked");
|
|
49
|
+
expect(result).toBe(true);
|
|
50
|
+
expect(provider.readContract).toHaveBeenCalledWith(expect.objectContaining({
|
|
51
|
+
functionName: "isBlocked",
|
|
52
|
+
}));
|
|
53
|
+
});
|
|
54
|
+
test("returns false when address is not blocked", async () => {
|
|
55
|
+
const provider = mockProvider(false);
|
|
56
|
+
const result = await isBlockedAddress(provider, "0xBlocklist", "0xClean");
|
|
57
|
+
expect(result).toBe(false);
|
|
58
|
+
});
|
|
59
|
+
test("coerces falsy return to false", async () => {
|
|
60
|
+
const provider = mockProvider(0);
|
|
61
|
+
const result = await isBlockedAddress(provider, "0xBlocklist", "0xAccount");
|
|
62
|
+
expect(result).toBe(false);
|
|
63
|
+
});
|
|
64
|
+
});
|
|
45
65
|
describe("readDecimalConversionRate", () => {
|
|
46
66
|
test("returns bigint conversion rate", async () => {
|
|
47
67
|
const provider = mockProvider(1000000000000n);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"tokenReads.test.js","sourceRoot":"","sources":["../../../src/onchain/__tests__/tokenReads.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AACpD,OAAO,
|
|
1
|
+
{"version":3,"file":"tokenReads.test.js","sourceRoot":"","sources":["../../../src/onchain/__tests__/tokenReads.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import AdaptorArtifact from "../assets/abi/Adaptor.json";
|
|
2
|
+
import BlocklistArtifact from "../assets/abi/Blocklist.json";
|
|
2
3
|
import HubArtifact from "../assets/abi/Hub.json";
|
|
3
4
|
import LiquidityManagerArtifact from "../assets/abi/LiquidityManager.json";
|
|
4
5
|
import VerifierArtifact from "../assets/abi/Verifier.json";
|
|
@@ -9,5 +10,5 @@ import Zerc20Artifact from "../assets/abi/zERC20.json";
|
|
|
9
10
|
* Use these with `provider.readContract` / `provider.writeContract`
|
|
10
11
|
* or with framework-specific helpers (e.g. viem's `getContract`, wagmi's `useReadContracts`).
|
|
11
12
|
*/
|
|
12
|
-
export { AdaptorArtifact, HubArtifact, LiquidityManagerArtifact, VerifierArtifact, Zerc20Artifact };
|
|
13
|
+
export { AdaptorArtifact, BlocklistArtifact, HubArtifact, LiquidityManagerArtifact, VerifierArtifact, Zerc20Artifact, };
|
|
13
14
|
//# sourceMappingURL=contracts.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"contracts.d.ts","sourceRoot":"","sources":["../../src/onchain/contracts.ts"],"names":[],"mappings":"AAAA,OAAO,eAAe,MAAM,4BAA4B,CAAuB;AAC/E,OAAO,WAAW,MAAM,wBAAwB,CAAuB;AACvE,OAAO,wBAAwB,MAAM,qCAAqC,CAAuB;AACjG,OAAO,gBAAgB,MAAM,6BAA6B,CAAuB;AACjF,OAAO,cAAc,MAAM,2BAA2B,CAAuB;AAE7E;;;;;GAKG;AACH,OAAO,
|
|
1
|
+
{"version":3,"file":"contracts.d.ts","sourceRoot":"","sources":["../../src/onchain/contracts.ts"],"names":[],"mappings":"AAAA,OAAO,eAAe,MAAM,4BAA4B,CAAuB;AAC/E,OAAO,iBAAiB,MAAM,8BAA8B,CAAuB;AACnF,OAAO,WAAW,MAAM,wBAAwB,CAAuB;AACvE,OAAO,wBAAwB,MAAM,qCAAqC,CAAuB;AACjG,OAAO,gBAAgB,MAAM,6BAA6B,CAAuB;AACjF,OAAO,cAAc,MAAM,2BAA2B,CAAuB;AAE7E;;;;;GAKG;AACH,OAAO,EACL,eAAe,EACf,iBAAiB,EACjB,WAAW,EACX,wBAAwB,EACxB,gBAAgB,EAChB,cAAc,GACf,CAAC"}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import AdaptorArtifact from "../assets/abi/Adaptor.json" with { type: "json" };
|
|
2
|
+
import BlocklistArtifact from "../assets/abi/Blocklist.json" with { type: "json" };
|
|
2
3
|
import HubArtifact from "../assets/abi/Hub.json" with { type: "json" };
|
|
3
4
|
import LiquidityManagerArtifact from "../assets/abi/LiquidityManager.json" with { type: "json" };
|
|
4
5
|
import VerifierArtifact from "../assets/abi/Verifier.json" with { type: "json" };
|
|
@@ -9,5 +10,5 @@ import Zerc20Artifact from "../assets/abi/zERC20.json" with { type: "json" };
|
|
|
9
10
|
* Use these with `provider.readContract` / `provider.writeContract`
|
|
10
11
|
* or with framework-specific helpers (e.g. viem's `getContract`, wagmi's `useReadContracts`).
|
|
11
12
|
*/
|
|
12
|
-
export { AdaptorArtifact, HubArtifact, LiquidityManagerArtifact, VerifierArtifact, Zerc20Artifact };
|
|
13
|
+
export { AdaptorArtifact, BlocklistArtifact, HubArtifact, LiquidityManagerArtifact, VerifierArtifact, Zerc20Artifact, };
|
|
13
14
|
//# sourceMappingURL=contracts.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"contracts.js","sourceRoot":"","sources":["../../src/onchain/contracts.ts"],"names":[],"mappings":"AAAA,OAAO,eAAe,MAAM,4BAA4B,CAAC,OAAO,IAAI,EAAE,MAAM,EAAE,CAAC;AAC/E,OAAO,WAAW,MAAM,wBAAwB,CAAC,OAAO,IAAI,EAAE,MAAM,EAAE,CAAC;AACvE,OAAO,wBAAwB,MAAM,qCAAqC,CAAC,OAAO,IAAI,EAAE,MAAM,EAAE,CAAC;AACjG,OAAO,gBAAgB,MAAM,6BAA6B,CAAC,OAAO,IAAI,EAAE,MAAM,EAAE,CAAC;AACjF,OAAO,cAAc,MAAM,2BAA2B,CAAC,OAAO,IAAI,EAAE,MAAM,EAAE,CAAC;AAE7E;;;;;GAKG;AACH,OAAO,
|
|
1
|
+
{"version":3,"file":"contracts.js","sourceRoot":"","sources":["../../src/onchain/contracts.ts"],"names":[],"mappings":"AAAA,OAAO,eAAe,MAAM,4BAA4B,CAAC,OAAO,IAAI,EAAE,MAAM,EAAE,CAAC;AAC/E,OAAO,iBAAiB,MAAM,8BAA8B,CAAC,OAAO,IAAI,EAAE,MAAM,EAAE,CAAC;AACnF,OAAO,WAAW,MAAM,wBAAwB,CAAC,OAAO,IAAI,EAAE,MAAM,EAAE,CAAC;AACvE,OAAO,wBAAwB,MAAM,qCAAqC,CAAC,OAAO,IAAI,EAAE,MAAM,EAAE,CAAC;AACjG,OAAO,gBAAgB,MAAM,6BAA6B,CAAC,OAAO,IAAI,EAAE,MAAM,EAAE,CAAC;AACjF,OAAO,cAAc,MAAM,2BAA2B,CAAC,OAAO,IAAI,EAAE,MAAM,EAAE,CAAC;AAE7E;;;;;GAKG;AACH,OAAO,EACL,eAAe,EACf,iBAAiB,EACjB,WAAW,EACX,wBAAwB,EACxB,gBAAgB,EAChB,cAAc,GACf,CAAC"}
|
|
@@ -16,6 +16,14 @@ export declare function readTokenBalance(provider: EvmReadProvider, tokenAddress
|
|
|
16
16
|
* @returns Token decimals (defaults to 18 if the call returns an unexpected value).
|
|
17
17
|
*/
|
|
18
18
|
export declare function readTokenDecimals(provider: EvmReadProvider, tokenAddress: string): Promise<number>;
|
|
19
|
+
/**
|
|
20
|
+
* Check whether an address is on the OFAC sanctions blocklist.
|
|
21
|
+
* @param provider - EVM read provider.
|
|
22
|
+
* @param blocklistAddress - Blocklist contract address on this chain.
|
|
23
|
+
* @param account - Account address to check.
|
|
24
|
+
* @returns `true` if the address is blocked, `false` otherwise.
|
|
25
|
+
*/
|
|
26
|
+
export declare function isBlockedAddress(provider: EvmReadProvider, blocklistAddress: string, account: string): Promise<boolean>;
|
|
19
27
|
/**
|
|
20
28
|
* Read the decimal conversion rate of a zERC-20 token.
|
|
21
29
|
*
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"tokenReads.d.ts","sourceRoot":"","sources":["../../src/onchain/tokenReads.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,OAAO,KAAK,EAAE,eAAe,EAAO,MAAM,iBAAiB,CAAC;
|
|
1
|
+
{"version":3,"file":"tokenReads.d.ts","sourceRoot":"","sources":["../../src/onchain/tokenReads.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,OAAO,KAAK,EAAE,eAAe,EAAO,MAAM,iBAAiB,CAAC;AAK5D;;;;;GAKG;AACH,wBAAsB,gBAAgB,CACpC,QAAQ,EAAE,eAAe,EACzB,YAAY,EAAE,MAAM,EACpB,OAAO,EAAE,MAAM,GACd,OAAO,CAAC,MAAM,CAAC,CAQjB;AAED;;;;;GAKG;AACH,wBAAsB,iBAAiB,CACrC,QAAQ,EAAE,eAAe,EACzB,YAAY,EAAE,MAAM,GACnB,OAAO,CAAC,MAAM,CAAC,CAQjB;AAED;;;;;;GAMG;AACH,wBAAsB,gBAAgB,CACpC,QAAQ,EAAE,eAAe,EACzB,gBAAgB,EAAE,MAAM,EACxB,OAAO,EAAE,MAAM,GACd,OAAO,CAAC,OAAO,CAAC,CAQlB;AAED;;;;;;;;;GASG;AACH,wBAAsB,yBAAyB,CAC7C,QAAQ,EAAE,eAAe,EACzB,YAAY,EAAE,MAAM,GACnB,OAAO,CAAC,MAAM,CAAC,CAOjB"}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { normalizeHex } from "../utils/hex.js";
|
|
2
|
+
import BlocklistArtifact from "../assets/abi/Blocklist.json" with { type: "json" };
|
|
2
3
|
import Zerc20Artifact from "../assets/abi/zERC20.json" with { type: "json" };
|
|
3
4
|
/**
|
|
4
5
|
* Read the token balance of an account.
|
|
@@ -30,6 +31,22 @@ export async function readTokenDecimals(provider, tokenAddress) {
|
|
|
30
31
|
const numeric = Number(result);
|
|
31
32
|
return Number.isFinite(numeric) && numeric >= 0 ? Math.trunc(numeric) : 18;
|
|
32
33
|
}
|
|
34
|
+
/**
|
|
35
|
+
* Check whether an address is on the OFAC sanctions blocklist.
|
|
36
|
+
* @param provider - EVM read provider.
|
|
37
|
+
* @param blocklistAddress - Blocklist contract address on this chain.
|
|
38
|
+
* @param account - Account address to check.
|
|
39
|
+
* @returns `true` if the address is blocked, `false` otherwise.
|
|
40
|
+
*/
|
|
41
|
+
export async function isBlockedAddress(provider, blocklistAddress, account) {
|
|
42
|
+
const result = await provider.readContract({
|
|
43
|
+
address: normalizeHex(blocklistAddress),
|
|
44
|
+
abi: BlocklistArtifact.abi,
|
|
45
|
+
functionName: "isBlocked",
|
|
46
|
+
args: [normalizeHex(account)],
|
|
47
|
+
});
|
|
48
|
+
return Boolean(result);
|
|
49
|
+
}
|
|
33
50
|
/**
|
|
34
51
|
* Read the decimal conversion rate of a zERC-20 token.
|
|
35
52
|
*
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"tokenReads.js","sourceRoot":"","sources":["../../src/onchain/tokenReads.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,cAAc,MAAM,2BAA2B,CAAC,OAAO,IAAI,EAAE,MAAM,EAAE,CAAC;AAE7E;;;;;GAKG;AACH,MAAM,CAAC,KAAK,UAAU,gBAAgB,CACpC,QAAyB,EACzB,YAAoB,EACpB,OAAe;IAEf,MAAM,MAAM,GAAG,MAAM,QAAQ,CAAC,YAAY,CAAC;QACzC,OAAO,EAAE,YAAY,CAAC,YAAY,CAAQ;QAC1C,GAAG,EAAE,cAAc,CAAC,GAAG;QACvB,YAAY,EAAE,WAAW;QACzB,IAAI,EAAE,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC;KAC9B,CAAC,CAAC;IACH,OAAO,MAAM,CAAC,MAAkC,CAAC,CAAC;AACpD,CAAC;AAED;;;;;GAKG;AACH,MAAM,CAAC,KAAK,UAAU,iBAAiB,CACrC,QAAyB,EACzB,YAAoB;IAEpB,MAAM,MAAM,GAAG,MAAM,QAAQ,CAAC,YAAY,CAAC;QACzC,OAAO,EAAE,YAAY,CAAC,YAAY,CAAQ;QAC1C,GAAG,EAAE,cAAc,CAAC,GAAG;QACvB,YAAY,EAAE,UAAU;KACzB,CAAC,CAAC;IACH,MAAM,OAAO,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC;IAC/B,OAAO,MAAM,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,OAAO,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;AAC7E,CAAC;AAED;;;;;;;;;GASG;AACH,MAAM,CAAC,KAAK,UAAU,yBAAyB,CAC7C,QAAyB,EACzB,YAAoB;IAEpB,MAAM,MAAM,GAAG,MAAM,QAAQ,CAAC,YAAY,CAAC;QACzC,OAAO,EAAE,YAAY,CAAC,YAAY,CAAQ;QAC1C,GAAG,EAAE,cAAc,CAAC,GAAG;QACvB,YAAY,EAAE,uBAAuB;KACtC,CAAC,CAAC;IACH,OAAO,MAAM,CAAC,MAAkC,CAAC,CAAC;AACpD,CAAC"}
|
|
1
|
+
{"version":3,"file":"tokenReads.js","sourceRoot":"","sources":["../../src/onchain/tokenReads.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,iBAAiB,MAAM,8BAA8B,CAAC,OAAO,IAAI,EAAE,MAAM,EAAE,CAAC;AACnF,OAAO,cAAc,MAAM,2BAA2B,CAAC,OAAO,IAAI,EAAE,MAAM,EAAE,CAAC;AAE7E;;;;;GAKG;AACH,MAAM,CAAC,KAAK,UAAU,gBAAgB,CACpC,QAAyB,EACzB,YAAoB,EACpB,OAAe;IAEf,MAAM,MAAM,GAAG,MAAM,QAAQ,CAAC,YAAY,CAAC;QACzC,OAAO,EAAE,YAAY,CAAC,YAAY,CAAQ;QAC1C,GAAG,EAAE,cAAc,CAAC,GAAG;QACvB,YAAY,EAAE,WAAW;QACzB,IAAI,EAAE,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC;KAC9B,CAAC,CAAC;IACH,OAAO,MAAM,CAAC,MAAkC,CAAC,CAAC;AACpD,CAAC;AAED;;;;;GAKG;AACH,MAAM,CAAC,KAAK,UAAU,iBAAiB,CACrC,QAAyB,EACzB,YAAoB;IAEpB,MAAM,MAAM,GAAG,MAAM,QAAQ,CAAC,YAAY,CAAC;QACzC,OAAO,EAAE,YAAY,CAAC,YAAY,CAAQ;QAC1C,GAAG,EAAE,cAAc,CAAC,GAAG;QACvB,YAAY,EAAE,UAAU;KACzB,CAAC,CAAC;IACH,MAAM,OAAO,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC;IAC/B,OAAO,MAAM,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,OAAO,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;AAC7E,CAAC;AAED;;;;;;GAMG;AACH,MAAM,CAAC,KAAK,UAAU,gBAAgB,CACpC,QAAyB,EACzB,gBAAwB,EACxB,OAAe;IAEf,MAAM,MAAM,GAAG,MAAM,QAAQ,CAAC,YAAY,CAAC;QACzC,OAAO,EAAE,YAAY,CAAC,gBAAgB,CAAQ;QAC9C,GAAG,EAAE,iBAAiB,CAAC,GAAG;QAC1B,YAAY,EAAE,WAAW;QACzB,IAAI,EAAE,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC;KAC9B,CAAC,CAAC;IACH,OAAO,OAAO,CAAC,MAAM,CAAC,CAAC;AACzB,CAAC;AAED;;;;;;;;;GASG;AACH,MAAM,CAAC,KAAK,UAAU,yBAAyB,CAC7C,QAAyB,EACzB,YAAoB;IAEpB,MAAM,MAAM,GAAG,MAAM,QAAQ,CAAC,YAAY,CAAC;QACzC,OAAO,EAAE,YAAY,CAAC,YAAY,CAAQ;QAC1C,GAAG,EAAE,cAAc,CAAC,GAAG;QACvB,YAAY,EAAE,uBAAuB;KACtC,CAAC,CAAC;IACH,OAAO,MAAM,CAAC,MAAkC,CAAC,CAAC;AACpD,CAAC"}
|
|
@@ -21,6 +21,7 @@ describe("submitPrivateSendTransfer", () => {
|
|
|
21
21
|
expect(result.transactionHash).toBe("0xtxhash");
|
|
22
22
|
expect(writeProvider.writeContract).toHaveBeenCalledWith(expect.objectContaining({
|
|
23
23
|
functionName: "transfer",
|
|
24
|
+
account: writeProvider.account,
|
|
24
25
|
}));
|
|
25
26
|
expect(readProvider.waitForTransactionReceipt).toHaveBeenCalledWith({ hash: "0xtxhash" });
|
|
26
27
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"privateSendTransfer.test.js","sourceRoot":"","sources":["../../../src/operations/__tests__/privateSendTransfer.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AACpD,OAAO,EAAE,yBAAyB,EAAE,MAAM,mBAAmB,CAAC;AAG9D,QAAQ,CAAC,2BAA2B,EAAE,GAAG,EAAE;IACzC,IAAI,CAAC,yDAAyD,EAAE,KAAK,IAAI,EAAE;QACzE,MAAM,aAAa,GAAqB;YACtC,OAAO,EAAE,EAAE,OAAO,EAAE,UAA2B,EAAE;YACjD,KAAK,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE;YAChB,aAAa,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC,UAAU,CAAC;SACrD,CAAC;QACF,MAAM,YAAY,GAAoB;YACpC,YAAY,EAAE,EAAE,CAAC,EAAE,EAAE;YACrB,yBAAyB,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC,EAAE,eAAe,EAAE,UAAU,EAAE,CAAC;SACtF,CAAC;QAEF,MAAM,MAAM,GAAG,MAAM,yBAAyB,CAAC;YAC7C,aAAa;YACb,YAAY,EAAE,aAAa;YAC3B,WAAW,EAAE,YAAY;YACzB,MAAM,EAAE,KAAK;YACb,YAAY;SACb,CAAC,CAAC;QAEH,MAAM,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAChD,MAAM,CAAC,aAAa,CAAC,aAAa,CAAC,CAAC,oBAAoB,CACtD,MAAM,CAAC,gBAAgB,CAAC;YACtB,YAAY,EAAE,UAAU;
|
|
1
|
+
{"version":3,"file":"privateSendTransfer.test.js","sourceRoot":"","sources":["../../../src/operations/__tests__/privateSendTransfer.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AACpD,OAAO,EAAE,yBAAyB,EAAE,MAAM,mBAAmB,CAAC;AAG9D,QAAQ,CAAC,2BAA2B,EAAE,GAAG,EAAE;IACzC,IAAI,CAAC,yDAAyD,EAAE,KAAK,IAAI,EAAE;QACzE,MAAM,aAAa,GAAqB;YACtC,OAAO,EAAE,EAAE,OAAO,EAAE,UAA2B,EAAE;YACjD,KAAK,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE;YAChB,aAAa,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC,UAAU,CAAC;SACrD,CAAC;QACF,MAAM,YAAY,GAAoB;YACpC,YAAY,EAAE,EAAE,CAAC,EAAE,EAAE;YACrB,yBAAyB,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC,EAAE,eAAe,EAAE,UAAU,EAAE,CAAC;SACtF,CAAC;QAEF,MAAM,MAAM,GAAG,MAAM,yBAAyB,CAAC;YAC7C,aAAa;YACb,YAAY,EAAE,aAAa;YAC3B,WAAW,EAAE,YAAY;YACzB,MAAM,EAAE,KAAK;YACb,YAAY;SACb,CAAC,CAAC;QAEH,MAAM,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAChD,MAAM,CAAC,aAAa,CAAC,aAAa,CAAC,CAAC,oBAAoB,CACtD,MAAM,CAAC,gBAAgB,CAAC;YACtB,YAAY,EAAE,UAAU;YACxB,OAAO,EAAE,aAAa,CAAC,OAAO;SAC/B,CAAC,CACH,CAAC;QACF,MAAM,CAAC,YAAY,CAAC,yBAAyB,CAAC,CAAC,oBAAoB,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC,CAAC;IAC5F,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,uBAAuB,EAAE,KAAK,IAAI,EAAE;QACvC,MAAM,aAAa,GAAqB;YACtC,aAAa,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC,QAAQ,CAAC;SACnD,CAAC;QACF,MAAM,YAAY,GAAoB;YACpC,YAAY,EAAE,EAAE,CAAC,EAAE,EAAE;YACrB,yBAAyB,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC,EAAE,CAAC;SACzD,CAAC;QAEF,MAAM,yBAAyB,CAAC;YAC9B,aAAa;YACb,YAAY,EAAE,SAAS;YACvB,WAAW,EAAE,QAAQ;YACrB,MAAM,EAAE,IAAI;YACZ,YAAY,EAAE,EAAE,YAAY,EAAE,IAAI,EAAE,oBAAoB,EAAE,GAAG,EAAE;YAC/D,YAAY;SACb,CAAC,CAAC;QAEH,MAAM,CAAC,aAAa,CAAC,aAAa,CAAC,CAAC,oBAAoB,CACtD,MAAM,CAAC,gBAAgB,CAAC;YACtB,YAAY,EAAE,IAAI;YAClB,oBAAoB,EAAE,GAAG;SAC1B,CAAC,CACH,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,4DAA4D,EAAE,KAAK,IAAI,EAAE;QAC5E,MAAM,aAAa,GAAqB;YACtC,aAAa,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC,QAAQ,CAAC;SACnD,CAAC;QAEF,MAAM,MAAM,CACV,yBAAyB,CAAC;YACxB,aAAa;YACb,YAAY,EAAE,SAAS;YACvB,WAAW,EAAE,QAAQ;YACrB,MAAM,EAAE,IAAI;SACb,CAAC,CACH,CAAC,OAAO,CAAC,OAAO,CAAC,2BAA2B,CAAC,CAAC;IACjD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -78,7 +78,7 @@ export async function submitPrivateSendTransfer(params) {
|
|
|
78
78
|
abi: Zerc20Artifact.abi,
|
|
79
79
|
functionName: "transfer",
|
|
80
80
|
args: [normalizeHex(burnAddress), amount],
|
|
81
|
-
account: writeProvider.account
|
|
81
|
+
account: writeProvider.account,
|
|
82
82
|
chain: writeProvider.chain,
|
|
83
83
|
...spreadFeeOverrides(feeOverrides),
|
|
84
84
|
}));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"privateSend.js","sourceRoot":"","sources":["../../src/operations/privateSend.ts"],"names":[],"mappings":"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
|
|
1
|
+
{"version":3,"file":"privateSend.js","sourceRoot":"","sources":["../../src/operations/privateSend.ts"],"names":[],"mappings":"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"}
|
|
@@ -26,7 +26,9 @@ describe("submitRedeemTransaction", () => {
|
|
|
26
26
|
readProvider,
|
|
27
27
|
});
|
|
28
28
|
expect(result.transactionHash).toBe("0xhash");
|
|
29
|
-
expect(writeProvider.writeContract).
|
|
29
|
+
expect(writeProvider.writeContract).toHaveBeenCalledWith(expect.objectContaining({
|
|
30
|
+
account: writeProvider.account,
|
|
31
|
+
}));
|
|
30
32
|
expect(readProvider.waitForTransactionReceipt).toHaveBeenCalledWith({ hash: "0xhash" });
|
|
31
33
|
});
|
|
32
34
|
test("applies fee overrides", async () => {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"submitRedeem.test.js","sourceRoot":"","sources":["../../../../src/operations/receive/__tests__/submitRedeem.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AACpD,OAAO,EAAE,uBAAuB,EAAE,MAAM,oBAAoB,CAAC;AAI7D,SAAS,MAAM;IACb,OAAO;QACL,IAAI,EAAE,QAAQ;QACd,OAAO,EAAE,4CAA4C;QACrD,GAAG,EAAE,EAAS;QACd,YAAY,EAAE,gBAAgB;QAC9B,IAAI,EAAE,CAAC,IAAI,EAAE,EAAE,EAAE,EAAE,OAAO,EAAE,EAAE,EAAE,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,EAAE,SAAS,CAAC;KAC/E,CAAC;AACJ,CAAC;AAED,QAAQ,CAAC,yBAAyB,EAAE,GAAG,EAAE;IACvC,IAAI,CAAC,mDAAmD,EAAE,KAAK,IAAI,EAAE;QACnE,MAAM,aAAa,GAAqB;YACtC,OAAO,EAAE,EAAE,OAAO,EAAE,OAAwB,EAAE;YAC9C,KAAK,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE;YAChB,aAAa,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC,QAAQ,CAAC;SACnD,CAAC;QACF,MAAM,YAAY,GAAoB;YACpC,YAAY,EAAE,EAAE,CAAC,EAAE,EAAE;YACrB,yBAAyB,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC,EAAE,eAAe,EAAE,QAAQ,EAAE,CAAC;SACpF,CAAC;QAEF,MAAM,MAAM,GAAG,MAAM,uBAAuB,CAAC;YAC3C,aAAa;YACb,EAAE,EAAE,MAAM,EAAE;YACZ,YAAY;SACb,CAAC,CAAC;QAEH,MAAM,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC9C,MAAM,CAAC,aAAa,CAAC,aAAa,CAAC,CAAC,
|
|
1
|
+
{"version":3,"file":"submitRedeem.test.js","sourceRoot":"","sources":["../../../../src/operations/receive/__tests__/submitRedeem.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -16,7 +16,7 @@ export async function submitRedeemTransaction(params) {
|
|
|
16
16
|
abi: tx.abi,
|
|
17
17
|
functionName: tx.functionName,
|
|
18
18
|
args: [...tx.args],
|
|
19
|
-
account: writeProvider.account
|
|
19
|
+
account: writeProvider.account,
|
|
20
20
|
chain: writeProvider.chain,
|
|
21
21
|
...spreadFeeOverrides(feeOverrides),
|
|
22
22
|
}));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"submitRedeem.js","sourceRoot":"","sources":["../../../src/operations/receive/submitRedeem.ts"],"names":[],"mappings":"AAAA;;GAEG;AAGH,OAAO,EAAE,eAAe,EAAE,MAAM,gCAAgC,CAAC;AACjE,OAAO,EAAqB,kBAAkB,EAAE,MAAM,qBAAqB,CAAC;AAoB5E;;;;;GAKG;AACH,MAAM,CAAC,KAAK,UAAU,uBAAuB,CAC3C,MAAqC;IAErC,MAAM,EAAE,aAAa,EAAE,EAAE,EAAE,YAAY,EAAE,YAAY,EAAE,GAAG,MAAM,CAAC;IAEjE,MAAM,IAAI,GAAG,CAAC,MAAM,aAAa,CAAC,aAAa,CAAC;QAC9C,OAAO,EAAE,EAAE,CAAC,OAAO;QACnB,GAAG,EAAE,EAAE,CAAC,GAAyB;QACjC,YAAY,EAAE,EAAE,CAAC,YAAY;QAC7B,IAAI,EAAE,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC;QAClB,OAAO,EAAE,aAAa,CAAC,OAAO
|
|
1
|
+
{"version":3,"file":"submitRedeem.js","sourceRoot":"","sources":["../../../src/operations/receive/submitRedeem.ts"],"names":[],"mappings":"AAAA;;GAEG;AAGH,OAAO,EAAE,eAAe,EAAE,MAAM,gCAAgC,CAAC;AACjE,OAAO,EAAqB,kBAAkB,EAAE,MAAM,qBAAqB,CAAC;AAoB5E;;;;;GAKG;AACH,MAAM,CAAC,KAAK,UAAU,uBAAuB,CAC3C,MAAqC;IAErC,MAAM,EAAE,aAAa,EAAE,EAAE,EAAE,YAAY,EAAE,YAAY,EAAE,GAAG,MAAM,CAAC;IAEjE,MAAM,IAAI,GAAG,CAAC,MAAM,aAAa,CAAC,aAAa,CAAC;QAC9C,OAAO,EAAE,EAAE,CAAC,OAAO;QACnB,GAAG,EAAE,EAAE,CAAC,GAAyB;QACjC,YAAY,EAAE,EAAE,CAAC,YAAY;QAC7B,IAAI,EAAE,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC;QAClB,OAAO,EAAE,aAAa,CAAC,OAAO;QAC9B,KAAK,EAAE,aAAa,CAAC,KAAK;QAC1B,GAAG,kBAAkB,CAAC,YAAY,CAAC;KACpC,CAAC,CAAQ,CAAC;IAEX,MAAM,OAAO,GAAG,eAAe,CAAC,aAAa,EAAE,YAAY,CAAC,CAAC;IAC7D,MAAM,OAAO,CAAC,yBAAyB,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC;IAElD,OAAO,EAAE,eAAe,EAAE,IAAI,EAAE,CAAC;AACnC,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "zerc20-client-sdk",
|
|
3
|
-
"version": "0.3.
|
|
3
|
+
"version": "0.3.3",
|
|
4
4
|
"description": "Client SDK for interacting with ZERC20 rollup services from browser or node environments.",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"license": "MIT",
|
|
@@ -56,12 +56,12 @@
|
|
|
56
56
|
"viem": "^2.38.6"
|
|
57
57
|
},
|
|
58
58
|
"devDependencies": {
|
|
59
|
-
"@types/node": "25.
|
|
59
|
+
"@types/node": "25.6.0",
|
|
60
60
|
"@types/pako": "2.0.4",
|
|
61
61
|
"esbuild": "0.28.0",
|
|
62
|
-
"prettier": "3.8.
|
|
62
|
+
"prettier": "3.8.3",
|
|
63
63
|
"tsx": "4.21.0",
|
|
64
|
-
"typescript": "6.0.
|
|
65
|
-
"vitest": "4.1.
|
|
64
|
+
"typescript": "6.0.3",
|
|
65
|
+
"vitest": "4.1.4"
|
|
66
66
|
}
|
|
67
67
|
}
|