@prb/effect-evm 1.0.0-beta.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/CONTRIBUTING.md +42 -0
- package/DOCS.md +798 -0
- package/README.md +74 -0
- package/dist/abi/erc165.d.ts +21 -0
- package/dist/abi/erc165.d.ts.map +1 -0
- package/dist/abi/erc165.js +36 -0
- package/dist/abi/erc165.js.map +1 -0
- package/dist/abi/erc20-no-output.d.ts +14 -0
- package/dist/abi/erc20-no-output.d.ts.map +1 -0
- package/dist/abi/erc20-no-output.js +13 -0
- package/dist/abi/erc20-no-output.js.map +1 -0
- package/dist/abi/erc20.d.ts +2 -0
- package/dist/abi/erc20.d.ts.map +1 -0
- package/dist/abi/erc20.js +2 -0
- package/dist/abi/erc20.js.map +1 -0
- package/dist/abi/erc721.d.ts +3 -0
- package/dist/abi/erc721.d.ts.map +1 -0
- package/dist/abi/erc721.js +3 -0
- package/dist/abi/erc721.js.map +1 -0
- package/dist/abi/index.d.ts +5 -0
- package/dist/abi/index.d.ts.map +1 -0
- package/dist/abi/index.js +5 -0
- package/dist/abi/index.js.map +1 -0
- package/dist/balance/index.d.ts +3 -0
- package/dist/balance/index.d.ts.map +1 -0
- package/dist/balance/index.js +3 -0
- package/dist/balance/index.js.map +1 -0
- package/dist/balance/service.d.ts +57 -0
- package/dist/balance/service.d.ts.map +1 -0
- package/dist/balance/service.js +244 -0
- package/dist/balance/service.js.map +1 -0
- package/dist/balance/utils.d.ts +3 -0
- package/dist/balance/utils.d.ts.map +1 -0
- package/dist/balance/utils.js +23 -0
- package/dist/balance/utils.js.map +1 -0
- package/dist/block/errors.d.ts +22 -0
- package/dist/block/errors.d.ts.map +1 -0
- package/dist/block/errors.js +15 -0
- package/dist/block/errors.js.map +1 -0
- package/dist/block/index.d.ts +3 -0
- package/dist/block/index.d.ts.map +1 -0
- package/dist/block/index.js +3 -0
- package/dist/block/index.js.map +1 -0
- package/dist/block/service.d.ts +48 -0
- package/dist/block/service.d.ts.map +1 -0
- package/dist/block/service.js +194 -0
- package/dist/block/service.js.map +1 -0
- package/dist/constants/index.d.ts +16 -0
- package/dist/constants/index.d.ts.map +1 -0
- package/dist/constants/index.js +17 -0
- package/dist/constants/index.js.map +1 -0
- package/dist/contract/cross-chain-reader.d.ts +33 -0
- package/dist/contract/cross-chain-reader.d.ts.map +1 -0
- package/dist/contract/cross-chain-reader.js +86 -0
- package/dist/contract/cross-chain-reader.js.map +1 -0
- package/dist/contract/index.d.ts +6 -0
- package/dist/contract/index.d.ts.map +1 -0
- package/dist/contract/index.js +6 -0
- package/dist/contract/index.js.map +1 -0
- package/dist/contract/pipeline/index.d.ts +4 -0
- package/dist/contract/pipeline/index.d.ts.map +1 -0
- package/dist/contract/pipeline/index.js +4 -0
- package/dist/contract/pipeline/index.js.map +1 -0
- package/dist/contract/pipeline/internal/core.d.ts +22 -0
- package/dist/contract/pipeline/internal/core.d.ts.map +1 -0
- package/dist/contract/pipeline/internal/core.js +64 -0
- package/dist/contract/pipeline/internal/core.js.map +1 -0
- package/dist/contract/pipeline/internal/helpers.d.ts +3 -0
- package/dist/contract/pipeline/internal/helpers.d.ts.map +1 -0
- package/dist/contract/pipeline/internal/helpers.js +9 -0
- package/dist/contract/pipeline/internal/helpers.js.map +1 -0
- package/dist/contract/pipeline/internal/nonce.d.ts +22 -0
- package/dist/contract/pipeline/internal/nonce.d.ts.map +1 -0
- package/dist/contract/pipeline/internal/nonce.js +44 -0
- package/dist/contract/pipeline/internal/nonce.js.map +1 -0
- package/dist/contract/pipeline/internal/prepare.d.ts +20 -0
- package/dist/contract/pipeline/internal/prepare.d.ts.map +1 -0
- package/dist/contract/pipeline/internal/prepare.js +41 -0
- package/dist/contract/pipeline/internal/prepare.js.map +1 -0
- package/dist/contract/pipeline/internal/receipt.d.ts +12 -0
- package/dist/contract/pipeline/internal/receipt.d.ts.map +1 -0
- package/dist/contract/pipeline/internal/receipt.js +24 -0
- package/dist/contract/pipeline/internal/receipt.js.map +1 -0
- package/dist/contract/pipeline/live.d.ts +10 -0
- package/dist/contract/pipeline/live.d.ts.map +1 -0
- package/dist/contract/pipeline/live.js +40 -0
- package/dist/contract/pipeline/live.js.map +1 -0
- package/dist/contract/pipeline/service.d.ts +24 -0
- package/dist/contract/pipeline/service.d.ts.map +1 -0
- package/dist/contract/pipeline/service.js +4 -0
- package/dist/contract/pipeline/service.js.map +1 -0
- package/dist/contract/pipeline/types.d.ts +47 -0
- package/dist/contract/pipeline/types.d.ts.map +1 -0
- package/dist/contract/pipeline/types.js +2 -0
- package/dist/contract/pipeline/types.js.map +1 -0
- package/dist/contract/pipeline/write-and-track.d.ts +28 -0
- package/dist/contract/pipeline/write-and-track.d.ts.map +1 -0
- package/dist/contract/pipeline/write-and-track.js +264 -0
- package/dist/contract/pipeline/write-and-track.js.map +1 -0
- package/dist/contract/pipeline/write-and-wait.d.ts +7 -0
- package/dist/contract/pipeline/write-and-wait.d.ts.map +1 -0
- package/dist/contract/pipeline/write-and-wait.js +7 -0
- package/dist/contract/pipeline/write-and-wait.js.map +1 -0
- package/dist/contract/pipeline.d.ts +2 -0
- package/dist/contract/pipeline.d.ts.map +1 -0
- package/dist/contract/pipeline.js +2 -0
- package/dist/contract/pipeline.js.map +1 -0
- package/dist/contract/reader.d.ts +20 -0
- package/dist/contract/reader.d.ts.map +1 -0
- package/dist/contract/reader.js +64 -0
- package/dist/contract/reader.js.map +1 -0
- package/dist/contract/typed-contract.d.ts +33 -0
- package/dist/contract/typed-contract.d.ts.map +1 -0
- package/dist/contract/typed-contract.js +53 -0
- package/dist/contract/typed-contract.js.map +1 -0
- package/dist/contract/writer.d.ts +16 -0
- package/dist/contract/writer.d.ts.map +1 -0
- package/dist/contract/writer.js +84 -0
- package/dist/contract/writer.js.map +1 -0
- package/dist/core/clients/index.d.ts +3 -0
- package/dist/core/clients/index.d.ts.map +1 -0
- package/dist/core/clients/index.js +3 -0
- package/dist/core/clients/index.js.map +1 -0
- package/dist/core/clients/public-client.d.ts +12 -0
- package/dist/core/clients/public-client.d.ts.map +1 -0
- package/dist/core/clients/public-client.js +4 -0
- package/dist/core/clients/public-client.js.map +1 -0
- package/dist/core/clients/wallet-client.d.ts +12 -0
- package/dist/core/clients/wallet-client.d.ts.map +1 -0
- package/dist/core/clients/wallet-client.js +4 -0
- package/dist/core/clients/wallet-client.js.map +1 -0
- package/dist/core/errors/client.d.ts +37 -0
- package/dist/core/errors/client.d.ts.map +1 -0
- package/dist/core/errors/client.js +24 -0
- package/dist/core/errors/client.js.map +1 -0
- package/dist/core/errors/contract.d.ts +58 -0
- package/dist/core/errors/contract.d.ts.map +1 -0
- package/dist/core/errors/contract.js +42 -0
- package/dist/core/errors/contract.js.map +1 -0
- package/dist/core/errors/erc20.d.ts +24 -0
- package/dist/core/errors/erc20.d.ts.map +1 -0
- package/dist/core/errors/erc20.js +17 -0
- package/dist/core/errors/erc20.js.map +1 -0
- package/dist/core/errors/event.d.ts +21 -0
- package/dist/core/errors/event.d.ts.map +1 -0
- package/dist/core/errors/event.js +14 -0
- package/dist/core/errors/event.js.map +1 -0
- package/dist/core/errors/index.d.ts +8 -0
- package/dist/core/errors/index.d.ts.map +1 -0
- package/dist/core/errors/index.js +8 -0
- package/dist/core/errors/index.js.map +1 -0
- package/dist/core/errors/predicates.d.ts +12 -0
- package/dist/core/errors/predicates.d.ts.map +1 -0
- package/dist/core/errors/predicates.js +3 -0
- package/dist/core/errors/predicates.js.map +1 -0
- package/dist/core/errors/transaction.d.ts +57 -0
- package/dist/core/errors/transaction.d.ts.map +1 -0
- package/dist/core/errors/transaction.js +36 -0
- package/dist/core/errors/transaction.js.map +1 -0
- package/dist/core/errors/viem-mapper.d.ts +45 -0
- package/dist/core/errors/viem-mapper.d.ts.map +1 -0
- package/dist/core/errors/viem-mapper.js +251 -0
- package/dist/core/errors/viem-mapper.js.map +1 -0
- package/dist/core/index.d.ts +3 -0
- package/dist/core/index.d.ts.map +1 -0
- package/dist/core/index.js +3 -0
- package/dist/core/index.js.map +1 -0
- package/dist/deploy/errors.d.ts +30 -0
- package/dist/deploy/errors.d.ts.map +1 -0
- package/dist/deploy/errors.js +20 -0
- package/dist/deploy/errors.js.map +1 -0
- package/dist/deploy/index.d.ts +3 -0
- package/dist/deploy/index.d.ts.map +1 -0
- package/dist/deploy/index.js +3 -0
- package/dist/deploy/index.js.map +1 -0
- package/dist/deploy/service.d.ts +62 -0
- package/dist/deploy/service.d.ts.map +1 -0
- package/dist/deploy/service.js +233 -0
- package/dist/deploy/service.js.map +1 -0
- package/dist/eip7702/erc7579.d.ts +36 -0
- package/dist/eip7702/erc7579.d.ts.map +1 -0
- package/dist/eip7702/erc7579.js +52 -0
- package/dist/eip7702/erc7579.js.map +1 -0
- package/dist/eip7702/errors.d.ts +30 -0
- package/dist/eip7702/errors.d.ts.map +1 -0
- package/dist/eip7702/errors.js +20 -0
- package/dist/eip7702/errors.js.map +1 -0
- package/dist/eip7702/index.d.ts +4 -0
- package/dist/eip7702/index.d.ts.map +1 -0
- package/dist/eip7702/index.js +4 -0
- package/dist/eip7702/index.js.map +1 -0
- package/dist/eip7702/service.d.ts +64 -0
- package/dist/eip7702/service.d.ts.map +1 -0
- package/dist/eip7702/service.js +166 -0
- package/dist/eip7702/service.js.map +1 -0
- package/dist/ens/ens.d.ts +26 -0
- package/dist/ens/ens.d.ts.map +1 -0
- package/dist/ens/ens.js +144 -0
- package/dist/ens/ens.js.map +1 -0
- package/dist/ens/errors.d.ts +53 -0
- package/dist/ens/errors.d.ts.map +1 -0
- package/dist/ens/errors.js +34 -0
- package/dist/ens/errors.js.map +1 -0
- package/dist/ens/index.d.ts +3 -0
- package/dist/ens/index.d.ts.map +1 -0
- package/dist/ens/index.js +3 -0
- package/dist/ens/index.js.map +1 -0
- package/dist/erc20/allowance/core.d.ts +9 -0
- package/dist/erc20/allowance/core.d.ts.map +1 -0
- package/dist/erc20/allowance/core.js +121 -0
- package/dist/erc20/allowance/core.js.map +1 -0
- package/dist/erc20/allowance/index.d.ts +4 -0
- package/dist/erc20/allowance/index.d.ts.map +1 -0
- package/dist/erc20/allowance/index.js +4 -0
- package/dist/erc20/allowance/index.js.map +1 -0
- package/dist/erc20/allowance/no-output.d.ts +9 -0
- package/dist/erc20/allowance/no-output.d.ts.map +1 -0
- package/dist/erc20/allowance/no-output.js +122 -0
- package/dist/erc20/allowance/no-output.js.map +1 -0
- package/dist/erc20/allowance/types.d.ts +42 -0
- package/dist/erc20/allowance/types.d.ts.map +1 -0
- package/dist/erc20/allowance/types.js +2 -0
- package/dist/erc20/allowance/types.js.map +1 -0
- package/dist/erc20/index.d.ts +2 -0
- package/dist/erc20/index.d.ts.map +1 -0
- package/dist/erc20/index.js +2 -0
- package/dist/erc20/index.js.map +1 -0
- package/dist/erc721/errors.d.ts +47 -0
- package/dist/erc721/errors.d.ts.map +1 -0
- package/dist/erc721/errors.js +34 -0
- package/dist/erc721/errors.js.map +1 -0
- package/dist/erc721/helpers.d.ts +24 -0
- package/dist/erc721/helpers.d.ts.map +1 -0
- package/dist/erc721/helpers.js +28 -0
- package/dist/erc721/helpers.js.map +1 -0
- package/dist/erc721/index.d.ts +4 -0
- package/dist/erc721/index.d.ts.map +1 -0
- package/dist/erc721/index.js +4 -0
- package/dist/erc721/index.js.map +1 -0
- package/dist/erc721/metadata.d.ts +28 -0
- package/dist/erc721/metadata.d.ts.map +1 -0
- package/dist/erc721/metadata.js +67 -0
- package/dist/erc721/metadata.js.map +1 -0
- package/dist/erc721/service.d.ts +93 -0
- package/dist/erc721/service.d.ts.map +1 -0
- package/dist/erc721/service.js +277 -0
- package/dist/erc721/service.js.map +1 -0
- package/dist/events/backfill.d.ts +25 -0
- package/dist/events/backfill.d.ts.map +1 -0
- package/dist/events/backfill.js +36 -0
- package/dist/events/backfill.js.map +1 -0
- package/dist/events/cursor.d.ts +40 -0
- package/dist/events/cursor.d.ts.map +1 -0
- package/dist/events/cursor.js +85 -0
- package/dist/events/cursor.js.map +1 -0
- package/dist/events/decoder.d.ts +18 -0
- package/dist/events/decoder.d.ts.map +1 -0
- package/dist/events/decoder.js +33 -0
- package/dist/events/decoder.js.map +1 -0
- package/dist/events/index.d.ts +6 -0
- package/dist/events/index.d.ts.map +1 -0
- package/dist/events/index.js +6 -0
- package/dist/events/index.js.map +1 -0
- package/dist/events/reliable-stream.d.ts +25 -0
- package/dist/events/reliable-stream.d.ts.map +1 -0
- package/dist/events/reliable-stream.js +121 -0
- package/dist/events/reliable-stream.js.map +1 -0
- package/dist/events/stream.d.ts +25 -0
- package/dist/events/stream.d.ts.map +1 -0
- package/dist/events/stream.js +39 -0
- package/dist/events/stream.js.map +1 -0
- package/dist/gas/errors.d.ts +12 -0
- package/dist/gas/errors.d.ts.map +1 -0
- package/dist/gas/errors.js +8 -0
- package/dist/gas/errors.js.map +1 -0
- package/dist/gas/estimator.d.ts +15 -0
- package/dist/gas/estimator.d.ts.map +1 -0
- package/dist/gas/estimator.js +113 -0
- package/dist/gas/estimator.js.map +1 -0
- package/dist/gas/index.d.ts +4 -0
- package/dist/gas/index.d.ts.map +1 -0
- package/dist/gas/index.js +4 -0
- package/dist/gas/index.js.map +1 -0
- package/dist/gas/service.d.ts +37 -0
- package/dist/gas/service.d.ts.map +1 -0
- package/dist/gas/service.js +95 -0
- package/dist/gas/service.js.map +1 -0
- package/dist/index.d.ts +26 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +26 -0
- package/dist/index.js.map +1 -0
- package/dist/integrations/react-hooks/convenience/index.d.ts +28 -0
- package/dist/integrations/react-hooks/convenience/index.d.ts.map +1 -0
- package/dist/integrations/react-hooks/convenience/index.js +126 -0
- package/dist/integrations/react-hooks/convenience/index.js.map +1 -0
- package/dist/integrations/react-hooks/internal/error.d.ts +5 -0
- package/dist/integrations/react-hooks/internal/error.d.ts.map +1 -0
- package/dist/integrations/react-hooks/internal/error.js +8 -0
- package/dist/integrations/react-hooks/internal/error.js.map +1 -0
- package/dist/integrations/react-hooks/internal/is-dev.d.ts +2 -0
- package/dist/integrations/react-hooks/internal/is-dev.d.ts.map +1 -0
- package/dist/integrations/react-hooks/internal/is-dev.js +4 -0
- package/dist/integrations/react-hooks/internal/is-dev.js.map +1 -0
- package/dist/integrations/react-hooks/internal/runtime.d.ts +21 -0
- package/dist/integrations/react-hooks/internal/runtime.d.ts.map +1 -0
- package/dist/integrations/react-hooks/internal/runtime.js +37 -0
- package/dist/integrations/react-hooks/internal/runtime.js.map +1 -0
- package/dist/integrations/react-hooks/internal/scoped-run.d.ts +11 -0
- package/dist/integrations/react-hooks/internal/scoped-run.d.ts.map +1 -0
- package/dist/integrations/react-hooks/internal/scoped-run.js +20 -0
- package/dist/integrations/react-hooks/internal/scoped-run.js.map +1 -0
- package/dist/integrations/react-hooks/internal/stable.d.ts +2 -0
- package/dist/integrations/react-hooks/internal/stable.d.ts.map +1 -0
- package/dist/integrations/react-hooks/internal/stable.js +2 -0
- package/dist/integrations/react-hooks/internal/stable.js.map +1 -0
- package/dist/integrations/react-hooks/primitives/use-effect-memo-factory.d.ts +11 -0
- package/dist/integrations/react-hooks/primitives/use-effect-memo-factory.d.ts.map +1 -0
- package/dist/integrations/react-hooks/primitives/use-effect-memo-factory.js +92 -0
- package/dist/integrations/react-hooks/primitives/use-effect-memo-factory.js.map +1 -0
- package/dist/integrations/react-hooks/primitives/use-effect.d.ts +23 -0
- package/dist/integrations/react-hooks/primitives/use-effect.d.ts.map +1 -0
- package/dist/integrations/react-hooks/primitives/use-effect.js +93 -0
- package/dist/integrations/react-hooks/primitives/use-effect.js.map +1 -0
- package/dist/integrations/react-hooks/primitives/use-fork-effect.d.ts +4 -0
- package/dist/integrations/react-hooks/primitives/use-fork-effect.d.ts.map +1 -0
- package/dist/integrations/react-hooks/primitives/use-fork-effect.js +20 -0
- package/dist/integrations/react-hooks/primitives/use-fork-effect.js.map +1 -0
- package/dist/integrations/react-hooks/primitives/use-stream.d.ts +26 -0
- package/dist/integrations/react-hooks/primitives/use-stream.d.ts.map +1 -0
- package/dist/integrations/react-hooks/primitives/use-stream.js +161 -0
- package/dist/integrations/react-hooks/primitives/use-stream.js.map +1 -0
- package/dist/integrations/react-hooks/primitives.d.ts +8 -0
- package/dist/integrations/react-hooks/primitives.d.ts.map +1 -0
- package/dist/integrations/react-hooks/primitives.js +6 -0
- package/dist/integrations/react-hooks/primitives.js.map +1 -0
- package/dist/integrations/react-hooks/provider.d.ts +19 -0
- package/dist/integrations/react-hooks/provider.d.ts.map +1 -0
- package/dist/integrations/react-hooks/provider.js +71 -0
- package/dist/integrations/react-hooks/provider.js.map +1 -0
- package/dist/integrations/react-hooks/wagmi/index.d.ts +13 -0
- package/dist/integrations/react-hooks/wagmi/index.d.ts.map +1 -0
- package/dist/integrations/react-hooks/wagmi/index.js +81 -0
- package/dist/integrations/react-hooks/wagmi/index.js.map +1 -0
- package/dist/integrations/react-hooks/wallet-provider-ref.d.ts +7 -0
- package/dist/integrations/react-hooks/wallet-provider-ref.d.ts.map +1 -0
- package/dist/integrations/react-hooks/wallet-provider-ref.js +27 -0
- package/dist/integrations/react-hooks/wallet-provider-ref.js.map +1 -0
- package/dist/integrations/wagmi/index.d.ts +2 -0
- package/dist/integrations/wagmi/index.d.ts.map +1 -0
- package/dist/integrations/wagmi/index.js +2 -0
- package/dist/integrations/wagmi/index.js.map +1 -0
- package/dist/integrations/wagmi/layers.d.ts +12 -0
- package/dist/integrations/wagmi/layers.d.ts.map +1 -0
- package/dist/integrations/wagmi/layers.js +72 -0
- package/dist/integrations/wagmi/layers.js.map +1 -0
- package/dist/internal/index.d.ts +5 -0
- package/dist/internal/index.d.ts.map +1 -0
- package/dist/internal/index.js +5 -0
- package/dist/internal/index.js.map +1 -0
- package/dist/internal/numbers.d.ts +28 -0
- package/dist/internal/numbers.d.ts.map +1 -0
- package/dist/internal/numbers.js +139 -0
- package/dist/internal/numbers.js.map +1 -0
- package/dist/internal/schedule.d.ts +9 -0
- package/dist/internal/schedule.d.ts.map +1 -0
- package/dist/internal/schedule.js +10 -0
- package/dist/internal/schedule.js.map +1 -0
- package/dist/internal/stream-adapters.d.ts +10 -0
- package/dist/internal/stream-adapters.d.ts.map +1 -0
- package/dist/internal/stream-adapters.js +9 -0
- package/dist/internal/stream-adapters.js.map +1 -0
- package/dist/internal/viem-effect.d.ts +8 -0
- package/dist/internal/viem-effect.d.ts.map +1 -0
- package/dist/internal/viem-effect.js +14 -0
- package/dist/internal/viem-effect.js.map +1 -0
- package/dist/nonce/index.d.ts +3 -0
- package/dist/nonce/index.d.ts.map +1 -0
- package/dist/nonce/index.js +3 -0
- package/dist/nonce/index.js.map +1 -0
- package/dist/nonce/manager.d.ts +13 -0
- package/dist/nonce/manager.d.ts.map +1 -0
- package/dist/nonce/manager.js +100 -0
- package/dist/nonce/manager.js.map +1 -0
- package/dist/nonce/service.d.ts +46 -0
- package/dist/nonce/service.d.ts.map +1 -0
- package/dist/nonce/service.js +139 -0
- package/dist/nonce/service.js.map +1 -0
- package/dist/platform/browser/cursor-store/index.d.ts +2 -0
- package/dist/platform/browser/cursor-store/index.d.ts.map +1 -0
- package/dist/platform/browser/cursor-store/index.js +2 -0
- package/dist/platform/browser/cursor-store/index.js.map +1 -0
- package/dist/platform/browser/cursor-store/local-storage.d.ts +5 -0
- package/dist/platform/browser/cursor-store/local-storage.d.ts.map +1 -0
- package/dist/platform/browser/cursor-store/local-storage.js +99 -0
- package/dist/platform/browser/cursor-store/local-storage.js.map +1 -0
- package/dist/platform/browser/index.d.ts +6 -0
- package/dist/platform/browser/index.d.ts.map +1 -0
- package/dist/platform/browser/index.js +6 -0
- package/dist/platform/browser/index.js.map +1 -0
- package/dist/platform/browser/layers.d.ts +13 -0
- package/dist/platform/browser/layers.d.ts.map +1 -0
- package/dist/platform/browser/layers.js +8 -0
- package/dist/platform/browser/layers.js.map +1 -0
- package/dist/platform/browser/storage/errors.d.ts +28 -0
- package/dist/platform/browser/storage/errors.d.ts.map +1 -0
- package/dist/platform/browser/storage/errors.js +17 -0
- package/dist/platform/browser/storage/errors.js.map +1 -0
- package/dist/platform/browser/storage/index.d.ts +3 -0
- package/dist/platform/browser/storage/index.d.ts.map +1 -0
- package/dist/platform/browser/storage/index.js +3 -0
- package/dist/platform/browser/storage/index.js.map +1 -0
- package/dist/platform/browser/storage/local-storage.d.ts +10 -0
- package/dist/platform/browser/storage/local-storage.d.ts.map +1 -0
- package/dist/platform/browser/storage/local-storage.js +89 -0
- package/dist/platform/browser/storage/local-storage.js.map +1 -0
- package/dist/platform/browser/tx-persistence/index.d.ts +2 -0
- package/dist/platform/browser/tx-persistence/index.d.ts.map +1 -0
- package/dist/platform/browser/tx-persistence/index.js +2 -0
- package/dist/platform/browser/tx-persistence/index.js.map +1 -0
- package/dist/platform/browser/tx-persistence/persistence.d.ts +22 -0
- package/dist/platform/browser/tx-persistence/persistence.d.ts.map +1 -0
- package/dist/platform/browser/tx-persistence/persistence.js +170 -0
- package/dist/platform/browser/tx-persistence/persistence.js.map +1 -0
- package/dist/platform/browser/tx-store/errors.d.ts +3 -0
- package/dist/platform/browser/tx-store/errors.d.ts.map +1 -0
- package/dist/platform/browser/tx-store/errors.js +2 -0
- package/dist/platform/browser/tx-store/errors.js.map +1 -0
- package/dist/platform/browser/tx-store/index.d.ts +5 -0
- package/dist/platform/browser/tx-store/index.d.ts.map +1 -0
- package/dist/platform/browser/tx-store/index.js +4 -0
- package/dist/platform/browser/tx-store/index.js.map +1 -0
- package/dist/platform/browser/tx-store/local-storage.d.ts +9 -0
- package/dist/platform/browser/tx-store/local-storage.d.ts.map +1 -0
- package/dist/platform/browser/tx-store/local-storage.js +163 -0
- package/dist/platform/browser/tx-store/local-storage.js.map +1 -0
- package/dist/platform/browser/tx-store/store.d.ts +16 -0
- package/dist/platform/browser/tx-store/store.d.ts.map +1 -0
- package/dist/platform/browser/tx-store/store.js +35 -0
- package/dist/platform/browser/tx-store/store.js.map +1 -0
- package/dist/platform/browser/tx-store/types.d.ts +34 -0
- package/dist/platform/browser/tx-store/types.d.ts.map +1 -0
- package/dist/platform/browser/tx-store/types.js +4 -0
- package/dist/platform/browser/tx-store/types.js.map +1 -0
- package/dist/presets/index.d.ts +3 -0
- package/dist/presets/index.d.ts.map +1 -0
- package/dist/presets/index.js +3 -0
- package/dist/presets/index.js.map +1 -0
- package/dist/presets/layers.d.ts +59 -0
- package/dist/presets/layers.d.ts.map +1 -0
- package/dist/presets/layers.js +317 -0
- package/dist/presets/layers.js.map +1 -0
- package/dist/presets/transports.d.ts +16 -0
- package/dist/presets/transports.d.ts.map +1 -0
- package/dist/presets/transports.js +19 -0
- package/dist/presets/transports.js.map +1 -0
- package/dist/query/chain-head.d.ts +14 -0
- package/dist/query/chain-head.d.ts.map +1 -0
- package/dist/query/chain-head.js +34 -0
- package/dist/query/chain-head.js.map +1 -0
- package/dist/query/client.d.ts +21 -0
- package/dist/query/client.d.ts.map +1 -0
- package/dist/query/client.js +64 -0
- package/dist/query/client.js.map +1 -0
- package/dist/query/contract-query.d.ts +25 -0
- package/dist/query/contract-query.d.ts.map +1 -0
- package/dist/query/contract-query.js +76 -0
- package/dist/query/contract-query.js.map +1 -0
- package/dist/query/index.d.ts +5 -0
- package/dist/query/index.d.ts.map +1 -0
- package/dist/query/index.js +5 -0
- package/dist/query/index.js.map +1 -0
- package/dist/query/multicall-batcher.d.ts +16 -0
- package/dist/query/multicall-batcher.d.ts.map +1 -0
- package/dist/query/multicall-batcher.js +62 -0
- package/dist/query/multicall-batcher.js.map +1 -0
- package/dist/react-hooks/index.d.ts +9 -0
- package/dist/react-hooks/index.d.ts.map +1 -0
- package/dist/react-hooks/index.js +7 -0
- package/dist/react-hooks/index.js.map +1 -0
- package/dist/react-hooks/use-is-safe-multisig.d.ts +2 -0
- package/dist/react-hooks/use-is-safe-multisig.d.ts.map +1 -0
- package/dist/react-hooks/use-is-safe-multisig.js +44 -0
- package/dist/react-hooks/use-is-safe-multisig.js.map +1 -0
- package/dist/react-hooks/use-safe-context.d.ts +2 -0
- package/dist/react-hooks/use-safe-context.d.ts.map +1 -0
- package/dist/react-hooks/use-safe-context.js +41 -0
- package/dist/react-hooks/use-safe-context.js.map +1 -0
- package/dist/react-hooks/wagmi/index.d.ts +2 -0
- package/dist/react-hooks/wagmi/index.d.ts.map +1 -0
- package/dist/react-hooks/wagmi/index.js +3 -0
- package/dist/react-hooks/wagmi/index.js.map +1 -0
- package/dist/rpc/cache.d.ts +25 -0
- package/dist/rpc/cache.d.ts.map +1 -0
- package/dist/rpc/cache.js +127 -0
- package/dist/rpc/cache.js.map +1 -0
- package/dist/rpc/circuit-breaker.d.ts +28 -0
- package/dist/rpc/circuit-breaker.d.ts.map +1 -0
- package/dist/rpc/circuit-breaker.js +108 -0
- package/dist/rpc/circuit-breaker.js.map +1 -0
- package/dist/rpc/dedup.d.ts +10 -0
- package/dist/rpc/dedup.d.ts.map +1 -0
- package/dist/rpc/dedup.js +39 -0
- package/dist/rpc/dedup.js.map +1 -0
- package/dist/rpc/index.d.ts +6 -0
- package/dist/rpc/index.d.ts.map +1 -0
- package/dist/rpc/index.js +6 -0
- package/dist/rpc/index.js.map +1 -0
- package/dist/rpc/retry.d.ts +15 -0
- package/dist/rpc/retry.d.ts.map +1 -0
- package/dist/rpc/retry.js +34 -0
- package/dist/rpc/retry.js.map +1 -0
- package/dist/rpc/routemesh.d.ts +29 -0
- package/dist/rpc/routemesh.d.ts.map +1 -0
- package/dist/rpc/routemesh.js +21 -0
- package/dist/rpc/routemesh.js.map +1 -0
- package/dist/safe/adapter.d.ts +9 -0
- package/dist/safe/adapter.d.ts.map +1 -0
- package/dist/safe/adapter.js +13 -0
- package/dist/safe/adapter.js.map +1 -0
- package/dist/safe/detection.d.ts +26 -0
- package/dist/safe/detection.d.ts.map +1 -0
- package/dist/safe/detection.js +102 -0
- package/dist/safe/detection.js.map +1 -0
- package/dist/safe/errors.d.ts +79 -0
- package/dist/safe/errors.d.ts.map +1 -0
- package/dist/safe/errors.js +34 -0
- package/dist/safe/errors.js.map +1 -0
- package/dist/safe/index.d.ts +8 -0
- package/dist/safe/index.d.ts.map +1 -0
- package/dist/safe/index.js +6 -0
- package/dist/safe/index.js.map +1 -0
- package/dist/safe/live.d.ts +8 -0
- package/dist/safe/live.d.ts.map +1 -0
- package/dist/safe/live.js +250 -0
- package/dist/safe/live.js.map +1 -0
- package/dist/safe/service.d.ts +26 -0
- package/dist/safe/service.d.ts.map +1 -0
- package/dist/safe/service.js +4 -0
- package/dist/safe/service.js.map +1 -0
- package/dist/safe/simulation/abis.d.ts +73 -0
- package/dist/safe/simulation/abis.d.ts.map +1 -0
- package/dist/safe/simulation/abis.js +61 -0
- package/dist/safe/simulation/abis.js.map +1 -0
- package/dist/safe/simulation/addresses.d.ts +4 -0
- package/dist/safe/simulation/addresses.d.ts.map +1 -0
- package/dist/safe/simulation/addresses.js +40 -0
- package/dist/safe/simulation/addresses.js.map +1 -0
- package/dist/safe/simulation/encoding.d.ts +16 -0
- package/dist/safe/simulation/encoding.d.ts.map +1 -0
- package/dist/safe/simulation/encoding.js +36 -0
- package/dist/safe/simulation/encoding.js.map +1 -0
- package/dist/safe/simulation/errors.d.ts +56 -0
- package/dist/safe/simulation/errors.d.ts.map +1 -0
- package/dist/safe/simulation/errors.js +37 -0
- package/dist/safe/simulation/errors.js.map +1 -0
- package/dist/safe/simulation/index.d.ts +7 -0
- package/dist/safe/simulation/index.d.ts.map +1 -0
- package/dist/safe/simulation/index.js +6 -0
- package/dist/safe/simulation/index.js.map +1 -0
- package/dist/safe/simulation/service.d.ts +14 -0
- package/dist/safe/simulation/service.d.ts.map +1 -0
- package/dist/safe/simulation/service.js +140 -0
- package/dist/safe/simulation/service.js.map +1 -0
- package/dist/safe/simulation/types.d.ts +20 -0
- package/dist/safe/simulation/types.d.ts.map +1 -0
- package/dist/safe/simulation/types.js +2 -0
- package/dist/safe/simulation/types.js.map +1 -0
- package/dist/safe/types.d.ts +61 -0
- package/dist/safe/types.d.ts.map +1 -0
- package/dist/safe/types.js +2 -0
- package/dist/safe/types.js.map +1 -0
- package/dist/signature/errors.d.ts +29 -0
- package/dist/signature/errors.d.ts.map +1 -0
- package/dist/signature/errors.js +19 -0
- package/dist/signature/errors.js.map +1 -0
- package/dist/signature/index.d.ts +4 -0
- package/dist/signature/index.d.ts.map +1 -0
- package/dist/signature/index.js +4 -0
- package/dist/signature/index.js.map +1 -0
- package/dist/signature/service.d.ts +34 -0
- package/dist/signature/service.d.ts.map +1 -0
- package/dist/signature/service.js +97 -0
- package/dist/signature/service.js.map +1 -0
- package/dist/signature/utils.d.ts +13 -0
- package/dist/signature/utils.d.ts.map +1 -0
- package/dist/signature/utils.js +17 -0
- package/dist/signature/utils.js.map +1 -0
- package/dist/simulation/errors.d.ts +36 -0
- package/dist/simulation/errors.d.ts.map +1 -0
- package/dist/simulation/errors.js +23 -0
- package/dist/simulation/errors.js.map +1 -0
- package/dist/simulation/index.d.ts +5 -0
- package/dist/simulation/index.d.ts.map +1 -0
- package/dist/simulation/index.js +5 -0
- package/dist/simulation/index.js.map +1 -0
- package/dist/simulation/service.d.ts +34 -0
- package/dist/simulation/service.d.ts.map +1 -0
- package/dist/simulation/service.js +149 -0
- package/dist/simulation/service.js.map +1 -0
- package/dist/simulation/tenderly.d.ts +26 -0
- package/dist/simulation/tenderly.d.ts.map +1 -0
- package/dist/simulation/tenderly.js +200 -0
- package/dist/simulation/tenderly.js.map +1 -0
- package/dist/simulation/types.d.ts +47 -0
- package/dist/simulation/types.d.ts.map +1 -0
- package/dist/simulation/types.js +2 -0
- package/dist/simulation/types.js.map +1 -0
- package/dist/subscriptions/block-subscription.d.ts +10 -0
- package/dist/subscriptions/block-subscription.d.ts.map +1 -0
- package/dist/subscriptions/block-subscription.js +31 -0
- package/dist/subscriptions/block-subscription.js.map +1 -0
- package/dist/subscriptions/errors.d.ts +21 -0
- package/dist/subscriptions/errors.d.ts.map +1 -0
- package/dist/subscriptions/errors.js +14 -0
- package/dist/subscriptions/errors.js.map +1 -0
- package/dist/subscriptions/index.d.ts +6 -0
- package/dist/subscriptions/index.d.ts.map +1 -0
- package/dist/subscriptions/index.js +6 -0
- package/dist/subscriptions/index.js.map +1 -0
- package/dist/subscriptions/log-subscription.d.ts +11 -0
- package/dist/subscriptions/log-subscription.d.ts.map +1 -0
- package/dist/subscriptions/log-subscription.js +35 -0
- package/dist/subscriptions/log-subscription.js.map +1 -0
- package/dist/subscriptions/pending-tx.d.ts +8 -0
- package/dist/subscriptions/pending-tx.d.ts.map +1 -0
- package/dist/subscriptions/pending-tx.js +39 -0
- package/dist/subscriptions/pending-tx.js.map +1 -0
- package/dist/subscriptions/service.d.ts +64 -0
- package/dist/subscriptions/service.d.ts.map +1 -0
- package/dist/subscriptions/service.js +56 -0
- package/dist/subscriptions/service.js.map +1 -0
- package/dist/telemetry/index.d.ts +3 -0
- package/dist/telemetry/index.d.ts.map +1 -0
- package/dist/telemetry/index.js +3 -0
- package/dist/telemetry/index.js.map +1 -0
- package/dist/telemetry/logger.d.ts +27 -0
- package/dist/telemetry/logger.d.ts.map +1 -0
- package/dist/telemetry/logger.js +7 -0
- package/dist/telemetry/logger.js.map +1 -0
- package/dist/telemetry/tracer.d.ts +94 -0
- package/dist/telemetry/tracer.d.ts.map +1 -0
- package/dist/telemetry/tracer.js +94 -0
- package/dist/telemetry/tracer.js.map +1 -0
- package/dist/testing-kit/_fixtures/addresses.d.ts +6 -0
- package/dist/testing-kit/_fixtures/addresses.d.ts.map +1 -0
- package/dist/testing-kit/_fixtures/addresses.js +7 -0
- package/dist/testing-kit/_fixtures/addresses.js.map +1 -0
- package/dist/testing-kit/_fixtures/receipts.d.ts +19 -0
- package/dist/testing-kit/_fixtures/receipts.d.ts.map +1 -0
- package/dist/testing-kit/_fixtures/receipts.js +22 -0
- package/dist/testing-kit/_fixtures/receipts.js.map +1 -0
- package/dist/testing-kit/helpers.d.ts +21 -0
- package/dist/testing-kit/helpers.d.ts.map +1 -0
- package/dist/testing-kit/helpers.js +56 -0
- package/dist/testing-kit/helpers.js.map +1 -0
- package/dist/testing-kit/index.d.ts +34 -0
- package/dist/testing-kit/index.d.ts.map +1 -0
- package/dist/testing-kit/index.js +19 -0
- package/dist/testing-kit/index.js.map +1 -0
- package/dist/testing-kit/mock-balance-service.d.ts +47 -0
- package/dist/testing-kit/mock-balance-service.d.ts.map +1 -0
- package/dist/testing-kit/mock-balance-service.js +28 -0
- package/dist/testing-kit/mock-balance-service.js.map +1 -0
- package/dist/testing-kit/mock-block-service.d.ts +44 -0
- package/dist/testing-kit/mock-block-service.d.ts.map +1 -0
- package/dist/testing-kit/mock-block-service.js +55 -0
- package/dist/testing-kit/mock-block-service.js.map +1 -0
- package/dist/testing-kit/mock-cross-chain-reader.d.ts +18 -0
- package/dist/testing-kit/mock-cross-chain-reader.d.ts.map +1 -0
- package/dist/testing-kit/mock-cross-chain-reader.js +65 -0
- package/dist/testing-kit/mock-cross-chain-reader.js.map +1 -0
- package/dist/testing-kit/mock-deploy-service.d.ts +47 -0
- package/dist/testing-kit/mock-deploy-service.d.ts.map +1 -0
- package/dist/testing-kit/mock-deploy-service.js +52 -0
- package/dist/testing-kit/mock-deploy-service.js.map +1 -0
- package/dist/testing-kit/mock-erc721-service.d.ts +87 -0
- package/dist/testing-kit/mock-erc721-service.d.ts.map +1 -0
- package/dist/testing-kit/mock-erc721-service.js +41 -0
- package/dist/testing-kit/mock-erc721-service.js.map +1 -0
- package/dist/testing-kit/mock-gas-service.d.ts +33 -0
- package/dist/testing-kit/mock-gas-service.d.ts.map +1 -0
- package/dist/testing-kit/mock-gas-service.js +58 -0
- package/dist/testing-kit/mock-gas-service.js.map +1 -0
- package/dist/testing-kit/mock-nonce-service.d.ts +43 -0
- package/dist/testing-kit/mock-nonce-service.d.ts.map +1 -0
- package/dist/testing-kit/mock-nonce-service.js +24 -0
- package/dist/testing-kit/mock-nonce-service.js.map +1 -0
- package/dist/testing-kit/mock-public-client.d.ts +56 -0
- package/dist/testing-kit/mock-public-client.d.ts.map +1 -0
- package/dist/testing-kit/mock-public-client.js +91 -0
- package/dist/testing-kit/mock-public-client.js.map +1 -0
- package/dist/testing-kit/mock-signature-service.d.ts +50 -0
- package/dist/testing-kit/mock-signature-service.d.ts.map +1 -0
- package/dist/testing-kit/mock-signature-service.js +30 -0
- package/dist/testing-kit/mock-signature-service.js.map +1 -0
- package/dist/testing-kit/mock-simulation-service.d.ts +29 -0
- package/dist/testing-kit/mock-simulation-service.d.ts.map +1 -0
- package/dist/testing-kit/mock-simulation-service.js +28 -0
- package/dist/testing-kit/mock-simulation-service.js.map +1 -0
- package/dist/testing-kit/mock-subscription-service.d.ts +52 -0
- package/dist/testing-kit/mock-subscription-service.d.ts.map +1 -0
- package/dist/testing-kit/mock-subscription-service.js +49 -0
- package/dist/testing-kit/mock-subscription-service.js.map +1 -0
- package/dist/testing-kit/mock-transfer-service.d.ts +28 -0
- package/dist/testing-kit/mock-transfer-service.d.ts.map +1 -0
- package/dist/testing-kit/mock-transfer-service.js +17 -0
- package/dist/testing-kit/mock-transfer-service.js.map +1 -0
- package/dist/testing-kit/mock-wallet-client.d.ts +17 -0
- package/dist/testing-kit/mock-wallet-client.d.ts.map +1 -0
- package/dist/testing-kit/mock-wallet-client.js +30 -0
- package/dist/testing-kit/mock-wallet-client.js.map +1 -0
- package/dist/testing-kit/mock-wallet-provider.d.ts +11 -0
- package/dist/testing-kit/mock-wallet-provider.d.ts.map +1 -0
- package/dist/testing-kit/mock-wallet-provider.js +6 -0
- package/dist/testing-kit/mock-wallet-provider.js.map +1 -0
- package/dist/testing-kit/test-layer.d.ts +42 -0
- package/dist/testing-kit/test-layer.d.ts.map +1 -0
- package/dist/testing-kit/test-layer.js +65 -0
- package/dist/testing-kit/test-layer.js.map +1 -0
- package/dist/transfer/index.d.ts +2 -0
- package/dist/transfer/index.d.ts.map +1 -0
- package/dist/transfer/index.js +2 -0
- package/dist/transfer/index.js.map +1 -0
- package/dist/transfer/service.d.ts +37 -0
- package/dist/transfer/service.d.ts.map +1 -0
- package/dist/transfer/service.js +146 -0
- package/dist/transfer/service.js.map +1 -0
- package/dist/tx/fees.d.ts +17 -0
- package/dist/tx/fees.d.ts.map +1 -0
- package/dist/tx/fees.js +49 -0
- package/dist/tx/fees.js.map +1 -0
- package/dist/tx/index.d.ts +6 -0
- package/dist/tx/index.d.ts.map +1 -0
- package/dist/tx/index.js +6 -0
- package/dist/tx/index.js.map +1 -0
- package/dist/tx/manager.d.ts +23 -0
- package/dist/tx/manager.d.ts.map +1 -0
- package/dist/tx/manager.js +240 -0
- package/dist/tx/manager.js.map +1 -0
- package/dist/tx/policy.d.ts +18 -0
- package/dist/tx/policy.d.ts.map +1 -0
- package/dist/tx/policy.js +9 -0
- package/dist/tx/policy.js.map +1 -0
- package/dist/tx/replacement.d.ts +17 -0
- package/dist/tx/replacement.d.ts.map +1 -0
- package/dist/tx/replacement.js +116 -0
- package/dist/tx/replacement.js.map +1 -0
- package/dist/tx/tracker.d.ts +72 -0
- package/dist/tx/tracker.d.ts.map +1 -0
- package/dist/tx/tracker.js +95 -0
- package/dist/tx/tracker.js.map +1 -0
- package/dist/types/abi.d.ts +13 -0
- package/dist/types/abi.d.ts.map +1 -0
- package/dist/types/abi.js +2 -0
- package/dist/types/abi.js.map +1 -0
- package/dist/types/index.d.ts +4 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +4 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types/params.d.ts +56 -0
- package/dist/types/params.d.ts.map +1 -0
- package/dist/types/params.js +2 -0
- package/dist/types/params.js.map +1 -0
- package/dist/types/tx-overrides.d.ts +20 -0
- package/dist/types/tx-overrides.d.ts.map +1 -0
- package/dist/types/tx-overrides.js +2 -0
- package/dist/types/tx-overrides.js.map +1 -0
- package/dist/wagmi/index.d.ts +2 -0
- package/dist/wagmi/index.d.ts.map +1 -0
- package/dist/wagmi/index.js +2 -0
- package/dist/wagmi/index.js.map +1 -0
- package/dist/wagmi/layers.d.ts +2 -0
- package/dist/wagmi/layers.d.ts.map +1 -0
- package/dist/wagmi/layers.js +2 -0
- package/dist/wagmi/layers.js.map +1 -0
- package/dist/wallet/errors.d.ts +68 -0
- package/dist/wallet/errors.d.ts.map +1 -0
- package/dist/wallet/errors.js +43 -0
- package/dist/wallet/errors.js.map +1 -0
- package/dist/wallet/index.d.ts +7 -0
- package/dist/wallet/index.d.ts.map +1 -0
- package/dist/wallet/index.js +7 -0
- package/dist/wallet/index.js.map +1 -0
- package/dist/wallet/lifecycle.d.ts +22 -0
- package/dist/wallet/lifecycle.d.ts.map +1 -0
- package/dist/wallet/lifecycle.js +242 -0
- package/dist/wallet/lifecycle.js.map +1 -0
- package/dist/wallet/operations.d.ts +8 -0
- package/dist/wallet/operations.d.ts.map +1 -0
- package/dist/wallet/operations.js +211 -0
- package/dist/wallet/operations.js.map +1 -0
- package/dist/wallet/provider-ref.d.ts +14 -0
- package/dist/wallet/provider-ref.d.ts.map +1 -0
- package/dist/wallet/provider-ref.js +13 -0
- package/dist/wallet/provider-ref.js.map +1 -0
- package/dist/wallet/service.d.ts +22 -0
- package/dist/wallet/service.d.ts.map +1 -0
- package/dist/wallet/service.js +156 -0
- package/dist/wallet/service.js.map +1 -0
- package/dist/wallet/types.d.ts +37 -0
- package/dist/wallet/types.d.ts.map +1 -0
- package/dist/wallet/types.js +2 -0
- package/dist/wallet/types.js.map +1 -0
- package/package.json +87 -0
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { Context, Layer } from "effect";
|
|
2
|
+
import { ContractReader, ContractWriter } from "../../contract/index.js";
|
|
3
|
+
import type { Erc20AllowanceServiceShape } from "../../erc20/allowance/index.js";
|
|
4
|
+
declare const Erc20NoOutputAllowanceService_base: Context.TagClass<Erc20NoOutputAllowanceService, "ew3/Erc20NoOutputAllowanceService", Erc20AllowanceServiceShape>;
|
|
5
|
+
export declare class Erc20NoOutputAllowanceService extends Erc20NoOutputAllowanceService_base {
|
|
6
|
+
}
|
|
7
|
+
export declare const Erc20NoOutputAllowanceServiceLive: Layer.Layer<Erc20NoOutputAllowanceService, never, ContractReader | ContractWriter>;
|
|
8
|
+
export {};
|
|
9
|
+
//# sourceMappingURL=no-output.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"no-output.d.ts","sourceRoot":"","sources":["../../../src/erc20/allowance/no-output.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAU,KAAK,EAAE,MAAM,QAAQ,CAAC;AAGhD,OAAO,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AAOzE,OAAO,KAAK,EAIV,0BAA0B,EAC3B,MAAM,gCAAgC,CAAC;;AAExC,qBAAa,6BAA8B,SAAQ,kCAGhD;CAAG;AAEN,eAAO,MAAM,iCAAiC,oFA+I7C,CAAC"}
|
|
@@ -0,0 +1,122 @@
|
|
|
1
|
+
import { Context, Effect, Layer } from "effect";
|
|
2
|
+
import { erc20Abi, maxUint256 } from "viem";
|
|
3
|
+
import { erc20NoOutputAbi } from "../../abi/index.js";
|
|
4
|
+
import { ContractReader, ContractWriter } from "../../contract/index.js";
|
|
5
|
+
import { ApprovalCheckError, ApprovalError } from "../../core/index.js";
|
|
6
|
+
export class Erc20NoOutputAllowanceService extends Context.Tag("ew3/Erc20NoOutputAllowanceService")() {
|
|
7
|
+
}
|
|
8
|
+
export const Erc20NoOutputAllowanceServiceLive = Layer.effect(Erc20NoOutputAllowanceService, Effect.gen(function* () {
|
|
9
|
+
const reader = yield* ContractReader;
|
|
10
|
+
const writer = yield* ContractWriter;
|
|
11
|
+
const approve = Effect.fn("approve")(function* (params) {
|
|
12
|
+
const writeParams = {
|
|
13
|
+
abi: erc20NoOutputAbi,
|
|
14
|
+
account: params.account,
|
|
15
|
+
address: params.tokenAddress,
|
|
16
|
+
args: [params.spender, params.amount],
|
|
17
|
+
chainId: params.chainId,
|
|
18
|
+
functionName: "approve",
|
|
19
|
+
};
|
|
20
|
+
yield* writer.simulate(writeParams).pipe(Effect.mapError((e) => {
|
|
21
|
+
if (e._tag === "ClientNotFoundError" ||
|
|
22
|
+
e._tag === "InsufficientFundsError" ||
|
|
23
|
+
e._tag === "UserRejectedError") {
|
|
24
|
+
return e;
|
|
25
|
+
}
|
|
26
|
+
return new ApprovalError({
|
|
27
|
+
cause: e,
|
|
28
|
+
message: `Approval simulation failed: ${String(e.message)}`,
|
|
29
|
+
spender: params.spender,
|
|
30
|
+
tokenAddress: params.tokenAddress,
|
|
31
|
+
});
|
|
32
|
+
}));
|
|
33
|
+
return yield* writer.write(writeParams);
|
|
34
|
+
});
|
|
35
|
+
const checkAllowance = Effect.fn("checkAllowance")(function* (params) {
|
|
36
|
+
const result = yield* reader
|
|
37
|
+
.read({
|
|
38
|
+
abi: erc20Abi,
|
|
39
|
+
address: params.tokenAddress,
|
|
40
|
+
args: [params.owner, params.spender],
|
|
41
|
+
chainId: params.chainId,
|
|
42
|
+
functionName: "allowance",
|
|
43
|
+
})
|
|
44
|
+
.pipe(Effect.mapError((e) => {
|
|
45
|
+
if (e._tag === "ClientNotFoundError") {
|
|
46
|
+
return e;
|
|
47
|
+
}
|
|
48
|
+
return new ApprovalCheckError({
|
|
49
|
+
cause: e,
|
|
50
|
+
message: `Failed to check allowance: ${String(e.message)}`,
|
|
51
|
+
owner: params.owner,
|
|
52
|
+
spender: params.spender,
|
|
53
|
+
tokenAddress: params.tokenAddress,
|
|
54
|
+
});
|
|
55
|
+
}));
|
|
56
|
+
return result;
|
|
57
|
+
});
|
|
58
|
+
const ensureAllowance = Effect.fn("ensureAllowance")(function* (params) {
|
|
59
|
+
if (params.required <= 0n) {
|
|
60
|
+
return { currentAllowance: 0n, status: "already-sufficient" };
|
|
61
|
+
}
|
|
62
|
+
const currentAllowance = yield* checkAllowance({
|
|
63
|
+
chainId: params.chainId,
|
|
64
|
+
owner: params.account,
|
|
65
|
+
spender: params.spender,
|
|
66
|
+
tokenAddress: params.tokenAddress,
|
|
67
|
+
});
|
|
68
|
+
if (currentAllowance >= params.required) {
|
|
69
|
+
return { currentAllowance, status: "already-sufficient" };
|
|
70
|
+
}
|
|
71
|
+
const approveAmount = params.approveAmount ?? params.required;
|
|
72
|
+
const zeroFirst = params.zeroFirst ?? true;
|
|
73
|
+
const direct = approve({
|
|
74
|
+
account: params.account,
|
|
75
|
+
amount: approveAmount,
|
|
76
|
+
chainId: params.chainId,
|
|
77
|
+
spender: params.spender,
|
|
78
|
+
tokenAddress: params.tokenAddress,
|
|
79
|
+
}).pipe(Effect.either);
|
|
80
|
+
const directResult = yield* direct;
|
|
81
|
+
if (directResult._tag === "Right") {
|
|
82
|
+
return {
|
|
83
|
+
approveAmount,
|
|
84
|
+
currentAllowance,
|
|
85
|
+
hashes: [directResult.right],
|
|
86
|
+
mode: "direct",
|
|
87
|
+
status: "approved",
|
|
88
|
+
};
|
|
89
|
+
}
|
|
90
|
+
if (!zeroFirst || currentAllowance === 0n) {
|
|
91
|
+
return yield* Effect.fail(directResult.left);
|
|
92
|
+
}
|
|
93
|
+
const resetHash = yield* approve({
|
|
94
|
+
account: params.account,
|
|
95
|
+
amount: 0n,
|
|
96
|
+
chainId: params.chainId,
|
|
97
|
+
spender: params.spender,
|
|
98
|
+
tokenAddress: params.tokenAddress,
|
|
99
|
+
});
|
|
100
|
+
const approveHash = yield* approve({
|
|
101
|
+
account: params.account,
|
|
102
|
+
amount: approveAmount,
|
|
103
|
+
chainId: params.chainId,
|
|
104
|
+
spender: params.spender,
|
|
105
|
+
tokenAddress: params.tokenAddress,
|
|
106
|
+
});
|
|
107
|
+
return {
|
|
108
|
+
approveAmount,
|
|
109
|
+
currentAllowance,
|
|
110
|
+
hashes: [resetHash, approveHash],
|
|
111
|
+
mode: "zero-first",
|
|
112
|
+
status: "approved",
|
|
113
|
+
};
|
|
114
|
+
});
|
|
115
|
+
return Erc20NoOutputAllowanceService.of({
|
|
116
|
+
approve,
|
|
117
|
+
checkAllowance,
|
|
118
|
+
ensureAllowance,
|
|
119
|
+
getMaxAmount: (_decimals) => maxUint256,
|
|
120
|
+
});
|
|
121
|
+
}));
|
|
122
|
+
//# sourceMappingURL=no-output.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"no-output.js","sourceRoot":"","sources":["../../../src/erc20/allowance/no-output.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import type { Effect } from "effect";
|
|
2
|
+
import type { Address, Hash } from "viem";
|
|
3
|
+
import type { ApprovalCheckError, ApprovalError, ClientNotFoundError, ContractWriteError, InsufficientFundsError, UserRejectedError, WalletNotConnectedError, WrongNetworkError } from "../../core/index.js";
|
|
4
|
+
export type CheckAllowanceParams = {
|
|
5
|
+
readonly chainId: number;
|
|
6
|
+
readonly owner: Address;
|
|
7
|
+
readonly spender: Address;
|
|
8
|
+
readonly tokenAddress: Address;
|
|
9
|
+
};
|
|
10
|
+
export type ApproveParams = {
|
|
11
|
+
readonly account: Address;
|
|
12
|
+
readonly amount: bigint;
|
|
13
|
+
readonly chainId: number;
|
|
14
|
+
readonly spender: Address;
|
|
15
|
+
readonly tokenAddress: Address;
|
|
16
|
+
};
|
|
17
|
+
export type EnsureAllowanceParams = {
|
|
18
|
+
readonly account: Address;
|
|
19
|
+
readonly chainId: number;
|
|
20
|
+
readonly required: bigint;
|
|
21
|
+
readonly spender: Address;
|
|
22
|
+
readonly tokenAddress: Address;
|
|
23
|
+
readonly approveAmount?: bigint | undefined;
|
|
24
|
+
readonly zeroFirst?: boolean | undefined;
|
|
25
|
+
};
|
|
26
|
+
export type EnsureAllowanceResult = {
|
|
27
|
+
readonly status: "already-sufficient";
|
|
28
|
+
readonly currentAllowance: bigint;
|
|
29
|
+
} | {
|
|
30
|
+
readonly status: "approved";
|
|
31
|
+
readonly approveAmount: bigint;
|
|
32
|
+
readonly currentAllowance: bigint;
|
|
33
|
+
readonly hashes: readonly Hash[];
|
|
34
|
+
readonly mode: "direct" | "zero-first";
|
|
35
|
+
};
|
|
36
|
+
export type Erc20AllowanceServiceShape = {
|
|
37
|
+
readonly checkAllowance: (params: CheckAllowanceParams) => Effect.Effect<bigint, ApprovalCheckError | ClientNotFoundError>;
|
|
38
|
+
readonly approve: (params: ApproveParams) => Effect.Effect<Hash, ApprovalError | ClientNotFoundError | ContractWriteError | InsufficientFundsError | UserRejectedError | WalletNotConnectedError | WrongNetworkError>;
|
|
39
|
+
readonly ensureAllowance: (params: EnsureAllowanceParams) => Effect.Effect<EnsureAllowanceResult, ApprovalCheckError | ApprovalError | ClientNotFoundError | ContractWriteError | InsufficientFundsError | UserRejectedError | WalletNotConnectedError | WrongNetworkError>;
|
|
40
|
+
readonly getMaxAmount: (decimals: number) => bigint;
|
|
41
|
+
};
|
|
42
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/erc20/allowance/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AACrC,OAAO,KAAK,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAC1C,OAAO,KAAK,EACV,kBAAkB,EAClB,aAAa,EACb,mBAAmB,EACnB,kBAAkB,EAClB,sBAAsB,EACtB,iBAAiB,EACjB,uBAAuB,EACvB,iBAAiB,EAClB,MAAM,qBAAqB,CAAC;AAE7B,MAAM,MAAM,oBAAoB,GAAG;IACjC,QAAQ,CAAC,OAAO,EAAE,MAAM,CAAC;IACzB,QAAQ,CAAC,KAAK,EAAE,OAAO,CAAC;IACxB,QAAQ,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1B,QAAQ,CAAC,YAAY,EAAE,OAAO,CAAC;CAChC,CAAC;AAEF,MAAM,MAAM,aAAa,GAAG;IAC1B,QAAQ,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1B,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC;IACxB,QAAQ,CAAC,OAAO,EAAE,MAAM,CAAC;IACzB,QAAQ,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1B,QAAQ,CAAC,YAAY,EAAE,OAAO,CAAC;CAChC,CAAC;AAEF,MAAM,MAAM,qBAAqB,GAAG;IAClC,QAAQ,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1B,QAAQ,CAAC,OAAO,EAAE,MAAM,CAAC;IACzB,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAC;IAC1B,QAAQ,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1B,QAAQ,CAAC,YAAY,EAAE,OAAO,CAAC;IAM/B,QAAQ,CAAC,aAAa,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;IAK5C,QAAQ,CAAC,SAAS,CAAC,EAAE,OAAO,GAAG,SAAS,CAAC;CAC1C,CAAC;AAEF,MAAM,MAAM,qBAAqB,GAC7B;IACE,QAAQ,CAAC,MAAM,EAAE,oBAAoB,CAAC;IACtC,QAAQ,CAAC,gBAAgB,EAAE,MAAM,CAAC;CACnC,GACD;IACE,QAAQ,CAAC,MAAM,EAAE,UAAU,CAAC;IAC5B,QAAQ,CAAC,aAAa,EAAE,MAAM,CAAC;IAC/B,QAAQ,CAAC,gBAAgB,EAAE,MAAM,CAAC;IAClC,QAAQ,CAAC,MAAM,EAAE,SAAS,IAAI,EAAE,CAAC;IACjC,QAAQ,CAAC,IAAI,EAAE,QAAQ,GAAG,YAAY,CAAC;CACxC,CAAC;AAEN,MAAM,MAAM,0BAA0B,GAAG;IACvC,QAAQ,CAAC,cAAc,EAAE,CACvB,MAAM,EAAE,oBAAoB,KACzB,MAAM,CAAC,MAAM,CAAC,MAAM,EAAE,kBAAkB,GAAG,mBAAmB,CAAC,CAAC;IAErE,QAAQ,CAAC,OAAO,EAAE,CAChB,MAAM,EAAE,aAAa,KAClB,MAAM,CAAC,MAAM,CAChB,IAAI,EACF,aAAa,GACb,mBAAmB,GACnB,kBAAkB,GAClB,sBAAsB,GACtB,iBAAiB,GACjB,uBAAuB,GACvB,iBAAiB,CACpB,CAAC;IAEF,QAAQ,CAAC,eAAe,EAAE,CACxB,MAAM,EAAE,qBAAqB,KAC1B,MAAM,CAAC,MAAM,CAChB,qBAAqB,EACnB,kBAAkB,GAClB,aAAa,GACb,mBAAmB,GACnB,kBAAkB,GAClB,sBAAsB,GACtB,iBAAiB,GACjB,uBAAuB,GACvB,iBAAiB,CACpB,CAAC;IAQF,QAAQ,CAAC,YAAY,EAAE,CAAC,QAAQ,EAAE,MAAM,KAAK,MAAM,CAAC;CACrD,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/erc20/allowance/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/erc20/index.ts"],"names":[],"mappings":"AAAA,cAAc,sBAAsB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/erc20/index.ts"],"names":[],"mappings":"AAAA,cAAc,sBAAsB,CAAC"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { Schema } from "effect";
|
|
2
|
+
declare const Erc721OwnerNotFoundError_base: Schema.TaggedErrorClass<Erc721OwnerNotFoundError, "Erc721OwnerNotFoundError", {
|
|
3
|
+
readonly _tag: Schema.tag<"Erc721OwnerNotFoundError">;
|
|
4
|
+
} & {
|
|
5
|
+
address: typeof Schema.String;
|
|
6
|
+
chainId: typeof Schema.Number;
|
|
7
|
+
message: typeof Schema.String;
|
|
8
|
+
tokenId: typeof Schema.BigIntFromSelf;
|
|
9
|
+
}>;
|
|
10
|
+
export declare class Erc721OwnerNotFoundError extends Erc721OwnerNotFoundError_base {
|
|
11
|
+
}
|
|
12
|
+
declare const Erc721NoTokenURIError_base: Schema.TaggedErrorClass<Erc721NoTokenURIError, "Erc721NoTokenURIError", {
|
|
13
|
+
readonly _tag: Schema.tag<"Erc721NoTokenURIError">;
|
|
14
|
+
} & {
|
|
15
|
+
address: typeof Schema.String;
|
|
16
|
+
chainId: typeof Schema.Number;
|
|
17
|
+
message: typeof Schema.String;
|
|
18
|
+
tokenId: typeof Schema.BigIntFromSelf;
|
|
19
|
+
}>;
|
|
20
|
+
export declare class Erc721NoTokenURIError extends Erc721NoTokenURIError_base {
|
|
21
|
+
}
|
|
22
|
+
declare const Erc721MetadataFetchError_base: Schema.TaggedErrorClass<Erc721MetadataFetchError, "Erc721MetadataFetchError", {
|
|
23
|
+
readonly _tag: Schema.tag<"Erc721MetadataFetchError">;
|
|
24
|
+
} & {
|
|
25
|
+
address: typeof Schema.String;
|
|
26
|
+
cause: Schema.optional<typeof Schema.Unknown>;
|
|
27
|
+
chainId: typeof Schema.Number;
|
|
28
|
+
message: typeof Schema.String;
|
|
29
|
+
tokenId: typeof Schema.BigIntFromSelf;
|
|
30
|
+
uri: typeof Schema.String;
|
|
31
|
+
}>;
|
|
32
|
+
export declare class Erc721MetadataFetchError extends Erc721MetadataFetchError_base {
|
|
33
|
+
}
|
|
34
|
+
declare const Erc721TransferError_base: Schema.TaggedErrorClass<Erc721TransferError, "Erc721TransferError", {
|
|
35
|
+
readonly _tag: Schema.tag<"Erc721TransferError">;
|
|
36
|
+
} & {
|
|
37
|
+
address: typeof Schema.String;
|
|
38
|
+
cause: Schema.optional<typeof Schema.Unknown>;
|
|
39
|
+
from: typeof Schema.String;
|
|
40
|
+
message: typeof Schema.String;
|
|
41
|
+
to: typeof Schema.String;
|
|
42
|
+
tokenId: typeof Schema.BigIntFromSelf;
|
|
43
|
+
}>;
|
|
44
|
+
export declare class Erc721TransferError extends Erc721TransferError_base {
|
|
45
|
+
}
|
|
46
|
+
export {};
|
|
47
|
+
//# sourceMappingURL=errors.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"errors.d.ts","sourceRoot":"","sources":["../../src/erc721/errors.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;;;;;;;;;AAEhC,qBAAa,wBAAyB,SAAQ,6BAQ7C;CAAG;;;;;;;;;AAEJ,qBAAa,qBAAsB,SAAQ,0BAQ1C;CAAG;;;;;;;;;;;AAEJ,qBAAa,wBAAyB,SAAQ,6BAU7C;CAAG;;;;;;;;;;;AAEJ,qBAAa,mBAAoB,SAAQ,wBAUxC;CAAG"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { Schema } from "effect";
|
|
2
|
+
export class Erc721OwnerNotFoundError extends Schema.TaggedError()("Erc721OwnerNotFoundError", {
|
|
3
|
+
address: Schema.String,
|
|
4
|
+
chainId: Schema.Number,
|
|
5
|
+
message: Schema.String,
|
|
6
|
+
tokenId: Schema.BigIntFromSelf,
|
|
7
|
+
}) {
|
|
8
|
+
}
|
|
9
|
+
export class Erc721NoTokenURIError extends Schema.TaggedError()("Erc721NoTokenURIError", {
|
|
10
|
+
address: Schema.String,
|
|
11
|
+
chainId: Schema.Number,
|
|
12
|
+
message: Schema.String,
|
|
13
|
+
tokenId: Schema.BigIntFromSelf,
|
|
14
|
+
}) {
|
|
15
|
+
}
|
|
16
|
+
export class Erc721MetadataFetchError extends Schema.TaggedError()("Erc721MetadataFetchError", {
|
|
17
|
+
address: Schema.String,
|
|
18
|
+
cause: Schema.optional(Schema.Unknown),
|
|
19
|
+
chainId: Schema.Number,
|
|
20
|
+
message: Schema.String,
|
|
21
|
+
tokenId: Schema.BigIntFromSelf,
|
|
22
|
+
uri: Schema.String,
|
|
23
|
+
}) {
|
|
24
|
+
}
|
|
25
|
+
export class Erc721TransferError extends Schema.TaggedError()("Erc721TransferError", {
|
|
26
|
+
address: Schema.String,
|
|
27
|
+
cause: Schema.optional(Schema.Unknown),
|
|
28
|
+
from: Schema.String,
|
|
29
|
+
message: Schema.String,
|
|
30
|
+
to: Schema.String,
|
|
31
|
+
tokenId: Schema.BigIntFromSelf,
|
|
32
|
+
}) {
|
|
33
|
+
}
|
|
34
|
+
//# sourceMappingURL=errors.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"errors.js","sourceRoot":"","sources":["../../src/erc721/errors.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAEhC,MAAM,OAAO,wBAAyB,SAAQ,MAAM,CAAC,WAAW,EAA4B,CAC1F,0BAA0B,EAC1B;IACE,OAAO,EAAE,MAAM,CAAC,MAAM;IACtB,OAAO,EAAE,MAAM,CAAC,MAAM;IACtB,OAAO,EAAE,MAAM,CAAC,MAAM;IACtB,OAAO,EAAE,MAAM,CAAC,cAAc;CAC/B,CACF;CAAG;AAEJ,MAAM,OAAO,qBAAsB,SAAQ,MAAM,CAAC,WAAW,EAAyB,CACpF,uBAAuB,EACvB;IACE,OAAO,EAAE,MAAM,CAAC,MAAM;IACtB,OAAO,EAAE,MAAM,CAAC,MAAM;IACtB,OAAO,EAAE,MAAM,CAAC,MAAM;IACtB,OAAO,EAAE,MAAM,CAAC,cAAc;CAC/B,CACF;CAAG;AAEJ,MAAM,OAAO,wBAAyB,SAAQ,MAAM,CAAC,WAAW,EAA4B,CAC1F,0BAA0B,EAC1B;IACE,OAAO,EAAE,MAAM,CAAC,MAAM;IACtB,KAAK,EAAE,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,OAAO,CAAC;IACtC,OAAO,EAAE,MAAM,CAAC,MAAM;IACtB,OAAO,EAAE,MAAM,CAAC,MAAM;IACtB,OAAO,EAAE,MAAM,CAAC,cAAc;IAC9B,GAAG,EAAE,MAAM,CAAC,MAAM;CACnB,CACF;CAAG;AAEJ,MAAM,OAAO,mBAAoB,SAAQ,MAAM,CAAC,WAAW,EAAuB,CAChF,qBAAqB,EACrB;IACE,OAAO,EAAE,MAAM,CAAC,MAAM;IACtB,KAAK,EAAE,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,OAAO,CAAC;IACtC,IAAI,EAAE,MAAM,CAAC,MAAM;IACnB,OAAO,EAAE,MAAM,CAAC,MAAM;IACtB,EAAE,EAAE,MAAM,CAAC,MAAM;IACjB,OAAO,EAAE,MAAM,CAAC,cAAc;CAC/B,CACF;CAAG"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { Effect } from "effect";
|
|
2
|
+
import type { Address, Hash, WalletClient } from "viem";
|
|
3
|
+
import type { PublicClientServiceShape, WalletClientServiceShape } from "../core/clients/index.js";
|
|
4
|
+
import type { ClientNotFoundError, WalletNotConnectedError, WrongNetworkError } from "../core/errors/index.js";
|
|
5
|
+
export declare const readErc721: <TResult, E>(publicClientService: PublicClientServiceShape, params: {
|
|
6
|
+
address: Address;
|
|
7
|
+
args?: readonly unknown[];
|
|
8
|
+
chainId: number;
|
|
9
|
+
errorFactory: (cause: unknown) => E;
|
|
10
|
+
functionName: string;
|
|
11
|
+
}) => Effect.Effect<TResult, E | ClientNotFoundError>;
|
|
12
|
+
export declare const writeErc721: <E>(walletClientService: WalletClientServiceShape, params: {
|
|
13
|
+
account: Address;
|
|
14
|
+
address: Address;
|
|
15
|
+
args: readonly unknown[];
|
|
16
|
+
chainId: number;
|
|
17
|
+
errorFactory: (cause: unknown) => E;
|
|
18
|
+
functionName: string;
|
|
19
|
+
}) => Effect.Effect<Hash, E | WalletNotConnectedError | WrongNetworkError>;
|
|
20
|
+
export declare const resolveAccount: (walletClient: WalletClient, params: {
|
|
21
|
+
account?: Address;
|
|
22
|
+
chainId: number;
|
|
23
|
+
}, errorFactory: (chainId: number) => WalletNotConnectedError) => Effect.Effect<Address, WalletNotConnectedError>;
|
|
24
|
+
//# sourceMappingURL=helpers.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"helpers.d.ts","sourceRoot":"","sources":["../../src/erc721/helpers.ts"],"names":[],"mappings":"AAQA,OAAO,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAChC,OAAO,KAAK,EAAE,OAAO,EAAE,IAAI,EAAE,YAAY,EAAE,MAAM,MAAM,CAAC;AAExD,OAAO,KAAK,EACV,wBAAwB,EACxB,wBAAwB,EACzB,MAAM,6BAA6B,CAAC;AACrC,OAAO,KAAK,EACV,mBAAmB,EACnB,uBAAuB,EACvB,iBAAiB,EAClB,MAAM,4BAA4B,CAAC;AAMpC,eAAO,MAAM,UAAU,GAAI,OAAO,EAAE,CAAC,EACnC,qBAAqB,wBAAwB,EAC7C,QAAQ;IACN,OAAO,EAAE,OAAO,CAAC;IACjB,IAAI,CAAC,EAAE,SAAS,OAAO,EAAE,CAAC;IAC1B,OAAO,EAAE,MAAM,CAAC;IAChB,YAAY,EAAE,CAAC,KAAK,EAAE,OAAO,KAAK,CAAC,CAAC;IACpC,YAAY,EAAE,MAAM,CAAC;CACtB,KACA,MAAM,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC,GAAG,mBAAmB,CAY9C,CAAC;AAKJ,eAAO,MAAM,WAAW,GAAI,CAAC,EAC3B,qBAAqB,wBAAwB,EAC7C,QAAQ;IACN,OAAO,EAAE,OAAO,CAAC;IACjB,OAAO,EAAE,OAAO,CAAC;IACjB,IAAI,EAAE,SAAS,OAAO,EAAE,CAAC;IACzB,OAAO,EAAE,MAAM,CAAC;IAChB,YAAY,EAAE,CAAC,KAAK,EAAE,OAAO,KAAK,CAAC,CAAC;IACpC,YAAY,EAAE,MAAM,CAAC;CACtB,KACA,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC,GAAG,uBAAuB,GAAG,iBAAiB,CAcnE,CAAC;AAKJ,eAAO,MAAM,cAAc,GACzB,cAAc,YAAY,EAC1B,QAAQ;IAAE,OAAO,CAAC,EAAE,OAAO,CAAC;IAAC,OAAO,EAAE,MAAM,CAAA;CAAE,EAC9C,cAAc,CAAC,OAAO,EAAE,MAAM,KAAK,uBAAuB,KACzD,MAAM,CAAC,MAAM,CAAC,OAAO,EAAE,uBAAuB,CAShD,CAAC"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { Effect } from "effect";
|
|
2
|
+
import { erc721Abi } from "../abi/index.js";
|
|
3
|
+
import { viemTryPromise, withPublicClient, withWalletClient } from "../internal/index.js";
|
|
4
|
+
export const readErc721 = (publicClientService, params) => withPublicClient(publicClientService, params.chainId, (client) => viemTryPromise(() => client.readContract({
|
|
5
|
+
abi: erc721Abi,
|
|
6
|
+
address: params.address,
|
|
7
|
+
args: params.args,
|
|
8
|
+
functionName: params.functionName,
|
|
9
|
+
}), params.errorFactory));
|
|
10
|
+
export const writeErc721 = (walletClientService, params) => withWalletClient(walletClientService, params.chainId, (walletClient) => viemTryPromise(() => walletClient.writeContract({
|
|
11
|
+
abi: erc721Abi,
|
|
12
|
+
account: params.account,
|
|
13
|
+
address: params.address,
|
|
14
|
+
args: params.args,
|
|
15
|
+
chain: walletClient.chain ?? null,
|
|
16
|
+
functionName: params.functionName,
|
|
17
|
+
}), params.errorFactory));
|
|
18
|
+
export const resolveAccount = (walletClient, params, errorFactory) => {
|
|
19
|
+
if (params.account) {
|
|
20
|
+
return Effect.succeed(params.account);
|
|
21
|
+
}
|
|
22
|
+
const account = walletClient.account?.address;
|
|
23
|
+
if (account) {
|
|
24
|
+
return Effect.succeed(account);
|
|
25
|
+
}
|
|
26
|
+
return Effect.fail(errorFactory(params.chainId));
|
|
27
|
+
};
|
|
28
|
+
//# sourceMappingURL=helpers.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"helpers.js","sourceRoot":"","sources":["../../src/erc721/helpers.ts"],"names":[],"mappings":"AAQA,OAAO,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAEhC,OAAO,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAC;AAU/C,OAAO,EAAE,cAAc,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAC;AAK7F,MAAM,CAAC,MAAM,UAAU,GAAG,CACxB,mBAA6C,EAC7C,MAMC,EACgD,EAAE,CACnD,gBAAgB,CAAC,mBAAmB,EAAE,MAAM,CAAC,OAAO,EAAE,CAAC,MAAM,EAAE,EAAE,CAC/D,cAAc,CACZ,GAAG,EAAE,CACH,MAAM,CAAC,YAAY,CAAC;IAClB,GAAG,EAAE,SAAS;IACd,OAAO,EAAE,MAAM,CAAC,OAAO;IACvB,IAAI,EAAE,MAAM,CAAC,IAAa;IAC1B,YAAY,EAAE,MAAM,CAAC,YAAqB;CAC3C,CAAqB,EACxB,MAAM,CAAC,YAAY,CACpB,CACF,CAAC;AAKJ,MAAM,CAAC,MAAM,WAAW,GAAG,CACzB,mBAA6C,EAC7C,MAOC,EACqE,EAAE,CACxE,gBAAgB,CAAC,mBAAmB,EAAE,MAAM,CAAC,OAAO,EAAE,CAAC,YAAY,EAAE,EAAE,CACrE,cAAc,CACZ,GAAG,EAAE,CACH,YAAY,CAAC,aAAa,CAAC;IACzB,GAAG,EAAE,SAAS;IACd,OAAO,EAAE,MAAM,CAAC,OAAO;IACvB,OAAO,EAAE,MAAM,CAAC,OAAO;IACvB,IAAI,EAAE,MAAM,CAAC,IAAa;IAC1B,KAAK,EAAE,YAAY,CAAC,KAAK,IAAI,IAAI;IACjC,YAAY,EAAE,MAAM,CAAC,YAAqB;CAC3C,CAAC,EACJ,MAAM,CAAC,YAAY,CACpB,CACF,CAAC;AAKJ,MAAM,CAAC,MAAM,cAAc,GAAG,CAC5B,YAA0B,EAC1B,MAA8C,EAC9C,YAA0D,EACT,EAAE;IACnD,IAAI,MAAM,CAAC,OAAO,EAAE,CAAC;QACnB,OAAO,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;IACxC,CAAC;IACD,MAAM,OAAO,GAAG,YAAY,CAAC,OAAO,EAAE,OAAO,CAAC;IAC9C,IAAI,OAAO,EAAE,CAAC;QACZ,OAAO,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;IACjC,CAAC;IACD,OAAO,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC;AACnD,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/erc721/index.ts"],"names":[],"mappings":"AAAA,cAAc,aAAa,CAAC;AAC5B,cAAc,eAAe,CAAC;AAC9B,cAAc,cAAc,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/erc721/index.ts"],"names":[],"mappings":"AAAA,cAAc,aAAa,CAAC;AAC5B,cAAc,eAAe,CAAC;AAC9B,cAAc,cAAc,CAAC"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { Effect } from "effect";
|
|
2
|
+
import { Erc721MetadataFetchError } from "../erc721/errors.js";
|
|
3
|
+
export type NftMetadata = {
|
|
4
|
+
animation_url?: string;
|
|
5
|
+
attributes?: Array<{
|
|
6
|
+
display_type?: string;
|
|
7
|
+
trait_type: string;
|
|
8
|
+
value: number | string;
|
|
9
|
+
}>;
|
|
10
|
+
description?: string;
|
|
11
|
+
external_url?: string;
|
|
12
|
+
image?: string;
|
|
13
|
+
name?: string;
|
|
14
|
+
[key: string]: unknown;
|
|
15
|
+
};
|
|
16
|
+
type GatewayConfig = {
|
|
17
|
+
arweave?: string;
|
|
18
|
+
ipfs?: string;
|
|
19
|
+
};
|
|
20
|
+
export declare const resolveUri: (uri: string, gateways?: GatewayConfig) => string;
|
|
21
|
+
export declare const fetchNftMetadata: (uri: string, params: {
|
|
22
|
+
address: string;
|
|
23
|
+
chainId: number;
|
|
24
|
+
gateways?: GatewayConfig;
|
|
25
|
+
tokenId: bigint;
|
|
26
|
+
}) => Effect.Effect<NftMetadata, Erc721MetadataFetchError>;
|
|
27
|
+
export {};
|
|
28
|
+
//# sourceMappingURL=metadata.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"metadata.d.ts","sourceRoot":"","sources":["../../src/erc721/metadata.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAChC,OAAO,EAAE,wBAAwB,EAAE,MAAM,wBAAwB,CAAC;AAElE,MAAM,MAAM,WAAW,GAAG;IACxB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,UAAU,CAAC,EAAE,KAAK,CAAC;QACjB,YAAY,CAAC,EAAE,MAAM,CAAC;QACtB,UAAU,EAAE,MAAM,CAAC;QACnB,KAAK,EAAE,MAAM,GAAG,MAAM,CAAC;KACxB,CAAC,CAAC;IACH,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;CACxB,CAAC;AAEF,KAAK,aAAa,GAAG;IACnB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,IAAI,CAAC,EAAE,MAAM,CAAC;CACf,CAAC;AAaF,eAAO,MAAM,UAAU,GAAI,KAAK,MAAM,EAAE,WAAW,aAAa,KAAG,MAiBlE,CAAC;AAKF,eAAO,MAAM,gBAAgB,GAC3B,KAAK,MAAM,EACX,QAAQ;IACN,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;IAChB,QAAQ,CAAC,EAAE,aAAa,CAAC;IACzB,OAAO,EAAE,MAAM,CAAC;CACjB,KACA,MAAM,CAAC,MAAM,CAAC,WAAW,EAAE,wBAAwB,CA0DlD,CAAC"}
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
import { Effect } from "effect";
|
|
2
|
+
import { Erc721MetadataFetchError } from "../erc721/errors.js";
|
|
3
|
+
const DATA_URI_BASE64_JSON_RE = /^data:application\/json;base64,(.+)$/;
|
|
4
|
+
const DATA_URI_PLAIN_JSON_RE = /^data:application\/json,(.+)$/;
|
|
5
|
+
const DEFAULT_GATEWAYS = {
|
|
6
|
+
arweave: "https://arweave.net/",
|
|
7
|
+
ipfs: "https://ipfs.io/ipfs/",
|
|
8
|
+
};
|
|
9
|
+
export const resolveUri = (uri, gateways) => {
|
|
10
|
+
const config = { ...DEFAULT_GATEWAYS, ...gateways };
|
|
11
|
+
if (uri.startsWith("ipfs://")) {
|
|
12
|
+
const hash = uri.replace("ipfs://", "");
|
|
13
|
+
return `${config.ipfs}${hash}`;
|
|
14
|
+
}
|
|
15
|
+
if (uri.startsWith("ar://")) {
|
|
16
|
+
const hash = uri.replace("ar://", "");
|
|
17
|
+
return `${config.arweave}${hash}`;
|
|
18
|
+
}
|
|
19
|
+
return uri;
|
|
20
|
+
};
|
|
21
|
+
export const fetchNftMetadata = (uri, params) => Effect.gen(function* () {
|
|
22
|
+
if (uri.startsWith("data:")) {
|
|
23
|
+
const match = uri.match(DATA_URI_BASE64_JSON_RE);
|
|
24
|
+
if (match) {
|
|
25
|
+
const decoded = Buffer.from(match[1], "base64").toString("utf-8");
|
|
26
|
+
return JSON.parse(decoded);
|
|
27
|
+
}
|
|
28
|
+
const jsonMatch = uri.match(DATA_URI_PLAIN_JSON_RE);
|
|
29
|
+
if (jsonMatch) {
|
|
30
|
+
return JSON.parse(decodeURIComponent(jsonMatch[1]));
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
const resolvedUri = resolveUri(uri, params.gateways);
|
|
34
|
+
const response = yield* Effect.tryPromise({
|
|
35
|
+
catch: (cause) => new Erc721MetadataFetchError({
|
|
36
|
+
address: params.address,
|
|
37
|
+
cause,
|
|
38
|
+
chainId: params.chainId,
|
|
39
|
+
message: `Failed to fetch metadata: ${String(cause)}`,
|
|
40
|
+
tokenId: params.tokenId,
|
|
41
|
+
uri: resolvedUri,
|
|
42
|
+
}),
|
|
43
|
+
try: () => fetch(resolvedUri),
|
|
44
|
+
});
|
|
45
|
+
if (!response.ok) {
|
|
46
|
+
return yield* Effect.fail(new Erc721MetadataFetchError({
|
|
47
|
+
address: params.address,
|
|
48
|
+
chainId: params.chainId,
|
|
49
|
+
message: `HTTP ${response.status}: ${response.statusText}`,
|
|
50
|
+
tokenId: params.tokenId,
|
|
51
|
+
uri: resolvedUri,
|
|
52
|
+
}));
|
|
53
|
+
}
|
|
54
|
+
const metadata = yield* Effect.tryPromise({
|
|
55
|
+
catch: (cause) => new Erc721MetadataFetchError({
|
|
56
|
+
address: params.address,
|
|
57
|
+
cause,
|
|
58
|
+
chainId: params.chainId,
|
|
59
|
+
message: `Failed to parse JSON metadata: ${String(cause)}`,
|
|
60
|
+
tokenId: params.tokenId,
|
|
61
|
+
uri: resolvedUri,
|
|
62
|
+
}),
|
|
63
|
+
try: () => response.json(),
|
|
64
|
+
});
|
|
65
|
+
return metadata;
|
|
66
|
+
});
|
|
67
|
+
//# sourceMappingURL=metadata.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"metadata.js","sourceRoot":"","sources":["../../src/erc721/metadata.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAChC,OAAO,EAAE,wBAAwB,EAAE,MAAM,wBAAwB,CAAC;AAqBlE,MAAM,uBAAuB,GAAG,sCAAsC,CAAC;AACvE,MAAM,sBAAsB,GAAG,+BAA+B,CAAC;AAE/D,MAAM,gBAAgB,GAAkB;IACtC,OAAO,EAAE,sBAAsB;IAC/B,IAAI,EAAE,uBAAuB;CAC9B,CAAC;AAKF,MAAM,CAAC,MAAM,UAAU,GAAG,CAAC,GAAW,EAAE,QAAwB,EAAU,EAAE;IAC1E,MAAM,MAAM,GAAG,EAAE,GAAG,gBAAgB,EAAE,GAAG,QAAQ,EAAE,CAAC;IAGpD,IAAI,GAAG,CAAC,UAAU,CAAC,SAAS,CAAC,EAAE,CAAC;QAC9B,MAAM,IAAI,GAAG,GAAG,CAAC,OAAO,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC;QACxC,OAAO,GAAG,MAAM,CAAC,IAAI,GAAG,IAAI,EAAE,CAAC;IACjC,CAAC;IAGD,IAAI,GAAG,CAAC,UAAU,CAAC,OAAO,CAAC,EAAE,CAAC;QAC5B,MAAM,IAAI,GAAG,GAAG,CAAC,OAAO,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;QACtC,OAAO,GAAG,MAAM,CAAC,OAAO,GAAG,IAAI,EAAE,CAAC;IACpC,CAAC;IAGD,OAAO,GAAG,CAAC;AACb,CAAC,CAAC;AAKF,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAC9B,GAAW,EACX,MAKC,EACqD,EAAE,CACxD,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC;IAElB,IAAI,GAAG,CAAC,UAAU,CAAC,OAAO,CAAC,EAAE,CAAC;QAC5B,MAAM,KAAK,GAAG,GAAG,CAAC,KAAK,CAAC,uBAAuB,CAAC,CAAC;QACjD,IAAI,KAAK,EAAE,CAAC;YACV,MAAM,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;YAClE,OAAO,IAAI,CAAC,KAAK,CAAC,OAAO,CAAgB,CAAC;QAC5C,CAAC;QACD,MAAM,SAAS,GAAG,GAAG,CAAC,KAAK,CAAC,sBAAsB,CAAC,CAAC;QACpD,IAAI,SAAS,EAAE,CAAC;YACd,OAAO,IAAI,CAAC,KAAK,CAAC,kBAAkB,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAgB,CAAC;QACrE,CAAC;IACH,CAAC;IAGD,MAAM,WAAW,GAAG,UAAU,CAAC,GAAG,EAAE,MAAM,CAAC,QAAQ,CAAC,CAAC;IAGrD,MAAM,QAAQ,GAAG,KAAK,CAAC,CAAC,MAAM,CAAC,UAAU,CAAC;QACxC,KAAK,EAAE,CAAC,KAAK,EAAE,EAAE,CACf,IAAI,wBAAwB,CAAC;YAC3B,OAAO,EAAE,MAAM,CAAC,OAAO;YACvB,KAAK;YACL,OAAO,EAAE,MAAM,CAAC,OAAO;YACvB,OAAO,EAAE,6BAA6B,MAAM,CAAC,KAAK,CAAC,EAAE;YACrD,OAAO,EAAE,MAAM,CAAC,OAAO;YACvB,GAAG,EAAE,WAAW;SACjB,CAAC;QACJ,GAAG,EAAE,GAAG,EAAE,CAAC,KAAK,CAAC,WAAW,CAAC;KAC9B,CAAC,CAAC;IAEH,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE,CAAC;QACjB,OAAO,KAAK,CAAC,CAAC,MAAM,CAAC,IAAI,CACvB,IAAI,wBAAwB,CAAC;YAC3B,OAAO,EAAE,MAAM,CAAC,OAAO;YACvB,OAAO,EAAE,MAAM,CAAC,OAAO;YACvB,OAAO,EAAE,QAAQ,QAAQ,CAAC,MAAM,KAAK,QAAQ,CAAC,UAAU,EAAE;YAC1D,OAAO,EAAE,MAAM,CAAC,OAAO;YACvB,GAAG,EAAE,WAAW;SACjB,CAAC,CACH,CAAC;IACJ,CAAC;IAED,MAAM,QAAQ,GAAG,KAAK,CAAC,CAAC,MAAM,CAAC,UAAU,CAAC;QACxC,KAAK,EAAE,CAAC,KAAK,EAAE,EAAE,CACf,IAAI,wBAAwB,CAAC;YAC3B,OAAO,EAAE,MAAM,CAAC,OAAO;YACvB,KAAK;YACL,OAAO,EAAE,MAAM,CAAC,OAAO;YACvB,OAAO,EAAE,kCAAkC,MAAM,CAAC,KAAK,CAAC,EAAE;YAC1D,OAAO,EAAE,MAAM,CAAC,OAAO;YACvB,GAAG,EAAE,WAAW;SACjB,CAAC;QACJ,GAAG,EAAE,GAAG,EAAE,CAAC,QAAQ,CAAC,IAAI,EAA0B;KACnD,CAAC,CAAC;IAEH,OAAO,QAAQ,CAAC;AAClB,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
import { Context, Effect, Layer } from "effect";
|
|
2
|
+
import type { Address, Hash, Hex } from "viem";
|
|
3
|
+
import type { ClientNotFoundError, WrongNetworkError } from "../core/errors/index.js";
|
|
4
|
+
import { ContractReadError, ContractWriteError, WalletNotConnectedError } from "../core/errors/index.js";
|
|
5
|
+
import { PublicClientService, WalletClientService } from "../core/index.js";
|
|
6
|
+
import { Erc721MetadataFetchError, Erc721NoTokenURIError, Erc721OwnerNotFoundError, Erc721TransferError } from "../erc721/errors.js";
|
|
7
|
+
import type { NftMetadata } from "../erc721/metadata.js";
|
|
8
|
+
export type Erc721ServiceShape = {
|
|
9
|
+
readonly ownerOf: (params: {
|
|
10
|
+
address: Address;
|
|
11
|
+
chainId: number;
|
|
12
|
+
tokenId: bigint;
|
|
13
|
+
}) => Effect.Effect<Address, Erc721OwnerNotFoundError | ClientNotFoundError>;
|
|
14
|
+
readonly balanceOf: (params: {
|
|
15
|
+
address: Address;
|
|
16
|
+
chainId: number;
|
|
17
|
+
owner: Address;
|
|
18
|
+
}) => Effect.Effect<bigint, ContractReadError | ClientNotFoundError>;
|
|
19
|
+
readonly getApproved: (params: {
|
|
20
|
+
address: Address;
|
|
21
|
+
chainId: number;
|
|
22
|
+
tokenId: bigint;
|
|
23
|
+
}) => Effect.Effect<Address, ContractReadError | ClientNotFoundError>;
|
|
24
|
+
readonly isApprovedForAll: (params: {
|
|
25
|
+
address: Address;
|
|
26
|
+
chainId: number;
|
|
27
|
+
operator: Address;
|
|
28
|
+
owner: Address;
|
|
29
|
+
}) => Effect.Effect<boolean, ContractReadError | ClientNotFoundError>;
|
|
30
|
+
readonly approve: (params: {
|
|
31
|
+
account?: Address;
|
|
32
|
+
address: Address;
|
|
33
|
+
chainId: number;
|
|
34
|
+
to: Address;
|
|
35
|
+
tokenId: bigint;
|
|
36
|
+
}) => Effect.Effect<Hash, ContractWriteError | WalletNotConnectedError | WrongNetworkError>;
|
|
37
|
+
readonly setApprovalForAll: (params: {
|
|
38
|
+
account?: Address;
|
|
39
|
+
address: Address;
|
|
40
|
+
approved: boolean;
|
|
41
|
+
chainId: number;
|
|
42
|
+
operator: Address;
|
|
43
|
+
}) => Effect.Effect<Hash, ContractWriteError | WalletNotConnectedError | WrongNetworkError>;
|
|
44
|
+
readonly transferFrom: (params: {
|
|
45
|
+
account?: Address;
|
|
46
|
+
address: Address;
|
|
47
|
+
chainId: number;
|
|
48
|
+
from: Address;
|
|
49
|
+
to: Address;
|
|
50
|
+
tokenId: bigint;
|
|
51
|
+
}) => Effect.Effect<Hash, Erc721TransferError | WalletNotConnectedError | WrongNetworkError>;
|
|
52
|
+
readonly safeTransferFrom: (params: {
|
|
53
|
+
account?: Address;
|
|
54
|
+
address: Address;
|
|
55
|
+
chainId: number;
|
|
56
|
+
data?: Hex;
|
|
57
|
+
from: Address;
|
|
58
|
+
to: Address;
|
|
59
|
+
tokenId: bigint;
|
|
60
|
+
}) => Effect.Effect<Hash, Erc721TransferError | WalletNotConnectedError | WrongNetworkError>;
|
|
61
|
+
readonly tokenURI: (params: {
|
|
62
|
+
address: Address;
|
|
63
|
+
chainId: number;
|
|
64
|
+
tokenId: bigint;
|
|
65
|
+
}) => Effect.Effect<string, Erc721NoTokenURIError | ContractReadError | ClientNotFoundError>;
|
|
66
|
+
readonly fetchMetadata: (params: {
|
|
67
|
+
address: Address;
|
|
68
|
+
chainId: number;
|
|
69
|
+
gateways?: {
|
|
70
|
+
arweave?: string;
|
|
71
|
+
ipfs?: string;
|
|
72
|
+
};
|
|
73
|
+
tokenId: bigint;
|
|
74
|
+
}) => Effect.Effect<NftMetadata, Erc721MetadataFetchError | ClientNotFoundError>;
|
|
75
|
+
readonly name: (params: {
|
|
76
|
+
address: Address;
|
|
77
|
+
chainId: number;
|
|
78
|
+
}) => Effect.Effect<string, ContractReadError | ClientNotFoundError>;
|
|
79
|
+
readonly symbol: (params: {
|
|
80
|
+
address: Address;
|
|
81
|
+
chainId: number;
|
|
82
|
+
}) => Effect.Effect<string, ContractReadError | ClientNotFoundError>;
|
|
83
|
+
readonly totalSupply: (params: {
|
|
84
|
+
address: Address;
|
|
85
|
+
chainId: number;
|
|
86
|
+
}) => Effect.Effect<bigint, ContractReadError | ClientNotFoundError>;
|
|
87
|
+
};
|
|
88
|
+
declare const Erc721Service_base: Context.TagClass<Erc721Service, "ew3/Erc721Service", Erc721ServiceShape>;
|
|
89
|
+
export declare class Erc721Service extends Erc721Service_base {
|
|
90
|
+
}
|
|
91
|
+
export declare const Erc721ServiceLive: Layer.Layer<Erc721Service, never, PublicClientService | WalletClientService>;
|
|
92
|
+
export {};
|
|
93
|
+
//# sourceMappingURL=service.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"service.d.ts","sourceRoot":"","sources":["../../src/erc721/service.ts"],"names":[],"mappings":"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"}
|