atom.io 0.33.21 → 0.34.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (54) hide show
  1. package/dist/eslint-plugin/index.js +1 -2
  2. package/dist/eslint-plugin/index.js.map +1 -1
  3. package/dist/internal/index.d.ts +10 -6
  4. package/dist/internal/index.d.ts.map +1 -1
  5. package/dist/internal/index.js +1262 -1253
  6. package/dist/internal/index.js.map +1 -1
  7. package/dist/json/index.d.ts +3 -0
  8. package/dist/json/index.d.ts.map +1 -1
  9. package/dist/json/index.js.map +1 -1
  10. package/dist/main/index.d.ts +405 -23
  11. package/dist/main/index.d.ts.map +1 -1
  12. package/dist/main/index.js +107 -11
  13. package/dist/main/index.js.map +1 -1
  14. package/dist/realtime-client/index.js +6 -10
  15. package/dist/realtime-client/index.js.map +1 -1
  16. package/dist/realtime-server/index.js +1 -1
  17. package/dist/realtime-server/index.js.map +1 -1
  18. package/dist/realtime-testing/index.d.ts.map +1 -1
  19. package/dist/realtime-testing/index.js +0 -1
  20. package/dist/realtime-testing/index.js.map +1 -1
  21. package/package.json +6 -6
  22. package/src/internal/atom/create-regular-atom.ts +6 -7
  23. package/src/internal/caching.ts +9 -9
  24. package/src/internal/future.ts +3 -0
  25. package/src/internal/get-state/read-or-compute-value.ts +12 -7
  26. package/src/internal/join/create-join.ts +27 -0
  27. package/src/internal/join/index.ts +1 -0
  28. package/src/internal/junction.ts +2 -0
  29. package/src/internal/mutable/create-mutable-atom.ts +2 -4
  30. package/src/internal/selector/create-readonly-held-selector.ts +10 -0
  31. package/src/internal/selector/create-readonly-pure-selector.ts +13 -4
  32. package/src/internal/selector/create-writable-held-selector.ts +11 -2
  33. package/src/internal/selector/create-writable-pure-selector.ts +11 -1
  34. package/src/internal/selector/trace-selector-atoms.ts +18 -40
  35. package/src/internal/selector/update-selector-atoms.ts +5 -5
  36. package/src/internal/set-state/evict-downstream.ts +2 -2
  37. package/src/internal/set-state/reset-atom-or-selector.ts +3 -3
  38. package/src/internal/store/store.ts +0 -1
  39. package/src/internal/subscribe/subscribe-to-root-atoms.ts +42 -38
  40. package/src/internal/subscribe/subscribe-to-state.ts +23 -11
  41. package/src/json/index.ts +3 -0
  42. package/src/main/atom.ts +54 -13
  43. package/src/main/dispose-state.ts +8 -2
  44. package/src/main/find-state.ts +44 -14
  45. package/src/main/get-state.ts +2 -2
  46. package/src/main/index.ts +8 -0
  47. package/src/main/join.ts +79 -22
  48. package/src/main/realm.ts +50 -4
  49. package/src/main/selector.ts +116 -6
  50. package/src/main/subscribe.ts +31 -1
  51. package/src/main/timeline.ts +17 -0
  52. package/src/main/transaction.ts +39 -3
  53. package/src/realtime-client/realtime-client-stores/client-sync-store.ts +2 -2
  54. package/src/realtime-testing/setup-realtime-test.tsx +0 -5
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","names":["event: string","emit: <Event extends keyof I>(\n\t\t\tevent: Event,\n\t\t\t...args: I[Event]\n\t\t) => CustomSocket<I, O>","event: Event","listener: (...args: O[Event]) => void","listener: (event: string, ...args: Json.Array) => void","listener?: (...args: O[Event]) => void","arg: Json.Serializable","process: ChildProcessWithoutNullStreams","key: string","logger?: Pick<Console, `error` | `info` | `warn`>","err: { code: string }","process","buffer: EventBuffer<string, I[Event]>","id: string","buffer: EventBuffer<string, I[Event]>","attachServices: (socket: SubjectSocket<any, any>) => (() => void) | void","roomArgumentsAtoms: RegularAtomFamilyToken<RoomArguments, string>","roomSelectors: ReadonlyPureSelectorFamilyToken<\n\tLoadable<ChildSocket<any, any>>,\n\tstring\n>","data: Buffer","createRoomTX: AtomIO.TransactionToken<\n\t(\n\t\troomId: string,\n\t\tscript: string,\n\t\toptions?: string[],\n\t) => Loadable<ChildSocket<any, any>>\n>","args: RoomArguments","joinRoomTX: AtomIO.TransactionToken<\n\t(roomId: string, userId: string, enteredAtEpoch: number) => UserInRoomMeta\n>","leaveRoomTX: AtomIO.TransactionToken<\n\t(roomId: string, userId: string) => void\n>","destroyRoomTX: AtomIO.TransactionToken<(roomId: string) => void>","visibleStateKeys: string[]","updates: TransactionUpdateContent[]","redactorAtoms: RegularAtomFamilyToken<\n\t{\n\t\tocclude: (updates: TransactionUpdateContent[]) => TransactionUpdateContent[]\n\t},\n\tUserKey\n>","userUnacknowledgedQueues: RegularAtomFamilyToken<\n\tContinuitySyncTransactionUpdate[],\n\tUserKey\n>","socketAtoms: RegularAtomFamilyToken<Socket | null, SocketKey>","socketIndex: MutableAtomToken<\n\tSetRTX<SocketKey>,\n\tSetRTXJson<SocketKey>\n>","userIndex: MutableAtomToken<\n\tSetRTX<UserKey>,\n\tSetRTXJson<UserKey>\n>","usersOfSockets: JoinToken<\n\t`user`,\n\tUserKey,\n\t`socket`,\n\tSocketKey,\n\t`1:1`\n>","store: Store","continuity: ContinuityToken","userKey: UserKey","socket: Socket | null","initialPayload: Json.Serializable[]","atom","store: Store","continuity: ContinuityToken","userKey: string","store: Store","continuity: ContinuityToken","userKey: string","userUnacknowledgedUpdates: ContinuitySyncTransactionUpdate[]","store: Store","continuity: ContinuityToken","userKey: UserKey","socket: Socket | null","unsubscribeFunctions: (() => void)[]","atom","store: Store","continuity: ContinuityToken","userKey: UserKey","socket: Socket | null","unsubFns: (() => void)[]","socket: Socket | null","unsubscribeFunctions: (() => void)[]","tx: AtomIO.TransactionToken<F>","update: Pick<AtomIO.TransactionUpdate<F>, `id` | `params`>","family: AtomIO.RegularAtomFamilyToken<J, K>","index: AtomIO.ReadableToken<Iterable<K>>","key: string","subKey: K","family: AtomIO.MutableAtomFamilyToken<T, J, K>","index: AtomIO.ReadableToken<Iterable<K>>","key: string","subKey: K","token: AtomIO.MutableAtomToken<Core, SerializableCore>","unsubscribeFromStateUpdates: (() => void) | null","token: AtomIO.WritableToken<J>","unsubscribeFromStateUpdates: (() => void) | undefined","token: WritableToken<J>","newValue: J"],"sources":["../../src/realtime-server/ipc-sockets/custom-socket.ts","../../src/realtime-server/ipc-sockets/child-socket.ts","../../src/realtime-server/ipc-sockets/parent-socket.ts","../../src/realtime-server/realtime-server-stores/server-room-external-store.ts","../../src/realtime-server/realtime-server-stores/server-room-external-actions.ts","../../src/realtime-server/realtime-server-stores/server-sync-store.ts","../../src/realtime-server/realtime-server-stores/server-user-store.ts","../../src/realtime-server/continuity/prepare-to-send-initial-payload.ts","../../src/realtime-server/continuity/prepare-to-serve-transaction-request.ts","../../src/realtime-server/continuity/prepare-to-track-client-acknowledgement.ts","../../src/realtime-server/continuity/subscribe-to-continuity-actions.ts","../../src/realtime-server/continuity/subscribe-to-continuity-perpectives.ts","../../src/realtime-server/continuity/prepare-to-sync-realtime-continuity.ts","../../src/realtime-server/realtime-action-receiver.ts","../../src/realtime-server/realtime-family-provider.ts","../../src/realtime-server/realtime-mutable-family-provider.ts","../../src/realtime-server/realtime-mutable-provider.ts","../../src/realtime-server/realtime-state-provider.ts","../../src/realtime-server/realtime-state-receiver.ts"],"sourcesContent":["import type { Json, stringified } from \"atom.io/json\"\n\nimport type { Socket } from \"..\"\n\nexport type Events = Json.Object<string, Json.Serializable[]>\n\nexport type StringifiedEvent<\n\tKey extends string,\n\tParams extends Json.Serializable[],\n> = stringified<[Key, ...Params]>\n\nexport interface EventBuffer<\n\tKey extends string,\n\tParams extends Json.Serializable[],\n> extends Buffer {\n\ttoString(): StringifiedEvent<Key, Params>\n}\n\nexport class CustomSocket<I extends Events, O extends Events> implements Socket {\n\tprotected listeners: Map<keyof O, Set<(...args: Json.Array) => void>>\n\tprotected globalListeners: Set<(event: string, ...args: Json.Array) => void>\n\tprotected handleEvent<Event extends keyof I>(\n\t\tevent: string,\n\t\t...args: I[Event]\n\t): void {\n\t\tfor (const listener of this.globalListeners) {\n\t\t\tlistener(event, ...args)\n\t\t}\n\t\tconst listeners = this.listeners.get(event)\n\t\tif (listeners) {\n\t\t\tfor (const listener of listeners) {\n\t\t\t\tlistener(...args)\n\t\t\t}\n\t\t}\n\t}\n\n\tpublic id = `no_id_retrieved`\n\tpublic emit: <Event extends keyof I>(\n\t\tevent: Event,\n\t\t...args: I[Event]\n\t) => CustomSocket<I, O>\n\n\tpublic constructor(\n\t\temit: <Event extends keyof I>(\n\t\t\tevent: Event,\n\t\t\t...args: I[Event]\n\t\t) => CustomSocket<I, O>,\n\t) {\n\t\tthis.emit = emit\n\t\tthis.listeners = new Map()\n\t\tthis.globalListeners = new Set()\n\t}\n\n\tpublic on<Event extends keyof O>(\n\t\tevent: Event,\n\t\tlistener: (...args: O[Event]) => void,\n\t): this {\n\t\tconst listeners = this.listeners.get(event)\n\t\tif (listeners) {\n\t\t\tlisteners.add(listener)\n\t\t} else {\n\t\t\tthis.listeners.set(event, new Set([listener]))\n\t\t}\n\t\treturn this\n\t}\n\n\tpublic onAny(listener: (event: string, ...args: Json.Array) => void): this {\n\t\tthis.globalListeners.add(listener)\n\t\treturn this\n\t}\n\n\tpublic off<Event extends keyof O>(\n\t\tevent: Event,\n\t\tlistener?: (...args: O[Event]) => void,\n\t): this {\n\t\tconst listeners = this.listeners.get(event)\n\t\tif (listeners) {\n\t\t\tif (listener) {\n\t\t\t\tlisteners.delete(listener)\n\t\t\t} else {\n\t\t\t\tthis.listeners.delete(event)\n\t\t\t}\n\t\t}\n\t\treturn this\n\t}\n\n\tpublic offAny(listener: (event: string, ...args: Json.Array) => void): this {\n\t\tthis.globalListeners.delete(listener)\n\t\treturn this\n\t}\n}\n","import type { ChildProcessWithoutNullStreams } from \"node:child_process\"\n\nimport type { Json } from \"atom.io/json\"\nimport { parseJson } from \"atom.io/json\"\n\nimport type { EventBuffer, Events } from \"./custom-socket\"\nimport { CustomSocket } from \"./custom-socket\"\n\n/* eslint-disable no-console */\n\nexport class ChildSocket<\n\tI extends Events,\n\tO extends Events,\n> extends CustomSocket<I, O> {\n\tprotected incompleteData = ``\n\tprotected unprocessedEvents: string[] = []\n\tprotected incompleteLog = ``\n\tprotected unprocessedLogs: string[] = []\n\n\tpublic id = `#####`\n\n\tpublic process: ChildProcessWithoutNullStreams\n\tpublic key: string\n\tpublic logger: Pick<Console, `error` | `info` | `warn`>\n\n\tprotected handleLog(arg: Json.Serializable): void {\n\t\tif (Array.isArray(arg)) {\n\t\t\tconst [level, ...rest] = arg\n\t\t\tswitch (level) {\n\t\t\t\tcase `i`:\n\t\t\t\t\tthis.logger.info(...rest)\n\t\t\t\t\tbreak\n\t\t\t\tcase `w`:\n\t\t\t\t\tthis.logger.warn(...rest)\n\t\t\t\t\tbreak\n\t\t\t\tcase `e`:\n\t\t\t\t\tthis.logger.error(...rest)\n\t\t\t\t\tbreak\n\t\t\t\tdefault:\n\t\t\t\t\treturn\n\t\t\t}\n\t\t}\n\t}\n\n\tpublic constructor(\n\t\tprocess: ChildProcessWithoutNullStreams,\n\t\tkey: string,\n\t\tlogger?: Pick<Console, `error` | `info` | `warn`>,\n\t) {\n\t\tsuper((event, ...args) => {\n\t\t\tconst stringifiedEvent = JSON.stringify([event, ...args]) + `\\x03`\n\t\t\tconst errorHandler = (err: { code: string }) => {\n\t\t\t\tif (err.code === `EPIPE`) {\n\t\t\t\t\tconsole.error(`EPIPE error during write`, this.process.stdin)\n\t\t\t\t}\n\t\t\t\tthis.process.stdin.removeListener(`error`, errorHandler)\n\t\t\t}\n\n\t\t\tthis.process.stdin.once(`error`, errorHandler)\n\t\t\tthis.process.stdin.write(stringifiedEvent)\n\n\t\t\treturn this\n\t\t})\n\t\tthis.process = process\n\t\tthis.key = key\n\t\tthis.logger = logger ?? {\n\t\t\tinfo: (...args: unknown[]) => {\n\t\t\t\tconsole.info(this.id, this.key, ...args)\n\t\t\t},\n\t\t\twarn: (...args: unknown[]) => {\n\t\t\t\tconsole.warn(this.id, this.key, ...args)\n\t\t\t},\n\t\t\terror: (...args: unknown[]) => {\n\t\t\t\tconsole.error(this.id, this.key, ...args)\n\t\t\t},\n\t\t}\n\t\tthis.process.stdout.on(\n\t\t\t`data`,\n\t\t\t<Event extends keyof I>(buffer: EventBuffer<string, I[Event]>) => {\n\t\t\t\tconst chunk = buffer.toString()\n\n\t\t\t\tif (chunk === `ALIVE`) {\n\t\t\t\t\t// console.log(chunk)\n\t\t\t\t\treturn\n\t\t\t\t}\n\t\t\t\tthis.unprocessedEvents.push(...chunk.split(`\\x03`))\n\t\t\t\t// console.log(`🤓`, chunk.length)\n\t\t\t\t// console.log(`🤓`, this.unprocessedEvents.length)\n\t\t\t\t// console.log(`🤓`, ...this.unprocessedEvents.map((x) => x.length))\n\t\t\t\tconst newInput = this.unprocessedEvents.shift()\n\t\t\t\tthis.incompleteData += newInput ?? ``\n\t\t\t\ttry {\n\t\t\t\t\tif (this.incompleteData.startsWith(`error`)) {\n\t\t\t\t\t\tconsole.log(`❗`, this.incompleteData)\n\t\t\t\t\t}\n\t\t\t\t\tlet parsedEvent = parseJson(this.incompleteData)\n\t\t\t\t\tthis.handleEvent(...(parsedEvent as [string, ...I[keyof I]]))\n\t\t\t\t\twhile (this.unprocessedEvents.length > 0) {\n\t\t\t\t\t\tconst event = this.unprocessedEvents.shift()\n\t\t\t\t\t\tif (event) {\n\t\t\t\t\t\t\tif (this.unprocessedEvents.length === 0) {\n\t\t\t\t\t\t\t\tthis.incompleteData = event\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tparsedEvent = parseJson(event)\n\t\t\t\t\t\t\tthis.handleEvent(...(parsedEvent as [string, ...I[keyof I]]))\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tthis.incompleteData = ``\n\t\t\t\t} catch (error) {\n\t\t\t\t\tconsole.warn(`⚠️----------------⚠️`)\n\t\t\t\t\tconsole.warn(this.incompleteData)\n\t\t\t\t\tconsole.warn(`⚠️----------------⚠️`)\n\t\t\t\t\tconsole.error(error)\n\t\t\t\t}\n\t\t\t},\n\t\t)\n\t\tthis.process.stderr.on(`data`, (buf) => {\n\t\t\tconst chunk = buf.toString()\n\t\t\tthis.unprocessedLogs.push(...chunk.split(`\\x03`))\n\t\t\t// console.log(`🤫`, chunk.length)\n\t\t\t// console.log(`🤫`, this.unprocessedLogs.length)\n\t\t\t// console.log(`🤫`, ...this.unprocessedLogs.map((x) => x.length))\n\t\t\tconst newInput = this.unprocessedLogs.shift()\n\t\t\tthis.incompleteLog += newInput ?? ``\n\t\t\ttry {\n\t\t\t\tlet parsedLog = parseJson(this.incompleteLog)\n\t\t\t\t// console.log(`🤫`, parsedLog)\n\t\t\t\tthis.handleLog(parsedLog)\n\t\t\t\twhile (this.unprocessedLogs.length > 0) {\n\t\t\t\t\tthis.incompleteLog = this.unprocessedLogs.shift() ?? ``\n\t\t\t\t\tif (this.incompleteLog) {\n\t\t\t\t\t\tparsedLog = parseJson(this.incompleteLog)\n\t\t\t\t\t\tthis.handleLog(parsedLog)\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} catch (error) {\n\t\t\t\tconsole.error(`❌❌❌`)\n\t\t\t\tconsole.error(this.incompleteLog)\n\t\t\t\tconsole.error(error)\n\t\t\t\tconsole.error(`❌❌❌️`)\n\t\t\t}\n\t\t})\n\t\tif (process.pid) {\n\t\t\tthis.id = process.pid.toString()\n\t\t}\n\t}\n}\n","import { Subject } from \"atom.io/internal\"\nimport type { Json } from \"atom.io/json\"\nimport { parseJson, stringifyJson } from \"atom.io/json\"\nimport { SetRTX } from \"atom.io/transceivers/set-rtx\"\n\nimport type { EventBuffer, Events } from \"./custom-socket\"\nimport { CustomSocket } from \"./custom-socket\"\n\nexport class SubjectSocket<\n\tI extends Events,\n\tO extends Events,\n> extends CustomSocket<I, O> {\n\tpublic in: Subject<[string, ...Json.Serializable[]]>\n\tpublic out: Subject<[string, ...Json.Serializable[]]>\n\tpublic id = `no_id_retrieved`\n\tpublic disposalFunctions: (() => void)[] = []\n\n\tpublic constructor(id: string) {\n\t\tsuper((...args) => {\n\t\t\tthis.out.next(args as any)\n\t\t\treturn this\n\t\t})\n\t\tthis.id = id\n\t\tthis.in = new Subject()\n\t\tthis.out = new Subject()\n\t\tthis.in.subscribe(`socket`, (event) => {\n\t\t\tthis.handleEvent(...(event as [string, ...I[keyof I]]))\n\t\t})\n\t}\n\n\tpublic dispose(): void {\n\t\tfor (const dispose of this.disposalFunctions) {\n\t\t\tdispose()\n\t\t}\n\t}\n}\n\nexport class ParentSocket<\n\tI extends Events & {\n\t\t[id in string as `relay:${id}`]: [string, ...Json.Serializable[]]\n\t},\n\tO extends Events & {\n\t\t[id in string as `user:${id}`]: [string, ...Json.Serializable[]]\n\t} & {\n\t\t/* eslint-disable quotes */\n\t\t\"user-joins\": [string]\n\t\t\"user-leaves\": [string]\n\t\t/* eslint-enable quotes */\n\t},\n> extends CustomSocket<I, O> {\n\tprotected incompleteData = ``\n\tprotected unprocessedEvents: string[] = []\n\tprotected relays: Map<string, SubjectSocket<any, any>>\n\tprotected relayServices: ((\n\t\tsocket: SubjectSocket<any, any>,\n\t) => (() => void) | void)[]\n\tprotected process: NodeJS.Process\n\n\tpublic id = `#####`\n\n\tprotected log(...args: any[]): void {\n\t\tthis.process.stderr.write(\n\t\t\tstringifyJson(\n\t\t\t\targs.map((arg) =>\n\t\t\t\t\targ instanceof SetRTX\n\t\t\t\t\t\t? `{ ${arg.toJSON().members.join(` | `)} }`\n\t\t\t\t\t\t: arg,\n\t\t\t\t),\n\t\t\t) + `\\x03`,\n\t\t)\n\t}\n\tpublic logger = {\n\t\tinfo: (...args: any[]): void => {\n\t\t\tthis.log(`i`, ...args)\n\t\t},\n\t\twarn: (...args: any[]): void => {\n\t\t\tthis.log(`w`, ...args)\n\t\t},\n\t\terror: (...args: any[]): void => {\n\t\t\tthis.log(`e`, ...args)\n\t\t},\n\t}\n\n\tpublic constructor() {\n\t\tsuper((event, ...args) => {\n\t\t\tconst stringifiedEvent = JSON.stringify([event, ...args])\n\t\t\tthis.process.stdout.write(stringifiedEvent + `\\x03`)\n\t\t\treturn this\n\t\t})\n\t\tthis.process = process\n\t\tthis.process.stdin.resume()\n\t\tthis.relays = new Map()\n\t\tthis.relayServices = []\n\t\t// this.logger.info(`🔗`, `uplink`, process.pid)\n\n\t\tthis.process.stdin.on(\n\t\t\t`data`,\n\t\t\t<Event extends keyof I>(buffer: EventBuffer<string, I[Event]>) => {\n\t\t\t\tconst chunk = buffer.toString()\n\t\t\t\tthis.unprocessedEvents.push(...chunk.split(`\\x03`))\n\t\t\t\tconst newInput = this.unprocessedEvents.shift()\n\t\t\t\tthis.incompleteData += newInput ?? ``\n\n\t\t\t\ttry {\n\t\t\t\t\tconst parsedData = parseJson(this.incompleteData)\n\t\t\t\t\tthis.logger.info(`🎰`, `received`, parsedData)\n\t\t\t\t\tthis.handleEvent(...(parsedData as [string, ...I[keyof I]]))\n\t\t\t\t\twhile (this.unprocessedEvents.length > 0) {\n\t\t\t\t\t\tconst event = this.unprocessedEvents.shift()\n\t\t\t\t\t\tif (event) {\n\t\t\t\t\t\t\tif (this.unprocessedEvents.length === 0) {\n\t\t\t\t\t\t\t\tthis.incompleteData = event\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tconst parsedEvent = parseJson(event)\n\t\t\t\t\t\t\tthis.handleEvent(...(parsedEvent as [string, ...I[keyof I]]))\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tthis.incompleteData = ``\n\t\t\t\t} catch (thrown) {\n\t\t\t\t\tif (thrown instanceof Error) {\n\t\t\t\t\t\tthis.logger.error(`❗`, thrown.message, thrown.cause, thrown.stack)\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t},\n\t\t)\n\n\t\tthis.on(`exit`, () => {\n\t\t\tthis.logger.info(`🔥`, this.id, `received \"exit\"`)\n\t\t\tprocess.exit(0)\n\t\t})\n\t\tprocess.on(`exit`, (code) => {\n\t\t\tthis.logger.info(`🔥`, this.id, `exited with code ${code}`)\n\t\t})\n\t\tprocess.on(`end`, () => {\n\t\t\tthis.logger.info(`🔥`, this.id, `ended`)\n\t\t\tprocess.exit(0)\n\t\t})\n\t\tprocess.on(`SIGTERM`, () => {\n\t\t\tthis.logger.error(`🔥`, this.id, `terminated`)\n\t\t\tprocess.exit(0)\n\t\t})\n\t\tprocess.on(`SIGINT`, () => {\n\t\t\tthis.logger.error(`🔥`, this.id, `interrupted`)\n\t\t\tprocess.exit(0)\n\t\t})\n\n\t\tif (process.pid) {\n\t\t\tthis.id = process.pid?.toString()\n\t\t}\n\n\t\tthis.on(`user-joins`, (username) => {\n\t\t\tthis.logger.info(`👤`, `user`, username, `joined`)\n\t\t\tconst relay = new SubjectSocket(`user:${username}`)\n\t\t\tthis.relays.set(username, relay)\n\t\t\tthis.logger.info(\n\t\t\t\t`🔗`,\n\t\t\t\t`attaching services:`,\n\t\t\t\t`[${[...this.relayServices.keys()].join(`, `)}]`,\n\t\t\t)\n\t\t\tfor (const attachServices of this.relayServices) {\n\t\t\t\tconst cleanup = attachServices(relay)\n\t\t\t\tif (cleanup) {\n\t\t\t\t\trelay.disposalFunctions.push(cleanup)\n\t\t\t\t}\n\t\t\t}\n\t\t\tthis.on(`user:${username}`, (...data) => {\n\t\t\t\trelay.in.next(data)\n\t\t\t})\n\t\t\trelay.out.subscribe(`socket`, (data) => {\n\t\t\t\tthis.emit(...(data as [string, ...I[keyof I]]))\n\t\t\t})\n\t\t})\n\n\t\tthis.on(`user-leaves`, (username) => {\n\t\t\tconst relay = this.relays.get(username)\n\t\t\tthis.off(`relay:${username}`)\n\t\t\tif (relay) {\n\t\t\t\trelay.dispose()\n\t\t\t\tthis.relays.delete(username)\n\t\t\t}\n\t\t})\n\n\t\tprocess.stdout.write(`ALIVE`)\n\t}\n\n\tpublic relay(\n\t\tattachServices: (socket: SubjectSocket<any, any>) => (() => void) | void,\n\t): void {\n\t\tthis.logger.info(`🔗`, `running relay method`)\n\t\tthis.relayServices.push(attachServices)\n\t}\n}\n","import type { ChildProcessWithoutNullStreams } from \"node:child_process\"\nimport { spawn } from \"node:child_process\"\n\nimport type {\n\tLoadable,\n\tReadonlyPureSelectorFamilyToken,\n\tRegularAtomFamilyToken,\n} from \"atom.io\"\nimport { atomFamily, selectorFamily } from \"atom.io\"\n\nimport { ChildSocket } from \"../ipc-sockets\"\n\nexport type RoomArguments =\n\t| [script: string, options: string[]]\n\t| [script: string]\n\nexport const roomArgumentsAtoms: RegularAtomFamilyToken<RoomArguments, string> =\n\tatomFamily<RoomArguments, string>({\n\t\tkey: `roomArguments`,\n\t\tdefault: [`echo`, [`Hello World!`]],\n\t})\n\nexport const roomSelectors: ReadonlyPureSelectorFamilyToken<\n\tLoadable<ChildSocket<any, any>>,\n\tstring\n> = selectorFamily<Loadable<ChildSocket<any, any>>, string>({\n\tkey: `room`,\n\tget:\n\t\t(roomId) =>\n\t\tasync ({ get, find }) => {\n\t\t\tconst argumentsState = find(roomArgumentsAtoms, roomId)\n\t\t\tconst args = get(argumentsState)\n\t\t\tconst [script, options] = args\n\t\t\tconst child = await new Promise<ChildProcessWithoutNullStreams>(\n\t\t\t\t(resolve) => {\n\t\t\t\t\tconst room = spawn(script, options, { env: process.env })\n\t\t\t\t\tconst resolver = (data: Buffer) => {\n\t\t\t\t\t\tif (data.toString() === `ALIVE`) {\n\t\t\t\t\t\t\troom.stdout.off(`data`, resolver)\n\t\t\t\t\t\t\tresolve(room)\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\troom.stdout.on(`data`, resolver)\n\t\t\t\t},\n\t\t\t)\n\t\t\treturn new ChildSocket(child, roomId)\n\t\t},\n})\n","import type { Loadable } from \"atom.io\"\nimport * as AtomIO from \"atom.io\"\nimport { editRelationsInStore } from \"atom.io/internal\"\nimport type { UserInRoomMeta } from \"atom.io/realtime\"\nimport { roomIndex, usersInRooms } from \"atom.io/realtime\"\n\nimport type { ChildSocket } from \"../ipc-sockets\"\nimport type { RoomArguments } from \"./server-room-external-store\"\nimport { roomArgumentsAtoms, roomSelectors } from \"./server-room-external-store\"\n\nexport const createRoomTX: AtomIO.TransactionToken<\n\t(\n\t\troomId: string,\n\t\tscript: string,\n\t\toptions?: string[],\n\t) => Loadable<ChildSocket<any, any>>\n> = AtomIO.transaction({\n\tkey: `createRoom`,\n\tdo: ({ get, set, find }, roomId, script, options) => {\n\t\tconst args: RoomArguments = options ? [script, options] : [script]\n\t\tconst roomArgumentsState = find(roomArgumentsAtoms, roomId)\n\t\tset(roomArgumentsState, args)\n\t\tset(roomIndex, (s) => s.add(roomId))\n\t\tconst roomState = find(roomSelectors, roomId)\n\t\tconst room = get(roomState)\n\t\treturn room\n\t},\n})\nexport type CreateRoomIO = AtomIO.TransactionIO<typeof createRoomTX>\n\nexport const joinRoomTX: AtomIO.TransactionToken<\n\t(roomId: string, userId: string, enteredAtEpoch: number) => UserInRoomMeta\n> = AtomIO.transaction({\n\tkey: `joinRoom`,\n\tdo: (tools, roomId, userId, enteredAtEpoch) => {\n\t\tconst meta = { enteredAtEpoch }\n\t\teditRelationsInStore(\n\t\t\tusersInRooms,\n\t\t\t(relations) => {\n\t\t\t\trelations.set({ room: roomId, user: userId }, meta)\n\t\t\t},\n\t\t\ttools.env().store,\n\t\t)\n\t\treturn meta\n\t},\n})\nexport type JoinRoomIO = AtomIO.TransactionIO<typeof joinRoomTX>\n\nexport const leaveRoomTX: AtomIO.TransactionToken<\n\t(roomId: string, userId: string) => void\n> = AtomIO.transaction({\n\tkey: `leaveRoom`,\n\tdo: (tools, roomId, userId) => {\n\t\teditRelationsInStore(\n\t\t\tusersInRooms,\n\t\t\t(relations) => {\n\t\t\t\trelations.delete({ room: roomId, user: userId })\n\t\t\t},\n\t\t\ttools.env().store,\n\t\t)\n\t},\n})\nexport type LeaveRoomIO = AtomIO.TransactionIO<typeof leaveRoomTX>\n\nexport const destroyRoomTX: AtomIO.TransactionToken<(roomId: string) => void> =\n\tAtomIO.transaction({\n\t\tkey: `destroyRoom`,\n\t\tdo: (tools, roomId) => {\n\t\t\teditRelationsInStore(\n\t\t\t\tusersInRooms,\n\t\t\t\t(relations) => {\n\t\t\t\t\trelations.delete({ room: roomId })\n\t\t\t\t},\n\t\t\t\ttools.env().store,\n\t\t\t)\n\t\t\ttools.set(roomIndex, (s) => (s.delete(roomId), s))\n\t\t},\n\t})\n","import type {\n\tRegularAtomFamilyToken,\n\tTransactionUpdate,\n\tTransactionUpdateContent,\n} from \"atom.io\"\nimport { atomFamily } from \"atom.io\"\n\nimport type { UserKey } from \"./server-user-store\"\n\n// export const completeUpdateAtoms = atomFamily<\n// \tTransactionUpdate<any> | null,\n// \tstring\n// >({\n// \tkey: `completeUpdate`,\n// \tdefault: null,\n// })\n\nexport function redactTransactionUpdateContent(\n\tvisibleStateKeys: string[],\n\tupdates: TransactionUpdateContent[],\n): TransactionUpdateContent[] {\n\treturn updates\n\t\t.map((update): TransactionUpdateContent => {\n\t\t\tswitch (update.type) {\n\t\t\t\tcase `transaction_update`: {\n\t\t\t\t\tconst redacted = redactTransactionUpdateContent(\n\t\t\t\t\t\tvisibleStateKeys,\n\t\t\t\t\t\tupdate.updates,\n\t\t\t\t\t)\n\t\t\t\t\treturn { ...update, updates: redacted }\n\t\t\t\t}\n\t\t\t\tcase `atom_update`:\n\t\t\t\tcase `selector_update`:\n\t\t\t\tcase `molecule_creation`:\n\t\t\t\tcase `molecule_disposal`:\n\t\t\t\tcase `molecule_transfer`:\n\t\t\t\tcase `state_creation`:\n\t\t\t\tcase `state_disposal`:\n\t\t\t\t\treturn update\n\t\t\t}\n\t\t})\n\t\t.filter((update) => {\n\t\t\tswitch (update.type) {\n\t\t\t\tcase `atom_update`:\n\t\t\t\tcase `selector_update`:\n\t\t\t\t\treturn visibleStateKeys.includes(update.key)\n\t\t\t\tcase `state_creation`:\n\t\t\t\tcase `state_disposal`:\n\t\t\t\t\treturn visibleStateKeys.includes(update.token.key)\n\t\t\t\tcase `molecule_creation`:\n\t\t\t\tcase `transaction_update`:\n\t\t\t\tcase `molecule_disposal`:\n\t\t\t\tcase `molecule_transfer`:\n\t\t\t\t\treturn true\n\t\t\t}\n\t\t})\n}\n\nexport const redactorAtoms: RegularAtomFamilyToken<\n\t{\n\t\tocclude: (updates: TransactionUpdateContent[]) => TransactionUpdateContent[]\n\t},\n\tUserKey\n> = atomFamily<\n\t{\n\t\tocclude: (updates: TransactionUpdateContent[]) => TransactionUpdateContent[]\n\t},\n\tUserKey\n>({\n\tkey: `redactor`,\n\tdefault: { occlude: (updates) => updates },\n})\n// export const redactedUpdateSelectors = selectorFamily<\n// \tTransactionUpdate<any> | null,\n// \t[transactionKey: string, updateId: string]\n// >({\n// \tkey: `redactedUpdate`,\n// \tget:\n// \t\t([transactionKey, updateId]) =>\n// \t\t({ get, find }) => {\n// \t\t\tconst update = get(find(completeUpdateAtoms, updateId))\n// \t\t\tconst { filter } = get(find(transactionRedactorAtoms, transactionKey))\n\n// \t\t\tif (update && filter) {\n// \t\t\t\treturn { ...update, updates: filter(update.updates) }\n// \t\t\t}\n// \t\t\treturn null\n// \t\t},\n// })\n\nexport type ContinuitySyncTransactionUpdate = Pick<\n\tTransactionUpdate<any>,\n\t`epoch` | `id` | `key` | `output` | `updates`\n>\nexport const userUnacknowledgedQueues: RegularAtomFamilyToken<\n\tContinuitySyncTransactionUpdate[],\n\tUserKey\n> = atomFamily<ContinuitySyncTransactionUpdate[], UserKey>({\n\tkey: `unacknowledgedUpdates`,\n\tdefault: () => [],\n})\n","import type {\n\tHierarchy,\n\tJoinToken,\n\tMutableAtomToken,\n\tRegularAtomFamilyToken,\n} from \"atom.io\"\nimport { atom, atomFamily, join } from \"atom.io\"\nimport type { SetRTXJson } from \"atom.io/transceivers/set-rtx\"\nimport { SetRTX } from \"atom.io/transceivers/set-rtx\"\n\nimport type { Socket } from \"..\"\n\nexport type SocketKey = `socket::${string}`\nexport type UserKey = `user::${string}`\nexport type RoomKey = `room::${string}`\n\nexport type SocketSystemHierarchy = Hierarchy<\n\t[\n\t\t{\n\t\t\tabove: `root`\n\t\t\tbelow: [UserKey, SocketKey, RoomKey]\n\t\t},\n\t]\n>\n\nexport const socketAtoms: RegularAtomFamilyToken<Socket | null, SocketKey> =\n\tatomFamily<Socket | null, SocketKey>({\n\t\tkey: `sockets`,\n\t\tdefault: null,\n\t})\n\nexport const socketIndex: MutableAtomToken<\n\tSetRTX<SocketKey>,\n\tSetRTXJson<SocketKey>\n> = atom<SetRTX<SocketKey>, SetRTXJson<SocketKey>>({\n\tkey: `socketsIndex`,\n\tmutable: true,\n\tdefault: () => new SetRTX(),\n\ttoJson: (set) => set.toJSON(),\n\tfromJson: (json) => SetRTX.fromJSON(json),\n})\nexport const userIndex: MutableAtomToken<\n\tSetRTX<UserKey>,\n\tSetRTXJson<UserKey>\n> = atom<SetRTX<UserKey>, SetRTXJson<UserKey>>({\n\tkey: `usersIndex`,\n\tmutable: true,\n\tdefault: () => new SetRTX(),\n\ttoJson: (set) => set.toJSON(),\n\tfromJson: (json) => SetRTX.fromJSON(json),\n})\nexport const usersOfSockets: JoinToken<\n\t`user`,\n\tUserKey,\n\t`socket`,\n\tSocketKey,\n\t`1:1`\n> = join({\n\tkey: `usersOfSockets`,\n\tbetween: [`user`, `socket`],\n\tcardinality: `1:1`,\n\tisAType: (s): s is UserKey => s.startsWith(`user::`),\n\tisBType: (s): s is SocketKey => s.startsWith(`socket::`),\n})\n","import type { Store } from \"atom.io/internal\"\nimport {\n\tfindInStore,\n\tgetFromStore,\n\tgetJsonToken,\n\tisRootStore,\n} from \"atom.io/internal\"\nimport type { Json } from \"atom.io/json\"\nimport type { ContinuityToken } from \"atom.io/realtime\"\n\nimport type { Socket, UserKey } from \"..\"\n\nexport function prepareToSendInitialPayload(\n\tstore: Store,\n\tcontinuity: ContinuityToken,\n\tuserKey: UserKey,\n\tsocket: Socket | null,\n): () => void {\n\tconst continuityKey = continuity.key\n\treturn function sendInitialPayload(): void {\n\t\tconst initialPayload: Json.Serializable[] = []\n\t\tfor (const atom of continuity.globals) {\n\t\t\tconst resourceToken =\n\t\t\t\tatom.type === `mutable_atom` ? getJsonToken(store, atom) : atom\n\t\t\tconst resource = getFromStore(store, resourceToken)\n\t\t\tinitialPayload.push(resourceToken, resource)\n\t\t}\n\t\tfor (const perspective of continuity.perspectives) {\n\t\t\tconst { viewAtoms, resourceAtoms } = perspective\n\t\t\tconst userViewState = findInStore(store, viewAtoms, userKey)\n\t\t\tconst userView = getFromStore(store, userViewState)\n\t\t\tstore.logger.info(`👁`, `atom`, resourceAtoms.key, `${userKey} can see`, {\n\t\t\t\tviewAtoms,\n\t\t\t\tresourceAtoms,\n\t\t\t\tuserView,\n\t\t\t})\n\t\t\tfor (const visibleToken of userView) {\n\t\t\t\tconst resourceToken =\n\t\t\t\t\tvisibleToken.type === `mutable_atom`\n\t\t\t\t\t\t? getJsonToken(store, visibleToken)\n\t\t\t\t\t\t: visibleToken\n\t\t\t\tconst resource = getFromStore(store, resourceToken)\n\n\t\t\t\tinitialPayload.push(resourceToken, resource)\n\t\t\t}\n\t\t}\n\n\t\tconst epoch = isRootStore(store)\n\t\t\t? (store.transactionMeta.epoch.get(continuityKey) ?? null)\n\t\t\t: null\n\n\t\tsocket?.emit(`continuity-init:${continuityKey}`, epoch, initialPayload)\n\t}\n}\n","import type { TransactionUpdate } from \"atom.io\"\nimport type { Store } from \"atom.io/internal\"\nimport { actUponStore } from \"atom.io/internal\"\nimport type { JsonIO } from \"atom.io/json\"\nimport type { ContinuityToken } from \"atom.io/realtime\"\n\nexport function prepareToServeTransactionRequest(\n\tstore: Store,\n\tcontinuity: ContinuityToken,\n\tuserKey: string,\n): (update: Pick<TransactionUpdate<JsonIO>, `id` | `key` | `params`>) => void {\n\tconst continuityKey = continuity.key\n\treturn function serveTransactionRequest(update) {\n\t\tstore.logger.info(`🛎️`, `continuity`, continuityKey, `received`, update)\n\t\tconst transactionKey = update.key\n\t\tconst updateId = update.id\n\t\tconst performanceKey = `tx-run:${transactionKey}:${updateId}`\n\t\tconst performanceKeyStart = `${performanceKey}:start`\n\t\tconst performanceKeyEnd = `${performanceKey}:end`\n\t\tperformance.mark(performanceKeyStart)\n\t\ttry {\n\t\t\tactUponStore(\n\t\t\t\tstore,\n\t\t\t\t{ type: `transaction`, key: transactionKey },\n\t\t\t\tupdateId,\n\t\t\t)(...update.params)\n\t\t} catch (thrown) {\n\t\t\tif (thrown instanceof Error) {\n\t\t\t\tstore.logger.error(\n\t\t\t\t\t`❌`,\n\t\t\t\t\t`continuity`,\n\t\t\t\t\tcontinuityKey,\n\t\t\t\t\t`failed to run transaction ${transactionKey} from ${userKey} with update ${updateId}`,\n\t\t\t\t\tthrown.message,\n\t\t\t\t)\n\t\t\t}\n\t\t}\n\t\tperformance.mark(performanceKeyEnd)\n\t\tconst metric = performance.measure(\n\t\t\tperformanceKey,\n\t\t\tperformanceKeyStart,\n\t\t\tperformanceKeyEnd,\n\t\t)\n\t\tstore?.logger.info(\n\t\t\t`🚀`,\n\t\t\t`transaction`,\n\t\t\ttransactionKey,\n\t\t\tupdateId,\n\t\t\tuserKey,\n\t\t\tmetric.duration,\n\t\t)\n\t}\n}\n","import type { Store } from \"atom.io/internal\"\nimport { setIntoStore } from \"atom.io/internal\"\nimport type { ContinuityToken } from \"atom.io/realtime\"\n\nimport type { ContinuitySyncTransactionUpdate } from \"../realtime-server-stores\"\nimport { userUnacknowledgedQueues } from \"../realtime-server-stores\"\n\nexport function prepareToTrackClientAcknowledgement(\n\tstore: Store,\n\tcontinuity: ContinuityToken,\n\tuserKey: string,\n\tuserUnacknowledgedUpdates: ContinuitySyncTransactionUpdate[],\n): (epoch: number) => void {\n\tconst continuityKey = continuity.key\n\treturn function trackClientAcknowledgement(epoch) {\n\t\tstore.logger.info(\n\t\t\t`👍`,\n\t\t\t`continuity`,\n\t\t\tcontinuityKey,\n\t\t\t`${userKey} acknowledged epoch ${epoch}`,\n\t\t)\n\t\tconst isUnacknowledged = userUnacknowledgedUpdates[0]?.epoch === epoch\n\t\tif (isUnacknowledged) {\n\t\t\tsetIntoStore(store, userUnacknowledgedQueues, userKey, (updates) => {\n\t\t\t\tupdates.shift()\n\t\t\t\tstore.logger.info(\n\t\t\t\t\t`👍`,\n\t\t\t\t\t`continuity`,\n\t\t\t\t\tcontinuityKey,\n\t\t\t\t\t`${userKey} unacknowledged update queue now has`,\n\t\t\t\t\tupdates.length,\n\t\t\t\t\t`items`,\n\t\t\t\t)\n\t\t\t\treturn updates\n\t\t\t})\n\t\t}\n\t}\n}\n","import type { Store } from \"atom.io/internal\"\nimport {\n\tfindInStore,\n\tgetFromStore,\n\tgetUpdateToken,\n\tsetIntoStore,\n\tsubscribeToTransaction,\n} from \"atom.io/internal\"\nimport type { Json } from \"atom.io/json\"\nimport type { ContinuityToken } from \"atom.io/realtime\"\n\nimport type { Socket, UserKey } from \"..\"\nimport {\n\tredactTransactionUpdateContent,\n\tuserUnacknowledgedQueues,\n} from \"../realtime-server-stores\"\n\nexport function subscribeToContinuityActions(\n\tstore: Store,\n\tcontinuity: ContinuityToken,\n\tuserKey: UserKey,\n\tsocket: Socket | null,\n): (() => void)[] {\n\tconst continuityKey = continuity.key\n\tconst unsubscribeFunctions: (() => void)[] = []\n\n\tfor (const transaction of continuity.actions) {\n\t\tconst unsubscribeFromTransaction = subscribeToTransaction(\n\t\t\tstore,\n\t\t\ttransaction,\n\t\t\t`sync-continuity:${continuityKey}:${userKey}`,\n\t\t\t(update) => {\n\t\t\t\ttry {\n\t\t\t\t\tconst visibleKeys = continuity.globals\n\t\t\t\t\t\t.map((atom) => {\n\t\t\t\t\t\t\tif (atom.type === `atom`) {\n\t\t\t\t\t\t\t\treturn atom.key\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\treturn getUpdateToken(atom).key\n\t\t\t\t\t\t})\n\t\t\t\t\t\t.concat(\n\t\t\t\t\t\t\tcontinuity.perspectives.flatMap((perspective) => {\n\t\t\t\t\t\t\t\tconst { viewAtoms } = perspective\n\t\t\t\t\t\t\t\tconst userPerspectiveTokenState = findInStore(\n\t\t\t\t\t\t\t\t\tstore,\n\t\t\t\t\t\t\t\t\tviewAtoms,\n\t\t\t\t\t\t\t\t\tuserKey,\n\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t\tconst visibleTokens = getFromStore(\n\t\t\t\t\t\t\t\t\tstore,\n\t\t\t\t\t\t\t\t\tuserPerspectiveTokenState,\n\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t\treturn visibleTokens.map((token) => {\n\t\t\t\t\t\t\t\t\tconst key =\n\t\t\t\t\t\t\t\t\t\ttoken.type === `mutable_atom` ? `*` + token.key : token.key\n\t\t\t\t\t\t\t\t\treturn key\n\t\t\t\t\t\t\t\t})\n\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t)\n\t\t\t\t\tconst redactedUpdates = redactTransactionUpdateContent(\n\t\t\t\t\t\tvisibleKeys,\n\t\t\t\t\t\tupdate.updates,\n\t\t\t\t\t)\n\t\t\t\t\tconst redactedUpdate = {\n\t\t\t\t\t\t...update,\n\t\t\t\t\t\tupdates: redactedUpdates,\n\t\t\t\t\t}\n\t\t\t\t\tsetIntoStore(store, userUnacknowledgedQueues, userKey, (updates) => {\n\t\t\t\t\t\tif (redactedUpdate) {\n\t\t\t\t\t\t\tupdates.push(redactedUpdate)\n\t\t\t\t\t\t\tupdates.sort((a, b) => a.epoch - b.epoch)\n\t\t\t\t\t\t\tstore.logger.info(\n\t\t\t\t\t\t\t\t`👍`,\n\t\t\t\t\t\t\t\t`continuity`,\n\t\t\t\t\t\t\t\tcontinuityKey,\n\t\t\t\t\t\t\t\t`${userKey} unacknowledged update queue now has`,\n\t\t\t\t\t\t\t\tupdates.length,\n\t\t\t\t\t\t\t\t`items`,\n\t\t\t\t\t\t\t)\n\t\t\t\t\t\t}\n\t\t\t\t\t\treturn updates\n\t\t\t\t\t})\n\n\t\t\t\t\tsocket?.emit(\n\t\t\t\t\t\t`tx-new:${continuityKey}`,\n\t\t\t\t\t\tredactedUpdate as Json.Serializable,\n\t\t\t\t\t)\n\t\t\t\t} catch (thrown) {\n\t\t\t\t\tif (thrown instanceof Error) {\n\t\t\t\t\t\tstore.logger.error(\n\t\t\t\t\t\t\t`❌`,\n\t\t\t\t\t\t\t`continuity`,\n\t\t\t\t\t\t\tcontinuityKey,\n\t\t\t\t\t\t\t`${userKey} failed to send update from transaction ${transaction.key} to ${userKey}`,\n\t\t\t\t\t\t\tthrown.message,\n\t\t\t\t\t\t)\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t},\n\t\t)\n\t\tunsubscribeFunctions.push(unsubscribeFromTransaction)\n\t}\n\treturn unsubscribeFunctions\n}\n","import type { Store } from \"atom.io/internal\"\nimport {\n\tfindInStore,\n\tgetFromStore,\n\tgetJsonToken,\n\tsubscribeToState,\n} from \"atom.io/internal\"\nimport type { ContinuityToken } from \"atom.io/realtime\"\n\nimport type { Socket } from \"..\"\nimport type { UserKey } from \"../realtime-server-stores\"\n\nexport function subscribeToContinuityPerspectives(\n\tstore: Store,\n\tcontinuity: ContinuityToken,\n\tuserKey: UserKey,\n\tsocket: Socket | null,\n): (() => void)[] {\n\tconst continuityKey = continuity.key\n\tconst unsubFns: (() => void)[] = []\n\tfor (const perspective of continuity.perspectives) {\n\t\tconst { viewAtoms } = perspective\n\t\tconst userViewState = findInStore(store, viewAtoms, userKey)\n\t\tconst unsubscribeFromUserView = subscribeToState(\n\t\t\tstore,\n\t\t\tuserViewState,\n\t\t\t`sync-continuity:${continuityKey}:${userKey}:perspective:${perspective.resourceAtoms.key}`,\n\t\t\t({ oldValue, newValue }) => {\n\t\t\t\tconst oldKeys = oldValue.map((token) => token.key)\n\t\t\t\tconst newKeys = newValue.map((token) => token.key)\n\t\t\t\tconst concealed = oldValue.filter(\n\t\t\t\t\t(token) => !newKeys.includes(token.key),\n\t\t\t\t)\n\t\t\t\tconst revealed = newValue\n\t\t\t\t\t.filter((token) => !oldKeys.includes(token.key))\n\t\t\t\t\t.flatMap((token) => {\n\t\t\t\t\t\tconst resourceToken =\n\t\t\t\t\t\t\ttoken.type === `mutable_atom` ? getJsonToken(store, token) : token\n\t\t\t\t\t\tconst resource = getFromStore(store, resourceToken)\n\t\t\t\t\t\treturn [resourceToken, resource]\n\t\t\t\t\t})\n\t\t\t\tstore.logger.info(\n\t\t\t\t\t`👁`,\n\t\t\t\t\t`atom`,\n\t\t\t\t\tperspective.resourceAtoms.key,\n\t\t\t\t\t`${userKey} has a new perspective`,\n\t\t\t\t\t{ oldKeys, newKeys, revealed, concealed },\n\t\t\t\t)\n\t\t\t\tif (revealed.length > 0) {\n\t\t\t\t\tsocket?.emit(`reveal:${continuityKey}`, revealed)\n\t\t\t\t}\n\t\t\t\tif (concealed.length > 0) {\n\t\t\t\t\tsocket?.emit(`conceal:${continuityKey}`, concealed)\n\t\t\t\t}\n\t\t\t},\n\t\t)\n\t\tunsubFns.push(unsubscribeFromUserView)\n\t}\n\treturn unsubFns\n}\n","import {\n\tfindInStore,\n\tfindRelationsInStore,\n\tgetFromStore,\n\tIMPLICIT,\n\tsubscribeToState,\n} from \"atom.io/internal\"\nimport type { Json } from \"atom.io/json\"\nimport type { ContinuityToken } from \"atom.io/realtime\"\n\nimport type { ServerConfig, Socket } from \"..\"\nimport { socketAtoms, usersOfSockets } from \"..\"\nimport { userUnacknowledgedQueues } from \"../realtime-server-stores\"\nimport { prepareToSendInitialPayload } from \"./prepare-to-send-initial-payload\"\nimport { prepareToServeTransactionRequest } from \"./prepare-to-serve-transaction-request\"\nimport { prepareToTrackClientAcknowledgement } from \"./prepare-to-track-client-acknowledgement\"\nimport { subscribeToContinuityActions } from \"./subscribe-to-continuity-actions\"\nimport { subscribeToContinuityPerspectives } from \"./subscribe-to-continuity-perpectives\"\n\nexport type ExposeRealtimeContinuity = (\n\tcontinuity: ContinuityToken,\n) => () => void\nexport function prepareToExposeRealtimeContinuity({\n\tsocket: initialSocket,\n\tstore = IMPLICIT.STORE,\n}: ServerConfig): ExposeRealtimeContinuity {\n\treturn function syncRealtimeContinuity(continuity) {\n\t\tlet socket: Socket | null = initialSocket\n\n\t\tconst continuityKey = continuity.key\n\t\tconst userKeyState = findRelationsInStore(\n\t\t\tusersOfSockets,\n\t\t\t`socket::${socket.id}`,\n\t\t\tstore,\n\t\t).userKeyOfSocket\n\t\tconst userKey = getFromStore(store, userKeyState)\n\t\tif (!userKey) {\n\t\t\tstore.logger.error(\n\t\t\t\t`❌`,\n\t\t\t\t`continuity`,\n\t\t\t\tcontinuityKey,\n\t\t\t\t`Tried to create a synchronizer for a socket (${socket.id}) that is not connected to a user.`,\n\t\t\t)\n\t\t\treturn () => {}\n\t\t}\n\n\t\tconst socketKeyState = findRelationsInStore(\n\t\t\tusersOfSockets,\n\t\t\tuserKey,\n\t\t\tstore,\n\t\t).socketKeyOfUser\n\t\tconst _unsubscribeFromSocketTracking = subscribeToState(\n\t\t\tstore,\n\t\t\tsocketKeyState,\n\t\t\t`sync-continuity:${continuityKey}:${userKey}`,\n\t\t\t({ newValue: newSocketKey }) => {\n\t\t\t\tstore.logger.info(\n\t\t\t\t\t`👋`,\n\t\t\t\t\t`continuity`,\n\t\t\t\t\tcontinuityKey,\n\t\t\t\t\t`seeing ${userKey} on new socket ${newSocketKey}`,\n\t\t\t\t)\n\t\t\t\tif (newSocketKey === null) {\n\t\t\t\t\tstore.logger.warn(\n\t\t\t\t\t\t`❌`,\n\t\t\t\t\t\t`continuity`,\n\t\t\t\t\t\tcontinuityKey,\n\t\t\t\t\t\t`User (${userKey}) is not connected to a socket, waiting for them to reappear.`,\n\t\t\t\t\t)\n\t\t\t\t\treturn\n\t\t\t\t}\n\t\t\t\tconst newSocketState = findInStore(store, socketAtoms, newSocketKey)\n\t\t\t\tconst newSocket = getFromStore(store, newSocketState)\n\t\t\t\tsocket = newSocket\n\t\t\t\tfor (const unacknowledgedUpdate of userUnacknowledgedUpdates) {\n\t\t\t\t\tsocket?.emit(\n\t\t\t\t\t\t`tx-new:${continuityKey}`,\n\t\t\t\t\t\tunacknowledgedUpdate as Json.Serializable,\n\t\t\t\t\t)\n\t\t\t\t}\n\t\t\t},\n\t\t)\n\n\t\tconst userUnacknowledgedUpdates = getFromStore(\n\t\t\tstore,\n\t\t\tuserUnacknowledgedQueues,\n\t\t\tuserKey,\n\t\t)\n\n\t\tconst unsubscribeFunctions: (() => void)[] = []\n\n\t\tconst unsubscribeFromPerspectives = subscribeToContinuityPerspectives(\n\t\t\tstore,\n\t\t\tcontinuity,\n\t\t\tuserKey,\n\t\t\tsocket,\n\t\t)\n\t\tconst unsubscribeFromTransactions = subscribeToContinuityActions(\n\t\t\tstore,\n\t\t\tcontinuity,\n\t\t\tuserKey,\n\t\t\tsocket,\n\t\t)\n\t\tunsubscribeFunctions.push(\n\t\t\t...unsubscribeFromPerspectives,\n\t\t\t...unsubscribeFromTransactions,\n\t\t)\n\n\t\tconst sendInitialPayload = prepareToSendInitialPayload(\n\t\t\tstore,\n\t\t\tcontinuity,\n\t\t\tuserKey,\n\t\t\tinitialSocket,\n\t\t)\n\n\t\tsocket.off(`get:${continuityKey}`, sendInitialPayload)\n\t\tsocket.on(`get:${continuityKey}`, sendInitialPayload)\n\n\t\tconst fillTransactionRequest = prepareToServeTransactionRequest(\n\t\t\tstore,\n\t\t\tcontinuity,\n\t\t\tuserKey,\n\t\t)\n\n\t\tsocket.off(`tx-run:${continuityKey}`, fillTransactionRequest)\n\t\tsocket.on(`tx-run:${continuityKey}`, fillTransactionRequest)\n\n\t\tconst trackClientAcknowledgement = prepareToTrackClientAcknowledgement(\n\t\t\tstore,\n\t\t\tcontinuity,\n\t\t\tuserKey,\n\t\t\tuserUnacknowledgedUpdates,\n\t\t)\n\n\t\tsocket?.on(`ack:${continuityKey}`, trackClientAcknowledgement)\n\n\t\treturn () => {\n\t\t\t// clearInterval(retryTimeout)\n\t\t\tfor (const unsubscribe of unsubscribeFunctions) unsubscribe()\n\t\t\tsocket?.off(`ack:${continuityKey}`, trackClientAcknowledgement)\n\t\t\tsocket?.off(`get:${continuityKey}`, sendInitialPayload)\n\t\t\tsocket?.off(`tx-run:${continuityKey}`, fillTransactionRequest)\n\t\t}\n\t}\n}\n","import type * as AtomIO from \"atom.io\"\nimport { actUponStore, IMPLICIT } from \"atom.io/internal\"\nimport type { JsonIO } from \"atom.io/json\"\n\nimport type { ServerConfig } from \".\"\n\nexport type ActionReceiver = ReturnType<typeof realtimeActionReceiver>\nexport function realtimeActionReceiver({\n\tsocket,\n\tstore = IMPLICIT.STORE,\n}: ServerConfig) {\n\treturn function actionReceiver<F extends JsonIO>(\n\t\ttx: AtomIO.TransactionToken<F>,\n\t): () => void {\n\t\tconst fillTransactionRequest = (\n\t\t\tupdate: Pick<AtomIO.TransactionUpdate<F>, `id` | `params`>,\n\t\t) => {\n\t\t\tconst performanceKey = `tx-run:${tx.key}:${update.id}`\n\t\t\tconst performanceKeyStart = `${performanceKey}:start`\n\t\t\tconst performanceKeyEnd = `${performanceKey}:end`\n\t\t\tperformance.mark(performanceKeyStart)\n\t\t\tactUponStore<F>(store, tx, update.id)(...update.params)\n\t\t\tperformance.mark(performanceKeyEnd)\n\t\t\tconst metric = performance.measure(\n\t\t\t\tperformanceKey,\n\t\t\t\tperformanceKeyStart,\n\t\t\t\tperformanceKeyEnd,\n\t\t\t)\n\t\t\tstore?.logger.info(`🚀`, `transaction`, tx.key, update.id, metric.duration)\n\t\t}\n\t\tsocket.on(`tx-run:${tx.key}`, fillTransactionRequest)\n\n\t\treturn () => {\n\t\t\tsocket.off(`tx-run:${tx.key}`, fillTransactionRequest)\n\t\t}\n\t}\n}\n","import type * as AtomIO from \"atom.io\"\nimport {\n\tfindInStore,\n\tgetFromStore,\n\tIMPLICIT,\n\tsubscribeToState,\n} from \"atom.io/internal\"\nimport type { Canonical, Json } from \"atom.io/json\"\nimport { stringifyJson } from \"atom.io/json\"\n\nimport type { ServerConfig } from \".\"\n\nexport type FamilyProvider = ReturnType<typeof realtimeAtomFamilyProvider>\nexport function realtimeAtomFamilyProvider({\n\tsocket,\n\tstore = IMPLICIT.STORE,\n}: ServerConfig) {\n\treturn function familyProvider<\n\t\tJ extends Json.Serializable,\n\t\tK extends Canonical,\n\t>(\n\t\tfamily: AtomIO.RegularAtomFamilyToken<J, K>,\n\t\tindex: AtomIO.ReadableToken<Iterable<K>>,\n\t): () => void {\n\t\tconst unsubCallbacksByKey = new Map<string, () => void>()\n\n\t\tconst fillUnsubRequest = (key: string) => {\n\t\t\tsocket.off(`unsub:${key}`, fillUnsubRequest)\n\t\t\tconst unsub = unsubCallbacksByKey.get(key)\n\t\t\tif (unsub) {\n\t\t\t\tunsub()\n\t\t\t\tunsubCallbacksByKey.delete(key)\n\t\t\t}\n\t\t}\n\n\t\tconst fillSubRequest = (subKey: K) => {\n\t\t\tconst exposedSubKeys = getFromStore(store, index)\n\t\t\tfor (const exposedSubKey of exposedSubKeys) {\n\t\t\t\tif (stringifyJson(exposedSubKey) === stringifyJson(subKey)) {\n\t\t\t\t\tconst token = findInStore(store, family, subKey)\n\t\t\t\t\tsocket.emit(`serve:${token.key}`, getFromStore(store, token))\n\t\t\t\t\tconst unsubscribe = subscribeToState(\n\t\t\t\t\t\tstore,\n\t\t\t\t\t\ttoken,\n\t\t\t\t\t\t`expose-family:${family.key}:${socket.id}`,\n\t\t\t\t\t\t({ newValue }) => {\n\t\t\t\t\t\t\tsocket.emit(`serve:${token.key}`, newValue)\n\t\t\t\t\t\t},\n\t\t\t\t\t)\n\t\t\t\t\tunsubCallbacksByKey.set(token.key, unsubscribe)\n\t\t\t\t\tsocket.on(`unsub:${token.key}`, () => {\n\t\t\t\t\t\tfillUnsubRequest(token.key)\n\t\t\t\t\t})\n\t\t\t\t\tbreak\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tsocket.on(`sub:${family.key}`, fillSubRequest)\n\n\t\treturn () => {\n\t\t\tsocket.off(`sub:${family.key}`, fillSubRequest)\n\n\t\t\tfor (const [, unsub] of unsubCallbacksByKey) {\n\t\t\t\tunsub()\n\t\t\t}\n\t\t\tunsubCallbacksByKey.clear()\n\t\t}\n\t}\n}\n","import type * as AtomIO from \"atom.io\"\nimport type { Transceiver } from \"atom.io/internal\"\nimport {\n\tfindInStore,\n\tgetFromStore,\n\tgetJsonToken,\n\tgetUpdateToken,\n\tIMPLICIT,\n\tsubscribeToState,\n} from \"atom.io/internal\"\nimport type { Canonical, Json } from \"atom.io/json\"\nimport { stringifyJson } from \"atom.io/json\"\n\nimport type { ServerConfig } from \".\"\n\nexport type MutableFamilyProvider = ReturnType<\n\ttypeof realtimeMutableFamilyProvider\n>\nexport function realtimeMutableFamilyProvider({\n\tsocket,\n\tstore = IMPLICIT.STORE,\n}: ServerConfig) {\n\treturn function mutableFamilyProvider<\n\t\tT extends Transceiver<any>,\n\t\tJ extends Json.Serializable,\n\t\tK extends Canonical,\n\t>(\n\t\tfamily: AtomIO.MutableAtomFamilyToken<T, J, K>,\n\t\tindex: AtomIO.ReadableToken<Iterable<K>>,\n\t): () => void {\n\t\tconst unsubCallbacksByKey = new Map<string, () => void>()\n\n\t\tconst fillUnsubRequest = (key: string) => {\n\t\t\tsocket.off(`unsub:${key}`, fillUnsubRequest)\n\t\t\tconst unsub = unsubCallbacksByKey.get(key)\n\t\t\tif (unsub) {\n\t\t\t\tunsub()\n\t\t\t\tunsubCallbacksByKey.delete(key)\n\t\t\t}\n\t\t}\n\n\t\tconst fillSubRequest = (subKey: K) => {\n\t\t\tconst exposedSubKeys = getFromStore(store, index)\n\t\t\tfor (const exposedSubKey of exposedSubKeys) {\n\t\t\t\tif (stringifyJson(exposedSubKey) === stringifyJson(subKey)) {\n\t\t\t\t\tconst token = findInStore(store, family, subKey)\n\t\t\t\t\tgetFromStore(store, token)\n\t\t\t\t\tconst jsonToken = getJsonToken(store, token)\n\t\t\t\t\tconst updateToken = getUpdateToken(token)\n\t\t\t\t\tsocket.emit(`init:${token.key}`, getFromStore(store, jsonToken))\n\t\t\t\t\tconst unsubscribe = subscribeToState(\n\t\t\t\t\t\tstore,\n\t\t\t\t\t\tupdateToken,\n\t\t\t\t\t\t`expose-family:${family.key}:${socket.id}`,\n\t\t\t\t\t\t({ newValue }) => {\n\t\t\t\t\t\t\tsocket.emit(`next:${token.key}`, newValue)\n\t\t\t\t\t\t},\n\t\t\t\t\t)\n\t\t\t\t\tunsubCallbacksByKey.set(token.key, unsubscribe)\n\t\t\t\t\tsocket.on(`unsub:${token.key}`, () => {\n\t\t\t\t\t\tfillUnsubRequest(token.key)\n\t\t\t\t\t})\n\t\t\t\t\tbreak\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tsocket.on(`sub:${family.key}`, fillSubRequest)\n\n\t\treturn () => {\n\t\t\tsocket.off(`sub:${family.key}`, fillSubRequest)\n\t\t\tfor (const [, unsub] of unsubCallbacksByKey) {\n\t\t\t\tunsub()\n\t\t\t}\n\t\t\tunsubCallbacksByKey.clear()\n\t\t}\n\t}\n}\n","import type * as AtomIO from \"atom.io\"\nimport type { Transceiver } from \"atom.io/internal\"\nimport {\n\tgetFromStore,\n\tgetJsonToken,\n\tgetUpdateToken,\n\tIMPLICIT,\n\tsubscribeToState,\n} from \"atom.io/internal\"\nimport type { Json } from \"atom.io/json\"\n\nimport type { ServerConfig } from \".\"\n\nexport type MutableProvider = ReturnType<typeof realtimeMutableProvider>\nexport function realtimeMutableProvider({\n\tsocket,\n\tstore = IMPLICIT.STORE,\n}: ServerConfig) {\n\treturn function mutableProvider<\n\t\tCore extends Transceiver<Json.Serializable>,\n\t\tSerializableCore extends Json.Serializable,\n\t>(token: AtomIO.MutableAtomToken<Core, SerializableCore>): () => void {\n\t\tlet unsubscribeFromStateUpdates: (() => void) | null = null\n\n\t\tconst jsonToken = getJsonToken(store, token)\n\t\tconst trackerToken = getUpdateToken(token)\n\n\t\tconst fillUnsubRequest = () => {\n\t\t\tsocket.off(`unsub:${token.key}`, fillUnsubRequest)\n\t\t\tunsubscribeFromStateUpdates?.()\n\t\t\tunsubscribeFromStateUpdates = null\n\t\t}\n\n\t\tconst fillSubRequest = () => {\n\t\t\tsocket.emit(`init:${token.key}`, getFromStore(store, jsonToken))\n\t\t\tunsubscribeFromStateUpdates = subscribeToState(\n\t\t\t\tstore,\n\t\t\t\ttrackerToken,\n\t\t\t\t`expose-single:${socket.id}`,\n\t\t\t\t({ newValue }) => {\n\t\t\t\t\tsocket.emit(`next:${token.key}`, newValue)\n\t\t\t\t},\n\t\t\t)\n\t\t\tsocket.on(`unsub:${token.key}`, fillUnsubRequest)\n\t\t}\n\n\t\tsocket.on(`sub:${token.key}`, fillSubRequest)\n\n\t\treturn () => {\n\t\t\tsocket.off(`sub:${token.key}`, fillSubRequest)\n\t\t\tunsubscribeFromStateUpdates?.()\n\t\t}\n\t}\n}\n","import type * as AtomIO from \"atom.io\"\nimport { getFromStore, IMPLICIT, subscribeToState } from \"atom.io/internal\"\nimport type { Json } from \"atom.io/json\"\n\nimport type { ServerConfig } from \".\"\n\nexport type StateProvider = ReturnType<typeof realtimeStateProvider>\nexport function realtimeStateProvider({\n\tsocket,\n\tstore = IMPLICIT.STORE,\n}: ServerConfig) {\n\treturn function stateProvider<J extends Json.Serializable>(\n\t\ttoken: AtomIO.WritableToken<J>,\n\t): () => void {\n\t\tlet unsubscribeFromStateUpdates: (() => void) | undefined\n\n\t\tconst fillSubRequest = () => {\n\t\t\tsocket.emit(`serve:${token.key}`, getFromStore(store, token))\n\n\t\t\tunsubscribeFromStateUpdates = subscribeToState(\n\t\t\t\tstore,\n\t\t\t\ttoken,\n\t\t\t\t`expose-single:${socket.id}`,\n\t\t\t\t({ newValue }) => {\n\t\t\t\t\tsocket.emit(`serve:${token.key}`, newValue)\n\t\t\t\t},\n\t\t\t)\n\n\t\t\tconst fillUnsubRequest = () => {\n\t\t\t\tsocket.off(`unsub:${token.key}`, fillUnsubRequest)\n\t\t\t\tif (unsubscribeFromStateUpdates) {\n\t\t\t\t\tunsubscribeFromStateUpdates()\n\t\t\t\t\tunsubscribeFromStateUpdates = undefined\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tsocket.on(`unsub:${token.key}`, fillUnsubRequest)\n\t\t}\n\n\t\tsocket.on(`sub:${token.key}`, fillSubRequest)\n\n\t\treturn () => {\n\t\t\tsocket.off(`sub:${token.key}`, fillSubRequest)\n\t\t\tif (unsubscribeFromStateUpdates) {\n\t\t\t\tunsubscribeFromStateUpdates()\n\t\t\t\tunsubscribeFromStateUpdates = undefined\n\t\t\t}\n\t\t}\n\t}\n}\n","import type { WritableToken } from \"atom.io\"\nimport { IMPLICIT, setIntoStore } from \"atom.io/internal\"\nimport type { Json } from \"atom.io/json\"\n\nimport type { ServerConfig } from \".\"\n\nexport type StateReceiver = ReturnType<typeof realtimeStateReceiver>\nexport function realtimeStateReceiver({\n\tsocket,\n\tstore = IMPLICIT.STORE,\n}: ServerConfig) {\n\treturn function stateReceiver<J extends Json.Serializable>(\n\t\ttoken: WritableToken<J>,\n\t): () => void {\n\t\tconst publish = (newValue: J) => {\n\t\t\tsetIntoStore(store, token, newValue)\n\t\t}\n\n\t\tconst fillPubUnclaim = () => {\n\t\t\tsocket.off(`pub:${token.key}`, publish)\n\t\t\tsocket.off(`unclaim:${token.key}`, fillPubUnclaim)\n\t\t}\n\t\tconst fillPubClaim = () => {\n\t\t\tsocket.on(`pub:${token.key}`, publish)\n\t\t\tsocket.on(`unclaim:${token.key}`, fillPubUnclaim)\n\t\t}\n\n\t\tsocket.on(`claim:${token.key}`, fillPubClaim)\n\n\t\treturn () => {\n\t\t\tsocket.off(`claim:${token.key}`, fillPubClaim)\n\t\t\tsocket.off(`pub:${token.key}`, publish)\n\t\t}\n\t}\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"index.js","names":["event: string","emit: <Event extends keyof I>(\n\t\t\tevent: Event,\n\t\t\t...args: I[Event]\n\t\t) => CustomSocket<I, O>","event: Event","listener: (...args: O[Event]) => void","listener: (event: string, ...args: Json.Array) => void","listener?: (...args: O[Event]) => void","arg: Json.Serializable","process: ChildProcessWithoutNullStreams","key: string","logger?: Pick<Console, `error` | `info` | `warn`>","err: { code: string }","process","buffer: EventBuffer<string, I[Event]>","id: string","buffer: EventBuffer<string, I[Event]>","attachServices: (socket: SubjectSocket<any, any>) => (() => void) | void","roomArgumentsAtoms: RegularAtomFamilyToken<RoomArguments, string>","roomSelectors: ReadonlyPureSelectorFamilyToken<\n\tLoadable<ChildSocket<any, any>>,\n\tstring\n>","data: Buffer","createRoomTX: AtomIO.TransactionToken<\n\t(\n\t\troomId: string,\n\t\tscript: string,\n\t\toptions?: string[],\n\t) => Loadable<ChildSocket<any, any>>\n>","args: RoomArguments","joinRoomTX: AtomIO.TransactionToken<\n\t(roomId: string, userId: string, enteredAtEpoch: number) => UserInRoomMeta\n>","leaveRoomTX: AtomIO.TransactionToken<\n\t(roomId: string, userId: string) => void\n>","destroyRoomTX: AtomIO.TransactionToken<(roomId: string) => void>","visibleStateKeys: string[]","updates: TransactionUpdateContent[]","redactorAtoms: RegularAtomFamilyToken<\n\t{\n\t\tocclude: (updates: TransactionUpdateContent[]) => TransactionUpdateContent[]\n\t},\n\tUserKey\n>","userUnacknowledgedQueues: RegularAtomFamilyToken<\n\tContinuitySyncTransactionUpdate[],\n\tUserKey\n>","socketAtoms: RegularAtomFamilyToken<Socket | null, SocketKey>","socketIndex: MutableAtomToken<\n\tSetRTX<SocketKey>,\n\tSetRTXJson<SocketKey>\n>","userIndex: MutableAtomToken<\n\tSetRTX<UserKey>,\n\tSetRTXJson<UserKey>\n>","usersOfSockets: JoinToken<\n\t`user`,\n\tUserKey,\n\t`socket`,\n\tSocketKey,\n\t`1:1`\n>","store: Store","continuity: ContinuityToken","userKey: UserKey","socket: Socket | null","initialPayload: Json.Serializable[]","atom","store: Store","continuity: ContinuityToken","userKey: string","store: Store","continuity: ContinuityToken","userKey: string","userUnacknowledgedUpdates: ContinuitySyncTransactionUpdate[]","store: Store","continuity: ContinuityToken","userKey: UserKey","socket: Socket | null","unsubscribeFunctions: (() => void)[]","atom","store: Store","continuity: ContinuityToken","userKey: UserKey","socket: Socket | null","unsubFns: (() => void)[]","socket: Socket | null","unsubscribeFunctions: (() => void)[]","tx: AtomIO.TransactionToken<F>","update: Pick<AtomIO.TransactionUpdate<F>, `id` | `params`>","family: AtomIO.RegularAtomFamilyToken<J, K>","index: AtomIO.ReadableToken<Iterable<K>>","key: string","subKey: K","family: AtomIO.MutableAtomFamilyToken<T, J, K>","index: AtomIO.ReadableToken<Iterable<K>>","key: string","subKey: K","token: AtomIO.MutableAtomToken<Core, SerializableCore>","unsubscribeFromStateUpdates: (() => void) | null","token: AtomIO.WritableToken<J>","unsubscribeFromStateUpdates: (() => void) | undefined","token: WritableToken<J>","newValue: J"],"sources":["../../src/realtime-server/ipc-sockets/custom-socket.ts","../../src/realtime-server/ipc-sockets/child-socket.ts","../../src/realtime-server/ipc-sockets/parent-socket.ts","../../src/realtime-server/realtime-server-stores/server-room-external-store.ts","../../src/realtime-server/realtime-server-stores/server-room-external-actions.ts","../../src/realtime-server/realtime-server-stores/server-sync-store.ts","../../src/realtime-server/realtime-server-stores/server-user-store.ts","../../src/realtime-server/continuity/prepare-to-send-initial-payload.ts","../../src/realtime-server/continuity/prepare-to-serve-transaction-request.ts","../../src/realtime-server/continuity/prepare-to-track-client-acknowledgement.ts","../../src/realtime-server/continuity/subscribe-to-continuity-actions.ts","../../src/realtime-server/continuity/subscribe-to-continuity-perpectives.ts","../../src/realtime-server/continuity/prepare-to-sync-realtime-continuity.ts","../../src/realtime-server/realtime-action-receiver.ts","../../src/realtime-server/realtime-family-provider.ts","../../src/realtime-server/realtime-mutable-family-provider.ts","../../src/realtime-server/realtime-mutable-provider.ts","../../src/realtime-server/realtime-state-provider.ts","../../src/realtime-server/realtime-state-receiver.ts"],"sourcesContent":["import type { Json, stringified } from \"atom.io/json\"\n\nimport type { Socket } from \"..\"\n\nexport type Events = Json.Object<string, Json.Serializable[]>\n\nexport type StringifiedEvent<\n\tKey extends string,\n\tParams extends Json.Serializable[],\n> = stringified<[Key, ...Params]>\n\nexport interface EventBuffer<\n\tKey extends string,\n\tParams extends Json.Serializable[],\n> extends Buffer {\n\ttoString(): StringifiedEvent<Key, Params>\n}\n\nexport class CustomSocket<I extends Events, O extends Events> implements Socket {\n\tprotected listeners: Map<keyof O, Set<(...args: Json.Array) => void>>\n\tprotected globalListeners: Set<(event: string, ...args: Json.Array) => void>\n\tprotected handleEvent<Event extends keyof I>(\n\t\tevent: string,\n\t\t...args: I[Event]\n\t): void {\n\t\tfor (const listener of this.globalListeners) {\n\t\t\tlistener(event, ...args)\n\t\t}\n\t\tconst listeners = this.listeners.get(event)\n\t\tif (listeners) {\n\t\t\tfor (const listener of listeners) {\n\t\t\t\tlistener(...args)\n\t\t\t}\n\t\t}\n\t}\n\n\tpublic id = `no_id_retrieved`\n\tpublic emit: <Event extends keyof I>(\n\t\tevent: Event,\n\t\t...args: I[Event]\n\t) => CustomSocket<I, O>\n\n\tpublic constructor(\n\t\temit: <Event extends keyof I>(\n\t\t\tevent: Event,\n\t\t\t...args: I[Event]\n\t\t) => CustomSocket<I, O>,\n\t) {\n\t\tthis.emit = emit\n\t\tthis.listeners = new Map()\n\t\tthis.globalListeners = new Set()\n\t}\n\n\tpublic on<Event extends keyof O>(\n\t\tevent: Event,\n\t\tlistener: (...args: O[Event]) => void,\n\t): this {\n\t\tconst listeners = this.listeners.get(event)\n\t\tif (listeners) {\n\t\t\tlisteners.add(listener)\n\t\t} else {\n\t\t\tthis.listeners.set(event, new Set([listener]))\n\t\t}\n\t\treturn this\n\t}\n\n\tpublic onAny(listener: (event: string, ...args: Json.Array) => void): this {\n\t\tthis.globalListeners.add(listener)\n\t\treturn this\n\t}\n\n\tpublic off<Event extends keyof O>(\n\t\tevent: Event,\n\t\tlistener?: (...args: O[Event]) => void,\n\t): this {\n\t\tconst listeners = this.listeners.get(event)\n\t\tif (listeners) {\n\t\t\tif (listener) {\n\t\t\t\tlisteners.delete(listener)\n\t\t\t} else {\n\t\t\t\tthis.listeners.delete(event)\n\t\t\t}\n\t\t}\n\t\treturn this\n\t}\n\n\tpublic offAny(listener: (event: string, ...args: Json.Array) => void): this {\n\t\tthis.globalListeners.delete(listener)\n\t\treturn this\n\t}\n}\n","import type { ChildProcessWithoutNullStreams } from \"node:child_process\"\n\nimport type { Json } from \"atom.io/json\"\nimport { parseJson } from \"atom.io/json\"\n\nimport type { EventBuffer, Events } from \"./custom-socket\"\nimport { CustomSocket } from \"./custom-socket\"\n\n/* eslint-disable no-console */\n\nexport class ChildSocket<\n\tI extends Events,\n\tO extends Events,\n> extends CustomSocket<I, O> {\n\tprotected incompleteData = ``\n\tprotected unprocessedEvents: string[] = []\n\tprotected incompleteLog = ``\n\tprotected unprocessedLogs: string[] = []\n\n\tpublic id = `#####`\n\n\tpublic process: ChildProcessWithoutNullStreams\n\tpublic key: string\n\tpublic logger: Pick<Console, `error` | `info` | `warn`>\n\n\tprotected handleLog(arg: Json.Serializable): void {\n\t\tif (Array.isArray(arg)) {\n\t\t\tconst [level, ...rest] = arg\n\t\t\tswitch (level) {\n\t\t\t\tcase `i`:\n\t\t\t\t\tthis.logger.info(...rest)\n\t\t\t\t\tbreak\n\t\t\t\tcase `w`:\n\t\t\t\t\tthis.logger.warn(...rest)\n\t\t\t\t\tbreak\n\t\t\t\tcase `e`:\n\t\t\t\t\tthis.logger.error(...rest)\n\t\t\t\t\tbreak\n\t\t\t\tdefault:\n\t\t\t\t\treturn\n\t\t\t}\n\t\t}\n\t}\n\n\tpublic constructor(\n\t\tprocess: ChildProcessWithoutNullStreams,\n\t\tkey: string,\n\t\tlogger?: Pick<Console, `error` | `info` | `warn`>,\n\t) {\n\t\tsuper((event, ...args) => {\n\t\t\tconst stringifiedEvent = JSON.stringify([event, ...args]) + `\\x03`\n\t\t\tconst errorHandler = (err: { code: string }) => {\n\t\t\t\tif (err.code === `EPIPE`) {\n\t\t\t\t\tconsole.error(`EPIPE error during write`, this.process.stdin)\n\t\t\t\t}\n\t\t\t\tthis.process.stdin.removeListener(`error`, errorHandler)\n\t\t\t}\n\n\t\t\tthis.process.stdin.once(`error`, errorHandler)\n\t\t\tthis.process.stdin.write(stringifiedEvent)\n\n\t\t\treturn this\n\t\t})\n\t\tthis.process = process\n\t\tthis.key = key\n\t\tthis.logger = logger ?? {\n\t\t\tinfo: (...args: unknown[]) => {\n\t\t\t\tconsole.info(this.id, this.key, ...args)\n\t\t\t},\n\t\t\twarn: (...args: unknown[]) => {\n\t\t\t\tconsole.warn(this.id, this.key, ...args)\n\t\t\t},\n\t\t\terror: (...args: unknown[]) => {\n\t\t\t\tconsole.error(this.id, this.key, ...args)\n\t\t\t},\n\t\t}\n\t\tthis.process.stdout.on(\n\t\t\t`data`,\n\t\t\t<Event extends keyof I>(buffer: EventBuffer<string, I[Event]>) => {\n\t\t\t\tconst chunk = buffer.toString()\n\n\t\t\t\tif (chunk === `ALIVE`) {\n\t\t\t\t\t// console.log(chunk)\n\t\t\t\t\treturn\n\t\t\t\t}\n\t\t\t\tthis.unprocessedEvents.push(...chunk.split(`\\x03`))\n\t\t\t\t// console.log(`🤓`, chunk.length)\n\t\t\t\t// console.log(`🤓`, this.unprocessedEvents.length)\n\t\t\t\t// console.log(`🤓`, ...this.unprocessedEvents.map((x) => x.length))\n\t\t\t\tconst newInput = this.unprocessedEvents.shift()\n\t\t\t\tthis.incompleteData += newInput ?? ``\n\t\t\t\ttry {\n\t\t\t\t\tif (this.incompleteData.startsWith(`error`)) {\n\t\t\t\t\t\tconsole.log(`❗`, this.incompleteData)\n\t\t\t\t\t}\n\t\t\t\t\tlet parsedEvent = parseJson(this.incompleteData)\n\t\t\t\t\tthis.handleEvent(...(parsedEvent as [string, ...I[keyof I]]))\n\t\t\t\t\twhile (this.unprocessedEvents.length > 0) {\n\t\t\t\t\t\tconst event = this.unprocessedEvents.shift()\n\t\t\t\t\t\tif (event) {\n\t\t\t\t\t\t\tif (this.unprocessedEvents.length === 0) {\n\t\t\t\t\t\t\t\tthis.incompleteData = event\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tparsedEvent = parseJson(event)\n\t\t\t\t\t\t\tthis.handleEvent(...(parsedEvent as [string, ...I[keyof I]]))\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tthis.incompleteData = ``\n\t\t\t\t} catch (error) {\n\t\t\t\t\tconsole.warn(`⚠️----------------⚠️`)\n\t\t\t\t\tconsole.warn(this.incompleteData)\n\t\t\t\t\tconsole.warn(`⚠️----------------⚠️`)\n\t\t\t\t\tconsole.error(error)\n\t\t\t\t}\n\t\t\t},\n\t\t)\n\t\tthis.process.stderr.on(`data`, (buf) => {\n\t\t\tconst chunk = buf.toString()\n\t\t\tthis.unprocessedLogs.push(...chunk.split(`\\x03`))\n\t\t\t// console.log(`🤫`, chunk.length)\n\t\t\t// console.log(`🤫`, this.unprocessedLogs.length)\n\t\t\t// console.log(`🤫`, ...this.unprocessedLogs.map((x) => x.length))\n\t\t\tconst newInput = this.unprocessedLogs.shift()\n\t\t\tthis.incompleteLog += newInput ?? ``\n\t\t\ttry {\n\t\t\t\tlet parsedLog = parseJson(this.incompleteLog)\n\t\t\t\t// console.log(`🤫`, parsedLog)\n\t\t\t\tthis.handleLog(parsedLog)\n\t\t\t\twhile (this.unprocessedLogs.length > 0) {\n\t\t\t\t\tthis.incompleteLog = this.unprocessedLogs.shift() ?? ``\n\t\t\t\t\tif (this.incompleteLog) {\n\t\t\t\t\t\tparsedLog = parseJson(this.incompleteLog)\n\t\t\t\t\t\tthis.handleLog(parsedLog)\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} catch (error) {\n\t\t\t\tconsole.error(`❌❌❌`)\n\t\t\t\tconsole.error(this.incompleteLog)\n\t\t\t\tconsole.error(error)\n\t\t\t\tconsole.error(`❌❌❌️`)\n\t\t\t}\n\t\t})\n\t\tif (process.pid) {\n\t\t\tthis.id = process.pid.toString()\n\t\t}\n\t}\n}\n","import { Subject } from \"atom.io/internal\"\nimport type { Json } from \"atom.io/json\"\nimport { parseJson, stringifyJson } from \"atom.io/json\"\nimport { SetRTX } from \"atom.io/transceivers/set-rtx\"\n\nimport type { EventBuffer, Events } from \"./custom-socket\"\nimport { CustomSocket } from \"./custom-socket\"\n\nexport class SubjectSocket<\n\tI extends Events,\n\tO extends Events,\n> extends CustomSocket<I, O> {\n\tpublic in: Subject<[string, ...Json.Serializable[]]>\n\tpublic out: Subject<[string, ...Json.Serializable[]]>\n\tpublic id = `no_id_retrieved`\n\tpublic disposalFunctions: (() => void)[] = []\n\n\tpublic constructor(id: string) {\n\t\tsuper((...args) => {\n\t\t\tthis.out.next(args as any)\n\t\t\treturn this\n\t\t})\n\t\tthis.id = id\n\t\tthis.in = new Subject()\n\t\tthis.out = new Subject()\n\t\tthis.in.subscribe(`socket`, (event) => {\n\t\t\tthis.handleEvent(...(event as [string, ...I[keyof I]]))\n\t\t})\n\t}\n\n\tpublic dispose(): void {\n\t\tfor (const dispose of this.disposalFunctions) {\n\t\t\tdispose()\n\t\t}\n\t}\n}\n\nexport class ParentSocket<\n\tI extends Events & {\n\t\t[id in string as `relay:${id}`]: [string, ...Json.Serializable[]]\n\t},\n\tO extends Events & {\n\t\t[id in string as `user:${id}`]: [string, ...Json.Serializable[]]\n\t} & {\n\t\t/* eslint-disable quotes */\n\t\t\"user-joins\": [string]\n\t\t\"user-leaves\": [string]\n\t\t/* eslint-enable quotes */\n\t},\n> extends CustomSocket<I, O> {\n\tprotected incompleteData = ``\n\tprotected unprocessedEvents: string[] = []\n\tprotected relays: Map<string, SubjectSocket<any, any>>\n\tprotected relayServices: ((\n\t\tsocket: SubjectSocket<any, any>,\n\t) => (() => void) | void)[]\n\tprotected process: NodeJS.Process\n\n\tpublic id = `#####`\n\n\tprotected log(...args: any[]): void {\n\t\tthis.process.stderr.write(\n\t\t\tstringifyJson(\n\t\t\t\targs.map((arg) =>\n\t\t\t\t\targ instanceof SetRTX\n\t\t\t\t\t\t? `{ ${arg.toJSON().members.join(` | `)} }`\n\t\t\t\t\t\t: arg,\n\t\t\t\t),\n\t\t\t) + `\\x03`,\n\t\t)\n\t}\n\tpublic logger = {\n\t\tinfo: (...args: any[]): void => {\n\t\t\tthis.log(`i`, ...args)\n\t\t},\n\t\twarn: (...args: any[]): void => {\n\t\t\tthis.log(`w`, ...args)\n\t\t},\n\t\terror: (...args: any[]): void => {\n\t\t\tthis.log(`e`, ...args)\n\t\t},\n\t}\n\n\tpublic constructor() {\n\t\tsuper((event, ...args) => {\n\t\t\tconst stringifiedEvent = JSON.stringify([event, ...args])\n\t\t\tthis.process.stdout.write(stringifiedEvent + `\\x03`)\n\t\t\treturn this\n\t\t})\n\t\tthis.process = process\n\t\tthis.process.stdin.resume()\n\t\tthis.relays = new Map()\n\t\tthis.relayServices = []\n\t\t// this.logger.info(`🔗`, `uplink`, process.pid)\n\n\t\tthis.process.stdin.on(\n\t\t\t`data`,\n\t\t\t<Event extends keyof I>(buffer: EventBuffer<string, I[Event]>) => {\n\t\t\t\tconst chunk = buffer.toString()\n\t\t\t\tthis.unprocessedEvents.push(...chunk.split(`\\x03`))\n\t\t\t\tconst newInput = this.unprocessedEvents.shift()\n\t\t\t\tthis.incompleteData += newInput ?? ``\n\n\t\t\t\ttry {\n\t\t\t\t\tconst parsedData = parseJson(this.incompleteData)\n\t\t\t\t\tthis.logger.info(`🎰`, `received`, parsedData)\n\t\t\t\t\tthis.handleEvent(...(parsedData as [string, ...I[keyof I]]))\n\t\t\t\t\twhile (this.unprocessedEvents.length > 0) {\n\t\t\t\t\t\tconst event = this.unprocessedEvents.shift()\n\t\t\t\t\t\tif (event) {\n\t\t\t\t\t\t\tif (this.unprocessedEvents.length === 0) {\n\t\t\t\t\t\t\t\tthis.incompleteData = event\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tconst parsedEvent = parseJson(event)\n\t\t\t\t\t\t\tthis.handleEvent(...(parsedEvent as [string, ...I[keyof I]]))\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tthis.incompleteData = ``\n\t\t\t\t} catch (thrown) {\n\t\t\t\t\tif (thrown instanceof Error) {\n\t\t\t\t\t\tthis.logger.error(`❗`, thrown.message, thrown.cause, thrown.stack)\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t},\n\t\t)\n\n\t\tthis.on(`exit`, () => {\n\t\t\tthis.logger.info(`🔥`, this.id, `received \"exit\"`)\n\t\t\tprocess.exit(0)\n\t\t})\n\t\tprocess.on(`exit`, (code) => {\n\t\t\tthis.logger.info(`🔥`, this.id, `exited with code ${code}`)\n\t\t})\n\t\tprocess.on(`end`, () => {\n\t\t\tthis.logger.info(`🔥`, this.id, `ended`)\n\t\t\tprocess.exit(0)\n\t\t})\n\t\tprocess.on(`SIGTERM`, () => {\n\t\t\tthis.logger.error(`🔥`, this.id, `terminated`)\n\t\t\tprocess.exit(0)\n\t\t})\n\t\tprocess.on(`SIGINT`, () => {\n\t\t\tthis.logger.error(`🔥`, this.id, `interrupted`)\n\t\t\tprocess.exit(0)\n\t\t})\n\n\t\tif (process.pid) {\n\t\t\tthis.id = process.pid?.toString()\n\t\t}\n\n\t\tthis.on(`user-joins`, (username) => {\n\t\t\tthis.logger.info(`👤`, `user`, username, `joined`)\n\t\t\tconst relay = new SubjectSocket(`user:${username}`)\n\t\t\tthis.relays.set(username, relay)\n\t\t\tthis.logger.info(\n\t\t\t\t`🔗`,\n\t\t\t\t`attaching services:`,\n\t\t\t\t`[${[...this.relayServices.keys()].join(`, `)}]`,\n\t\t\t)\n\t\t\tfor (const attachServices of this.relayServices) {\n\t\t\t\tconst cleanup = attachServices(relay)\n\t\t\t\tif (cleanup) {\n\t\t\t\t\trelay.disposalFunctions.push(cleanup)\n\t\t\t\t}\n\t\t\t}\n\t\t\tthis.on(`user:${username}`, (...data) => {\n\t\t\t\trelay.in.next(data)\n\t\t\t})\n\t\t\trelay.out.subscribe(`socket`, (data) => {\n\t\t\t\tthis.emit(...(data as [string, ...I[keyof I]]))\n\t\t\t})\n\t\t})\n\n\t\tthis.on(`user-leaves`, (username) => {\n\t\t\tconst relay = this.relays.get(username)\n\t\t\tthis.off(`relay:${username}`)\n\t\t\tif (relay) {\n\t\t\t\trelay.dispose()\n\t\t\t\tthis.relays.delete(username)\n\t\t\t}\n\t\t})\n\n\t\tprocess.stdout.write(`ALIVE`)\n\t}\n\n\tpublic relay(\n\t\tattachServices: (socket: SubjectSocket<any, any>) => (() => void) | void,\n\t): void {\n\t\tthis.logger.info(`🔗`, `running relay method`)\n\t\tthis.relayServices.push(attachServices)\n\t}\n}\n","import type { ChildProcessWithoutNullStreams } from \"node:child_process\"\nimport { spawn } from \"node:child_process\"\n\nimport type {\n\tLoadable,\n\tReadonlyPureSelectorFamilyToken,\n\tRegularAtomFamilyToken,\n} from \"atom.io\"\nimport { atomFamily, selectorFamily } from \"atom.io\"\n\nimport { ChildSocket } from \"../ipc-sockets\"\n\nexport type RoomArguments =\n\t| [script: string, options: string[]]\n\t| [script: string]\n\nexport const roomArgumentsAtoms: RegularAtomFamilyToken<RoomArguments, string> =\n\tatomFamily<RoomArguments, string>({\n\t\tkey: `roomArguments`,\n\t\tdefault: [`echo`, [`Hello World!`]],\n\t})\n\nexport const roomSelectors: ReadonlyPureSelectorFamilyToken<\n\tLoadable<ChildSocket<any, any>>,\n\tstring\n> = selectorFamily<Loadable<ChildSocket<any, any>>, string>({\n\tkey: `room`,\n\tget:\n\t\t(roomId) =>\n\t\tasync ({ get, find }) => {\n\t\t\tconst argumentsState = find(roomArgumentsAtoms, roomId)\n\t\t\tconst args = get(argumentsState)\n\t\t\tconst [script, options] = args\n\t\t\tconst child = await new Promise<ChildProcessWithoutNullStreams>(\n\t\t\t\t(resolve) => {\n\t\t\t\t\tconst room = spawn(script, options, { env: process.env })\n\t\t\t\t\tconst resolver = (data: Buffer) => {\n\t\t\t\t\t\tif (data.toString() === `ALIVE`) {\n\t\t\t\t\t\t\troom.stdout.off(`data`, resolver)\n\t\t\t\t\t\t\tresolve(room)\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\troom.stdout.on(`data`, resolver)\n\t\t\t\t},\n\t\t\t)\n\t\t\treturn new ChildSocket(child, roomId)\n\t\t},\n})\n","import type { Loadable } from \"atom.io\"\nimport * as AtomIO from \"atom.io\"\nimport { editRelationsInStore } from \"atom.io/internal\"\nimport type { UserInRoomMeta } from \"atom.io/realtime\"\nimport { roomIndex, usersInRooms } from \"atom.io/realtime\"\n\nimport type { ChildSocket } from \"../ipc-sockets\"\nimport type { RoomArguments } from \"./server-room-external-store\"\nimport { roomArgumentsAtoms, roomSelectors } from \"./server-room-external-store\"\n\nexport const createRoomTX: AtomIO.TransactionToken<\n\t(\n\t\troomId: string,\n\t\tscript: string,\n\t\toptions?: string[],\n\t) => Loadable<ChildSocket<any, any>>\n> = AtomIO.transaction({\n\tkey: `createRoom`,\n\tdo: ({ get, set, find }, roomId, script, options) => {\n\t\tconst args: RoomArguments = options ? [script, options] : [script]\n\t\tconst roomArgumentsState = find(roomArgumentsAtoms, roomId)\n\t\tset(roomArgumentsState, args)\n\t\tset(roomIndex, (s) => s.add(roomId))\n\t\tconst roomState = find(roomSelectors, roomId)\n\t\tconst room = get(roomState)\n\t\treturn room\n\t},\n})\nexport type CreateRoomIO = AtomIO.TransactionIO<typeof createRoomTX>\n\nexport const joinRoomTX: AtomIO.TransactionToken<\n\t(roomId: string, userId: string, enteredAtEpoch: number) => UserInRoomMeta\n> = AtomIO.transaction({\n\tkey: `joinRoom`,\n\tdo: (tools, roomId, userId, enteredAtEpoch) => {\n\t\tconst meta = { enteredAtEpoch }\n\t\teditRelationsInStore(\n\t\t\tusersInRooms,\n\t\t\t(relations) => {\n\t\t\t\trelations.set({ room: roomId, user: userId }, meta)\n\t\t\t},\n\t\t\ttools.env().store,\n\t\t)\n\t\treturn meta\n\t},\n})\nexport type JoinRoomIO = AtomIO.TransactionIO<typeof joinRoomTX>\n\nexport const leaveRoomTX: AtomIO.TransactionToken<\n\t(roomId: string, userId: string) => void\n> = AtomIO.transaction({\n\tkey: `leaveRoom`,\n\tdo: (tools, roomId, userId) => {\n\t\teditRelationsInStore(\n\t\t\tusersInRooms,\n\t\t\t(relations) => {\n\t\t\t\trelations.delete({ room: roomId, user: userId })\n\t\t\t},\n\t\t\ttools.env().store,\n\t\t)\n\t},\n})\nexport type LeaveRoomIO = AtomIO.TransactionIO<typeof leaveRoomTX>\n\nexport const destroyRoomTX: AtomIO.TransactionToken<(roomId: string) => void> =\n\tAtomIO.transaction({\n\t\tkey: `destroyRoom`,\n\t\tdo: (tools, roomId) => {\n\t\t\teditRelationsInStore(\n\t\t\t\tusersInRooms,\n\t\t\t\t(relations) => {\n\t\t\t\t\trelations.delete({ room: roomId })\n\t\t\t\t},\n\t\t\t\ttools.env().store,\n\t\t\t)\n\t\t\ttools.set(roomIndex, (s) => (s.delete(roomId), s))\n\t\t},\n\t})\n","import type {\n\tRegularAtomFamilyToken,\n\tTransactionUpdate,\n\tTransactionUpdateContent,\n} from \"atom.io\"\nimport { atomFamily } from \"atom.io\"\n\nimport type { UserKey } from \"./server-user-store\"\n\n// export const completeUpdateAtoms = atomFamily<\n// \tTransactionUpdate<any> | null,\n// \tstring\n// >({\n// \tkey: `completeUpdate`,\n// \tdefault: null,\n// })\n\nexport function redactTransactionUpdateContent(\n\tvisibleStateKeys: string[],\n\tupdates: TransactionUpdateContent[],\n): TransactionUpdateContent[] {\n\treturn updates\n\t\t.map((update): TransactionUpdateContent => {\n\t\t\tswitch (update.type) {\n\t\t\t\tcase `transaction_update`: {\n\t\t\t\t\tconst redacted = redactTransactionUpdateContent(\n\t\t\t\t\t\tvisibleStateKeys,\n\t\t\t\t\t\tupdate.updates,\n\t\t\t\t\t)\n\t\t\t\t\treturn { ...update, updates: redacted }\n\t\t\t\t}\n\t\t\t\tcase `atom_update`:\n\t\t\t\tcase `selector_update`:\n\t\t\t\tcase `molecule_creation`:\n\t\t\t\tcase `molecule_disposal`:\n\t\t\t\tcase `molecule_transfer`:\n\t\t\t\tcase `state_creation`:\n\t\t\t\tcase `state_disposal`:\n\t\t\t\t\treturn update\n\t\t\t}\n\t\t})\n\t\t.filter((update) => {\n\t\t\tswitch (update.type) {\n\t\t\t\tcase `atom_update`:\n\t\t\t\tcase `selector_update`:\n\t\t\t\t\treturn visibleStateKeys.includes(update.key)\n\t\t\t\tcase `state_creation`:\n\t\t\t\tcase `state_disposal`:\n\t\t\t\t\treturn visibleStateKeys.includes(update.token.key)\n\t\t\t\tcase `molecule_creation`:\n\t\t\t\tcase `transaction_update`:\n\t\t\t\tcase `molecule_disposal`:\n\t\t\t\tcase `molecule_transfer`:\n\t\t\t\t\treturn true\n\t\t\t}\n\t\t})\n}\n\nexport const redactorAtoms: RegularAtomFamilyToken<\n\t{\n\t\tocclude: (updates: TransactionUpdateContent[]) => TransactionUpdateContent[]\n\t},\n\tUserKey\n> = atomFamily<\n\t{\n\t\tocclude: (updates: TransactionUpdateContent[]) => TransactionUpdateContent[]\n\t},\n\tUserKey\n>({\n\tkey: `redactor`,\n\tdefault: { occlude: (updates) => updates },\n})\n// export const redactedUpdateSelectors = selectorFamily<\n// \tTransactionUpdate<any> | null,\n// \t[transactionKey: string, updateId: string]\n// >({\n// \tkey: `redactedUpdate`,\n// \tget:\n// \t\t([transactionKey, updateId]) =>\n// \t\t({ get, find }) => {\n// \t\t\tconst update = get(find(completeUpdateAtoms, updateId))\n// \t\t\tconst { filter } = get(find(transactionRedactorAtoms, transactionKey))\n\n// \t\t\tif (update && filter) {\n// \t\t\t\treturn { ...update, updates: filter(update.updates) }\n// \t\t\t}\n// \t\t\treturn null\n// \t\t},\n// })\n\nexport type ContinuitySyncTransactionUpdate = Pick<\n\tTransactionUpdate<any>,\n\t`epoch` | `id` | `key` | `output` | `updates`\n>\nexport const userUnacknowledgedQueues: RegularAtomFamilyToken<\n\tContinuitySyncTransactionUpdate[],\n\tUserKey\n> = atomFamily<ContinuitySyncTransactionUpdate[], UserKey>({\n\tkey: `unacknowledgedUpdates`,\n\tdefault: () => [],\n})\n","import type {\n\tHierarchy,\n\tJoinToken,\n\tMutableAtomToken,\n\tRegularAtomFamilyToken,\n} from \"atom.io\"\nimport { atom, atomFamily, join } from \"atom.io\"\nimport type { SetRTXJson } from \"atom.io/transceivers/set-rtx\"\nimport { SetRTX } from \"atom.io/transceivers/set-rtx\"\n\nimport type { Socket } from \"..\"\n\nexport type SocketKey = `socket::${string}`\nexport type UserKey = `user::${string}`\nexport type RoomKey = `room::${string}`\n\nexport type SocketSystemHierarchy = Hierarchy<\n\t[\n\t\t{\n\t\t\tabove: `root`\n\t\t\tbelow: [UserKey, SocketKey, RoomKey]\n\t\t},\n\t]\n>\n\nexport const socketAtoms: RegularAtomFamilyToken<Socket | null, SocketKey> =\n\tatomFamily<Socket | null, SocketKey>({\n\t\tkey: `sockets`,\n\t\tdefault: null,\n\t})\n\nexport const socketIndex: MutableAtomToken<\n\tSetRTX<SocketKey>,\n\tSetRTXJson<SocketKey>\n> = atom<SetRTX<SocketKey>, SetRTXJson<SocketKey>>({\n\tkey: `socketsIndex`,\n\tmutable: true,\n\tdefault: () => new SetRTX(),\n\ttoJson: (set) => set.toJSON(),\n\tfromJson: (json) => SetRTX.fromJSON(json),\n})\nexport const userIndex: MutableAtomToken<\n\tSetRTX<UserKey>,\n\tSetRTXJson<UserKey>\n> = atom<SetRTX<UserKey>, SetRTXJson<UserKey>>({\n\tkey: `usersIndex`,\n\tmutable: true,\n\tdefault: () => new SetRTX(),\n\ttoJson: (set) => set.toJSON(),\n\tfromJson: (json) => SetRTX.fromJSON(json),\n})\nexport const usersOfSockets: JoinToken<\n\t`user`,\n\tUserKey,\n\t`socket`,\n\tSocketKey,\n\t`1:1`\n> = join({\n\tkey: `usersOfSockets`,\n\tbetween: [`user`, `socket`],\n\tcardinality: `1:1`,\n\tisAType: (s): s is UserKey => s.startsWith(`user::`),\n\tisBType: (s): s is SocketKey => s.startsWith(`socket::`),\n})\n","import type { Store } from \"atom.io/internal\"\nimport {\n\tfindInStore,\n\tgetFromStore,\n\tgetJsonToken,\n\tisRootStore,\n} from \"atom.io/internal\"\nimport type { Json } from \"atom.io/json\"\nimport type { ContinuityToken } from \"atom.io/realtime\"\n\nimport type { Socket, UserKey } from \"..\"\n\nexport function prepareToSendInitialPayload(\n\tstore: Store,\n\tcontinuity: ContinuityToken,\n\tuserKey: UserKey,\n\tsocket: Socket | null,\n): () => void {\n\tconst continuityKey = continuity.key\n\treturn function sendInitialPayload(): void {\n\t\tconst initialPayload: Json.Serializable[] = []\n\t\tfor (const atom of continuity.globals) {\n\t\t\tconst resourceToken =\n\t\t\t\tatom.type === `mutable_atom` ? getJsonToken(store, atom) : atom\n\t\t\tconst resource = getFromStore(store, resourceToken)\n\t\t\tinitialPayload.push(resourceToken, resource)\n\t\t}\n\t\tfor (const perspective of continuity.perspectives) {\n\t\t\tconst { viewAtoms, resourceAtoms } = perspective\n\t\t\tconst userViewState = findInStore(store, viewAtoms, userKey)\n\t\t\tconst userView = getFromStore(store, userViewState)\n\t\t\tstore.logger.info(`👁`, `atom`, resourceAtoms.key, `${userKey} can see`, {\n\t\t\t\tviewAtoms,\n\t\t\t\tresourceAtoms,\n\t\t\t\tuserView,\n\t\t\t})\n\t\t\tfor (const visibleToken of userView) {\n\t\t\t\tconst resourceToken =\n\t\t\t\t\tvisibleToken.type === `mutable_atom`\n\t\t\t\t\t\t? getJsonToken(store, visibleToken)\n\t\t\t\t\t\t: visibleToken\n\t\t\t\tconst resource = getFromStore(store, resourceToken)\n\n\t\t\t\tinitialPayload.push(resourceToken, resource)\n\t\t\t}\n\t\t}\n\n\t\tconst epoch = isRootStore(store)\n\t\t\t? (store.transactionMeta.epoch.get(continuityKey) ?? null)\n\t\t\t: null\n\n\t\tsocket?.emit(`continuity-init:${continuityKey}`, epoch, initialPayload)\n\t}\n}\n","import type { TransactionUpdate } from \"atom.io\"\nimport type { Store } from \"atom.io/internal\"\nimport { actUponStore } from \"atom.io/internal\"\nimport type { JsonIO } from \"atom.io/json\"\nimport type { ContinuityToken } from \"atom.io/realtime\"\n\nexport function prepareToServeTransactionRequest(\n\tstore: Store,\n\tcontinuity: ContinuityToken,\n\tuserKey: string,\n): (update: Pick<TransactionUpdate<JsonIO>, `id` | `key` | `params`>) => void {\n\tconst continuityKey = continuity.key\n\treturn function serveTransactionRequest(update) {\n\t\tstore.logger.info(`🛎️`, `continuity`, continuityKey, `received`, update)\n\t\tconst transactionKey = update.key\n\t\tconst updateId = update.id\n\t\tconst performanceKey = `tx-run:${transactionKey}:${updateId}`\n\t\tconst performanceKeyStart = `${performanceKey}:start`\n\t\tconst performanceKeyEnd = `${performanceKey}:end`\n\t\tperformance.mark(performanceKeyStart)\n\t\ttry {\n\t\t\tactUponStore(\n\t\t\t\tstore,\n\t\t\t\t{ type: `transaction`, key: transactionKey },\n\t\t\t\tupdateId,\n\t\t\t)(...update.params)\n\t\t} catch (thrown) {\n\t\t\tif (thrown instanceof Error) {\n\t\t\t\tstore.logger.error(\n\t\t\t\t\t`❌`,\n\t\t\t\t\t`continuity`,\n\t\t\t\t\tcontinuityKey,\n\t\t\t\t\t`failed to run transaction ${transactionKey} from ${userKey} with update ${updateId}`,\n\t\t\t\t\tthrown.message,\n\t\t\t\t)\n\t\t\t}\n\t\t}\n\t\tperformance.mark(performanceKeyEnd)\n\t\tconst metric = performance.measure(\n\t\t\tperformanceKey,\n\t\t\tperformanceKeyStart,\n\t\t\tperformanceKeyEnd,\n\t\t)\n\t\tstore?.logger.info(\n\t\t\t`🚀`,\n\t\t\t`transaction`,\n\t\t\ttransactionKey,\n\t\t\tupdateId,\n\t\t\tuserKey,\n\t\t\tmetric.duration,\n\t\t)\n\t}\n}\n","import type { Store } from \"atom.io/internal\"\nimport { setIntoStore } from \"atom.io/internal\"\nimport type { ContinuityToken } from \"atom.io/realtime\"\n\nimport type { ContinuitySyncTransactionUpdate } from \"../realtime-server-stores\"\nimport { userUnacknowledgedQueues } from \"../realtime-server-stores\"\n\nexport function prepareToTrackClientAcknowledgement(\n\tstore: Store,\n\tcontinuity: ContinuityToken,\n\tuserKey: string,\n\tuserUnacknowledgedUpdates: ContinuitySyncTransactionUpdate[],\n): (epoch: number) => void {\n\tconst continuityKey = continuity.key\n\treturn function trackClientAcknowledgement(epoch) {\n\t\tstore.logger.info(\n\t\t\t`👍`,\n\t\t\t`continuity`,\n\t\t\tcontinuityKey,\n\t\t\t`${userKey} acknowledged epoch ${epoch}`,\n\t\t)\n\t\tconst isUnacknowledged = userUnacknowledgedUpdates[0]?.epoch === epoch\n\t\tif (isUnacknowledged) {\n\t\t\tsetIntoStore(store, userUnacknowledgedQueues, userKey, (updates) => {\n\t\t\t\tupdates.shift()\n\t\t\t\tstore.logger.info(\n\t\t\t\t\t`👍`,\n\t\t\t\t\t`continuity`,\n\t\t\t\t\tcontinuityKey,\n\t\t\t\t\t`${userKey} unacknowledged update queue now has`,\n\t\t\t\t\tupdates.length,\n\t\t\t\t\t`items`,\n\t\t\t\t)\n\t\t\t\treturn updates\n\t\t\t})\n\t\t}\n\t}\n}\n","import type { Store } from \"atom.io/internal\"\nimport {\n\tfindInStore,\n\tgetFromStore,\n\tgetUpdateToken,\n\tsetIntoStore,\n\tsubscribeToTransaction,\n} from \"atom.io/internal\"\nimport type { Json } from \"atom.io/json\"\nimport type { ContinuityToken } from \"atom.io/realtime\"\n\nimport type { Socket, UserKey } from \"..\"\nimport {\n\tredactTransactionUpdateContent,\n\tuserUnacknowledgedQueues,\n} from \"../realtime-server-stores\"\n\nexport function subscribeToContinuityActions(\n\tstore: Store,\n\tcontinuity: ContinuityToken,\n\tuserKey: UserKey,\n\tsocket: Socket | null,\n): (() => void)[] {\n\tconst continuityKey = continuity.key\n\tconst unsubscribeFunctions: (() => void)[] = []\n\n\tfor (const transaction of continuity.actions) {\n\t\tconst unsubscribeFromTransaction = subscribeToTransaction(\n\t\t\tstore,\n\t\t\ttransaction,\n\t\t\t`sync-continuity:${continuityKey}:${userKey}`,\n\t\t\t(update) => {\n\t\t\t\ttry {\n\t\t\t\t\tconst visibleKeys = continuity.globals\n\t\t\t\t\t\t.map((atom) => {\n\t\t\t\t\t\t\tif (atom.type === `atom`) {\n\t\t\t\t\t\t\t\treturn atom.key\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\treturn getUpdateToken(atom).key\n\t\t\t\t\t\t})\n\t\t\t\t\t\t.concat(\n\t\t\t\t\t\t\tcontinuity.perspectives.flatMap((perspective) => {\n\t\t\t\t\t\t\t\tconst { viewAtoms } = perspective\n\t\t\t\t\t\t\t\tconst userPerspectiveTokenState = findInStore(\n\t\t\t\t\t\t\t\t\tstore,\n\t\t\t\t\t\t\t\t\tviewAtoms,\n\t\t\t\t\t\t\t\t\tuserKey,\n\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t\tconst visibleTokens = getFromStore(\n\t\t\t\t\t\t\t\t\tstore,\n\t\t\t\t\t\t\t\t\tuserPerspectiveTokenState,\n\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t\treturn visibleTokens.map((token) => {\n\t\t\t\t\t\t\t\t\tconst key =\n\t\t\t\t\t\t\t\t\t\ttoken.type === `mutable_atom` ? `*` + token.key : token.key\n\t\t\t\t\t\t\t\t\treturn key\n\t\t\t\t\t\t\t\t})\n\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t)\n\t\t\t\t\tconst redactedUpdates = redactTransactionUpdateContent(\n\t\t\t\t\t\tvisibleKeys,\n\t\t\t\t\t\tupdate.updates,\n\t\t\t\t\t)\n\t\t\t\t\tconst redactedUpdate = {\n\t\t\t\t\t\t...update,\n\t\t\t\t\t\tupdates: redactedUpdates,\n\t\t\t\t\t}\n\t\t\t\t\tsetIntoStore(store, userUnacknowledgedQueues, userKey, (updates) => {\n\t\t\t\t\t\tif (redactedUpdate) {\n\t\t\t\t\t\t\tupdates.push(redactedUpdate)\n\t\t\t\t\t\t\tupdates.sort((a, b) => a.epoch - b.epoch)\n\t\t\t\t\t\t\tstore.logger.info(\n\t\t\t\t\t\t\t\t`👍`,\n\t\t\t\t\t\t\t\t`continuity`,\n\t\t\t\t\t\t\t\tcontinuityKey,\n\t\t\t\t\t\t\t\t`${userKey} unacknowledged update queue now has`,\n\t\t\t\t\t\t\t\tupdates.length,\n\t\t\t\t\t\t\t\t`items`,\n\t\t\t\t\t\t\t)\n\t\t\t\t\t\t}\n\t\t\t\t\t\treturn updates\n\t\t\t\t\t})\n\n\t\t\t\t\tsocket?.emit(\n\t\t\t\t\t\t`tx-new:${continuityKey}`,\n\t\t\t\t\t\tredactedUpdate as Json.Serializable,\n\t\t\t\t\t)\n\t\t\t\t} catch (thrown) {\n\t\t\t\t\tif (thrown instanceof Error) {\n\t\t\t\t\t\tstore.logger.error(\n\t\t\t\t\t\t\t`❌`,\n\t\t\t\t\t\t\t`continuity`,\n\t\t\t\t\t\t\tcontinuityKey,\n\t\t\t\t\t\t\t`${userKey} failed to send update from transaction ${transaction.key} to ${userKey}`,\n\t\t\t\t\t\t\tthrown.message,\n\t\t\t\t\t\t)\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t},\n\t\t)\n\t\tunsubscribeFunctions.push(unsubscribeFromTransaction)\n\t}\n\treturn unsubscribeFunctions\n}\n","import type { Store } from \"atom.io/internal\"\nimport {\n\tfindInStore,\n\tgetFromStore,\n\tgetJsonToken,\n\tsubscribeToState,\n} from \"atom.io/internal\"\nimport type { ContinuityToken } from \"atom.io/realtime\"\n\nimport type { Socket } from \"..\"\nimport type { UserKey } from \"../realtime-server-stores\"\n\nexport function subscribeToContinuityPerspectives(\n\tstore: Store,\n\tcontinuity: ContinuityToken,\n\tuserKey: UserKey,\n\tsocket: Socket | null,\n): (() => void)[] {\n\tconst continuityKey = continuity.key\n\tconst unsubFns: (() => void)[] = []\n\tfor (const perspective of continuity.perspectives) {\n\t\tconst { viewAtoms } = perspective\n\t\tconst userViewState = findInStore(store, viewAtoms, userKey)\n\t\tconst unsubscribeFromUserView = subscribeToState(\n\t\t\tstore,\n\t\t\tuserViewState,\n\t\t\t`sync-continuity:${continuityKey}:${userKey}:perspective:${perspective.resourceAtoms.key}`,\n\t\t\t({ oldValue, newValue }) => {\n\t\t\t\tconst oldKeys = oldValue.map((token) => token.key)\n\t\t\t\tconst newKeys = newValue.map((token) => token.key)\n\t\t\t\tconst concealed = oldValue.filter(\n\t\t\t\t\t(token) => !newKeys.includes(token.key),\n\t\t\t\t)\n\t\t\t\tconst revealed = newValue\n\t\t\t\t\t.filter((token) => !oldKeys.includes(token.key))\n\t\t\t\t\t.flatMap((token) => {\n\t\t\t\t\t\tconst resourceToken =\n\t\t\t\t\t\t\ttoken.type === `mutable_atom` ? getJsonToken(store, token) : token\n\t\t\t\t\t\tconst resource = getFromStore(store, resourceToken)\n\t\t\t\t\t\treturn [resourceToken, resource]\n\t\t\t\t\t})\n\t\t\t\tstore.logger.info(\n\t\t\t\t\t`👁`,\n\t\t\t\t\t`atom`,\n\t\t\t\t\tperspective.resourceAtoms.key,\n\t\t\t\t\t`${userKey} has a new perspective`,\n\t\t\t\t\t{ oldKeys, newKeys, revealed, concealed },\n\t\t\t\t)\n\t\t\t\tif (revealed.length > 0) {\n\t\t\t\t\tsocket?.emit(`reveal:${continuityKey}`, revealed)\n\t\t\t\t}\n\t\t\t\tif (concealed.length > 0) {\n\t\t\t\t\tsocket?.emit(`conceal:${continuityKey}`, concealed)\n\t\t\t\t}\n\t\t\t},\n\t\t)\n\t\tunsubFns.push(unsubscribeFromUserView)\n\t}\n\treturn unsubFns\n}\n","import {\n\tfindInStore,\n\tfindRelationsInStore,\n\tgetFromStore,\n\tIMPLICIT,\n\tsubscribeToState,\n} from \"atom.io/internal\"\nimport type { Json } from \"atom.io/json\"\nimport type { ContinuityToken } from \"atom.io/realtime\"\n\nimport type { ServerConfig, Socket } from \"..\"\nimport { socketAtoms, usersOfSockets } from \"..\"\nimport { userUnacknowledgedQueues } from \"../realtime-server-stores\"\nimport { prepareToSendInitialPayload } from \"./prepare-to-send-initial-payload\"\nimport { prepareToServeTransactionRequest } from \"./prepare-to-serve-transaction-request\"\nimport { prepareToTrackClientAcknowledgement } from \"./prepare-to-track-client-acknowledgement\"\nimport { subscribeToContinuityActions } from \"./subscribe-to-continuity-actions\"\nimport { subscribeToContinuityPerspectives } from \"./subscribe-to-continuity-perpectives\"\n\nexport type ExposeRealtimeContinuity = (\n\tcontinuity: ContinuityToken,\n) => () => void\nexport function prepareToExposeRealtimeContinuity({\n\tsocket: initialSocket,\n\tstore = IMPLICIT.STORE,\n}: ServerConfig): ExposeRealtimeContinuity {\n\treturn function syncRealtimeContinuity(continuity) {\n\t\tlet socket: Socket | null = initialSocket\n\n\t\tconst continuityKey = continuity.key\n\t\tconst userKeyState = findRelationsInStore(\n\t\t\tusersOfSockets,\n\t\t\t`socket::${socket.id}`,\n\t\t\tstore,\n\t\t).userKeyOfSocket\n\t\tconst userKey = getFromStore(store, userKeyState)\n\t\tif (!userKey) {\n\t\t\tstore.logger.error(\n\t\t\t\t`❌`,\n\t\t\t\t`continuity`,\n\t\t\t\tcontinuityKey,\n\t\t\t\t`Tried to create a synchronizer for a socket (${socket.id}) that is not connected to a user.`,\n\t\t\t)\n\t\t\treturn () => {}\n\t\t}\n\n\t\tconst socketKeyState = findRelationsInStore(\n\t\t\tusersOfSockets,\n\t\t\tuserKey,\n\t\t\tstore,\n\t\t).socketKeyOfUser\n\t\tconst _unsubscribeFromSocketTracking = subscribeToState(\n\t\t\tstore,\n\t\t\tsocketKeyState,\n\t\t\t`sync-continuity:${continuityKey}:${userKey}`,\n\t\t\t({ newValue: newSocketKey }) => {\n\t\t\t\tstore.logger.info(\n\t\t\t\t\t`👋`,\n\t\t\t\t\t`continuity`,\n\t\t\t\t\tcontinuityKey,\n\t\t\t\t\t`seeing ${userKey} on new socket ${newSocketKey}`,\n\t\t\t\t)\n\t\t\t\tif (newSocketKey === null) {\n\t\t\t\t\tstore.logger.warn(\n\t\t\t\t\t\t`❌`,\n\t\t\t\t\t\t`continuity`,\n\t\t\t\t\t\tcontinuityKey,\n\t\t\t\t\t\t`User (${userKey}) is not connected to a socket, waiting for them to reappear.`,\n\t\t\t\t\t)\n\t\t\t\t\treturn\n\t\t\t\t}\n\t\t\t\tconst newSocketState = findInStore(store, socketAtoms, newSocketKey)\n\t\t\t\tconst newSocket = getFromStore(store, newSocketState)\n\t\t\t\tsocket = newSocket\n\t\t\t\tfor (const unacknowledgedUpdate of userUnacknowledgedUpdates) {\n\t\t\t\t\tsocket?.emit(\n\t\t\t\t\t\t`tx-new:${continuityKey}`,\n\t\t\t\t\t\tunacknowledgedUpdate as Json.Serializable,\n\t\t\t\t\t)\n\t\t\t\t}\n\t\t\t},\n\t\t)\n\n\t\tconst userUnacknowledgedUpdates = getFromStore(\n\t\t\tstore,\n\t\t\tuserUnacknowledgedQueues,\n\t\t\tuserKey,\n\t\t)\n\n\t\tconst unsubscribeFunctions: (() => void)[] = []\n\n\t\tconst unsubscribeFromPerspectives = subscribeToContinuityPerspectives(\n\t\t\tstore,\n\t\t\tcontinuity,\n\t\t\tuserKey,\n\t\t\tsocket,\n\t\t)\n\t\tconst unsubscribeFromTransactions = subscribeToContinuityActions(\n\t\t\tstore,\n\t\t\tcontinuity,\n\t\t\tuserKey,\n\t\t\tsocket,\n\t\t)\n\t\tunsubscribeFunctions.push(\n\t\t\t...unsubscribeFromPerspectives,\n\t\t\t...unsubscribeFromTransactions,\n\t\t)\n\n\t\tconst sendInitialPayload = prepareToSendInitialPayload(\n\t\t\tstore,\n\t\t\tcontinuity,\n\t\t\tuserKey,\n\t\t\tinitialSocket,\n\t\t)\n\n\t\tsocket.off(`get:${continuityKey}`, sendInitialPayload)\n\t\tsocket.on(`get:${continuityKey}`, sendInitialPayload)\n\n\t\tconst fillTransactionRequest = prepareToServeTransactionRequest(\n\t\t\tstore,\n\t\t\tcontinuity,\n\t\t\tuserKey,\n\t\t)\n\n\t\tsocket.off(`tx-run:${continuityKey}`, fillTransactionRequest)\n\t\tsocket.on(`tx-run:${continuityKey}`, fillTransactionRequest)\n\n\t\tconst trackClientAcknowledgement = prepareToTrackClientAcknowledgement(\n\t\t\tstore,\n\t\t\tcontinuity,\n\t\t\tuserKey,\n\t\t\tuserUnacknowledgedUpdates,\n\t\t)\n\n\t\tsocket?.on(`ack:${continuityKey}`, trackClientAcknowledgement)\n\n\t\treturn () => {\n\t\t\t// clearInterval(retryTimeout)\n\t\t\tfor (const unsubscribe of unsubscribeFunctions) unsubscribe()\n\t\t\tsocket?.off(`ack:${continuityKey}`, trackClientAcknowledgement)\n\t\t\tsocket?.off(`get:${continuityKey}`, sendInitialPayload)\n\t\t\tsocket?.off(`tx-run:${continuityKey}`, fillTransactionRequest)\n\t\t}\n\t}\n}\n","import type * as AtomIO from \"atom.io\"\nimport { actUponStore, IMPLICIT } from \"atom.io/internal\"\nimport type { JsonIO } from \"atom.io/json\"\n\nimport type { ServerConfig } from \".\"\n\nexport type ActionReceiver = ReturnType<typeof realtimeActionReceiver>\nexport function realtimeActionReceiver({\n\tsocket,\n\tstore = IMPLICIT.STORE,\n}: ServerConfig) {\n\treturn function actionReceiver<F extends JsonIO>(\n\t\ttx: AtomIO.TransactionToken<F>,\n\t): () => void {\n\t\tconst fillTransactionRequest = (\n\t\t\tupdate: Pick<AtomIO.TransactionUpdate<F>, `id` | `params`>,\n\t\t) => {\n\t\t\tconst performanceKey = `tx-run:${tx.key}:${update.id}`\n\t\t\tconst performanceKeyStart = `${performanceKey}:start`\n\t\t\tconst performanceKeyEnd = `${performanceKey}:end`\n\t\t\tperformance.mark(performanceKeyStart)\n\t\t\tactUponStore<F>(store, tx, update.id)(...update.params)\n\t\t\tperformance.mark(performanceKeyEnd)\n\t\t\tconst metric = performance.measure(\n\t\t\t\tperformanceKey,\n\t\t\t\tperformanceKeyStart,\n\t\t\t\tperformanceKeyEnd,\n\t\t\t)\n\t\t\tstore?.logger.info(`🚀`, `transaction`, tx.key, update.id, metric.duration)\n\t\t}\n\t\tsocket.on(`tx-run:${tx.key}`, fillTransactionRequest)\n\n\t\treturn () => {\n\t\t\tsocket.off(`tx-run:${tx.key}`, fillTransactionRequest)\n\t\t}\n\t}\n}\n","import type * as AtomIO from \"atom.io\"\nimport {\n\tfindInStore,\n\tgetFromStore,\n\tIMPLICIT,\n\tsubscribeToState,\n} from \"atom.io/internal\"\nimport type { Canonical, Json } from \"atom.io/json\"\nimport { stringifyJson } from \"atom.io/json\"\n\nimport type { ServerConfig } from \".\"\n\nexport type FamilyProvider = ReturnType<typeof realtimeAtomFamilyProvider>\nexport function realtimeAtomFamilyProvider({\n\tsocket,\n\tstore = IMPLICIT.STORE,\n}: ServerConfig) {\n\treturn function familyProvider<\n\t\tJ extends Json.Serializable,\n\t\tK extends Canonical,\n\t>(\n\t\tfamily: AtomIO.RegularAtomFamilyToken<J, K>,\n\t\tindex: AtomIO.ReadableToken<Iterable<K>>,\n\t): () => void {\n\t\tconst unsubCallbacksByKey = new Map<string, () => void>()\n\n\t\tconst fillUnsubRequest = (key: string) => {\n\t\t\tsocket.off(`unsub:${key}`, fillUnsubRequest)\n\t\t\tconst unsub = unsubCallbacksByKey.get(key)\n\t\t\tif (unsub) {\n\t\t\t\tunsub()\n\t\t\t\tunsubCallbacksByKey.delete(key)\n\t\t\t}\n\t\t}\n\n\t\tconst fillSubRequest = (subKey: K) => {\n\t\t\tconst exposedSubKeys = getFromStore(store, index)\n\t\t\tfor (const exposedSubKey of exposedSubKeys) {\n\t\t\t\tif (stringifyJson(exposedSubKey) === stringifyJson(subKey)) {\n\t\t\t\t\tconst token = findInStore(store, family, subKey)\n\t\t\t\t\tsocket.emit(`serve:${token.key}`, getFromStore(store, token))\n\t\t\t\t\tconst unsubscribe = subscribeToState(\n\t\t\t\t\t\tstore,\n\t\t\t\t\t\ttoken,\n\t\t\t\t\t\t`expose-family:${family.key}:${socket.id}`,\n\t\t\t\t\t\t({ newValue }) => {\n\t\t\t\t\t\t\tsocket.emit(`serve:${token.key}`, newValue)\n\t\t\t\t\t\t},\n\t\t\t\t\t)\n\t\t\t\t\tunsubCallbacksByKey.set(token.key, unsubscribe)\n\t\t\t\t\tsocket.on(`unsub:${token.key}`, () => {\n\t\t\t\t\t\tfillUnsubRequest(token.key)\n\t\t\t\t\t})\n\t\t\t\t\tbreak\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tsocket.on(`sub:${family.key}`, fillSubRequest)\n\n\t\treturn () => {\n\t\t\tsocket.off(`sub:${family.key}`, fillSubRequest)\n\n\t\t\tfor (const [, unsub] of unsubCallbacksByKey) {\n\t\t\t\tunsub()\n\t\t\t}\n\t\t\tunsubCallbacksByKey.clear()\n\t\t}\n\t}\n}\n","import type * as AtomIO from \"atom.io\"\nimport type { Transceiver } from \"atom.io/internal\"\nimport {\n\tfindInStore,\n\tgetFromStore,\n\tgetJsonToken,\n\tgetUpdateToken,\n\tIMPLICIT,\n\tsubscribeToState,\n} from \"atom.io/internal\"\nimport type { Canonical, Json } from \"atom.io/json\"\nimport { stringifyJson } from \"atom.io/json\"\n\nimport type { ServerConfig } from \".\"\n\nexport type MutableFamilyProvider = ReturnType<\n\ttypeof realtimeMutableFamilyProvider\n>\nexport function realtimeMutableFamilyProvider({\n\tsocket,\n\tstore = IMPLICIT.STORE,\n}: ServerConfig) {\n\treturn function mutableFamilyProvider<\n\t\tT extends Transceiver<any>,\n\t\tJ extends Json.Serializable,\n\t\tK extends Canonical,\n\t>(\n\t\tfamily: AtomIO.MutableAtomFamilyToken<T, J, K>,\n\t\tindex: AtomIO.ReadableToken<Iterable<K>>,\n\t): () => void {\n\t\tconst unsubCallbacksByKey = new Map<string, () => void>()\n\n\t\tconst fillUnsubRequest = (key: string) => {\n\t\t\tsocket.off(`unsub:${key}`, fillUnsubRequest)\n\t\t\tconst unsub = unsubCallbacksByKey.get(key)\n\t\t\tif (unsub) {\n\t\t\t\tunsub()\n\t\t\t\tunsubCallbacksByKey.delete(key)\n\t\t\t}\n\t\t}\n\n\t\tconst fillSubRequest = (subKey: K) => {\n\t\t\tconst exposedSubKeys = getFromStore(store, index)\n\t\t\tfor (const exposedSubKey of exposedSubKeys) {\n\t\t\t\tif (stringifyJson(exposedSubKey) === stringifyJson(subKey)) {\n\t\t\t\t\tconst token = findInStore(store, family, subKey)\n\t\t\t\t\tgetFromStore(store, token)\n\t\t\t\t\tconst jsonToken = getJsonToken(store, token)\n\t\t\t\t\tconst updateToken = getUpdateToken(token)\n\t\t\t\t\tsocket.emit(`init:${token.key}`, getFromStore(store, jsonToken))\n\t\t\t\t\tconst unsubscribe = subscribeToState(\n\t\t\t\t\t\tstore,\n\t\t\t\t\t\tupdateToken,\n\t\t\t\t\t\t`expose-family:${family.key}:${socket.id}`,\n\t\t\t\t\t\t({ newValue }) => {\n\t\t\t\t\t\t\tsocket.emit(`next:${token.key}`, newValue)\n\t\t\t\t\t\t},\n\t\t\t\t\t)\n\t\t\t\t\tunsubCallbacksByKey.set(token.key, unsubscribe)\n\t\t\t\t\tsocket.on(`unsub:${token.key}`, () => {\n\t\t\t\t\t\tfillUnsubRequest(token.key)\n\t\t\t\t\t})\n\t\t\t\t\tbreak\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tsocket.on(`sub:${family.key}`, fillSubRequest)\n\n\t\treturn () => {\n\t\t\tsocket.off(`sub:${family.key}`, fillSubRequest)\n\t\t\tfor (const [, unsub] of unsubCallbacksByKey) {\n\t\t\t\tunsub()\n\t\t\t}\n\t\t\tunsubCallbacksByKey.clear()\n\t\t}\n\t}\n}\n","import type * as AtomIO from \"atom.io\"\nimport type { Transceiver } from \"atom.io/internal\"\nimport {\n\tgetFromStore,\n\tgetJsonToken,\n\tgetUpdateToken,\n\tIMPLICIT,\n\tsubscribeToState,\n} from \"atom.io/internal\"\nimport type { Json } from \"atom.io/json\"\n\nimport type { ServerConfig } from \".\"\n\nexport type MutableProvider = ReturnType<typeof realtimeMutableProvider>\nexport function realtimeMutableProvider({\n\tsocket,\n\tstore = IMPLICIT.STORE,\n}: ServerConfig) {\n\treturn function mutableProvider<\n\t\tCore extends Transceiver<Json.Serializable>,\n\t\tSerializableCore extends Json.Serializable,\n\t>(token: AtomIO.MutableAtomToken<Core, SerializableCore>): () => void {\n\t\tlet unsubscribeFromStateUpdates: (() => void) | null = null\n\n\t\tconst jsonToken = getJsonToken(store, token)\n\t\tconst trackerToken = getUpdateToken(token)\n\n\t\tconst fillUnsubRequest = () => {\n\t\t\tsocket.off(`unsub:${token.key}`, fillUnsubRequest)\n\t\t\tunsubscribeFromStateUpdates?.()\n\t\t\tunsubscribeFromStateUpdates = null\n\t\t}\n\n\t\tconst fillSubRequest = () => {\n\t\t\tsocket.emit(`init:${token.key}`, getFromStore(store, jsonToken))\n\t\t\tunsubscribeFromStateUpdates = subscribeToState(\n\t\t\t\tstore,\n\t\t\t\ttrackerToken,\n\t\t\t\t`expose-single:${socket.id}`,\n\t\t\t\t({ newValue }) => {\n\t\t\t\t\tsocket.emit(`next:${token.key}`, newValue)\n\t\t\t\t},\n\t\t\t)\n\t\t\tsocket.on(`unsub:${token.key}`, fillUnsubRequest)\n\t\t}\n\n\t\tsocket.on(`sub:${token.key}`, fillSubRequest)\n\n\t\treturn () => {\n\t\t\tsocket.off(`sub:${token.key}`, fillSubRequest)\n\t\t\tunsubscribeFromStateUpdates?.()\n\t\t}\n\t}\n}\n","import type * as AtomIO from \"atom.io\"\nimport { getFromStore, IMPLICIT, subscribeToState } from \"atom.io/internal\"\nimport type { Json } from \"atom.io/json\"\n\nimport type { ServerConfig } from \".\"\n\nexport type StateProvider = ReturnType<typeof realtimeStateProvider>\nexport function realtimeStateProvider({\n\tsocket,\n\tstore = IMPLICIT.STORE,\n}: ServerConfig) {\n\treturn function stateProvider<J extends Json.Serializable>(\n\t\ttoken: AtomIO.WritableToken<J>,\n\t): () => void {\n\t\tlet unsubscribeFromStateUpdates: (() => void) | undefined\n\n\t\tconst fillSubRequest = () => {\n\t\t\tsocket.emit(`serve:${token.key}`, getFromStore(store, token))\n\n\t\t\tunsubscribeFromStateUpdates = subscribeToState(\n\t\t\t\tstore,\n\t\t\t\ttoken,\n\t\t\t\t`expose-single:${socket.id}`,\n\t\t\t\t({ newValue }) => {\n\t\t\t\t\tsocket.emit(`serve:${token.key}`, newValue)\n\t\t\t\t},\n\t\t\t)\n\n\t\t\tconst fillUnsubRequest = () => {\n\t\t\t\tsocket.off(`unsub:${token.key}`, fillUnsubRequest)\n\t\t\t\tif (unsubscribeFromStateUpdates) {\n\t\t\t\t\tunsubscribeFromStateUpdates()\n\t\t\t\t\tunsubscribeFromStateUpdates = undefined\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tsocket.on(`unsub:${token.key}`, fillUnsubRequest)\n\t\t}\n\n\t\tsocket.on(`sub:${token.key}`, fillSubRequest)\n\n\t\treturn () => {\n\t\t\tsocket.off(`sub:${token.key}`, fillSubRequest)\n\t\t\tif (unsubscribeFromStateUpdates) {\n\t\t\t\tunsubscribeFromStateUpdates()\n\t\t\t\tunsubscribeFromStateUpdates = undefined\n\t\t\t}\n\t\t}\n\t}\n}\n","import type { WritableToken } from \"atom.io\"\nimport { IMPLICIT, setIntoStore } from \"atom.io/internal\"\nimport type { Json } from \"atom.io/json\"\n\nimport type { ServerConfig } from \".\"\n\nexport type StateReceiver = ReturnType<typeof realtimeStateReceiver>\nexport function realtimeStateReceiver({\n\tsocket,\n\tstore = IMPLICIT.STORE,\n}: ServerConfig) {\n\treturn function stateReceiver<J extends Json.Serializable>(\n\t\ttoken: WritableToken<J>,\n\t): () => void {\n\t\tconst publish = (newValue: J) => {\n\t\t\tsetIntoStore(store, token, newValue)\n\t\t}\n\n\t\tconst fillPubUnclaim = () => {\n\t\t\tsocket.off(`pub:${token.key}`, publish)\n\t\t\tsocket.off(`unclaim:${token.key}`, fillPubUnclaim)\n\t\t}\n\t\tconst fillPubClaim = () => {\n\t\t\tsocket.on(`pub:${token.key}`, publish)\n\t\t\tsocket.on(`unclaim:${token.key}`, fillPubUnclaim)\n\t\t}\n\n\t\tsocket.on(`claim:${token.key}`, fillPubClaim)\n\n\t\treturn () => {\n\t\t\tsocket.off(`claim:${token.key}`, fillPubClaim)\n\t\t\tsocket.off(`pub:${token.key}`, publish)\n\t\t}\n\t}\n}\n"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","names":["tools: {\n\t\tsocket: SocketIO.Socket\n\t\tsilo: AtomIO.Silo\n\t\tenableLogging: () => void\n\t}","options: TestSetupOptions","options: TestSetupOptions__SingleClient","name: string","port: number","options: TestSetupOptions__MultiClient<ClientNames>"],"sources":["../../src/realtime-testing/setup-realtime-test.tsx"],"sourcesContent":[],"mappings":";;;;;;;KA6CY,gBAAA;;EAAZ,QAAY,CAAA,EAAA;IAAA,MAAA,CAAA,EAAA,OAAA;EAAA,CAAA;EAIO,MACX,EAAA,CAAA,KAAO,EAAA;IAAA,MAAA,EADL,QAAA,CAAS,MACJ;IAIf,IAAY,EAJJ,MAAA,CAAO,IAIH;IAAA,aAAA,EAAA,GAAA,GAAA,IAAA;EAAA,CAAA,EAAA,GAAiC,IAAA;CAAA;AAC9B,KADH,8BAAA,GAAiC,gBAC9B,GAAA;EAEf,MAAY,EAFH,OAAA,CAAM,EAEH;CAAA;AACX,KADW,6BACX,CAAA,oBAAA,MAAA,CAAA,GAAA,gBAAA,GAAA;EAAA,OAEQ,EAAA,QAAA,WAAA,GAAc,OAAA,CAAM,EAApB,EAAA;CAAA;AAAoB,KAIjB,iBAAA,GAJiB;EAI7B,IAAY,EAAA,MAAA;EAIZ,IAAY,EAFL,MAAA,CAAO,IAEF;CAAA;AAAqB,KAArB,kBAAA,GAAqB,iBAAA,GAAA;EAAA,YAClB,EAAA,YAAA;EAAA,WAGN,EAAA,GAAA,GAAA,IAAA;EAAA,aAAA,EAAA,GAAA,GAAA,IAAA;EAET,MAAY,EAFH,MAEG;AAKZ,CAAA;AAAY,KALA,yBAAA,GAKA;EAAA,OAAqB,EAAA,GAAA,GAAA,IAAA;EAAA,IAAA,EACjB,GAAA,GAJH,kBAIG;AAAA,CAAA;AAIJ,KALA,kBAAA,GAAqB,iBAKrB,GAAA;EAAA,OAAA,EAAA,GAAA,GAJI,OAIJ,CAAA,IAAA,CAAA;EAAA,IAAA,EACH,MAAA;CAAA;AACQ,KAFL,eAAA,GAEK;EAEjB,MAAY,EAHH,kBAGG;EAAA,QAAA,EAAA,GAAA,GAFK,OAEL,CAAA,IAAA,CAAA;CAAA;AACH,KADG,6BAAA,GAAgC,eACnC,GAAA;EAAA,MAAA,EAAA,yBAAA;AAET,CAAA;AAAY,KAAA,4BAAA,CAAA,oBAAA,MAAA,CAAA,GACX,eADW,GAAA;EAAA,OACX,EACU,MADV,CACiB,WADjB,EAC8B,yBAD9B,CAAA;CAAA;AAC8B,cAGlB,uBAHkB,EAAA,CAAA,OAAA,EAIrB,gBAJqB,EAAA,GAK5B,kBAL4B;AAApB,cA0FE,uBA1FF,EAAA,CAAA,OAAA,EA2FD,8BA3FC,EAAA,IAAA,EAAA,MAAA,EAAA,IAAA,EAAA,MAAA,EAAA,GA8FR,yBA9FQ;AAAA,cA0JE,YA1JF,EAAA,CAAA,OAAA,EA2JD,8BA3JC,EAAA,GA4JR,6BA5JQ;AAGE,cAuKA,WArKV,EAAA,CAAA,oBAAA,MAAA,CAAA,CAAA,OAAA,EAsKO,6BAtKP,CAsKqC,WAtKrC,CAAA,EAAA,GAuKA,4BAvKA,CAuK6B,WAvK7B,CAAA"}
1
+ {"version":3,"file":"index.d.ts","names":["tools: {\n\t\tsocket: SocketIO.Socket\n\t\tsilo: AtomIO.Silo\n\t\tenableLogging: () => void\n\t}","options: TestSetupOptions","options: TestSetupOptions__SingleClient","name: string","port: number","options: TestSetupOptions__MultiClient<ClientNames>"],"sources":["../../src/realtime-testing/setup-realtime-test.tsx"],"sourcesContent":[],"mappings":";;;;;;;KA6CY,gBAAA;;EAAZ,QAAY,CAAA,EAAA;IAAA,MAAA,CAAA,EAAA,OAAA;EAAA,CAAA;EAIO,MACX,EAAA,CAAA,KAAO,EAAA;IAAA,MAAA,EADL,QAAA,CAAS,MACJ;IAIf,IAAY,EAJJ,MAAA,CAAO,IAIH;IAAA,aAAA,EAAA,GAAA,GAAA,IAAA;EAAA,CAAA,EAAA,GAAiC,IAAA;CAAA;AAC9B,KADH,8BAAA,GAAiC,gBAC9B,GAAA;EAEf,MAAY,EAFH,OAAA,CAAM,EAEH;CAAA;AACX,KADW,6BACX,CAAA,oBAAA,MAAA,CAAA,GAAA,gBAAA,GAAA;EAAA,OAEQ,EAAA,QAAA,WAAA,GAAc,OAAA,CAAM,EAApB,EAAA;CAAA;AAAoB,KAIjB,iBAAA,GAJiB;EAI7B,IAAY,EAAA,MAAA;EAIZ,IAAY,EAFL,MAAA,CAAO,IAEF;CAAA;AAAqB,KAArB,kBAAA,GAAqB,iBAAA,GAAA;EAAA,YAClB,EAAA,YAAA;EAAA,WAGN,EAAA,GAAA,GAAA,IAAA;EAAA,aAAA,EAAA,GAAA,GAAA,IAAA;EAET,MAAY,EAFH,MAEG;AAKZ,CAAA;AAAY,KALA,yBAAA,GAKA;EAAA,OAAqB,EAAA,GAAA,GAAA,IAAA;EAAA,IAAA,EACjB,GAAA,GAJH,kBAIG;AAAA,CAAA;AAIJ,KALA,kBAAA,GAAqB,iBAKrB,GAAA;EAAA,OAAA,EAAA,GAAA,GAJI,OAIJ,CAAA,IAAA,CAAA;EAAA,IAAA,EACH,MAAA;CAAA;AACQ,KAFL,eAAA,GAEK;EAEjB,MAAY,EAHH,kBAGG;EAAA,QAAA,EAAA,GAAA,GAFK,OAEL,CAAA,IAAA,CAAA;CAAA;AACH,KADG,6BAAA,GAAgC,eACnC,GAAA;EAAA,MAAA,EAAA,yBAAA;AAET,CAAA;AAAY,KAAA,4BAAA,CAAA,oBAAA,MAAA,CAAA,GACX,eADW,GAAA;EAAA,OACX,EACU,MADV,CACiB,WADjB,EAC8B,yBAD9B,CAAA;CAAA;AAC8B,cAGlB,uBAHkB,EAAA,CAAA,OAAA,EAIrB,gBAJqB,EAAA,GAK5B,kBAL4B;AAApB,cA0FE,uBA1FF,EAAA,CAAA,OAAA,EA2FD,8BA3FC,EAAA,IAAA,EAAA,MAAA,EAAA,IAAA,EAAA,MAAA,EAAA,GA8FR,yBA9FQ;AAAA,cAqJE,YArJF,EAAA,CAAA,OAAA,EAsJD,8BAtJC,EAAA,GAuJR,6BAvJQ;AAGE,cAkKA,WAhKV,EAAA,CAAA,oBAAA,MAAA,CAAA,CAAA,OAAA,EAiKO,6BAjKP,CAiKqC,WAjKrC,CAAA,EAAA,GAkKA,4BAlKA,CAkK6B,WAlK7B,CAAA"}
@@ -105,7 +105,6 @@ const setupRealtimeTestClient = (options, name, port) => {
105
105
  name,
106
106
  lifespan: `ephemeral`
107
107
  }, IMPLICIT.STORE);
