@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,289 @@
|
|
|
1
|
+
import Logger from "../logger.js";
|
|
2
|
+
import { RpcRemoteCommunity } from "./rpc-remote-community.js";
|
|
3
|
+
import * as remeda from "remeda";
|
|
4
|
+
import { PKCError } from "../pkc-error.js";
|
|
5
|
+
import { CommunityEditOptionsSchema } from "./schema.js";
|
|
6
|
+
import { decodeRpcChallengeAnswerPubsubMsg, decodeRpcChallengePubsubMsg, decodeRpcChallengeRequestPubsubMsg, decodeRpcChallengeVerificationPubsubMsg } from "../clients/rpc-client/decode-rpc-response-util.js";
|
|
7
|
+
import { deepMergeRuntimeFields, hideClassPrivateProps } from "../util.js";
|
|
8
|
+
import { findStartedCommunity, trackStartedCommunity, untrackStartedCommunity } from "../pkc/tracked-instance-registry-util.js";
|
|
9
|
+
// This class is for communities that are running and publishing, over RPC. Can be used for both browser and node
|
|
10
|
+
export class RpcLocalCommunity extends RpcRemoteCommunity {
|
|
11
|
+
constructor(pkc) {
|
|
12
|
+
super(pkc);
|
|
13
|
+
this.raw = {};
|
|
14
|
+
// Private stuff
|
|
15
|
+
this._startRpcSubscriptionId = undefined;
|
|
16
|
+
this.started = false;
|
|
17
|
+
//@ts-expect-error
|
|
18
|
+
this._usingDefaultChallenge = undefined;
|
|
19
|
+
this.start = this.start.bind(this);
|
|
20
|
+
this.edit = this.edit.bind(this);
|
|
21
|
+
this._setStartedStateWithEmission("stopped");
|
|
22
|
+
this.on("update", () => {
|
|
23
|
+
this.editable = remeda.pick(this, remeda.keys.strict(CommunityEditOptionsSchema.shape));
|
|
24
|
+
});
|
|
25
|
+
hideClassPrivateProps(this);
|
|
26
|
+
}
|
|
27
|
+
toJSONInternalRpcAfterFirstUpdate() {
|
|
28
|
+
if (!this.updateCid)
|
|
29
|
+
throw Error("rpcLocalCommunity.cid should be defined before calling toJSONInternalRpcAfterFirstUpdate");
|
|
30
|
+
return {
|
|
31
|
+
community: this.raw.communityIpfs,
|
|
32
|
+
localCommunity: {
|
|
33
|
+
signer: this.signer,
|
|
34
|
+
settings: this.settings,
|
|
35
|
+
_usingDefaultChallenge: this._usingDefaultChallenge,
|
|
36
|
+
address: this.address,
|
|
37
|
+
started: this.started,
|
|
38
|
+
startedState: this.startedState
|
|
39
|
+
},
|
|
40
|
+
runtimeFields: {
|
|
41
|
+
updateCid: this.updateCid,
|
|
42
|
+
updatingState: this.updatingState,
|
|
43
|
+
nameResolved: this.nameResolved
|
|
44
|
+
}
|
|
45
|
+
};
|
|
46
|
+
}
|
|
47
|
+
toJSONInternalRpcBeforeFirstUpdate() {
|
|
48
|
+
if (!this.settings)
|
|
49
|
+
throw Error("Attempting to transmit InternalRpc record without defining settings");
|
|
50
|
+
return {
|
|
51
|
+
localCommunity: {
|
|
52
|
+
...this._toJSONIpfsBaseNoPosts(),
|
|
53
|
+
address: this.address,
|
|
54
|
+
signer: this.signer,
|
|
55
|
+
settings: this.settings,
|
|
56
|
+
_usingDefaultChallenge: this._usingDefaultChallenge,
|
|
57
|
+
started: this.started,
|
|
58
|
+
startedState: this.startedState
|
|
59
|
+
}
|
|
60
|
+
};
|
|
61
|
+
}
|
|
62
|
+
initRpcInternalCommunityBeforeFirstUpdateNoMerge(newProps) {
|
|
63
|
+
this.initRemoteCommunityPropsNoMerge(newProps.localCommunity);
|
|
64
|
+
// Apply address from localCommunity — may differ after edit (same as afterFirstUpdate variant)
|
|
65
|
+
if (newProps.localCommunity.address)
|
|
66
|
+
this.setAddress(newProps.localCommunity.address);
|
|
67
|
+
this.signer = newProps.localCommunity.signer;
|
|
68
|
+
this.settings = newProps.localCommunity.settings;
|
|
69
|
+
this._usingDefaultChallenge = newProps.localCommunity._usingDefaultChallenge;
|
|
70
|
+
this.started = newProps.localCommunity.started;
|
|
71
|
+
this.raw.localCommunity = newProps;
|
|
72
|
+
}
|
|
73
|
+
initRpcInternalCommunityAfterFirstUpdateNoMerge(newProps) {
|
|
74
|
+
super.initCommunityIpfsPropsNoMerge(newProps.community);
|
|
75
|
+
// Apply address from localCommunity — may differ from community record's name (e.g. .bso/.eth before ENS propagation)
|
|
76
|
+
if (newProps.localCommunity.address)
|
|
77
|
+
this.setAddress(newProps.localCommunity.address);
|
|
78
|
+
this.signer = newProps.localCommunity.signer;
|
|
79
|
+
this.settings = newProps.localCommunity.settings;
|
|
80
|
+
this._usingDefaultChallenge = newProps.localCommunity._usingDefaultChallenge;
|
|
81
|
+
this.started = newProps.localCommunity.started;
|
|
82
|
+
this.updateCid = newProps.runtimeFields.updateCid;
|
|
83
|
+
this.raw.localCommunity = newProps;
|
|
84
|
+
this.editable = remeda.pick(this, remeda.keys.strict(CommunityEditOptionsSchema.shape));
|
|
85
|
+
}
|
|
86
|
+
_updateRpcClientStateFromStartedState(startedState) {
|
|
87
|
+
const mapper = {
|
|
88
|
+
failed: ["stopped"],
|
|
89
|
+
"publishing-ipns": ["publishing-ipns"],
|
|
90
|
+
stopped: ["stopped"],
|
|
91
|
+
succeeded: ["stopped"]
|
|
92
|
+
};
|
|
93
|
+
const newClientState = mapper[startedState] || [startedState]; // in case rpc server transmits a startedState we don't know about, default to startedState
|
|
94
|
+
newClientState.forEach(this._setRpcClientStateWithEmission.bind(this));
|
|
95
|
+
}
|
|
96
|
+
_processUpdateEventFromRpcUpdate(args) {
|
|
97
|
+
// This function is gonna be called with every update event from rpcLocalCommunity.update()
|
|
98
|
+
const log = Logger("pkc-js:rpc-local-community:_processUpdateEventFromRpcUpdate");
|
|
99
|
+
log("Received an update event from rpc within rpcLocalCommunity.update for community " + this.address);
|
|
100
|
+
const updateRecord = args.params.result; // we're being optimistic here and hoping the rpc server sent the correct update
|
|
101
|
+
if ("community" in updateRecord)
|
|
102
|
+
this.initRpcInternalCommunityAfterFirstUpdateNoMerge(updateRecord);
|
|
103
|
+
else
|
|
104
|
+
this.initRpcInternalCommunityBeforeFirstUpdateNoMerge(updateRecord);
|
|
105
|
+
const runtimeFields = "runtimeFields" in updateRecord ? updateRecord.runtimeFields : undefined;
|
|
106
|
+
if (runtimeFields) {
|
|
107
|
+
this.raw.runtimeFieldsFromRpc = runtimeFields;
|
|
108
|
+
deepMergeRuntimeFields(this, runtimeFields);
|
|
109
|
+
}
|
|
110
|
+
if (updateRecord.localCommunity.startedState)
|
|
111
|
+
this._setStartedStateNoEmission(updateRecord.localCommunity.startedState);
|
|
112
|
+
this.emit("update", this);
|
|
113
|
+
}
|
|
114
|
+
_handleRpcUpdateEventFromStart(args) {
|
|
115
|
+
// This function is gonna be called with every update event from rpcLocalCommunity.start()
|
|
116
|
+
const log = Logger("pkc-js:rpc-local-community:_handleRpcUpdateEventFromStart");
|
|
117
|
+
const updateRecord = args.params.result;
|
|
118
|
+
log("Received an update event from rpc within rpcLocalCommunity.start for community " + this.address);
|
|
119
|
+
if ("community" in updateRecord) {
|
|
120
|
+
this.initRpcInternalCommunityAfterFirstUpdateNoMerge(updateRecord);
|
|
121
|
+
}
|
|
122
|
+
else
|
|
123
|
+
this.initRpcInternalCommunityBeforeFirstUpdateNoMerge(updateRecord);
|
|
124
|
+
const runtimeFields = "runtimeFields" in updateRecord ? updateRecord.runtimeFields : undefined;
|
|
125
|
+
if (runtimeFields) {
|
|
126
|
+
this.raw.runtimeFieldsFromRpc = runtimeFields;
|
|
127
|
+
deepMergeRuntimeFields(this, runtimeFields);
|
|
128
|
+
}
|
|
129
|
+
if (updateRecord.localCommunity.startedState) {
|
|
130
|
+
this._setStartedStateNoEmission(updateRecord.localCommunity.startedState);
|
|
131
|
+
}
|
|
132
|
+
this.emit("update", this);
|
|
133
|
+
}
|
|
134
|
+
_handleRpcStartedStateChangeEvent(args) {
|
|
135
|
+
const log = Logger("pkc-js:rpc-local-community:_handleRpcStartedStateChangeEvent");
|
|
136
|
+
const newStartedState = args.params.result.state; // we're being optimistic that the rpc server transmitted a valid string here
|
|
137
|
+
log("Received a startedstatechange for community " + this.address, "new started state is", newStartedState);
|
|
138
|
+
if (newStartedState !== this.startedState)
|
|
139
|
+
this._setStartedStateWithEmission(newStartedState);
|
|
140
|
+
else
|
|
141
|
+
this.emit("startedstatechange", newStartedState);
|
|
142
|
+
this._updateRpcClientStateFromStartedState(newStartedState);
|
|
143
|
+
}
|
|
144
|
+
_handleRpcChallengeRequestEvent(args) {
|
|
145
|
+
const encodedRequest = args.params.result;
|
|
146
|
+
const request = decodeRpcChallengeRequestPubsubMsg(encodedRequest);
|
|
147
|
+
this._setRpcClientStateWithEmission("waiting-challenge-requests");
|
|
148
|
+
this.emit("challengerequest", request);
|
|
149
|
+
}
|
|
150
|
+
_handleRpcChallengeEvent(args) {
|
|
151
|
+
const encodedChallenge = args.params.result;
|
|
152
|
+
const challenge = decodeRpcChallengePubsubMsg(encodedChallenge);
|
|
153
|
+
this._setRpcClientStateWithEmission("publishing-challenge");
|
|
154
|
+
this.emit("challenge", challenge);
|
|
155
|
+
this._setRpcClientStateWithEmission("waiting-challenge-answers");
|
|
156
|
+
}
|
|
157
|
+
_handleRpcChallengeAnswerEvent(args) {
|
|
158
|
+
const encodedChallengeAnswer = args.params.result;
|
|
159
|
+
const challengeAnswer = decodeRpcChallengeAnswerPubsubMsg(encodedChallengeAnswer);
|
|
160
|
+
this.emit("challengeanswer", challengeAnswer);
|
|
161
|
+
}
|
|
162
|
+
_handleRpcChallengeVerificationEvent(args) {
|
|
163
|
+
const { challengeVerification: encodedChallengeVerification } = args.params.result;
|
|
164
|
+
const challengeVerification = decodeRpcChallengeVerificationPubsubMsg(encodedChallengeVerification);
|
|
165
|
+
this._setRpcClientStateWithEmission("publishing-challenge-verification");
|
|
166
|
+
this.emit("challengeverification", challengeVerification);
|
|
167
|
+
this._setRpcClientStateWithEmission("waiting-challenge-requests");
|
|
168
|
+
}
|
|
169
|
+
async start() {
|
|
170
|
+
const log = Logger("pkc-js:rpc-local-community:start");
|
|
171
|
+
if (this.state === "updating")
|
|
172
|
+
throw new PKCError("ERR_NEED_TO_STOP_UPDATING_COMMUNITY_BEFORE_STARTING", { address: this.address });
|
|
173
|
+
// we can't start the same instance multiple times
|
|
174
|
+
if (typeof this._startRpcSubscriptionId === "number")
|
|
175
|
+
throw new PKCError("ERR_COMMUNITY_ALREADY_STARTED", { communityAddress: this.address });
|
|
176
|
+
if (findStartedCommunity(this._pkc, { address: this.address }))
|
|
177
|
+
throw new PKCError("ERR_COMMUNITY_ALREADY_STARTED_IN_SAME_PKC_INSTANCE", { communityAddress: this.address });
|
|
178
|
+
try {
|
|
179
|
+
this._startRpcSubscriptionId = await this._pkc._pkcRpcClient.startCommunity({ address: this.address });
|
|
180
|
+
this._setState("started");
|
|
181
|
+
}
|
|
182
|
+
catch (e) {
|
|
183
|
+
log.error(`Failed to start community (${this.address}) from RPC due to error`, e);
|
|
184
|
+
this._setState("stopped");
|
|
185
|
+
this._setStartedStateWithEmission("failed");
|
|
186
|
+
throw e;
|
|
187
|
+
}
|
|
188
|
+
trackStartedCommunity(this._pkc, this);
|
|
189
|
+
this.started = true;
|
|
190
|
+
this._pkc
|
|
191
|
+
._pkcRpcClient.getSubscription(this._startRpcSubscriptionId)
|
|
192
|
+
.on("update", this._handleRpcUpdateEventFromStart.bind(this))
|
|
193
|
+
.on("startedstatechange", this._handleRpcStartedStateChangeEvent.bind(this))
|
|
194
|
+
.on("challengerequest", this._handleRpcChallengeRequestEvent.bind(this))
|
|
195
|
+
.on("challenge", this._handleRpcChallengeEvent.bind(this))
|
|
196
|
+
.on("challengeanswer", this._handleRpcChallengeAnswerEvent.bind(this))
|
|
197
|
+
.on("challengeverification", this._handleRpcChallengeVerificationEvent.bind(this))
|
|
198
|
+
.on("error", this._handleRpcErrorEvent.bind(this));
|
|
199
|
+
this._pkc._pkcRpcClient.emitAllPendingMessages(this._startRpcSubscriptionId);
|
|
200
|
+
}
|
|
201
|
+
async _cleanUpRpcConnection(log) {
|
|
202
|
+
if (this._startRpcSubscriptionId) {
|
|
203
|
+
try {
|
|
204
|
+
await this._pkc._pkcRpcClient.unsubscribe(this._startRpcSubscriptionId);
|
|
205
|
+
}
|
|
206
|
+
catch (e) {
|
|
207
|
+
log.error("Failed to unsubscribe from communityStart", e);
|
|
208
|
+
}
|
|
209
|
+
}
|
|
210
|
+
this._setStartedStateWithEmission("stopped");
|
|
211
|
+
this._setRpcClientStateWithEmission("stopped");
|
|
212
|
+
this.started = false;
|
|
213
|
+
this._startRpcSubscriptionId = undefined;
|
|
214
|
+
log(`Stopped the running of local community (${this.address}) via RPC`);
|
|
215
|
+
this._setState("stopped");
|
|
216
|
+
}
|
|
217
|
+
async stopWithoutRpcCall() {
|
|
218
|
+
const log = Logger("pkc-js:rpc-local-community:stop");
|
|
219
|
+
await this._cleanUpRpcConnection(log);
|
|
220
|
+
this.posts._stop();
|
|
221
|
+
this._setState("stopped");
|
|
222
|
+
this._setStartedStateWithEmission("stopped");
|
|
223
|
+
this._setRpcClientStateWithEmission("stopped");
|
|
224
|
+
this.started = false;
|
|
225
|
+
untrackStartedCommunity(this._pkc, this);
|
|
226
|
+
}
|
|
227
|
+
async stop() {
|
|
228
|
+
this.posts._stop();
|
|
229
|
+
if (this.state === "updating") {
|
|
230
|
+
return super.stop();
|
|
231
|
+
}
|
|
232
|
+
else if (this.state === "started") {
|
|
233
|
+
// Need to be careful not to stop an already running community
|
|
234
|
+
const log = Logger("pkc-js:rpc-local-community:stop");
|
|
235
|
+
try {
|
|
236
|
+
await this._pkc._pkcRpcClient.stopCommunity({ address: this.address });
|
|
237
|
+
}
|
|
238
|
+
catch (e) {
|
|
239
|
+
log.error("RPC client received an error when asking rpc server to stop community", e);
|
|
240
|
+
}
|
|
241
|
+
await this._cleanUpRpcConnection(log);
|
|
242
|
+
untrackStartedCommunity(this._pkc, this);
|
|
243
|
+
}
|
|
244
|
+
}
|
|
245
|
+
async edit(newCommunityOptions) {
|
|
246
|
+
if (newCommunityOptions.settings?.challenges) {
|
|
247
|
+
const serverChallenges = this._pkc._pkcRpcClient.settings?.challenges;
|
|
248
|
+
if (serverChallenges) {
|
|
249
|
+
for (const challengeSetting of newCommunityOptions.settings.challenges) {
|
|
250
|
+
if (challengeSetting.name && !challengeSetting.path && !(challengeSetting.name in serverChallenges)) {
|
|
251
|
+
throw new PKCError("ERR_RPC_CLIENT_CHALLENGE_NAME_NOT_AVAILABLE_ON_SERVER", {
|
|
252
|
+
challengeName: challengeSetting.name,
|
|
253
|
+
availableChallenges: Object.keys(serverChallenges)
|
|
254
|
+
});
|
|
255
|
+
}
|
|
256
|
+
}
|
|
257
|
+
}
|
|
258
|
+
}
|
|
259
|
+
const subPropsAfterEdit = await this._pkc._pkcRpcClient.editCommunity(this.address, newCommunityOptions);
|
|
260
|
+
if ("community" in subPropsAfterEdit)
|
|
261
|
+
this.initRpcInternalCommunityAfterFirstUpdateNoMerge(subPropsAfterEdit);
|
|
262
|
+
else
|
|
263
|
+
this.initRpcInternalCommunityBeforeFirstUpdateNoMerge(subPropsAfterEdit);
|
|
264
|
+
this.emit("update", this);
|
|
265
|
+
return this;
|
|
266
|
+
}
|
|
267
|
+
async update() {
|
|
268
|
+
if (this.state === "started")
|
|
269
|
+
throw new PKCError("ERR_COMMUNITY_ALREADY_STARTED", { address: this.address });
|
|
270
|
+
return super.update();
|
|
271
|
+
}
|
|
272
|
+
async delete() {
|
|
273
|
+
// Make sure to stop updating or starting first
|
|
274
|
+
const startedCommunity = findStartedCommunity(this._pkc, { address: this.address });
|
|
275
|
+
if (startedCommunity && startedCommunity !== this) {
|
|
276
|
+
await startedCommunity.delete();
|
|
277
|
+
}
|
|
278
|
+
else {
|
|
279
|
+
if (this.state === "started" || this.state === "updating")
|
|
280
|
+
await this.stop();
|
|
281
|
+
await this._pkc._pkcRpcClient.deleteCommunity({ address: this.address });
|
|
282
|
+
}
|
|
283
|
+
this.started = false;
|
|
284
|
+
this._setRpcClientStateWithEmission("stopped");
|
|
285
|
+
this._setState("stopped");
|
|
286
|
+
this._setStartedStateWithEmission("stopped");
|
|
287
|
+
}
|
|
288
|
+
}
|
|
289
|
+
//# sourceMappingURL=rpc-local-community.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rpc-local-community.js","sourceRoot":"","sources":["../../../src/community/rpc-local-community.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { RemoteCommunity } from "./remote-community.js";
|
|
2
|
+
export declare class RpcRemoteCommunity extends RemoteCommunity {
|
|
3
|
+
private _updateRpcSubscriptionId?;
|
|
4
|
+
private _updatingRpcCommunityInstanceWithListeners?;
|
|
5
|
+
protected _setRpcClientStateWithoutEmission(newState: RemoteCommunity["clients"]["pkcRpcClients"][""]["state"]): void;
|
|
6
|
+
protected _setRpcClientStateWithEmission(newState: RemoteCommunity["clients"]["pkcRpcClients"][""]["state"]): void;
|
|
7
|
+
get updatingState(): RemoteCommunity["updatingState"];
|
|
8
|
+
protected _updateRpcClientStateFromUpdatingState(updatingState: RpcRemoteCommunity["updatingState"]): void;
|
|
9
|
+
protected _processUpdateEventFromRpcUpdate(args: any): void;
|
|
10
|
+
private _handleUpdatingStateChangeFromRpcUpdate;
|
|
11
|
+
private _initMirroringUpdatingCommunity;
|
|
12
|
+
protected _handleRpcErrorEvent(args: any): void;
|
|
13
|
+
_initRpcUpdateSubscription(): Promise<void>;
|
|
14
|
+
_createAndSubscribeToNewUpdatingCommunity(updatingCommunity?: RpcRemoteCommunity): Promise<void>;
|
|
15
|
+
update(): Promise<void>;
|
|
16
|
+
private _cleanupMirroringUpdatingCommunity;
|
|
17
|
+
stop(): Promise<void>;
|
|
18
|
+
}
|
|
@@ -0,0 +1,286 @@
|
|
|
1
|
+
import Logger from "../logger.js";
|
|
2
|
+
import { RemoteCommunity } from "./remote-community.js";
|
|
3
|
+
import * as remeda from "remeda";
|
|
4
|
+
import { PKCError } from "../pkc-error.js";
|
|
5
|
+
import { parseRpcRemoteCommunityUpdateEventWithPKCErrorIfItFails } from "../schema/schema-util.js";
|
|
6
|
+
import { deepMergeRuntimeFields } from "../util.js";
|
|
7
|
+
import { findStartedCommunity, findUpdatingCommunity, trackUpdatingCommunity, untrackUpdatingCommunity } from "../pkc/tracked-instance-registry-util.js";
|
|
8
|
+
export class RpcRemoteCommunity extends RemoteCommunity {
|
|
9
|
+
constructor() {
|
|
10
|
+
super(...arguments);
|
|
11
|
+
this._updateRpcSubscriptionId = undefined;
|
|
12
|
+
this._updatingRpcCommunityInstanceWithListeners = undefined; // The pkc._updatingCommunities we're subscribed to
|
|
13
|
+
}
|
|
14
|
+
_setRpcClientStateWithoutEmission(newState) {
|
|
15
|
+
const currentRpcUrl = remeda.keys.strict(this.clients.pkcRpcClients)[0];
|
|
16
|
+
const currentState = this.clients.pkcRpcClients[currentRpcUrl].state;
|
|
17
|
+
if (newState === currentState)
|
|
18
|
+
return;
|
|
19
|
+
this.clients.pkcRpcClients[currentRpcUrl].state = newState;
|
|
20
|
+
}
|
|
21
|
+
_setRpcClientStateWithEmission(newState) {
|
|
22
|
+
const currentRpcUrl = remeda.keys.strict(this.clients.pkcRpcClients)[0];
|
|
23
|
+
const currentState = this.clients.pkcRpcClients[currentRpcUrl].state;
|
|
24
|
+
if (newState === currentState)
|
|
25
|
+
return;
|
|
26
|
+
this.clients.pkcRpcClients[currentRpcUrl].state = newState;
|
|
27
|
+
this.clients.pkcRpcClients[currentRpcUrl].emit("statechange", newState);
|
|
28
|
+
}
|
|
29
|
+
get updatingState() {
|
|
30
|
+
if (this._updatingRpcCommunityInstanceWithListeners) {
|
|
31
|
+
return this._updatingRpcCommunityInstanceWithListeners.community.updatingState;
|
|
32
|
+
}
|
|
33
|
+
else
|
|
34
|
+
return this._updatingState;
|
|
35
|
+
}
|
|
36
|
+
_updateRpcClientStateFromUpdatingState(updatingState) {
|
|
37
|
+
// We're deriving the the rpc state from updating state
|
|
38
|
+
const mapper = {
|
|
39
|
+
failed: ["stopped"],
|
|
40
|
+
"fetching-ipfs": ["fetching-ipfs"],
|
|
41
|
+
"fetching-ipns": ["fetching-ipns"],
|
|
42
|
+
"waiting-retry": ["stopped"],
|
|
43
|
+
"publishing-ipns": ["publishing-ipns"],
|
|
44
|
+
"resolving-name": ["resolving-community-name"],
|
|
45
|
+
stopped: ["stopped"],
|
|
46
|
+
succeeded: ["stopped"]
|
|
47
|
+
};
|
|
48
|
+
const newRpcClientState = mapper[updatingState] || [updatingState]; // There may be a case where the rpc server transmits a new state that is not part of mapper
|
|
49
|
+
newRpcClientState.forEach(this._setRpcClientStateWithEmission.bind(this));
|
|
50
|
+
}
|
|
51
|
+
_processUpdateEventFromRpcUpdate(args) {
|
|
52
|
+
// This function is to handle "update" event emitted after calling rpcRemoteCommunity.update()
|
|
53
|
+
// It's overidden in rpc-local-community
|
|
54
|
+
const log = Logger("pkc-js:rpc-remote-community:_processUpdateEventFromRpcUpdate");
|
|
55
|
+
let updateRecord;
|
|
56
|
+
try {
|
|
57
|
+
updateRecord = parseRpcRemoteCommunityUpdateEventWithPKCErrorIfItFails(args.params.result);
|
|
58
|
+
}
|
|
59
|
+
catch (e) {
|
|
60
|
+
log.error("Failed to parse the schema of remote community sent by rpc", e);
|
|
61
|
+
this.emit("error", e);
|
|
62
|
+
throw e;
|
|
63
|
+
}
|
|
64
|
+
// Key migration: server cleared its state, client should do the same
|
|
65
|
+
if (updateRecord.resetInstance && updateRecord.runtimeFields.newPublicKey) {
|
|
66
|
+
this._clearDataForKeyMigration(updateRecord.runtimeFields.newPublicKey);
|
|
67
|
+
if (typeof updateRecord.runtimeFields.nameResolved === "boolean")
|
|
68
|
+
this.nameResolved = updateRecord.runtimeFields.nameResolved;
|
|
69
|
+
this.emit("update", this);
|
|
70
|
+
return;
|
|
71
|
+
}
|
|
72
|
+
this.initCommunityIpfsPropsNoMerge(updateRecord.community);
|
|
73
|
+
this.updateCid = updateRecord.runtimeFields.updateCid;
|
|
74
|
+
this._setUpdatingStateNoEmission(updateRecord.runtimeFields.updatingState || "succeeded");
|
|
75
|
+
this.raw.runtimeFieldsFromRpc = updateRecord.runtimeFields;
|
|
76
|
+
deepMergeRuntimeFields(this, updateRecord.runtimeFields);
|
|
77
|
+
this.emit("update", this);
|
|
78
|
+
}
|
|
79
|
+
_handleUpdatingStateChangeFromRpcUpdate(args) {
|
|
80
|
+
const newUpdatingState = args.params.result.state; // we're being optimistic that RPC server sent an appropiate updating state string
|
|
81
|
+
this._setUpdatingStateWithEventEmissionIfNewState(newUpdatingState);
|
|
82
|
+
this._updateRpcClientStateFromUpdatingState(newUpdatingState);
|
|
83
|
+
}
|
|
84
|
+
async _initMirroringUpdatingCommunity(updatingCommunity) {
|
|
85
|
+
if (updatingCommunity === this)
|
|
86
|
+
return; // avoid mirroring to itself
|
|
87
|
+
this._updatingRpcCommunityInstanceWithListeners = {
|
|
88
|
+
community: updatingCommunity,
|
|
89
|
+
error: (err) => this.emit("error", err),
|
|
90
|
+
updatingstatechange: (updatingState) => this._setUpdatingStateWithEventEmissionIfNewState.bind(this)(updatingState),
|
|
91
|
+
update: (updatingCommunity) => {
|
|
92
|
+
const keyChanged = updatingCommunity.publicKey && updatingCommunity.publicKey !== this.publicKey;
|
|
93
|
+
if (!updatingCommunity.raw.communityIpfs || !updatingCommunity.updateCid) {
|
|
94
|
+
if (updatingCommunity.publicKey)
|
|
95
|
+
this._clearDataForKeyMigration(updatingCommunity.publicKey);
|
|
96
|
+
}
|
|
97
|
+
else {
|
|
98
|
+
this.initCommunityIpfsPropsNoMerge(updatingCommunity.raw.communityIpfs);
|
|
99
|
+
this.updateCid = updatingCommunity.updateCid;
|
|
100
|
+
if (updatingCommunity.raw.runtimeFieldsFromRpc)
|
|
101
|
+
deepMergeRuntimeFields(this, updatingCommunity.raw.runtimeFieldsFromRpc);
|
|
102
|
+
}
|
|
103
|
+
if (typeof updatingCommunity.nameResolved === "boolean")
|
|
104
|
+
this.nameResolved = updatingCommunity.nameResolved;
|
|
105
|
+
// Only emit when there's actual data or a key migration — avoid spurious updates for empty subs
|
|
106
|
+
if ((updatingCommunity.raw.communityIpfs && updatingCommunity.updateCid) || keyChanged) {
|
|
107
|
+
this.emit("update", this);
|
|
108
|
+
}
|
|
109
|
+
},
|
|
110
|
+
statechange: async (newState) => {
|
|
111
|
+
if (newState === "stopped" && this.state !== "stopped")
|
|
112
|
+
// pkc._updatingCommunities[address].stop() has been called, we need to clean up the subscription
|
|
113
|
+
// or pkc._startedCommunities[address].stop has been called
|
|
114
|
+
await this.stop();
|
|
115
|
+
},
|
|
116
|
+
challengerequest: (challengeRequest) => this.emit("challengerequest", challengeRequest),
|
|
117
|
+
challengeverification: (challengeVerification) => this.emit("challengeverification", challengeVerification),
|
|
118
|
+
challengeanswer: (challengeAnswer) => this.emit("challengeanswer", challengeAnswer),
|
|
119
|
+
challenge: (challenge) => this.emit("challenge", challenge),
|
|
120
|
+
startedstatechange: (startedState) => this._setStartedStateWithEmission.bind(this)(startedState)
|
|
121
|
+
};
|
|
122
|
+
this._updatingRpcCommunityInstanceWithListeners.community.on("update", this._updatingRpcCommunityInstanceWithListeners.update);
|
|
123
|
+
this._updatingRpcCommunityInstanceWithListeners.community.on("updatingstatechange", this._updatingRpcCommunityInstanceWithListeners.updatingstatechange);
|
|
124
|
+
this._updatingRpcCommunityInstanceWithListeners.community.on("error", this._updatingRpcCommunityInstanceWithListeners.error);
|
|
125
|
+
this._updatingRpcCommunityInstanceWithListeners.community.on("statechange", this._updatingRpcCommunityInstanceWithListeners.statechange);
|
|
126
|
+
this._updatingRpcCommunityInstanceWithListeners.community.on("challengerequest", this._updatingRpcCommunityInstanceWithListeners.challengerequest);
|
|
127
|
+
this._updatingRpcCommunityInstanceWithListeners.community.on("challengeverification", this._updatingRpcCommunityInstanceWithListeners.challengeverification);
|
|
128
|
+
this._updatingRpcCommunityInstanceWithListeners.community.on("challengeanswer", this._updatingRpcCommunityInstanceWithListeners.challengeanswer);
|
|
129
|
+
this._updatingRpcCommunityInstanceWithListeners.community.on("challenge", this._updatingRpcCommunityInstanceWithListeners.challenge);
|
|
130
|
+
this._updatingRpcCommunityInstanceWithListeners.community.on("startedstatechange", this._updatingRpcCommunityInstanceWithListeners.startedstatechange);
|
|
131
|
+
const clientKeys = remeda.keys.strict(this.clients);
|
|
132
|
+
for (const clientType of clientKeys)
|
|
133
|
+
if (updatingCommunity.clients[clientType])
|
|
134
|
+
for (const clientUrl of Object.keys(updatingCommunity.clients[clientType]))
|
|
135
|
+
this.clients[clientType][clientUrl].mirror(updatingCommunity.clients[clientType][clientUrl]);
|
|
136
|
+
this._updatingRpcCommunityInstanceWithListeners.community._numOfListenersForUpdatingInstance++;
|
|
137
|
+
if (!updatingCommunity.raw.communityIpfs || !updatingCommunity.updateCid) {
|
|
138
|
+
if (updatingCommunity.publicKey)
|
|
139
|
+
this._clearDataForKeyMigration(updatingCommunity.publicKey);
|
|
140
|
+
}
|
|
141
|
+
else {
|
|
142
|
+
this.initCommunityIpfsPropsNoMerge(updatingCommunity.raw.communityIpfs);
|
|
143
|
+
this.updateCid = updatingCommunity.updateCid;
|
|
144
|
+
if (updatingCommunity.raw.runtimeFieldsFromRpc)
|
|
145
|
+
deepMergeRuntimeFields(this, updatingCommunity.raw.runtimeFieldsFromRpc);
|
|
146
|
+
}
|
|
147
|
+
if (typeof updatingCommunity.nameResolved === "boolean")
|
|
148
|
+
this.nameResolved = updatingCommunity.nameResolved;
|
|
149
|
+
if (updatingCommunity.raw.communityIpfs || updatingCommunity.updateCid) {
|
|
150
|
+
this.emit("update", this);
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
_handleRpcErrorEvent(args) {
|
|
154
|
+
const error = args.params.result;
|
|
155
|
+
if (error.details?.newUpdatingState)
|
|
156
|
+
this._setUpdatingStateNoEmission(error.details.newUpdatingState);
|
|
157
|
+
if (error.details?.newStartedState)
|
|
158
|
+
this._setStartedStateNoEmission(error.details.newStartedState);
|
|
159
|
+
if ("code" in error && error.code === "ERR_COMMUNITY_NAME_RESOLVES_TO_DIFFERENT_PUBLIC_KEY" && error.details?.newPublicKey) {
|
|
160
|
+
this._clearDataForKeyMigration(error.details.newPublicKey);
|
|
161
|
+
this.nameResolved = true;
|
|
162
|
+
this.emit("update", this);
|
|
163
|
+
}
|
|
164
|
+
this.emit("error", error);
|
|
165
|
+
}
|
|
166
|
+
async _initRpcUpdateSubscription() {
|
|
167
|
+
const log = Logger("pkc-js:rpc-remote-community:_initRpcUpdateSubscription");
|
|
168
|
+
this._setState("updating");
|
|
169
|
+
try {
|
|
170
|
+
this._updateRpcSubscriptionId = await this._pkc._pkcRpcClient.communityUpdateSubscribe({
|
|
171
|
+
address: this.address,
|
|
172
|
+
...(this.name ? { name: this.name } : undefined),
|
|
173
|
+
...(this.publicKey ? { publicKey: this.publicKey } : undefined)
|
|
174
|
+
});
|
|
175
|
+
}
|
|
176
|
+
catch (e) {
|
|
177
|
+
log.error("Failed to receive communityUpdate from RPC due to error", e);
|
|
178
|
+
this._setState("stopped");
|
|
179
|
+
this._setUpdatingStateWithEventEmissionIfNewState("failed");
|
|
180
|
+
throw e;
|
|
181
|
+
}
|
|
182
|
+
this._pkc
|
|
183
|
+
._pkcRpcClient.getSubscription(this._updateRpcSubscriptionId)
|
|
184
|
+
.on("update", this._processUpdateEventFromRpcUpdate.bind(this))
|
|
185
|
+
.on("updatingstatechange", this._handleUpdatingStateChangeFromRpcUpdate.bind(this))
|
|
186
|
+
.on("error", this._handleRpcErrorEvent.bind(this));
|
|
187
|
+
this._pkc._pkcRpcClient.emitAllPendingMessages(this._updateRpcSubscriptionId);
|
|
188
|
+
}
|
|
189
|
+
async _createAndSubscribeToNewUpdatingCommunity(updatingCommunity) {
|
|
190
|
+
const log = Logger("pkc-js:rpc-remote-community:_createNewUpdatingCommunity");
|
|
191
|
+
const updatingSub = updatingCommunity ||
|
|
192
|
+
(await this._pkc.createCommunity({
|
|
193
|
+
address: this.address,
|
|
194
|
+
...(this.name ? { name: this.name } : undefined),
|
|
195
|
+
...(this.publicKey ? { publicKey: this.publicKey } : undefined)
|
|
196
|
+
}));
|
|
197
|
+
trackUpdatingCommunity(this._pkc, updatingSub);
|
|
198
|
+
log("Creating a new entry for this._pkc._updatingCommunities", this.address);
|
|
199
|
+
if (updatingSub !== this)
|
|
200
|
+
// in pkc.createCommunity() this function is called with the community instance itself
|
|
201
|
+
await this._initMirroringUpdatingCommunity(updatingSub);
|
|
202
|
+
await updatingSub._initRpcUpdateSubscription();
|
|
203
|
+
}
|
|
204
|
+
async update() {
|
|
205
|
+
const log = Logger("pkc-js:rpc-remote-community:update");
|
|
206
|
+
if (this.state === "started")
|
|
207
|
+
throw new PKCError("ERR_COMMUNITY_ALREADY_STARTED", { address: this.address });
|
|
208
|
+
if (this.state !== "stopped")
|
|
209
|
+
return; // No need to do anything if community is already updating
|
|
210
|
+
this._setState("updating");
|
|
211
|
+
try {
|
|
212
|
+
const existingSub = findUpdatingCommunity(this._pkc, { address: this.address });
|
|
213
|
+
if (existingSub) {
|
|
214
|
+
if (existingSub === this)
|
|
215
|
+
await this._initRpcUpdateSubscription();
|
|
216
|
+
else
|
|
217
|
+
await this._initMirroringUpdatingCommunity(existingSub);
|
|
218
|
+
}
|
|
219
|
+
else {
|
|
220
|
+
const startedSub = findStartedCommunity(this._pkc, { address: this.address });
|
|
221
|
+
if (startedSub)
|
|
222
|
+
await this._initMirroringUpdatingCommunity(startedSub);
|
|
223
|
+
else {
|
|
224
|
+
// creating a new entry in pkc._updatingCommunities
|
|
225
|
+
// poll updates from RPC
|
|
226
|
+
await this._createAndSubscribeToNewUpdatingCommunity();
|
|
227
|
+
}
|
|
228
|
+
}
|
|
229
|
+
}
|
|
230
|
+
catch (e) {
|
|
231
|
+
await this.stop();
|
|
232
|
+
throw e;
|
|
233
|
+
}
|
|
234
|
+
}
|
|
235
|
+
async _cleanupMirroringUpdatingCommunity() {
|
|
236
|
+
if (!this._updatingRpcCommunityInstanceWithListeners)
|
|
237
|
+
throw Error("rpcRemoteCommunity.state is updating but no mirroring updating community");
|
|
238
|
+
this._updatingRpcCommunityInstanceWithListeners.community.removeListener("update", this._updatingRpcCommunityInstanceWithListeners.update);
|
|
239
|
+
this._updatingRpcCommunityInstanceWithListeners.community.removeListener("updatingstatechange", this._updatingRpcCommunityInstanceWithListeners.updatingstatechange);
|
|
240
|
+
this._updatingRpcCommunityInstanceWithListeners.community.removeListener("error", this._updatingRpcCommunityInstanceWithListeners.error);
|
|
241
|
+
this._updatingRpcCommunityInstanceWithListeners.community.removeListener("statechange", this._updatingRpcCommunityInstanceWithListeners.statechange);
|
|
242
|
+
this._updatingRpcCommunityInstanceWithListeners.community.removeListener("challengerequest", this._updatingRpcCommunityInstanceWithListeners.challengerequest);
|
|
243
|
+
this._updatingRpcCommunityInstanceWithListeners.community.removeListener("challengeverification", this._updatingRpcCommunityInstanceWithListeners.challengeverification);
|
|
244
|
+
this._updatingRpcCommunityInstanceWithListeners.community.removeListener("challengeanswer", this._updatingRpcCommunityInstanceWithListeners.challengeanswer);
|
|
245
|
+
this._updatingRpcCommunityInstanceWithListeners.community.removeListener("challenge", this._updatingRpcCommunityInstanceWithListeners.challenge);
|
|
246
|
+
this._updatingRpcCommunityInstanceWithListeners.community.removeListener("startedstatechange", this._updatingRpcCommunityInstanceWithListeners.startedstatechange);
|
|
247
|
+
const clientKeys = remeda.keys.strict(this.clients);
|
|
248
|
+
for (const clientType of clientKeys)
|
|
249
|
+
if (this.clients[clientType])
|
|
250
|
+
for (const clientUrl of Object.keys(this.clients[clientType]))
|
|
251
|
+
this.clients[clientType][clientUrl].unmirror();
|
|
252
|
+
this._updatingRpcCommunityInstanceWithListeners.community._numOfListenersForUpdatingInstance--;
|
|
253
|
+
if (this._updatingRpcCommunityInstanceWithListeners.community._numOfListenersForUpdatingInstance === 0 &&
|
|
254
|
+
this._updatingRpcCommunityInstanceWithListeners.community.state === "updating") {
|
|
255
|
+
const log = Logger("pkc-js:rpc-remote-community:_cleanupMirroringUpdatingCommunity");
|
|
256
|
+
log("Cleaning up pkc._updatingCommunities", this.address, "There are no communities using it for updates");
|
|
257
|
+
await this._updatingRpcCommunityInstanceWithListeners.community.stop();
|
|
258
|
+
}
|
|
259
|
+
this._updatingRpcCommunityInstanceWithListeners = undefined;
|
|
260
|
+
}
|
|
261
|
+
async stop() {
|
|
262
|
+
const log = Logger("pkc-js:rpc-remote-community:stop");
|
|
263
|
+
if (this.state === "stopped")
|
|
264
|
+
return;
|
|
265
|
+
if (this._updatingRpcCommunityInstanceWithListeners) {
|
|
266
|
+
await this._cleanupMirroringUpdatingCommunity();
|
|
267
|
+
}
|
|
268
|
+
else if (this._updateRpcSubscriptionId) {
|
|
269
|
+
try {
|
|
270
|
+
await this._pkc._pkcRpcClient.unsubscribe(this._updateRpcSubscriptionId);
|
|
271
|
+
}
|
|
272
|
+
catch (e) {
|
|
273
|
+
log.error("Failed to unsubscribe from communityUpdate", e);
|
|
274
|
+
}
|
|
275
|
+
this._updateRpcSubscriptionId = undefined;
|
|
276
|
+
log.trace(`Stopped the update of remote community (${this.address}) via RPC`);
|
|
277
|
+
untrackUpdatingCommunity(this._pkc, this);
|
|
278
|
+
}
|
|
279
|
+
this._setRpcClientStateWithEmission("stopped");
|
|
280
|
+
this._setUpdatingStateWithEventEmissionIfNewState("stopped");
|
|
281
|
+
this._setState("stopped");
|
|
282
|
+
this._setStartedStateWithEmission("stopped");
|
|
283
|
+
this.posts._stop();
|
|
284
|
+
}
|
|
285
|
+
}
|
|
286
|
+
//# sourceMappingURL=rpc-remote-community.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rpc-remote-community.js","sourceRoot":"","sources":["../../../src/community/rpc-remote-community.ts"],"names":[],"mappings":"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"}
|