@towns-protocol/sdk 0.0.191
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +29 -0
- package/dist/check.d.ts +31 -0
- package/dist/check.d.ts.map +1 -0
- package/dist/check.js +44 -0
- package/dist/check.js.map +1 -0
- package/dist/client.d.ts +333 -0
- package/dist/client.d.ts.map +1 -0
- package/dist/client.js +1767 -0
- package/dist/client.js.map +1 -0
- package/dist/clientDecryptionExtensions.d.ts +44 -0
- package/dist/clientDecryptionExtensions.d.ts.map +1 -0
- package/dist/clientDecryptionExtensions.js +256 -0
- package/dist/clientDecryptionExtensions.js.map +1 -0
- package/dist/crypto_utils.d.ts +15 -0
- package/dist/crypto_utils.d.ts.map +1 -0
- package/dist/crypto_utils.js +99 -0
- package/dist/crypto_utils.js.map +1 -0
- package/dist/encryptedContentTypes.d.ts +31 -0
- package/dist/encryptedContentTypes.d.ts.map +1 -0
- package/dist/encryptedContentTypes.js +73 -0
- package/dist/encryptedContentTypes.js.map +1 -0
- package/dist/id.d.ts +54 -0
- package/dist/id.d.ts.map +1 -0
- package/dist/id.js +190 -0
- package/dist/id.js.map +1 -0
- package/dist/index.d.ts +101 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +101 -0
- package/dist/index.js.map +1 -0
- package/dist/makeAuthenticationRpcClient.d.ts +8 -0
- package/dist/makeAuthenticationRpcClient.d.ts.map +1 -0
- package/dist/makeAuthenticationRpcClient.js +39 -0
- package/dist/makeAuthenticationRpcClient.js.map +1 -0
- package/dist/makeNotificationRpcClient.d.ts +8 -0
- package/dist/makeNotificationRpcClient.d.ts.map +1 -0
- package/dist/makeNotificationRpcClient.js +40 -0
- package/dist/makeNotificationRpcClient.js.map +1 -0
- package/dist/makeRiverRpcClient.d.ts +6 -0
- package/dist/makeRiverRpcClient.d.ts.map +1 -0
- package/dist/makeRiverRpcClient.js +9 -0
- package/dist/makeRiverRpcClient.js.map +1 -0
- package/dist/makeStreamRpcClient.d.ts +20 -0
- package/dist/makeStreamRpcClient.d.ts.map +1 -0
- package/dist/makeStreamRpcClient.js +91 -0
- package/dist/makeStreamRpcClient.js.map +1 -0
- package/dist/memberMetadata_DisplayNames.d.ts +27 -0
- package/dist/memberMetadata_DisplayNames.d.ts.map +1 -0
- package/dist/memberMetadata_DisplayNames.js +96 -0
- package/dist/memberMetadata_DisplayNames.js.map +1 -0
- package/dist/memberMetadata_EnsAddresses.d.ts +25 -0
- package/dist/memberMetadata_EnsAddresses.d.ts.map +1 -0
- package/dist/memberMetadata_EnsAddresses.js +86 -0
- package/dist/memberMetadata_EnsAddresses.js.map +1 -0
- package/dist/memberMetadata_Nft.d.ts +31 -0
- package/dist/memberMetadata_Nft.d.ts.map +1 -0
- package/dist/memberMetadata_Nft.js +95 -0
- package/dist/memberMetadata_Nft.js.map +1 -0
- package/dist/memberMetadata_Usernames.d.ts +33 -0
- package/dist/memberMetadata_Usernames.d.ts.map +1 -0
- package/dist/memberMetadata_Usernames.js +152 -0
- package/dist/memberMetadata_Usernames.js.map +1 -0
- package/dist/migrations/migrateSnapshot.d.ts +3 -0
- package/dist/migrations/migrateSnapshot.d.ts.map +1 -0
- package/dist/migrations/migrateSnapshot.js +17 -0
- package/dist/migrations/migrateSnapshot.js.map +1 -0
- package/dist/migrations/snapshotMigration0000.d.ts +3 -0
- package/dist/migrations/snapshotMigration0000.d.ts.map +1 -0
- package/dist/migrations/snapshotMigration0000.js +5 -0
- package/dist/migrations/snapshotMigration0000.js.map +1 -0
- package/dist/migrations/snapshotMigration0001.d.ts +3 -0
- package/dist/migrations/snapshotMigration0001.d.ts.map +1 -0
- package/dist/migrations/snapshotMigration0001.js +40 -0
- package/dist/migrations/snapshotMigration0001.js.map +1 -0
- package/dist/migrations/snapshotMigration0002.d.ts +3 -0
- package/dist/migrations/snapshotMigration0002.d.ts.map +1 -0
- package/dist/migrations/snapshotMigration0002.js +23 -0
- package/dist/migrations/snapshotMigration0002.js.map +1 -0
- package/dist/notificationService.d.ts +17 -0
- package/dist/notificationService.d.ts.map +1 -0
- package/dist/notificationService.js +48 -0
- package/dist/notificationService.js.map +1 -0
- package/dist/observable/observable.d.ts +28 -0
- package/dist/observable/observable.d.ts.map +1 -0
- package/dist/observable/observable.js +57 -0
- package/dist/observable/observable.js.map +1 -0
- package/dist/observable/persistedObservable.d.ts +37 -0
- package/dist/observable/persistedObservable.d.ts.map +1 -0
- package/dist/observable/persistedObservable.js +77 -0
- package/dist/observable/persistedObservable.js.map +1 -0
- package/dist/persistenceStore.d.ts +71 -0
- package/dist/persistenceStore.d.ts.map +1 -0
- package/dist/persistenceStore.js +366 -0
- package/dist/persistenceStore.js.map +1 -0
- package/dist/riverConfig.d.ts +23 -0
- package/dist/riverConfig.d.ts.map +1 -0
- package/dist/riverConfig.js +111 -0
- package/dist/riverConfig.js.map +1 -0
- package/dist/riverDbManager.d.ts +5 -0
- package/dist/riverDbManager.d.ts.map +1 -0
- package/dist/riverDbManager.js +7 -0
- package/dist/riverDbManager.js.map +1 -0
- package/dist/rpcCommon.d.ts +9 -0
- package/dist/rpcCommon.d.ts.map +1 -0
- package/dist/rpcCommon.js +14 -0
- package/dist/rpcCommon.js.map +1 -0
- package/dist/rpcInterceptors.d.ts +20 -0
- package/dist/rpcInterceptors.d.ts.map +1 -0
- package/dist/rpcInterceptors.js +369 -0
- package/dist/rpcInterceptors.js.map +1 -0
- package/dist/sign.d.ts +41 -0
- package/dist/sign.d.ts.map +1 -0
- package/dist/sign.js +268 -0
- package/dist/sign.js.map +1 -0
- package/dist/signerContext.d.ts +60 -0
- package/dist/signerContext.d.ts.map +1 -0
- package/dist/signerContext.js +101 -0
- package/dist/signerContext.js.map +1 -0
- package/dist/store/store.d.ts +22 -0
- package/dist/store/store.d.ts.map +1 -0
- package/dist/store/store.js +165 -0
- package/dist/store/store.js.map +1 -0
- package/dist/stream.d.ts +47 -0
- package/dist/stream.d.ts.map +1 -0
- package/dist/stream.js +111 -0
- package/dist/stream.js.map +1 -0
- package/dist/streamEvents.d.ts +86 -0
- package/dist/streamEvents.d.ts.map +1 -0
- package/dist/streamEvents.js +2 -0
- package/dist/streamEvents.js.map +1 -0
- package/dist/streamStateView.d.ts +119 -0
- package/dist/streamStateView.d.ts.map +1 -0
- package/dist/streamStateView.js +527 -0
- package/dist/streamStateView.js.map +1 -0
- package/dist/streamStateView_AbstractContent.d.ts +20 -0
- package/dist/streamStateView_AbstractContent.d.ts.map +1 -0
- package/dist/streamStateView_AbstractContent.js +41 -0
- package/dist/streamStateView_AbstractContent.js.map +1 -0
- package/dist/streamStateView_Channel.d.ts +20 -0
- package/dist/streamStateView_Channel.d.ts.map +1 -0
- package/dist/streamStateView_Channel.js +65 -0
- package/dist/streamStateView_Channel.js.map +1 -0
- package/dist/streamStateView_ChannelMetadata.d.ts +22 -0
- package/dist/streamStateView_ChannelMetadata.d.ts.map +1 -0
- package/dist/streamStateView_ChannelMetadata.js +57 -0
- package/dist/streamStateView_ChannelMetadata.js.map +1 -0
- package/dist/streamStateView_DMChannel.d.ts +22 -0
- package/dist/streamStateView_DMChannel.d.ts.map +1 -0
- package/dist/streamStateView_DMChannel.js +78 -0
- package/dist/streamStateView_DMChannel.js.map +1 -0
- package/dist/streamStateView_GDMChannel.d.ts +22 -0
- package/dist/streamStateView_GDMChannel.d.ts.map +1 -0
- package/dist/streamStateView_GDMChannel.js +82 -0
- package/dist/streamStateView_GDMChannel.js.map +1 -0
- package/dist/streamStateView_Media.d.ts +20 -0
- package/dist/streamStateView_Media.d.ts.map +1 -0
- package/dist/streamStateView_Media.js +54 -0
- package/dist/streamStateView_Media.js.map +1 -0
- package/dist/streamStateView_MemberMetadata.d.ts +51 -0
- package/dist/streamStateView_MemberMetadata.d.ts.map +1 -0
- package/dist/streamStateView_MemberMetadata.js +97 -0
- package/dist/streamStateView_MemberMetadata.js.map +1 -0
- package/dist/streamStateView_Members.d.ts +70 -0
- package/dist/streamStateView_Members.d.ts.map +1 -0
- package/dist/streamStateView_Members.js +409 -0
- package/dist/streamStateView_Members.js.map +1 -0
- package/dist/streamStateView_Members_Membership.d.ts +29 -0
- package/dist/streamStateView_Members_Membership.d.ts.map +1 -0
- package/dist/streamStateView_Members_Membership.js +117 -0
- package/dist/streamStateView_Members_Membership.js.map +1 -0
- package/dist/streamStateView_Members_Solicitations.d.ts +15 -0
- package/dist/streamStateView_Members_Solicitations.d.ts.map +1 -0
- package/dist/streamStateView_Members_Solicitations.js +49 -0
- package/dist/streamStateView_Members_Solicitations.js.map +1 -0
- package/dist/streamStateView_Space.d.ts +34 -0
- package/dist/streamStateView_Space.d.ts.map +1 -0
- package/dist/streamStateView_Space.js +190 -0
- package/dist/streamStateView_Space.js.map +1 -0
- package/dist/streamStateView_UnknownContent.d.ts +11 -0
- package/dist/streamStateView_UnknownContent.d.ts.map +1 -0
- package/dist/streamStateView_UnknownContent.js +15 -0
- package/dist/streamStateView_UnknownContent.js.map +1 -0
- package/dist/streamStateView_User.d.ts +26 -0
- package/dist/streamStateView_User.d.ts.map +1 -0
- package/dist/streamStateView_User.js +154 -0
- package/dist/streamStateView_User.js.map +1 -0
- package/dist/streamStateView_UserInbox.d.ts +17 -0
- package/dist/streamStateView_UserInbox.d.ts.map +1 -0
- package/dist/streamStateView_UserInbox.js +70 -0
- package/dist/streamStateView_UserInbox.js.map +1 -0
- package/dist/streamStateView_UserMetadata.d.ts +27 -0
- package/dist/streamStateView_UserMetadata.d.ts.map +1 -0
- package/dist/streamStateView_UserMetadata.js +146 -0
- package/dist/streamStateView_UserMetadata.js.map +1 -0
- package/dist/streamStateView_UserSettings.d.ts +32 -0
- package/dist/streamStateView_UserSettings.d.ts.map +1 -0
- package/dist/streamStateView_UserSettings.js +112 -0
- package/dist/streamStateView_UserSettings.js.map +1 -0
- package/dist/streamUtils.d.ts +15 -0
- package/dist/streamUtils.d.ts.map +1 -0
- package/dist/streamUtils.js +112 -0
- package/dist/streamUtils.js.map +1 -0
- package/dist/sync-agent/db.d.ts +19 -0
- package/dist/sync-agent/db.d.ts.map +1 -0
- package/dist/sync-agent/db.js +36 -0
- package/dist/sync-agent/db.js.map +1 -0
- package/dist/sync-agent/dms/dms.d.ts +24 -0
- package/dist/sync-agent/dms/dms.d.ts.map +1 -0
- package/dist/sync-agent/dms/dms.js +60 -0
- package/dist/sync-agent/dms/dms.js.map +1 -0
- package/dist/sync-agent/dms/models/dm.d.ts +59 -0
- package/dist/sync-agent/dms/models/dm.d.ts.map +1 -0
- package/dist/sync-agent/dms/models/dm.js +140 -0
- package/dist/sync-agent/dms/models/dm.js.map +1 -0
- package/dist/sync-agent/entitlements/entitlements.d.ts +10 -0
- package/dist/sync-agent/entitlements/entitlements.d.ts.map +1 -0
- package/dist/sync-agent/entitlements/entitlements.js +23 -0
- package/dist/sync-agent/entitlements/entitlements.js.map +1 -0
- package/dist/sync-agent/gdms/gdms.d.ts +23 -0
- package/dist/sync-agent/gdms/gdms.d.ts.map +1 -0
- package/dist/sync-agent/gdms/gdms.js +56 -0
- package/dist/sync-agent/gdms/gdms.js.map +1 -0
- package/dist/sync-agent/gdms/models/gdm.d.ts +59 -0
- package/dist/sync-agent/gdms/models/gdm.d.ts.map +1 -0
- package/dist/sync-agent/gdms/models/gdm.js +138 -0
- package/dist/sync-agent/gdms/models/gdm.js.map +1 -0
- package/dist/sync-agent/members/members.d.ts +32 -0
- package/dist/sync-agent/members/members.d.ts.map +1 -0
- package/dist/sync-agent/members/members.js +143 -0
- package/dist/sync-agent/members/members.js.map +1 -0
- package/dist/sync-agent/members/models/member.d.ts +66 -0
- package/dist/sync-agent/members/models/member.d.ts.map +1 -0
- package/dist/sync-agent/members/models/member.js +131 -0
- package/dist/sync-agent/members/models/member.js.map +1 -0
- package/dist/sync-agent/members/models/myself.d.ts +20 -0
- package/dist/sync-agent/members/models/myself.d.ts.map +1 -0
- package/dist/sync-agent/members/models/myself.js +97 -0
- package/dist/sync-agent/members/models/myself.js.map +1 -0
- package/dist/sync-agent/river-connection/models/authStatus.d.ts +18 -0
- package/dist/sync-agent/river-connection/models/authStatus.d.ts.map +1 -0
- package/dist/sync-agent/river-connection/models/authStatus.js +19 -0
- package/dist/sync-agent/river-connection/models/authStatus.js.map +1 -0
- package/dist/sync-agent/river-connection/models/riverChain.d.ts +30 -0
- package/dist/sync-agent/river-connection/models/riverChain.d.ts.map +1 -0
- package/dist/sync-agent/river-connection/models/riverChain.js +93 -0
- package/dist/sync-agent/river-connection/models/riverChain.js.map +1 -0
- package/dist/sync-agent/river-connection/models/transactionalClient.d.ts +11 -0
- package/dist/sync-agent/river-connection/models/transactionalClient.d.ts.map +1 -0
- package/dist/sync-agent/river-connection/models/transactionalClient.js +14 -0
- package/dist/sync-agent/river-connection/models/transactionalClient.js.map +1 -0
- package/dist/sync-agent/river-connection/riverConnection.d.ts +61 -0
- package/dist/sync-agent/river-connection/riverConnection.d.ts.map +1 -0
- package/dist/sync-agent/river-connection/riverConnection.js +229 -0
- package/dist/sync-agent/river-connection/riverConnection.js.map +1 -0
- package/dist/sync-agent/spaces/models/channel.d.ts +84 -0
- package/dist/sync-agent/spaces/models/channel.d.ts.map +1 -0
- package/dist/sync-agent/spaces/models/channel.js +173 -0
- package/dist/sync-agent/spaces/models/channel.js.map +1 -0
- package/dist/sync-agent/spaces/models/space.d.ts +57 -0
- package/dist/sync-agent/spaces/models/space.d.ts.map +1 -0
- package/dist/sync-agent/spaces/models/space.js +147 -0
- package/dist/sync-agent/spaces/models/space.js.map +1 -0
- package/dist/sync-agent/spaces/spaces.d.ts +29 -0
- package/dist/sync-agent/spaces/spaces.d.ts.map +1 -0
- package/dist/sync-agent/spaces/spaces.js +90 -0
- package/dist/sync-agent/spaces/spaces.js.map +1 -0
- package/dist/sync-agent/syncAgent.d.ts +68 -0
- package/dist/sync-agent/syncAgent.d.ts.map +1 -0
- package/dist/sync-agent/syncAgent.js +108 -0
- package/dist/sync-agent/syncAgent.js.map +1 -0
- package/dist/sync-agent/timeline/models/pendingReplacedEvents.d.ts +12 -0
- package/dist/sync-agent/timeline/models/pendingReplacedEvents.d.ts.map +1 -0
- package/dist/sync-agent/timeline/models/pendingReplacedEvents.js +20 -0
- package/dist/sync-agent/timeline/models/pendingReplacedEvents.js.map +1 -0
- package/dist/sync-agent/timeline/models/reactions.d.ts +13 -0
- package/dist/sync-agent/timeline/models/reactions.d.ts.map +1 -0
- package/dist/sync-agent/timeline/models/reactions.js +67 -0
- package/dist/sync-agent/timeline/models/reactions.js.map +1 -0
- package/dist/sync-agent/timeline/models/replacedEvents.d.ts +18 -0
- package/dist/sync-agent/timeline/models/replacedEvents.d.ts.map +1 -0
- package/dist/sync-agent/timeline/models/replacedEvents.js +19 -0
- package/dist/sync-agent/timeline/models/replacedEvents.js.map +1 -0
- package/dist/sync-agent/timeline/models/threadStats.d.ts +13 -0
- package/dist/sync-agent/timeline/models/threadStats.d.ts.map +1 -0
- package/dist/sync-agent/timeline/models/threadStats.js +99 -0
- package/dist/sync-agent/timeline/models/threadStats.js.map +1 -0
- package/dist/sync-agent/timeline/models/threads.d.ts +14 -0
- package/dist/sync-agent/timeline/models/threads.d.ts.map +1 -0
- package/dist/sync-agent/timeline/models/threads.js +57 -0
- package/dist/sync-agent/timeline/models/threads.js.map +1 -0
- package/dist/sync-agent/timeline/models/timeline-types.d.ts +364 -0
- package/dist/sync-agent/timeline/models/timeline-types.d.ts.map +1 -0
- package/dist/sync-agent/timeline/models/timeline-types.js +66 -0
- package/dist/sync-agent/timeline/models/timeline-types.js.map +1 -0
- package/dist/sync-agent/timeline/models/timelineEvent.d.ts +14 -0
- package/dist/sync-agent/timeline/models/timelineEvent.d.ts.map +1 -0
- package/dist/sync-agent/timeline/models/timelineEvent.js +1080 -0
- package/dist/sync-agent/timeline/models/timelineEvent.js.map +1 -0
- package/dist/sync-agent/timeline/models/timelineEvents.d.ts +13 -0
- package/dist/sync-agent/timeline/models/timelineEvents.d.ts.map +1 -0
- package/dist/sync-agent/timeline/models/timelineEvents.js +37 -0
- package/dist/sync-agent/timeline/models/timelineEvents.js.map +1 -0
- package/dist/sync-agent/timeline/timeline.d.ts +43 -0
- package/dist/sync-agent/timeline/timeline.d.ts.map +1 -0
- package/dist/sync-agent/timeline/timeline.js +246 -0
- package/dist/sync-agent/timeline/timeline.js.map +1 -0
- package/dist/sync-agent/user/models/userInbox.d.ts +21 -0
- package/dist/sync-agent/user/models/userInbox.d.ts.map +1 -0
- package/dist/sync-agent/user/models/userInbox.js +68 -0
- package/dist/sync-agent/user/models/userInbox.js.map +1 -0
- package/dist/sync-agent/user/models/userMemberships.d.ts +29 -0
- package/dist/sync-agent/user/models/userMemberships.d.ts.map +1 -0
- package/dist/sync-agent/user/models/userMemberships.js +84 -0
- package/dist/sync-agent/user/models/userMemberships.js.map +1 -0
- package/dist/sync-agent/user/models/userMetadata.d.ts +21 -0
- package/dist/sync-agent/user/models/userMetadata.d.ts.map +1 -0
- package/dist/sync-agent/user/models/userMetadata.js +68 -0
- package/dist/sync-agent/user/models/userMetadata.js.map +1 -0
- package/dist/sync-agent/user/models/userSettings.d.ts +17 -0
- package/dist/sync-agent/user/models/userSettings.d.ts.map +1 -0
- package/dist/sync-agent/user/models/userSettings.js +48 -0
- package/dist/sync-agent/user/models/userSettings.js.map +1 -0
- package/dist/sync-agent/user/user.d.ts +18 -0
- package/dist/sync-agent/user/user.d.ts.map +1 -0
- package/dist/sync-agent/user/user.js +30 -0
- package/dist/sync-agent/user/user.js.map +1 -0
- package/dist/sync-agent/utils/bot.d.ts +16 -0
- package/dist/sync-agent/utils/bot.d.ts.map +1 -0
- package/dist/sync-agent/utils/bot.js +39 -0
- package/dist/sync-agent/utils/bot.js.map +1 -0
- package/dist/sync-agent/utils/promiseQueue.d.ts +6 -0
- package/dist/sync-agent/utils/promiseQueue.d.ts.map +1 -0
- package/dist/sync-agent/utils/promiseQueue.js +20 -0
- package/dist/sync-agent/utils/promiseQueue.js.map +1 -0
- package/dist/sync-agent/utils/providers.d.ts +5 -0
- package/dist/sync-agent/utils/providers.d.ts.map +1 -0
- package/dist/sync-agent/utils/providers.js +16 -0
- package/dist/sync-agent/utils/providers.js.map +1 -0
- package/dist/sync-agent/utils/spaceUtils.d.ts +22 -0
- package/dist/sync-agent/utils/spaceUtils.d.ts.map +1 -0
- package/dist/sync-agent/utils/spaceUtils.js +27 -0
- package/dist/sync-agent/utils/spaceUtils.js.map +1 -0
- package/dist/syncEvents.d.ts +9 -0
- package/dist/syncEvents.d.ts.map +1 -0
- package/dist/syncEvents.js +2 -0
- package/dist/syncEvents.js.map +1 -0
- package/dist/syncedStream.d.ts +22 -0
- package/dist/syncedStream.d.ts.map +1 -0
- package/dist/syncedStream.js +108 -0
- package/dist/syncedStream.js.map +1 -0
- package/dist/syncedStreams.d.ts +46 -0
- package/dist/syncedStreams.d.ts.map +1 -0
- package/dist/syncedStreams.js +116 -0
- package/dist/syncedStreams.js.map +1 -0
- package/dist/syncedStreamsExtension.d.ts +50 -0
- package/dist/syncedStreamsExtension.d.ts.map +1 -0
- package/dist/syncedStreamsExtension.js +285 -0
- package/dist/syncedStreamsExtension.js.map +1 -0
- package/dist/syncedStreamsLoop.d.ts +121 -0
- package/dist/syncedStreamsLoop.d.ts.map +1 -0
- package/dist/syncedStreamsLoop.js +781 -0
- package/dist/syncedStreamsLoop.js.map +1 -0
- package/dist/tags.d.ts +7 -0
- package/dist/tags.d.ts.map +1 -0
- package/dist/tags.js +144 -0
- package/dist/tags.js.map +1 -0
- package/dist/tests/bob_testUtils.d.ts +4 -0
- package/dist/tests/bob_testUtils.d.ts.map +1 -0
- package/dist/tests/bob_testUtils.js +159 -0
- package/dist/tests/bob_testUtils.js.map +1 -0
- package/dist/tests/multi/channelScrubbing.test.d.ts +5 -0
- package/dist/tests/multi/channelScrubbing.test.d.ts.map +1 -0
- package/dist/tests/multi/channelScrubbing.test.js +33 -0
- package/dist/tests/multi/channelScrubbing.test.js.map +1 -0
- package/dist/tests/multi/channelSpaceSettings.test.d.ts +5 -0
- package/dist/tests/multi/channelSpaceSettings.test.d.ts.map +1 -0
- package/dist/tests/multi/channelSpaceSettings.test.js +206 -0
- package/dist/tests/multi/channelSpaceSettings.test.js.map +1 -0
- package/dist/tests/multi/disableChannel.test.d.ts +5 -0
- package/dist/tests/multi/disableChannel.test.d.ts.map +1 -0
- package/dist/tests/multi/disableChannel.test.js +30 -0
- package/dist/tests/multi/disableChannel.test.js.map +1 -0
- package/dist/tests/multi/disableSpace.test.d.ts +5 -0
- package/dist/tests/multi/disableSpace.test.d.ts.map +1 -0
- package/dist/tests/multi/disableSpace.test.js +37 -0
- package/dist/tests/multi/disableSpace.test.js.map +1 -0
- package/dist/tests/multi/entitlements/channelEntitlementPermissions.test.d.ts +5 -0
- package/dist/tests/multi/entitlements/channelEntitlementPermissions.test.d.ts.map +1 -0
- package/dist/tests/multi/entitlements/channelEntitlementPermissions.test.js +129 -0
- package/dist/tests/multi/entitlements/channelEntitlementPermissions.test.js.map +1 -0
- package/dist/tests/multi/entitlements/channelWithThreeNestedEntitlement.test.d.ts +5 -0
- package/dist/tests/multi/entitlements/channelWithThreeNestedEntitlement.test.d.ts.map +1 -0
- package/dist/tests/multi/entitlements/channelWithThreeNestedEntitlement.test.js +44 -0
- package/dist/tests/multi/entitlements/channelWithThreeNestedEntitlement.test.js.map +1 -0
- package/dist/tests/multi/entitlements/channelsWithComplexEntitlements.test.d.ts +5 -0
- package/dist/tests/multi/entitlements/channelsWithComplexEntitlements.test.d.ts.map +1 -0
- package/dist/tests/multi/entitlements/channelsWithComplexEntitlements.test.js +145 -0
- package/dist/tests/multi/entitlements/channelsWithComplexEntitlements.test.js.map +1 -0
- package/dist/tests/multi/entitlements/channelsWithEntitlementLoss.test.d.ts +5 -0
- package/dist/tests/multi/entitlements/channelsWithEntitlementLoss.test.d.ts.map +1 -0
- package/dist/tests/multi/entitlements/channelsWithEntitlementLoss.test.js +72 -0
- package/dist/tests/multi/entitlements/channelsWithEntitlementLoss.test.js.map +1 -0
- package/dist/tests/multi/entitlements/channelsWithEntitlements.test.d.ts +5 -0
- package/dist/tests/multi/entitlements/channelsWithEntitlements.test.d.ts.map +1 -0
- package/dist/tests/multi/entitlements/channelsWithEntitlements.test.js +51 -0
- package/dist/tests/multi/entitlements/channelsWithEntitlements.test.js.map +1 -0
- package/dist/tests/multi/entitlements/channelsWithErc20Entitlements.test.d.ts +5 -0
- package/dist/tests/multi/entitlements/channelsWithErc20Entitlements.test.d.ts.map +1 -0
- package/dist/tests/multi/entitlements/channelsWithErc20Entitlements.test.js +86 -0
- package/dist/tests/multi/entitlements/channelsWithErc20Entitlements.test.js.map +1 -0
- package/dist/tests/multi/entitlements/channelsWithErc721Entitlements.test.d.ts +5 -0
- package/dist/tests/multi/entitlements/channelsWithErc721Entitlements.test.d.ts.map +1 -0
- package/dist/tests/multi/entitlements/channelsWithErc721Entitlements.test.js +69 -0
- package/dist/tests/multi/entitlements/channelsWithErc721Entitlements.test.js.map +1 -0
- package/dist/tests/multi/entitlements/channelsWithEthBalanceEntitlements.test.d.ts +5 -0
- package/dist/tests/multi/entitlements/channelsWithEthBalanceEntitlements.test.d.ts.map +1 -0
- package/dist/tests/multi/entitlements/channelsWithEthBalanceEntitlements.test.js +145 -0
- package/dist/tests/multi/entitlements/channelsWithEthBalanceEntitlements.test.js.map +1 -0
- package/dist/tests/multi/entitlements/channelsWithUserEntitlements.test.d.ts +5 -0
- package/dist/tests/multi/entitlements/channelsWithUserEntitlements.test.d.ts.map +1 -0
- package/dist/tests/multi/entitlements/channelsWithUserEntitlements.test.js +53 -0
- package/dist/tests/multi/entitlements/channelsWithUserEntitlements.test.js.map +1 -0
- package/dist/tests/multi/entitlements/spaceWithComplexEntitlements.test.d.ts +5 -0
- package/dist/tests/multi/entitlements/spaceWithComplexEntitlements.test.d.ts.map +1 -0
- package/dist/tests/multi/entitlements/spaceWithComplexEntitlements.test.js +151 -0
- package/dist/tests/multi/entitlements/spaceWithComplexEntitlements.test.js.map +1 -0
- package/dist/tests/multi/entitlements/spaceWithEntitlements.test.d.ts +5 -0
- package/dist/tests/multi/entitlements/spaceWithEntitlements.test.d.ts.map +1 -0
- package/dist/tests/multi/entitlements/spaceWithEntitlements.test.js +101 -0
- package/dist/tests/multi/entitlements/spaceWithEntitlements.test.js.map +1 -0
- package/dist/tests/multi/entitlements/spaceWithErc20Entitlements.test.d.ts +5 -0
- package/dist/tests/multi/entitlements/spaceWithErc20Entitlements.test.d.ts.map +1 -0
- package/dist/tests/multi/entitlements/spaceWithErc20Entitlements.test.js +103 -0
- package/dist/tests/multi/entitlements/spaceWithErc20Entitlements.test.js.map +1 -0
- package/dist/tests/multi/entitlements/spaceWithErc721Entitlements.test.d.ts +5 -0
- package/dist/tests/multi/entitlements/spaceWithErc721Entitlements.test.d.ts.map +1 -0
- package/dist/tests/multi/entitlements/spaceWithErc721Entitlements.test.js +84 -0
- package/dist/tests/multi/entitlements/spaceWithErc721Entitlements.test.js.map +1 -0
- package/dist/tests/multi/entitlements/spaceWithEthBalanceEntitlements.test.d.ts +5 -0
- package/dist/tests/multi/entitlements/spaceWithEthBalanceEntitlements.test.d.ts.map +1 -0
- package/dist/tests/multi/entitlements/spaceWithEthBalanceEntitlements.test.js +168 -0
- package/dist/tests/multi/entitlements/spaceWithEthBalanceEntitlements.test.js.map +1 -0
- package/dist/tests/multi/entitlements/spaceWithThreeNestedEntitlement.test.d.ts +5 -0
- package/dist/tests/multi/entitlements/spaceWithThreeNestedEntitlement.test.d.ts.map +1 -0
- package/dist/tests/multi/entitlements/spaceWithThreeNestedEntitlement.test.js +45 -0
- package/dist/tests/multi/entitlements/spaceWithThreeNestedEntitlement.test.js.map +1 -0
- package/dist/tests/multi/entitlements/spaceWithUserEntitlements.test.d.ts +5 -0
- package/dist/tests/multi/entitlements/spaceWithUserEntitlements.test.d.ts.map +1 -0
- package/dist/tests/multi/entitlements/spaceWithUserEntitlements.test.js +79 -0
- package/dist/tests/multi/entitlements/spaceWithUserEntitlements.test.js.map +1 -0
- package/dist/tests/multi/legacySpace.test.d.ts +5 -0
- package/dist/tests/multi/legacySpace.test.d.ts.map +1 -0
- package/dist/tests/multi/legacySpace.test.js +48 -0
- package/dist/tests/multi/legacySpace.test.js.map +1 -0
- package/dist/tests/multi/mediaWithEntitlements.test.d.ts +5 -0
- package/dist/tests/multi/mediaWithEntitlements.test.d.ts.map +1 -0
- package/dist/tests/multi/mediaWithEntitlements.test.js +152 -0
- package/dist/tests/multi/mediaWithEntitlements.test.js.map +1 -0
- package/dist/tests/multi/membershipManagement.test.d.ts +5 -0
- package/dist/tests/multi/membershipManagement.test.d.ts.map +1 -0
- package/dist/tests/multi/membershipManagement.test.js +76 -0
- package/dist/tests/multi/membershipManagement.test.js.map +1 -0
- package/dist/tests/multi/notificationService.test.d.ts +2 -0
- package/dist/tests/multi/notificationService.test.d.ts.map +1 -0
- package/dist/tests/multi/notificationService.test.js +51 -0
- package/dist/tests/multi/notificationService.test.js.map +1 -0
- package/dist/tests/multi/riverAirdropDapp.test.d.ts +5 -0
- package/dist/tests/multi/riverAirdropDapp.test.d.ts.map +1 -0
- package/dist/tests/multi/riverAirdropDapp.test.js +43 -0
- package/dist/tests/multi/riverAirdropDapp.test.js.map +1 -0
- package/dist/tests/multi/spaceDapp.test.d.ts +5 -0
- package/dist/tests/multi/spaceDapp.test.d.ts.map +1 -0
- package/dist/tests/multi/spaceDapp.test.js +59 -0
- package/dist/tests/multi/spaceDapp.test.js.map +1 -0
- package/dist/tests/multi/spaceWithVariousPriceConfigurations.test.d.ts +2 -0
- package/dist/tests/multi/spaceWithVariousPriceConfigurations.test.d.ts.map +1 -0
- package/dist/tests/multi/spaceWithVariousPriceConfigurations.test.js +61 -0
- package/dist/tests/multi/spaceWithVariousPriceConfigurations.test.js.map +1 -0
- package/dist/tests/multi/sync-agent/member-queue.test.d.ts +2 -0
- package/dist/tests/multi/sync-agent/member-queue.test.d.ts.map +1 -0
- package/dist/tests/multi/sync-agent/member-queue.test.js +46 -0
- package/dist/tests/multi/sync-agent/member-queue.test.js.map +1 -0
- package/dist/tests/multi/sync-agent/member.test.d.ts +2 -0
- package/dist/tests/multi/sync-agent/member.test.d.ts.map +1 -0
- package/dist/tests/multi/sync-agent/member.test.js +45 -0
- package/dist/tests/multi/sync-agent/member.test.js.map +1 -0
- package/dist/tests/multi/sync-agent/members.test.d.ts +2 -0
- package/dist/tests/multi/sync-agent/members.test.d.ts.map +1 -0
- package/dist/tests/multi/sync-agent/members.test.js +35 -0
- package/dist/tests/multi/sync-agent/members.test.js.map +1 -0
- package/dist/tests/multi/sync-agent/riverConnection.test.d.ts +5 -0
- package/dist/tests/multi/sync-agent/riverConnection.test.d.ts.map +1 -0
- package/dist/tests/multi/sync-agent/riverConnection.test.js +49 -0
- package/dist/tests/multi/sync-agent/riverConnection.test.js.map +1 -0
- package/dist/tests/multi/sync-agent/spaces.test.d.ts +2 -0
- package/dist/tests/multi/sync-agent/spaces.test.d.ts.map +1 -0
- package/dist/tests/multi/sync-agent/spaces.test.js +33 -0
- package/dist/tests/multi/sync-agent/spaces.test.js.map +1 -0
- package/dist/tests/multi/sync-agent/streams.test.d.ts +2 -0
- package/dist/tests/multi/sync-agent/streams.test.d.ts.map +1 -0
- package/dist/tests/multi/sync-agent/streams.test.js +27 -0
- package/dist/tests/multi/sync-agent/streams.test.js.map +1 -0
- package/dist/tests/multi/sync-agent/syncAgent.test.d.ts +2 -0
- package/dist/tests/multi/sync-agent/syncAgent.test.d.ts.map +1 -0
- package/dist/tests/multi/sync-agent/syncAgent.test.js +65 -0
- package/dist/tests/multi/sync-agent/syncAgent.test.js.map +1 -0
- package/dist/tests/multi/sync-agent/syncAgents.test.d.ts +2 -0
- package/dist/tests/multi/sync-agent/syncAgents.test.d.ts.map +1 -0
- package/dist/tests/multi/sync-agent/syncAgents.test.js +160 -0
- package/dist/tests/multi/sync-agent/syncAgents.test.js.map +1 -0
- package/dist/tests/multi/sync-agent/timeline.test.d.ts +2 -0
- package/dist/tests/multi/sync-agent/timeline.test.d.ts.map +1 -0
- package/dist/tests/multi/sync-agent/timeline.test.js +220 -0
- package/dist/tests/multi/sync-agent/timeline.test.js.map +1 -0
- package/dist/tests/multi/sync-agent/user.test.d.ts +5 -0
- package/dist/tests/multi/sync-agent/user.test.d.ts.map +1 -0
- package/dist/tests/multi/sync-agent/user.test.js +55 -0
- package/dist/tests/multi/sync-agent/user.test.js.map +1 -0
- package/dist/tests/multi/transactions.test.d.ts +5 -0
- package/dist/tests/multi/transactions.test.d.ts.map +1 -0
- package/dist/tests/multi/transactions.test.js +153 -0
- package/dist/tests/multi/transactions.test.js.map +1 -0
- package/dist/tests/multi/transactions_SpaceReview.test.d.ts +2 -0
- package/dist/tests/multi/transactions_SpaceReview.test.d.ts.map +1 -0
- package/dist/tests/multi/transactions_SpaceReview.test.js +280 -0
- package/dist/tests/multi/transactions_SpaceReview.test.js.map +1 -0
- package/dist/tests/multi/transactions_Tip.test.d.ts +5 -0
- package/dist/tests/multi/transactions_Tip.test.d.ts.map +1 -0
- package/dist/tests/multi/transactions_Tip.test.js +235 -0
- package/dist/tests/multi/transactions_Tip.test.js.map +1 -0
- package/dist/tests/multi/withEntitlements.test.d.ts +5 -0
- package/dist/tests/multi/withEntitlements.test.d.ts.map +1 -0
- package/dist/tests/multi/withEntitlements.test.js +125 -0
- package/dist/tests/multi/withEntitlements.test.js.map +1 -0
- package/dist/tests/multi_ne/aliceAndFriends.test.d.ts +5 -0
- package/dist/tests/multi_ne/aliceAndFriends.test.d.ts.map +1 -0
- package/dist/tests/multi_ne/aliceAndFriends.test.js +20 -0
- package/dist/tests/multi_ne/aliceAndFriends.test.js.map +1 -0
- package/dist/tests/multi_ne/aliceAndFriends10for10.test.d.ts +5 -0
- package/dist/tests/multi_ne/aliceAndFriends10for10.test.d.ts.map +1 -0
- package/dist/tests/multi_ne/aliceAndFriends10for10.test.js +23 -0
- package/dist/tests/multi_ne/aliceAndFriends10for10.test.js.map +1 -0
- package/dist/tests/multi_ne/aliceAndFriends3for8.test.d.ts +5 -0
- package/dist/tests/multi_ne/aliceAndFriends3for8.test.d.ts.map +1 -0
- package/dist/tests/multi_ne/aliceAndFriends3for8.test.js +22 -0
- package/dist/tests/multi_ne/aliceAndFriends3for8.test.js.map +1 -0
- package/dist/tests/multi_ne/aliceAndFriendslongAndRandom.test.d.ts +5 -0
- package/dist/tests/multi_ne/aliceAndFriendslongAndRandom.test.d.ts.map +1 -0
- package/dist/tests/multi_ne/aliceAndFriendslongAndRandom.test.js +28 -0
- package/dist/tests/multi_ne/aliceAndFriendslongAndRandom.test.js.map +1 -0
- package/dist/tests/multi_ne/bobFlushes.test.d.ts +5 -0
- package/dist/tests/multi_ne/bobFlushes.test.d.ts.map +1 -0
- package/dist/tests/multi_ne/bobFlushes.test.js +20 -0
- package/dist/tests/multi_ne/bobFlushes.test.js.map +1 -0
- package/dist/tests/multi_ne/channels.test.d.ts +5 -0
- package/dist/tests/multi_ne/channels.test.d.ts.map +1 -0
- package/dist/tests/multi_ne/channels.test.js +47 -0
- package/dist/tests/multi_ne/channels.test.js.map +1 -0
- package/dist/tests/multi_ne/client.test.d.ts +5 -0
- package/dist/tests/multi_ne/client.test.d.ts.map +1 -0
- package/dist/tests/multi_ne/client.test.js +786 -0
- package/dist/tests/multi_ne/client.test.js.map +1 -0
- package/dist/tests/multi_ne/clientCrypto.test.d.ts +5 -0
- package/dist/tests/multi_ne/clientCrypto.test.d.ts.map +1 -0
- package/dist/tests/multi_ne/clientCrypto.test.js +64 -0
- package/dist/tests/multi_ne/clientCrypto.test.js.map +1 -0
- package/dist/tests/multi_ne/clientDecryptionExtensions.test.d.ts +5 -0
- package/dist/tests/multi_ne/clientDecryptionExtensions.test.d.ts.map +1 -0
- package/dist/tests/multi_ne/clientDecryptionExtensions.test.js +174 -0
- package/dist/tests/multi_ne/clientDecryptionExtensions.test.js.map +1 -0
- package/dist/tests/multi_ne/deviceKeyMessage.test.d.ts +5 -0
- package/dist/tests/multi_ne/deviceKeyMessage.test.d.ts.map +1 -0
- package/dist/tests/multi_ne/deviceKeyMessage.test.js +154 -0
- package/dist/tests/multi_ne/deviceKeyMessage.test.js.map +1 -0
- package/dist/tests/multi_ne/dms.test.d.ts +5 -0
- package/dist/tests/multi_ne/dms.test.d.ts.map +1 -0
- package/dist/tests/multi_ne/dms.test.js +131 -0
- package/dist/tests/multi_ne/dms.test.js.map +1 -0
- package/dist/tests/multi_ne/gdms.test.d.ts +5 -0
- package/dist/tests/multi_ne/gdms.test.d.ts.map +1 -0
- package/dist/tests/multi_ne/gdms.test.js +274 -0
- package/dist/tests/multi_ne/gdms.test.js.map +1 -0
- package/dist/tests/multi_ne/id.test.d.ts +5 -0
- package/dist/tests/multi_ne/id.test.d.ts.map +1 -0
- package/dist/tests/multi_ne/id.test.js +70 -0
- package/dist/tests/multi_ne/id.test.js.map +1 -0
- package/dist/tests/multi_ne/makeStreamRpcClient.test.d.ts +5 -0
- package/dist/tests/multi_ne/makeStreamRpcClient.test.d.ts.map +1 -0
- package/dist/tests/multi_ne/makeStreamRpcClient.test.js +77 -0
- package/dist/tests/multi_ne/makeStreamRpcClient.test.js.map +1 -0
- package/dist/tests/multi_ne/media.test.d.ts +5 -0
- package/dist/tests/multi_ne/media.test.d.ts.map +1 -0
- package/dist/tests/multi_ne/media.test.js +218 -0
- package/dist/tests/multi_ne/media.test.js.map +1 -0
- package/dist/tests/multi_ne/memberMetadata.test.d.ts +5 -0
- package/dist/tests/multi_ne/memberMetadata.test.d.ts.map +1 -0
- package/dist/tests/multi_ne/memberMetadata.test.js +545 -0
- package/dist/tests/multi_ne/memberMetadata.test.js.map +1 -0
- package/dist/tests/multi_ne/memberMetadata_DisplayNames.test.d.ts +5 -0
- package/dist/tests/multi_ne/memberMetadata_DisplayNames.test.d.ts.map +1 -0
- package/dist/tests/multi_ne/memberMetadata_DisplayNames.test.js +54 -0
- package/dist/tests/multi_ne/memberMetadata_DisplayNames.test.js.map +1 -0
- package/dist/tests/multi_ne/memberMetadata_EnsAddresses.test.d.ts +5 -0
- package/dist/tests/multi_ne/memberMetadata_EnsAddresses.test.d.ts.map +1 -0
- package/dist/tests/multi_ne/memberMetadata_EnsAddresses.test.js +37 -0
- package/dist/tests/multi_ne/memberMetadata_EnsAddresses.test.js.map +1 -0
- package/dist/tests/multi_ne/memberMetadata_Nft.test.d.ts +5 -0
- package/dist/tests/multi_ne/memberMetadata_Nft.test.d.ts.map +1 -0
- package/dist/tests/multi_ne/memberMetadata_Nft.test.js +49 -0
- package/dist/tests/multi_ne/memberMetadata_Nft.test.js.map +1 -0
- package/dist/tests/multi_ne/memberMetadata_Usernames.test.d.ts +5 -0
- package/dist/tests/multi_ne/memberMetadata_Usernames.test.d.ts.map +1 -0
- package/dist/tests/multi_ne/memberMetadata_Usernames.test.js +113 -0
- package/dist/tests/multi_ne/memberMetadata_Usernames.test.js.map +1 -0
- package/dist/tests/multi_ne/nodeSelection.test.d.ts +5 -0
- package/dist/tests/multi_ne/nodeSelection.test.d.ts.map +1 -0
- package/dist/tests/multi_ne/nodeSelection.test.js +41 -0
- package/dist/tests/multi_ne/nodeSelection.test.js.map +1 -0
- package/dist/tests/multi_ne/outboundGroupSession.test.d.ts +5 -0
- package/dist/tests/multi_ne/outboundGroupSession.test.d.ts.map +1 -0
- package/dist/tests/multi_ne/outboundGroupSession.test.js +107 -0
- package/dist/tests/multi_ne/outboundGroupSession.test.js.map +1 -0
- package/dist/tests/multi_ne/persistenceStore.test.d.ts +5 -0
- package/dist/tests/multi_ne/persistenceStore.test.d.ts.map +1 -0
- package/dist/tests/multi_ne/persistenceStore.test.js +27 -0
- package/dist/tests/multi_ne/persistenceStore.test.js.map +1 -0
- package/dist/tests/multi_ne/restart.test.d.ts +4 -0
- package/dist/tests/multi_ne/restart.test.d.ts.map +1 -0
- package/dist/tests/multi_ne/restart.test.js +161 -0
- package/dist/tests/multi_ne/restart.test.js.map +1 -0
- package/dist/tests/multi_ne/sign.test.d.ts +5 -0
- package/dist/tests/multi_ne/sign.test.d.ts.map +1 -0
- package/dist/tests/multi_ne/sign.test.js +218 -0
- package/dist/tests/multi_ne/sign.test.js.map +1 -0
- package/dist/tests/multi_ne/space.test.d.ts +5 -0
- package/dist/tests/multi_ne/space.test.d.ts.map +1 -0
- package/dist/tests/multi_ne/space.test.js +190 -0
- package/dist/tests/multi_ne/space.test.js.map +1 -0
- package/dist/tests/multi_ne/streamMembershipHardening.test.d.ts +5 -0
- package/dist/tests/multi_ne/streamMembershipHardening.test.d.ts.map +1 -0
- package/dist/tests/multi_ne/streamMembershipHardening.test.js +30 -0
- package/dist/tests/multi_ne/streamMembershipHardening.test.js.map +1 -0
- package/dist/tests/multi_ne/streamRpcClient.test.d.ts +5 -0
- package/dist/tests/multi_ne/streamRpcClient.test.d.ts.map +1 -0
- package/dist/tests/multi_ne/streamRpcClient.test.js +559 -0
- package/dist/tests/multi_ne/streamRpcClient.test.js.map +1 -0
- package/dist/tests/multi_ne/streamRpcClientGetSince.test.d.ts +2 -0
- package/dist/tests/multi_ne/streamRpcClientGetSince.test.d.ts.map +1 -0
- package/dist/tests/multi_ne/streamRpcClientGetSince.test.js +105 -0
- package/dist/tests/multi_ne/streamRpcClientGetSince.test.js.map +1 -0
- package/dist/tests/multi_ne/streamRpcClientSync.test.d.ts +5 -0
- package/dist/tests/multi_ne/streamRpcClientSync.test.d.ts.map +1 -0
- package/dist/tests/multi_ne/streamRpcClientSync.test.js +199 -0
- package/dist/tests/multi_ne/streamRpcClientSync.test.js.map +1 -0
- package/dist/tests/multi_ne/streamStateView_User.test.d.ts +5 -0
- package/dist/tests/multi_ne/streamStateView_User.test.d.ts.map +1 -0
- package/dist/tests/multi_ne/streamStateView_User.test.js +31 -0
- package/dist/tests/multi_ne/streamStateView_User.test.js.map +1 -0
- package/dist/tests/multi_ne/syncWithBlocks.test.d.ts +2 -0
- package/dist/tests/multi_ne/syncWithBlocks.test.d.ts.map +1 -0
- package/dist/tests/multi_ne/syncWithBlocks.test.js +155 -0
- package/dist/tests/multi_ne/syncWithBlocks.test.js.map +1 -0
- package/dist/tests/multi_ne/syncedStream.test.d.ts +5 -0
- package/dist/tests/multi_ne/syncedStream.test.d.ts.map +1 -0
- package/dist/tests/multi_ne/syncedStream.test.js +62 -0
- package/dist/tests/multi_ne/syncedStream.test.js.map +1 -0
- package/dist/tests/multi_ne/syncedStreams.test.d.ts +5 -0
- package/dist/tests/multi_ne/syncedStreams.test.d.ts.map +1 -0
- package/dist/tests/multi_ne/syncedStreams.test.js +504 -0
- package/dist/tests/multi_ne/syncedStreams.test.js.map +1 -0
- package/dist/tests/multi_ne/tags.test.d.ts +2 -0
- package/dist/tests/multi_ne/tags.test.d.ts.map +1 -0
- package/dist/tests/multi_ne/tags.test.js +186 -0
- package/dist/tests/multi_ne/tags.test.js.map +1 -0
- package/dist/tests/multi_ne/trading.solana.test.d.ts +2 -0
- package/dist/tests/multi_ne/trading.solana.test.d.ts.map +1 -0
- package/dist/tests/multi_ne/trading.solana.test.js +229 -0
- package/dist/tests/multi_ne/trading.solana.test.js.map +1 -0
- package/dist/tests/multi_ne/trading.test.d.ts +2 -0
- package/dist/tests/multi_ne/trading.test.d.ts.map +1 -0
- package/dist/tests/multi_ne/trading.test.js +243 -0
- package/dist/tests/multi_ne/trading.test.js.map +1 -0
- package/dist/tests/multi_ne/userInboxMessage.test.d.ts +5 -0
- package/dist/tests/multi_ne/userInboxMessage.test.d.ts.map +1 -0
- package/dist/tests/multi_ne/userInboxMessage.test.js +56 -0
- package/dist/tests/multi_ne/userInboxMessage.test.js.map +1 -0
- package/dist/tests/multi_ne/userSettings.test.d.ts +5 -0
- package/dist/tests/multi_ne/userSettings.test.d.ts.map +1 -0
- package/dist/tests/multi_ne/userSettings.test.js +116 -0
- package/dist/tests/multi_ne/userSettings.test.js.map +1 -0
- package/dist/tests/multi_ne/workflows.test.d.ts +5 -0
- package/dist/tests/multi_ne/workflows.test.d.ts.map +1 -0
- package/dist/tests/multi_ne/workflows.test.js +88 -0
- package/dist/tests/multi_ne/workflows.test.js.map +1 -0
- package/dist/tests/multi_v2/entitlements/channelsWithCrossChainEntitlements.test.d.ts +6 -0
- package/dist/tests/multi_v2/entitlements/channelsWithCrossChainEntitlements.test.d.ts.map +1 -0
- package/dist/tests/multi_v2/entitlements/channelsWithCrossChainEntitlements.test.js +78 -0
- package/dist/tests/multi_v2/entitlements/channelsWithCrossChainEntitlements.test.js.map +1 -0
- package/dist/tests/multi_v2/entitlements/channelsWithErc1155Entitlement.test.d.ts +6 -0
- package/dist/tests/multi_v2/entitlements/channelsWithErc1155Entitlement.test.d.ts.map +1 -0
- package/dist/tests/multi_v2/entitlements/channelsWithErc1155Entitlement.test.js +89 -0
- package/dist/tests/multi_v2/entitlements/channelsWithErc1155Entitlement.test.js.map +1 -0
- package/dist/tests/multi_v2/entitlements/spaceWithCrossChainEntitlements.test.d.ts +6 -0
- package/dist/tests/multi_v2/entitlements/spaceWithCrossChainEntitlements.test.d.ts.map +1 -0
- package/dist/tests/multi_v2/entitlements/spaceWithCrossChainEntitlements.test.js +88 -0
- package/dist/tests/multi_v2/entitlements/spaceWithCrossChainEntitlements.test.js.map +1 -0
- package/dist/tests/multi_v2/entitlements/spaceWithErc1155Entitlements.test.d.ts +6 -0
- package/dist/tests/multi_v2/entitlements/spaceWithErc1155Entitlements.test.d.ts.map +1 -0
- package/dist/tests/multi_v2/entitlements/spaceWithErc1155Entitlements.test.js +105 -0
- package/dist/tests/multi_v2/entitlements/spaceWithErc1155Entitlements.test.js.map +1 -0
- package/dist/tests/multi_v2/updateRole.test.d.ts +5 -0
- package/dist/tests/multi_v2/updateRole.test.d.ts.map +1 -0
- package/dist/tests/multi_v2/updateRole.test.js +25 -0
- package/dist/tests/multi_v2/updateRole.test.js.map +1 -0
- package/dist/tests/syncAgent_testUtils.d.ts +10 -0
- package/dist/tests/syncAgent_testUtils.d.ts.map +1 -0
- package/dist/tests/syncAgent_testUtils.js +41 -0
- package/dist/tests/syncAgent_testUtils.js.map +1 -0
- package/dist/tests/testDriver_testUtils.d.ts +2 -0
- package/dist/tests/testDriver_testUtils.d.ts.map +1 -0
- package/dist/tests/testDriver_testUtils.js +157 -0
- package/dist/tests/testDriver_testUtils.js.map +1 -0
- package/dist/tests/testUtils.d.ts +188 -0
- package/dist/tests/testUtils.d.ts.map +1 -0
- package/dist/tests/testUtils.js +1026 -0
- package/dist/tests/testUtils.js.map +1 -0
- package/dist/tests/unit/crypto.test.d.ts +5 -0
- package/dist/tests/unit/crypto.test.d.ts.map +1 -0
- package/dist/tests/unit/crypto.test.js +109 -0
- package/dist/tests/unit/crypto.test.js.map +1 -0
- package/dist/tests/unit/crypto_utils.test.d.ts +5 -0
- package/dist/tests/unit/crypto_utils.test.d.ts.map +1 -0
- package/dist/tests/unit/crypto_utils.test.js +35 -0
- package/dist/tests/unit/crypto_utils.test.js.map +1 -0
- package/dist/tests/unit/decorators.test.d.ts +2 -0
- package/dist/tests/unit/decorators.test.d.ts.map +1 -0
- package/dist/tests/unit/decorators.test.js +76 -0
- package/dist/tests/unit/decorators.test.js.map +1 -0
- package/dist/tests/unit/snapshotMigration0000.test.d.ts +2 -0
- package/dist/tests/unit/snapshotMigration0000.test.d.ts.map +1 -0
- package/dist/tests/unit/snapshotMigration0000.test.js +12 -0
- package/dist/tests/unit/snapshotMigration0000.test.js.map +1 -0
- package/dist/tests/unit/snapshotMigration0001.test.d.ts +2 -0
- package/dist/tests/unit/snapshotMigration0001.test.d.ts.map +1 -0
- package/dist/tests/unit/snapshotMigration0001.test.js +63 -0
- package/dist/tests/unit/snapshotMigration0001.test.js.map +1 -0
- package/dist/tests/unit/snapshotMigration0002.test.d.ts +2 -0
- package/dist/tests/unit/snapshotMigration0002.test.d.ts.map +1 -0
- package/dist/tests/unit/snapshotMigration0002.test.js +31 -0
- package/dist/tests/unit/snapshotMigration0002.test.js.map +1 -0
- package/dist/tests/unit/store.test.d.ts +2 -0
- package/dist/tests/unit/store.test.d.ts.map +1 -0
- package/dist/tests/unit/store.test.js +47 -0
- package/dist/tests/unit/store.test.js.map +1 -0
- package/dist/tests/unit/testUtils.test.d.ts +5 -0
- package/dist/tests/unit/testUtils.test.d.ts.map +1 -0
- package/dist/tests/unit/testUtils.test.js +65 -0
- package/dist/tests/unit/testUtils.test.js.map +1 -0
- package/dist/types.d.ts +168 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +659 -0
- package/dist/types.js.map +1 -0
- package/dist/unauthenticatedClient.d.ts +26 -0
- package/dist/unauthenticatedClient.d.ts.map +1 -0
- package/dist/unauthenticatedClient.js +156 -0
- package/dist/unauthenticatedClient.js.map +1 -0
- package/dist/utils.d.ts +28 -0
- package/dist/utils.d.ts.map +1 -0
- package/dist/utils.js +99 -0
- package/dist/utils.js.map +1 -0
- package/package.json +70 -0
|
@@ -0,0 +1,97 @@
|
|
|
1
|
+
import { addressFromUserId } from '../../../id';
|
|
2
|
+
export class Myself {
|
|
3
|
+
member;
|
|
4
|
+
streamId;
|
|
5
|
+
riverConnection;
|
|
6
|
+
constructor(member, streamId, riverConnection) {
|
|
7
|
+
this.member = member;
|
|
8
|
+
this.streamId = streamId;
|
|
9
|
+
this.riverConnection = riverConnection;
|
|
10
|
+
}
|
|
11
|
+
get userId() {
|
|
12
|
+
return this.member.data.userId;
|
|
13
|
+
}
|
|
14
|
+
get username() {
|
|
15
|
+
return this.member.username;
|
|
16
|
+
}
|
|
17
|
+
get displayName() {
|
|
18
|
+
return this.member.displayName;
|
|
19
|
+
}
|
|
20
|
+
get ensAddress() {
|
|
21
|
+
return this.member.ensAddress;
|
|
22
|
+
}
|
|
23
|
+
get nft() {
|
|
24
|
+
return this.member.nft;
|
|
25
|
+
}
|
|
26
|
+
get membership() {
|
|
27
|
+
return this.member.membership;
|
|
28
|
+
}
|
|
29
|
+
async setUsername(username) {
|
|
30
|
+
const streamId = this.streamId;
|
|
31
|
+
const oldData = {
|
|
32
|
+
username: this.member.data.username,
|
|
33
|
+
isUsernameConfirmed: this.member.data.isUsernameConfirmed,
|
|
34
|
+
isUsernameEncrypted: this.member.data.isUsernameEncrypted,
|
|
35
|
+
};
|
|
36
|
+
this.member.setData({ username, isUsernameConfirmed: true, isUsernameEncrypted: false });
|
|
37
|
+
return this.riverConnection
|
|
38
|
+
.withStream(streamId)
|
|
39
|
+
.call((client) => client.setUsername(streamId, username))
|
|
40
|
+
.catch((e) => {
|
|
41
|
+
this.member.setData(oldData);
|
|
42
|
+
throw e;
|
|
43
|
+
});
|
|
44
|
+
}
|
|
45
|
+
async setDisplayName(displayName) {
|
|
46
|
+
const streamId = this.streamId;
|
|
47
|
+
const oldData = {
|
|
48
|
+
displayName: this.member.data.displayName,
|
|
49
|
+
isDisplayNameEncrypted: this.member.data.isDisplayNameEncrypted,
|
|
50
|
+
};
|
|
51
|
+
this.member.setData({ displayName, isDisplayNameEncrypted: false });
|
|
52
|
+
return this.riverConnection
|
|
53
|
+
.withStream(streamId)
|
|
54
|
+
.call((client) => client.setDisplayName(streamId, displayName))
|
|
55
|
+
.catch((e) => {
|
|
56
|
+
this.member.setData(oldData);
|
|
57
|
+
throw e;
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
async setEnsAddress(ensAddress) {
|
|
61
|
+
const streamId = this.streamId;
|
|
62
|
+
const oldData = {
|
|
63
|
+
ensAddress: this.member.data.ensAddress,
|
|
64
|
+
};
|
|
65
|
+
this.member.setData({ ensAddress });
|
|
66
|
+
const bytes = addressFromUserId(ensAddress);
|
|
67
|
+
return this.riverConnection
|
|
68
|
+
.withStream(streamId)
|
|
69
|
+
.call((client) => client.setEnsAddress(streamId, bytes))
|
|
70
|
+
.catch((e) => {
|
|
71
|
+
this.member.setData(oldData);
|
|
72
|
+
throw e;
|
|
73
|
+
});
|
|
74
|
+
}
|
|
75
|
+
async setNft(nft) {
|
|
76
|
+
const streamId = this.streamId;
|
|
77
|
+
const oldData = {
|
|
78
|
+
nft: this.member.data.nft,
|
|
79
|
+
};
|
|
80
|
+
const { contractAddress, tokenId, chainId } = nft;
|
|
81
|
+
this.member.setData({
|
|
82
|
+
nft: {
|
|
83
|
+
contractAddress,
|
|
84
|
+
tokenId,
|
|
85
|
+
chainId,
|
|
86
|
+
},
|
|
87
|
+
});
|
|
88
|
+
return this.riverConnection
|
|
89
|
+
.withStream(streamId)
|
|
90
|
+
.call((client) => client.setNft(streamId, nft.tokenId, nft.chainId, nft.contractAddress))
|
|
91
|
+
.catch((e) => {
|
|
92
|
+
this.member.setData(oldData);
|
|
93
|
+
throw e;
|
|
94
|
+
});
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
//# sourceMappingURL=myself.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"myself.js","sourceRoot":"","sources":["../../../../src/sync-agent/members/models/myself.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
export declare enum AuthStatus {
|
|
2
|
+
/** Fetching river urls. */
|
|
3
|
+
Initializing = "Initializing",
|
|
4
|
+
/** Transition state: None -\> EvaluatingCredentials -\> [Credentialed OR ConnectedToRiver]
|
|
5
|
+
* if a river user is found, will connect to river client, otherwise will just validate credentials.
|
|
6
|
+
*/
|
|
7
|
+
EvaluatingCredentials = "EvaluatingCredentials",
|
|
8
|
+
/** User authenticated with a valid credential but without an active river stream client. */
|
|
9
|
+
Credentialed = "Credentialed",
|
|
10
|
+
/** User authenticated with a valid credential and with an active river river client. */
|
|
11
|
+
ConnectingToRiver = "ConnectingToRiver",
|
|
12
|
+
ConnectedToRiver = "ConnectedToRiver",
|
|
13
|
+
/** Disconnected, client was stopped */
|
|
14
|
+
Disconnected = "Disconnected",
|
|
15
|
+
/** Error state: User failed to authenticate or connect to river client. */
|
|
16
|
+
Error = "Error"
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=authStatus.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"authStatus.d.ts","sourceRoot":"","sources":["../../../../src/sync-agent/river-connection/models/authStatus.ts"],"names":[],"mappings":"AAAA,oBAAY,UAAU;IAClB,2BAA2B;IAC3B,YAAY,iBAAiB;IAC7B;;OAEG;IACH,qBAAqB,0BAA0B;IAC/C,4FAA4F;IAC5F,YAAY,iBAAiB;IAC7B,wFAAwF;IACxF,iBAAiB,sBAAsB;IACvC,gBAAgB,qBAAqB;IACrC,uCAAuC;IACvC,YAAY,iBAAiB;IAC7B,2EAA2E;IAC3E,KAAK,UAAU;CAClB"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
export var AuthStatus;
|
|
2
|
+
(function (AuthStatus) {
|
|
3
|
+
/** Fetching river urls. */
|
|
4
|
+
AuthStatus["Initializing"] = "Initializing";
|
|
5
|
+
/** Transition state: None -\> EvaluatingCredentials -\> [Credentialed OR ConnectedToRiver]
|
|
6
|
+
* if a river user is found, will connect to river client, otherwise will just validate credentials.
|
|
7
|
+
*/
|
|
8
|
+
AuthStatus["EvaluatingCredentials"] = "EvaluatingCredentials";
|
|
9
|
+
/** User authenticated with a valid credential but without an active river stream client. */
|
|
10
|
+
AuthStatus["Credentialed"] = "Credentialed";
|
|
11
|
+
/** User authenticated with a valid credential and with an active river river client. */
|
|
12
|
+
AuthStatus["ConnectingToRiver"] = "ConnectingToRiver";
|
|
13
|
+
AuthStatus["ConnectedToRiver"] = "ConnectedToRiver";
|
|
14
|
+
/** Disconnected, client was stopped */
|
|
15
|
+
AuthStatus["Disconnected"] = "Disconnected";
|
|
16
|
+
/** Error state: User failed to authenticate or connect to river client. */
|
|
17
|
+
AuthStatus["Error"] = "Error";
|
|
18
|
+
})(AuthStatus || (AuthStatus = {}));
|
|
19
|
+
//# sourceMappingURL=authStatus.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"authStatus.js","sourceRoot":"","sources":["../../../../src/sync-agent/river-connection/models/authStatus.ts"],"names":[],"mappings":"AAAA,MAAM,CAAN,IAAY,UAgBX;AAhBD,WAAY,UAAU;IAClB,2BAA2B;IAC3B,2CAA6B,CAAA;IAC7B;;OAEG;IACH,6DAA+C,CAAA;IAC/C,4FAA4F;IAC5F,2CAA6B,CAAA;IAC7B,wFAAwF;IACxF,qDAAuC,CAAA;IACvC,mDAAqC,CAAA;IACrC,uCAAuC;IACvC,2CAA6B,CAAA;IAC7B,2EAA2E;IAC3E,6BAAe,CAAA;AACnB,CAAC,EAhBW,UAAU,KAAV,UAAU,QAgBrB"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { RiverRegistry } from '@towns-protocol/web3';
|
|
2
|
+
import { PersistedObservable } from '../../../observable/persistedObservable';
|
|
3
|
+
import { Store } from '../../../store/store';
|
|
4
|
+
export interface RiverChainModel {
|
|
5
|
+
id: '0';
|
|
6
|
+
urls: {
|
|
7
|
+
value: string;
|
|
8
|
+
fetchedAtMs?: number;
|
|
9
|
+
};
|
|
10
|
+
streamExists: Record<string, {
|
|
11
|
+
fetchedAtMs: number;
|
|
12
|
+
exists: boolean;
|
|
13
|
+
}>;
|
|
14
|
+
}
|
|
15
|
+
export declare class RiverChain extends PersistedObservable<RiverChainModel> {
|
|
16
|
+
private riverRegistryDapp;
|
|
17
|
+
private userId;
|
|
18
|
+
private log;
|
|
19
|
+
private sessionStartMs;
|
|
20
|
+
private stopped;
|
|
21
|
+
constructor(store: Store, riverRegistryDapp: RiverRegistry, userId: string, logId: string);
|
|
22
|
+
protected onLoaded(): void;
|
|
23
|
+
stop(): void;
|
|
24
|
+
urls(): Promise<string>;
|
|
25
|
+
userStreamExists(): Promise<boolean>;
|
|
26
|
+
fetchUrls(): Promise<string>;
|
|
27
|
+
fetchStreamExists(streamId: string): Promise<boolean>;
|
|
28
|
+
private withInfiniteRetries;
|
|
29
|
+
}
|
|
30
|
+
//# sourceMappingURL=riverChain.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"riverChain.d.ts","sourceRoot":"","sources":["../../../../src/sync-agent/river-connection/models/riverChain.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAA;AACpD,OAAO,EAAE,mBAAmB,EAAuB,MAAM,yCAAyC,CAAA;AAClG,OAAO,EAAgB,KAAK,EAAE,MAAM,sBAAsB,CAAA;AAO1D,MAAM,WAAW,eAAe;IAC5B,EAAE,EAAE,GAAG,CAAA;IAEP,IAAI,EAAE;QACF,KAAK,EAAE,MAAM,CAAA;QACb,WAAW,CAAC,EAAE,MAAM,CAAA;KACvB,CAAA;IACD,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE;QAAE,WAAW,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,OAAO,CAAA;KAAE,CAAC,CAAA;CACzE;AAGD,qBAGa,UAAW,SAAQ,mBAAmB,CAAC,eAAe,CAAC;IAO5D,OAAO,CAAC,iBAAiB;IACzB,OAAO,CAAC,MAAM;IAPlB,OAAO,CAAC,GAAG,CAAgB;IAC3B,OAAO,CAAC,cAAc,CAAa;IACnC,OAAO,CAAC,OAAO,CAAQ;gBAGnB,KAAK,EAAE,KAAK,EACJ,iBAAiB,EAAE,aAAa,EAChC,MAAM,EAAE,MAAM,EACtB,KAAK,EAAE,MAAM;cASE,QAAQ;IAM3B,IAAI;IAIE,IAAI,IAAI,OAAO,CAAC,MAAM,CAAC;IAQvB,gBAAgB,IAAI,OAAO,CAAC,OAAO,CAAC;IAWpC,SAAS,IAAI,OAAO,CAAC,MAAM,CAAC;IAO5B,iBAAiB,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAgB3D,OAAO,CAAC,mBAAmB;CAY9B"}
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
import { PersistedObservable, persistedObservable } from '../../../observable/persistedObservable';
|
|
8
|
+
import { LoadPriority } from '../../../store/store';
|
|
9
|
+
import { dlogger } from '@towns-protocol/dlog';
|
|
10
|
+
import { makeUserStreamId, streamIdAsBytes } from '../../../id';
|
|
11
|
+
// Define a class that will manage the data model, decorate it to give it store properties
|
|
12
|
+
let RiverChain = class RiverChain extends PersistedObservable {
|
|
13
|
+
riverRegistryDapp;
|
|
14
|
+
userId;
|
|
15
|
+
log;
|
|
16
|
+
sessionStartMs = Date.now();
|
|
17
|
+
stopped = false;
|
|
18
|
+
// The constructor is where we set up the class, we pass in the store and any other dependencies
|
|
19
|
+
constructor(store, riverRegistryDapp, userId, logId) {
|
|
20
|
+
// pass a default value to the parent class, this is what will be used if the data is not loaded
|
|
21
|
+
// set the load priority to high, this will load first
|
|
22
|
+
super({ id: '0', urls: { value: '' }, streamExists: {} }, store, LoadPriority.high);
|
|
23
|
+
this.riverRegistryDapp = riverRegistryDapp;
|
|
24
|
+
this.userId = userId;
|
|
25
|
+
this.log = dlogger(`csb:agent:riverChain:${logId}`);
|
|
26
|
+
}
|
|
27
|
+
// implement start function then wire it up from parent
|
|
28
|
+
onLoaded() {
|
|
29
|
+
this.log.info('riverChain onLoaded');
|
|
30
|
+
this.withInfiniteRetries(() => this.fetchUrls());
|
|
31
|
+
this.withInfiniteRetries(() => this.fetchStreamExists(makeUserStreamId(this.userId)));
|
|
32
|
+
}
|
|
33
|
+
stop() {
|
|
34
|
+
this.stopped = true;
|
|
35
|
+
}
|
|
36
|
+
async urls() {
|
|
37
|
+
// urls is returning the cached data if it exists, otherwise waiting for the data to be fetched
|
|
38
|
+
// if the cached data returns a stale node url, the startup will fail
|
|
39
|
+
// nodes almost never exit the network, so this is a very rare case
|
|
40
|
+
await this.when((x) => x.data.urls.fetchedAtMs !== undefined, { timeoutMs: 15000 });
|
|
41
|
+
return this.data.urls.value;
|
|
42
|
+
}
|
|
43
|
+
async userStreamExists() {
|
|
44
|
+
// user stream exists is returning the cached data if it exists,
|
|
45
|
+
// otherwise waiting for new data to be fetched by comparing fetchedAtMs against sessionStartMs
|
|
46
|
+
const streamId = makeUserStreamId(this.userId);
|
|
47
|
+
await this.when((x) => {
|
|
48
|
+
const entry = x.data.streamExists[streamId];
|
|
49
|
+
return entry && (entry.exists || entry.fetchedAtMs >= this.sessionStartMs);
|
|
50
|
+
});
|
|
51
|
+
return this.data.streamExists[streamId]?.exists;
|
|
52
|
+
}
|
|
53
|
+
async fetchUrls() {
|
|
54
|
+
const now = Date.now();
|
|
55
|
+
const urls = await this.riverRegistryDapp.getOperationalNodeUrls(); // here we are fetching the node urls
|
|
56
|
+
this.setData({ urls: { value: urls, fetchedAtMs: now } }); // if the data is new, update our own state
|
|
57
|
+
return urls;
|
|
58
|
+
}
|
|
59
|
+
async fetchStreamExists(streamId) {
|
|
60
|
+
if (this.data.streamExists[streamId]?.exists === true) {
|
|
61
|
+
return true;
|
|
62
|
+
}
|
|
63
|
+
const streamIdBytes = streamIdAsBytes(streamId);
|
|
64
|
+
const now = Date.now();
|
|
65
|
+
const exists = await this.riverRegistryDapp.streamExists(streamIdBytes);
|
|
66
|
+
this.setData({
|
|
67
|
+
streamExists: {
|
|
68
|
+
...this.data.streamExists,
|
|
69
|
+
[streamId]: { exists, fetchedAtMs: now },
|
|
70
|
+
},
|
|
71
|
+
});
|
|
72
|
+
return exists;
|
|
73
|
+
}
|
|
74
|
+
withInfiniteRetries(fn, delayMs = 5000) {
|
|
75
|
+
if (this.stopped) {
|
|
76
|
+
return;
|
|
77
|
+
}
|
|
78
|
+
fn().catch((e) => {
|
|
79
|
+
this.log.error(e);
|
|
80
|
+
this.log.info(`retrying in ${delayMs / 1000} seconds`);
|
|
81
|
+
setTimeout(() => {
|
|
82
|
+
this.withInfiniteRetries(fn, delayMs);
|
|
83
|
+
}, delayMs);
|
|
84
|
+
});
|
|
85
|
+
}
|
|
86
|
+
};
|
|
87
|
+
RiverChain = __decorate([
|
|
88
|
+
persistedObservable({
|
|
89
|
+
tableName: 'riverChain', // this is the name of the table in the database
|
|
90
|
+
})
|
|
91
|
+
], RiverChain);
|
|
92
|
+
export { RiverChain };
|
|
93
|
+
//# sourceMappingURL=riverChain.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"riverChain.js","sourceRoot":"","sources":["../../../../src/sync-agent/river-connection/models/riverChain.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { CryptoStore, EntitlementsDelegate } from '@towns-protocol/encryption';
|
|
2
|
+
import { Client, ClientEvents, ClientOptions } from '../../../client';
|
|
3
|
+
import { StreamRpcClient } from '../../../makeStreamRpcClient';
|
|
4
|
+
import { SignerContext } from '../../../signerContext';
|
|
5
|
+
import { Store } from '../../../store/store';
|
|
6
|
+
export declare class TransactionalClient extends Client {
|
|
7
|
+
store: Store;
|
|
8
|
+
constructor(store: Store, signerContext: SignerContext, rpcClient: StreamRpcClient, cryptoStore: CryptoStore, entitlementsDelegate: EntitlementsDelegate, opts?: ClientOptions);
|
|
9
|
+
emit<E extends keyof ClientEvents>(event: E, ...args: Parameters<ClientEvents[E]>): boolean;
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=transactionalClient.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"transactionalClient.d.ts","sourceRoot":"","sources":["../../../../src/sync-agent/river-connection/models/transactionalClient.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,oBAAoB,EAAE,MAAM,4BAA4B,CAAA;AAC9E,OAAO,EAAE,MAAM,EAAE,YAAY,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAA;AACrE,OAAO,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAA;AAC9D,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAA;AACtD,OAAO,EAAE,KAAK,EAAE,MAAM,sBAAsB,CAAA;AAE5C,qBAAa,mBAAoB,SAAQ,MAAM;IAC3C,KAAK,EAAE,KAAK,CAAA;gBAER,KAAK,EAAE,KAAK,EACZ,aAAa,EAAE,aAAa,EAC5B,SAAS,EAAE,eAAe,EAC1B,WAAW,EAAE,WAAW,EACxB,oBAAoB,EAAE,oBAAoB,EAC1C,IAAI,CAAC,EAAE,aAAa;IAMf,IAAI,CAAC,CAAC,SAAS,MAAM,YAAY,EACtC,KAAK,EAAE,CAAC,EACR,GAAG,IAAI,EAAE,UAAU,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,GACrC,OAAO;CAKb"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { Client } from '../../../client';
|
|
2
|
+
export class TransactionalClient extends Client {
|
|
3
|
+
store;
|
|
4
|
+
constructor(store, signerContext, rpcClient, cryptoStore, entitlementsDelegate, opts) {
|
|
5
|
+
super(signerContext, rpcClient, cryptoStore, entitlementsDelegate, opts);
|
|
6
|
+
this.store = store;
|
|
7
|
+
}
|
|
8
|
+
emit(event, ...args) {
|
|
9
|
+
return this.store.withTransaction(event.toLocaleString(), () => {
|
|
10
|
+
return super.emit(event, ...args);
|
|
11
|
+
});
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=transactionalClient.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"transactionalClient.js","sourceRoot":"","sources":["../../../../src/sync-agent/river-connection/models/transactionalClient.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAA+B,MAAM,iBAAiB,CAAA;AAKrE,MAAM,OAAO,mBAAoB,SAAQ,MAAM;IAC3C,KAAK,CAAO;IACZ,YACI,KAAY,EACZ,aAA4B,EAC5B,SAA0B,EAC1B,WAAwB,EACxB,oBAA0C,EAC1C,IAAoB;QAEpB,KAAK,CAAC,aAAa,EAAE,SAAS,EAAE,WAAW,EAAE,oBAAoB,EAAE,IAAI,CAAC,CAAA;QACxE,IAAI,CAAC,KAAK,GAAG,KAAK,CAAA;IACtB,CAAC;IAEQ,IAAI,CACT,KAAQ,EACR,GAAG,IAAiC;QAEpC,OAAO,IAAI,CAAC,KAAK,CAAC,eAAe,CAAC,KAAK,CAAC,cAAc,EAAE,EAAE,GAAG,EAAE;YAC3D,OAAO,KAAK,CAAC,IAAI,CAAC,KAAK,EAAE,GAAG,IAAI,CAAC,CAAA;QACrC,CAAC,CAAC,CAAA;IACN,CAAC;CACJ"}
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
import { RiverRegistry, SpaceDapp } from '@towns-protocol/web3';
|
|
2
|
+
import { RiverChain } from './models/riverChain';
|
|
3
|
+
import { Identifiable, Store } from '../../store/store';
|
|
4
|
+
import { CryptoStore, EntitlementsDelegate, type EncryptionDeviceInitOpts } from '@towns-protocol/encryption';
|
|
5
|
+
import { Client, ClientOptions } from '../../client';
|
|
6
|
+
import { SignerContext } from '../../signerContext';
|
|
7
|
+
import { PersistedObservable } from '../../observable/persistedObservable';
|
|
8
|
+
import { TransactionalClient } from './models/transactionalClient';
|
|
9
|
+
import { Observable } from '../../observable/observable';
|
|
10
|
+
import { AuthStatus } from './models/authStatus';
|
|
11
|
+
import { RetryParams } from '../../rpcInterceptors';
|
|
12
|
+
import { Stream } from '../../stream';
|
|
13
|
+
export interface ClientParams {
|
|
14
|
+
signerContext: SignerContext;
|
|
15
|
+
cryptoStore: CryptoStore;
|
|
16
|
+
entitlementsDelegate: EntitlementsDelegate;
|
|
17
|
+
opts?: ClientOptions;
|
|
18
|
+
encryptionDevice?: EncryptionDeviceInitOpts;
|
|
19
|
+
onTokenExpired?: () => void;
|
|
20
|
+
rpcRetryParams?: RetryParams;
|
|
21
|
+
}
|
|
22
|
+
export type OnStoppedFn = () => void;
|
|
23
|
+
export type onClientStartedFn = (client: Client) => OnStoppedFn;
|
|
24
|
+
export interface RiverConnectionModel extends Identifiable {
|
|
25
|
+
id: '0';
|
|
26
|
+
userExists: boolean;
|
|
27
|
+
}
|
|
28
|
+
export declare class RiverConnection extends PersistedObservable<RiverConnectionModel> {
|
|
29
|
+
spaceDapp: SpaceDapp;
|
|
30
|
+
riverRegistryDapp: RiverRegistry;
|
|
31
|
+
clientParams: ClientParams;
|
|
32
|
+
client?: TransactionalClient;
|
|
33
|
+
riverChain: RiverChain;
|
|
34
|
+
authStatus: Observable<AuthStatus>;
|
|
35
|
+
loginError?: Error;
|
|
36
|
+
private logger;
|
|
37
|
+
private clientQueue;
|
|
38
|
+
private views;
|
|
39
|
+
private onStoppedFns;
|
|
40
|
+
newUserMetadata?: {
|
|
41
|
+
spaceId: Uint8Array | string;
|
|
42
|
+
};
|
|
43
|
+
private loginPromise?;
|
|
44
|
+
constructor(store: Store, spaceDapp: SpaceDapp, riverRegistryDapp: RiverRegistry, clientParams: ClientParams);
|
|
45
|
+
protected onLoaded(): void;
|
|
46
|
+
get userId(): string;
|
|
47
|
+
start(): Promise<void>;
|
|
48
|
+
stop(): Promise<void>;
|
|
49
|
+
call<T>(fn: (client: Client) => Promise<T>): Promise<T>;
|
|
50
|
+
withStream(streamId: string): {
|
|
51
|
+
call: <T>(fn: (client: Client, stream: Stream) => Promise<T>) => Promise<T>;
|
|
52
|
+
};
|
|
53
|
+
callWithStream<T>(streamId: string, fn: (client: Client, stream: Stream) => Promise<T>): Promise<T>;
|
|
54
|
+
registerView(viewFn: onClientStartedFn): void;
|
|
55
|
+
private createStreamsClient;
|
|
56
|
+
login(newUserMetadata?: {
|
|
57
|
+
spaceId: Uint8Array | string;
|
|
58
|
+
}): Promise<void>;
|
|
59
|
+
private loginWithRetries;
|
|
60
|
+
}
|
|
61
|
+
//# sourceMappingURL=riverConnection.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"riverConnection.d.ts","sourceRoot":"","sources":["../../../src/sync-agent/river-connection/riverConnection.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,229 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
import { makeStreamRpcClient } from '../../makeStreamRpcClient';
|
|
8
|
+
import { RiverChain } from './models/riverChain';
|
|
9
|
+
import { LoadPriority } from '../../store/store';
|
|
10
|
+
import { check, dlogger, shortenHexString } from '@towns-protocol/dlog';
|
|
11
|
+
import { PromiseQueue } from '../utils/promiseQueue';
|
|
12
|
+
import { PersistedObservable, persistedObservable } from '../../observable/persistedObservable';
|
|
13
|
+
import { userIdFromAddress } from '../../id';
|
|
14
|
+
import { TransactionalClient } from './models/transactionalClient';
|
|
15
|
+
import { Observable } from '../../observable/observable';
|
|
16
|
+
import { AuthStatus } from './models/authStatus';
|
|
17
|
+
import { expiryInterceptor } from '../../rpcInterceptors';
|
|
18
|
+
import { isDefined } from '../../check';
|
|
19
|
+
class LoginContext {
|
|
20
|
+
cancelled;
|
|
21
|
+
constructor(cancelled = false) {
|
|
22
|
+
this.cancelled = cancelled;
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
let RiverConnection = class RiverConnection extends PersistedObservable {
|
|
26
|
+
spaceDapp;
|
|
27
|
+
riverRegistryDapp;
|
|
28
|
+
clientParams;
|
|
29
|
+
client;
|
|
30
|
+
riverChain;
|
|
31
|
+
authStatus = new Observable(AuthStatus.Initializing);
|
|
32
|
+
loginError;
|
|
33
|
+
logger;
|
|
34
|
+
clientQueue = new PromiseQueue();
|
|
35
|
+
views = [];
|
|
36
|
+
onStoppedFns = [];
|
|
37
|
+
newUserMetadata;
|
|
38
|
+
loginPromise;
|
|
39
|
+
constructor(store, spaceDapp, riverRegistryDapp, clientParams) {
|
|
40
|
+
super({ id: '0', userExists: false }, store, LoadPriority.high);
|
|
41
|
+
this.spaceDapp = spaceDapp;
|
|
42
|
+
this.riverRegistryDapp = riverRegistryDapp;
|
|
43
|
+
this.clientParams = clientParams;
|
|
44
|
+
const logId = this.clientParams.opts?.logId ?? shortenHexString(this.userId);
|
|
45
|
+
this.logger = dlogger(`csb:rconn:${logId}`);
|
|
46
|
+
this.riverChain = new RiverChain(store, riverRegistryDapp, this.userId, logId);
|
|
47
|
+
}
|
|
48
|
+
onLoaded() {
|
|
49
|
+
//
|
|
50
|
+
}
|
|
51
|
+
get userId() {
|
|
52
|
+
return userIdFromAddress(this.clientParams.signerContext.creatorAddress);
|
|
53
|
+
}
|
|
54
|
+
async start() {
|
|
55
|
+
check(this.value.status === 'loaded', 'riverConnection not loaded');
|
|
56
|
+
const [urls, userStreamExists] = await Promise.all([
|
|
57
|
+
this.riverChain.urls(),
|
|
58
|
+
this.riverChain.userStreamExists(),
|
|
59
|
+
]);
|
|
60
|
+
if (!urls) {
|
|
61
|
+
throw new Error('riverConnection::start urls is not set');
|
|
62
|
+
}
|
|
63
|
+
await this.createStreamsClient();
|
|
64
|
+
if (userStreamExists) {
|
|
65
|
+
await this.login();
|
|
66
|
+
}
|
|
67
|
+
else {
|
|
68
|
+
this.authStatus.setValue(AuthStatus.Credentialed);
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
async stop() {
|
|
72
|
+
for (const fn of this.onStoppedFns) {
|
|
73
|
+
fn();
|
|
74
|
+
}
|
|
75
|
+
this.onStoppedFns = [];
|
|
76
|
+
if (this.loginPromise) {
|
|
77
|
+
this.loginPromise.context.cancelled = true;
|
|
78
|
+
}
|
|
79
|
+
this.riverChain.stop();
|
|
80
|
+
await this.client?.stop();
|
|
81
|
+
this.client = undefined;
|
|
82
|
+
this.authStatus.setValue(AuthStatus.Disconnected);
|
|
83
|
+
}
|
|
84
|
+
call(fn) {
|
|
85
|
+
if (this.client) {
|
|
86
|
+
return fn(this.client);
|
|
87
|
+
}
|
|
88
|
+
else {
|
|
89
|
+
// Enqueue the request if client is not available
|
|
90
|
+
return this.clientQueue.enqueue(fn);
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
withStream(streamId) {
|
|
94
|
+
return {
|
|
95
|
+
call: (fn) => {
|
|
96
|
+
return this.call(async (client) => {
|
|
97
|
+
const stream = await client.waitForStream(streamId);
|
|
98
|
+
return fn(client, stream);
|
|
99
|
+
});
|
|
100
|
+
},
|
|
101
|
+
};
|
|
102
|
+
}
|
|
103
|
+
callWithStream(streamId, fn) {
|
|
104
|
+
return this.withStream(streamId).call(fn);
|
|
105
|
+
}
|
|
106
|
+
registerView(viewFn) {
|
|
107
|
+
if (this.client) {
|
|
108
|
+
const onStopFn = viewFn(this.client);
|
|
109
|
+
this.onStoppedFns.push(onStopFn);
|
|
110
|
+
}
|
|
111
|
+
this.views.push(viewFn);
|
|
112
|
+
}
|
|
113
|
+
async createStreamsClient() {
|
|
114
|
+
const urls = await this.riverChain.urls();
|
|
115
|
+
if (this.client !== undefined) {
|
|
116
|
+
// this is wired up to be reactive to changes in the urls
|
|
117
|
+
this.logger.log('RiverConnection: rpc urls changed, client already set', urls);
|
|
118
|
+
return;
|
|
119
|
+
}
|
|
120
|
+
if (!urls) {
|
|
121
|
+
this.logger.error('RiverConnection: urls is not set');
|
|
122
|
+
return;
|
|
123
|
+
}
|
|
124
|
+
this.logger.info(`setting rpcClient with urls: "${urls}"`);
|
|
125
|
+
const rpcClient = makeStreamRpcClient(urls, () => this.riverRegistryDapp.getOperationalNodeUrls(), {
|
|
126
|
+
retryParams: this.clientParams.rpcRetryParams,
|
|
127
|
+
interceptors: [
|
|
128
|
+
expiryInterceptor({
|
|
129
|
+
onTokenExpired: this.clientParams.onTokenExpired,
|
|
130
|
+
}),
|
|
131
|
+
],
|
|
132
|
+
});
|
|
133
|
+
const client = new TransactionalClient(this.store, this.clientParams.signerContext, rpcClient, this.clientParams.cryptoStore, this.clientParams.entitlementsDelegate, this.clientParams.opts);
|
|
134
|
+
client.setMaxListeners(100);
|
|
135
|
+
this.client = client;
|
|
136
|
+
// initialize views
|
|
137
|
+
this.store.withTransaction('RiverConnection::onNewClient', () => {
|
|
138
|
+
this.views.forEach((viewFn) => {
|
|
139
|
+
const onStopFn = viewFn(client);
|
|
140
|
+
this.onStoppedFns.push(onStopFn);
|
|
141
|
+
});
|
|
142
|
+
});
|
|
143
|
+
}
|
|
144
|
+
async login(newUserMetadata) {
|
|
145
|
+
this.newUserMetadata = newUserMetadata ?? this.newUserMetadata;
|
|
146
|
+
this.logger.log('login', { newUserMetadata });
|
|
147
|
+
await this.loginWithRetries();
|
|
148
|
+
}
|
|
149
|
+
async loginWithRetries() {
|
|
150
|
+
check(isDefined(this.client), 'riverConnection::loginWithRetries client is not defined');
|
|
151
|
+
this.logger.info('login', { authStatus: this.authStatus.value, promise: this.loginPromise });
|
|
152
|
+
if (this.loginPromise) {
|
|
153
|
+
this.loginPromise.context.cancelled = true;
|
|
154
|
+
await this.loginPromise.promise;
|
|
155
|
+
}
|
|
156
|
+
if (this.authStatus.value === AuthStatus.ConnectedToRiver) {
|
|
157
|
+
return;
|
|
158
|
+
}
|
|
159
|
+
const loginContext = new LoginContext();
|
|
160
|
+
this.authStatus.setValue(AuthStatus.EvaluatingCredentials);
|
|
161
|
+
const login = async () => {
|
|
162
|
+
let retryCount = 0;
|
|
163
|
+
const MAX_RETRY_COUNT = 20;
|
|
164
|
+
while (!loginContext.cancelled) {
|
|
165
|
+
check(isDefined(this.client), 'riverConnection::loginWithRetries client is not defined');
|
|
166
|
+
try {
|
|
167
|
+
this.logger.info('logging in', {
|
|
168
|
+
userExists: this.data.userExists,
|
|
169
|
+
newUserMetadata: this.newUserMetadata,
|
|
170
|
+
});
|
|
171
|
+
this.authStatus.setValue(AuthStatus.ConnectingToRiver);
|
|
172
|
+
const client = this.client;
|
|
173
|
+
await client.initializeUser({
|
|
174
|
+
spaceId: this.newUserMetadata?.spaceId,
|
|
175
|
+
encryptionDeviceInit: this.clientParams.encryptionDevice,
|
|
176
|
+
});
|
|
177
|
+
this.logger.info('user initialized');
|
|
178
|
+
client.startSync();
|
|
179
|
+
this.setData({ userExists: true });
|
|
180
|
+
this.authStatus.setValue(AuthStatus.ConnectedToRiver);
|
|
181
|
+
// New rpcClient is available, resolve all queued requests
|
|
182
|
+
this.clientQueue.flush(client);
|
|
183
|
+
this.loginPromise = undefined;
|
|
184
|
+
break;
|
|
185
|
+
}
|
|
186
|
+
catch (err) {
|
|
187
|
+
retryCount++;
|
|
188
|
+
this.loginError = err;
|
|
189
|
+
this.logger.error(`encountered exception while initializing ${this.userId}`, err);
|
|
190
|
+
for (const fn of this.onStoppedFns) {
|
|
191
|
+
fn();
|
|
192
|
+
}
|
|
193
|
+
this.onStoppedFns = [];
|
|
194
|
+
await this.client.stop();
|
|
195
|
+
this.client = undefined;
|
|
196
|
+
await this.createStreamsClient();
|
|
197
|
+
if (loginContext.cancelled) {
|
|
198
|
+
this.logger.info('login cancelled after error');
|
|
199
|
+
this.loginPromise = undefined;
|
|
200
|
+
break;
|
|
201
|
+
}
|
|
202
|
+
else if (retryCount >= MAX_RETRY_COUNT) {
|
|
203
|
+
this.logger.info('login MAX_RETRY_COUNT reached');
|
|
204
|
+
this.authStatus.setValue(AuthStatus.Error);
|
|
205
|
+
this.loginPromise = undefined;
|
|
206
|
+
throw err;
|
|
207
|
+
}
|
|
208
|
+
else {
|
|
209
|
+
const retryDelay = getRetryDelay(retryCount);
|
|
210
|
+
this.logger.info('retrying', { retryDelay, retryCount });
|
|
211
|
+
// sleep
|
|
212
|
+
await new Promise((resolve) => setTimeout(resolve, retryDelay));
|
|
213
|
+
}
|
|
214
|
+
}
|
|
215
|
+
}
|
|
216
|
+
};
|
|
217
|
+
this.loginPromise = { promise: login(), context: loginContext };
|
|
218
|
+
return this.loginPromise.promise;
|
|
219
|
+
}
|
|
220
|
+
};
|
|
221
|
+
RiverConnection = __decorate([
|
|
222
|
+
persistedObservable({ tableName: 'riverConnection' })
|
|
223
|
+
], RiverConnection);
|
|
224
|
+
export { RiverConnection };
|
|
225
|
+
// exponentially back off, but never wait more than 20 seconds
|
|
226
|
+
function getRetryDelay(retryCount) {
|
|
227
|
+
return Math.min(1000 * 2 ** retryCount, 20000);
|
|
228
|
+
}
|
|
229
|
+
//# sourceMappingURL=riverConnection.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"riverConnection.js","sourceRoot":"","sources":["../../../src/sync-agent/river-connection/riverConnection.ts"],"names":[],"mappings":"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"}
|