zerc20-client-sdk 0.1.15 → 0.2.0
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/README.md +239 -25
- package/dist/chain/__tests__/metadata.test.d.ts +2 -0
- package/dist/chain/__tests__/metadata.test.d.ts.map +1 -0
- package/dist/chain/__tests__/metadata.test.js +162 -0
- package/dist/chain/__tests__/metadata.test.js.map +1 -0
- package/dist/chain/index.d.ts +3 -0
- package/dist/chain/index.d.ts.map +1 -0
- package/dist/chain/index.js +2 -0
- package/dist/chain/index.js.map +1 -0
- package/dist/chain/metadata.d.ts +38 -0
- package/dist/chain/metadata.d.ts.map +1 -0
- package/dist/chain/metadata.js +158 -0
- package/dist/chain/metadata.js.map +1 -0
- package/dist/chain/types.d.ts +18 -0
- package/dist/chain/types.d.ts.map +1 -0
- package/dist/chain/types.js +2 -0
- package/dist/chain/types.js.map +1 -0
- package/dist/constants.d.ts +3 -3
- package/dist/constants.js +3 -3
- package/dist/ic/__tests__/connections.test.js +16 -152
- package/dist/ic/__tests__/connections.test.js.map +1 -1
- package/dist/ic/__tests__/recipient.test.d.ts +2 -0
- package/dist/ic/__tests__/recipient.test.d.ts.map +1 -0
- package/dist/ic/__tests__/recipient.test.js +47 -0
- package/dist/ic/__tests__/recipient.test.js.map +1 -0
- package/dist/ic/authorization.js +2 -2
- package/dist/ic/authorization.js.map +1 -1
- package/dist/ic/connections.d.ts +0 -50
- package/dist/ic/connections.d.ts.map +1 -1
- package/dist/ic/connections.js +0 -127
- package/dist/ic/connections.js.map +1 -1
- package/dist/ic/index.d.ts +4 -8
- package/dist/ic/index.d.ts.map +1 -1
- package/dist/ic/index.js +3 -8
- package/dist/ic/index.js.map +1 -1
- package/dist/ic/recipient.d.ts +10 -0
- package/dist/ic/recipient.d.ts.map +1 -1
- package/dist/ic/recipient.js +21 -1
- package/dist/ic/recipient.js.map +1 -1
- package/dist/index.d.ts +14 -5
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +8 -5
- package/dist/index.js.map +1 -1
- package/dist/onchain/__tests__/contracts.test.js +2 -32
- package/dist/onchain/__tests__/contracts.test.js.map +1 -1
- package/dist/onchain/__tests__/decode.test.d.ts +2 -0
- package/dist/onchain/__tests__/decode.test.d.ts.map +1 -0
- package/dist/onchain/__tests__/decode.test.js +155 -0
- package/dist/onchain/__tests__/decode.test.js.map +1 -0
- package/dist/onchain/__tests__/tokenReads.test.d.ts +2 -0
- package/dist/onchain/__tests__/tokenReads.test.d.ts.map +1 -0
- package/dist/onchain/__tests__/tokenReads.test.js +60 -0
- package/dist/onchain/__tests__/tokenReads.test.js.map +1 -0
- package/dist/onchain/contracts.d.ts +3 -29734
- package/dist/onchain/contracts.d.ts.map +1 -1
- package/dist/onchain/contracts.js +3 -59
- package/dist/onchain/contracts.js.map +1 -1
- package/dist/onchain/decode.d.ts +39 -0
- package/dist/onchain/decode.d.ts.map +1 -0
- package/dist/onchain/decode.js +100 -0
- package/dist/onchain/decode.js.map +1 -0
- package/dist/onchain/tokenReads.d.ts +30 -0
- package/dist/onchain/tokenReads.d.ts.map +1 -0
- package/dist/onchain/tokenReads.js +51 -0
- package/dist/onchain/tokenReads.js.map +1 -0
- package/dist/operations/__tests__/invoice.test.js +52 -1
- package/dist/operations/__tests__/invoice.test.js.map +1 -1
- package/dist/operations/__tests__/privateSendTransfer.test.d.ts +2 -0
- package/dist/operations/__tests__/privateSendTransfer.test.d.ts.map +1 -0
- package/dist/operations/__tests__/privateSendTransfer.test.js +60 -0
- package/dist/operations/__tests__/privateSendTransfer.test.js.map +1 -0
- package/dist/operations/__tests__/reexports.test.js +1 -1
- package/dist/operations/__tests__/reexports.test.js.map +1 -1
- package/dist/operations/__tests__/teleportProof.test.js +35 -75
- package/dist/operations/__tests__/teleportProof.test.js.map +1 -1
- package/dist/operations/invoice.d.ts +14 -0
- package/dist/operations/invoice.d.ts.map +1 -1
- package/dist/operations/invoice.js +22 -0
- package/dist/operations/invoice.js.map +1 -1
- package/dist/operations/layerzeroScan/__tests__/codec.decode.test.d.ts +2 -0
- package/dist/operations/layerzeroScan/__tests__/codec.decode.test.d.ts.map +1 -0
- package/dist/operations/layerzeroScan/__tests__/codec.decode.test.js +57 -0
- package/dist/operations/layerzeroScan/__tests__/codec.decode.test.js.map +1 -0
- package/dist/operations/layerzeroScan/__tests__/codec.test.d.ts +2 -0
- package/dist/operations/layerzeroScan/__tests__/codec.test.d.ts.map +1 -0
- package/dist/operations/layerzeroScan/__tests__/codec.test.js +120 -0
- package/dist/operations/layerzeroScan/__tests__/codec.test.js.map +1 -0
- package/dist/operations/layerzeroScan/__tests__/formatters.test.d.ts +2 -0
- package/dist/operations/layerzeroScan/__tests__/formatters.test.d.ts.map +1 -0
- package/dist/operations/layerzeroScan/__tests__/formatters.test.js +164 -0
- package/dist/operations/layerzeroScan/__tests__/formatters.test.js.map +1 -0
- package/dist/operations/layerzeroScan/__tests__/integration.test.d.ts +2 -0
- package/dist/operations/layerzeroScan/__tests__/integration.test.d.ts.map +1 -0
- package/dist/operations/layerzeroScan/__tests__/integration.test.js +164 -0
- package/dist/operations/layerzeroScan/__tests__/integration.test.js.map +1 -0
- package/dist/operations/layerzeroScan/__tests__/scan.test.d.ts +2 -0
- package/dist/operations/layerzeroScan/__tests__/scan.test.d.ts.map +1 -0
- package/dist/operations/layerzeroScan/__tests__/scan.test.js +103 -0
- package/dist/operations/layerzeroScan/__tests__/scan.test.js.map +1 -0
- package/dist/operations/layerzeroScan/__tests__/status.test.d.ts +2 -0
- package/dist/operations/layerzeroScan/__tests__/status.test.d.ts.map +1 -0
- package/dist/operations/layerzeroScan/__tests__/status.test.js +153 -0
- package/dist/operations/layerzeroScan/__tests__/status.test.js.map +1 -0
- package/dist/operations/layerzeroScan/codec.d.ts +34 -0
- package/dist/operations/layerzeroScan/codec.d.ts.map +1 -0
- package/dist/operations/layerzeroScan/codec.js +79 -0
- package/dist/operations/layerzeroScan/codec.js.map +1 -0
- package/dist/operations/layerzeroScan/formatters.d.ts +26 -0
- package/dist/operations/layerzeroScan/formatters.d.ts.map +1 -0
- package/dist/operations/layerzeroScan/formatters.js +75 -0
- package/dist/operations/layerzeroScan/formatters.js.map +1 -0
- package/dist/operations/layerzeroScan/index.d.ts +9 -0
- package/dist/operations/layerzeroScan/index.d.ts.map +1 -0
- package/dist/operations/layerzeroScan/index.js +12 -0
- package/dist/operations/layerzeroScan/index.js.map +1 -0
- package/dist/operations/layerzeroScan/scan.d.ts +21 -0
- package/dist/operations/layerzeroScan/scan.d.ts.map +1 -0
- package/dist/operations/layerzeroScan/scan.js +70 -0
- package/dist/operations/layerzeroScan/scan.js.map +1 -0
- package/dist/operations/layerzeroScan/status.d.ts +17 -0
- package/dist/operations/layerzeroScan/status.d.ts.map +1 -0
- package/dist/operations/layerzeroScan/status.js +178 -0
- package/dist/operations/layerzeroScan/status.js.map +1 -0
- package/dist/operations/layerzeroScan/types.d.ts +181 -0
- package/dist/operations/layerzeroScan/types.d.ts.map +1 -0
- package/dist/operations/layerzeroScan/types.js +5 -0
- package/dist/operations/layerzeroScan/types.js.map +1 -0
- package/dist/operations/layerzeroScan.d.ts +5 -0
- package/dist/operations/layerzeroScan.d.ts.map +1 -0
- package/dist/operations/layerzeroScan.js +5 -0
- package/dist/operations/layerzeroScan.js.map +1 -0
- package/dist/operations/liquidityManager/__tests__/balance.test.js +24 -37
- package/dist/operations/liquidityManager/__tests__/balance.test.js.map +1 -1
- package/dist/operations/liquidityManager/__tests__/crossUnwrap.test.js +51 -31
- package/dist/operations/liquidityManager/__tests__/crossUnwrap.test.js.map +1 -1
- package/dist/operations/liquidityManager/__tests__/helpers.test.js +11 -8
- package/dist/operations/liquidityManager/__tests__/helpers.test.js.map +1 -1
- package/dist/operations/liquidityManager/__tests__/unwrap.test.js +68 -82
- package/dist/operations/liquidityManager/__tests__/unwrap.test.js.map +1 -1
- package/dist/operations/liquidityManager/__tests__/wrap.test.js +55 -64
- package/dist/operations/liquidityManager/__tests__/wrap.test.js.map +1 -1
- package/dist/operations/liquidityManager/abi.d.ts +57 -0
- package/dist/operations/liquidityManager/abi.d.ts.map +1 -0
- package/dist/operations/liquidityManager/abi.js +41 -0
- package/dist/operations/liquidityManager/abi.js.map +1 -0
- package/dist/operations/liquidityManager/balance.d.ts +3 -3
- package/dist/operations/liquidityManager/balance.d.ts.map +1 -1
- package/dist/operations/liquidityManager/balance.js +22 -15
- package/dist/operations/liquidityManager/balance.js.map +1 -1
- package/dist/operations/liquidityManager/crossUnwrap.d.ts +13 -11
- package/dist/operations/liquidityManager/crossUnwrap.d.ts.map +1 -1
- package/dist/operations/liquidityManager/crossUnwrap.js +44 -20
- package/dist/operations/liquidityManager/crossUnwrap.js.map +1 -1
- package/dist/operations/liquidityManager/helpers.d.ts +10 -15474
- package/dist/operations/liquidityManager/helpers.d.ts.map +1 -1
- package/dist/operations/liquidityManager/helpers.js +28 -18
- package/dist/operations/liquidityManager/helpers.js.map +1 -1
- package/dist/operations/liquidityManager/index.d.ts +1 -0
- package/dist/operations/liquidityManager/index.d.ts.map +1 -1
- package/dist/operations/liquidityManager/index.js +2 -0
- package/dist/operations/liquidityManager/index.js.map +1 -1
- package/dist/operations/liquidityManager/types.d.ts +1 -1
- package/dist/operations/liquidityManager/types.d.ts.map +1 -1
- package/dist/operations/liquidityManager/unwrap.d.ts +9 -9
- package/dist/operations/liquidityManager/unwrap.d.ts.map +1 -1
- package/dist/operations/liquidityManager/unwrap.js +48 -24
- package/dist/operations/liquidityManager/unwrap.js.map +1 -1
- package/dist/operations/liquidityManager/wrap.d.ts +7 -7
- package/dist/operations/liquidityManager/wrap.d.ts.map +1 -1
- package/dist/operations/liquidityManager/wrap.js +35 -16
- package/dist/operations/liquidityManager/wrap.js.map +1 -1
- package/dist/operations/privateSend.d.ts +33 -0
- package/dist/operations/privateSend.d.ts.map +1 -1
- package/dist/operations/privateSend.js +26 -0
- package/dist/operations/privateSend.js.map +1 -1
- package/dist/operations/receive/__tests__/announcementStatus.test.js +34 -11
- package/dist/operations/receive/__tests__/announcementStatus.test.js.map +1 -1
- package/dist/operations/receive/__tests__/cache.test.js +28 -167
- package/dist/operations/receive/__tests__/cache.test.js.map +1 -1
- package/dist/operations/receive/__tests__/createVerifierReader.test.d.ts +2 -0
- package/dist/operations/receive/__tests__/createVerifierReader.test.d.ts.map +1 -0
- package/dist/operations/receive/__tests__/createVerifierReader.test.js +28 -0
- package/dist/operations/receive/__tests__/createVerifierReader.test.js.map +1 -0
- package/dist/operations/receive/__tests__/helpers.test.js +9 -9
- package/dist/operations/receive/__tests__/helpers.test.js.map +1 -1
- package/dist/operations/receive/__tests__/redeemTransaction.test.d.ts +2 -0
- package/dist/operations/receive/__tests__/redeemTransaction.test.d.ts.map +1 -0
- package/dist/operations/receive/__tests__/redeemTransaction.test.js +258 -0
- package/dist/operations/receive/__tests__/redeemTransaction.test.js.map +1 -0
- package/dist/operations/receive/__tests__/submitRedeem.test.d.ts +2 -0
- package/dist/operations/receive/__tests__/submitRedeem.test.d.ts.map +1 -0
- package/dist/operations/receive/__tests__/submitRedeem.test.js +58 -0
- package/dist/operations/receive/__tests__/submitRedeem.test.js.map +1 -0
- package/dist/operations/receive/announcementStatus.d.ts +1 -1
- package/dist/operations/receive/announcementStatus.d.ts.map +1 -1
- package/dist/operations/receive/announcementStatus.js +7 -5
- package/dist/operations/receive/announcementStatus.js.map +1 -1
- package/dist/operations/receive/cache.d.ts +0 -18
- package/dist/operations/receive/cache.d.ts.map +1 -1
- package/dist/operations/receive/cache.js +0 -30
- package/dist/operations/receive/cache.js.map +1 -1
- package/dist/operations/receive/helpers.d.ts +14 -3
- package/dist/operations/receive/helpers.d.ts.map +1 -1
- package/dist/operations/receive/helpers.js +33 -3
- package/dist/operations/receive/helpers.js.map +1 -1
- package/dist/operations/receive/index.d.ts +6 -2
- package/dist/operations/receive/index.d.ts.map +1 -1
- package/dist/operations/receive/index.js +6 -1
- package/dist/operations/receive/index.js.map +1 -1
- package/dist/operations/receive/redeemTransaction.d.ts +30 -0
- package/dist/operations/receive/redeemTransaction.d.ts.map +1 -0
- package/dist/operations/receive/redeemTransaction.js +104 -0
- package/dist/operations/receive/redeemTransaction.js.map +1 -0
- package/dist/operations/receive/submitRedeem.d.ts +32 -0
- package/dist/operations/receive/submitRedeem.d.ts.map +1 -0
- package/dist/operations/receive/submitRedeem.js +27 -0
- package/dist/operations/receive/submitRedeem.js.map +1 -0
- package/dist/operations/receive/types.d.ts +53 -5
- package/dist/operations/receive/types.d.ts.map +1 -1
- package/dist/operations/teleportProof.d.ts +10 -31
- package/dist/operations/teleportProof.d.ts.map +1 -1
- package/dist/operations/teleportProof.js +14 -26
- package/dist/operations/teleportProof.js.map +1 -1
- package/dist/registry/__tests__/helpers.test.js +2 -44
- package/dist/registry/__tests__/helpers.test.js.map +1 -1
- package/dist/registry/__tests__/loader.test.js +17 -191
- package/dist/registry/__tests__/loader.test.js.map +1 -1
- package/dist/registry/__tests__/normalize.test.js +109 -1
- package/dist/registry/__tests__/normalize.test.js.map +1 -1
- package/dist/registry/helpers.d.ts +0 -7
- package/dist/registry/helpers.d.ts.map +1 -1
- package/dist/registry/helpers.js +0 -14
- package/dist/registry/helpers.js.map +1 -1
- package/dist/registry/index.d.ts +5 -5
- package/dist/registry/index.d.ts.map +1 -1
- package/dist/registry/index.js +4 -4
- package/dist/registry/index.js.map +1 -1
- package/dist/registry/loader.d.ts +0 -25
- package/dist/registry/loader.d.ts.map +1 -1
- package/dist/registry/loader.js +0 -68
- package/dist/registry/loader.js.map +1 -1
- package/dist/registry/normalize.d.ts +13 -1
- package/dist/registry/normalize.d.ts.map +1 -1
- package/dist/registry/normalize.js +43 -0
- package/dist/registry/normalize.js.map +1 -1
- package/dist/registry/types.d.ts +13 -2
- package/dist/registry/types.d.ts.map +1 -1
- package/dist/types/__tests__/evm.test.d.ts +2 -0
- package/dist/types/__tests__/evm.test.d.ts.map +1 -0
- package/dist/types/__tests__/evm.test.js +15 -0
- package/dist/types/__tests__/evm.test.js.map +1 -0
- package/dist/types/evm.d.ts +95 -0
- package/dist/types/evm.d.ts.map +1 -0
- package/dist/types/evm.js +11 -0
- package/dist/types/evm.js.map +1 -0
- package/dist/types.d.ts +15 -13
- package/dist/types.d.ts.map +1 -1
- package/dist/utils/__tests__/fees.test.js +66 -29
- package/dist/utils/__tests__/fees.test.js.map +1 -1
- package/dist/utils/__tests__/hex.test.js +64 -1
- package/dist/utils/__tests__/hex.test.js.map +1 -1
- package/dist/utils/__tests__/http.test.js +2 -64
- package/dist/utils/__tests__/http.test.js.map +1 -1
- package/dist/utils/fees.d.ts +7 -2
- package/dist/utils/fees.d.ts.map +1 -1
- package/dist/utils/fees.js +32 -16
- package/dist/utils/fees.js.map +1 -1
- package/dist/utils/hex.d.ts +11 -0
- package/dist/utils/hex.d.ts.map +1 -1
- package/dist/utils/hex.js +16 -1
- package/dist/utils/hex.js.map +1 -1
- package/dist/utils/http.d.ts +0 -27
- package/dist/utils/http.d.ts.map +1 -1
- package/dist/utils/http.js +0 -36
- package/dist/utils/http.js.map +1 -1
- package/dist/wasm/__tests__/functions.test.js +56 -1
- package/dist/wasm/__tests__/functions.test.js.map +1 -1
- package/dist/wasm/functions.d.ts +6 -0
- package/dist/wasm/functions.d.ts.map +1 -1
- package/dist/wasm/functions.js +17 -0
- package/dist/wasm/functions.js.map +1 -1
- package/dist/wasm/index.d.ts +1 -1
- package/dist/wasm/index.d.ts.map +1 -1
- package/dist/wasm/index.js +1 -1
- package/dist/wasm/index.js.map +1 -1
- package/dist/zkp/__tests__/proofService.test.js +34 -52
- package/dist/zkp/__tests__/proofService.test.js.map +1 -1
- package/dist/zkp/__tests__/workerClient.test.js +1 -40
- package/dist/zkp/__tests__/workerClient.test.js.map +1 -1
- package/dist/zkp/index.d.ts +1 -1
- package/dist/zkp/index.d.ts.map +1 -1
- package/dist/zkp/index.js +1 -1
- package/dist/zkp/index.js.map +1 -1
- package/dist/zkp/proofService.d.ts +6 -2
- package/dist/zkp/proofService.d.ts.map +1 -1
- package/dist/zkp/proofService.js +12 -15
- package/dist/zkp/proofService.js.map +1 -1
- package/dist/zkp/worker.js +13 -137
- package/dist/zkp/worker.js.map +1 -1
- package/dist/zkp/workerClient.d.ts +0 -24
- package/dist/zkp/workerClient.d.ts.map +1 -1
- package/dist/zkp/workerClient.js +0 -36
- package/dist/zkp/workerClient.js.map +1 -1
- package/package.json +3 -4
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"helpers.d.ts","sourceRoot":"","sources":["../../../src/operations/liquidityManager/helpers.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,KAAK,EAAE,YAAY,EAAE,YAAY,EAAE,MAAM,MAAM,CAAC;AAKvD,KAAK,cAAc,GAAG,YAAY,GAAG,YAAY,CAAC;AAElD;;;GAGG;AACH,eAAO,MAAM,oBAAoB,EAAmD,KAAK,MAAM,EAAE,CAAC;AAElG,0CAA0C;AAC1C,eAAO,MAAM,eAAe,KAAK,CAAC;AAElC;;;GAGG;AACH,wBAAgB,gBAAgB,CAAC,OAAO,EAAE,KAAK,MAAM,EAAE,EAAE,MAAM,EAAE,cAAc;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAM9E;AAED;;;;GAIG;AACH,wBAAgB,aAAa,CAAC,YAAY,EAAE,YAAY,GAAG,KAAK,MAAM,EAAE,CAMvE;AAED;;;GAGG;AACH,wBAAgB,aAAa,CAC3B,YAAY,EAAE,YAAY,EAC1B,YAAY,CAAC,EAAE,YAAY,GAC1B,cAAc,CAEhB;AAED;;;;;;GAMG;AACH,wBAAgB,gBAAgB,CAAC,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,GAAG,MAAM,CAKtE;AAED;;;;GAIG;AACH,wBAAgB,gBAAgB,CAAC,KAAK,EAAE,MAAM,GAAG,KAAK,MAAM,EAAE,CAE7D;AAED;;;GAGG;AACH,wBAAgB,aAAa,CAAC,OAAO,EAAE,KAAK,MAAM,EAAE,GAAG,OAAO,CAE7D;AAED;;;;;;GAMG;AACH,wBAAgB,UAAU,CAAC,MAAM,EAAE,MAAM,EAAE,qBAAqB,EAAE,MAAM,GAAG,MAAM,CAEhF"}
|
|
1
|
+
{"version":3,"file":"helpers.d.ts","sourceRoot":"","sources":["../../../src/operations/liquidityManager/helpers.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,KAAK,EAAE,eAAe,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AAG5E;;;GAGG;AACH,eAAO,MAAM,oBAAoB,EAAmD,KAAK,MAAM,EAAE,CAAC;AAElG,0CAA0C;AAC1C,eAAO,MAAM,eAAe,KAAK,CAAC;AAElC;;;;GAIG;AACH,wBAAgB,aAAa,CAAC,QAAQ,EAAE,gBAAgB,GAAG,KAAK,MAAM,EAAE,CAMvE;AAED;;;;GAIG;AACH,wBAAgB,mBAAmB,CACjC,aAAa,EAAE,gBAAgB,EAC/B,YAAY,CAAC,EAAE,eAAe,GAC7B,eAAe,CAOjB;AAED;;;;GAIG;AACH,wBAAgB,eAAe,CAC7B,aAAa,EAAE,gBAAgB,EAC/B,YAAY,CAAC,EAAE,eAAe,GAC7B,QAAQ,CAAC,IAAI,CAAC,eAAe,EAAE,2BAA2B,CAAC,CAAC,CAW9D;AAED;;;;;;GAMG;AACH,wBAAgB,gBAAgB,CAAC,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,GAAG,MAAM,CAKtE;AAED;;;;GAIG;AACH,wBAAgB,gBAAgB,CAAC,KAAK,EAAE,MAAM,GAAG,KAAK,MAAM,EAAE,CAE7D;AAED;;;GAGG;AACH,wBAAgB,aAAa,CAAC,OAAO,EAAE,KAAK,MAAM,EAAE,GAAG,OAAO,CAE7D;AAED;;;;;;GAMG;AACH,wBAAgB,UAAU,CAAC,MAAM,EAAE,MAAM,EAAE,qBAAqB,EAAE,MAAM,GAAG,MAAM,CAEhF"}
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* Internal helper functions for liquidity manager operations.
|
|
3
3
|
*/
|
|
4
|
-
import { erc20Abi, getContract } from "viem";
|
|
5
4
|
import { normalizeHex, toBigInt } from "../../utils/hex.js";
|
|
6
5
|
/**
|
|
7
6
|
* Sentinel address used by liquidity manager contracts to represent the native token.
|
|
@@ -11,34 +10,45 @@ export const NATIVE_TOKEN_ADDRESS = "0xeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee"
|
|
|
11
10
|
/** Decimals assumed for native tokens. */
|
|
12
11
|
export const NATIVE_DECIMALS = 18;
|
|
13
12
|
/**
|
|
14
|
-
*
|
|
13
|
+
* Resolve the default account address from an `EvmWriteProvider`.
|
|
14
|
+
* @throws If the provider has no default account configured.
|
|
15
15
|
* @internal
|
|
16
16
|
*/
|
|
17
|
-
export function
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
17
|
+
export function ensureAccount(provider) {
|
|
18
|
+
const account = provider.account?.address;
|
|
19
|
+
if (!account) {
|
|
20
|
+
throw new Error("writeProvider is missing default account");
|
|
21
|
+
}
|
|
22
|
+
return normalizeHex(account);
|
|
23
23
|
}
|
|
24
24
|
/**
|
|
25
|
-
* Resolve the
|
|
26
|
-
* @throws If
|
|
25
|
+
* Resolve a read provider, falling back to the write provider if it supports `readContract`.
|
|
26
|
+
* @throws If neither `readProvider` nor `writeProvider` has `readContract`.
|
|
27
27
|
* @internal
|
|
28
28
|
*/
|
|
29
|
-
export function
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
29
|
+
export function resolveReadProvider(writeProvider, readProvider) {
|
|
30
|
+
if (readProvider)
|
|
31
|
+
return readProvider;
|
|
32
|
+
const wp = writeProvider;
|
|
33
|
+
if (typeof wp.readContract === "function") {
|
|
34
|
+
return wp;
|
|
33
35
|
}
|
|
34
|
-
|
|
36
|
+
throw new Error("readProvider is required: writeProvider does not support readContract");
|
|
35
37
|
}
|
|
36
38
|
/**
|
|
37
|
-
* Choose which
|
|
39
|
+
* Choose which provider should be used for transaction receipt polling.
|
|
40
|
+
* @throws If neither `readProvider` nor `writeProvider` has `waitForTransactionReceipt`.
|
|
38
41
|
* @internal
|
|
39
42
|
*/
|
|
40
|
-
export function
|
|
41
|
-
|
|
43
|
+
export function receiptProvider(writeProvider, readProvider) {
|
|
44
|
+
if (readProvider?.waitForTransactionReceipt) {
|
|
45
|
+
return readProvider;
|
|
46
|
+
}
|
|
47
|
+
const wp = writeProvider;
|
|
48
|
+
if (typeof wp.waitForTransactionReceipt === "function") {
|
|
49
|
+
return wp;
|
|
50
|
+
}
|
|
51
|
+
throw new Error("readProvider is required: writeProvider does not support waitForTransactionReceipt");
|
|
42
52
|
}
|
|
43
53
|
/**
|
|
44
54
|
* Convert a value to bigint, accepting common "bigint-like" inputs.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"helpers.js","sourceRoot":"","sources":["../../../src/operations/liquidityManager/helpers.ts"],"names":[],"mappings":"AAAA;;GAEG;AAGH,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"helpers.js","sourceRoot":"","sources":["../../../src/operations/liquidityManager/helpers.ts"],"names":[],"mappings":"AAAA;;GAEG;AAGH,OAAO,EAAE,YAAY,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAC;AAE5D;;;GAGG;AACH,MAAM,CAAC,MAAM,oBAAoB,GAAG,4CAA6D,CAAC;AAElG,0CAA0C;AAC1C,MAAM,CAAC,MAAM,eAAe,GAAG,EAAE,CAAC;AAElC;;;;GAIG;AACH,MAAM,UAAU,aAAa,CAAC,QAA0B;IACtD,MAAM,OAAO,GAAG,QAAQ,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1C,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,MAAM,IAAI,KAAK,CAAC,0CAA0C,CAAC,CAAC;IAC9D,CAAC;IACD,OAAO,YAAY,CAAC,OAAO,CAAkB,CAAC;AAChD,CAAC;AAED;;;;GAIG;AACH,MAAM,UAAU,mBAAmB,CACjC,aAA+B,EAC/B,YAA8B;IAE9B,IAAI,YAAY;QAAE,OAAO,YAAY,CAAC;IACtC,MAAM,EAAE,GAAG,aAAoD,CAAC;IAChE,IAAI,OAAO,EAAE,CAAC,YAAY,KAAK,UAAU,EAAE,CAAC;QAC1C,OAAO,EAAqB,CAAC;IAC/B,CAAC;IACD,MAAM,IAAI,KAAK,CAAC,uEAAuE,CAAC,CAAC;AAC3F,CAAC;AAED;;;;GAIG;AACH,MAAM,UAAU,eAAe,CAC7B,aAA+B,EAC/B,YAA8B;IAE9B,IAAI,YAAY,EAAE,yBAAyB,EAAE,CAAC;QAC5C,OAAO,YAA4E,CAAC;IACtF,CAAC;IACD,MAAM,EAAE,GAAG,aAAoD,CAAC;IAChE,IAAI,OAAO,EAAE,CAAC,yBAAyB,KAAK,UAAU,EAAE,CAAC;QACvD,OAAO,EAAkE,CAAC;IAC5E,CAAC;IACD,MAAM,IAAI,KAAK,CACb,oFAAoF,CACrF,CAAC;AACJ,CAAC;AAED;;;;;;GAMG;AACH,MAAM,UAAU,gBAAgB,CAAC,KAAc,EAAE,KAAa;IAC5D,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;QACxF,OAAO,QAAQ,CAAC,KAAK,CAAC,CAAC;IACzB,CAAC;IACD,MAAM,IAAI,KAAK,CAAC,GAAG,KAAK,4BAA4B,CAAC,CAAC;AACxD,CAAC;AAED;;;;GAIG;AACH,MAAM,UAAU,gBAAgB,CAAC,KAAa;IAC5C,OAAO,YAAY,CAAC,KAAK,CAAkB,CAAC;AAC9C,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,aAAa,CAAC,OAAsB;IAClD,OAAO,OAAO,KAAK,oBAAoB,CAAC;AAC1C,CAAC;AAED;;;;;;GAMG;AACH,MAAM,UAAU,UAAU,CAAC,MAAc,EAAE,qBAA6B;IACtE,OAAO,MAAM,GAAG,CAAC,MAAM,GAAG,qBAAqB,CAAC,CAAC;AACnD,CAAC"}
|
|
@@ -9,4 +9,5 @@ export type { LocalUnwrapParams } from "./unwrap.js";
|
|
|
9
9
|
export { quoteLocalUnwrap, unwrapWithLiquidityManager } from "./unwrap.js";
|
|
10
10
|
export type { CrossUnwrapQuoteParams, CrossUnwrapSendParams } from "./crossUnwrap.js";
|
|
11
11
|
export { applySlippage, buildCrossUnwrapQuote, sendCrossUnwrap } from "./crossUnwrap.js";
|
|
12
|
+
export { removeDust } from "./helpers.js";
|
|
12
13
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/operations/liquidityManager/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AAGH,YAAY,EACV,qBAAqB,EACrB,gBAAgB,EAChB,iBAAiB,EACjB,aAAa,EACb,SAAS,EACT,gBAAgB,GACjB,MAAM,YAAY,CAAC;AAGpB,OAAO,EAAE,6BAA6B,EAAE,MAAM,cAAc,CAAC;AAG7D,YAAY,EAAE,8BAA8B,EAAE,MAAM,WAAW,CAAC;AAChE,OAAO,EAAE,wBAAwB,EAAE,MAAM,WAAW,CAAC;AAGrD,YAAY,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC;AACrD,OAAO,EAAE,gBAAgB,EAAE,0BAA0B,EAAE,MAAM,aAAa,CAAC;AAG3E,YAAY,EAAE,sBAAsB,EAAE,qBAAqB,EAAE,MAAM,kBAAkB,CAAC;AACtF,OAAO,EAAE,aAAa,EAAE,qBAAqB,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/operations/liquidityManager/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AAGH,YAAY,EACV,qBAAqB,EACrB,gBAAgB,EAChB,iBAAiB,EACjB,aAAa,EACb,SAAS,EACT,gBAAgB,GACjB,MAAM,YAAY,CAAC;AAGpB,OAAO,EAAE,6BAA6B,EAAE,MAAM,cAAc,CAAC;AAG7D,YAAY,EAAE,8BAA8B,EAAE,MAAM,WAAW,CAAC;AAChE,OAAO,EAAE,wBAAwB,EAAE,MAAM,WAAW,CAAC;AAGrD,YAAY,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC;AACrD,OAAO,EAAE,gBAAgB,EAAE,0BAA0B,EAAE,MAAM,aAAa,CAAC;AAG3E,YAAY,EAAE,sBAAsB,EAAE,qBAAqB,EAAE,MAAM,kBAAkB,CAAC;AACtF,OAAO,EAAE,aAAa,EAAE,qBAAqB,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAC;AAGzF,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC"}
|
|
@@ -6,4 +6,6 @@ export { fetchLiquidityManagerBalances } from "./balance.js";
|
|
|
6
6
|
export { wrapWithLiquidityManager } from "./wrap.js";
|
|
7
7
|
export { quoteLocalUnwrap, unwrapWithLiquidityManager } from "./unwrap.js";
|
|
8
8
|
export { applySlippage, buildCrossUnwrapQuote, sendCrossUnwrap } from "./crossUnwrap.js";
|
|
9
|
+
// Helpers
|
|
10
|
+
export { removeDust } from "./helpers.js";
|
|
9
11
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/operations/liquidityManager/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AAYH,qBAAqB;AACrB,OAAO,EAAE,6BAA6B,EAAE,MAAM,cAAc,CAAC;AAI7D,OAAO,EAAE,wBAAwB,EAAE,MAAM,WAAW,CAAC;AAIrD,OAAO,EAAE,gBAAgB,EAAE,0BAA0B,EAAE,MAAM,aAAa,CAAC;AAI3E,OAAO,EAAE,aAAa,EAAE,qBAAqB,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/operations/liquidityManager/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AAYH,qBAAqB;AACrB,OAAO,EAAE,6BAA6B,EAAE,MAAM,cAAc,CAAC;AAI7D,OAAO,EAAE,wBAAwB,EAAE,MAAM,WAAW,CAAC;AAIrD,OAAO,EAAE,gBAAgB,EAAE,0BAA0B,EAAE,MAAM,aAAa,CAAC;AAI3E,OAAO,EAAE,aAAa,EAAE,qBAAqB,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAC;AAEzF,UAAU;AACV,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/operations/liquidityManager/types.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/operations/liquidityManager/types.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,oBAAoB,CAAC;AAE9C;;;;GAIG;AACH,MAAM,WAAW,qBAAqB;IACpC,mEAAmE;IACnE,eAAe,EAAE,MAAM,CAAC;IACxB,6FAA6F;IAC7F,uBAAuB,CAAC,EAAE,MAAM,CAAC;CAClC;AAED;;;GAGG;AACH,MAAM,WAAW,gBAAgB;IAC/B,uDAAuD;IACvD,GAAG,EAAE,MAAM,CAAC;IACZ,sDAAsD;IACtD,WAAW,EAAE,MAAM,CAAC;CACrB;AAED;;GAEG;AACH,MAAM,WAAW,iBAAiB;IAChC,uEAAuE;IACvE,iBAAiB,EAAE,KAAK,MAAM,EAAE,CAAC;IACjC,uDAAuD;IACvD,iBAAiB,EAAE,MAAM,CAAC;IAC1B,gEAAgE;IAChE,kBAAkB,EAAE,MAAM,CAAC;IAC3B,mDAAmD;IACnD,aAAa,EAAE,MAAM,CAAC;IACtB,qCAAqC;IACrC,cAAc,EAAE,MAAM,CAAC;CACxB;AAED;;;GAGG;AACH,MAAM,WAAW,aAAa;IAC5B,MAAM,EAAE,MAAM,CAAC;IACf,EAAE,EAAE,KAAK,MAAM,EAAE,CAAC;IAClB,yEAAyE;IACzE,YAAY,EAAE,MAAM,CAAC;IACrB,YAAY,EAAE,GAAG,CAAC;IAClB,UAAU,EAAE,GAAG,CAAC;IAChB,MAAM,EAAE,GAAG,CAAC;CACb;AAED;;;;GAIG;AACH,MAAM,WAAW,SAAS;IACxB,MAAM,EAAE,MAAM,CAAC;IACf,EAAE,EAAE,GAAG,CAAC;IACR,qCAAqC;IACrC,QAAQ,EAAE,MAAM,CAAC;IACjB,wEAAwE;IACxE,WAAW,EAAE,MAAM,CAAC;IACpB,YAAY,EAAE,GAAG,CAAC;IAClB,UAAU,EAAE,GAAG,CAAC;IAChB,MAAM,EAAE,GAAG,CAAC;CACb;AAED;;;GAGG;AACH,MAAM,WAAW,gBAAgB;IAC/B,0EAA0E;IAC1E,cAAc,EAAE,MAAM,CAAC;IACvB,uEAAuE;IACvE,eAAe,EAAE,MAAM,CAAC;IACxB,mDAAmD;IACnD,cAAc,EAAE,MAAM,CAAC;IACvB,4EAA4E;IAC5E,aAAa,EAAE,MAAM,CAAC;IACtB,kGAAkG;IAClG,WAAW,EAAE,MAAM,CAAC;IACpB,6CAA6C;IAC7C,SAAS,EAAE,SAAS,CAAC;IACrB,2EAA2E;IAC3E,aAAa,EAAE,aAAa,CAAC;CAC9B"}
|
|
@@ -1,17 +1,17 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* Local unwrap operations for liquidity manager.
|
|
3
3
|
*/
|
|
4
|
-
import type {
|
|
5
|
-
import type
|
|
4
|
+
import type { EvmReadProvider, EvmWriteProvider } from "../../types/evm.js";
|
|
5
|
+
import { type FeeOverrides } from "../../utils/fees.js";
|
|
6
6
|
import type { LiquidityActionResult, LocalUnwrapQuote } from "./types.js";
|
|
7
7
|
/**
|
|
8
8
|
* Parameters for `unwrapWithLiquidityManager`.
|
|
9
9
|
*/
|
|
10
10
|
export interface LocalUnwrapParams {
|
|
11
|
-
/**
|
|
12
|
-
|
|
13
|
-
/** Optional
|
|
14
|
-
|
|
11
|
+
/** Write provider used to sign and submit transactions. */
|
|
12
|
+
writeProvider: EvmWriteProvider;
|
|
13
|
+
/** Optional read provider for reads and receipt polling. */
|
|
14
|
+
readProvider?: EvmReadProvider;
|
|
15
15
|
/** Liquidity manager contract address. */
|
|
16
16
|
liquidityManagerAddress: string;
|
|
17
17
|
/** zERC20 token contract address. */
|
|
@@ -20,7 +20,7 @@ export interface LocalUnwrapParams {
|
|
|
20
20
|
amount: bigint | number | string;
|
|
21
21
|
/** Recipient of the underlying token. Defaults to the wallet's account. */
|
|
22
22
|
recipient?: string;
|
|
23
|
-
/** Optional
|
|
23
|
+
/** Optional fee overrides (e.g., gas, maxFeePerGas). */
|
|
24
24
|
feeOverrides?: FeeOverrides;
|
|
25
25
|
/**
|
|
26
26
|
* Minimum acceptable output amount.
|
|
@@ -32,12 +32,12 @@ export interface LocalUnwrapParams {
|
|
|
32
32
|
}
|
|
33
33
|
/**
|
|
34
34
|
* Quote local unwrap fee and expected output for a given amount.
|
|
35
|
-
* @param params.
|
|
35
|
+
* @param params.provider - Provider to use for contract reads.
|
|
36
36
|
* @param params.liquidityManagerAddress - Liquidity manager contract address.
|
|
37
37
|
* @param params.amount - Amount to unwrap (bigint-like).
|
|
38
38
|
*/
|
|
39
39
|
export declare function quoteLocalUnwrap(params: {
|
|
40
|
-
|
|
40
|
+
provider: EvmReadProvider;
|
|
41
41
|
liquidityManagerAddress: string;
|
|
42
42
|
amount: bigint | number | string;
|
|
43
43
|
}): Promise<LocalUnwrapQuote>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"unwrap.d.ts","sourceRoot":"","sources":["../../../src/operations/liquidityManager/unwrap.ts"],"names":[],"mappings":"AAAA;;GAEG;
|
|
1
|
+
{"version":3,"file":"unwrap.d.ts","sourceRoot":"","sources":["../../../src/operations/liquidityManager/unwrap.ts"],"names":[],"mappings":"AAAA;;GAEG;AAIH,OAAO,KAAK,EAAE,eAAe,EAAE,gBAAgB,EAAO,MAAM,oBAAoB,CAAC;AACjF,OAAO,EAAE,KAAK,YAAY,EAAsB,MAAM,qBAAqB,CAAC;AAE5E,OAAO,KAAK,EAAE,qBAAqB,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAS1E;;GAEG;AACH,MAAM,WAAW,iBAAiB;IAChC,2DAA2D;IAC3D,aAAa,EAAE,gBAAgB,CAAC;IAChC,4DAA4D;IAC5D,YAAY,CAAC,EAAE,eAAe,CAAC;IAC/B,0CAA0C;IAC1C,uBAAuB,EAAE,MAAM,CAAC;IAChC,qCAAqC;IACrC,kBAAkB,EAAE,MAAM,CAAC;IAC3B,sCAAsC;IACtC,MAAM,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,CAAC;IACjC,2EAA2E;IAC3E,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,wDAAwD;IACxD,YAAY,CAAC,EAAE,YAAY,CAAC;IAC5B;;;;;OAKG;IACH,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB;AAED;;;;;GAKG;AACH,wBAAsB,gBAAgB,CAAC,MAAM,EAAE;IAC7C,QAAQ,EAAE,eAAe,CAAC;IAC1B,uBAAuB,EAAE,MAAM,CAAC;IAChC,MAAM,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,CAAC;CAClC,GAAG,OAAO,CAAC,gBAAgB,CAAC,CAgB5B;AAED;;;;;;;;GAQG;AACH,wBAAsB,0BAA0B,CAC9C,MAAM,EAAE,iBAAiB,GACxB,OAAO,CAAC,qBAAqB,CAAC,CA2FhC"}
|
|
@@ -1,21 +1,26 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* Local unwrap operations for liquidity manager.
|
|
3
3
|
*/
|
|
4
|
-
import
|
|
5
|
-
import
|
|
6
|
-
import {
|
|
4
|
+
import LiquidityManagerArtifact from "../../assets/abi/LiquidityManager.json" with { type: "json" };
|
|
5
|
+
import Zerc20Artifact from "../../assets/abi/zERC20.json" with { type: "json" };
|
|
6
|
+
import { spreadFeeOverrides } from "../../utils/fees.js";
|
|
7
|
+
import { ensureAccount, ensureBigintLike, normalizeAddress, receiptProvider, resolveReadProvider, } from "./helpers.js";
|
|
7
8
|
/**
|
|
8
9
|
* Quote local unwrap fee and expected output for a given amount.
|
|
9
|
-
* @param params.
|
|
10
|
+
* @param params.provider - Provider to use for contract reads.
|
|
10
11
|
* @param params.liquidityManagerAddress - Liquidity manager contract address.
|
|
11
12
|
* @param params.amount - Amount to unwrap (bigint-like).
|
|
12
13
|
*/
|
|
13
14
|
export async function quoteLocalUnwrap(params) {
|
|
14
|
-
const {
|
|
15
|
+
const { provider, liquidityManagerAddress, amount } = params;
|
|
15
16
|
const normalizedAmount = ensureBigintLike(amount, "amount");
|
|
16
17
|
const managerAddress = normalizeAddress(liquidityManagerAddress);
|
|
17
|
-
const
|
|
18
|
-
|
|
18
|
+
const fee = ensureBigintLike(await provider.readContract({
|
|
19
|
+
address: managerAddress,
|
|
20
|
+
abi: LiquidityManagerArtifact.abi,
|
|
21
|
+
functionName: "quoteUnwrapFee",
|
|
22
|
+
args: [normalizedAmount],
|
|
23
|
+
}), "fee");
|
|
19
24
|
const expectedOut = normalizedAmount > fee ? normalizedAmount - fee : 0n;
|
|
20
25
|
return { fee, expectedOut };
|
|
21
26
|
}
|
|
@@ -29,49 +34,68 @@ export async function quoteLocalUnwrap(params) {
|
|
|
29
34
|
* @returns Transaction hash for the unwrap, plus optional approval transaction hash.
|
|
30
35
|
*/
|
|
31
36
|
export async function unwrapWithLiquidityManager(params) {
|
|
32
|
-
const {
|
|
37
|
+
const { writeProvider, readProvider, liquidityManagerAddress, zerc20TokenAddress, amount, recipient, minAmountOut, } = params;
|
|
33
38
|
const normalizedAmount = ensureBigintLike(amount, "amount");
|
|
34
39
|
if (normalizedAmount <= 0n) {
|
|
35
40
|
throw new Error("amount must be greater than zero");
|
|
36
41
|
}
|
|
37
|
-
const account = ensureAccount(
|
|
42
|
+
const account = ensureAccount(writeProvider);
|
|
38
43
|
const managerAddress = normalizeAddress(liquidityManagerAddress);
|
|
39
44
|
const tokenAddress = normalizeAddress(zerc20TokenAddress);
|
|
40
|
-
const
|
|
41
|
-
const
|
|
42
|
-
const receiptClientInstance = receiptClient(walletClient, publicClient);
|
|
43
|
-
const zerc20 = getZerc20Contract(tokenAddress, readClient);
|
|
45
|
+
const reader = resolveReadProvider(writeProvider, readProvider);
|
|
46
|
+
const receipt = receiptProvider(writeProvider, readProvider);
|
|
44
47
|
const feeOverrides = params.feeOverrides;
|
|
45
|
-
const txOverrides = { account, chain:
|
|
48
|
+
const txOverrides = { account, chain: writeProvider.chain, ...spreadFeeOverrides(feeOverrides) };
|
|
46
49
|
// Pre-flight slippage check: re-quote on-chain and verify expectedOut >= minAmountOut
|
|
47
50
|
if (minAmountOut !== undefined && minAmountOut > 0n) {
|
|
48
|
-
const
|
|
49
|
-
|
|
51
|
+
const fee = ensureBigintLike(await reader.readContract({
|
|
52
|
+
address: managerAddress,
|
|
53
|
+
abi: LiquidityManagerArtifact.abi,
|
|
54
|
+
functionName: "quoteUnwrapFee",
|
|
55
|
+
args: [normalizedAmount],
|
|
56
|
+
}), "fee");
|
|
50
57
|
const expectedOut = normalizedAmount > fee ? normalizedAmount - fee : 0n;
|
|
51
58
|
if (expectedOut < minAmountOut) {
|
|
52
59
|
throw new Error("Price changed beyond slippage tolerance. Expected output is below the minimum acceptable amount.");
|
|
53
60
|
}
|
|
54
61
|
}
|
|
55
|
-
const allowance = ensureBigintLike(await
|
|
62
|
+
const allowance = ensureBigintLike(await reader.readContract({
|
|
63
|
+
address: tokenAddress,
|
|
64
|
+
abi: Zerc20Artifact.abi,
|
|
65
|
+
functionName: "allowance",
|
|
66
|
+
args: [account, managerAddress],
|
|
67
|
+
}), "allowance");
|
|
56
68
|
let approvalTransactionHash;
|
|
57
69
|
if (allowance < normalizedAmount) {
|
|
58
|
-
const approvalHash = await
|
|
59
|
-
|
|
70
|
+
const approvalHash = await writeProvider.writeContract({
|
|
71
|
+
address: tokenAddress,
|
|
72
|
+
abi: Zerc20Artifact.abi,
|
|
73
|
+
functionName: "approve",
|
|
74
|
+
args: [managerAddress, normalizedAmount],
|
|
75
|
+
...txOverrides,
|
|
76
|
+
});
|
|
77
|
+
const approvalReceipt = await receipt.waitForTransactionReceipt({
|
|
60
78
|
hash: approvalHash,
|
|
61
79
|
});
|
|
62
80
|
approvalTransactionHash = approvalReceipt.transactionHash;
|
|
63
81
|
}
|
|
64
82
|
const to = (recipient ?? account);
|
|
65
83
|
const unwrapHash = minAmountOut !== undefined && minAmountOut > 0n
|
|
66
|
-
? await
|
|
84
|
+
? await writeProvider.writeContract({
|
|
85
|
+
address: managerAddress,
|
|
86
|
+
abi: LiquidityManagerArtifact.abi,
|
|
87
|
+
functionName: "unwrapWithMinOut",
|
|
88
|
+
args: [normalizedAmount, minAmountOut, to],
|
|
67
89
|
...txOverrides,
|
|
68
90
|
})
|
|
69
|
-
: await
|
|
91
|
+
: await writeProvider.writeContract({
|
|
92
|
+
address: managerAddress,
|
|
93
|
+
abi: LiquidityManagerArtifact.abi,
|
|
94
|
+
functionName: "unwrap",
|
|
95
|
+
args: [normalizedAmount, to],
|
|
70
96
|
...txOverrides,
|
|
71
97
|
});
|
|
72
|
-
const unwrapReceipt = await waitForTransactionReceipt(
|
|
73
|
-
hash: unwrapHash,
|
|
74
|
-
});
|
|
98
|
+
const unwrapReceipt = await receipt.waitForTransactionReceipt({ hash: unwrapHash });
|
|
75
99
|
return {
|
|
76
100
|
transactionHash: unwrapReceipt.transactionHash,
|
|
77
101
|
approvalTransactionHash,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"unwrap.js","sourceRoot":"","sources":["../../../src/operations/liquidityManager/unwrap.ts"],"names":[],"mappings":"AAAA;;GAEG;
|
|
1
|
+
{"version":3,"file":"unwrap.js","sourceRoot":"","sources":["../../../src/operations/liquidityManager/unwrap.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,17 +1,17 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* Wrap operations for liquidity manager.
|
|
3
3
|
*/
|
|
4
|
-
import type {
|
|
5
|
-
import type
|
|
4
|
+
import type { EvmReadProvider, EvmWriteProvider } from "../../types/evm.js";
|
|
5
|
+
import { type FeeOverrides } from "../../utils/fees.js";
|
|
6
6
|
import type { LiquidityActionResult } from "./types.js";
|
|
7
7
|
/**
|
|
8
8
|
* Parameters for `wrapWithLiquidityManager`.
|
|
9
9
|
*/
|
|
10
10
|
export interface WrapWithLiquidityManagerParams {
|
|
11
|
-
/**
|
|
12
|
-
|
|
13
|
-
/** Optional
|
|
14
|
-
|
|
11
|
+
/** Write provider used to sign and submit transactions. */
|
|
12
|
+
writeProvider: EvmWriteProvider;
|
|
13
|
+
/** Optional read provider for reads and receipt polling. */
|
|
14
|
+
readProvider?: EvmReadProvider;
|
|
15
15
|
/** Liquidity manager contract address. */
|
|
16
16
|
liquidityManagerAddress: string;
|
|
17
17
|
/** Amount to wrap (bigint-like). */
|
|
@@ -23,7 +23,7 @@ export interface WrapWithLiquidityManagerParams {
|
|
|
23
23
|
underlyingTokenAddress?: string;
|
|
24
24
|
/** Recipient of the wrapped zERC20. Defaults to the wallet's account. */
|
|
25
25
|
recipient?: string;
|
|
26
|
-
/** Optional
|
|
26
|
+
/** Optional fee overrides (e.g., gas, maxFeePerGas). */
|
|
27
27
|
feeOverrides?: FeeOverrides;
|
|
28
28
|
}
|
|
29
29
|
/**
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"wrap.d.ts","sourceRoot":"","sources":["../../../src/operations/liquidityManager/wrap.ts"],"names":[],"mappings":"AAAA;;GAEG;
|
|
1
|
+
{"version":3,"file":"wrap.d.ts","sourceRoot":"","sources":["../../../src/operations/liquidityManager/wrap.ts"],"names":[],"mappings":"AAAA;;GAEG;AAGH,OAAO,KAAK,EAAE,eAAe,EAAE,gBAAgB,EAAO,MAAM,oBAAoB,CAAC;AACjF,OAAO,EAAE,KAAK,YAAY,EAAsB,MAAM,qBAAqB,CAAC;AAG5E,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,YAAY,CAAC;AAUxD;;GAEG;AACH,MAAM,WAAW,8BAA8B;IAC7C,2DAA2D;IAC3D,aAAa,EAAE,gBAAgB,CAAC;IAChC,4DAA4D;IAC5D,YAAY,CAAC,EAAE,eAAe,CAAC;IAC/B,0CAA0C;IAC1C,uBAAuB,EAAE,MAAM,CAAC;IAChC,oCAAoC;IACpC,MAAM,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,CAAC;IACjC;;;OAGG;IACH,sBAAsB,CAAC,EAAE,MAAM,CAAC;IAChC,yEAAyE;IACzE,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,wDAAwD;IACxD,YAAY,CAAC,EAAE,YAAY,CAAC;CAC7B;AAED;;;;;;;GAOG;AACH,wBAAsB,wBAAwB,CAC5C,MAAM,EAAE,8BAA8B,GACrC,OAAO,CAAC,qBAAqB,CAAC,CA0EhC"}
|
|
@@ -1,9 +1,10 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* Wrap operations for liquidity manager.
|
|
3
3
|
*/
|
|
4
|
-
import
|
|
5
|
-
import {
|
|
6
|
-
import {
|
|
4
|
+
import LiquidityManagerArtifact from "../../assets/abi/LiquidityManager.json" with { type: "json" };
|
|
5
|
+
import { spreadFeeOverrides } from "../../utils/fees.js";
|
|
6
|
+
import { ERC20_ABI } from "./abi.js";
|
|
7
|
+
import { ensureAccount, ensureBigintLike, isNativeToken, normalizeAddress, receiptProvider, resolveReadProvider, } from "./helpers.js";
|
|
7
8
|
/**
|
|
8
9
|
* Wrap underlying tokens into zERC20 via the liquidity manager.
|
|
9
10
|
* @remarks
|
|
@@ -13,38 +14,56 @@ import { ensureAccount, ensureBigintLike, getErc20Contract, isNativeToken, norma
|
|
|
13
14
|
* @returns Transaction hash for the wrap, plus optional approval transaction hash.
|
|
14
15
|
*/
|
|
15
16
|
export async function wrapWithLiquidityManager(params) {
|
|
16
|
-
const {
|
|
17
|
+
const { writeProvider, readProvider, liquidityManagerAddress, amount, underlyingTokenAddress, recipient, } = params;
|
|
17
18
|
const normalizedAmount = ensureBigintLike(amount, "amount");
|
|
18
19
|
if (normalizedAmount <= 0n) {
|
|
19
20
|
throw new Error("amount must be greater than zero");
|
|
20
21
|
}
|
|
21
|
-
const account = ensureAccount(
|
|
22
|
+
const account = ensureAccount(writeProvider);
|
|
22
23
|
const managerAddress = normalizeAddress(liquidityManagerAddress);
|
|
23
|
-
const
|
|
24
|
-
const
|
|
25
|
-
const receiptClientInstance = receiptClient(walletClient, publicClient);
|
|
24
|
+
const reader = resolveReadProvider(writeProvider, readProvider);
|
|
25
|
+
const receipt = receiptProvider(writeProvider, readProvider);
|
|
26
26
|
const feeOverrides = params.feeOverrides;
|
|
27
|
-
const txOverrides = { account, chain:
|
|
27
|
+
const txOverrides = { account, chain: writeProvider.chain, ...spreadFeeOverrides(feeOverrides) };
|
|
28
28
|
const underlying = underlyingTokenAddress !== undefined && underlyingTokenAddress !== null
|
|
29
29
|
? normalizeAddress(underlyingTokenAddress)
|
|
30
|
-
: normalizeAddress((await
|
|
30
|
+
: normalizeAddress((await reader.readContract({
|
|
31
|
+
address: managerAddress,
|
|
32
|
+
abi: LiquidityManagerArtifact.abi,
|
|
33
|
+
functionName: "underlyingToken",
|
|
34
|
+
})));
|
|
31
35
|
const nativeUnderlying = isNativeToken(underlying);
|
|
32
36
|
let approvalTransactionHash;
|
|
33
37
|
if (!nativeUnderlying) {
|
|
34
|
-
const currentAllowance = ensureBigintLike(await
|
|
38
|
+
const currentAllowance = ensureBigintLike(await reader.readContract({
|
|
39
|
+
address: underlying,
|
|
40
|
+
abi: ERC20_ABI,
|
|
41
|
+
functionName: "allowance",
|
|
42
|
+
args: [account, managerAddress],
|
|
43
|
+
}), "allowance");
|
|
35
44
|
if (currentAllowance < normalizedAmount) {
|
|
36
|
-
const approvalHash = await
|
|
37
|
-
|
|
45
|
+
const approvalHash = await writeProvider.writeContract({
|
|
46
|
+
address: underlying,
|
|
47
|
+
abi: ERC20_ABI,
|
|
48
|
+
functionName: "approve",
|
|
49
|
+
args: [managerAddress, normalizedAmount],
|
|
50
|
+
...txOverrides,
|
|
51
|
+
});
|
|
52
|
+
const approvalReceipt = await receipt.waitForTransactionReceipt({
|
|
38
53
|
hash: approvalHash,
|
|
39
54
|
});
|
|
40
55
|
approvalTransactionHash = approvalReceipt.transactionHash;
|
|
41
56
|
}
|
|
42
57
|
}
|
|
43
|
-
const wrapHash = await
|
|
44
|
-
|
|
58
|
+
const wrapHash = await writeProvider.writeContract({
|
|
59
|
+
address: managerAddress,
|
|
60
|
+
abi: LiquidityManagerArtifact.abi,
|
|
61
|
+
functionName: "wrap",
|
|
62
|
+
args: [normalizedAmount, (recipient ?? account)],
|
|
45
63
|
value: nativeUnderlying ? normalizedAmount : undefined,
|
|
64
|
+
...txOverrides,
|
|
46
65
|
});
|
|
47
|
-
const wrapReceipt = await waitForTransactionReceipt(
|
|
66
|
+
const wrapReceipt = await receipt.waitForTransactionReceipt({ hash: wrapHash });
|
|
48
67
|
return {
|
|
49
68
|
transactionHash: wrapReceipt.transactionHash,
|
|
50
69
|
approvalTransactionHash,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"wrap.js","sourceRoot":"","sources":["../../../src/operations/liquidityManager/wrap.ts"],"names":[],"mappings":"AAAA;;GAEG;
|
|
1
|
+
{"version":3,"file":"wrap.js","sourceRoot":"","sources":["../../../src/operations/liquidityManager/wrap.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,3 +1,5 @@
|
|
|
1
|
+
import type { EvmReadProvider, EvmWriteProvider, Hex } from "../types/evm.js";
|
|
2
|
+
import { type FeeOverrides } from "../utils/fees.js";
|
|
1
3
|
import { StealthCanisterClient } from "../ic/client.js";
|
|
2
4
|
import { PreparedPrivateSend, PrivateSendResult } from "../types.js";
|
|
3
5
|
/**
|
|
@@ -43,4 +45,35 @@ export interface SubmitPrivateSendParams {
|
|
|
43
45
|
* @returns The stored announcement and the same preparation metadata.
|
|
44
46
|
*/
|
|
45
47
|
export declare function submitPrivateSendAnnouncement(params: SubmitPrivateSendParams): Promise<PrivateSendResult>;
|
|
48
|
+
/**
|
|
49
|
+
* Parameters for {@link submitPrivateSendTransfer}.
|
|
50
|
+
*/
|
|
51
|
+
export interface SubmitPrivateSendTransferParams {
|
|
52
|
+
/** EVM write provider (e.g. wallet client). */
|
|
53
|
+
writeProvider: EvmWriteProvider;
|
|
54
|
+
/** Token contract address. */
|
|
55
|
+
tokenAddress: string;
|
|
56
|
+
/** Burn address generated by `preparePrivateSend`. */
|
|
57
|
+
burnAddress: string;
|
|
58
|
+
/** Amount in the token's smallest unit. */
|
|
59
|
+
amount: bigint;
|
|
60
|
+
/** Optional fee overrides from `buildFeeOverrides`. */
|
|
61
|
+
feeOverrides?: FeeOverrides;
|
|
62
|
+
/**
|
|
63
|
+
* EVM read provider for awaiting the receipt.
|
|
64
|
+
* Falls back to `writeProvider` if it exposes `waitForTransactionReceipt`.
|
|
65
|
+
*/
|
|
66
|
+
readProvider?: EvmReadProvider;
|
|
67
|
+
}
|
|
68
|
+
/**
|
|
69
|
+
* Execute an ERC-20 `transfer` to the burn address and wait for the receipt.
|
|
70
|
+
*
|
|
71
|
+
* This is the final on-chain step of a private send, after the announcement
|
|
72
|
+
* has been prepared and submitted.
|
|
73
|
+
*
|
|
74
|
+
* @returns The confirmed transaction hash.
|
|
75
|
+
*/
|
|
76
|
+
export declare function submitPrivateSendTransfer(params: SubmitPrivateSendTransferParams): Promise<{
|
|
77
|
+
transactionHash: Hex;
|
|
78
|
+
}>;
|
|
46
79
|
//# sourceMappingURL=privateSend.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"privateSend.d.ts","sourceRoot":"","sources":["../../src/operations/privateSend.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,iBAAiB,CAAC;AAKxD,OAAO,EAAE,mBAAmB,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC;AAWrE;;;;;GAKG;AACH,MAAM,WAAW,wBAAwB;IACvC,iFAAiF;IACjF,MAAM,EAAE,qBAAqB,CAAC;IAC9B,qDAAqD;IACrD,gBAAgB,EAAE,MAAM,CAAC;IACzB,yCAAyC;IACzC,gBAAgB,EAAE,MAAM,GAAG,MAAM,CAAC;IAClC,qCAAqC;IACrC,OAAO,EAAE,MAAM,CAAC;IAChB,gFAAgF;IAChF,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,6DAA6D;IAC7D,WAAW,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,KAAK,UAAU,CAAC;IAC7C,0FAA0F;IAC1F,cAAc,CAAC,EAAE,MAAM,CAAC;CACzB;AAED;;;;;GAKG;AACH,wBAAsB,kBAAkB,CACtC,MAAM,EAAE,wBAAwB,GAC/B,OAAO,CAAC,mBAAmB,CAAC,CAkD9B;AAED,MAAM,WAAW,uBAAuB;IACtC,0BAA0B;IAC1B,MAAM,EAAE,qBAAqB,CAAC;IAC9B,sCAAsC;IACtC,WAAW,EAAE,mBAAmB,CAAC;IACjC,4BAA4B;IAC5B,GAAG,CAAC,EAAE,MAAM,CAAC;CACd;AAED;;;;GAIG;AACH,wBAAsB,6BAA6B,CACjD,MAAM,EAAE,uBAAuB,GAC9B,OAAO,CAAC,iBAAiB,CAAC,CAe5B"}
|
|
1
|
+
{"version":3,"file":"privateSend.d.ts","sourceRoot":"","sources":["../../src/operations/privateSend.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,gBAAgB,EAAE,GAAG,EAAE,MAAM,iBAAiB,CAAC;AAE9E,OAAO,EAAE,KAAK,YAAY,EAAsB,MAAM,kBAAkB,CAAC;AAEzE,OAAO,EAAE,qBAAqB,EAAE,MAAM,iBAAiB,CAAC;AAKxD,OAAO,EAAE,mBAAmB,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC;AAWrE;;;;;GAKG;AACH,MAAM,WAAW,wBAAwB;IACvC,iFAAiF;IACjF,MAAM,EAAE,qBAAqB,CAAC;IAC9B,qDAAqD;IACrD,gBAAgB,EAAE,MAAM,CAAC;IACzB,yCAAyC;IACzC,gBAAgB,EAAE,MAAM,GAAG,MAAM,CAAC;IAClC,qCAAqC;IACrC,OAAO,EAAE,MAAM,CAAC;IAChB,gFAAgF;IAChF,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,6DAA6D;IAC7D,WAAW,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,KAAK,UAAU,CAAC;IAC7C,0FAA0F;IAC1F,cAAc,CAAC,EAAE,MAAM,CAAC;CACzB;AAED;;;;;GAKG;AACH,wBAAsB,kBAAkB,CACtC,MAAM,EAAE,wBAAwB,GAC/B,OAAO,CAAC,mBAAmB,CAAC,CAkD9B;AAED,MAAM,WAAW,uBAAuB;IACtC,0BAA0B;IAC1B,MAAM,EAAE,qBAAqB,CAAC;IAC9B,sCAAsC;IACtC,WAAW,EAAE,mBAAmB,CAAC;IACjC,4BAA4B;IAC5B,GAAG,CAAC,EAAE,MAAM,CAAC;CACd;AAED;;;;GAIG;AACH,wBAAsB,6BAA6B,CACjD,MAAM,EAAE,uBAAuB,GAC9B,OAAO,CAAC,iBAAiB,CAAC,CAe5B;AAMD;;GAEG;AACH,MAAM,WAAW,+BAA+B;IAC9C,+CAA+C;IAC/C,aAAa,EAAE,gBAAgB,CAAC;IAChC,8BAA8B;IAC9B,YAAY,EAAE,MAAM,CAAC;IACrB,sDAAsD;IACtD,WAAW,EAAE,MAAM,CAAC;IACpB,2CAA2C;IAC3C,MAAM,EAAE,MAAM,CAAC;IACf,uDAAuD;IACvD,YAAY,CAAC,EAAE,YAAY,CAAC;IAC5B;;;OAGG;IACH,YAAY,CAAC,EAAE,eAAe,CAAC;CAChC;AAED;;;;;;;GAOG;AACH,wBAAsB,yBAAyB,CAC7C,MAAM,EAAE,+BAA+B,GACtC,OAAO,CAAC;IAAE,eAAe,EAAE,GAAG,CAAA;CAAE,CAAC,CAiBnC"}
|
|
@@ -1,3 +1,6 @@
|
|
|
1
|
+
import Zerc20Artifact from "../assets/abi/zERC20.json" with { type: "json" };
|
|
2
|
+
import { spreadFeeOverrides } from "../utils/fees.js";
|
|
3
|
+
import { receiptProvider } from "./liquidityManager/helpers.js";
|
|
1
4
|
import { deriveViewPublicKeyOffchain } from "../ic/keys.js";
|
|
2
5
|
import { encryptAnnouncementWithArtifacts } from "../ic/encryption.js";
|
|
3
6
|
import { addressToBytes, bytesToHex, ensureHexLength, hexToBytes, normalizeHex, randomBytes, } from "../utils/hex.js";
|
|
@@ -60,4 +63,27 @@ export async function submitPrivateSendAnnouncement(params) {
|
|
|
60
63
|
announcement: storedAnnouncement,
|
|
61
64
|
};
|
|
62
65
|
}
|
|
66
|
+
/**
|
|
67
|
+
* Execute an ERC-20 `transfer` to the burn address and wait for the receipt.
|
|
68
|
+
*
|
|
69
|
+
* This is the final on-chain step of a private send, after the announcement
|
|
70
|
+
* has been prepared and submitted.
|
|
71
|
+
*
|
|
72
|
+
* @returns The confirmed transaction hash.
|
|
73
|
+
*/
|
|
74
|
+
export async function submitPrivateSendTransfer(params) {
|
|
75
|
+
const { writeProvider, tokenAddress, burnAddress, amount, feeOverrides, readProvider } = params;
|
|
76
|
+
const hash = (await writeProvider.writeContract({
|
|
77
|
+
address: normalizeHex(tokenAddress),
|
|
78
|
+
abi: Zerc20Artifact.abi,
|
|
79
|
+
functionName: "transfer",
|
|
80
|
+
args: [normalizeHex(burnAddress), amount],
|
|
81
|
+
account: writeProvider.account?.address,
|
|
82
|
+
chain: writeProvider.chain,
|
|
83
|
+
...spreadFeeOverrides(feeOverrides),
|
|
84
|
+
}));
|
|
85
|
+
const receipt = receiptProvider(writeProvider, readProvider);
|
|
86
|
+
await receipt.waitForTransactionReceipt({ hash });
|
|
87
|
+
return { transactionHash: hash };
|
|
88
|
+
}
|
|
63
89
|
//# sourceMappingURL=privateSend.js.map
|