atom.io 0.34.0 → 0.34.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/eslint-plugin/index.js +1 -2
- package/dist/eslint-plugin/index.js.map +1 -1
- package/dist/internal/index.d.ts +6 -1
- package/dist/internal/index.d.ts.map +1 -1
- package/dist/internal/index.js +26 -22
- package/dist/internal/index.js.map +1 -1
- package/dist/json/index.d.ts +19 -4
- package/dist/json/index.d.ts.map +1 -1
- package/dist/json/index.js +4 -0
- package/dist/json/index.js.map +1 -1
- package/dist/main/index.d.ts +431 -26
- package/dist/main/index.d.ts.map +1 -1
- package/dist/main/index.js +109 -17
- package/dist/main/index.js.map +1 -1
- package/dist/realtime-client/index.js +4 -8
- package/dist/realtime-client/index.js.map +1 -1
- package/dist/realtime-server/index.js +1 -1
- package/dist/realtime-server/index.js.map +1 -1
- package/package.json +10 -10
- package/src/internal/join/create-join.ts +27 -0
- package/src/internal/join/index.ts +1 -0
- package/src/internal/junction.ts +2 -0
- package/src/json/entries.ts +10 -3
- package/src/json/index.ts +40 -14
- package/src/main/atom.ts +53 -12
- package/src/main/dispose-state.ts +8 -2
- package/src/main/find-state.ts +44 -14
- package/src/main/get-state.ts +2 -2
- package/src/main/index.ts +8 -0
- package/src/main/join.ts +78 -22
- package/src/main/realm.ts +50 -4
- package/src/main/selector.ts +116 -6
- package/src/main/subscribe.ts +31 -1
- package/src/main/timeline.ts +41 -15
- package/src/main/transaction.ts +39 -3
|
@@ -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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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "atom.io",
|
|
3
|
-
"version": "0.34.
|
|
3
|
+
"version": "0.34.2",
|
|
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.
|
|
65
|
-
"@storybook/addon-onboarding": "9.
|
|
66
|
-
"@storybook/react-vite": "9.
|
|
64
|
+
"@storybook/addon-docs": "9.1.1",
|
|
65
|
+
"@storybook/addon-onboarding": "9.1.1",
|
|
66
|
+
"@storybook/react-vite": "9.1.1",
|
|
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",
|
|
@@ -72,9 +72,9 @@
|
|
|
72
72
|
"@types/npmlog": "7.0.0",
|
|
73
73
|
"@types/react": "19.1.9",
|
|
74
74
|
"@types/tmp": "0.2.6",
|
|
75
|
-
"@typescript-eslint/parser": "8.
|
|
76
|
-
"@typescript-eslint/rule-tester": "8.
|
|
77
|
-
"@typescript-eslint/utils": "8.
|
|
75
|
+
"@typescript-eslint/parser": "8.39.0",
|
|
76
|
+
"@typescript-eslint/rule-tester": "8.39.0",
|
|
77
|
+
"@typescript-eslint/utils": "8.39.0",
|
|
78
78
|
"@vitest/coverage-v8": "3.2.4",
|
|
79
79
|
"@vitest/ui": "3.2.4",
|
|
80
80
|
"concurrently": "9.2.0",
|
|
@@ -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.
|
|
97
|
+
"storybook": "9.1.1",
|
|
98
98
|
"tmp": "0.2.3",
|
|
99
|
-
"tsdown": "0.13.
|
|
99
|
+
"tsdown": "0.13.3",
|
|
100
100
|
"tsx": "4.20.3",
|
|
101
|
-
"typescript": "5.
|
|
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",
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import type { JoinOptions, JoinToken } from "atom.io"
|
|
2
|
+
import type { Store } from "atom.io/internal"
|
|
3
|
+
import { Join } from "atom.io/internal"
|
|
4
|
+
import type { Json } from "atom.io/json"
|
|
5
|
+
|
|
6
|
+
export function createJoin<
|
|
7
|
+
ASide extends string,
|
|
8
|
+
AType extends string,
|
|
9
|
+
BSide extends string,
|
|
10
|
+
BType extends string,
|
|
11
|
+
Cardinality extends `1:1` | `1:n` | `n:n`,
|
|
12
|
+
Content extends Json.Object,
|
|
13
|
+
>(
|
|
14
|
+
store: Store,
|
|
15
|
+
options: JoinOptions<ASide, AType, BSide, BType, Cardinality, Content>,
|
|
16
|
+
defaultContent: Content | undefined,
|
|
17
|
+
): JoinToken<ASide, AType, BSide, BType, Cardinality, Content> {
|
|
18
|
+
store.joins.set(options.key, new Join(options, defaultContent, store))
|
|
19
|
+
const token: JoinToken<ASide, AType, BSide, BType, Cardinality, Content> = {
|
|
20
|
+
key: options.key,
|
|
21
|
+
type: `join`,
|
|
22
|
+
a: options.between[0],
|
|
23
|
+
b: options.between[1],
|
|
24
|
+
cardinality: options.cardinality,
|
|
25
|
+
}
|
|
26
|
+
return token
|
|
27
|
+
}
|
package/src/internal/junction.ts
CHANGED
|
@@ -18,7 +18,9 @@ export interface JunctionEntries<
|
|
|
18
18
|
JunctionEntriesBase<AType, BType, Content> {}
|
|
19
19
|
|
|
20
20
|
export type JunctionSchemaBase<ASide extends string, BSide extends string> = {
|
|
21
|
+
/** Description of the relationship between the two sides */
|
|
21
22
|
readonly between: [a: ASide, b: BSide]
|
|
23
|
+
/** How many relations are allowed in each direction? */
|
|
22
24
|
readonly cardinality: `1:1` | `1:n` | `n:n`
|
|
23
25
|
}
|
|
24
26
|
export interface JunctionSchema<ASide extends string, BSide extends string>
|
package/src/json/entries.ts
CHANGED
|
@@ -1,25 +1,32 @@
|
|
|
1
1
|
import type { Count, Flat } from "atom.io/internal"
|
|
2
2
|
|
|
3
|
+
/** @public Tuples of `[key, value]` pairs, as returned from `Object.entries` */
|
|
3
4
|
export type Entries<K extends PropertyKey = PropertyKey, V = any> = [K, V][]
|
|
4
5
|
|
|
6
|
+
/** @public The collective or "union" type of the keys in a set of entries */
|
|
5
7
|
export type KeyOfEntries<E extends Entries> = E extends [infer K, any][]
|
|
6
8
|
? K
|
|
7
9
|
: never
|
|
8
10
|
|
|
11
|
+
/** @public The type of the value of entry `K` in a set of entries `E` */
|
|
9
12
|
export type ValueOfEntry<E extends Entries, K extends KeyOfEntries<E>> = {
|
|
10
13
|
[P in Count<E[`length`]>]: E[P] extends [K, infer V] ? V : never
|
|
11
14
|
}[Count<E[`length`]>]
|
|
12
15
|
|
|
16
|
+
/** @public The type of a set of entries `E` in object form */
|
|
13
17
|
export type FromEntries<E extends Entries> = Flat<{
|
|
14
18
|
[K in KeyOfEntries<E>]: ValueOfEntry<E, K>
|
|
15
19
|
}>
|
|
16
20
|
|
|
21
|
+
/** @public Typed form of `Object.fromEntries` */
|
|
17
22
|
export function fromEntries<E extends Entries>(entries: E): FromEntries<E> {
|
|
18
23
|
return Object.fromEntries(entries) as FromEntries<E>
|
|
19
24
|
}
|
|
20
25
|
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
26
|
+
/** @public The type of an object T in {@link Entries} form */
|
|
27
|
+
export type ToEntries<T extends object> = Entries<keyof T, T[keyof T]>
|
|
28
|
+
|
|
29
|
+
/** @public Typed form of `Object.entries` */
|
|
30
|
+
export function toEntries<T extends object>(obj: T): ToEntries<T> {
|
|
24
31
|
return Object.entries(obj) as Entries<keyof T, T[keyof T]>
|
|
25
32
|
}
|
package/src/json/index.ts
CHANGED
|
@@ -15,6 +15,7 @@ export namespace Json {
|
|
|
15
15
|
export type Node = Fork | Leaf
|
|
16
16
|
}
|
|
17
17
|
|
|
18
|
+
/** A value can survive being {@link JSON.stringify}-ed and {@link JSON.parse}-d fully intact */
|
|
18
19
|
export type Serializable =
|
|
19
20
|
| primitive
|
|
20
21
|
| Readonly<{ [key: string]: Serializable }>
|
|
@@ -29,30 +30,55 @@ export namespace Json {
|
|
|
29
30
|
ReadonlyArray<Element>
|
|
30
31
|
}
|
|
31
32
|
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
33
|
+
/** A generic that retains the type information of a {@link Json.Serializable} value while in string form */
|
|
34
|
+
// biome-ignore format: long silly ternary
|
|
35
|
+
export type stringified<J extends Json.Serializable> = (
|
|
36
|
+
J extends string
|
|
37
|
+
? `"${J}"`
|
|
38
|
+
: J extends number
|
|
39
|
+
? `${J}`
|
|
40
|
+
: J extends true
|
|
41
|
+
? `true`
|
|
42
|
+
: J extends false
|
|
43
|
+
? `false`
|
|
44
|
+
: J extends boolean
|
|
45
|
+
? `false` | `true`
|
|
46
|
+
: J extends null
|
|
47
|
+
? `null`
|
|
48
|
+
: J extends []
|
|
49
|
+
? `[]`
|
|
50
|
+
: J extends [infer Element extends Json.Serializable]
|
|
51
|
+
? `[${stringified<Element>}]`
|
|
52
|
+
: J extends [
|
|
53
|
+
infer Element1 extends Json.Serializable,
|
|
54
|
+
infer Element2 extends Json.Serializable,
|
|
55
|
+
]
|
|
56
|
+
? `[${stringified<Element1>}, ${stringified<Element2>}]`
|
|
57
|
+
: J extends [
|
|
58
|
+
infer Element1 extends Json.Serializable,
|
|
59
|
+
infer Element2 extends Json.Serializable,
|
|
60
|
+
infer Element3 extends Json.Serializable,
|
|
61
|
+
]
|
|
62
|
+
? `[${stringified<Element1>}, ${stringified<Element2>}, ${stringified<Element3>}]`
|
|
63
|
+
: J extends any[]
|
|
64
|
+
? `[${string}]` & { __json?: J }
|
|
65
|
+
: string & { __json?: J }
|
|
66
|
+
)
|
|
67
|
+
|
|
68
|
+
/** Type-safe wrapper for {@link JSON.parse} */
|
|
46
69
|
export const parseJson = <S extends stringified<Json.Serializable>>(
|
|
47
70
|
str: S | string,
|
|
48
71
|
): S extends stringified<infer J> ? J : Json.Serializable => JSON.parse(str)
|
|
49
72
|
|
|
73
|
+
/** Type-safe wrapper for {@link JSON.stringify} */
|
|
50
74
|
export const stringifyJson = <J extends Json.Serializable>(
|
|
51
75
|
json: J,
|
|
52
76
|
): stringified<J> => JSON.stringify(json) as stringified<J>
|
|
53
77
|
|
|
78
|
+
/** Only Canonical values should be used for keys because they always serialize to the same string */
|
|
54
79
|
export type Canonical = primitive | ReadonlyArray<Canonical>
|
|
55
80
|
|
|
81
|
+
/** A function whose parameters and return value are {@link Json.Serializable} */
|
|
56
82
|
export type JsonIO = (...params: Json.Serializable[]) => Json.Serializable | void
|
|
57
83
|
|
|
58
84
|
export type JsonInterface<T, J extends Json.Serializable = Json.Serializable> = {
|