@pkcprotocol/pkc-js 0.0.11
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +339 -0
- package/README.md +1663 -0
- package/dist/browser/challenges.d.ts +1 -0
- package/dist/browser/challenges.js +2 -0
- package/dist/browser/challenges.js.map +1 -0
- package/dist/browser/clients/base-client-manager.d.ts +126 -0
- package/dist/browser/clients/base-client-manager.js +673 -0
- package/dist/browser/clients/base-client-manager.js.map +1 -0
- package/dist/browser/clients/name-resolver-client.d.ts +8 -0
- package/dist/browser/clients/name-resolver-client.js +10 -0
- package/dist/browser/clients/name-resolver-client.js.map +1 -0
- package/dist/browser/clients/pkc-typed-emitter.d.ts +9 -0
- package/dist/browser/clients/pkc-typed-emitter.js +52 -0
- package/dist/browser/clients/pkc-typed-emitter.js.map +1 -0
- package/dist/browser/clients/rpc-client/decode-rpc-response-util.d.ts +8 -0
- package/dist/browser/clients/rpc-client/decode-rpc-response-util.js +53 -0
- package/dist/browser/clients/rpc-client/decode-rpc-response-util.js.map +1 -0
- package/dist/browser/clients/rpc-client/pkc-rpc-client.d.ts +68 -0
- package/dist/browser/clients/rpc-client/pkc-rpc-client.js +404 -0
- package/dist/browser/clients/rpc-client/pkc-rpc-client.js.map +1 -0
- package/dist/browser/clients/rpc-client/rpc-schema-util.d.ts +147 -0
- package/dist/browser/clients/rpc-client/rpc-schema-util.js +11 -0
- package/dist/browser/clients/rpc-client/rpc-schema-util.js.map +1 -0
- package/dist/browser/clients/rpc-client/schema.d.ts +433 -0
- package/dist/browser/clients/rpc-client/schema.js +49 -0
- package/dist/browser/clients/rpc-client/schema.js.map +1 -0
- package/dist/browser/clients/rpc-client/types.d.ts +8 -0
- package/dist/browser/clients/rpc-client/types.js +2 -0
- package/dist/browser/clients/rpc-client/types.js.map +1 -0
- package/dist/browser/community/community-client-manager.d.ts +60 -0
- package/dist/browser/community/community-client-manager.js +717 -0
- package/dist/browser/community/community-client-manager.js.map +1 -0
- package/dist/browser/community/community-clients.d.ts +18 -0
- package/dist/browser/community/community-clients.js +12 -0
- package/dist/browser/community/community-clients.js.map +1 -0
- package/dist/browser/community/community-wire.d.ts +20 -0
- package/dist/browser/community/community-wire.js +38 -0
- package/dist/browser/community/community-wire.js.map +1 -0
- package/dist/browser/community/remote-community.d.ts +110 -0
- package/dist/browser/community/remote-community.js +555 -0
- package/dist/browser/community/remote-community.js.map +1 -0
- package/dist/browser/community/rpc-local-community.d.ts +41 -0
- package/dist/browser/community/rpc-local-community.js +289 -0
- package/dist/browser/community/rpc-local-community.js.map +1 -0
- package/dist/browser/community/rpc-remote-community.d.ts +18 -0
- package/dist/browser/community/rpc-remote-community.js +286 -0
- package/dist/browser/community/rpc-remote-community.js.map +1 -0
- package/dist/browser/community/schema.d.ts +4217 -0
- package/dist/browser/community/schema.js +289 -0
- package/dist/browser/community/schema.js.map +1 -0
- package/dist/browser/community/types.d.ts +135 -0
- package/dist/browser/community/types.js +2 -0
- package/dist/browser/community/types.js.map +1 -0
- package/dist/browser/constants.d.ts +6 -0
- package/dist/browser/constants.js +9 -0
- package/dist/browser/constants.js.map +1 -0
- package/dist/browser/decorator-util.d.ts +1 -0
- package/dist/browser/decorator-util.js +35 -0
- package/dist/browser/decorator-util.js.map +1 -0
- package/dist/browser/errors.d.ts +343 -0
- package/dist/browser/errors.js +358 -0
- package/dist/browser/errors.js.map +1 -0
- package/dist/browser/general-util/limited-set.d.ts +15 -0
- package/dist/browser/general-util/limited-set.js +66 -0
- package/dist/browser/general-util/limited-set.js.map +1 -0
- package/dist/browser/generated-version.d.ts +1 -0
- package/dist/browser/generated-version.js +3 -0
- package/dist/browser/generated-version.js.map +1 -0
- package/dist/browser/generic-state-client.d.ts +6 -0
- package/dist/browser/generic-state-client.js +11 -0
- package/dist/browser/generic-state-client.js.map +1 -0
- package/dist/browser/helia/helia-for-pkc.d.ts +3 -0
- package/dist/browser/helia/helia-for-pkc.js +255 -0
- package/dist/browser/helia/helia-for-pkc.js.map +1 -0
- package/dist/browser/helia/ipns-over-pubsub-with-fetch.d.ts +36 -0
- package/dist/browser/helia/ipns-over-pubsub-with-fetch.js +229 -0
- package/dist/browser/helia/ipns-over-pubsub-with-fetch.js.map +1 -0
- package/dist/browser/helia/libp2pjsClient.d.ts +27 -0
- package/dist/browser/helia/libp2pjsClient.js +15 -0
- package/dist/browser/helia/libp2pjsClient.js.map +1 -0
- package/dist/browser/helia/types.d.ts +19 -0
- package/dist/browser/helia/types.js +2 -0
- package/dist/browser/helia/types.js.map +1 -0
- package/dist/browser/helia/util.d.ts +13 -0
- package/dist/browser/helia/util.js +98 -0
- package/dist/browser/helia/util.js.map +1 -0
- package/dist/browser/index.d.ts +244 -0
- package/dist/browser/index.js +36 -0
- package/dist/browser/index.js.map +1 -0
- package/dist/browser/logger.d.ts +12 -0
- package/dist/browser/logger.js +11 -0
- package/dist/browser/logger.js.map +1 -0
- package/dist/browser/pages/pages-client-manager.d.ts +159 -0
- package/dist/browser/pages/pages-client-manager.js +334 -0
- package/dist/browser/pages/pages-client-manager.js.map +1 -0
- package/dist/browser/pages/pages-clients.d.ts +11 -0
- package/dist/browser/pages/pages-clients.js +10 -0
- package/dist/browser/pages/pages-clients.js.map +1 -0
- package/dist/browser/pages/pages.d.ts +107 -0
- package/dist/browser/pages/pages.js +262 -0
- package/dist/browser/pages/pages.js.map +1 -0
- package/dist/browser/pages/schema-util.d.ts +3 -0
- package/dist/browser/pages/schema-util.js +3 -0
- package/dist/browser/pages/schema-util.js.map +1 -0
- package/dist/browser/pages/schema.d.ts +719 -0
- package/dist/browser/pages/schema.js +32 -0
- package/dist/browser/pages/schema.js.map +1 -0
- package/dist/browser/pages/types.d.ts +44 -0
- package/dist/browser/pages/types.js +2 -0
- package/dist/browser/pages/types.js.map +1 -0
- package/dist/browser/pages/util.d.ts +56 -0
- package/dist/browser/pages/util.js +446 -0
- package/dist/browser/pages/util.js.map +1 -0
- package/dist/browser/pkc/pkc-client-manager.d.ts +44 -0
- package/dist/browser/pkc/pkc-client-manager.js +156 -0
- package/dist/browser/pkc/pkc-client-manager.js.map +1 -0
- package/dist/browser/pkc/pkc-clients.d.ts +11 -0
- package/dist/browser/pkc/pkc-clients.js +8 -0
- package/dist/browser/pkc/pkc-clients.js.map +1 -0
- package/dist/browser/pkc/pkc-with-rpc-client.d.ts +19 -0
- package/dist/browser/pkc/pkc-with-rpc-client.js +128 -0
- package/dist/browser/pkc/pkc-with-rpc-client.js.map +1 -0
- package/dist/browser/pkc/pkc.d.ts +137 -0
- package/dist/browser/pkc/pkc.js +888 -0
- package/dist/browser/pkc/pkc.js.map +1 -0
- package/dist/browser/pkc/tracked-instance-registry-util.d.ts +44 -0
- package/dist/browser/pkc/tracked-instance-registry-util.js +106 -0
- package/dist/browser/pkc/tracked-instance-registry-util.js.map +1 -0
- package/dist/browser/pkc/tracked-instance-registry.d.ts +18 -0
- package/dist/browser/pkc/tracked-instance-registry.js +134 -0
- package/dist/browser/pkc/tracked-instance-registry.js.map +1 -0
- package/dist/browser/pkc-error.d.ts +65 -0
- package/dist/browser/pkc-error.js +137 -0
- package/dist/browser/pkc-error.js.map +1 -0
- package/dist/browser/publications/comment/comment-client-manager.d.ts +86 -0
- package/dist/browser/publications/comment/comment-client-manager.js +908 -0
- package/dist/browser/publications/comment/comment-client-manager.js.map +1 -0
- package/dist/browser/publications/comment/comment-clients.d.ts +19 -0
- package/dist/browser/publications/comment/comment-clients.js +12 -0
- package/dist/browser/publications/comment/comment-clients.js.map +1 -0
- package/dist/browser/publications/comment/comment-util.d.ts +10 -0
- package/dist/browser/publications/comment/comment-util.js +202 -0
- package/dist/browser/publications/comment/comment-util.js.map +1 -0
- package/dist/browser/publications/comment/comment.d.ts +147 -0
- package/dist/browser/publications/comment/comment.js +1044 -0
- package/dist/browser/publications/comment/comment.js.map +1 -0
- package/dist/browser/publications/comment/schema.d.ts +1237 -0
- package/dist/browser/publications/comment/schema.js +184 -0
- package/dist/browser/publications/comment/schema.js.map +1 -0
- package/dist/browser/publications/comment/types.d.ts +100 -0
- package/dist/browser/publications/comment/types.js +2 -0
- package/dist/browser/publications/comment/types.js.map +1 -0
- package/dist/browser/publications/comment-edit/comment-edit.d.ts +41 -0
- package/dist/browser/publications/comment-edit/comment-edit.js +63 -0
- package/dist/browser/publications/comment-edit/comment-edit.js.map +1 -0
- package/dist/browser/publications/comment-edit/schema.d.ts +295 -0
- package/dist/browser/publications/comment-edit/schema.js +55 -0
- package/dist/browser/publications/comment-edit/schema.js.map +1 -0
- package/dist/browser/publications/comment-edit/types.d.ts +25 -0
- package/dist/browser/publications/comment-edit/types.js +2 -0
- package/dist/browser/publications/comment-edit/types.js.map +1 -0
- package/dist/browser/publications/comment-moderation/comment-moderation.d.ts +36 -0
- package/dist/browser/publications/comment-moderation/comment-moderation.js +53 -0
- package/dist/browser/publications/comment-moderation/comment-moderation.js.map +1 -0
- package/dist/browser/publications/comment-moderation/schema.d.ts +315 -0
- package/dist/browser/publications/comment-moderation/schema.js +62 -0
- package/dist/browser/publications/comment-moderation/schema.js.map +1 -0
- package/dist/browser/publications/comment-moderation/types.d.ts +22 -0
- package/dist/browser/publications/comment-moderation/types.js +2 -0
- package/dist/browser/publications/comment-moderation/types.js.map +1 -0
- package/dist/browser/publications/community-edit/community-edit.d.ts +35 -0
- package/dist/browser/publications/community-edit/community-edit.js +50 -0
- package/dist/browser/publications/community-edit/community-edit.js.map +1 -0
- package/dist/browser/publications/community-edit/schema.d.ts +467 -0
- package/dist/browser/publications/community-edit/schema.js +36 -0
- package/dist/browser/publications/community-edit/schema.js.map +1 -0
- package/dist/browser/publications/community-edit/types.d.ts +19 -0
- package/dist/browser/publications/community-edit/types.js +2 -0
- package/dist/browser/publications/community-edit/types.js.map +1 -0
- package/dist/browser/publications/publication-author.d.ts +22 -0
- package/dist/browser/publications/publication-author.js +66 -0
- package/dist/browser/publications/publication-author.js.map +1 -0
- package/dist/browser/publications/publication-client-manager.d.ts +62 -0
- package/dist/browser/publications/publication-client-manager.js +257 -0
- package/dist/browser/publications/publication-client-manager.js.map +1 -0
- package/dist/browser/publications/publication-clients.d.ts +19 -0
- package/dist/browser/publications/publication-clients.js +12 -0
- package/dist/browser/publications/publication-clients.js.map +1 -0
- package/dist/browser/publications/publication-community.d.ts +55 -0
- package/dist/browser/publications/publication-community.js +87 -0
- package/dist/browser/publications/publication-community.js.map +1 -0
- package/dist/browser/publications/publication.d.ts +120 -0
- package/dist/browser/publications/publication.js +950 -0
- package/dist/browser/publications/publication.js.map +1 -0
- package/dist/browser/publications/types.d.ts +26 -0
- package/dist/browser/publications/types.js +2 -0
- package/dist/browser/publications/types.js.map +1 -0
- package/dist/browser/publications/vote/schema.d.ts +150 -0
- package/dist/browser/publications/vote/schema.js +44 -0
- package/dist/browser/publications/vote/schema.js.map +1 -0
- package/dist/browser/publications/vote/types.d.ts +21 -0
- package/dist/browser/publications/vote/types.js +2 -0
- package/dist/browser/publications/vote/types.js.map +1 -0
- package/dist/browser/publications/vote/vote.d.ts +36 -0
- package/dist/browser/publications/vote/vote.js +49 -0
- package/dist/browser/publications/vote/vote.js.map +1 -0
- package/dist/browser/pubsub-messages/schema.d.ts +964 -0
- package/dist/browser/pubsub-messages/schema.js +98 -0
- package/dist/browser/pubsub-messages/schema.js.map +1 -0
- package/dist/browser/pubsub-messages/types.d.ts +81 -0
- package/dist/browser/pubsub-messages/types.js +2 -0
- package/dist/browser/pubsub-messages/types.js.map +1 -0
- package/dist/browser/rpc/src/index.d.ts +483 -0
- package/dist/browser/rpc/src/index.js +1267 -0
- package/dist/browser/rpc/src/index.js.map +1 -0
- package/dist/browser/rpc/src/json-rpc-util.d.ts +1 -0
- package/dist/browser/rpc/src/json-rpc-util.js +19 -0
- package/dist/browser/rpc/src/json-rpc-util.js.map +1 -0
- package/dist/browser/rpc/src/lib/pkc-js/index.d.ts +132 -0
- package/dist/browser/rpc/src/lib/pkc-js/index.js +29 -0
- package/dist/browser/rpc/src/lib/pkc-js/index.js.map +1 -0
- package/dist/browser/rpc/src/lib/pkc-js/pkc-js-mock.d.ts +1 -0
- package/dist/browser/rpc/src/lib/pkc-js/pkc-js-mock.js +472 -0
- package/dist/browser/rpc/src/lib/pkc-js/pkc-js-mock.js.map +1 -0
- package/dist/browser/rpc/src/schema.d.ts +843 -0
- package/dist/browser/rpc/src/schema.js +28 -0
- package/dist/browser/rpc/src/schema.js.map +1 -0
- package/dist/browser/rpc/src/types.d.ts +24 -0
- package/dist/browser/rpc/src/types.js +2 -0
- package/dist/browser/rpc/src/types.js.map +1 -0
- package/dist/browser/rpc/src/utils.d.ts +7 -0
- package/dist/browser/rpc/src/utils.js +58 -0
- package/dist/browser/rpc/src/utils.js.map +1 -0
- package/dist/browser/runtime/browser/community/challenges/index.d.ts +6 -0
- package/dist/browser/runtime/browser/community/challenges/index.js +7 -0
- package/dist/browser/runtime/browser/community/challenges/index.js.map +1 -0
- package/dist/browser/runtime/browser/community/local-community.d.ts +3 -0
- package/dist/browser/runtime/browser/community/local-community.js +6 -0
- package/dist/browser/runtime/browser/community/local-community.js.map +1 -0
- package/dist/browser/runtime/browser/db-handler.d.ts +4 -0
- package/dist/browser/runtime/browser/db-handler.js +8 -0
- package/dist/browser/runtime/browser/db-handler.js.map +1 -0
- package/dist/browser/runtime/browser/localforage-lru.d.ts +15 -0
- package/dist/browser/runtime/browser/localforage-lru.js +140 -0
- package/dist/browser/runtime/browser/localforage-lru.js.map +1 -0
- package/dist/browser/runtime/browser/lru-storage.d.ts +14 -0
- package/dist/browser/runtime/browser/lru-storage.js +34 -0
- package/dist/browser/runtime/browser/lru-storage.js.map +1 -0
- package/dist/browser/runtime/browser/native-functions.d.ts +3 -0
- package/dist/browser/runtime/browser/native-functions.js +6 -0
- package/dist/browser/runtime/browser/native-functions.js.map +1 -0
- package/dist/browser/runtime/browser/polyfill.d.ts +3 -0
- package/dist/browser/runtime/browser/polyfill.js +37 -0
- package/dist/browser/runtime/browser/polyfill.js.map +1 -0
- package/dist/browser/runtime/browser/setup-kubo-address-rewriter-and-http-router.d.ts +1 -0
- package/dist/browser/runtime/browser/setup-kubo-address-rewriter-and-http-router.js +4 -0
- package/dist/browser/runtime/browser/setup-kubo-address-rewriter-and-http-router.js.map +1 -0
- package/dist/browser/runtime/browser/storage.d.ts +13 -0
- package/dist/browser/runtime/browser/storage.js +37 -0
- package/dist/browser/runtime/browser/storage.js.map +1 -0
- package/dist/browser/runtime/browser/util.d.ts +14 -0
- package/dist/browser/runtime/browser/util.js +61 -0
- package/dist/browser/runtime/browser/util.js.map +1 -0
- package/dist/browser/runtime/node/address-rewriter-db.d.ts +31 -0
- package/dist/browser/runtime/node/address-rewriter-db.js +156 -0
- package/dist/browser/runtime/node/address-rewriter-db.js.map +1 -0
- package/dist/browser/runtime/node/addresses-rewriter-proxy-server.d.ts +45 -0
- package/dist/browser/runtime/node/addresses-rewriter-proxy-server.js +493 -0
- package/dist/browser/runtime/node/addresses-rewriter-proxy-server.js.map +1 -0
- package/dist/browser/runtime/node/community/challenges/exclude/exclude.d.ts +8 -0
- package/dist/browser/runtime/node/community/challenges/exclude/exclude.js +280 -0
- package/dist/browser/runtime/node/community/challenges/exclude/exclude.js.map +1 -0
- package/dist/browser/runtime/node/community/challenges/exclude/index.d.ts +3 -0
- package/dist/browser/runtime/node/community/challenges/exclude/index.js +4 -0
- package/dist/browser/runtime/node/community/challenges/exclude/index.js.map +1 -0
- package/dist/browser/runtime/node/community/challenges/exclude/rate-limiter.d.ts +5 -0
- package/dist/browser/runtime/node/community/challenges/exclude/rate-limiter.js +127 -0
- package/dist/browser/runtime/node/community/challenges/exclude/rate-limiter.js.map +1 -0
- package/dist/browser/runtime/node/community/challenges/exclude/utils.d.ts +13 -0
- package/dist/browser/runtime/node/community/challenges/exclude/utils.js +52 -0
- package/dist/browser/runtime/node/community/challenges/exclude/utils.js.map +1 -0
- package/dist/browser/runtime/node/community/challenges/index.d.ts +32 -0
- package/dist/browser/runtime/node/community/challenges/index.js +307 -0
- package/dist/browser/runtime/node/community/challenges/index.js.map +1 -0
- package/dist/browser/runtime/node/community/challenges/pkc-js-challenges/blacklist.d.ts +5 -0
- package/dist/browser/runtime/node/community/challenges/pkc-js-challenges/blacklist.js +118 -0
- package/dist/browser/runtime/node/community/challenges/pkc-js-challenges/blacklist.js.map +1 -0
- package/dist/browser/runtime/node/community/challenges/pkc-js-challenges/fail.d.ts +5 -0
- package/dist/browser/runtime/node/community/challenges/pkc-js-challenges/fail.js +26 -0
- package/dist/browser/runtime/node/community/challenges/pkc-js-challenges/fail.js.map +1 -0
- package/dist/browser/runtime/node/community/challenges/pkc-js-challenges/publication-match.d.ts +5 -0
- package/dist/browser/runtime/node/community/challenges/pkc-js-challenges/publication-match.js +135 -0
- package/dist/browser/runtime/node/community/challenges/pkc-js-challenges/publication-match.js.map +1 -0
- package/dist/browser/runtime/node/community/challenges/pkc-js-challenges/question.d.ts +5 -0
- package/dist/browser/runtime/node/community/challenges/pkc-js-challenges/question.js +66 -0
- package/dist/browser/runtime/node/community/challenges/pkc-js-challenges/question.js.map +1 -0
- package/dist/browser/runtime/node/community/challenges/pkc-js-challenges/text-math.d.ts +5 -0
- package/dist/browser/runtime/node/community/challenges/pkc-js-challenges/text-math.js +61 -0
- package/dist/browser/runtime/node/community/challenges/pkc-js-challenges/text-math.js.map +1 -0
- package/dist/browser/runtime/node/community/challenges/pkc-js-challenges/whitelist.d.ts +5 -0
- package/dist/browser/runtime/node/community/challenges/pkc-js-challenges/whitelist.js +118 -0
- package/dist/browser/runtime/node/community/challenges/pkc-js-challenges/whitelist.js.map +1 -0
- package/dist/browser/runtime/node/community/db-handler-types.d.ts +19 -0
- package/dist/browser/runtime/node/community/db-handler-types.js +2 -0
- package/dist/browser/runtime/node/community/db-handler-types.js.map +1 -0
- package/dist/browser/runtime/node/community/db-handler.d.ts +226 -0
- package/dist/browser/runtime/node/community/db-handler.js +2462 -0
- package/dist/browser/runtime/node/community/db-handler.js.map +1 -0
- package/dist/browser/runtime/node/community/db-row-parser.d.ts +19 -0
- package/dist/browser/runtime/node/community/db-row-parser.js +40 -0
- package/dist/browser/runtime/node/community/db-row-parser.js.map +1 -0
- package/dist/browser/runtime/node/community/keyv-better-sqlite3.d.ts +68 -0
- package/dist/browser/runtime/node/community/keyv-better-sqlite3.js +251 -0
- package/dist/browser/runtime/node/community/keyv-better-sqlite3.js.map +1 -0
- package/dist/browser/runtime/node/community/local-community.d.ts +129 -0
- package/dist/browser/runtime/node/community/local-community.js +2978 -0
- package/dist/browser/runtime/node/community/local-community.js.map +1 -0
- package/dist/browser/runtime/node/community/page-generator.d.ts +433 -0
- package/dist/browser/runtime/node/community/page-generator.js +441 -0
- package/dist/browser/runtime/node/community/page-generator.js.map +1 -0
- package/dist/browser/runtime/node/lru-storage.d.ts +14 -0
- package/dist/browser/runtime/node/lru-storage.js +40 -0
- package/dist/browser/runtime/node/lru-storage.js.map +1 -0
- package/dist/browser/runtime/node/native-functions.d.ts +3 -0
- package/dist/browser/runtime/node/native-functions.js +7 -0
- package/dist/browser/runtime/node/native-functions.js.map +1 -0
- package/dist/browser/runtime/node/polyfill.d.ts +3 -0
- package/dist/browser/runtime/node/polyfill.js +20 -0
- package/dist/browser/runtime/node/polyfill.js.map +1 -0
- package/dist/browser/runtime/node/setup-kubo-address-rewriter-and-http-router.d.ts +4 -0
- package/dist/browser/runtime/node/setup-kubo-address-rewriter-and-http-router.js +240 -0
- package/dist/browser/runtime/node/setup-kubo-address-rewriter-and-http-router.js.map +1 -0
- package/dist/browser/runtime/node/sqlite-lru-cache.d.ts +52 -0
- package/dist/browser/runtime/node/sqlite-lru-cache.js +127 -0
- package/dist/browser/runtime/node/sqlite-lru-cache.js.map +1 -0
- package/dist/browser/runtime/node/storage.d.ts +14 -0
- package/dist/browser/runtime/node/storage.js +52 -0
- package/dist/browser/runtime/node/storage.js.map +1 -0
- package/dist/browser/runtime/node/test/helpers/hanging-runner.d.ts +1 -0
- package/dist/browser/runtime/node/test/helpers/hanging-runner.js +157 -0
- package/dist/browser/runtime/node/test/helpers/hanging-runner.js.map +1 -0
- package/dist/browser/runtime/node/test/helpers/run-hanging-node.d.ts +7 -0
- package/dist/browser/runtime/node/test/helpers/run-hanging-node.js +68 -0
- package/dist/browser/runtime/node/test/helpers/run-hanging-node.js.map +1 -0
- package/dist/browser/runtime/node/test/mock-http-router.d.ts +54 -0
- package/dist/browser/runtime/node/test/mock-http-router.js +397 -0
- package/dist/browser/runtime/node/test/mock-http-router.js.map +1 -0
- package/dist/browser/runtime/node/util.d.ts +43 -0
- package/dist/browser/runtime/node/util.js +384 -0
- package/dist/browser/runtime/node/util.js.map +1 -0
- package/dist/browser/schema/schema-util.d.ts +2751 -0
- package/dist/browser/schema/schema-util.js +562 -0
- package/dist/browser/schema/schema-util.js.map +1 -0
- package/dist/browser/schema/schema.d.ts +237 -0
- package/dist/browser/schema/schema.js +128 -0
- package/dist/browser/schema/schema.js.map +1 -0
- package/dist/browser/schema.d.ts +1142 -0
- package/dist/browser/schema.js +104 -0
- package/dist/browser/schema.js.map +1 -0
- package/dist/browser/signer/constants.d.ts +2 -0
- package/dist/browser/signer/constants.js +3 -0
- package/dist/browser/signer/constants.js.map +1 -0
- package/dist/browser/signer/encryption.d.ts +21 -0
- package/dist/browser/signer/encryption.js +122 -0
- package/dist/browser/signer/encryption.js.map +1 -0
- package/dist/browser/signer/index.d.ts +21 -0
- package/dist/browser/signer/index.js +49 -0
- package/dist/browser/signer/index.js.map +1 -0
- package/dist/browser/signer/signatures.d.ts +200 -0
- package/dist/browser/signer/signatures.js +594 -0
- package/dist/browser/signer/signatures.js.map +1 -0
- package/dist/browser/signer/types.d.ts +20 -0
- package/dist/browser/signer/types.js +2 -0
- package/dist/browser/signer/types.js.map +1 -0
- package/dist/browser/signer/util.d.ts +14 -0
- package/dist/browser/signer/util.js +156 -0
- package/dist/browser/signer/util.js.map +1 -0
- package/dist/browser/stats.d.ts +15 -0
- package/dist/browser/stats.js +64 -0
- package/dist/browser/stats.js.map +1 -0
- package/dist/browser/test/mock-ipfs-client.d.ts +34 -0
- package/dist/browser/test/mock-ipfs-client.js +208 -0
- package/dist/browser/test/mock-ipfs-client.js.map +1 -0
- package/dist/browser/test/node/hanging-test/scenarios/comment-publish-pending.scenario.d.ts +8 -0
- package/dist/browser/test/node/hanging-test/scenarios/comment-publish-pending.scenario.js +21 -0
- package/dist/browser/test/node/hanging-test/scenarios/comment-publish-pending.scenario.js.map +1 -0
- package/dist/browser/test/node/hanging-test/scenarios/comment-publish.scenario.d.ts +8 -0
- package/dist/browser/test/node/hanging-test/scenarios/comment-publish.scenario.js +19 -0
- package/dist/browser/test/node/hanging-test/scenarios/comment-publish.scenario.js.map +1 -0
- package/dist/browser/test/node/hanging-test/scenarios/comment-update.scenario.d.ts +8 -0
- package/dist/browser/test/node/hanging-test/scenarios/comment-update.scenario.js +22 -0
- package/dist/browser/test/node/hanging-test/scenarios/comment-update.scenario.js.map +1 -0
- package/dist/browser/test/node/hanging-test/scenarios/community-start.scenario.d.ts +8 -0
- package/dist/browser/test/node/hanging-test/scenarios/community-start.scenario.js +23 -0
- package/dist/browser/test/node/hanging-test/scenarios/community-start.scenario.js.map +1 -0
- package/dist/browser/test/node/hanging-test/scenarios/community-update.scenario.d.ts +8 -0
- package/dist/browser/test/node/hanging-test/scenarios/community-update.scenario.js +21 -0
- package/dist/browser/test/node/hanging-test/scenarios/community-update.scenario.js.map +1 -0
- package/dist/browser/test/node/hanging-test/scenarios/destroy-only.scenario.d.ts +7 -0
- package/dist/browser/test/node/hanging-test/scenarios/destroy-only.scenario.js +15 -0
- package/dist/browser/test/node/hanging-test/scenarios/destroy-only.scenario.js.map +1 -0
- package/dist/browser/test/node/hanging-test/scenarios/hanging-test-util.d.ts +30 -0
- package/dist/browser/test/node/hanging-test/scenarios/hanging-test-util.js +46 -0
- package/dist/browser/test/node/hanging-test/scenarios/hanging-test-util.js.map +1 -0
- package/dist/browser/test/test-util.d.ts +1019 -0
- package/dist/browser/test/test-util.js +1886 -0
- package/dist/browser/test/test-util.js.map +1 -0
- package/dist/browser/types.d.ts +165 -0
- package/dist/browser/types.js +2 -0
- package/dist/browser/types.js.map +1 -0
- package/dist/browser/util/inflight-fetch-manager.d.ts +11 -0
- package/dist/browser/util/inflight-fetch-manager.js +41 -0
- package/dist/browser/util/inflight-fetch-manager.js.map +1 -0
- package/dist/browser/util.d.ts +120 -0
- package/dist/browser/util.js +816 -0
- package/dist/browser/util.js.map +1 -0
- package/dist/browser/version.d.ts +7 -0
- package/dist/browser/version.js +12 -0
- package/dist/browser/version.js.map +1 -0
- package/dist/browser/zod-error-map.d.ts +1 -0
- package/dist/browser/zod-error-map.js +10 -0
- package/dist/browser/zod-error-map.js.map +1 -0
- package/dist/node/challenges.d.ts +1 -0
- package/dist/node/challenges.js +2 -0
- package/dist/node/challenges.js.map +1 -0
- package/dist/node/clients/base-client-manager.d.ts +126 -0
- package/dist/node/clients/base-client-manager.js +673 -0
- package/dist/node/clients/base-client-manager.js.map +1 -0
- package/dist/node/clients/name-resolver-client.d.ts +8 -0
- package/dist/node/clients/name-resolver-client.js +10 -0
- package/dist/node/clients/name-resolver-client.js.map +1 -0
- package/dist/node/clients/pkc-typed-emitter.d.ts +9 -0
- package/dist/node/clients/pkc-typed-emitter.js +52 -0
- package/dist/node/clients/pkc-typed-emitter.js.map +1 -0
- package/dist/node/clients/rpc-client/decode-rpc-response-util.d.ts +8 -0
- package/dist/node/clients/rpc-client/decode-rpc-response-util.js +53 -0
- package/dist/node/clients/rpc-client/decode-rpc-response-util.js.map +1 -0
- package/dist/node/clients/rpc-client/pkc-rpc-client.d.ts +68 -0
- package/dist/node/clients/rpc-client/pkc-rpc-client.js +404 -0
- package/dist/node/clients/rpc-client/pkc-rpc-client.js.map +1 -0
- package/dist/node/clients/rpc-client/rpc-schema-util.d.ts +147 -0
- package/dist/node/clients/rpc-client/rpc-schema-util.js +11 -0
- package/dist/node/clients/rpc-client/rpc-schema-util.js.map +1 -0
- package/dist/node/clients/rpc-client/schema.d.ts +433 -0
- package/dist/node/clients/rpc-client/schema.js +49 -0
- package/dist/node/clients/rpc-client/schema.js.map +1 -0
- package/dist/node/clients/rpc-client/types.d.ts +8 -0
- package/dist/node/clients/rpc-client/types.js +2 -0
- package/dist/node/clients/rpc-client/types.js.map +1 -0
- package/dist/node/community/community-client-manager.d.ts +60 -0
- package/dist/node/community/community-client-manager.js +717 -0
- package/dist/node/community/community-client-manager.js.map +1 -0
- package/dist/node/community/community-clients.d.ts +18 -0
- package/dist/node/community/community-clients.js +12 -0
- package/dist/node/community/community-clients.js.map +1 -0
- package/dist/node/community/community-wire.d.ts +20 -0
- package/dist/node/community/community-wire.js +38 -0
- package/dist/node/community/community-wire.js.map +1 -0
- package/dist/node/community/remote-community.d.ts +110 -0
- package/dist/node/community/remote-community.js +555 -0
- package/dist/node/community/remote-community.js.map +1 -0
- package/dist/node/community/rpc-local-community.d.ts +41 -0
- package/dist/node/community/rpc-local-community.js +289 -0
- package/dist/node/community/rpc-local-community.js.map +1 -0
- package/dist/node/community/rpc-remote-community.d.ts +18 -0
- package/dist/node/community/rpc-remote-community.js +286 -0
- package/dist/node/community/rpc-remote-community.js.map +1 -0
- package/dist/node/community/schema.d.ts +4217 -0
- package/dist/node/community/schema.js +289 -0
- package/dist/node/community/schema.js.map +1 -0
- package/dist/node/community/types.d.ts +135 -0
- package/dist/node/community/types.js +2 -0
- package/dist/node/community/types.js.map +1 -0
- package/dist/node/constants.d.ts +6 -0
- package/dist/node/constants.js +9 -0
- package/dist/node/constants.js.map +1 -0
- package/dist/node/decorator-util.d.ts +1 -0
- package/dist/node/decorator-util.js +35 -0
- package/dist/node/decorator-util.js.map +1 -0
- package/dist/node/errors.d.ts +343 -0
- package/dist/node/errors.js +358 -0
- package/dist/node/errors.js.map +1 -0
- package/dist/node/general-util/limited-set.d.ts +15 -0
- package/dist/node/general-util/limited-set.js +66 -0
- package/dist/node/general-util/limited-set.js.map +1 -0
- package/dist/node/generated-version.d.ts +1 -0
- package/dist/node/generated-version.js +3 -0
- package/dist/node/generated-version.js.map +1 -0
- package/dist/node/generic-state-client.d.ts +6 -0
- package/dist/node/generic-state-client.js +11 -0
- package/dist/node/generic-state-client.js.map +1 -0
- package/dist/node/helia/helia-for-pkc.d.ts +3 -0
- package/dist/node/helia/helia-for-pkc.js +255 -0
- package/dist/node/helia/helia-for-pkc.js.map +1 -0
- package/dist/node/helia/ipns-over-pubsub-with-fetch.d.ts +36 -0
- package/dist/node/helia/ipns-over-pubsub-with-fetch.js +229 -0
- package/dist/node/helia/ipns-over-pubsub-with-fetch.js.map +1 -0
- package/dist/node/helia/libp2pjsClient.d.ts +27 -0
- package/dist/node/helia/libp2pjsClient.js +15 -0
- package/dist/node/helia/libp2pjsClient.js.map +1 -0
- package/dist/node/helia/types.d.ts +19 -0
- package/dist/node/helia/types.js +2 -0
- package/dist/node/helia/types.js.map +1 -0
- package/dist/node/helia/util.d.ts +13 -0
- package/dist/node/helia/util.js +98 -0
- package/dist/node/helia/util.js.map +1 -0
- package/dist/node/index.d.ts +244 -0
- package/dist/node/index.js +36 -0
- package/dist/node/index.js.map +1 -0
- package/dist/node/logger.d.ts +12 -0
- package/dist/node/logger.js +11 -0
- package/dist/node/logger.js.map +1 -0
- package/dist/node/pages/pages-client-manager.d.ts +159 -0
- package/dist/node/pages/pages-client-manager.js +334 -0
- package/dist/node/pages/pages-client-manager.js.map +1 -0
- package/dist/node/pages/pages-clients.d.ts +11 -0
- package/dist/node/pages/pages-clients.js +10 -0
- package/dist/node/pages/pages-clients.js.map +1 -0
- package/dist/node/pages/pages.d.ts +107 -0
- package/dist/node/pages/pages.js +262 -0
- package/dist/node/pages/pages.js.map +1 -0
- package/dist/node/pages/schema-util.d.ts +3 -0
- package/dist/node/pages/schema-util.js +3 -0
- package/dist/node/pages/schema-util.js.map +1 -0
- package/dist/node/pages/schema.d.ts +719 -0
- package/dist/node/pages/schema.js +32 -0
- package/dist/node/pages/schema.js.map +1 -0
- package/dist/node/pages/types.d.ts +44 -0
- package/dist/node/pages/types.js +2 -0
- package/dist/node/pages/types.js.map +1 -0
- package/dist/node/pages/util.d.ts +56 -0
- package/dist/node/pages/util.js +446 -0
- package/dist/node/pages/util.js.map +1 -0
- package/dist/node/pkc/pkc-client-manager.d.ts +44 -0
- package/dist/node/pkc/pkc-client-manager.js +156 -0
- package/dist/node/pkc/pkc-client-manager.js.map +1 -0
- package/dist/node/pkc/pkc-clients.d.ts +11 -0
- package/dist/node/pkc/pkc-clients.js +8 -0
- package/dist/node/pkc/pkc-clients.js.map +1 -0
- package/dist/node/pkc/pkc-with-rpc-client.d.ts +19 -0
- package/dist/node/pkc/pkc-with-rpc-client.js +128 -0
- package/dist/node/pkc/pkc-with-rpc-client.js.map +1 -0
- package/dist/node/pkc/pkc.d.ts +137 -0
- package/dist/node/pkc/pkc.js +888 -0
- package/dist/node/pkc/pkc.js.map +1 -0
- package/dist/node/pkc/tracked-instance-registry-util.d.ts +44 -0
- package/dist/node/pkc/tracked-instance-registry-util.js +106 -0
- package/dist/node/pkc/tracked-instance-registry-util.js.map +1 -0
- package/dist/node/pkc/tracked-instance-registry.d.ts +18 -0
- package/dist/node/pkc/tracked-instance-registry.js +134 -0
- package/dist/node/pkc/tracked-instance-registry.js.map +1 -0
- package/dist/node/pkc-error.d.ts +65 -0
- package/dist/node/pkc-error.js +137 -0
- package/dist/node/pkc-error.js.map +1 -0
- package/dist/node/publications/comment/comment-client-manager.d.ts +86 -0
- package/dist/node/publications/comment/comment-client-manager.js +908 -0
- package/dist/node/publications/comment/comment-client-manager.js.map +1 -0
- package/dist/node/publications/comment/comment-clients.d.ts +19 -0
- package/dist/node/publications/comment/comment-clients.js +12 -0
- package/dist/node/publications/comment/comment-clients.js.map +1 -0
- package/dist/node/publications/comment/comment-util.d.ts +10 -0
- package/dist/node/publications/comment/comment-util.js +202 -0
- package/dist/node/publications/comment/comment-util.js.map +1 -0
- package/dist/node/publications/comment/comment.d.ts +147 -0
- package/dist/node/publications/comment/comment.js +1044 -0
- package/dist/node/publications/comment/comment.js.map +1 -0
- package/dist/node/publications/comment/schema.d.ts +1237 -0
- package/dist/node/publications/comment/schema.js +184 -0
- package/dist/node/publications/comment/schema.js.map +1 -0
- package/dist/node/publications/comment/types.d.ts +100 -0
- package/dist/node/publications/comment/types.js +2 -0
- package/dist/node/publications/comment/types.js.map +1 -0
- package/dist/node/publications/comment-edit/comment-edit.d.ts +41 -0
- package/dist/node/publications/comment-edit/comment-edit.js +63 -0
- package/dist/node/publications/comment-edit/comment-edit.js.map +1 -0
- package/dist/node/publications/comment-edit/schema.d.ts +295 -0
- package/dist/node/publications/comment-edit/schema.js +55 -0
- package/dist/node/publications/comment-edit/schema.js.map +1 -0
- package/dist/node/publications/comment-edit/types.d.ts +25 -0
- package/dist/node/publications/comment-edit/types.js +2 -0
- package/dist/node/publications/comment-edit/types.js.map +1 -0
- package/dist/node/publications/comment-moderation/comment-moderation.d.ts +36 -0
- package/dist/node/publications/comment-moderation/comment-moderation.js +53 -0
- package/dist/node/publications/comment-moderation/comment-moderation.js.map +1 -0
- package/dist/node/publications/comment-moderation/schema.d.ts +315 -0
- package/dist/node/publications/comment-moderation/schema.js +62 -0
- package/dist/node/publications/comment-moderation/schema.js.map +1 -0
- package/dist/node/publications/comment-moderation/types.d.ts +22 -0
- package/dist/node/publications/comment-moderation/types.js +2 -0
- package/dist/node/publications/comment-moderation/types.js.map +1 -0
- package/dist/node/publications/community-edit/community-edit.d.ts +35 -0
- package/dist/node/publications/community-edit/community-edit.js +50 -0
- package/dist/node/publications/community-edit/community-edit.js.map +1 -0
- package/dist/node/publications/community-edit/schema.d.ts +467 -0
- package/dist/node/publications/community-edit/schema.js +36 -0
- package/dist/node/publications/community-edit/schema.js.map +1 -0
- package/dist/node/publications/community-edit/types.d.ts +19 -0
- package/dist/node/publications/community-edit/types.js +2 -0
- package/dist/node/publications/community-edit/types.js.map +1 -0
- package/dist/node/publications/publication-author.d.ts +22 -0
- package/dist/node/publications/publication-author.js +66 -0
- package/dist/node/publications/publication-author.js.map +1 -0
- package/dist/node/publications/publication-client-manager.d.ts +62 -0
- package/dist/node/publications/publication-client-manager.js +257 -0
- package/dist/node/publications/publication-client-manager.js.map +1 -0
- package/dist/node/publications/publication-clients.d.ts +19 -0
- package/dist/node/publications/publication-clients.js +12 -0
- package/dist/node/publications/publication-clients.js.map +1 -0
- package/dist/node/publications/publication-community.d.ts +55 -0
- package/dist/node/publications/publication-community.js +87 -0
- package/dist/node/publications/publication-community.js.map +1 -0
- package/dist/node/publications/publication.d.ts +120 -0
- package/dist/node/publications/publication.js +950 -0
- package/dist/node/publications/publication.js.map +1 -0
- package/dist/node/publications/types.d.ts +26 -0
- package/dist/node/publications/types.js +2 -0
- package/dist/node/publications/types.js.map +1 -0
- package/dist/node/publications/vote/schema.d.ts +150 -0
- package/dist/node/publications/vote/schema.js +44 -0
- package/dist/node/publications/vote/schema.js.map +1 -0
- package/dist/node/publications/vote/types.d.ts +21 -0
- package/dist/node/publications/vote/types.js +2 -0
- package/dist/node/publications/vote/types.js.map +1 -0
- package/dist/node/publications/vote/vote.d.ts +36 -0
- package/dist/node/publications/vote/vote.js +49 -0
- package/dist/node/publications/vote/vote.js.map +1 -0
- package/dist/node/pubsub-messages/schema.d.ts +964 -0
- package/dist/node/pubsub-messages/schema.js +98 -0
- package/dist/node/pubsub-messages/schema.js.map +1 -0
- package/dist/node/pubsub-messages/types.d.ts +81 -0
- package/dist/node/pubsub-messages/types.js +2 -0
- package/dist/node/pubsub-messages/types.js.map +1 -0
- package/dist/node/rpc/src/index.d.ts +483 -0
- package/dist/node/rpc/src/index.js +1267 -0
- package/dist/node/rpc/src/index.js.map +1 -0
- package/dist/node/rpc/src/json-rpc-util.d.ts +1 -0
- package/dist/node/rpc/src/json-rpc-util.js +19 -0
- package/dist/node/rpc/src/json-rpc-util.js.map +1 -0
- package/dist/node/rpc/src/lib/pkc-js/index.d.ts +132 -0
- package/dist/node/rpc/src/lib/pkc-js/index.js +29 -0
- package/dist/node/rpc/src/lib/pkc-js/index.js.map +1 -0
- package/dist/node/rpc/src/lib/pkc-js/pkc-js-mock.d.ts +1 -0
- package/dist/node/rpc/src/lib/pkc-js/pkc-js-mock.js +472 -0
- package/dist/node/rpc/src/lib/pkc-js/pkc-js-mock.js.map +1 -0
- package/dist/node/rpc/src/schema.d.ts +843 -0
- package/dist/node/rpc/src/schema.js +28 -0
- package/dist/node/rpc/src/schema.js.map +1 -0
- package/dist/node/rpc/src/types.d.ts +24 -0
- package/dist/node/rpc/src/types.js +2 -0
- package/dist/node/rpc/src/types.js.map +1 -0
- package/dist/node/rpc/src/utils.d.ts +7 -0
- package/dist/node/rpc/src/utils.js +58 -0
- package/dist/node/rpc/src/utils.js.map +1 -0
- package/dist/node/runtime/browser/community/challenges/index.d.ts +6 -0
- package/dist/node/runtime/browser/community/challenges/index.js +7 -0
- package/dist/node/runtime/browser/community/challenges/index.js.map +1 -0
- package/dist/node/runtime/browser/community/local-community.d.ts +3 -0
- package/dist/node/runtime/browser/community/local-community.js +6 -0
- package/dist/node/runtime/browser/community/local-community.js.map +1 -0
- package/dist/node/runtime/browser/db-handler.d.ts +4 -0
- package/dist/node/runtime/browser/db-handler.js +8 -0
- package/dist/node/runtime/browser/db-handler.js.map +1 -0
- package/dist/node/runtime/browser/localforage-lru.d.ts +15 -0
- package/dist/node/runtime/browser/localforage-lru.js +140 -0
- package/dist/node/runtime/browser/localforage-lru.js.map +1 -0
- package/dist/node/runtime/browser/lru-storage.d.ts +14 -0
- package/dist/node/runtime/browser/lru-storage.js +34 -0
- package/dist/node/runtime/browser/lru-storage.js.map +1 -0
- package/dist/node/runtime/browser/native-functions.d.ts +3 -0
- package/dist/node/runtime/browser/native-functions.js +6 -0
- package/dist/node/runtime/browser/native-functions.js.map +1 -0
- package/dist/node/runtime/browser/polyfill.d.ts +3 -0
- package/dist/node/runtime/browser/polyfill.js +37 -0
- package/dist/node/runtime/browser/polyfill.js.map +1 -0
- package/dist/node/runtime/browser/setup-kubo-address-rewriter-and-http-router.d.ts +1 -0
- package/dist/node/runtime/browser/setup-kubo-address-rewriter-and-http-router.js +4 -0
- package/dist/node/runtime/browser/setup-kubo-address-rewriter-and-http-router.js.map +1 -0
- package/dist/node/runtime/browser/storage.d.ts +13 -0
- package/dist/node/runtime/browser/storage.js +37 -0
- package/dist/node/runtime/browser/storage.js.map +1 -0
- package/dist/node/runtime/browser/util.d.ts +14 -0
- package/dist/node/runtime/browser/util.js +61 -0
- package/dist/node/runtime/browser/util.js.map +1 -0
- package/dist/node/runtime/node/address-rewriter-db.d.ts +31 -0
- package/dist/node/runtime/node/address-rewriter-db.js +156 -0
- package/dist/node/runtime/node/address-rewriter-db.js.map +1 -0
- package/dist/node/runtime/node/addresses-rewriter-proxy-server.d.ts +45 -0
- package/dist/node/runtime/node/addresses-rewriter-proxy-server.js +493 -0
- package/dist/node/runtime/node/addresses-rewriter-proxy-server.js.map +1 -0
- package/dist/node/runtime/node/community/challenges/exclude/exclude.d.ts +8 -0
- package/dist/node/runtime/node/community/challenges/exclude/exclude.js +280 -0
- package/dist/node/runtime/node/community/challenges/exclude/exclude.js.map +1 -0
- package/dist/node/runtime/node/community/challenges/exclude/index.d.ts +3 -0
- package/dist/node/runtime/node/community/challenges/exclude/index.js +4 -0
- package/dist/node/runtime/node/community/challenges/exclude/index.js.map +1 -0
- package/dist/node/runtime/node/community/challenges/exclude/rate-limiter.d.ts +5 -0
- package/dist/node/runtime/node/community/challenges/exclude/rate-limiter.js +127 -0
- package/dist/node/runtime/node/community/challenges/exclude/rate-limiter.js.map +1 -0
- package/dist/node/runtime/node/community/challenges/exclude/utils.d.ts +13 -0
- package/dist/node/runtime/node/community/challenges/exclude/utils.js +52 -0
- package/dist/node/runtime/node/community/challenges/exclude/utils.js.map +1 -0
- package/dist/node/runtime/node/community/challenges/index.d.ts +32 -0
- package/dist/node/runtime/node/community/challenges/index.js +307 -0
- package/dist/node/runtime/node/community/challenges/index.js.map +1 -0
- package/dist/node/runtime/node/community/challenges/pkc-js-challenges/blacklist.d.ts +5 -0
- package/dist/node/runtime/node/community/challenges/pkc-js-challenges/blacklist.js +118 -0
- package/dist/node/runtime/node/community/challenges/pkc-js-challenges/blacklist.js.map +1 -0
- package/dist/node/runtime/node/community/challenges/pkc-js-challenges/fail.d.ts +5 -0
- package/dist/node/runtime/node/community/challenges/pkc-js-challenges/fail.js +26 -0
- package/dist/node/runtime/node/community/challenges/pkc-js-challenges/fail.js.map +1 -0
- package/dist/node/runtime/node/community/challenges/pkc-js-challenges/publication-match.d.ts +5 -0
- package/dist/node/runtime/node/community/challenges/pkc-js-challenges/publication-match.js +135 -0
- package/dist/node/runtime/node/community/challenges/pkc-js-challenges/publication-match.js.map +1 -0
- package/dist/node/runtime/node/community/challenges/pkc-js-challenges/question.d.ts +5 -0
- package/dist/node/runtime/node/community/challenges/pkc-js-challenges/question.js +66 -0
- package/dist/node/runtime/node/community/challenges/pkc-js-challenges/question.js.map +1 -0
- package/dist/node/runtime/node/community/challenges/pkc-js-challenges/text-math.d.ts +5 -0
- package/dist/node/runtime/node/community/challenges/pkc-js-challenges/text-math.js +61 -0
- package/dist/node/runtime/node/community/challenges/pkc-js-challenges/text-math.js.map +1 -0
- package/dist/node/runtime/node/community/challenges/pkc-js-challenges/whitelist.d.ts +5 -0
- package/dist/node/runtime/node/community/challenges/pkc-js-challenges/whitelist.js +118 -0
- package/dist/node/runtime/node/community/challenges/pkc-js-challenges/whitelist.js.map +1 -0
- package/dist/node/runtime/node/community/db-handler-types.d.ts +19 -0
- package/dist/node/runtime/node/community/db-handler-types.js +2 -0
- package/dist/node/runtime/node/community/db-handler-types.js.map +1 -0
- package/dist/node/runtime/node/community/db-handler.d.ts +226 -0
- package/dist/node/runtime/node/community/db-handler.js +2462 -0
- package/dist/node/runtime/node/community/db-handler.js.map +1 -0
- package/dist/node/runtime/node/community/db-row-parser.d.ts +19 -0
- package/dist/node/runtime/node/community/db-row-parser.js +40 -0
- package/dist/node/runtime/node/community/db-row-parser.js.map +1 -0
- package/dist/node/runtime/node/community/keyv-better-sqlite3.d.ts +68 -0
- package/dist/node/runtime/node/community/keyv-better-sqlite3.js +251 -0
- package/dist/node/runtime/node/community/keyv-better-sqlite3.js.map +1 -0
- package/dist/node/runtime/node/community/local-community.d.ts +129 -0
- package/dist/node/runtime/node/community/local-community.js +2978 -0
- package/dist/node/runtime/node/community/local-community.js.map +1 -0
- package/dist/node/runtime/node/community/page-generator.d.ts +433 -0
- package/dist/node/runtime/node/community/page-generator.js +441 -0
- package/dist/node/runtime/node/community/page-generator.js.map +1 -0
- package/dist/node/runtime/node/lru-storage.d.ts +14 -0
- package/dist/node/runtime/node/lru-storage.js +40 -0
- package/dist/node/runtime/node/lru-storage.js.map +1 -0
- package/dist/node/runtime/node/native-functions.d.ts +3 -0
- package/dist/node/runtime/node/native-functions.js +7 -0
- package/dist/node/runtime/node/native-functions.js.map +1 -0
- package/dist/node/runtime/node/polyfill.d.ts +3 -0
- package/dist/node/runtime/node/polyfill.js +20 -0
- package/dist/node/runtime/node/polyfill.js.map +1 -0
- package/dist/node/runtime/node/setup-kubo-address-rewriter-and-http-router.d.ts +4 -0
- package/dist/node/runtime/node/setup-kubo-address-rewriter-and-http-router.js +240 -0
- package/dist/node/runtime/node/setup-kubo-address-rewriter-and-http-router.js.map +1 -0
- package/dist/node/runtime/node/sqlite-lru-cache.d.ts +52 -0
- package/dist/node/runtime/node/sqlite-lru-cache.js +127 -0
- package/dist/node/runtime/node/sqlite-lru-cache.js.map +1 -0
- package/dist/node/runtime/node/storage.d.ts +14 -0
- package/dist/node/runtime/node/storage.js +52 -0
- package/dist/node/runtime/node/storage.js.map +1 -0
- package/dist/node/runtime/node/test/helpers/hanging-runner.d.ts +1 -0
- package/dist/node/runtime/node/test/helpers/hanging-runner.js +157 -0
- package/dist/node/runtime/node/test/helpers/hanging-runner.js.map +1 -0
- package/dist/node/runtime/node/test/helpers/run-hanging-node.d.ts +7 -0
- package/dist/node/runtime/node/test/helpers/run-hanging-node.js +68 -0
- package/dist/node/runtime/node/test/helpers/run-hanging-node.js.map +1 -0
- package/dist/node/runtime/node/test/mock-http-router.d.ts +54 -0
- package/dist/node/runtime/node/test/mock-http-router.js +397 -0
- package/dist/node/runtime/node/test/mock-http-router.js.map +1 -0
- package/dist/node/runtime/node/util.d.ts +43 -0
- package/dist/node/runtime/node/util.js +384 -0
- package/dist/node/runtime/node/util.js.map +1 -0
- package/dist/node/schema/schema-util.d.ts +2751 -0
- package/dist/node/schema/schema-util.js +562 -0
- package/dist/node/schema/schema-util.js.map +1 -0
- package/dist/node/schema/schema.d.ts +237 -0
- package/dist/node/schema/schema.js +128 -0
- package/dist/node/schema/schema.js.map +1 -0
- package/dist/node/schema.d.ts +1142 -0
- package/dist/node/schema.js +104 -0
- package/dist/node/schema.js.map +1 -0
- package/dist/node/signer/constants.d.ts +2 -0
- package/dist/node/signer/constants.js +3 -0
- package/dist/node/signer/constants.js.map +1 -0
- package/dist/node/signer/encryption.d.ts +21 -0
- package/dist/node/signer/encryption.js +122 -0
- package/dist/node/signer/encryption.js.map +1 -0
- package/dist/node/signer/index.d.ts +21 -0
- package/dist/node/signer/index.js +49 -0
- package/dist/node/signer/index.js.map +1 -0
- package/dist/node/signer/signatures.d.ts +200 -0
- package/dist/node/signer/signatures.js +594 -0
- package/dist/node/signer/signatures.js.map +1 -0
- package/dist/node/signer/types.d.ts +20 -0
- package/dist/node/signer/types.js +2 -0
- package/dist/node/signer/types.js.map +1 -0
- package/dist/node/signer/util.d.ts +14 -0
- package/dist/node/signer/util.js +156 -0
- package/dist/node/signer/util.js.map +1 -0
- package/dist/node/stats.d.ts +15 -0
- package/dist/node/stats.js +64 -0
- package/dist/node/stats.js.map +1 -0
- package/dist/node/test/mock-ipfs-client.d.ts +34 -0
- package/dist/node/test/mock-ipfs-client.js +208 -0
- package/dist/node/test/mock-ipfs-client.js.map +1 -0
- package/dist/node/test/node/hanging-test/scenarios/comment-publish-pending.scenario.d.ts +8 -0
- package/dist/node/test/node/hanging-test/scenarios/comment-publish-pending.scenario.js +21 -0
- package/dist/node/test/node/hanging-test/scenarios/comment-publish-pending.scenario.js.map +1 -0
- package/dist/node/test/node/hanging-test/scenarios/comment-publish.scenario.d.ts +8 -0
- package/dist/node/test/node/hanging-test/scenarios/comment-publish.scenario.js +19 -0
- package/dist/node/test/node/hanging-test/scenarios/comment-publish.scenario.js.map +1 -0
- package/dist/node/test/node/hanging-test/scenarios/comment-update.scenario.d.ts +8 -0
- package/dist/node/test/node/hanging-test/scenarios/comment-update.scenario.js +22 -0
- package/dist/node/test/node/hanging-test/scenarios/comment-update.scenario.js.map +1 -0
- package/dist/node/test/node/hanging-test/scenarios/community-start.scenario.d.ts +8 -0
- package/dist/node/test/node/hanging-test/scenarios/community-start.scenario.js +23 -0
- package/dist/node/test/node/hanging-test/scenarios/community-start.scenario.js.map +1 -0
- package/dist/node/test/node/hanging-test/scenarios/community-update.scenario.d.ts +8 -0
- package/dist/node/test/node/hanging-test/scenarios/community-update.scenario.js +21 -0
- package/dist/node/test/node/hanging-test/scenarios/community-update.scenario.js.map +1 -0
- package/dist/node/test/node/hanging-test/scenarios/destroy-only.scenario.d.ts +7 -0
- package/dist/node/test/node/hanging-test/scenarios/destroy-only.scenario.js +15 -0
- package/dist/node/test/node/hanging-test/scenarios/destroy-only.scenario.js.map +1 -0
- package/dist/node/test/node/hanging-test/scenarios/hanging-test-util.d.ts +30 -0
- package/dist/node/test/node/hanging-test/scenarios/hanging-test-util.js +46 -0
- package/dist/node/test/node/hanging-test/scenarios/hanging-test-util.js.map +1 -0
- package/dist/node/test/test-util.d.ts +1019 -0
- package/dist/node/test/test-util.js +1886 -0
- package/dist/node/test/test-util.js.map +1 -0
- package/dist/node/types.d.ts +165 -0
- package/dist/node/types.js +2 -0
- package/dist/node/types.js.map +1 -0
- package/dist/node/util/inflight-fetch-manager.d.ts +11 -0
- package/dist/node/util/inflight-fetch-manager.js +41 -0
- package/dist/node/util/inflight-fetch-manager.js.map +1 -0
- package/dist/node/util.d.ts +120 -0
- package/dist/node/util.js +816 -0
- package/dist/node/util.js.map +1 -0
- package/dist/node/version.d.ts +7 -0
- package/dist/node/version.js +12 -0
- package/dist/node/version.js.map +1 -0
- package/dist/node/zod-error-map.d.ts +1 -0
- package/dist/node/zod-error-map.js +10 -0
- package/dist/node/zod-error-map.js.map +1 -0
- package/package.json +212 -0
|
@@ -0,0 +1,441 @@
|
|
|
1
|
+
import { calculateStringSizeSameAsIpfsAddCidV0, hideClassPrivateProps, retryKuboIpfsAddAndProvide, timestamp } from "../../../util.js";
|
|
2
|
+
import assert from "assert";
|
|
3
|
+
import * as remeda from "remeda";
|
|
4
|
+
import { stringify as deterministicStringify } from "safe-stable-stringify";
|
|
5
|
+
import env from "../../../version.js";
|
|
6
|
+
import { POSTS_SORT_TYPES, POST_REPLIES_SORT_TYPES, TIMEFRAMES_TO_SECONDS, REPLY_REPLIES_SORT_TYPES } from "../../../pages/util.js";
|
|
7
|
+
import { PKCError } from "../../../pkc-error.js";
|
|
8
|
+
import Logger from "../../../logger.js";
|
|
9
|
+
import { cleanUpBeforePublishing, signCommentUpdateForChallengeVerification } from "../../../signer/signatures.js";
|
|
10
|
+
import { deriveCommentIpfsFromCommentTableRow } from "../util.js";
|
|
11
|
+
import { sha256 } from "js-sha256";
|
|
12
|
+
async function getSerializedCommentsSize(comments, hasNextCid) {
|
|
13
|
+
const payload = hasNextCid ? { comments, nextCid: "QmXsYKgNH7XoZXdLko5uDvtWSRNE2AXuQ4u8KxVpCacrZx" } : { comments };
|
|
14
|
+
const serializedPayload = JSON.stringify(payload);
|
|
15
|
+
return await calculateStringSizeSameAsIpfsAddCidV0(serializedPayload);
|
|
16
|
+
}
|
|
17
|
+
export class PageGenerator {
|
|
18
|
+
constructor(community) {
|
|
19
|
+
this._community = community;
|
|
20
|
+
hideClassPrivateProps(this);
|
|
21
|
+
}
|
|
22
|
+
async addQueuedCommentChunksToIpfs(chunks, sortName = "pendingApproval") {
|
|
23
|
+
const ipfsClient = this._community._clientsManager.getDefaultKuboRpcClient();
|
|
24
|
+
const listOfPage = new Array(chunks.length);
|
|
25
|
+
const cids = new Array(chunks.length);
|
|
26
|
+
let expectedSize = 1024 * 1024 * Math.pow(2, chunks.length - 1); // expected size of last page
|
|
27
|
+
for (let i = chunks.length - 1; i >= 0; i--) {
|
|
28
|
+
const modQueuePageIpfs = { nextCid: cids[i + 1], comments: chunks[i] };
|
|
29
|
+
if (!modQueuePageIpfs.nextCid)
|
|
30
|
+
delete modQueuePageIpfs.nextCid; // we don't to include undefined anywhere in the protocol
|
|
31
|
+
const addRes = await retryKuboIpfsAddAndProvide({
|
|
32
|
+
ipfsClient: ipfsClient._client,
|
|
33
|
+
log: Logger("pkc-js:page-generator:addQueuedCommentChunksToIpfs"),
|
|
34
|
+
content: deterministicStringify(modQueuePageIpfs),
|
|
35
|
+
addOptions: { pin: true },
|
|
36
|
+
provideOptions: { recursive: true },
|
|
37
|
+
provideInBackground: true
|
|
38
|
+
});
|
|
39
|
+
if (addRes.size > expectedSize)
|
|
40
|
+
throw new PKCError("ERR_PAGE_GENERATED_IS_OVER_EXPECTED_SIZE", {
|
|
41
|
+
addRes,
|
|
42
|
+
pageIpfs: modQueuePageIpfs,
|
|
43
|
+
expectedSize,
|
|
44
|
+
sortName,
|
|
45
|
+
pageNum: i
|
|
46
|
+
});
|
|
47
|
+
cids[i] = addRes.path;
|
|
48
|
+
listOfPage[i] = modQueuePageIpfs;
|
|
49
|
+
expectedSize = expectedSize / 2; // we're going backward now
|
|
50
|
+
}
|
|
51
|
+
return { pages: listOfPage, cids };
|
|
52
|
+
}
|
|
53
|
+
async addCommentChunksToIpfs(chunks, sortName) {
|
|
54
|
+
assert(chunks.length > 0);
|
|
55
|
+
const ipfsClient = this._community._clientsManager.getDefaultKuboRpcClient();
|
|
56
|
+
const listOfPage = new Array(chunks.length);
|
|
57
|
+
const cids = new Array(chunks.length);
|
|
58
|
+
let curMaxPageSize = 1024 * 1024 * Math.pow(2, chunks.length - 1); // expected size of last page
|
|
59
|
+
for (let pageNum = chunks.length - 1; pageNum >= 0; pageNum--) {
|
|
60
|
+
const pageIpfs = { nextCid: cids[pageNum + 1], comments: chunks[pageNum] };
|
|
61
|
+
if (!pageIpfs.nextCid)
|
|
62
|
+
delete pageIpfs.nextCid; // we don't to include undefined anywhere in the protocol
|
|
63
|
+
const stringifiedPageIpfs = deterministicStringify(pageIpfs);
|
|
64
|
+
const calculatedSizeOfStringifedPageIpfs = await calculateStringSizeSameAsIpfsAddCidV0(stringifiedPageIpfs);
|
|
65
|
+
if (calculatedSizeOfStringifedPageIpfs > curMaxPageSize)
|
|
66
|
+
throw new PKCError("ERR_PAGE_GENERATED_IS_OVER_EXPECTED_SIZE", {
|
|
67
|
+
calculatedSizeOfStringifedPageIpfs,
|
|
68
|
+
pageIpfs,
|
|
69
|
+
expectedSize: curMaxPageSize,
|
|
70
|
+
sortName,
|
|
71
|
+
pageNum
|
|
72
|
+
});
|
|
73
|
+
const addRes = await retryKuboIpfsAddAndProvide({
|
|
74
|
+
ipfsClient: ipfsClient._client,
|
|
75
|
+
log: Logger("pkc-js:page-generator:addCommentChunksToIpfs"),
|
|
76
|
+
content: stringifiedPageIpfs,
|
|
77
|
+
addOptions: { pin: true },
|
|
78
|
+
provideOptions: { recursive: true },
|
|
79
|
+
provideInBackground: true
|
|
80
|
+
});
|
|
81
|
+
if (addRes.size > curMaxPageSize)
|
|
82
|
+
throw new PKCError("ERR_PAGE_GENERATED_IS_OVER_EXPECTED_SIZE", {
|
|
83
|
+
addRes,
|
|
84
|
+
pageIpfs,
|
|
85
|
+
expectedSize: curMaxPageSize,
|
|
86
|
+
sortName,
|
|
87
|
+
pageNum
|
|
88
|
+
});
|
|
89
|
+
cids[pageNum] = addRes.path;
|
|
90
|
+
listOfPage[pageNum] = pageIpfs;
|
|
91
|
+
curMaxPageSize = curMaxPageSize / 2; // we're going backward now
|
|
92
|
+
}
|
|
93
|
+
return { [sortName]: { pages: listOfPage, cids } };
|
|
94
|
+
}
|
|
95
|
+
async addPreloadedCommentChunksToIpfs(chunks, sortName) {
|
|
96
|
+
const listOfPage = new Array(chunks.length);
|
|
97
|
+
const cids = [undefined]; // pageCids will never have the cid of preloaded page
|
|
98
|
+
const ipfsClient = this._community._clientsManager.getDefaultKuboRpcClient();
|
|
99
|
+
for (let pageNum = chunks.length - 1; pageNum >= 1; pageNum--) {
|
|
100
|
+
const pageIpfs = { nextCid: cids[pageNum + 1], comments: chunks[pageNum] };
|
|
101
|
+
if (!pageIpfs.nextCid)
|
|
102
|
+
delete pageIpfs.nextCid; // we don't to include undefined anywhere in the protocol
|
|
103
|
+
const maximumPageSize = 1024 * 1024 * Math.pow(2, Math.max(pageNum - 1, 0));
|
|
104
|
+
const stringifiedPageIpfs = deterministicStringify(pageIpfs);
|
|
105
|
+
const calculatedSizeOfStringifedPageIpfs = await calculateStringSizeSameAsIpfsAddCidV0(stringifiedPageIpfs);
|
|
106
|
+
if (calculatedSizeOfStringifedPageIpfs > maximumPageSize)
|
|
107
|
+
throw new PKCError("ERR_PAGE_GENERATED_IS_OVER_EXPECTED_SIZE", {
|
|
108
|
+
calculatedSizeOfStringifedPageIpfs,
|
|
109
|
+
pageIpfs,
|
|
110
|
+
maximumPageSize,
|
|
111
|
+
sortName,
|
|
112
|
+
pageNum
|
|
113
|
+
});
|
|
114
|
+
const addRes = await retryKuboIpfsAddAndProvide({
|
|
115
|
+
ipfsClient: ipfsClient._client,
|
|
116
|
+
log: Logger("pkc-js:page-generator:addPreloadedCommentChunksToIpfs"),
|
|
117
|
+
content: stringifiedPageIpfs,
|
|
118
|
+
addOptions: { pin: true },
|
|
119
|
+
provideOptions: { recursive: true },
|
|
120
|
+
provideInBackground: true
|
|
121
|
+
});
|
|
122
|
+
if (addRes.size > maximumPageSize)
|
|
123
|
+
throw new PKCError("ERR_PAGE_GENERATED_IS_OVER_EXPECTED_SIZE", {
|
|
124
|
+
addRes,
|
|
125
|
+
pageIpfs,
|
|
126
|
+
maximumPageSize,
|
|
127
|
+
sortName,
|
|
128
|
+
pageNum
|
|
129
|
+
});
|
|
130
|
+
cids[pageNum] = addRes.path;
|
|
131
|
+
listOfPage[pageNum] = pageIpfs;
|
|
132
|
+
}
|
|
133
|
+
const firstPage = { comments: chunks[0], nextCid: cids[1] };
|
|
134
|
+
if (!firstPage.nextCid)
|
|
135
|
+
throw Error("First page should have nextCid");
|
|
136
|
+
listOfPage[0] = firstPage;
|
|
137
|
+
return { [sortName]: { pages: listOfPage } };
|
|
138
|
+
}
|
|
139
|
+
async _chunkComments({ comments, firstPageSizeBytes }) {
|
|
140
|
+
const FIRST_PAGE_SIZE = firstPageSizeBytes; // dynamic page size for preloaded sorts, 1MB for others
|
|
141
|
+
const SAFETY_MARGIN = 1024; // Use 1KiB margin
|
|
142
|
+
// Calculate overhead with and without nextCid
|
|
143
|
+
const OBJECT_WRAPPER_WITH_CID = (await calculateStringSizeSameAsIpfsAddCidV0(JSON.stringify({
|
|
144
|
+
comments: [],
|
|
145
|
+
nextCid: "QmXsYKgNH7XoZXdLko5uDvtWSRNE2AXuQ4u8KxVpCacrZx" // random cid as a place holder
|
|
146
|
+
}))) - 2; // Subtract 2 for empty array "[]"
|
|
147
|
+
const OBJECT_WRAPPER_WITHOUT_CID = (await calculateStringSizeSameAsIpfsAddCidV0(JSON.stringify({
|
|
148
|
+
comments: []
|
|
149
|
+
}))) - 2; // Subtract 2 for empty array "[]"
|
|
150
|
+
// Quick check for small arrays - if everything fits in one page, no nextCid needed
|
|
151
|
+
const totalSizeWithoutCid = await calculateStringSizeSameAsIpfsAddCidV0(JSON.stringify({ comments }));
|
|
152
|
+
if (totalSizeWithoutCid <= FIRST_PAGE_SIZE) {
|
|
153
|
+
return [comments]; // Single page, no chunking needed
|
|
154
|
+
}
|
|
155
|
+
const chunks = [];
|
|
156
|
+
let currentChunk = [];
|
|
157
|
+
let chunkIndex = 0;
|
|
158
|
+
let accumulatedSize = OBJECT_WRAPPER_WITH_CID;
|
|
159
|
+
// Pre-calculate sizes to avoid repeated stringification
|
|
160
|
+
const commentSizes = new Map();
|
|
161
|
+
async function getCommentSize(index) {
|
|
162
|
+
if (!commentSizes.has(index)) {
|
|
163
|
+
const size = await calculateStringSizeSameAsIpfsAddCidV0(JSON.stringify(comments[index]));
|
|
164
|
+
commentSizes.set(index, size);
|
|
165
|
+
}
|
|
166
|
+
return commentSizes.get(index);
|
|
167
|
+
}
|
|
168
|
+
function getCurrentMaxSize(index) {
|
|
169
|
+
if (index === 0) {
|
|
170
|
+
return FIRST_PAGE_SIZE; // First page is dynamic for preloaded
|
|
171
|
+
}
|
|
172
|
+
else {
|
|
173
|
+
const MB = 1024 * 1024;
|
|
174
|
+
// For preloaded: dynamic page size, 1MB, 2MB, 4MB, etc.
|
|
175
|
+
// For non-preloaded: 1MB, 2MB, 4MB, 8MB, etc.
|
|
176
|
+
return MB * Math.pow(2, index - 1); // index-1 because we want to start with 1MB
|
|
177
|
+
}
|
|
178
|
+
}
|
|
179
|
+
for (let i = 0; i < comments.length; i++) {
|
|
180
|
+
const commentSize = await getCommentSize(i);
|
|
181
|
+
const maxSize = getCurrentMaxSize(chunkIndex);
|
|
182
|
+
const isLastItem = i === comments.length - 1;
|
|
183
|
+
// Add comma if needed
|
|
184
|
+
const commaSize = currentChunk.length > 0 ? 1 : 0;
|
|
185
|
+
// Check if adding this comment would exceed the limit MINUS the safety margin
|
|
186
|
+
if (accumulatedSize + commaSize + commentSize > maxSize - SAFETY_MARGIN) {
|
|
187
|
+
if (currentChunk.length > 0) {
|
|
188
|
+
chunks.push(currentChunk);
|
|
189
|
+
currentChunk = [];
|
|
190
|
+
chunkIndex++;
|
|
191
|
+
if (isLastItem) {
|
|
192
|
+
accumulatedSize = OBJECT_WRAPPER_WITHOUT_CID;
|
|
193
|
+
}
|
|
194
|
+
else {
|
|
195
|
+
accumulatedSize = OBJECT_WRAPPER_WITH_CID;
|
|
196
|
+
}
|
|
197
|
+
}
|
|
198
|
+
else if (commentSize > maxSize - SAFETY_MARGIN) {
|
|
199
|
+
const log = Logger("pkc-js:page-generator:_chunkComments");
|
|
200
|
+
log.trace(`Single comment at index ${i} (size ${commentSize}) is large relative to page size limit (${maxSize}) for page ${chunkIndex}`);
|
|
201
|
+
accumulatedSize = isLastItem ? OBJECT_WRAPPER_WITHOUT_CID : OBJECT_WRAPPER_WITH_CID;
|
|
202
|
+
}
|
|
203
|
+
}
|
|
204
|
+
currentChunk.push(comments[i]);
|
|
205
|
+
accumulatedSize += commaSize + commentSize;
|
|
206
|
+
}
|
|
207
|
+
if (currentChunk.length > 0) {
|
|
208
|
+
chunks.push(currentChunk);
|
|
209
|
+
}
|
|
210
|
+
return chunks;
|
|
211
|
+
}
|
|
212
|
+
async sortAndChunkComments(unsortedComments, sortName, options) {
|
|
213
|
+
if (unsortedComments.length === 0)
|
|
214
|
+
throw Error("Should not provide empty array of comments to sort");
|
|
215
|
+
const sortProps = options.parentCid
|
|
216
|
+
? POST_REPLIES_SORT_TYPES[sortName]
|
|
217
|
+
: POSTS_SORT_TYPES[sortName];
|
|
218
|
+
if (typeof sortProps.score !== "function")
|
|
219
|
+
throw Error(`SortProps[${sortName}] score function is not defined`);
|
|
220
|
+
const scoreSort = (obj1, obj2) => {
|
|
221
|
+
// calculated from DB
|
|
222
|
+
if (sortName === "active") {
|
|
223
|
+
if (typeof obj1.activeScore !== "number")
|
|
224
|
+
throw Error("Active score is not defined");
|
|
225
|
+
if (typeof obj2.activeScore !== "number")
|
|
226
|
+
throw Error("Active score is not defined");
|
|
227
|
+
return obj2.activeScore - obj1.activeScore;
|
|
228
|
+
}
|
|
229
|
+
else {
|
|
230
|
+
const score1 = sortProps.score(obj1);
|
|
231
|
+
const score2 = sortProps.score(obj2);
|
|
232
|
+
return score2 - score1;
|
|
233
|
+
}
|
|
234
|
+
};
|
|
235
|
+
const pinnedComments = unsortedComments.filter((obj) => obj.commentUpdate.pinned === true).sort(scoreSort);
|
|
236
|
+
let unpinnedComments = unsortedComments.filter((obj) => !obj.commentUpdate.pinned).sort(scoreSort);
|
|
237
|
+
if (sortProps.timeframe) {
|
|
238
|
+
const timestampLower = options.baseTimestamp - TIMEFRAMES_TO_SECONDS[sortProps.timeframe];
|
|
239
|
+
unpinnedComments = unpinnedComments.filter((obj) => obj.comment.timestamp >= timestampLower);
|
|
240
|
+
}
|
|
241
|
+
const commentsSorted = pinnedComments.concat(unpinnedComments).map((comment) => remeda.omit(comment, ["activeScore"]));
|
|
242
|
+
if (commentsSorted.length === 0)
|
|
243
|
+
return [];
|
|
244
|
+
const commentsChunks = await this._chunkComments({
|
|
245
|
+
comments: commentsSorted,
|
|
246
|
+
firstPageSizeBytes: options.firstPageSizeBytes
|
|
247
|
+
});
|
|
248
|
+
return commentsChunks;
|
|
249
|
+
}
|
|
250
|
+
// Resolves to sortedComments
|
|
251
|
+
// this is for non preloaded sorts
|
|
252
|
+
async sortChunkAddIpfsNonPreloaded(comments, sortName, options) {
|
|
253
|
+
const commentsChunks = await this.sortAndChunkComments(comments, sortName, options);
|
|
254
|
+
if (commentsChunks.length === 0)
|
|
255
|
+
return undefined;
|
|
256
|
+
const res = await this.addCommentChunksToIpfs(commentsChunks, sortName);
|
|
257
|
+
return res;
|
|
258
|
+
}
|
|
259
|
+
_generationResToPages(res) {
|
|
260
|
+
const filteredGeneratedPages = res.filter(Boolean); // Take out undefined values
|
|
261
|
+
if (filteredGeneratedPages.length === 0)
|
|
262
|
+
return undefined;
|
|
263
|
+
const mergedObject = Object.assign({}, ...filteredGeneratedPages);
|
|
264
|
+
return {
|
|
265
|
+
pages: Object.assign({}, ...Object.entries(mergedObject).map(([sortName, pages]) => ({ [sortName]: pages.pages[0] }))),
|
|
266
|
+
pageCids: Object.assign({}, ...Object.entries(mergedObject).map(([sortName, pages]) => (pages.cids ? { [sortName]: pages.cids[0] } : undefined)))
|
|
267
|
+
};
|
|
268
|
+
}
|
|
269
|
+
async generateCommunityPosts(preloadedPageSortName, preloadedPageSizeBytes) {
|
|
270
|
+
const pageOptions = {
|
|
271
|
+
excludeCommentsWithDifferentCommunityAddress: true,
|
|
272
|
+
excludeDeletedComments: true,
|
|
273
|
+
excludeRemovedComments: true,
|
|
274
|
+
excludeCommentPendingApproval: true,
|
|
275
|
+
excludeCommentWithApprovedFalse: true,
|
|
276
|
+
parentCid: null,
|
|
277
|
+
preloadedPage: preloadedPageSortName,
|
|
278
|
+
baseTimestamp: timestamp(),
|
|
279
|
+
firstPageSizeBytes: preloadedPageSizeBytes
|
|
280
|
+
};
|
|
281
|
+
// Sorting posts on a community level
|
|
282
|
+
const rawPosts = this._community._dbHandler.queryPostsWithActiveScore(pageOptions);
|
|
283
|
+
if (rawPosts.length === 0)
|
|
284
|
+
return undefined;
|
|
285
|
+
const preloadedChunk = await this.sortAndChunkComments(rawPosts, preloadedPageSortName, pageOptions);
|
|
286
|
+
const firstChunkSize = await getSerializedCommentsSize(preloadedChunk[0], preloadedChunk.length > 1);
|
|
287
|
+
if (firstChunkSize > preloadedPageSizeBytes)
|
|
288
|
+
throw new PKCError("ERR_PAGE_GENERATED_IS_OVER_EXPECTED_SIZE", {
|
|
289
|
+
firstChunkSize,
|
|
290
|
+
preloadedPageSizeBytes,
|
|
291
|
+
sortName: preloadedPageSortName
|
|
292
|
+
});
|
|
293
|
+
if (preloadedChunk.length === 1)
|
|
294
|
+
return { singlePreloadedPage: { [preloadedPageSortName]: { comments: preloadedChunk[0] } } }; // all comments fit in one preloaded page
|
|
295
|
+
// we're gonna have pages for each sort type, they don't fit in a single preloaded chunk
|
|
296
|
+
const sortResults = [];
|
|
297
|
+
sortResults.push(await this.addPreloadedCommentChunksToIpfs(preloadedChunk, preloadedPageSortName));
|
|
298
|
+
const nonPreloadedSorts = remeda.keys.strict(POSTS_SORT_TYPES).filter((sortName) => sortName !== preloadedPageSortName);
|
|
299
|
+
await Promise.all(nonPreloadedSorts.map(async (sortName) => {
|
|
300
|
+
sortResults.push(await this.sortChunkAddIpfsNonPreloaded(rawPosts, sortName, {
|
|
301
|
+
...pageOptions,
|
|
302
|
+
firstPageSizeBytes: 1024 * 1024
|
|
303
|
+
}));
|
|
304
|
+
}));
|
|
305
|
+
const generatedPages = this._generationResToPages(sortResults);
|
|
306
|
+
if (!generatedPages)
|
|
307
|
+
return undefined;
|
|
308
|
+
return generatedPages;
|
|
309
|
+
}
|
|
310
|
+
async _bundleLatestCommentUpdateWithQueuedComments(queuedComment) {
|
|
311
|
+
const communityAuthor = this._community._dbHandler.queryCommunityAuthor(queuedComment.authorSignerAddress);
|
|
312
|
+
const commentUpdateOfVerificationNoSignature = cleanUpBeforePublishing({
|
|
313
|
+
author: { community: communityAuthor },
|
|
314
|
+
cid: queuedComment.cid,
|
|
315
|
+
protocolVersion: env.PROTOCOL_VERSION,
|
|
316
|
+
pendingApproval: true
|
|
317
|
+
});
|
|
318
|
+
const commentUpdate = {
|
|
319
|
+
...commentUpdateOfVerificationNoSignature,
|
|
320
|
+
signature: await signCommentUpdateForChallengeVerification({
|
|
321
|
+
update: commentUpdateOfVerificationNoSignature,
|
|
322
|
+
signer: this._community.signer
|
|
323
|
+
})
|
|
324
|
+
};
|
|
325
|
+
const commentIpfs = deriveCommentIpfsFromCommentTableRow(queuedComment);
|
|
326
|
+
return { comment: commentIpfs, commentUpdate };
|
|
327
|
+
}
|
|
328
|
+
async generateModQueuePages() {
|
|
329
|
+
const firstPageSizeBytes = 1024 * 1024;
|
|
330
|
+
const commentsPendingApproval = this._community._dbHandler.queryCommentsPendingApproval();
|
|
331
|
+
if (commentsPendingApproval.length === 0)
|
|
332
|
+
return undefined;
|
|
333
|
+
const queuedComments = await Promise.all(commentsPendingApproval.map((comment) => this._bundleLatestCommentUpdateWithQueuedComments(comment)));
|
|
334
|
+
const combinedHashOfCids = sha256(queuedComments.map((comment) => comment.commentUpdate.cid).join(""));
|
|
335
|
+
const chunkedQueuedComments = await this._chunkComments({ comments: queuedComments, firstPageSizeBytes });
|
|
336
|
+
const pages = await this.addQueuedCommentChunksToIpfs(chunkedQueuedComments, "pendingApproval");
|
|
337
|
+
return { pageCids: { pendingApproval: pages.cids[0] }, combinedHashOfCids };
|
|
338
|
+
}
|
|
339
|
+
async generatePostPages(comment, preloadedReplyPageSortName, preloadedPageSizeBytes) {
|
|
340
|
+
const pageOptions = {
|
|
341
|
+
excludeCommentsWithDifferentCommunityAddress: true,
|
|
342
|
+
excludeDeletedComments: false,
|
|
343
|
+
excludeRemovedComments: false,
|
|
344
|
+
excludeCommentWithApprovedFalse: false,
|
|
345
|
+
excludeCommentPendingApproval: true,
|
|
346
|
+
parentCid: comment.cid,
|
|
347
|
+
preloadedPage: preloadedReplyPageSortName,
|
|
348
|
+
baseTimestamp: timestamp()
|
|
349
|
+
};
|
|
350
|
+
const hierarchalReplies = this._community._dbHandler.queryPageComments(pageOptions);
|
|
351
|
+
if (hierarchalReplies.length === 0)
|
|
352
|
+
return undefined;
|
|
353
|
+
const preloadedChunk = await this.sortAndChunkComments(hierarchalReplies, preloadedReplyPageSortName, {
|
|
354
|
+
...pageOptions,
|
|
355
|
+
firstPageSizeBytes: preloadedPageSizeBytes
|
|
356
|
+
});
|
|
357
|
+
const firstChunkSize = await getSerializedCommentsSize(preloadedChunk[0], preloadedChunk.length > 1);
|
|
358
|
+
const disablePreload = firstChunkSize > preloadedPageSizeBytes;
|
|
359
|
+
if (!disablePreload && preloadedChunk.length === 1)
|
|
360
|
+
return { singlePreloadedPage: { [preloadedReplyPageSortName]: { comments: preloadedChunk[0] } } }; // all comments fit in one page
|
|
361
|
+
const sortResults = [];
|
|
362
|
+
if (disablePreload) {
|
|
363
|
+
sortResults.push(await this.sortChunkAddIpfsNonPreloaded(hierarchalReplies, preloadedReplyPageSortName, {
|
|
364
|
+
...pageOptions,
|
|
365
|
+
firstPageSizeBytes: 1024 * 1024
|
|
366
|
+
}));
|
|
367
|
+
}
|
|
368
|
+
else {
|
|
369
|
+
sortResults.push(await this.addPreloadedCommentChunksToIpfs(preloadedChunk, preloadedReplyPageSortName));
|
|
370
|
+
}
|
|
371
|
+
const nonPreloadedSorts = remeda.keys.strict(POST_REPLIES_SORT_TYPES).filter((sortName) => sortName !== preloadedReplyPageSortName);
|
|
372
|
+
const flattenedReplies = this._community._dbHandler.queryFlattenedPageReplies({
|
|
373
|
+
...pageOptions,
|
|
374
|
+
commentUpdateFieldsToExclude: ["replies"]
|
|
375
|
+
});
|
|
376
|
+
await Promise.all(nonPreloadedSorts.map(async (sortName) => {
|
|
377
|
+
const replies = POST_REPLIES_SORT_TYPES[sortName].flat ? flattenedReplies : hierarchalReplies;
|
|
378
|
+
sortResults.push(await this.sortChunkAddIpfsNonPreloaded(replies, sortName, { ...pageOptions, firstPageSizeBytes: 1024 * 1024 }));
|
|
379
|
+
}));
|
|
380
|
+
const generatedPages = this._generationResToPages(sortResults);
|
|
381
|
+
if (!generatedPages)
|
|
382
|
+
return undefined;
|
|
383
|
+
if (disablePreload)
|
|
384
|
+
return { pageCids: generatedPages.pageCids, pages: {} };
|
|
385
|
+
else
|
|
386
|
+
return generatedPages;
|
|
387
|
+
}
|
|
388
|
+
async generateReplyPages(comment, preloadedReplyPageSortName, preloadedPageSizeBytes) {
|
|
389
|
+
const pageOptions = {
|
|
390
|
+
excludeCommentsWithDifferentCommunityAddress: true,
|
|
391
|
+
excludeDeletedComments: false,
|
|
392
|
+
excludeRemovedComments: false,
|
|
393
|
+
excludeCommentPendingApproval: true,
|
|
394
|
+
parentCid: comment.cid,
|
|
395
|
+
preloadedPage: preloadedReplyPageSortName,
|
|
396
|
+
baseTimestamp: timestamp(),
|
|
397
|
+
excludeCommentWithApprovedFalse: false
|
|
398
|
+
};
|
|
399
|
+
const hierarchalReplies = this._community._dbHandler.queryPageComments(pageOptions);
|
|
400
|
+
if (hierarchalReplies.length === 0)
|
|
401
|
+
return undefined;
|
|
402
|
+
const preloadedChunk = await this.sortAndChunkComments(hierarchalReplies, preloadedReplyPageSortName, {
|
|
403
|
+
...pageOptions,
|
|
404
|
+
firstPageSizeBytes: preloadedPageSizeBytes
|
|
405
|
+
});
|
|
406
|
+
const firstChunkSize = await getSerializedCommentsSize(preloadedChunk[0], preloadedChunk.length > 1);
|
|
407
|
+
const disablePreload = firstChunkSize > preloadedPageSizeBytes;
|
|
408
|
+
if (!disablePreload && preloadedChunk.length === 1)
|
|
409
|
+
return { singlePreloadedPage: { [preloadedReplyPageSortName]: { comments: preloadedChunk[0] } } }; // all comments fit in one page
|
|
410
|
+
const nonPreloadedSorts = remeda.keys
|
|
411
|
+
.strict(REPLY_REPLIES_SORT_TYPES)
|
|
412
|
+
.filter((sortName) => sortName !== preloadedReplyPageSortName);
|
|
413
|
+
const sortResults = [];
|
|
414
|
+
if (disablePreload) {
|
|
415
|
+
sortResults.push(await this.sortChunkAddIpfsNonPreloaded(hierarchalReplies, preloadedReplyPageSortName, {
|
|
416
|
+
...pageOptions,
|
|
417
|
+
firstPageSizeBytes: 1024 * 1024
|
|
418
|
+
}));
|
|
419
|
+
}
|
|
420
|
+
else {
|
|
421
|
+
sortResults.push(await this.addPreloadedCommentChunksToIpfs(preloadedChunk, preloadedReplyPageSortName));
|
|
422
|
+
}
|
|
423
|
+
await Promise.all(nonPreloadedSorts.map(async (hierarchalSortName) => {
|
|
424
|
+
sortResults.push(await this.sortChunkAddIpfsNonPreloaded(hierarchalReplies, hierarchalSortName, {
|
|
425
|
+
...pageOptions,
|
|
426
|
+
firstPageSizeBytes: 1024 * 1024 // pageCids will always have first pages with limit of 1mib, regardless of preloadedPageSizeBytes
|
|
427
|
+
}));
|
|
428
|
+
}));
|
|
429
|
+
const generatedPages = this._generationResToPages(sortResults);
|
|
430
|
+
if (!generatedPages)
|
|
431
|
+
return undefined;
|
|
432
|
+
if (disablePreload)
|
|
433
|
+
return { pageCids: generatedPages.pageCids, pages: {} };
|
|
434
|
+
else
|
|
435
|
+
return generatedPages;
|
|
436
|
+
}
|
|
437
|
+
toJSON() {
|
|
438
|
+
return undefined;
|
|
439
|
+
}
|
|
440
|
+
}
|
|
441
|
+
//# sourceMappingURL=page-generator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"page-generator.js","sourceRoot":"","sources":["../../../../../src/runtime/node/community/page-generator.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { LRUStorageConstructor, LRUStorageInterface } from "../../types.js";
|
|
2
|
+
export default class LRUStorage implements LRUStorageInterface {
|
|
3
|
+
private _opts;
|
|
4
|
+
private _cache;
|
|
5
|
+
constructor(opts: LRUStorageConstructor);
|
|
6
|
+
toJSON(): undefined;
|
|
7
|
+
init(): Promise<void>;
|
|
8
|
+
getItem(key: string): Promise<any | undefined>;
|
|
9
|
+
setItem(key: string, value: any): Promise<void>;
|
|
10
|
+
removeItem(key: string): Promise<boolean>;
|
|
11
|
+
clear(): Promise<void>;
|
|
12
|
+
keys(): Promise<string[]>;
|
|
13
|
+
destroy(): Promise<void>;
|
|
14
|
+
}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import path from "path";
|
|
2
|
+
import SqliteCache from "./sqlite-lru-cache.js";
|
|
3
|
+
// This code is highly inspired by https://github.com/jkelin/cache-sqlite-lru-ttl
|
|
4
|
+
// Storing items that will be evicted based on LRU
|
|
5
|
+
export default class LRUStorage {
|
|
6
|
+
constructor(opts) {
|
|
7
|
+
this._opts = opts;
|
|
8
|
+
}
|
|
9
|
+
toJSON() {
|
|
10
|
+
return undefined;
|
|
11
|
+
}
|
|
12
|
+
async init() {
|
|
13
|
+
const dbPath = this._opts.pkc.noData || !this._opts.pkc.dataPath ? `:memory:` : path.join(this._opts.pkc.dataPath, "lru-storage");
|
|
14
|
+
this._cache = new SqliteCache({
|
|
15
|
+
database: dbPath,
|
|
16
|
+
cacheTableName: this._opts.cacheName,
|
|
17
|
+
maxItems: this._opts.maxItems
|
|
18
|
+
});
|
|
19
|
+
}
|
|
20
|
+
async getItem(key) {
|
|
21
|
+
return this._cache.get(key);
|
|
22
|
+
}
|
|
23
|
+
async setItem(key, value) {
|
|
24
|
+
return this._cache.set(key, value);
|
|
25
|
+
}
|
|
26
|
+
async removeItem(key) {
|
|
27
|
+
await this._cache.delete(key);
|
|
28
|
+
return true;
|
|
29
|
+
}
|
|
30
|
+
async clear() {
|
|
31
|
+
return this._cache.clear();
|
|
32
|
+
}
|
|
33
|
+
async keys() {
|
|
34
|
+
throw Error("LruStorage.keys() is Not implemented");
|
|
35
|
+
}
|
|
36
|
+
async destroy() {
|
|
37
|
+
await this._cache.close();
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
//# sourceMappingURL=lru-storage.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lru-storage.js","sourceRoot":"","sources":["../../../../src/runtime/node/lru-storage.ts"],"names":[],"mappings":"AACA,OAAO,IAAI,MAAM,MAAM,CAAC;AACxB,OAAO,WAAW,MAAM,uBAAuB,CAAC;AAEhD,iFAAiF;AAEjF,kDAAkD;AAElD,MAAM,CAAC,OAAO,OAAO,UAAU;IAI3B,YAAY,IAA2B;QACnC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;IACtB,CAAC;IAED,MAAM;QACF,OAAO,SAAS,CAAC;IACrB,CAAC;IAED,KAAK,CAAC,IAAI;QACN,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,QAAQ,EAAE,aAAa,CAAC,CAAC;QAClI,IAAI,CAAC,MAAM,GAAG,IAAI,WAAW,CAAC;YAC1B,QAAQ,EAAE,MAAM;YAChB,cAAc,EAAE,IAAI,CAAC,KAAK,CAAC,SAAS;YACpC,QAAQ,EAAE,IAAI,CAAC,KAAK,CAAC,QAAQ;SAChC,CAAC,CAAC;IACP,CAAC;IACD,KAAK,CAAC,OAAO,CAAC,GAAW;QACrB,OAAO,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;IAChC,CAAC;IAED,KAAK,CAAC,OAAO,CAAC,GAAW,EAAE,KAAU;QACjC,OAAO,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;IACvC,CAAC;IAED,KAAK,CAAC,UAAU,CAAC,GAAW;QACxB,MAAM,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;QAC9B,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,KAAK,CAAC,KAAK;QACP,OAAO,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;IAC/B,CAAC;IAED,KAAK,CAAC,IAAI;QACN,MAAM,KAAK,CAAC,sCAAsC,CAAC,CAAC;IACxD,CAAC;IAED,KAAK,CAAC,OAAO;QACT,MAAM,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;IAC9B,CAAC;CACJ"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"native-functions.js","sourceRoot":"","sources":["../../../../src/runtime/node/native-functions.ts"],"names":[],"mappings":"AACA,OAAO,GAAG,MAAM,UAAU,CAAC;AAC3B,GAAG,CAAC,qBAAqB,CAAC,WAAW,CAAC,CAAC;AACvC,MAAM,eAAe,GAAoB;IACrC,KAAK,EAAE,KAAK,EAAE,GAAG,IAAI,EAAE,EAAE,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC;CAC3C,CAAC;AAEF,eAAe,eAAe,CAAC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
// import this file at the very top of index.ts to polyfill
|
|
2
|
+
// stuff for browsers
|
|
3
|
+
// nothing to polyfill in node
|
|
4
|
+
import { setGlobalDispatcher, Agent, WebSocket } from "undici";
|
|
5
|
+
import Logger from "../../logger.js";
|
|
6
|
+
// Add Promise.withResolvers polyfill for Node.js < 22
|
|
7
|
+
import "@enhances/with-resolvers";
|
|
8
|
+
if (Number(process.versions.node.split(".")[0]) >= 18) {
|
|
9
|
+
// We're on node 18+, we need to change the timeout of the body globally
|
|
10
|
+
// Should be removed at some point once kubo-rpc-client fixes their problem with node 18+
|
|
11
|
+
const log = Logger("pkc-js:polyfill");
|
|
12
|
+
log("Patching up the global body timeout");
|
|
13
|
+
setGlobalDispatcher(new Agent({ bodyTimeout: Number.MAX_SAFE_INTEGER }));
|
|
14
|
+
}
|
|
15
|
+
if (typeof globalThis.WebSocket === "undefined") {
|
|
16
|
+
Reflect.set(globalThis, "WebSocket", WebSocket);
|
|
17
|
+
}
|
|
18
|
+
// must export a function and call it or this file isn't read
|
|
19
|
+
export default () => { };
|
|
20
|
+
//# sourceMappingURL=polyfill.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"polyfill.js","sourceRoot":"","sources":["../../../../src/runtime/node/polyfill.ts"],"names":[],"mappings":"AAAA,2DAA2D;AAC3D,qBAAqB;AAErB,8BAA8B;AAC9B,OAAO,EAAE,mBAAmB,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,QAAQ,CAAC;AAC/D,OAAO,MAAM,MAAM,iBAAiB,CAAC;AAErC,sDAAsD;AACtD,OAAO,0BAA0B,CAAC;AAElC,IAAI,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC;IACpD,wEAAwE;IACxE,yFAAyF;IACzF,MAAM,GAAG,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;IACtC,GAAG,CAAC,qCAAqC,CAAC,CAAC;IAC3C,mBAAmB,CAAC,IAAI,KAAK,CAAC,EAAE,WAAW,EAAE,MAAM,CAAC,gBAAgB,EAAE,CAAC,CAAC,CAAC;AAC7E,CAAC;AAED,IAAI,OAAQ,UAAsC,CAAC,SAAS,KAAK,WAAW,EAAE,CAAC;IAC3E,OAAO,CAAC,GAAG,CAAC,UAAoB,EAAE,WAAW,EAAE,SAAS,CAAC,CAAC;AAC9D,CAAC;AAED,6DAA6D;AAC7D,eAAe,GAAG,EAAE,GAAE,CAAC,CAAC"}
|