@geoprotocol/geo-sdk 0.1.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +528 -0
- package/dist/abis.d.ts +7 -0
- package/dist/abis.d.ts.map +1 -0
- package/dist/abis.js +7 -0
- package/dist/abis.js.map +1 -0
- package/dist/constants.d.ts +7 -0
- package/dist/constants.d.ts.map +1 -0
- package/dist/constants.js +8 -0
- package/dist/constants.js.map +1 -0
- package/dist/contracts.d.ts +31 -0
- package/dist/contracts.d.ts.map +1 -0
- package/dist/contracts.js +31 -0
- package/dist/contracts.js.map +1 -0
- package/dist/convert-ids.d.ts +2 -0
- package/dist/convert-ids.d.ts.map +1 -0
- package/dist/convert-ids.js +42 -0
- package/dist/convert-ids.js.map +1 -0
- package/dist/examples/ranks/create-ordinal-rank.d.ts +8 -0
- package/dist/examples/ranks/create-ordinal-rank.d.ts.map +1 -0
- package/dist/examples/ranks/create-ordinal-rank.js +42 -0
- package/dist/examples/ranks/create-ordinal-rank.js.map +1 -0
- package/dist/examples/ranks/create-weighted-rank.d.ts +8 -0
- package/dist/examples/ranks/create-weighted-rank.d.ts.map +1 -0
- package/dist/examples/ranks/create-weighted-rank.js +42 -0
- package/dist/examples/ranks/create-weighted-rank.js.map +1 -0
- package/dist/index.d.ts +49 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +49 -0
- package/dist/index.js.map +1 -0
- package/dist/proto.d.ts +5 -0
- package/dist/proto.d.ts.map +1 -0
- package/dist/proto.js +5 -0
- package/dist/proto.js.map +1 -0
- package/dist/protov2.d.ts +11 -0
- package/dist/protov2.d.ts.map +1 -0
- package/dist/protov2.js +11 -0
- package/dist/protov2.js.map +1 -0
- package/dist/scripts/setup-rank-types.d.ts +15 -0
- package/dist/scripts/setup-rank-types.d.ts.map +1 -0
- package/dist/scripts/setup-rank-types.js +62 -0
- package/dist/scripts/setup-rank-types.js.map +1 -0
- package/dist/src/abis/dao-space-factory.d.ts +276 -0
- package/dist/src/abis/dao-space-factory.d.ts.map +1 -0
- package/dist/src/abis/dao-space-factory.js +359 -0
- package/dist/src/abis/dao-space-factory.js.map +1 -0
- package/dist/src/abis/dao-space.d.ts +698 -0
- package/dist/src/abis/dao-space.d.ts.map +1 -0
- package/dist/src/abis/dao-space.js +906 -0
- package/dist/src/abis/dao-space.js.map +1 -0
- package/dist/src/abis/dao.d.ts +899 -0
- package/dist/src/abis/dao.d.ts.map +1 -0
- package/dist/src/abis/dao.js +1159 -0
- package/dist/src/abis/dao.js.map +1 -0
- package/dist/src/abis/governance-setup.d.ts +351 -0
- package/dist/src/abis/governance-setup.d.ts.map +1 -0
- package/dist/src/abis/governance-setup.js +461 -0
- package/dist/src/abis/governance-setup.js.map +1 -0
- package/dist/src/abis/index.d.ts +13 -0
- package/dist/src/abis/index.d.ts.map +1 -0
- package/dist/src/abis/index.js +13 -0
- package/dist/src/abis/index.js.map +1 -0
- package/dist/src/abis/main-voting.d.ts +1504 -0
- package/dist/src/abis/main-voting.d.ts.map +1 -0
- package/dist/src/abis/main-voting.js +1943 -0
- package/dist/src/abis/main-voting.js.map +1 -0
- package/dist/src/abis/member-access.d.ts +567 -0
- package/dist/src/abis/member-access.d.ts.map +1 -0
- package/dist/src/abis/member-access.js +735 -0
- package/dist/src/abis/member-access.js.map +1 -0
- package/dist/src/abis/personal-space-admin-setup.d.ts +259 -0
- package/dist/src/abis/personal-space-admin-setup.d.ts.map +1 -0
- package/dist/src/abis/personal-space-admin-setup.js +340 -0
- package/dist/src/abis/personal-space-admin-setup.js.map +1 -0
- package/dist/src/abis/personal-space-admin.d.ts +431 -0
- package/dist/src/abis/personal-space-admin.d.ts.map +1 -0
- package/dist/src/abis/personal-space-admin.js +555 -0
- package/dist/src/abis/personal-space-admin.js.map +1 -0
- package/dist/src/abis/plugin-setup-processor.d.ts +998 -0
- package/dist/src/abis/plugin-setup-processor.d.ts.map +1 -0
- package/dist/src/abis/plugin-setup-processor.js +1293 -0
- package/dist/src/abis/plugin-setup-processor.js.map +1 -0
- package/dist/src/abis/space-registry.d.ts +413 -0
- package/dist/src/abis/space-registry.d.ts.map +1 -0
- package/dist/src/abis/space-registry.js +537 -0
- package/dist/src/abis/space-registry.js.map +1 -0
- package/dist/src/abis/space-setup.d.ts +310 -0
- package/dist/src/abis/space-setup.d.ts.map +1 -0
- package/dist/src/abis/space-setup.js +407 -0
- package/dist/src/abis/space-setup.js.map +1 -0
- package/dist/src/abis/space.d.ts +359 -0
- package/dist/src/abis/space.d.ts.map +1 -0
- package/dist/src/abis/space.js +462 -0
- package/dist/src/abis/space.js.map +1 -0
- package/dist/src/account.d.ts +8 -0
- package/dist/src/account.d.ts.map +1 -0
- package/dist/src/account.js +8 -0
- package/dist/src/account.js.map +1 -0
- package/dist/src/blocks.d.ts +15 -0
- package/dist/src/blocks.d.ts.map +1 -0
- package/dist/src/blocks.js +15 -0
- package/dist/src/blocks.js.map +1 -0
- package/dist/src/codec/convert.d.ts +18 -0
- package/dist/src/codec/convert.d.ts.map +1 -0
- package/dist/src/codec/convert.js +188 -0
- package/dist/src/codec/convert.js.map +1 -0
- package/dist/src/core/account.d.ts +28 -0
- package/dist/src/core/account.d.ts.map +1 -0
- package/dist/src/core/account.js +67 -0
- package/dist/src/core/account.js.map +1 -0
- package/dist/src/core/account.test.d.ts +2 -0
- package/dist/src/core/account.test.d.ts.map +1 -0
- package/dist/src/core/account.test.js +80 -0
- package/dist/src/core/account.test.js.map +1 -0
- package/dist/src/core/base58.d.ts +43 -0
- package/dist/src/core/base58.d.ts.map +1 -0
- package/dist/src/core/base58.js +68 -0
- package/dist/src/core/base58.js.map +1 -0
- package/dist/src/core/base58.test.d.ts +2 -0
- package/dist/src/core/base58.test.d.ts.map +1 -0
- package/dist/src/core/base58.test.js +17 -0
- package/dist/src/core/base58.test.js.map +1 -0
- package/dist/src/core/blocks/data.d.ts +34 -0
- package/dist/src/core/blocks/data.d.ts.map +1 -0
- package/dist/src/core/blocks/data.js +77 -0
- package/dist/src/core/blocks/data.js.map +1 -0
- package/dist/src/core/blocks/data.test.d.ts +2 -0
- package/dist/src/core/blocks/data.test.d.ts.map +1 -0
- package/dist/src/core/blocks/data.test.js +96 -0
- package/dist/src/core/blocks/data.test.js.map +1 -0
- package/dist/src/core/blocks/image.d.ts +15 -0
- package/dist/src/core/blocks/image.d.ts.map +1 -0
- package/dist/src/core/blocks/image.js +15 -0
- package/dist/src/core/blocks/image.js.map +1 -0
- package/dist/src/core/blocks/text.d.ts +31 -0
- package/dist/src/core/blocks/text.d.ts.map +1 -0
- package/dist/src/core/blocks/text.js +57 -0
- package/dist/src/core/blocks/text.js.map +1 -0
- package/dist/src/core/blocks/text.test.d.ts +2 -0
- package/dist/src/core/blocks/text.test.d.ts.map +1 -0
- package/dist/src/core/blocks/text.test.js +93 -0
- package/dist/src/core/blocks/text.test.js.map +1 -0
- package/dist/src/core/get-checksum-address.d.ts +10 -0
- package/dist/src/core/get-checksum-address.d.ts.map +1 -0
- package/dist/src/core/get-checksum-address.js +20 -0
- package/dist/src/core/get-checksum-address.js.map +1 -0
- package/dist/src/core/ids/content.d.ts +60 -0
- package/dist/src/core/ids/content.d.ts.map +1 -0
- package/dist/src/core/ids/content.js +60 -0
- package/dist/src/core/ids/content.js.map +1 -0
- package/dist/src/core/ids/network.d.ts +5 -0
- package/dist/src/core/ids/network.d.ts.map +1 -0
- package/dist/src/core/ids/network.js +5 -0
- package/dist/src/core/ids/network.js.map +1 -0
- package/dist/src/core/ids/system.d.ts +239 -0
- package/dist/src/core/ids/system.d.ts.map +1 -0
- package/dist/src/core/ids/system.js +247 -0
- package/dist/src/core/ids/system.js.map +1 -0
- package/dist/src/core/idsv2/content.d.ts +59 -0
- package/dist/src/core/idsv2/content.d.ts.map +1 -0
- package/dist/src/core/idsv2/content.js +59 -0
- package/dist/src/core/idsv2/content.js.map +1 -0
- package/dist/src/core/idsv2/network.d.ts +5 -0
- package/dist/src/core/idsv2/network.d.ts.map +1 -0
- package/dist/src/core/idsv2/network.js +5 -0
- package/dist/src/core/idsv2/network.js.map +1 -0
- package/dist/src/core/idsv2/system.d.ts +222 -0
- package/dist/src/core/idsv2/system.d.ts.map +1 -0
- package/dist/src/core/idsv2/system.js +230 -0
- package/dist/src/core/idsv2/system.js.map +1 -0
- package/dist/src/core/image.d.ts +40 -0
- package/dist/src/core/image.d.ts.map +1 -0
- package/dist/src/core/image.js +76 -0
- package/dist/src/core/image.js.map +1 -0
- package/dist/src/core/image.test.d.ts +2 -0
- package/dist/src/core/image.test.d.ts.map +1 -0
- package/dist/src/core/image.test.js +52 -0
- package/dist/src/core/image.test.js.map +1 -0
- package/dist/src/core/position.d.ts +26 -0
- package/dist/src/core/position.d.ts.map +1 -0
- package/dist/src/core/position.js +41 -0
- package/dist/src/core/position.js.map +1 -0
- package/dist/src/core/position.test.d.ts +2 -0
- package/dist/src/core/position.test.d.ts.map +1 -0
- package/dist/src/core/position.test.js +126 -0
- package/dist/src/core/position.test.js.map +1 -0
- package/dist/src/core/relation.d.ts +88 -0
- package/dist/src/core/relation.d.ts.map +1 -0
- package/dist/src/core/relation.js +89 -0
- package/dist/src/core/relation.js.map +1 -0
- package/dist/src/core/relation.test.d.ts +2 -0
- package/dist/src/core/relation.test.d.ts.map +1 -0
- package/dist/src/core/relation.test.js +45 -0
- package/dist/src/core/relation.test.js.map +1 -0
- package/dist/src/core/scheme.d.ts +78 -0
- package/dist/src/core/scheme.d.ts.map +1 -0
- package/dist/src/core/scheme.js +99 -0
- package/dist/src/core/scheme.js.map +1 -0
- package/dist/src/core/scheme.test.d.ts +2 -0
- package/dist/src/core/scheme.test.d.ts.map +1 -0
- package/dist/src/core/scheme.test.js +34 -0
- package/dist/src/core/scheme.test.js.map +1 -0
- package/dist/src/core/triple.d.ts +50 -0
- package/dist/src/core/triple.d.ts.map +1 -0
- package/dist/src/core/triple.js +56 -0
- package/dist/src/core/triple.js.map +1 -0
- package/dist/src/core/triple.test.d.ts +2 -0
- package/dist/src/core/triple.test.d.ts.map +1 -0
- package/dist/src/core/triple.test.js +37 -0
- package/dist/src/core/triple.test.js.map +1 -0
- package/dist/src/encoding.d.ts +12 -0
- package/dist/src/encoding.d.ts.map +1 -0
- package/dist/src/encoding.js +30 -0
- package/dist/src/encoding.js.map +1 -0
- package/dist/src/encoding.test.d.ts +2 -0
- package/dist/src/encoding.test.d.ts.map +1 -0
- package/dist/src/encoding.test.js +644 -0
- package/dist/src/encoding.test.js.map +1 -0
- package/dist/src/encodings/get-accept-editor-arguments.d.ts +11 -0
- package/dist/src/encodings/get-accept-editor-arguments.d.ts.map +1 -0
- package/dist/src/encodings/get-accept-editor-arguments.js +23 -0
- package/dist/src/encodings/get-accept-editor-arguments.js.map +1 -0
- package/dist/src/encodings/get-accept-subspace-arguments.d.ts +11 -0
- package/dist/src/encodings/get-accept-subspace-arguments.d.ts.map +1 -0
- package/dist/src/encodings/get-accept-subspace-arguments.js +23 -0
- package/dist/src/encodings/get-accept-subspace-arguments.js.map +1 -0
- package/dist/src/encodings/get-calldata-for-space-governance-type.d.ts +8 -0
- package/dist/src/encodings/get-calldata-for-space-governance-type.d.ts.map +1 -0
- package/dist/src/encodings/get-calldata-for-space-governance-type.js +19 -0
- package/dist/src/encodings/get-calldata-for-space-governance-type.js.map +1 -0
- package/dist/src/encodings/get-create-dao-space-calldata.d.ts +157 -0
- package/dist/src/encodings/get-create-dao-space-calldata.d.ts.map +1 -0
- package/dist/src/encodings/get-create-dao-space-calldata.js +208 -0
- package/dist/src/encodings/get-create-dao-space-calldata.js.map +1 -0
- package/dist/src/encodings/get-create-dao-space-calldata.test.d.ts +2 -0
- package/dist/src/encodings/get-create-dao-space-calldata.test.d.ts.map +1 -0
- package/dist/src/encodings/get-create-dao-space-calldata.test.js +185 -0
- package/dist/src/encodings/get-create-dao-space-calldata.test.js.map +1 -0
- package/dist/src/encodings/get-create-personal-space-calldata.d.ts +33 -0
- package/dist/src/encodings/get-create-personal-space-calldata.d.ts.map +1 -0
- package/dist/src/encodings/get-create-personal-space-calldata.js +43 -0
- package/dist/src/encodings/get-create-personal-space-calldata.js.map +1 -0
- package/dist/src/encodings/get-create-personal-space-calldata.test.d.ts +2 -0
- package/dist/src/encodings/get-create-personal-space-calldata.test.d.ts.map +1 -0
- package/dist/src/encodings/get-create-personal-space-calldata.test.js +15 -0
- package/dist/src/encodings/get-create-personal-space-calldata.test.js.map +1 -0
- package/dist/src/encodings/get-process-geo-proposal-arguments.d.ts +7 -0
- package/dist/src/encodings/get-process-geo-proposal-arguments.d.ts.map +1 -0
- package/dist/src/encodings/get-process-geo-proposal-arguments.js +23 -0
- package/dist/src/encodings/get-process-geo-proposal-arguments.js.map +1 -0
- package/dist/src/encodings/get-register-space-calldata.d.ts +32 -0
- package/dist/src/encodings/get-register-space-calldata.d.ts.map +1 -0
- package/dist/src/encodings/get-register-space-calldata.js +39 -0
- package/dist/src/encodings/get-register-space-calldata.js.map +1 -0
- package/dist/src/encodings/get-register-space-calldata.test.d.ts +2 -0
- package/dist/src/encodings/get-register-space-calldata.test.d.ts.map +1 -0
- package/dist/src/encodings/get-register-space-calldata.test.js +15 -0
- package/dist/src/encodings/get-register-space-calldata.test.js.map +1 -0
- package/dist/src/encodings/get-remove-editor-arguments.d.ts +11 -0
- package/dist/src/encodings/get-remove-editor-arguments.d.ts.map +1 -0
- package/dist/src/encodings/get-remove-editor-arguments.js +23 -0
- package/dist/src/encodings/get-remove-editor-arguments.js.map +1 -0
- package/dist/src/encodings/get-remove-subspace-arguments.d.ts +11 -0
- package/dist/src/encodings/get-remove-subspace-arguments.d.ts.map +1 -0
- package/dist/src/encodings/get-remove-subspace-arguments.js +23 -0
- package/dist/src/encodings/get-remove-subspace-arguments.js.map +1 -0
- package/dist/src/encodings/index.d.ts +9 -0
- package/dist/src/encodings/index.d.ts.map +1 -0
- package/dist/src/encodings/index.js +9 -0
- package/dist/src/encodings/index.js.map +1 -0
- package/dist/src/full-flow-test.test.d.ts +2 -0
- package/dist/src/full-flow-test.test.d.ts.map +1 -0
- package/dist/src/full-flow-test.test.js +142 -0
- package/dist/src/full-flow-test.test.js.map +1 -0
- package/dist/src/graph/constants.d.ts +4 -0
- package/dist/src/graph/constants.d.ts.map +1 -0
- package/dist/src/graph/constants.js +8 -0
- package/dist/src/graph/constants.js.map +1 -0
- package/dist/src/graph/create-entity.d.ts +54 -0
- package/dist/src/graph/create-entity.d.ts.map +1 -0
- package/dist/src/graph/create-entity.js +272 -0
- package/dist/src/graph/create-entity.js.map +1 -0
- package/dist/src/graph/create-entity.test.d.ts +2 -0
- package/dist/src/graph/create-entity.test.d.ts.map +1 -0
- package/dist/src/graph/create-entity.test.js +459 -0
- package/dist/src/graph/create-entity.test.js.map +1 -0
- package/dist/src/graph/create-image.d.ts +28 -0
- package/dist/src/graph/create-image.d.ts.map +1 -0
- package/dist/src/graph/create-image.js +77 -0
- package/dist/src/graph/create-image.js.map +1 -0
- package/dist/src/graph/create-image.test.d.ts +2 -0
- package/dist/src/graph/create-image.test.d.ts.map +1 -0
- package/dist/src/graph/create-image.test.js +233 -0
- package/dist/src/graph/create-image.test.js.map +1 -0
- package/dist/src/graph/create-property.d.ts +24 -0
- package/dist/src/graph/create-property.d.ts.map +1 -0
- package/dist/src/graph/create-property.js +113 -0
- package/dist/src/graph/create-property.js.map +1 -0
- package/dist/src/graph/create-property.test.d.ts +2 -0
- package/dist/src/graph/create-property.test.d.ts.map +1 -0
- package/dist/src/graph/create-property.test.js +203 -0
- package/dist/src/graph/create-property.test.js.map +1 -0
- package/dist/src/graph/create-relation.d.ts +42 -0
- package/dist/src/graph/create-relation.d.ts.map +1 -0
- package/dist/src/graph/create-relation.js +110 -0
- package/dist/src/graph/create-relation.js.map +1 -0
- package/dist/src/graph/create-relation.test.d.ts +2 -0
- package/dist/src/graph/create-relation.test.d.ts.map +1 -0
- package/dist/src/graph/create-relation.test.js +358 -0
- package/dist/src/graph/create-relation.test.js.map +1 -0
- package/dist/src/graph/create-space.d.ts +37 -0
- package/dist/src/graph/create-space.d.ts.map +1 -0
- package/dist/src/graph/create-space.js +67 -0
- package/dist/src/graph/create-space.js.map +1 -0
- package/dist/src/graph/create-type.d.ts +22 -0
- package/dist/src/graph/create-type.d.ts.map +1 -0
- package/dist/src/graph/create-type.js +63 -0
- package/dist/src/graph/create-type.js.map +1 -0
- package/dist/src/graph/create-type.test.d.ts +2 -0
- package/dist/src/graph/create-type.test.d.ts.map +1 -0
- package/dist/src/graph/create-type.test.js +117 -0
- package/dist/src/graph/create-type.test.js.map +1 -0
- package/dist/src/graph/delete-entity.d.ts +14 -0
- package/dist/src/graph/delete-entity.d.ts.map +1 -0
- package/dist/src/graph/delete-entity.js +19 -0
- package/dist/src/graph/delete-entity.js.map +1 -0
- package/dist/src/graph/delete-entity.test.d.ts +2 -0
- package/dist/src/graph/delete-entity.test.d.ts.map +1 -0
- package/dist/src/graph/delete-entity.test.js +21 -0
- package/dist/src/graph/delete-entity.test.js.map +1 -0
- package/dist/src/graph/delete-relation.d.ts +14 -0
- package/dist/src/graph/delete-relation.d.ts.map +1 -0
- package/dist/src/graph/delete-relation.js +19 -0
- package/dist/src/graph/delete-relation.js.map +1 -0
- package/dist/src/graph/delete-relation.test.d.ts +2 -0
- package/dist/src/graph/delete-relation.test.d.ts.map +1 -0
- package/dist/src/graph/delete-relation.test.js +21 -0
- package/dist/src/graph/delete-relation.test.js.map +1 -0
- package/dist/src/graph/graph.test.d.ts +2 -0
- package/dist/src/graph/graph.test.d.ts.map +1 -0
- package/dist/src/graph/graph.test.js +46 -0
- package/dist/src/graph/graph.test.js.map +1 -0
- package/dist/src/graph/helpers/create-default-properties.d.ts +5 -0
- package/dist/src/graph/helpers/create-default-properties.d.ts.map +1 -0
- package/dist/src/graph/helpers/create-default-properties.js +44 -0
- package/dist/src/graph/helpers/create-default-properties.js.map +1 -0
- package/dist/src/graph/helpers/create-properties.d.ts +8 -0
- package/dist/src/graph/helpers/create-properties.d.ts.map +1 -0
- package/dist/src/graph/helpers/create-properties.js +53 -0
- package/dist/src/graph/helpers/create-properties.js.map +1 -0
- package/dist/src/graph/index.d.ts +13 -0
- package/dist/src/graph/index.d.ts.map +1 -0
- package/dist/src/graph/index.js +12 -0
- package/dist/src/graph/index.js.map +1 -0
- package/dist/src/graph/serialize.d.ts +5 -0
- package/dist/src/graph/serialize.d.ts.map +1 -0
- package/dist/src/graph/serialize.js +13 -0
- package/dist/src/graph/serialize.js.map +1 -0
- package/dist/src/graph/serialize.test.d.ts +2 -0
- package/dist/src/graph/serialize.test.d.ts.map +1 -0
- package/dist/src/graph/serialize.test.js +49 -0
- package/dist/src/graph/serialize.test.js.map +1 -0
- package/dist/src/graph/unset-entity-values.d.ts +21 -0
- package/dist/src/graph/unset-entity-values.d.ts.map +1 -0
- package/dist/src/graph/unset-entity-values.js +31 -0
- package/dist/src/graph/unset-entity-values.js.map +1 -0
- package/dist/src/graph/unset-entity-values.test.d.ts +2 -0
- package/dist/src/graph/unset-entity-values.test.d.ts.map +1 -0
- package/dist/src/graph/unset-entity-values.test.js +40 -0
- package/dist/src/graph/unset-entity-values.test.js.map +1 -0
- package/dist/src/graph/unset-relation-fields.d.ts +26 -0
- package/dist/src/graph/unset-relation-fields.d.ts.map +1 -0
- package/dist/src/graph/unset-relation-fields.js +38 -0
- package/dist/src/graph/unset-relation-fields.js.map +1 -0
- package/dist/src/graph/unset-relation-fields.test.d.ts +2 -0
- package/dist/src/graph/unset-relation-fields.test.d.ts.map +1 -0
- package/dist/src/graph/unset-relation-fields.test.js +70 -0
- package/dist/src/graph/unset-relation-fields.test.js.map +1 -0
- package/dist/src/graph/update-entity.d.ts +27 -0
- package/dist/src/graph/update-entity.d.ts.map +1 -0
- package/dist/src/graph/update-entity.js +153 -0
- package/dist/src/graph/update-entity.js.map +1 -0
- package/dist/src/graph/update-entity.test.d.ts +2 -0
- package/dist/src/graph/update-entity.test.d.ts.map +1 -0
- package/dist/src/graph/update-entity.test.js +208 -0
- package/dist/src/graph/update-entity.test.js.map +1 -0
- package/dist/src/graph/update-relation.d.ts +21 -0
- package/dist/src/graph/update-relation.d.ts.map +1 -0
- package/dist/src/graph/update-relation.js +43 -0
- package/dist/src/graph/update-relation.js.map +1 -0
- package/dist/src/graph/update-relation.test.d.ts +2 -0
- package/dist/src/graph/update-relation.test.d.ts.map +1 -0
- package/dist/src/graph/update-relation.test.js +230 -0
- package/dist/src/graph/update-relation.test.js.map +1 -0
- package/dist/src/graphv2/constants.d.ts +2 -0
- package/dist/src/graphv2/constants.d.ts.map +1 -0
- package/dist/src/graphv2/constants.js +2 -0
- package/dist/src/graphv2/constants.js.map +1 -0
- package/dist/src/graphv2/create-entity.d.ts +52 -0
- package/dist/src/graphv2/create-entity.d.ts.map +1 -0
- package/dist/src/graphv2/create-entity.js +140 -0
- package/dist/src/graphv2/create-entity.js.map +1 -0
- package/dist/src/graphv2/create-entity.test.d.ts +2 -0
- package/dist/src/graphv2/create-entity.test.d.ts.map +1 -0
- package/dist/src/graphv2/create-entity.test.js +158 -0
- package/dist/src/graphv2/create-entity.test.js.map +1 -0
- package/dist/src/graphv2/create-image.d.ts +28 -0
- package/dist/src/graphv2/create-image.d.ts.map +1 -0
- package/dist/src/graphv2/create-image.js +71 -0
- package/dist/src/graphv2/create-image.js.map +1 -0
- package/dist/src/graphv2/create-image.test.d.ts +2 -0
- package/dist/src/graphv2/create-image.test.d.ts.map +1 -0
- package/dist/src/graphv2/create-image.test.js +142 -0
- package/dist/src/graphv2/create-image.test.js.map +1 -0
- package/dist/src/graphv2/create-property.d.ts +22 -0
- package/dist/src/graphv2/create-property.d.ts.map +1 -0
- package/dist/src/graphv2/create-property.js +129 -0
- package/dist/src/graphv2/create-property.js.map +1 -0
- package/dist/src/graphv2/create-property.test.d.ts +2 -0
- package/dist/src/graphv2/create-property.test.d.ts.map +1 -0
- package/dist/src/graphv2/create-property.test.js +82 -0
- package/dist/src/graphv2/create-property.test.js.map +1 -0
- package/dist/src/graphv2/create-relation.d.ts +33 -0
- package/dist/src/graphv2/create-relation.d.ts.map +1 -0
- package/dist/src/graphv2/create-relation.js +66 -0
- package/dist/src/graphv2/create-relation.js.map +1 -0
- package/dist/src/graphv2/create-relation.test.d.ts +2 -0
- package/dist/src/graphv2/create-relation.test.d.ts.map +1 -0
- package/dist/src/graphv2/create-relation.test.js +208 -0
- package/dist/src/graphv2/create-relation.test.js.map +1 -0
- package/dist/src/graphv2/create-space.d.ts +13 -0
- package/dist/src/graphv2/create-space.d.ts.map +1 -0
- package/dist/src/graphv2/create-space.js +21 -0
- package/dist/src/graphv2/create-space.js.map +1 -0
- package/dist/src/graphv2/create-type.d.ts +22 -0
- package/dist/src/graphv2/create-type.d.ts.map +1 -0
- package/dist/src/graphv2/create-type.js +64 -0
- package/dist/src/graphv2/create-type.js.map +1 -0
- package/dist/src/graphv2/create-type.test.d.ts +2 -0
- package/dist/src/graphv2/create-type.test.d.ts.map +1 -0
- package/dist/src/graphv2/create-type.test.js +109 -0
- package/dist/src/graphv2/create-type.test.js.map +1 -0
- package/dist/src/graphv2/delete-entity.d.ts +14 -0
- package/dist/src/graphv2/delete-entity.d.ts.map +1 -0
- package/dist/src/graphv2/delete-entity.js +21 -0
- package/dist/src/graphv2/delete-entity.js.map +1 -0
- package/dist/src/graphv2/delete-entity.test.d.ts +2 -0
- package/dist/src/graphv2/delete-entity.test.d.ts.map +1 -0
- package/dist/src/graphv2/delete-entity.test.js +24 -0
- package/dist/src/graphv2/delete-entity.test.js.map +1 -0
- package/dist/src/graphv2/delete-relation.d.ts +14 -0
- package/dist/src/graphv2/delete-relation.d.ts.map +1 -0
- package/dist/src/graphv2/delete-relation.js +21 -0
- package/dist/src/graphv2/delete-relation.js.map +1 -0
- package/dist/src/graphv2/delete-relation.test.d.ts +2 -0
- package/dist/src/graphv2/delete-relation.test.d.ts.map +1 -0
- package/dist/src/graphv2/delete-relation.test.js +24 -0
- package/dist/src/graphv2/delete-relation.test.js.map +1 -0
- package/dist/src/graphv2/index.d.ts +12 -0
- package/dist/src/graphv2/index.d.ts.map +1 -0
- package/dist/src/graphv2/index.js +12 -0
- package/dist/src/graphv2/index.js.map +1 -0
- package/dist/src/graphv2/remove-entity-properties.d.ts +25 -0
- package/dist/src/graphv2/remove-entity-properties.d.ts.map +1 -0
- package/dist/src/graphv2/remove-entity-properties.js +24 -0
- package/dist/src/graphv2/remove-entity-properties.js.map +1 -0
- package/dist/src/graphv2/unset-entity-values.d.ts +21 -0
- package/dist/src/graphv2/unset-entity-values.d.ts.map +1 -0
- package/dist/src/graphv2/unset-entity-values.js +26 -0
- package/dist/src/graphv2/unset-entity-values.js.map +1 -0
- package/dist/src/graphv2/unset-entity-values.test.d.ts +2 -0
- package/dist/src/graphv2/unset-entity-values.test.d.ts.map +1 -0
- package/dist/src/graphv2/unset-entity-values.test.js +40 -0
- package/dist/src/graphv2/unset-entity-values.test.js.map +1 -0
- package/dist/src/graphv2/unset-relation-fields.d.ts +25 -0
- package/dist/src/graphv2/unset-relation-fields.d.ts.map +1 -0
- package/dist/src/graphv2/unset-relation-fields.js +34 -0
- package/dist/src/graphv2/unset-relation-fields.js.map +1 -0
- package/dist/src/graphv2/unset-relation-fields.test.d.ts +2 -0
- package/dist/src/graphv2/unset-relation-fields.test.d.ts.map +1 -0
- package/dist/src/graphv2/unset-relation-fields.test.js +64 -0
- package/dist/src/graphv2/unset-relation-fields.test.js.map +1 -0
- package/dist/src/graphv2/update-entity.d.ts +28 -0
- package/dist/src/graphv2/update-entity.d.ts.map +1 -0
- package/dist/src/graphv2/update-entity.js +73 -0
- package/dist/src/graphv2/update-entity.js.map +1 -0
- package/dist/src/graphv2/update-entity.test.d.ts +2 -0
- package/dist/src/graphv2/update-entity.test.d.ts.map +1 -0
- package/dist/src/graphv2/update-entity.test.js +116 -0
- package/dist/src/graphv2/update-entity.test.js.map +1 -0
- package/dist/src/graphv2/update-relation.d.ts +21 -0
- package/dist/src/graphv2/update-relation.d.ts.map +1 -0
- package/dist/src/graphv2/update-relation.js +37 -0
- package/dist/src/graphv2/update-relation.js.map +1 -0
- package/dist/src/id-utils.d.ts +36 -0
- package/dist/src/id-utils.d.ts.map +1 -0
- package/dist/src/id-utils.js +100 -0
- package/dist/src/id-utils.js.map +1 -0
- package/dist/src/id-utils.test.d.ts +2 -0
- package/dist/src/id-utils.test.d.ts.map +1 -0
- package/dist/src/id-utils.test.js +33 -0
- package/dist/src/id-utils.test.js.map +1 -0
- package/dist/src/id.d.ts +11 -0
- package/dist/src/id.d.ts.map +1 -0
- package/dist/src/id.js +13 -0
- package/dist/src/id.js.map +1 -0
- package/dist/src/id.test.d.ts +2 -0
- package/dist/src/id.test.d.ts.map +1 -0
- package/dist/src/id.test.js +14 -0
- package/dist/src/id.test.js.map +1 -0
- package/dist/src/idv2.d.ts +27 -0
- package/dist/src/idv2.d.ts.map +1 -0
- package/dist/src/idv2.js +88 -0
- package/dist/src/idv2.js.map +1 -0
- package/dist/src/idv2.test.d.ts +2 -0
- package/dist/src/idv2.test.d.ts.map +1 -0
- package/dist/src/idv2.test.js +26 -0
- package/dist/src/idv2.test.js.map +1 -0
- package/dist/src/image.d.ts +8 -0
- package/dist/src/image.d.ts.map +1 -0
- package/dist/src/image.js +8 -0
- package/dist/src/image.js.map +1 -0
- package/dist/src/internal/uuid.d.ts +11 -0
- package/dist/src/internal/uuid.d.ts.map +1 -0
- package/dist/src/internal/uuid.js +18 -0
- package/dist/src/internal/uuid.js.map +1 -0
- package/dist/src/ipfs.d.ts +98 -0
- package/dist/src/ipfs.d.ts.map +1 -0
- package/dist/src/ipfs.js +192 -0
- package/dist/src/ipfs.js.map +1 -0
- package/dist/src/ipfs.test.d.ts +2 -0
- package/dist/src/ipfs.test.d.ts.map +1 -0
- package/dist/src/ipfs.test.js +137 -0
- package/dist/src/ipfs.test.js.map +1 -0
- package/dist/src/ipfsv2.d.ts +96 -0
- package/dist/src/ipfsv2.d.ts.map +1 -0
- package/dist/src/ipfsv2.js +163 -0
- package/dist/src/ipfsv2.js.map +1 -0
- package/dist/src/ipfsv2.test.d.ts +2 -0
- package/dist/src/ipfsv2.test.d.ts.map +1 -0
- package/dist/src/ipfsv2.test.js +22 -0
- package/dist/src/ipfsv2.test.js.map +1 -0
- package/dist/src/position.d.ts +7 -0
- package/dist/src/position.d.ts.map +1 -0
- package/dist/src/position.js +7 -0
- package/dist/src/position.js.map +1 -0
- package/dist/src/proto/edit.d.ts +11 -0
- package/dist/src/proto/edit.d.ts.map +1 -0
- package/dist/src/proto/edit.js +210 -0
- package/dist/src/proto/edit.js.map +1 -0
- package/dist/src/proto/edit.test.d.ts +2 -0
- package/dist/src/proto/edit.test.d.ts.map +1 -0
- package/dist/src/proto/edit.test.js +326 -0
- package/dist/src/proto/edit.test.js.map +1 -0
- package/dist/src/proto/editv2.d.ts +11 -0
- package/dist/src/proto/editv2.d.ts.map +1 -0
- package/dist/src/proto/editv2.js +81 -0
- package/dist/src/proto/editv2.js.map +1 -0
- package/dist/src/proto/editv2.test.d.ts +2 -0
- package/dist/src/proto/editv2.test.d.ts.map +1 -0
- package/dist/src/proto/editv2.test.js +211 -0
- package/dist/src/proto/editv2.test.js.map +1 -0
- package/dist/src/proto/gen/src/proto/ipfs_pb.d.ts +530 -0
- package/dist/src/proto/gen/src/proto/ipfs_pb.d.ts.map +1 -0
- package/dist/src/proto/gen/src/proto/ipfs_pb.js +706 -0
- package/dist/src/proto/gen/src/proto/ipfs_pb.js.map +1 -0
- package/dist/src/proto/gen/src/proto/ipfsv2_pb.d.ts +410 -0
- package/dist/src/proto/gen/src/proto/ipfsv2_pb.d.ts.map +1 -0
- package/dist/src/proto/gen/src/proto/ipfsv2_pb.js +536 -0
- package/dist/src/proto/gen/src/proto/ipfsv2_pb.js.map +1 -0
- package/dist/src/proto/index.d.ts +7 -0
- package/dist/src/proto/index.d.ts.map +1 -0
- package/dist/src/proto/index.js +7 -0
- package/dist/src/proto/index.js.map +1 -0
- package/dist/src/ranks/create-rank.d.ts +42 -0
- package/dist/src/ranks/create-rank.d.ts.map +1 -0
- package/dist/src/ranks/create-rank.js +146 -0
- package/dist/src/ranks/create-rank.js.map +1 -0
- package/dist/src/ranks/create-rank.test.d.ts +2 -0
- package/dist/src/ranks/create-rank.test.d.ts.map +1 -0
- package/dist/src/ranks/create-rank.test.js +333 -0
- package/dist/src/ranks/create-rank.test.js.map +1 -0
- package/dist/src/ranks/index.d.ts +3 -0
- package/dist/src/ranks/index.d.ts.map +1 -0
- package/dist/src/ranks/index.js +3 -0
- package/dist/src/ranks/index.js.map +1 -0
- package/dist/src/ranks/types.d.ts +30 -0
- package/dist/src/ranks/types.d.ts.map +1 -0
- package/dist/src/ranks/types.js +2 -0
- package/dist/src/ranks/types.js.map +1 -0
- package/dist/src/relation.d.ts +7 -0
- package/dist/src/relation.d.ts.map +1 -0
- package/dist/src/relation.js +7 -0
- package/dist/src/relation.js.map +1 -0
- package/dist/src/scheme.d.ts +7 -0
- package/dist/src/scheme.d.ts.map +1 -0
- package/dist/src/scheme.js +7 -0
- package/dist/src/scheme.js.map +1 -0
- package/dist/src/smart-wallet-2.test-invalid.d.ts +2 -0
- package/dist/src/smart-wallet-2.test-invalid.d.ts.map +1 -0
- package/dist/src/smart-wallet-2.test-invalid.js +49 -0
- package/dist/src/smart-wallet-2.test-invalid.js.map +1 -0
- package/dist/src/smart-wallet-2.test.d.ts +2 -0
- package/dist/src/smart-wallet-2.test.d.ts.map +1 -0
- package/dist/src/smart-wallet-2.test.js +49 -0
- package/dist/src/smart-wallet-2.test.js.map +1 -0
- package/dist/src/smart-wallet.d.ts +26 -0
- package/dist/src/smart-wallet.d.ts.map +1 -0
- package/dist/src/smart-wallet.js +100 -0
- package/dist/src/smart-wallet.js.map +1 -0
- package/dist/src/smart-wallet.test.d.ts +2 -0
- package/dist/src/smart-wallet.test.d.ts.map +1 -0
- package/dist/src/smart-wallet.test.js +66 -0
- package/dist/src/smart-wallet.test.js.map +1 -0
- package/dist/src/system-ids-v2.d.ts +7 -0
- package/dist/src/system-ids-v2.d.ts.map +1 -0
- package/dist/src/system-ids-v2.js +7 -0
- package/dist/src/system-ids-v2.js.map +1 -0
- package/dist/src/system-ids.d.ts +7 -0
- package/dist/src/system-ids.d.ts.map +1 -0
- package/dist/src/system-ids.js +7 -0
- package/dist/src/system-ids.js.map +1 -0
- package/dist/src/triple.d.ts +7 -0
- package/dist/src/triple.d.ts.map +1 -0
- package/dist/src/triple.js +7 -0
- package/dist/src/triple.js.map +1 -0
- package/dist/src/types-backup.d.ts +134 -0
- package/dist/src/types-backup.d.ts.map +1 -0
- package/dist/src/types-backup.js +13 -0
- package/dist/src/types-backup.js.map +1 -0
- package/dist/src/types.d.ts +176 -0
- package/dist/src/types.d.ts.map +1 -0
- package/dist/src/types.js +8 -0
- package/dist/src/types.js.map +1 -0
- package/dist/src/typesv2.d.ts +173 -0
- package/dist/src/typesv2.d.ts.map +1 -0
- package/dist/src/typesv2.js +8 -0
- package/dist/src/typesv2.js.map +1 -0
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/package.json +46 -0
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { Brand } from 'effect';
|
|
2
|
+
export type Id = string & Brand.Brand<'Id'>;
|
|
3
|
+
export type IdBase64 = string & Brand.Brand<'IdBase64'>;
|
|
4
|
+
export declare const Id: Brand.Brand.Constructor<Id>;
|
|
5
|
+
export declare const IdBase64: Brand.Brand.Constructor<IdBase64>;
|
|
6
|
+
/**
|
|
7
|
+
* Generates a globally unique knowledge graph identifier.
|
|
8
|
+
*
|
|
9
|
+
* @example
|
|
10
|
+
* ```
|
|
11
|
+
* import { ID } from '@graphprotocol/grc-20'
|
|
12
|
+
*
|
|
13
|
+
* const id = ID.generate();
|
|
14
|
+
* console.log(id)
|
|
15
|
+
* ```
|
|
16
|
+
*
|
|
17
|
+
* @returns v4 UUID
|
|
18
|
+
*/
|
|
19
|
+
export declare function generate(): Id;
|
|
20
|
+
export declare function isValid(id: string): boolean;
|
|
21
|
+
export declare function isValidBase64(id: string): boolean;
|
|
22
|
+
export declare function assertValid(id: string, sourceHint?: string): void;
|
|
23
|
+
export declare function toBytes(id: Id): Uint8Array;
|
|
24
|
+
export declare function fromBytes(bytes: Uint8Array): Id;
|
|
25
|
+
export declare function toBase64(id: Id): IdBase64;
|
|
26
|
+
export declare function fromBase64(id: IdBase64): Id;
|
|
27
|
+
//# sourceMappingURL=idv2.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"idv2.d.ts","sourceRoot":"","sources":["../../src/idv2.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,QAAQ,CAAC;AAS/B,MAAM,MAAM,EAAE,GAAG,MAAM,GAAG,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;AAE5C,MAAM,MAAM,QAAQ,GAAG,MAAM,GAAG,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;AAExD,eAAO,MAAM,EAAE,6BAGd,CAAC;AAEF,eAAO,MAAM,QAAQ,mCAGpB,CAAC;AAEF;;;;;;;;;;;;GAYG;AACH,wBAAgB,QAAQ,IAAI,EAAE,CAG7B;AAED,wBAAgB,OAAO,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAE3C;AAED,wBAAgB,aAAa,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAQjD;AAED,wBAAgB,WAAW,CAAC,EAAE,EAAE,MAAM,EAAE,UAAU,CAAC,EAAE,MAAM,QAI1D;AAED,wBAAgB,OAAO,CAAC,EAAE,EAAE,EAAE,GAAG,UAAU,CAE1C;AAED,wBAAgB,SAAS,CAAC,KAAK,EAAE,UAAU,GAAG,EAAE,CAE/C;AAID,wBAAgB,QAAQ,CAAC,EAAE,EAAE,EAAE,GAAG,QAAQ,CAoBzC;AAED,wBAAgB,UAAU,CAAC,EAAE,EAAE,QAAQ,GAAG,EAAE,CAqB3C"}
|
package/dist/src/idv2.js
ADDED
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
import { Brand } from 'effect';
|
|
2
|
+
/**
|
|
3
|
+
* This module provides utility functions for working knowledge graph
|
|
4
|
+
* identifiers in TypeScript.
|
|
5
|
+
*/
|
|
6
|
+
import { parse as uuidParse, stringify as uuidStringify, validate as uuidValidate, v4 as uuidv4 } from 'uuid';
|
|
7
|
+
export const Id = Brand.refined(id => isValid(id), id => Brand.error(`Expected ${id} to be a valid Id`));
|
|
8
|
+
export const IdBase64 = Brand.refined(id => isValidBase64(id), id => Brand.error(`Expected ${id} to be a valid IdBase64`));
|
|
9
|
+
/**
|
|
10
|
+
* Generates a globally unique knowledge graph identifier.
|
|
11
|
+
*
|
|
12
|
+
* @example
|
|
13
|
+
* ```
|
|
14
|
+
* import { ID } from '@graphprotocol/grc-20'
|
|
15
|
+
*
|
|
16
|
+
* const id = ID.generate();
|
|
17
|
+
* console.log(id)
|
|
18
|
+
* ```
|
|
19
|
+
*
|
|
20
|
+
* @returns v4 UUID
|
|
21
|
+
*/
|
|
22
|
+
export function generate() {
|
|
23
|
+
const uuid = uuidv4();
|
|
24
|
+
return Id(uuid);
|
|
25
|
+
}
|
|
26
|
+
export function isValid(id) {
|
|
27
|
+
return uuidValidate(id);
|
|
28
|
+
}
|
|
29
|
+
export function isValidBase64(id) {
|
|
30
|
+
try {
|
|
31
|
+
// @ts-expect-error
|
|
32
|
+
const uuid = fromBase64(id);
|
|
33
|
+
return isValid(uuid);
|
|
34
|
+
}
|
|
35
|
+
catch (error) {
|
|
36
|
+
return false;
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
export function assertValid(id, sourceHint) {
|
|
40
|
+
if (!isValid(id)) {
|
|
41
|
+
throw new Error(`Invalid id: "${id}"${sourceHint ? ` for ${sourceHint}` : ''}`);
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
export function toBytes(id) {
|
|
45
|
+
return uuidParse(id);
|
|
46
|
+
}
|
|
47
|
+
export function fromBytes(bytes) {
|
|
48
|
+
return Id(uuidStringify(bytes));
|
|
49
|
+
}
|
|
50
|
+
const base64Chars = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/';
|
|
51
|
+
export function toBase64(id) {
|
|
52
|
+
const bytes = toBytes(id);
|
|
53
|
+
let result = '';
|
|
54
|
+
let i;
|
|
55
|
+
for (i = 0; i < bytes.length; i += 3) {
|
|
56
|
+
const a = bytes[i];
|
|
57
|
+
const b = bytes[i + 1] ?? 0;
|
|
58
|
+
const c = bytes[i + 2] ?? 0;
|
|
59
|
+
// @ts-expect-error
|
|
60
|
+
const triple = (a << 16) | (b << 8) | c;
|
|
61
|
+
result += base64Chars[(triple >> 18) & 0x3f];
|
|
62
|
+
result += base64Chars[(triple >> 12) & 0x3f];
|
|
63
|
+
result += i + 1 < bytes.length ? base64Chars[(triple >> 6) & 0x3f] : '=';
|
|
64
|
+
result += i + 2 < bytes.length ? base64Chars[triple & 0x3f] : '=';
|
|
65
|
+
}
|
|
66
|
+
return IdBase64(result);
|
|
67
|
+
}
|
|
68
|
+
export function fromBase64(id) {
|
|
69
|
+
const bytes = [];
|
|
70
|
+
for (let i = 0; i < id.length; i += 4) {
|
|
71
|
+
// @ts-expect-error
|
|
72
|
+
const c1 = base64Chars.indexOf(id[i]);
|
|
73
|
+
// @ts-expect-error
|
|
74
|
+
const c2 = base64Chars.indexOf(id[i + 1]);
|
|
75
|
+
// @ts-expect-error
|
|
76
|
+
const c3 = base64Chars.indexOf(id[i + 2]);
|
|
77
|
+
// @ts-expect-error
|
|
78
|
+
const c4 = base64Chars.indexOf(id[i + 3]);
|
|
79
|
+
const triple = (c1 << 18) | (c2 << 12) | ((c3 & 63) << 6) | (c4 & 63);
|
|
80
|
+
bytes.push((triple >> 16) & 0xff);
|
|
81
|
+
if (c3 !== -1 && c3 !== 64)
|
|
82
|
+
bytes.push((triple >> 8) & 0xff);
|
|
83
|
+
if (c4 !== -1 && c4 !== 64)
|
|
84
|
+
bytes.push(triple & 0xff);
|
|
85
|
+
}
|
|
86
|
+
return fromBytes(new Uint8Array(bytes));
|
|
87
|
+
}
|
|
88
|
+
//# sourceMappingURL=idv2.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"idv2.js","sourceRoot":"","sources":["../../src/idv2.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"idv2.test.d.ts","sourceRoot":"","sources":["../../src/idv2.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { expect, it } from 'vitest';
|
|
2
|
+
import { Id, generate, isValid, toBase64 } from './idv2.js';
|
|
3
|
+
it('should generate valid uuid', () => {
|
|
4
|
+
const id = generate();
|
|
5
|
+
expect(id).toBeTypeOf('string');
|
|
6
|
+
expect(id.length).toBe(36);
|
|
7
|
+
expect(id).toMatch(/^[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}$/);
|
|
8
|
+
});
|
|
9
|
+
it('should validate uuid', () => {
|
|
10
|
+
expect(isValid(generate())).toBe(true);
|
|
11
|
+
expect(isValid(generate())).toBe(true);
|
|
12
|
+
expect(isValid(generate())).toBe(true);
|
|
13
|
+
expect(isValid('3af3e22d-2169-4a07-8681-516710b7ecf1')).toBe(true);
|
|
14
|
+
});
|
|
15
|
+
it('should not validate invalid id', () => {
|
|
16
|
+
expect(isValid('invalid-id')).toBe(false);
|
|
17
|
+
expect(isValid('0123456789012345678901')).toBe(false);
|
|
18
|
+
});
|
|
19
|
+
it('should convert id to base64', () => {
|
|
20
|
+
const id = Id('3af3e22d-2169-4a07-8681-516710b7ecf1');
|
|
21
|
+
const base64 = toBase64(id);
|
|
22
|
+
expect(base64).toBeTypeOf('string');
|
|
23
|
+
expect(base64).toBe('OvPiLSFpSgeGgVFnELfs8Q==');
|
|
24
|
+
expect(toBase64(Id('1d501a3a-d6ce-4693-bc90-d25286f21c7e'))).toBe('HVAaOtbORpO8kNJShvIcfg==');
|
|
25
|
+
});
|
|
26
|
+
//# sourceMappingURL=idv2.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"idv2.test.js","sourceRoot":"","sources":["../../src/idv2.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAEpC,OAAO,EAAE,EAAE,EAAE,QAAQ,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,WAAW,CAAC;AAE5D,EAAE,CAAC,4BAA4B,EAAE,GAAG,EAAE;IACpC,MAAM,EAAE,GAAG,QAAQ,EAAE,CAAC;IACtB,MAAM,CAAC,EAAE,CAAC,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;IAChC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAC3B,MAAM,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,+EAA+E,CAAC,CAAC;AACtG,CAAC,CAAC,CAAC;AAEH,EAAE,CAAC,sBAAsB,EAAE,GAAG,EAAE;IAC9B,MAAM,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACvC,MAAM,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACvC,MAAM,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACvC,MAAM,CAAC,OAAO,CAAC,sCAAsC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AACrE,CAAC,CAAC,CAAC;AAEH,EAAE,CAAC,gCAAgC,EAAE,GAAG,EAAE;IACxC,MAAM,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC1C,MAAM,CAAC,OAAO,CAAC,wBAAwB,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;AACxD,CAAC,CAAC,CAAC;AAEH,EAAE,CAAC,6BAA6B,EAAE,GAAG,EAAE;IACrC,MAAM,EAAE,GAAG,EAAE,CAAC,sCAAsC,CAAC,CAAC;IACtD,MAAM,MAAM,GAAG,QAAQ,CAAC,EAAE,CAAC,CAAC;IAC5B,MAAM,CAAC,MAAM,CAAC,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;IACpC,MAAM,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,0BAA0B,CAAC,CAAC;IAChD,MAAM,CAAC,QAAQ,CAAC,EAAE,CAAC,sCAAsC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,0BAA0B,CAAC,CAAC;AAChG,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"image.d.ts","sourceRoot":"","sources":["../../src/image.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AACH,OAAO,KAAK,KAAK,MAAM,iBAAiB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"image.js","sourceRoot":"","sources":["../../src/image.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AACH,OAAO,KAAK,KAAK,MAAM,iBAAiB,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* If `id` looks like a UUID without dashes (32 hex chars), convert it to the
|
|
3
|
+
* dashed UUID format. Otherwise returns `null`.
|
|
4
|
+
*/
|
|
5
|
+
export declare function dashlessUuidToDashed(id: string): string | null;
|
|
6
|
+
/**
|
|
7
|
+
* `uuid.parse` accepts the dashed UUID format, so normalize canonical (dashless)
|
|
8
|
+
* UUIDs into the dashed representation, leaving other inputs unchanged.
|
|
9
|
+
*/
|
|
10
|
+
export declare function normalizeUuidForParse(id: string): string;
|
|
11
|
+
//# sourceMappingURL=uuid.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"uuid.d.ts","sourceRoot":"","sources":["../../../src/internal/uuid.ts"],"names":[],"mappings":"AAEA;;;GAGG;AACH,wBAAgB,oBAAoB,CAAC,EAAE,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI,CAG9D;AAED;;;GAGG;AACH,wBAAgB,qBAAqB,CAAC,EAAE,EAAE,MAAM,GAAG,MAAM,CAExD"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
const UUID_DASHLESS_REGEX = /^[0-9a-fA-F]{32}$/;
|
|
2
|
+
/**
|
|
3
|
+
* If `id` looks like a UUID without dashes (32 hex chars), convert it to the
|
|
4
|
+
* dashed UUID format. Otherwise returns `null`.
|
|
5
|
+
*/
|
|
6
|
+
export function dashlessUuidToDashed(id) {
|
|
7
|
+
if (!UUID_DASHLESS_REGEX.test(id))
|
|
8
|
+
return null;
|
|
9
|
+
return `${id.slice(0, 8)}-${id.slice(8, 12)}-${id.slice(12, 16)}-${id.slice(16, 20)}-${id.slice(20)}`;
|
|
10
|
+
}
|
|
11
|
+
/**
|
|
12
|
+
* `uuid.parse` accepts the dashed UUID format, so normalize canonical (dashless)
|
|
13
|
+
* UUIDs into the dashed representation, leaving other inputs unchanged.
|
|
14
|
+
*/
|
|
15
|
+
export function normalizeUuidForParse(id) {
|
|
16
|
+
return dashlessUuidToDashed(id) ?? id;
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=uuid.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"uuid.js","sourceRoot":"","sources":["../../../src/internal/uuid.ts"],"names":[],"mappings":"AAAA,MAAM,mBAAmB,GAAG,mBAAmB,CAAC;AAEhD;;;GAGG;AACH,MAAM,UAAU,oBAAoB,CAAC,EAAU;IAC7C,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,EAAE,CAAC;QAAE,OAAO,IAAI,CAAC;IAC/C,OAAO,GAAG,EAAE,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,EAAE,CAAC;AACxG,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,qBAAqB,CAAC,EAAU;IAC9C,OAAO,oBAAoB,CAAC,EAAE,CAAC,IAAI,EAAE,CAAC;AACxC,CAAC"}
|
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* This module provides utility functions for interacting with the default
|
|
3
|
+
* IPFS gateway in TypeScript.
|
|
4
|
+
*
|
|
5
|
+
* @since 0.1.1
|
|
6
|
+
*/
|
|
7
|
+
import { type Op } from '@geoprotocol/grc-20';
|
|
8
|
+
import type { Id } from './id.js';
|
|
9
|
+
import type { Network } from './types.js';
|
|
10
|
+
type PublishEditProposalParams = {
|
|
11
|
+
name: string;
|
|
12
|
+
ops: Op[];
|
|
13
|
+
author: `0x${string}`;
|
|
14
|
+
network?: Network;
|
|
15
|
+
};
|
|
16
|
+
type PublishEditResult = {
|
|
17
|
+
cid: string;
|
|
18
|
+
editId: Id;
|
|
19
|
+
};
|
|
20
|
+
/**
|
|
21
|
+
* Generates correct GRC-20 v2 binary encoding for an Edit and uploads it to IPFS.
|
|
22
|
+
*
|
|
23
|
+
* @example
|
|
24
|
+
* ```ts
|
|
25
|
+
* import { IPFS } from '@geoprotocol/geo-sdk';
|
|
26
|
+
*
|
|
27
|
+
* const { cid, editId } = await IPFS.publishEdit({
|
|
28
|
+
* name: 'Edit name',
|
|
29
|
+
* ops: ops,
|
|
30
|
+
* author: '0x000000000000000000000000000000000000',
|
|
31
|
+
* });
|
|
32
|
+
* ```
|
|
33
|
+
*
|
|
34
|
+
* @param args arguments for publishing an edit to IPFS {@link PublishEditProposalParams}
|
|
35
|
+
* @returns - {@link PublishEditResult}
|
|
36
|
+
*/
|
|
37
|
+
export declare function publishEdit(args: PublishEditProposalParams): Promise<PublishEditResult>;
|
|
38
|
+
type PublishImageParams = {
|
|
39
|
+
blob: Blob;
|
|
40
|
+
} | {
|
|
41
|
+
url: string;
|
|
42
|
+
};
|
|
43
|
+
export declare function uploadImage(params: PublishImageParams, network?: Network, alternativeGateway?: boolean): Promise<{
|
|
44
|
+
cid: `ipfs://${string}`;
|
|
45
|
+
dimensions: {
|
|
46
|
+
width: number;
|
|
47
|
+
height: number;
|
|
48
|
+
};
|
|
49
|
+
} | {
|
|
50
|
+
cid: `ipfs://${string}`;
|
|
51
|
+
dimensions?: undefined;
|
|
52
|
+
}>;
|
|
53
|
+
/**
|
|
54
|
+
* Uploads a CSV file to IPFS and returns the CID. This CSV
|
|
55
|
+
* file will be compressed using gzip before being uploaded.
|
|
56
|
+
*
|
|
57
|
+
* @example
|
|
58
|
+
* ```ts
|
|
59
|
+
* const file = Bun.file('cities.csv');
|
|
60
|
+
* const fileText = await file.text();
|
|
61
|
+
*
|
|
62
|
+
* const cid = await Ipfs.uploadCSV(fileText);
|
|
63
|
+
* ```
|
|
64
|
+
*
|
|
65
|
+
* @example
|
|
66
|
+
* ```ts
|
|
67
|
+
* import { Csv } from '@geoprotocol/geo-sdk';
|
|
68
|
+
*
|
|
69
|
+
* const csvString = Csv.stringify({
|
|
70
|
+
* data: Array.from({ length: 151_000 }, (_, i: number) => [i.toString(), (i * 2).toString(), (i * 3).toString()]),
|
|
71
|
+
* metadata: {
|
|
72
|
+
* filetype: 'CSV',
|
|
73
|
+
* columns: [
|
|
74
|
+
* {
|
|
75
|
+
* id: 'foo',
|
|
76
|
+
* type: 'TEXT',
|
|
77
|
+
* },
|
|
78
|
+
* {
|
|
79
|
+
* id: 'bar',
|
|
80
|
+
* type: 'NUMBER',
|
|
81
|
+
* },
|
|
82
|
+
* {
|
|
83
|
+
* id: 'baz',
|
|
84
|
+
* type: 'TEXT',
|
|
85
|
+
* },
|
|
86
|
+
* ],
|
|
87
|
+
* },
|
|
88
|
+
* })
|
|
89
|
+
*
|
|
90
|
+
* const cid = await Ipfs.uploadCSV(csvString);
|
|
91
|
+
* ```
|
|
92
|
+
*
|
|
93
|
+
* @param csvString The CSV to upload as a string
|
|
94
|
+
* @returns IPFS CID representing the uploaded file prefixed with `ipfs://`
|
|
95
|
+
*/
|
|
96
|
+
export declare function uploadCSV(csvString: string, network?: Network): Promise<`ipfs://${string}`>;
|
|
97
|
+
export {};
|
|
98
|
+
//# sourceMappingURL=ipfs.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ipfs.d.ts","sourceRoot":"","sources":["../../src/ipfs.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAKL,KAAK,EAAE,EAER,MAAM,qBAAqB,CAAC;AAO7B,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,SAAS,CAAC;AAClC,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,YAAY,CAAC;AAc1C,KAAK,yBAAyB,GAAG;IAC/B,IAAI,EAAE,MAAM,CAAC;IACb,GAAG,EAAE,EAAE,EAAE,CAAC;IACV,MAAM,EAAE,KAAK,MAAM,EAAE,CAAC;IACtB,OAAO,CAAC,EAAE,OAAO,CAAC;CACnB,CAAC;AAEF,KAAK,iBAAiB,GAAG;IAEvB,GAAG,EAAE,MAAM,CAAC;IAEZ,MAAM,EAAE,EAAE,CAAC;CACZ,CAAC;AAEF;;;;;;;;;;;;;;;;GAgBG;AACH,wBAAsB,WAAW,CAAC,IAAI,EAAE,yBAAyB,GAAG,OAAO,CAAC,iBAAiB,CAAC,CA8B7F;AAED,KAAK,kBAAkB,GACnB;IACE,IAAI,EAAE,IAAI,CAAC;CACZ,GACD;IACE,GAAG,EAAE,MAAM,CAAC;CACb,CAAC;AAEN,wBAAsB,WAAW,CAAC,MAAM,EAAE,kBAAkB,EAAE,OAAO,CAAC,EAAE,OAAO,EAAE,kBAAkB,CAAC,EAAE,OAAO;;;;;;;;;GAkC5G;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA0CG;AACH,wBAAsB,SAAS,CAAC,SAAS,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,UAAU,MAAM,EAAE,CAAC,CAUjG"}
|
package/dist/src/ipfs.js
ADDED
|
@@ -0,0 +1,192 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* This module provides utility functions for interacting with the default
|
|
3
|
+
* IPFS gateway in TypeScript.
|
|
4
|
+
*
|
|
5
|
+
* @since 0.1.1
|
|
6
|
+
*/
|
|
7
|
+
import { derivedUuidFromString, encodeEdit, randomId, } from '@geoprotocol/grc-20';
|
|
8
|
+
import { Micro } from 'effect';
|
|
9
|
+
import { gzipSync } from 'fflate';
|
|
10
|
+
import { imageSize } from 'image-size';
|
|
11
|
+
import { getApiOrigin } from './graph/constants.js';
|
|
12
|
+
import { fromBytes } from './id-utils.js';
|
|
13
|
+
class IpfsUploadError extends Error {
|
|
14
|
+
_tag = 'IpfsUploadError';
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* Converts a hex string (like an ethereum address) to a GRC-20 Id.
|
|
18
|
+
* Uses derived UUID since ethereum addresses (20 bytes) don't fit directly into UUIDs (16 bytes).
|
|
19
|
+
*/
|
|
20
|
+
function hexToGrcId(hex) {
|
|
21
|
+
return derivedUuidFromString(hex);
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* Generates correct GRC-20 v2 binary encoding for an Edit and uploads it to IPFS.
|
|
25
|
+
*
|
|
26
|
+
* @example
|
|
27
|
+
* ```ts
|
|
28
|
+
* import { IPFS } from '@geoprotocol/geo-sdk';
|
|
29
|
+
*
|
|
30
|
+
* const { cid, editId } = await IPFS.publishEdit({
|
|
31
|
+
* name: 'Edit name',
|
|
32
|
+
* ops: ops,
|
|
33
|
+
* author: '0x000000000000000000000000000000000000',
|
|
34
|
+
* });
|
|
35
|
+
* ```
|
|
36
|
+
*
|
|
37
|
+
* @param args arguments for publishing an edit to IPFS {@link PublishEditProposalParams}
|
|
38
|
+
* @returns - {@link PublishEditResult}
|
|
39
|
+
*/
|
|
40
|
+
export async function publishEdit(args) {
|
|
41
|
+
const { name, ops, author, network = 'TESTNET' } = args;
|
|
42
|
+
// Generate a new edit ID
|
|
43
|
+
const editId = randomId();
|
|
44
|
+
// Build the GRC-20 v2 Edit structure
|
|
45
|
+
const grcEdit = {
|
|
46
|
+
id: editId,
|
|
47
|
+
name,
|
|
48
|
+
authors: [hexToGrcId(author)],
|
|
49
|
+
createdAt: BigInt(Date.now()) * 1000n, // Convert to microseconds
|
|
50
|
+
ops,
|
|
51
|
+
};
|
|
52
|
+
// Encode to binary format
|
|
53
|
+
const binary = encodeEdit(grcEdit);
|
|
54
|
+
// Create a copy to ensure we have a regular ArrayBuffer for Blob compatibility
|
|
55
|
+
const binaryArray = new Uint8Array(binary);
|
|
56
|
+
const blob = new Blob([binaryArray], { type: 'application/octet-stream' });
|
|
57
|
+
const formData = new FormData();
|
|
58
|
+
formData.append('file', blob);
|
|
59
|
+
const cid = await Micro.runPromise(uploadBinary(formData, network));
|
|
60
|
+
// Convert the GrcId back to a grc-20-ts Id string
|
|
61
|
+
const editIdString = fromBytes(editId);
|
|
62
|
+
return { cid, editId: editIdString };
|
|
63
|
+
}
|
|
64
|
+
export async function uploadImage(params, network, alternativeGateway) {
|
|
65
|
+
const formData = new FormData();
|
|
66
|
+
let blob;
|
|
67
|
+
if ('blob' in params) {
|
|
68
|
+
blob = params.blob;
|
|
69
|
+
}
|
|
70
|
+
else {
|
|
71
|
+
// fetch the image and upload it to IPFS
|
|
72
|
+
const response = await fetch(params.url);
|
|
73
|
+
blob = await response.blob();
|
|
74
|
+
}
|
|
75
|
+
formData.append('file', blob);
|
|
76
|
+
const buffer = new Uint8Array(await blob.arrayBuffer());
|
|
77
|
+
let dimensions;
|
|
78
|
+
try {
|
|
79
|
+
dimensions = imageSize(buffer);
|
|
80
|
+
}
|
|
81
|
+
catch (_error) { }
|
|
82
|
+
const cid = await Micro.runPromise(uploadFile(formData, network, alternativeGateway));
|
|
83
|
+
if (dimensions) {
|
|
84
|
+
return {
|
|
85
|
+
cid,
|
|
86
|
+
dimensions: {
|
|
87
|
+
width: dimensions.width,
|
|
88
|
+
height: dimensions.height,
|
|
89
|
+
},
|
|
90
|
+
};
|
|
91
|
+
}
|
|
92
|
+
return {
|
|
93
|
+
cid,
|
|
94
|
+
};
|
|
95
|
+
}
|
|
96
|
+
/**
|
|
97
|
+
* Uploads a CSV file to IPFS and returns the CID. This CSV
|
|
98
|
+
* file will be compressed using gzip before being uploaded.
|
|
99
|
+
*
|
|
100
|
+
* @example
|
|
101
|
+
* ```ts
|
|
102
|
+
* const file = Bun.file('cities.csv');
|
|
103
|
+
* const fileText = await file.text();
|
|
104
|
+
*
|
|
105
|
+
* const cid = await Ipfs.uploadCSV(fileText);
|
|
106
|
+
* ```
|
|
107
|
+
*
|
|
108
|
+
* @example
|
|
109
|
+
* ```ts
|
|
110
|
+
* import { Csv } from '@geoprotocol/geo-sdk';
|
|
111
|
+
*
|
|
112
|
+
* const csvString = Csv.stringify({
|
|
113
|
+
* data: Array.from({ length: 151_000 }, (_, i: number) => [i.toString(), (i * 2).toString(), (i * 3).toString()]),
|
|
114
|
+
* metadata: {
|
|
115
|
+
* filetype: 'CSV',
|
|
116
|
+
* columns: [
|
|
117
|
+
* {
|
|
118
|
+
* id: 'foo',
|
|
119
|
+
* type: 'TEXT',
|
|
120
|
+
* },
|
|
121
|
+
* {
|
|
122
|
+
* id: 'bar',
|
|
123
|
+
* type: 'NUMBER',
|
|
124
|
+
* },
|
|
125
|
+
* {
|
|
126
|
+
* id: 'baz',
|
|
127
|
+
* type: 'TEXT',
|
|
128
|
+
* },
|
|
129
|
+
* ],
|
|
130
|
+
* },
|
|
131
|
+
* })
|
|
132
|
+
*
|
|
133
|
+
* const cid = await Ipfs.uploadCSV(csvString);
|
|
134
|
+
* ```
|
|
135
|
+
*
|
|
136
|
+
* @param csvString The CSV to upload as a string
|
|
137
|
+
* @returns IPFS CID representing the uploaded file prefixed with `ipfs://`
|
|
138
|
+
*/
|
|
139
|
+
export async function uploadCSV(csvString, network) {
|
|
140
|
+
const encoder = new TextEncoder();
|
|
141
|
+
const csvStringBytes = encoder.encode(csvString);
|
|
142
|
+
const blob = await gzipSync(csvStringBytes);
|
|
143
|
+
const formData = new FormData();
|
|
144
|
+
// @ts-expect-error - this is a type missmatch which is fine
|
|
145
|
+
formData.append('file', new Blob([blob], { type: 'text/csv' }));
|
|
146
|
+
return await Micro.runPromise(uploadBinary(formData, network));
|
|
147
|
+
}
|
|
148
|
+
function uploadBinary(formData, network = 'TESTNET') {
|
|
149
|
+
return Micro.gen(function* () {
|
|
150
|
+
const result = yield* Micro.tryPromise({
|
|
151
|
+
try: () => fetch(`${getApiOrigin(network)}/ipfs/upload-edit`, {
|
|
152
|
+
method: 'POST',
|
|
153
|
+
body: formData,
|
|
154
|
+
}),
|
|
155
|
+
catch: error => new IpfsUploadError(`Could not upload data to IPFS: ${error}`),
|
|
156
|
+
});
|
|
157
|
+
const maybeCid = yield* Micro.tryPromise({
|
|
158
|
+
try: async () => {
|
|
159
|
+
const { cid } = await result.json();
|
|
160
|
+
return cid;
|
|
161
|
+
},
|
|
162
|
+
catch: error => new IpfsUploadError(`Could not parse response from IPFS: ${error}`),
|
|
163
|
+
});
|
|
164
|
+
return maybeCid;
|
|
165
|
+
});
|
|
166
|
+
}
|
|
167
|
+
function uploadFile(formData, network = 'TESTNET', alternativeGateway) {
|
|
168
|
+
return Micro.gen(function* () {
|
|
169
|
+
let apiUrl = `${getApiOrigin(network)}/ipfs/upload-file`;
|
|
170
|
+
if (alternativeGateway) {
|
|
171
|
+
apiUrl = `${getApiOrigin('TESTNET')}/ipfs/upload-file-alternative-gateway`;
|
|
172
|
+
}
|
|
173
|
+
const result = yield* Micro.tryPromise({
|
|
174
|
+
try: () => fetch(apiUrl, {
|
|
175
|
+
method: 'POST',
|
|
176
|
+
body: formData,
|
|
177
|
+
}),
|
|
178
|
+
catch: error => {
|
|
179
|
+
return new IpfsUploadError(`Could not upload file to IPFS: ${error}`);
|
|
180
|
+
},
|
|
181
|
+
});
|
|
182
|
+
const maybeCid = yield* Micro.tryPromise({
|
|
183
|
+
try: async () => {
|
|
184
|
+
const { cid } = await result.json();
|
|
185
|
+
return cid;
|
|
186
|
+
},
|
|
187
|
+
catch: error => new IpfsUploadError(`Could not parse response from IPFS: ${error}`),
|
|
188
|
+
});
|
|
189
|
+
return maybeCid;
|
|
190
|
+
});
|
|
191
|
+
}
|
|
192
|
+
//# sourceMappingURL=ipfs.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ipfs.js","sourceRoot":"","sources":["../../src/ipfs.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ipfs.test.d.ts","sourceRoot":"","sources":["../../src/ipfs.test.ts"],"names":[],"mappings":""}
|