108
- for (const [key, value] of silo.store.valueMap.entries()) if (Array.isArray(value)) silo.store.valueMap.set(key, [...value]);
109
108
  silo.setState(RTC.myUsernameState, `${name}-${testNumber}`);
110
109
  const { document } = new Happy.Window();
111
110
  document.body.innerHTML = `<div id="app"></div>`;
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","names":["store: Store","prefix: string","options: TestSetupOptions","socket: SocketIO.Socket","userKey: string | null","options: TestSetupOptions__SingleClient","name: string","port: number","socket: ClientSocket","options: TestSetupOptions__MultiClient<ClientNames>"],"sources":["../../src/realtime-testing/setup-realtime-test.tsx"],"sourcesContent":["import * as http from \"node:http\"\n\nimport type { RenderResult } from \"@testing-library/react\"\nimport { prettyDOM, render } from \"@testing-library/react\"\nimport * as AtomIO from \"atom.io\"\nimport type { Store } from \"atom.io/internal\"\nimport {\n\tclearStore,\n\teditRelationsInStore,\n\tfindInStore,\n\tfindRelationsInStore,\n\tgetFromStore,\n\tIMPLICIT,\n\tsetIntoStore,\n} from \"atom.io/internal\"\nimport { toEntries } from \"atom.io/json\"\nimport * as AR from \"atom.io/react\"\nimport * as RT from \"atom.io/realtime\"\nimport * as RTC from \"atom.io/realtime-client\"\nimport * as RTR from \"atom.io/realtime-react\"\nimport * as RTS from \"atom.io/realtime-server\"\nimport * as Happy from \"happy-dom\"\nimport * as React from \"react\"\nimport * as SocketIO from \"socket.io\"\nimport type { Socket as ClientSocket } from \"socket.io-client\"\nimport { io } from \"socket.io-client\"\n\nlet testNumber = 0\n\n/* eslint-disable no-console */\n\nfunction prefixLogger(store: Store, prefix: string) {\n\tstore.loggers[0] = new AtomIO.AtomIOLogger(`info`, undefined, {\n\t\tinfo: (...args) => {\n\t\t\tconsole.info(prefix, ...args)\n\t\t},\n\t\twarn: (...args) => {\n\t\t\tconsole.warn(prefix, ...args)\n\t\t},\n\t\terror: (...args) => {\n\t\t\tconsole.error(prefix, ...args)\n\t\t},\n\t})\n}\n\nexport type TestSetupOptions = {\n\tport: number\n\timmortal?: { server?: boolean }\n\tserver: (tools: {\n\t\tsocket: SocketIO.Socket\n\t\tsilo: AtomIO.Silo\n\t\tenableLogging: () => void\n\t}) => void\n}\nexport type TestSetupOptions__SingleClient = TestSetupOptions & {\n\tclient: React.FC\n}\nexport type TestSetupOptions__MultiClient<ClientNames extends string> =\n\tTestSetupOptions & {\n\t\tclients: {\n\t\t\t[K in ClientNames]: React.FC\n\t\t}\n\t}\n\nexport type RealtimeTestTools = {\n\tname: string\n\tsilo: AtomIO.Silo\n}\nexport type RealtimeTestClient = RealtimeTestTools & {\n\trenderResult: RenderResult\n\tprettyPrint: () => void\n\tenableLogging: () => void\n\tsocket: ClientSocket\n}\nexport type RealtimeTestClientBuilder = {\n\tdispose: () => void\n\tinit: () => RealtimeTestClient\n}\n\nexport type RealtimeTestServer = RealtimeTestTools & {\n\tdispose: () => Promise<void>\n\tport: number\n}\n\nexport type RealtimeTestAPI = {\n\tserver: RealtimeTestServer\n\tteardown: () => Promise<void>\n}\nexport type RealtimeTestAPI__SingleClient = RealtimeTestAPI & {\n\tclient: RealtimeTestClientBuilder\n}\nexport type RealtimeTestAPI__MultiClient<ClientNames extends string> =\n\tRealtimeTestAPI & {\n\t\tclients: Record<ClientNames, RealtimeTestClientBuilder>\n\t}\n\nexport const setupRealtimeTestServer = (\n\toptions: TestSetupOptions,\n): RealtimeTestServer => {\n\t++testNumber\n\tconst silo = new AtomIO.Silo(\n\t\t{\n\t\t\tname: `SERVER-${testNumber}`,\n\t\t\tlifespan: options.immortal?.server ? `immortal` : `ephemeral`,\n\t\t},\n\t\tIMPLICIT.STORE,\n\t)\n\tconst socketRealm = new AtomIO.Realm<RTS.SocketSystemHierarchy>(silo.store)\n\n\tconst httpServer = http.createServer((_, res) => res.end(`Hello World!`))\n\tconst address = httpServer.listen(options.port).address()\n\tconst port =\n\t\ttypeof address === `string` ? null : address === null ? null : address.port\n\tif (port === null) throw new Error(`Could not determine port for test server`)\n\n\tconst server = new SocketIO.Server(httpServer).use((socket, next) => {\n\t\tconst { token, username } = socket.handshake.auth\n\t\tif (token === `test` && socket.id) {\n\t\t\tconst userClaim = socketRealm.allocate(`root`, `user::${username}`)\n\t\t\tconst socketClaim = socketRealm.allocate(`root`, `socket::${socket.id}`)\n\t\t\tconst socketState = findInStore(silo.store, RTS.socketAtoms, socketClaim)\n\t\t\tsetIntoStore(silo.store, socketState, socket)\n\t\t\teditRelationsInStore(\n\t\t\t\tRTS.usersOfSockets,\n\t\t\t\t(relations) => {\n\t\t\t\t\trelations.set(userClaim, socketClaim)\n\t\t\t\t},\n\t\t\t\tsilo.store,\n\t\t\t)\n\t\t\tsetIntoStore(silo.store, RTS.userIndex, (index) => index.add(userClaim))\n\t\t\tsetIntoStore(silo.store, RTS.socketIndex, (index) =>\n\t\t\t\tindex.add(socketClaim),\n\t\t\t)\n\t\t\t// console.log(`${username} connected on ${socket.id}`)\n\t\t\tnext()\n\t\t} else {\n\t\t\tnext(new Error(`Authentication error`))\n\t\t}\n\t})\n\n\tserver.on(`connection`, (socket: SocketIO.Socket) => {\n\t\tlet userKey: string | null = null\n\t\tfunction enableLogging() {\n\t\t\tconst userKeyState = findRelationsInStore(\n\t\t\t\tRTS.usersOfSockets,\n\t\t\t\t`socket::${socket.id}`,\n\t\t\t\tsilo.store,\n\t\t\t).userKeyOfSocket\n\t\t\tuserKey = getFromStore(silo.store, userKeyState)\n\t\t\tprefixLogger(silo.store, `server`)\n\t\t\tsocket.onAny((event, ...args) => {\n\t\t\t\tconsole.log(`🛰 `, userKey, event, ...args)\n\t\t\t})\n\t\t\tsocket.onAnyOutgoing((event, ...args) => {\n\t\t\t\tconsole.log(`🛰 >>`, userKey, event, ...args)\n\t\t\t})\n\t\t\tsocket.on(`disconnect`, () => {\n\t\t\t\tconsole.log(`${userKey} disconnected`)\n\t\t\t})\n\t\t}\n\t\toptions.server({ socket, enableLogging, silo })\n\t})\n\n\tconst dispose = async () => {\n\t\tawait server.close()\n\t\tconst roomKeys = getFromStore(silo.store, RT.roomIndex)\n\t\tfor (const roomKey of roomKeys) {\n\t\t\tconst roomState = findInStore(silo.store, RTS.roomSelectors, roomKey)\n\t\t\tconst room = getFromStore(silo.store, roomState)\n\t\t\tif (room && !(room instanceof Promise)) {\n\t\t\t\troom.process.kill()\n\t\t\t}\n\t\t}\n\t\tsilo.store.valueMap.clear()\n\t}\n\n\treturn {\n\t\tname: `SERVER`,\n\t\tsilo,\n\t\tdispose,\n\t\tport,\n\t}\n}\nexport const setupRealtimeTestClient = (\n\toptions: TestSetupOptions__SingleClient,\n\tname: string,\n\tport: number,\n): RealtimeTestClientBuilder => {\n\tconst testClient = { dispose: () => {} }\n\tconst init = () => {\n\t\tconst socket: ClientSocket = io(`http://localhost:${port}/`, {\n\t\t\tauth: { token: `test`, username: `${name}-${testNumber}` },\n\t\t})\n\t\tconst silo = new AtomIO.Silo({ name, lifespan: `ephemeral` }, IMPLICIT.STORE)\n\t\tfor (const [key, value] of silo.store.valueMap.entries()) {\n\t\t\tif (Array.isArray(value)) {\n\t\t\t\tsilo.store.valueMap.set(key, [...value])\n\t\t\t}\n\t\t}\n\t\tsilo.setState(RTC.myUsernameState, `${name}-${testNumber}`)\n\n\t\tconst { document } = new Happy.Window()\n\t\tdocument.body.innerHTML = `<div id=\"app\"></div>`\n\t\tconst renderResult = render(\n\t\t\t<AR.StoreProvider store={silo.store}>\n\t\t\t\t<RTR.RealtimeProvider socket={socket}>\n\t\t\t\t\t<options.client />\n\t\t\t\t</RTR.RealtimeProvider>\n\t\t\t</AR.StoreProvider>,\n\t\t\t{\n\t\t\t\tcontainer: document.querySelector(`#app`) as unknown as HTMLElement,\n\t\t\t},\n\t\t)\n\n\t\tconst prettyPrint = () => {\n\t\t\tconsole.log(prettyDOM(renderResult.container))\n\t\t}\n\n\t\tconst enableLogging = () => {\n\t\t\tprefixLogger(silo.store, name)\n\t\t\tsocket.onAny((event, ...args) => {\n\t\t\t\tconsole.log(`📡 `, name, event, ...args)\n\t\t\t})\n\t\t\tsocket.onAnyOutgoing((event, ...args) => {\n\t\t\t\tconsole.log(`📡 >>`, name, event, ...args)\n\t\t\t})\n\t\t}\n\n\t\tconst dispose = () => {\n\t\t\trenderResult.unmount()\n\t\t\tsocket.disconnect()\n\t\t\tclearStore(silo.store)\n\t\t}\n\t\ttestClient.dispose = dispose\n\n\t\treturn {\n\t\t\tname,\n\t\t\tsilo,\n\t\t\tsocket,\n\t\t\trenderResult,\n\t\t\tprettyPrint,\n\t\t\tenableLogging,\n\t\t}\n\t}\n\treturn Object.assign(testClient, { init })\n}\n\nexport const singleClient = (\n\toptions: TestSetupOptions__SingleClient,\n): RealtimeTestAPI__SingleClient => {\n\tconst server = setupRealtimeTestServer(options)\n\tconst client = setupRealtimeTestClient(options, `CLIENT`, server.port)\n\n\treturn {\n\t\tclient,\n\t\tserver,\n\t\tteardown: async () => {\n\t\t\tawait server.dispose()\n\t\t\tclient.dispose()\n\t\t},\n\t}\n}\n\nexport const multiClient = <ClientNames extends string>(\n\toptions: TestSetupOptions__MultiClient<ClientNames>,\n): RealtimeTestAPI__MultiClient<ClientNames> => {\n\tconst server = setupRealtimeTestServer(options)\n\tconst clients = toEntries(options.clients).reduce(\n\t\t(clientRecord, [name, client]) => {\n\t\t\tclientRecord[name] = setupRealtimeTestClient(\n\t\t\t\t{ ...options, client },\n\t\t\t\tname,\n\t\t\t\tserver.port,\n\t\t\t)\n\t\t\treturn clientRecord\n\t\t},\n\t\t{} as Record<ClientNames, RealtimeTestClientBuilder>,\n\t)\n\n\treturn {\n\t\tclients,\n\t\tserver,\n\t\tteardown: async () => {\n\t\t\tawait server.dispose()\n\t\t\tfor (const [, client] of toEntries(clients)) {\n\t\t\t\tclient.dispose()\n\t\t\t}\n\t\t},\n\t}\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"index.js","names":["store: Store","prefix: string","options: TestSetupOptions","socket: SocketIO.Socket","userKey: string | null","options: TestSetupOptions__SingleClient","name: string","port: number","socket: ClientSocket","options: TestSetupOptions__MultiClient<ClientNames>"],"sources":["../../src/realtime-testing/setup-realtime-test.tsx"],"sourcesContent":["import * as http from \"node:http\"\n\nimport type { RenderResult } from \"@testing-library/react\"\nimport { prettyDOM, render } from \"@testing-library/react\"\nimport * as AtomIO from \"atom.io\"\nimport type { Store } from \"atom.io/internal\"\nimport {\n\tclearStore,\n\teditRelationsInStore,\n\tfindInStore,\n\tfindRelationsInStore,\n\tgetFromStore,\n\tIMPLICIT,\n\tsetIntoStore,\n} from \"atom.io/internal\"\nimport { toEntries } from \"atom.io/json\"\nimport * as AR from \"atom.io/react\"\nimport * as RT from \"atom.io/realtime\"\nimport * as RTC from \"atom.io/realtime-client\"\nimport * as RTR from \"atom.io/realtime-react\"\nimport * as RTS from \"atom.io/realtime-server\"\nimport * as Happy from \"happy-dom\"\nimport * as React from \"react\"\nimport * as SocketIO from \"socket.io\"\nimport type { Socket as ClientSocket } from \"socket.io-client\"\nimport { io } from \"socket.io-client\"\n\nlet testNumber = 0\n\n/* eslint-disable no-console */\n\nfunction prefixLogger(store: Store, prefix: string) {\n\tstore.loggers[0] = new AtomIO.AtomIOLogger(`info`, undefined, {\n\t\tinfo: (...args) => {\n\t\t\tconsole.info(prefix, ...args)\n\t\t},\n\t\twarn: (...args) => {\n\t\t\tconsole.warn(prefix, ...args)\n\t\t},\n\t\terror: (...args) => {\n\t\t\tconsole.error(prefix, ...args)\n\t\t},\n\t})\n}\n\nexport type TestSetupOptions = {\n\tport: number\n\timmortal?: { server?: boolean }\n\tserver: (tools: {\n\t\tsocket: SocketIO.Socket\n\t\tsilo: AtomIO.Silo\n\t\tenableLogging: () => void\n\t}) => void\n}\nexport type TestSetupOptions__SingleClient = TestSetupOptions & {\n\tclient: React.FC\n}\nexport type TestSetupOptions__MultiClient<ClientNames extends string> =\n\tTestSetupOptions & {\n\t\tclients: {\n\t\t\t[K in ClientNames]: React.FC\n\t\t}\n\t}\n\nexport type RealtimeTestTools = {\n\tname: string\n\tsilo: AtomIO.Silo\n}\nexport type RealtimeTestClient = RealtimeTestTools & {\n\trenderResult: RenderResult\n\tprettyPrint: () => void\n\tenableLogging: () => void\n\tsocket: ClientSocket\n}\nexport type RealtimeTestClientBuilder = {\n\tdispose: () => void\n\tinit: () => RealtimeTestClient\n}\n\nexport type RealtimeTestServer = RealtimeTestTools & {\n\tdispose: () => Promise<void>\n\tport: number\n}\n\nexport type RealtimeTestAPI = {\n\tserver: RealtimeTestServer\n\tteardown: () => Promise<void>\n}\nexport type RealtimeTestAPI__SingleClient = RealtimeTestAPI & {\n\tclient: RealtimeTestClientBuilder\n}\nexport type RealtimeTestAPI__MultiClient<ClientNames extends string> =\n\tRealtimeTestAPI & {\n\t\tclients: Record<ClientNames, RealtimeTestClientBuilder>\n\t}\n\nexport const setupRealtimeTestServer = (\n\toptions: TestSetupOptions,\n): RealtimeTestServer => {\n\t++testNumber\n\tconst silo = new AtomIO.Silo(\n\t\t{\n\t\t\tname: `SERVER-${testNumber}`,\n\t\t\tlifespan: options.immortal?.server ? `immortal` : `ephemeral`,\n\t\t},\n\t\tIMPLICIT.STORE,\n\t)\n\tconst socketRealm = new AtomIO.Realm<RTS.SocketSystemHierarchy>(silo.store)\n\n\tconst httpServer = http.createServer((_, res) => res.end(`Hello World!`))\n\tconst address = httpServer.listen(options.port).address()\n\tconst port =\n\t\ttypeof address === `string` ? null : address === null ? null : address.port\n\tif (port === null) throw new Error(`Could not determine port for test server`)\n\n\tconst server = new SocketIO.Server(httpServer).use((socket, next) => {\n\t\tconst { token, username } = socket.handshake.auth\n\t\tif (token === `test` && socket.id) {\n\t\t\tconst userClaim = socketRealm.allocate(`root`, `user::${username}`)\n\t\t\tconst socketClaim = socketRealm.allocate(`root`, `socket::${socket.id}`)\n\t\t\tconst socketState = findInStore(silo.store, RTS.socketAtoms, socketClaim)\n\t\t\tsetIntoStore(silo.store, socketState, socket)\n\t\t\teditRelationsInStore(\n\t\t\t\tRTS.usersOfSockets,\n\t\t\t\t(relations) => {\n\t\t\t\t\trelations.set(userClaim, socketClaim)\n\t\t\t\t},\n\t\t\t\tsilo.store,\n\t\t\t)\n\t\t\tsetIntoStore(silo.store, RTS.userIndex, (index) => index.add(userClaim))\n\t\t\tsetIntoStore(silo.store, RTS.socketIndex, (index) =>\n\t\t\t\tindex.add(socketClaim),\n\t\t\t)\n\t\t\t// console.log(`${username} connected on ${socket.id}`)\n\t\t\tnext()\n\t\t} else {\n\t\t\tnext(new Error(`Authentication error`))\n\t\t}\n\t})\n\n\tserver.on(`connection`, (socket: SocketIO.Socket) => {\n\t\tlet userKey: string | null = null\n\t\tfunction enableLogging() {\n\t\t\tconst userKeyState = findRelationsInStore(\n\t\t\t\tRTS.usersOfSockets,\n\t\t\t\t`socket::${socket.id}`,\n\t\t\t\tsilo.store,\n\t\t\t).userKeyOfSocket\n\t\t\tuserKey = getFromStore(silo.store, userKeyState)\n\t\t\tprefixLogger(silo.store, `server`)\n\t\t\tsocket.onAny((event, ...args) => {\n\t\t\t\tconsole.log(`🛰 `, userKey, event, ...args)\n\t\t\t})\n\t\t\tsocket.onAnyOutgoing((event, ...args) => {\n\t\t\t\tconsole.log(`🛰 >>`, userKey, event, ...args)\n\t\t\t})\n\t\t\tsocket.on(`disconnect`, () => {\n\t\t\t\tconsole.log(`${userKey} disconnected`)\n\t\t\t})\n\t\t}\n\t\toptions.server({ socket, enableLogging, silo })\n\t})\n\n\tconst dispose = async () => {\n\t\tawait server.close()\n\t\tconst roomKeys = getFromStore(silo.store, RT.roomIndex)\n\t\tfor (const roomKey of roomKeys) {\n\t\t\tconst roomState = findInStore(silo.store, RTS.roomSelectors, roomKey)\n\t\t\tconst room = getFromStore(silo.store, roomState)\n\t\t\tif (room && !(room instanceof Promise)) {\n\t\t\t\troom.process.kill()\n\t\t\t}\n\t\t}\n\t\tsilo.store.valueMap.clear()\n\t}\n\n\treturn {\n\t\tname: `SERVER`,\n\t\tsilo,\n\t\tdispose,\n\t\tport,\n\t}\n}\nexport const setupRealtimeTestClient = (\n\toptions: TestSetupOptions__SingleClient,\n\tname: string,\n\tport: number,\n): RealtimeTestClientBuilder => {\n\tconst testClient = { dispose: () => {} }\n\tconst init = () => {\n\t\tconst socket: ClientSocket = io(`http://localhost:${port}/`, {\n\t\t\tauth: { token: `test`, username: `${name}-${testNumber}` },\n\t\t})\n\t\tconst silo = new AtomIO.Silo({ name, lifespan: `ephemeral` }, IMPLICIT.STORE)\n\t\tsilo.setState(RTC.myUsernameState, `${name}-${testNumber}`)\n\n\t\tconst { document } = new Happy.Window()\n\t\tdocument.body.innerHTML = `<div id=\"app\"></div>`\n\t\tconst renderResult = render(\n\t\t\t<AR.StoreProvider store={silo.store}>\n\t\t\t\t<RTR.RealtimeProvider socket={socket}>\n\t\t\t\t\t<options.client />\n\t\t\t\t</RTR.RealtimeProvider>\n\t\t\t</AR.StoreProvider>,\n\t\t\t{\n\t\t\t\tcontainer: document.querySelector(`#app`) as unknown as HTMLElement,\n\t\t\t},\n\t\t)\n\n\t\tconst prettyPrint = () => {\n\t\t\tconsole.log(prettyDOM(renderResult.container))\n\t\t}\n\n\t\tconst enableLogging = () => {\n\t\t\tprefixLogger(silo.store, name)\n\t\t\tsocket.onAny((event, ...args) => {\n\t\t\t\tconsole.log(`📡 `, name, event, ...args)\n\t\t\t})\n\t\t\tsocket.onAnyOutgoing((event, ...args) => {\n\t\t\t\tconsole.log(`📡 >>`, name, event, ...args)\n\t\t\t})\n\t\t}\n\n\t\tconst dispose = () => {\n\t\t\trenderResult.unmount()\n\t\t\tsocket.disconnect()\n\t\t\tclearStore(silo.store)\n\t\t}\n\t\ttestClient.dispose = dispose\n\n\t\treturn {\n\t\t\tname,\n\t\t\tsilo,\n\t\t\tsocket,\n\t\t\trenderResult,\n\t\t\tprettyPrint,\n\t\t\tenableLogging,\n\t\t}\n\t}\n\treturn Object.assign(testClient, { init })\n}\n\nexport const singleClient = (\n\toptions: TestSetupOptions__SingleClient,\n): RealtimeTestAPI__SingleClient => {\n\tconst server = setupRealtimeTestServer(options)\n\tconst client = setupRealtimeTestClient(options, `CLIENT`, server.port)\n\n\treturn {\n\t\tclient,\n\t\tserver,\n\t\tteardown: async () => {\n\t\t\tawait server.dispose()\n\t\t\tclient.dispose()\n\t\t},\n\t}\n}\n\nexport const multiClient = <ClientNames extends string>(\n\toptions: TestSetupOptions__MultiClient<ClientNames>,\n): RealtimeTestAPI__MultiClient<ClientNames> => {\n\tconst server = setupRealtimeTestServer(options)\n\tconst clients = toEntries(options.clients).reduce(\n\t\t(clientRecord, [name, client]) => {\n\t\t\tclientRecord[name] = setupRealtimeTestClient(\n\t\t\t\t{ ...options, client },\n\t\t\t\tname,\n\t\t\t\tserver.port,\n\t\t\t)\n\t\t\treturn clientRecord\n\t\t},\n\t\t{} as Record<ClientNames, RealtimeTestClientBuilder>,\n\t)\n\n\treturn {\n\t\tclients,\n\t\tserver,\n\t\tteardown: async () => {\n\t\t\tawait server.dispose()\n\t\t\tfor (const [, client] of toEntries(clients)) {\n\t\t\t\tclient.dispose()\n\t\t\t}\n\t\t},\n\t}\n}\n"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "atom.io",
3
- "version": "0.33.21",
3
+ "version": "0.34.1",
4
4
  "description": "Composable and testable reactive data library.",
5
5
  "homepage": "https://atom.io.fyi",
6
6
  "sideEffects": false,
@@ -61,9 +61,9 @@
61
61
  },
62
62
  "devDependencies": {
63
63
  "@eslint/core": "0.15.1",
64
- "@storybook/addon-docs": "9.0.18",
65
- "@storybook/addon-onboarding": "9.0.18",
66
- "@storybook/react-vite": "9.0.18",
64
+ "@storybook/addon-docs": "9.1.0",
65
+ "@storybook/addon-onboarding": "9.1.0",
66
+ "@storybook/react-vite": "9.1.0",
67
67
  "@testing-library/react": "16.3.0",
68
68
  "@types/bun": "npm:bun-types@1.2.19",
69
69
  "@types/eslint": "9.6.1",
@@ -94,11 +94,11 @@
94
94
  "recoverage": "0.1.11",
95
95
  "socket.io": "4.8.1",
96
96
  "socket.io-client": "4.8.1",
97
- "storybook": "9.0.18",
97
+ "storybook": "9.1.0",
98
98
  "tmp": "0.2.3",
99
99
  "tsdown": "0.13.0",
100
100
  "tsx": "4.20.3",
101
- "typescript": "5.8.3",
101
+ "typescript": "5.9.2",
102
102
  "vite": "7.0.6",
103
103
  "vite-tsconfig-paths": "5.1.4",
104
104
  "vitest": "3.2.4",
@@ -6,7 +6,6 @@ import type {
6
6
  } from "atom.io"
7
7
 
8
8
  import { type RegularAtom, resetInStore, setIntoStore } from ".."
9
- import { cacheValue } from "../caching"
10
9
  import { newest } from "../lineage"
11
10
  import type { Store } from "../store"
12
11
  import { deposit } from "../store"
@@ -19,7 +18,7 @@ export function createRegularAtom<T>(
19
18
  family: FamilyMetadata | undefined,
20
19
  ): RegularAtomToken<T> {
21
20
  const type = `atom`
22
- const { key, default: def } = options
21
+ const { key } = options
23
22
  store.logger.info(
24
23
  `🔨`,
25
24
  `atom`,
@@ -50,12 +49,12 @@ export function createRegularAtom<T>(
50
49
  if (family) {
51
50
  newAtom.family = family
52
51
  }
53
- let initialValue = def
54
- if (def instanceof Function) {
55
- initialValue = def()
56
- }
52
+ // let initialValue = def
53
+ // if (def instanceof Function) {
54
+ // initialValue = def()
55
+ // }
57
56
  target.atoms.set(key, newAtom)
58
- cacheValue(target, key, initialValue, subject)
57
+ // cacheValue(target, key, initialValue, subject)
59
58
  const token = deposit(newAtom)
60
59
  if (options.effects) {
61
60
  let effectIndex = 0
@@ -30,7 +30,7 @@ export function cacheValue<T>(
30
30
  subject: Subject<StateUpdate<unknown>>,
31
31
  ): Future<T> | T {
32
32
  const currentValue = target.valueMap.get(key)
33
- if (currentValue instanceof Future) {
33
+ if (currentValue instanceof Future && !currentValue.done) {
34
34
  const future = currentValue
35
35
  if (value instanceof Promise) {
36
36
  future.use(value)
@@ -43,7 +43,7 @@ export function cacheValue<T>(
43
43
  const future = new Future<T>(value)
44
44
  target.valueMap.set(key, future)
45
45
  future
46
- .then((resolved) => {
46
+ .then(function handleResolvedFuture(resolved) {
47
47
  const current = target.valueMap.get(key)
48
48
  if (current === future) {
49
49
  cacheValue(target, key, resolved, subject)
@@ -75,26 +75,26 @@ export function cacheValue<T>(
75
75
  }
76
76
 
77
77
  export const readCachedValue = <T>(
78
- token: ReadableState<any>,
78
+ state: ReadableState<any>,
79
79
  target: Store,
80
80
  ): T => {
81
- let value = target.valueMap.get(token.key) as T
82
- if (token.type === `mutable_atom` && isChildStore(target)) {
81
+ target.logger.info(`📖`, state.type, state.key, `reading cached value`)
82
+ let value = target.valueMap.get(state.key) as T
83
+ if (state.type === `mutable_atom` && isChildStore(target)) {
83
84
  const { parent } = target
84
- const copiedValue = copyMutableIfNeeded(target, token, parent)
85
+ const copiedValue = copyMutableIfNeeded(target, state, parent)
85
86
  value = copiedValue
86
87
  }
87
88
  return value
88
89
  }
89
90
 
90
- export const evictCachedValue = (key: string, target: Store): void => {
91
+ export const evictCachedValue = (target: Store, key: string): void => {
91
92
  const currentValue = target.valueMap.get(key)
92
93
  if (currentValue instanceof Future) {
93
- const future = currentValue
94
94
  const selector =
95
95
  target.writableSelectors.get(key) ?? target.readonlySelectors.get(key)
96
96
  if (selector) {
97
- future.use(selector.get())
97
+ selector.get()
98
98
  }
99
99
  return
100
100
  }
@@ -44,6 +44,9 @@ export class Future<T> extends Promise<T> {
44
44
  }
45
45
 
46
46
  public use(value: Promise<T> | T): void {
47
+ if (this === value) {
48
+ return
49
+ }
47
50
  if (value instanceof Promise) {
48
51
  const promise = value
49
52
  this.fate = promise