atom.io 0.46.7 → 0.46.9
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/realtime/index.d.ts +2 -1
- package/dist/realtime/index.d.ts.map +1 -1
- package/dist/realtime/index.js.map +1 -1
- package/dist/realtime-client/index.d.ts +2 -2
- package/dist/realtime-client/index.d.ts.map +1 -1
- package/dist/realtime-client/index.js +110 -70
- package/dist/realtime-client/index.js.map +1 -1
- package/dist/realtime-react/index.js +4 -1
- package/dist/realtime-react/index.js.map +1 -1
- package/dist/realtime-server/index.d.ts +4 -2
- package/dist/realtime-server/index.d.ts.map +1 -1
- package/dist/realtime-server/index.js +88 -87
- package/dist/realtime-server/index.js.map +1 -1
- package/package.json +3 -3
- package/src/realtime/employ-socket.ts +11 -1
- package/src/realtime-client/create-subscriber.ts +45 -0
- package/src/realtime-client/pull-atom-family-member.ts +17 -10
- package/src/realtime-client/pull-atom.ts +13 -10
- package/src/realtime-client/pull-mutable-atom-family-member.ts +26 -13
- package/src/realtime-client/pull-mutable-atom.ts +24 -12
- package/src/realtime-client/pull-selector-roots.ts +1 -5
- package/src/realtime-client/push-state.ts +17 -28
- package/src/realtime-client/realtime-client-stores/client-main-store.ts +27 -4
- package/src/realtime-react/use-pull-mutable-family-member.ts +5 -3
- package/src/realtime-server/ipc-sockets/child-socket.ts +6 -4
- package/src/realtime-server/ipc-sockets/parent-socket.ts +17 -11
- package/src/realtime-server/provide-rooms.ts +36 -36
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","names":["RealtimeContext: React.Context<RealtimeReactStore>","RealtimeProvider: React.FC<{\n\tchildren: React.ReactNode\n\tsocket: Socket | null\n}>","myRoomKey: RoomKey | undefined","roomKey"],"sources":["../../src/realtime-react/realtime-context.tsx","../../src/realtime-react/use-realtime-service.ts","../../src/realtime-react/use-pull-atom.ts","../../src/realtime-react/use-pull-atom-family-member.ts","../../src/realtime-react/use-pull-mutable-atom.ts","../../src/realtime-react/use-pull-mutable-family-member.ts","../../src/realtime-react/use-pull-selector.ts","../../src/realtime-react/use-pull-selector-family-member.ts","../../src/realtime-react/use-push.ts","../../src/realtime-react/use-realtime-rooms.ts","../../src/realtime-react/use-sync-continuity.ts"],"sourcesContent":["import { useI } from \"atom.io/react\"\nimport * as RTC from \"atom.io/realtime-client\"\nimport * as React from \"react\"\nimport type { Socket } from \"socket.io-client\"\n\nexport type RealtimeServiceCounter = {\n\tconsumerCount: number\n\tdispose: () => void\n}\n\nexport type RealtimeReactStore = {\n\tsocket: Socket | null\n\tservices: Map<string, RealtimeServiceCounter> | null\n}\n\nexport const RealtimeContext: React.Context<RealtimeReactStore> =\n\tReact.createContext({\n\t\tsocket: null,\n\t\tservices: null,\n\t})\n\nexport const RealtimeProvider: React.FC<{\n\tchildren: React.ReactNode\n\tsocket: Socket | null\n}> = ({ children, socket }) => {\n\tconst services = React.useRef(\n\t\tnew Map<string, RealtimeServiceCounter>(),\n\t).current\n\tconst setMySocketKey = useI(RTC.mySocketKeyAtom)\n\tReact.useEffect(() => {\n\t\tsetMySocketKey(socket?.id ? `socket::${socket.id}` : undefined)\n\t\tsocket?.on(`connect`, () => {\n\t\t\tsetMySocketKey(socket?.id ? `socket::${socket.id}` : undefined)\n\t\t})\n\t\tsocket?.on(`disconnect`, () => {\n\t\t\tsetMySocketKey(undefined)\n\t\t})\n\t}, [socket, setMySocketKey])\n\treturn (\n\t\t<RealtimeContext.Provider value={{ socket, services }}>\n\t\t\t{children}\n\t\t</RealtimeContext.Provider>\n\t)\n}\n","import { useSingleEffect } from \"atom.io/react\"\nimport * as React from \"react\"\nimport type { Socket } from \"socket.io-client\"\n\nimport { RealtimeContext } from \"./realtime-context\"\n\nexport function useRealtimeService(\n\tkey: string,\n\tcreate: (socket: Socket) => () => void,\n): void {\n\tconst { socket, services } = React.useContext(RealtimeContext)\n\tuseSingleEffect(() => {\n\t\tlet service = services?.get(key)\n\t\tif (service) {\n\t\t\t++service.consumerCount\n\t\t} else if (socket) {\n\t\t\tconst dispose = create(socket)\n\t\t\tservice = { consumerCount: 1, dispose }\n\t\t\tservices?.set(key, service)\n\t\t}\n\t\treturn () => {\n\t\t\tif (service) {\n\t\t\t\t--service.consumerCount\n\t\t\t\tif (service.consumerCount === 0) {\n\t\t\t\t\tservice.dispose?.()\n\t\t\t\t\tservices?.delete(key)\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}, [socket, key])\n}\n","import type * as AtomIO from \"atom.io\"\nimport type { Json } from \"atom.io/json\"\nimport { StoreContext, useO } from \"atom.io/react\"\nimport * as RTC from \"atom.io/realtime-client\"\nimport * as React from \"react\"\n\nimport { useRealtimeService } from \"./use-realtime-service\"\n\nexport function usePullAtom<J extends Json.Serializable>(\n\ttoken: AtomIO.RegularAtomToken<J>,\n): AtomIO.ViewOf<J> {\n\tconst store = React.useContext(StoreContext)\n\tuseRealtimeService(`pull:${token.key}`, (socket) =>\n\t\tRTC.pullAtom(store, socket, token),\n\t)\n\treturn useO(token)\n}\n","import type * as AtomIO from \"atom.io\"\nimport { findInStore } from \"atom.io/internal\"\nimport type { Canonical, Json } from \"atom.io/json\"\nimport { StoreContext, useO } from \"atom.io/react\"\nimport * as RTC from \"atom.io/realtime-client\"\nimport * as React from \"react\"\n\nimport { useRealtimeService } from \"./use-realtime-service\"\n\nexport function usePullAtomFamilyMember<\n\tJ extends Json.Serializable,\n\tK extends Canonical,\n>(\n\tfamily: AtomIO.RegularAtomFamilyToken<J, K>,\n\tsubKey: NoInfer<K>,\n): AtomIO.ViewOf<J> {\n\tconst store = React.useContext(StoreContext)\n\tconst token = findInStore(store, family, subKey)\n\tuseRealtimeService(`pull:${token.key}`, (socket) =>\n\t\tRTC.pullAtomFamilyMember(store, socket, family, subKey),\n\t)\n\treturn useO(token)\n}\n","import type * as AtomIO from \"atom.io\"\nimport type { Transceiver } from \"atom.io/internal\"\nimport { StoreContext, useO } from \"atom.io/react\"\nimport * as RTC from \"atom.io/realtime-client\"\nimport * as React from \"react\"\n\nimport { useRealtimeService } from \"./use-realtime-service\"\n\nexport function usePullMutable<T extends Transceiver<any, any, any>>(\n\ttoken: AtomIO.MutableAtomToken<T>,\n): T {\n\tconst store = React.useContext(StoreContext)\n\tuseRealtimeService(`pull:${token.key}`, (socket) =>\n\t\tRTC.pullMutableAtom(store, socket, token),\n\t)\n\treturn useO(token)\n}\n","import type * as AtomIO from \"atom.io\"\nimport type { Transceiver } from \"atom.io/internal\"\nimport { findInStore } from \"atom.io/internal\"\nimport type { Canonical } from \"atom.io/json\"\nimport { StoreContext, useO } from \"atom.io/react\"\nimport * as RTC from \"atom.io/realtime-client\"\nimport * as React from \"react\"\n\nimport { useRealtimeService } from \"./use-realtime-service\"\n\nexport function usePullMutableAtomFamilyMember<\n\tT extends Transceiver<any, any, any>,\n\tK extends Canonical,\n>(familyToken: AtomIO.MutableAtomFamilyToken<T, K>, key: NoInfer<K>): T {\n\tconst store = React.useContext(StoreContext)\n\tconst token = findInStore(store, familyToken, key)\n\tuseRealtimeService(`pull:${token.key}`, (socket) =>\n\t\tRTC.pullMutableAtomFamilyMember(store, socket, familyToken, key),\n\t)\n\treturn useO(token)\n}\n","import type * as AtomIO from \"atom.io\"\nimport type { Json } from \"atom.io/json\"\nimport { StoreContext, useO } from \"atom.io/react\"\nimport * as RTC from \"atom.io/realtime-client\"\nimport * as React from \"react\"\n\nimport { useRealtimeService } from \"./use-realtime-service\"\n\nexport function usePullSelector<J extends Json.Serializable>(\n\ttoken: AtomIO.SelectorToken<J>,\n): AtomIO.ViewOf<J> {\n\tconst store = React.useContext(StoreContext)\n\tuseRealtimeService(`pull:${token.key}`, (socket) =>\n\t\tRTC.pullSelector(store, socket, token),\n\t)\n\treturn useO(token)\n}\n","import type * as AtomIO from \"atom.io\"\nimport { findInStore } from \"atom.io/internal\"\nimport type { Canonical } from \"atom.io/json\"\nimport { StoreContext, useO } from \"atom.io/react\"\nimport * as RTC from \"atom.io/realtime-client\"\nimport * as React from \"react\"\n\nimport { useRealtimeService } from \"./use-realtime-service\"\n\nexport function usePullSelectorFamilyMember<T, K extends Canonical>(\n\tfamilyToken: AtomIO.SelectorFamilyToken<T, K>,\n\tkey: NoInfer<K>,\n): AtomIO.ViewOf<T> {\n\tconst store = React.useContext(StoreContext)\n\tconst token = findInStore(store, familyToken, key)\n\tuseRealtimeService(`pull:${token.key}`, (socket) =>\n\t\tRTC.pullSelectorFamilyMember(store, socket, familyToken, key),\n\t)\n\treturn useO(token)\n}\n","import type * as AtomIO from \"atom.io\"\nimport type { Json } from \"atom.io/json\"\nimport { StoreContext, useI, useO } from \"atom.io/react\"\nimport * as RT from \"atom.io/realtime\"\nimport * as RTC from \"atom.io/realtime-client\"\nimport * as React from \"react\"\n\nimport { useRealtimeService } from \"./use-realtime-service\"\n\nexport function usePush<J extends Json.Serializable>(\n\ttoken: AtomIO.WritableToken<J>,\n): (<New extends J>(next: New | ((old: J) => New)) => void) | null {\n\tconst store = React.useContext(StoreContext)\n\tuseRealtimeService(`push:${token.key}`, (socket) =>\n\t\tRTC.pushState(store, socket, token),\n\t)\n\tconst mutex = useO(RT.mutexAtoms, token.key)\n\tconst setter = useI(token)\n\n\treturn mutex ? setter : null\n}\n","import type { MutableAtomToken } from \"atom.io\"\nimport { findInStore, getInternalRelationsFromStore } from \"atom.io/internal\"\nimport { StoreContext, useO } from \"atom.io/react\"\nimport type { RoomKey, RoomSocketInterface, UserKey } from \"atom.io/realtime\"\nimport { ownersOfRooms, roomKeysAtom, usersInRooms } from \"atom.io/realtime\"\nimport type { UList } from \"atom.io/transceivers/u-list\"\nimport * as React from \"react\"\nimport type { Socket } from \"socket.io-client\"\n\nimport { RealtimeContext } from \"./realtime-context\"\nimport { usePullMutable } from \"./use-pull-mutable-atom\"\nimport { usePullMutableAtomFamilyMember } from \"./use-pull-mutable-family-member\"\n\nexport type RealtimeRoomsTools = {\n\tsocket: Socket<{}, RoomSocketInterface<string>>\n\tmyRoomKey: RoomKey | undefined\n\tmyMutualsAtom: MutableAtomToken<UList<UserKey>>\n\tmyOwnedRoomsAtom: MutableAtomToken<UList<RoomKey>>\n\tallRoomKeysAtom: MutableAtomToken<UList<RoomKey>>\n}\nexport function useRealtimeRooms<RoomNames extends string>(\n\tuserKey: UserKey,\n): RealtimeRoomsTools {\n\tconst store = React.useContext(StoreContext)\n\tconst { socket } = React.useContext(RealtimeContext)\n\tusePullMutable(roomKeysAtom)\n\n\tconst [userKeysFamily, roomKeysFamily] = getInternalRelationsFromStore(\n\t\tstore,\n\t\tusersInRooms,\n\t\t`split`,\n\t)\n\n\tusePullMutableAtomFamilyMember(roomKeysFamily, userKey)\n\tconst myJoinedRoomKeys = useO(roomKeysFamily, userKey)\n\tlet myRoomKey: RoomKey | undefined\n\tfor (const roomKey of myJoinedRoomKeys) {\n\t\tmyRoomKey = roomKey\n\t\tbreak\n\t}\n\n\tconst roomKey = myRoomKey ?? `room::$_NONE_$`\n\tconst myMutualsAtom = findInStore(store, userKeysFamily, roomKey)\n\tusePullMutableAtomFamilyMember(userKeysFamily, roomKey)\n\n\tconst [ownedRoomsFamily] = getInternalRelationsFromStore(\n\t\tstore,\n\t\townersOfRooms,\n\t\t`split`,\n\t)\n\tconst myOwnedRoomsAtom = findInStore(store, ownedRoomsFamily, userKey)\n\tusePullMutableAtomFamilyMember(ownedRoomsFamily, userKey)\n\n\treturn {\n\t\tsocket: socket as Socket<{}, RoomSocketInterface<RoomNames>>,\n\t\tmyRoomKey,\n\t\tallRoomKeysAtom: roomKeysAtom,\n\t\tmyMutualsAtom,\n\t\tmyOwnedRoomsAtom,\n\t}\n}\n","import { StoreContext } from \"atom.io/react\"\nimport type { ContinuityToken } from \"atom.io/realtime\"\nimport { syncContinuity } from \"atom.io/realtime-client\"\nimport * as React from \"react\"\n\nimport { useRealtimeService } from \"./use-realtime-service\"\n\nexport function useSyncContinuity(token: ContinuityToken): void {\n\tconst store = React.useContext(StoreContext)\n\tuseRealtimeService(`tx-sync:${token.key}`, (socket) => {\n\t\treturn syncContinuity(store, socket, token)\n\t})\n}\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.js","names":["RealtimeContext: React.Context<RealtimeReactStore>","RealtimeProvider: React.FC<{\n\tchildren: React.ReactNode\n\tsocket: Socket | null\n}>","myRoomKey: RoomKey | undefined","roomKey"],"sources":["../../src/realtime-react/realtime-context.tsx","../../src/realtime-react/use-realtime-service.ts","../../src/realtime-react/use-pull-atom.ts","../../src/realtime-react/use-pull-atom-family-member.ts","../../src/realtime-react/use-pull-mutable-atom.ts","../../src/realtime-react/use-pull-mutable-family-member.ts","../../src/realtime-react/use-pull-selector.ts","../../src/realtime-react/use-pull-selector-family-member.ts","../../src/realtime-react/use-push.ts","../../src/realtime-react/use-realtime-rooms.ts","../../src/realtime-react/use-sync-continuity.ts"],"sourcesContent":["import { useI } from \"atom.io/react\"\nimport * as RTC from \"atom.io/realtime-client\"\nimport * as React from \"react\"\nimport type { Socket } from \"socket.io-client\"\n\nexport type RealtimeServiceCounter = {\n\tconsumerCount: number\n\tdispose: () => void\n}\n\nexport type RealtimeReactStore = {\n\tsocket: Socket | null\n\tservices: Map<string, RealtimeServiceCounter> | null\n}\n\nexport const RealtimeContext: React.Context<RealtimeReactStore> =\n\tReact.createContext({\n\t\tsocket: null,\n\t\tservices: null,\n\t})\n\nexport const RealtimeProvider: React.FC<{\n\tchildren: React.ReactNode\n\tsocket: Socket | null\n}> = ({ children, socket }) => {\n\tconst services = React.useRef(\n\t\tnew Map<string, RealtimeServiceCounter>(),\n\t).current\n\tconst setMySocketKey = useI(RTC.mySocketKeyAtom)\n\tReact.useEffect(() => {\n\t\tsetMySocketKey(socket?.id ? `socket::${socket.id}` : undefined)\n\t\tsocket?.on(`connect`, () => {\n\t\t\tsetMySocketKey(socket?.id ? `socket::${socket.id}` : undefined)\n\t\t})\n\t\tsocket?.on(`disconnect`, () => {\n\t\t\tsetMySocketKey(undefined)\n\t\t})\n\t}, [socket, setMySocketKey])\n\treturn (\n\t\t<RealtimeContext.Provider value={{ socket, services }}>\n\t\t\t{children}\n\t\t</RealtimeContext.Provider>\n\t)\n}\n","import { useSingleEffect } from \"atom.io/react\"\nimport * as React from \"react\"\nimport type { Socket } from \"socket.io-client\"\n\nimport { RealtimeContext } from \"./realtime-context\"\n\nexport function useRealtimeService(\n\tkey: string,\n\tcreate: (socket: Socket) => () => void,\n): void {\n\tconst { socket, services } = React.useContext(RealtimeContext)\n\tuseSingleEffect(() => {\n\t\tlet service = services?.get(key)\n\t\tif (service) {\n\t\t\t++service.consumerCount\n\t\t} else if (socket) {\n\t\t\tconst dispose = create(socket)\n\t\t\tservice = { consumerCount: 1, dispose }\n\t\t\tservices?.set(key, service)\n\t\t}\n\t\treturn () => {\n\t\t\tif (service) {\n\t\t\t\t--service.consumerCount\n\t\t\t\tif (service.consumerCount === 0) {\n\t\t\t\t\tservice.dispose?.()\n\t\t\t\t\tservices?.delete(key)\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}, [socket, key])\n}\n","import type * as AtomIO from \"atom.io\"\nimport type { Json } from \"atom.io/json\"\nimport { StoreContext, useO } from \"atom.io/react\"\nimport * as RTC from \"atom.io/realtime-client\"\nimport * as React from \"react\"\n\nimport { useRealtimeService } from \"./use-realtime-service\"\n\nexport function usePullAtom<J extends Json.Serializable>(\n\ttoken: AtomIO.RegularAtomToken<J>,\n): AtomIO.ViewOf<J> {\n\tconst store = React.useContext(StoreContext)\n\tuseRealtimeService(`pull:${token.key}`, (socket) =>\n\t\tRTC.pullAtom(store, socket, token),\n\t)\n\treturn useO(token)\n}\n","import type * as AtomIO from \"atom.io\"\nimport { findInStore } from \"atom.io/internal\"\nimport type { Canonical, Json } from \"atom.io/json\"\nimport { StoreContext, useO } from \"atom.io/react\"\nimport * as RTC from \"atom.io/realtime-client\"\nimport * as React from \"react\"\n\nimport { useRealtimeService } from \"./use-realtime-service\"\n\nexport function usePullAtomFamilyMember<\n\tJ extends Json.Serializable,\n\tK extends Canonical,\n>(\n\tfamily: AtomIO.RegularAtomFamilyToken<J, K>,\n\tsubKey: NoInfer<K>,\n): AtomIO.ViewOf<J> {\n\tconst store = React.useContext(StoreContext)\n\tconst token = findInStore(store, family, subKey)\n\tuseRealtimeService(`pull:${token.key}`, (socket) =>\n\t\tRTC.pullAtomFamilyMember(store, socket, family, subKey),\n\t)\n\treturn useO(token)\n}\n","import type * as AtomIO from \"atom.io\"\nimport type { Transceiver } from \"atom.io/internal\"\nimport { StoreContext, useO } from \"atom.io/react\"\nimport * as RTC from \"atom.io/realtime-client\"\nimport * as React from \"react\"\n\nimport { useRealtimeService } from \"./use-realtime-service\"\n\nexport function usePullMutable<T extends Transceiver<any, any, any>>(\n\ttoken: AtomIO.MutableAtomToken<T>,\n): T {\n\tconst store = React.useContext(StoreContext)\n\tuseRealtimeService(`pull:${token.key}`, (socket) =>\n\t\tRTC.pullMutableAtom(store, socket, token),\n\t)\n\treturn useO(token)\n}\n","import type * as AtomIO from \"atom.io\"\nimport type { Transceiver } from \"atom.io/internal\"\nimport { findInStore } from \"atom.io/internal\"\nimport type { Canonical } from \"atom.io/json\"\nimport { StoreContext, useO } from \"atom.io/react\"\nimport * as RTC from \"atom.io/realtime-client\"\nimport * as React from \"react\"\n\nimport { useRealtimeService } from \"./use-realtime-service\"\n\nexport function usePullMutableAtomFamilyMember<\n\tT extends Transceiver<any, any, any>,\n\tK extends Canonical,\n>(familyToken: AtomIO.MutableAtomFamilyToken<T, K>, key: NoInfer<K>): T {\n\tconst store = React.useContext(StoreContext)\n\tconst token = findInStore(store, familyToken, key)\n\tuseRealtimeService(`pull:${token.key}`, (socket) => {\n\t\tif (familyToken.key === `usersInRooms/relatedKeys`) {\n\t\t}\n\t\treturn RTC.pullMutableAtomFamilyMember(store, socket, familyToken, key)\n\t})\n\treturn useO(token)\n}\n","import type * as AtomIO from \"atom.io\"\nimport type { Json } from \"atom.io/json\"\nimport { StoreContext, useO } from \"atom.io/react\"\nimport * as RTC from \"atom.io/realtime-client\"\nimport * as React from \"react\"\n\nimport { useRealtimeService } from \"./use-realtime-service\"\n\nexport function usePullSelector<J extends Json.Serializable>(\n\ttoken: AtomIO.SelectorToken<J>,\n): AtomIO.ViewOf<J> {\n\tconst store = React.useContext(StoreContext)\n\tuseRealtimeService(`pull:${token.key}`, (socket) =>\n\t\tRTC.pullSelector(store, socket, token),\n\t)\n\treturn useO(token)\n}\n","import type * as AtomIO from \"atom.io\"\nimport { findInStore } from \"atom.io/internal\"\nimport type { Canonical } from \"atom.io/json\"\nimport { StoreContext, useO } from \"atom.io/react\"\nimport * as RTC from \"atom.io/realtime-client\"\nimport * as React from \"react\"\n\nimport { useRealtimeService } from \"./use-realtime-service\"\n\nexport function usePullSelectorFamilyMember<T, K extends Canonical>(\n\tfamilyToken: AtomIO.SelectorFamilyToken<T, K>,\n\tkey: NoInfer<K>,\n): AtomIO.ViewOf<T> {\n\tconst store = React.useContext(StoreContext)\n\tconst token = findInStore(store, familyToken, key)\n\tuseRealtimeService(`pull:${token.key}`, (socket) =>\n\t\tRTC.pullSelectorFamilyMember(store, socket, familyToken, key),\n\t)\n\treturn useO(token)\n}\n","import type * as AtomIO from \"atom.io\"\nimport type { Json } from \"atom.io/json\"\nimport { StoreContext, useI, useO } from \"atom.io/react\"\nimport * as RT from \"atom.io/realtime\"\nimport * as RTC from \"atom.io/realtime-client\"\nimport * as React from \"react\"\n\nimport { useRealtimeService } from \"./use-realtime-service\"\n\nexport function usePush<J extends Json.Serializable>(\n\ttoken: AtomIO.WritableToken<J>,\n): (<New extends J>(next: New | ((old: J) => New)) => void) | null {\n\tconst store = React.useContext(StoreContext)\n\tuseRealtimeService(`push:${token.key}`, (socket) =>\n\t\tRTC.pushState(store, socket, token),\n\t)\n\tconst mutex = useO(RT.mutexAtoms, token.key)\n\tconst setter = useI(token)\n\n\treturn mutex ? setter : null\n}\n","import type { MutableAtomToken } from \"atom.io\"\nimport { findInStore, getInternalRelationsFromStore } from \"atom.io/internal\"\nimport { StoreContext, useO } from \"atom.io/react\"\nimport type { RoomKey, RoomSocketInterface, UserKey } from \"atom.io/realtime\"\nimport { ownersOfRooms, roomKeysAtom, usersInRooms } from \"atom.io/realtime\"\nimport type { UList } from \"atom.io/transceivers/u-list\"\nimport * as React from \"react\"\nimport type { Socket } from \"socket.io-client\"\n\nimport { RealtimeContext } from \"./realtime-context\"\nimport { usePullMutable } from \"./use-pull-mutable-atom\"\nimport { usePullMutableAtomFamilyMember } from \"./use-pull-mutable-family-member\"\n\nexport type RealtimeRoomsTools = {\n\tsocket: Socket<{}, RoomSocketInterface<string>>\n\tmyRoomKey: RoomKey | undefined\n\tmyMutualsAtom: MutableAtomToken<UList<UserKey>>\n\tmyOwnedRoomsAtom: MutableAtomToken<UList<RoomKey>>\n\tallRoomKeysAtom: MutableAtomToken<UList<RoomKey>>\n}\nexport function useRealtimeRooms<RoomNames extends string>(\n\tuserKey: UserKey,\n): RealtimeRoomsTools {\n\tconst store = React.useContext(StoreContext)\n\tconst { socket } = React.useContext(RealtimeContext)\n\tusePullMutable(roomKeysAtom)\n\n\tconst [userKeysFamily, roomKeysFamily] = getInternalRelationsFromStore(\n\t\tstore,\n\t\tusersInRooms,\n\t\t`split`,\n\t)\n\n\tusePullMutableAtomFamilyMember(roomKeysFamily, userKey)\n\tconst myJoinedRoomKeys = useO(roomKeysFamily, userKey)\n\tlet myRoomKey: RoomKey | undefined\n\tfor (const roomKey of myJoinedRoomKeys) {\n\t\tmyRoomKey = roomKey\n\t\tbreak\n\t}\n\n\tconst roomKey = myRoomKey ?? `room::$_NONE_$`\n\tconst myMutualsAtom = findInStore(store, userKeysFamily, roomKey)\n\tusePullMutableAtomFamilyMember(userKeysFamily, roomKey)\n\n\tconst [ownedRoomsFamily] = getInternalRelationsFromStore(\n\t\tstore,\n\t\townersOfRooms,\n\t\t`split`,\n\t)\n\tconst myOwnedRoomsAtom = findInStore(store, ownedRoomsFamily, userKey)\n\tusePullMutableAtomFamilyMember(ownedRoomsFamily, userKey)\n\n\treturn {\n\t\tsocket: socket as Socket<{}, RoomSocketInterface<RoomNames>>,\n\t\tmyRoomKey,\n\t\tallRoomKeysAtom: roomKeysAtom,\n\t\tmyMutualsAtom,\n\t\tmyOwnedRoomsAtom,\n\t}\n}\n","import { StoreContext } from \"atom.io/react\"\nimport type { ContinuityToken } from \"atom.io/realtime\"\nimport { syncContinuity } from \"atom.io/realtime-client\"\nimport * as React from \"react\"\n\nimport { useRealtimeService } from \"./use-realtime-service\"\n\nexport function useSyncContinuity(token: ContinuityToken): void {\n\tconst store = React.useContext(StoreContext)\n\tuseRealtimeService(`tx-sync:${token.key}`, (socket) => {\n\t\treturn syncContinuity(store, socket, token)\n\t})\n}\n"],"mappings":"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"}
|
|
@@ -76,13 +76,15 @@ type ParentProcess = {
|
|
|
76
76
|
stderr: Writable;
|
|
77
77
|
exit: (code?: number) => void;
|
|
78
78
|
};
|
|
79
|
-
declare class ParentSocket<I extends Events & {
|
|
79
|
+
declare class ParentSocket<I extends Events & {
|
|
80
|
+
[user: UserKey]: [string, ...Json.Array[]];
|
|
81
|
+
}, O extends Events & { [id in string as `user::${id}`]: [string, ...Json.Array[]] } & {
|
|
80
82
|
"user-joins": [key: UserKey];
|
|
81
83
|
"user-leaves": [key: UserKey];
|
|
82
84
|
}, P extends ParentProcess = ParentProcess> extends CustomSocket<I, O> {
|
|
83
85
|
protected incompleteData: string;
|
|
84
86
|
protected unprocessedEvents: string[];
|
|
85
|
-
protected relays: Map<
|
|
87
|
+
protected relays: Map<UserKey, SubjectSocket<any, any>>;
|
|
86
88
|
protected initRelay: (socket: SubjectSocket<any, any>, userKey: UserKey) => (() => void) | void;
|
|
87
89
|
proc: P;
|
|
88
90
|
id: string;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","names":["ATOM_IO_REALTIME_SERVER_ROOMS: RoomMap","ROOMS: RoomMap","roomMeta: { count: number }","socketAtoms: RegularAtomFamilyToken<Socket | null, SocketKey>","socketKeysAtom: MutableAtomToken<UList<SocketKey>>","onlineUsersAtom: MutableAtomToken<UList<UserKey>>","usersOfSockets: JoinToken<\n\t`user`,\n\tUserKey,\n\t`socket`,\n\tSocketKey,\n\t`1:1`\n>"],"sources":["../../src/realtime-server/continuity/provide-continuity.ts","../../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/provide-rooms.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","../../src/realtime-server/server-config.ts","../../src/realtime-server/server-socket-state.ts"],"sourcesContent":[],"mappings":"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
|
|
1
|
+
{"version":3,"file":"index.d.ts","names":["ATOM_IO_REALTIME_SERVER_ROOMS: RoomMap","ROOMS: RoomMap","roomMeta: { count: number }","socketAtoms: RegularAtomFamilyToken<Socket | null, SocketKey>","socketKeysAtom: MutableAtomToken<UList<SocketKey>>","onlineUsersAtom: MutableAtomToken<UList<UserKey>>","usersOfSockets: JoinToken<\n\t`user`,\n\tUserKey,\n\t`socket`,\n\tSocketKey,\n\t`1:1`\n>"],"sources":["../../src/realtime-server/continuity/provide-continuity.ts","../../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/provide-rooms.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","../../src/realtime-server/server-config.ts","../../src/realtime-server/server-socket-state.ts"],"sourcesContent":[],"mappings":"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"}
|
|
@@ -3,7 +3,7 @@ import { Realm, atomFamily, join, mutableAtom } from "atom.io";
|
|
|
3
3
|
import { parseJson, stringifyJson } from "atom.io/json";
|
|
4
4
|
import { UList } from "atom.io/transceivers/u-list";
|
|
5
5
|
import { castSocket, employSocket, isRoomKey, isSocketKey, isUserKey, mutexAtoms, ownersOfRooms, roomKeysAtom, usersInRooms, visibilityFromRoomSelector, visibleUsersInRoomsSelector } from "atom.io/realtime";
|
|
6
|
-
import {
|
|
6
|
+
import { myUserKeyAtom } from "atom.io/realtime-client";
|
|
7
7
|
import { spawn } from "node:child_process";
|
|
8
8
|
|
|
9
9
|
//#region src/realtime-server/continuity/continuity-store.ts
|
|
@@ -365,31 +365,32 @@ var ParentSocket = class extends CustomSocket {
|
|
|
365
365
|
if (this.proc.pid) this.id = this.proc.pid?.toString();
|
|
366
366
|
this.on(`user-joins`, (userKey) => {
|
|
367
367
|
this.logger.info(`👤`, userKey, `joined`);
|
|
368
|
+
if (this.relays.get(userKey)) return;
|
|
368
369
|
const relay = new SubjectSocket(userKey);
|
|
369
370
|
this.relays.set(userKey, relay);
|
|
370
|
-
this.logger.info(`🔗`, `attaching services for
|
|
371
|
+
this.logger.info(`🔗`, `attaching relay services for`, userKey);
|
|
371
372
|
const cleanupRelay = this.initRelay(relay, userKey);
|
|
372
373
|
if (cleanupRelay) relay.disposalFunctions.push(cleanupRelay);
|
|
373
374
|
this.on(userKey, (...data) => {
|
|
374
375
|
relay.in.next(data);
|
|
375
376
|
});
|
|
376
|
-
relay.out.subscribe(`socket`, (data) => {
|
|
377
|
-
this.emit(...data);
|
|
378
|
-
});
|
|
377
|
+
relay.disposalFunctions.push(relay.out.subscribe(`socket`, (data) => {
|
|
378
|
+
this.emit(userKey, ...data);
|
|
379
|
+
}));
|
|
379
380
|
});
|
|
380
|
-
this.on(`user-leaves`, (
|
|
381
|
-
const relay = this.relays.get(
|
|
382
|
-
this.off(
|
|
381
|
+
this.on(`user-leaves`, (userKey) => {
|
|
382
|
+
const relay = this.relays.get(userKey);
|
|
383
|
+
this.off(userKey);
|
|
383
384
|
if (relay) {
|
|
384
385
|
relay.dispose();
|
|
385
|
-
this.relays.delete(
|
|
386
|
+
this.relays.delete(userKey);
|
|
386
387
|
}
|
|
387
388
|
});
|
|
388
389
|
this.proc.stdout.write(PROOF_OF_LIFE_SIGNAL);
|
|
389
390
|
}
|
|
390
391
|
receiveRelay(attachServices) {
|
|
391
|
-
this.logger.info(`🔗`, `running relay method`);
|
|
392
392
|
this.initRelay = attachServices;
|
|
393
|
+
this.logger.info(`🔗`, `ready to relay`);
|
|
393
394
|
}
|
|
394
395
|
};
|
|
395
396
|
|
|
@@ -454,11 +455,12 @@ var ChildSocket = class extends CustomSocket {
|
|
|
454
455
|
if (piece === ``) continue;
|
|
455
456
|
try {
|
|
456
457
|
const jsonPiece = parseJson(piece);
|
|
458
|
+
this.logger.info(`💸`, `emitted`, jsonPiece);
|
|
457
459
|
this.handleEvent(...jsonPiece);
|
|
458
460
|
this.incompleteData = ``;
|
|
459
461
|
} catch (thrown0) {
|
|
460
462
|
if (thrown0 instanceof Error) console.error([
|
|
461
|
-
`❌ Malformed data received from child process
|
|
463
|
+
`❌ Malformed data received from child process:`,
|
|
462
464
|
``,
|
|
463
465
|
...piece.split(`\n`),
|
|
464
466
|
``,
|
|
@@ -468,12 +470,13 @@ var ChildSocket = class extends CustomSocket {
|
|
|
468
470
|
if (idx === 0) {
|
|
469
471
|
this.incompleteData = piece;
|
|
470
472
|
const maybeActualJsonPiece = parseJson(initialMaybeWellFormed);
|
|
473
|
+
this.logger.info(`💸`, `emitted`, maybeActualJsonPiece);
|
|
471
474
|
this.handleEvent(...maybeActualJsonPiece);
|
|
472
475
|
this.incompleteData = ``;
|
|
473
476
|
} else this.incompleteData += piece;
|
|
474
477
|
} catch (thrown1) {
|
|
475
478
|
if (thrown1 instanceof Error) console.error([
|
|
476
|
-
`❌ Malformed data received from child process
|
|
479
|
+
`❌ Malformed data received from child process:`,
|
|
477
480
|
``,
|
|
478
481
|
...initialMaybeWellFormed.split(`\n`),
|
|
479
482
|
``,
|
|
@@ -501,7 +504,7 @@ var ChildSocket = class extends CustomSocket {
|
|
|
501
504
|
this.incompleteData = ``;
|
|
502
505
|
} catch (thrown0) {
|
|
503
506
|
if (thrown0 instanceof Error) this.logger.error([
|
|
504
|
-
`❌ Malformed log received from child process
|
|
507
|
+
`❌ Malformed log received from child process:`,
|
|
505
508
|
``,
|
|
506
509
|
...piece.split(`\n`),
|
|
507
510
|
``,
|
|
@@ -516,7 +519,7 @@ var ChildSocket = class extends CustomSocket {
|
|
|
516
519
|
} else this.incompleteData += piece;
|
|
517
520
|
} catch (thrown1) {
|
|
518
521
|
if (thrown1 instanceof Error) this.logger.error([
|
|
519
|
-
`❌ Malformed log received from child process
|
|
522
|
+
`❌ Malformed log received from child process:`,
|
|
520
523
|
``,
|
|
521
524
|
...initialMaybeWellFormed.split(`\n`),
|
|
522
525
|
``,
|
|
@@ -645,47 +648,6 @@ function realtimeMutableProvider({ socket, consumer, store = IMPLICIT.STORE }) {
|
|
|
645
648
|
};
|
|
646
649
|
}
|
|
647
650
|
|
|
648
|
-
//#endregion
|
|
649
|
-
//#region src/realtime-server/realtime-state-provider.ts
|
|
650
|
-
function isReadableToken(input) {
|
|
651
|
-
return typeof input === `object` && input !== null && `key` in input && `type` in input;
|
|
652
|
-
}
|
|
653
|
-
function realtimeStateProvider({ socket, consumer, store = IMPLICIT.STORE }) {
|
|
654
|
-
store.logger.info(`🔌`, `user`, consumer, `initialized state provider`);
|
|
655
|
-
return function stateProvider(clientToken, serverData = clientToken) {
|
|
656
|
-
const isStatic = !isReadableToken(serverData);
|
|
657
|
-
const subscriptions = /* @__PURE__ */ new Set();
|
|
658
|
-
const clearSubscriptions = () => {
|
|
659
|
-
for (const unsub of subscriptions) unsub();
|
|
660
|
-
subscriptions.clear();
|
|
661
|
-
};
|
|
662
|
-
const start = () => {
|
|
663
|
-
if (isStatic) store.logger.info(`👀`, `user`, consumer, `will be served`, serverData, `as "${clientToken.key}"`);
|
|
664
|
-
else store.logger.info(`👀`, `user`, consumer, `can subscribe to state "${serverData.key}" as "${clientToken.key}"`);
|
|
665
|
-
subscriptions.add(employSocket(socket, `sub:${clientToken.key}`, () => {
|
|
666
|
-
if (isStatic) {
|
|
667
|
-
store.logger.info(`👀`, `user`, consumer, `requests`, `"${clientToken.key}"`);
|
|
668
|
-
socket.emit(`serve:${clientToken.key}`, serverData);
|
|
669
|
-
} else {
|
|
670
|
-
store.logger.info(`👀`, `user`, consumer, `subscribes to state "${serverData.key}"`, clientToken === serverData ? `directly` : `as "${clientToken.key}"`);
|
|
671
|
-
clearSubscriptions();
|
|
672
|
-
socket.emit(`serve:${clientToken.key}`, getFromStore(store, serverData));
|
|
673
|
-
subscriptions.add(subscribeToState(store, serverData, `expose-single:${socket.id}`, ({ newValue }) => {
|
|
674
|
-
socket.emit(`serve:${clientToken.key}`, newValue);
|
|
675
|
-
}));
|
|
676
|
-
subscriptions.add(employSocket(socket, `unsub:${serverData.key}`, () => {
|
|
677
|
-
store.logger.info(`🙈`, `user`, consumer, `unsubscribes from state "${serverData.key}", served`, clientToken === serverData ? `directly` : `as "${clientToken.key}"`);
|
|
678
|
-
clearSubscriptions();
|
|
679
|
-
start();
|
|
680
|
-
}));
|
|
681
|
-
}
|
|
682
|
-
}));
|
|
683
|
-
};
|
|
684
|
-
start();
|
|
685
|
-
return clearSubscriptions;
|
|
686
|
-
};
|
|
687
|
-
}
|
|
688
|
-
|
|
689
651
|
//#endregion
|
|
690
652
|
//#region src/realtime-server/provide-rooms.ts
|
|
691
653
|
const ROOMS = globalThis.ATOM_IO_REALTIME_SERVER_ROOMS ?? (globalThis.ATOM_IO_REALTIME_SERVER_ROOMS = /* @__PURE__ */ new Map());
|
|
@@ -696,7 +658,10 @@ function spawnRoom({ store, socket, userKey, resolveRoomScript }) {
|
|
|
696
658
|
const roomKey = `room::${roomMeta.count++}`;
|
|
697
659
|
const [command, args] = resolveRoomScript(roomName);
|
|
698
660
|
const room = new ChildSocket(await new Promise((resolve) => {
|
|
699
|
-
const room$1 = spawn(command, args, { env:
|
|
661
|
+
const room$1 = spawn(command, args, { env: {
|
|
662
|
+
...process.env,
|
|
663
|
+
REALTIME_ROOM_KEY: roomKey
|
|
664
|
+
} });
|
|
700
665
|
const resolver = (data) => {
|
|
701
666
|
if (data.toString() === PROOF_OF_LIFE_SIGNAL) {
|
|
702
667
|
room$1.stdout.off(`data`, resolver);
|
|
@@ -718,15 +683,9 @@ function spawnRoom({ store, socket, userKey, resolveRoomScript }) {
|
|
|
718
683
|
consumer: roomKey,
|
|
719
684
|
store
|
|
720
685
|
});
|
|
721
|
-
const unsubFromRoomKey = realtimeStateProvider({
|
|
722
|
-
socket: room,
|
|
723
|
-
consumer: roomKey,
|
|
724
|
-
store
|
|
725
|
-
})(myRoomKeyAtom, roomKey);
|
|
726
686
|
const unsubFromOwnerKeys = provideMutableFamily(getInternalRelationsFromStore(store, ownersOfRooms), [roomKey]);
|
|
727
687
|
const unsubFromUsersInRooms = provideMutableFamily(getInternalRelationsFromStore(store, usersInRooms), findInStore(store, visibilityFromRoomSelector, roomKey));
|
|
728
688
|
room.on(`close`, () => {
|
|
729
|
-
unsubFromRoomKey();
|
|
730
689
|
unsubFromOwnerKeys();
|
|
731
690
|
unsubFromUsersInRooms();
|
|
732
691
|
destroyRoom({
|
|
@@ -740,13 +699,31 @@ function spawnRoom({ store, socket, userKey, resolveRoomScript }) {
|
|
|
740
699
|
}
|
|
741
700
|
function provideEnterAndExit({ store, socket, roomSocket, userKey }) {
|
|
742
701
|
const enterRoom = (roomKey) => {
|
|
743
|
-
store.logger.info(`📡`, `socket`, socket.id ?? `[ID MISSING?!]`, `👤 ${userKey} enters
|
|
702
|
+
store.logger.info(`📡`, `socket`, socket.id ?? `[ID MISSING?!]`, `👤 ${userKey} enters ${roomKey}`);
|
|
703
|
+
const childSocket = ROOMS.get(roomKey);
|
|
704
|
+
if (!childSocket) {
|
|
705
|
+
store.logger.error(`❌`, `unknown`, roomKey, `no room found with this id`);
|
|
706
|
+
return;
|
|
707
|
+
}
|
|
708
|
+
const toUser = socket.emit.bind(socket);
|
|
709
|
+
childSocket.on(userKey, toUser);
|
|
710
|
+
const roomQueue = [];
|
|
711
|
+
const pushToRoomQueue = (payload) => {
|
|
712
|
+
roomQueue.push(payload);
|
|
713
|
+
};
|
|
714
|
+
let toRoom = pushToRoomQueue;
|
|
715
|
+
const forward = (...payload) => {
|
|
716
|
+
toRoom([userKey, ...payload]);
|
|
717
|
+
};
|
|
718
|
+
socket.onAny(forward);
|
|
744
719
|
const dcUserFromRoom = () => {
|
|
745
|
-
|
|
720
|
+
store.logger.info(`📡`, `socket`, socket.id ?? `[ID MISSING?!]`, `👤 ${userKey} is has lost connection to ${roomKey}`);
|
|
721
|
+
socket.offAny(forward);
|
|
722
|
+
childSocket.off(userKey, toUser);
|
|
723
|
+
toRoom([`user-leaves`, userKey]);
|
|
746
724
|
};
|
|
747
725
|
const exitRoom = () => {
|
|
748
|
-
store.logger.info(`📡`, `socket`, socket.id ?? `[ID MISSING?!]`, `👤 ${userKey} leaves
|
|
749
|
-
socket.offAny(forward);
|
|
726
|
+
store.logger.info(`📡`, `socket`, socket.id ?? `[ID MISSING?!]`, `👤 ${userKey} leaves ${roomKey}`);
|
|
750
727
|
dcUserFromRoom();
|
|
751
728
|
editRelationsInStore(store, usersInRooms, (relations) => {
|
|
752
729
|
relations.delete({
|
|
@@ -757,32 +734,15 @@ function provideEnterAndExit({ store, socket, roomSocket, userKey }) {
|
|
|
757
734
|
roomSocket.off(`leaveRoom`, exitRoom);
|
|
758
735
|
roomSocket.on(`joinRoom`, enterRoom);
|
|
759
736
|
};
|
|
760
|
-
const roomQueue = [];
|
|
761
|
-
const pushToRoomQueue = (payload) => {
|
|
762
|
-
roomQueue.push(payload);
|
|
763
|
-
};
|
|
764
|
-
let toRoom = pushToRoomQueue;
|
|
765
|
-
const forward = (...payload) => {
|
|
766
|
-
toRoom(payload);
|
|
767
|
-
};
|
|
768
|
-
socket.onAny(forward);
|
|
769
737
|
editRelationsInStore(store, usersInRooms, (relations) => {
|
|
770
738
|
relations.set({
|
|
771
739
|
room: roomKey,
|
|
772
740
|
user: userKey
|
|
773
741
|
});
|
|
774
742
|
});
|
|
775
|
-
const childSocket = ROOMS.get(roomKey);
|
|
776
|
-
if (!childSocket) {
|
|
777
|
-
store.logger.error(`❌`, `unknown`, roomKey, `no room found with this id`);
|
|
778
|
-
return;
|
|
779
|
-
}
|
|
780
|
-
childSocket.onAny((...payload) => {
|
|
781
|
-
socket.emit(...payload);
|
|
782
|
-
});
|
|
783
743
|
childSocket.emit(`user-joins`, userKey);
|
|
784
744
|
toRoom = (payload) => {
|
|
785
|
-
childSocket.emit(
|
|
745
|
+
childSocket.emit(...payload);
|
|
786
746
|
};
|
|
787
747
|
while (roomQueue.length > 0) {
|
|
788
748
|
const payload = roomQueue.shift();
|
|
@@ -797,10 +757,10 @@ function provideEnterAndExit({ store, socket, roomSocket, userKey }) {
|
|
|
797
757
|
}
|
|
798
758
|
function destroyRoom({ store, socket, userKey }) {
|
|
799
759
|
return (roomKey) => {
|
|
800
|
-
store.logger.info(`📡`, `socket`, socket.id ?? `[ID MISSING?!]`, `👤 ${userKey} attempts to delete
|
|
760
|
+
store.logger.info(`📡`, `socket`, socket.id ?? `[ID MISSING?!]`, `👤 ${userKey} attempts to delete ${roomKey}`);
|
|
801
761
|
const owner = getFromStore(store, findRelationsInStore(store, ownersOfRooms, roomKey).userKeyOfRoom);
|
|
802
762
|
if (owner === userKey) {
|
|
803
|
-
store.logger.info(`📡`, `socket`, socket.id ?? `[ID MISSING?!]`, `👤 ${userKey} deletes
|
|
763
|
+
store.logger.info(`📡`, `socket`, socket.id ?? `[ID MISSING?!]`, `👤 ${userKey} deletes ${roomKey}`);
|
|
804
764
|
setIntoStore(store, roomKeysAtom, (s) => (s.delete(roomKey), s));
|
|
805
765
|
editRelationsInStore(store, usersInRooms, (relations) => {
|
|
806
766
|
relations.delete({ room: roomKey });
|
|
@@ -812,7 +772,7 @@ function destroyRoom({ store, socket, userKey }) {
|
|
|
812
772
|
}
|
|
813
773
|
return;
|
|
814
774
|
}
|
|
815
|
-
store.logger.info(`📡`, `socket`, socket.id ?? `[ID MISSING?!]`, `👤 ${userKey} failed to delete
|
|
775
|
+
store.logger.info(`📡`, `socket`, socket.id ?? `[ID MISSING?!]`, `👤 ${userKey} failed to delete ${roomKey}; its owner is ${owner}`);
|
|
816
776
|
};
|
|
817
777
|
}
|
|
818
778
|
function provideRooms({ store = IMPLICIT.STORE, socket, resolveRoomScript, roomNames, userKey }) {
|
|
@@ -970,6 +930,47 @@ function realtimeAtomFamilyProvider({ socket, consumer, store = IMPLICIT.STORE }
|
|
|
970
930
|
};
|
|
971
931
|
}
|
|
972
932
|
|
|
933
|
+
//#endregion
|
|
934
|
+
//#region src/realtime-server/realtime-state-provider.ts
|
|
935
|
+
function isReadableToken(input) {
|
|
936
|
+
return typeof input === `object` && input !== null && `key` in input && `type` in input;
|
|
937
|
+
}
|
|
938
|
+
function realtimeStateProvider({ socket, consumer, store = IMPLICIT.STORE }) {
|
|
939
|
+
store.logger.info(`🔌`, `user`, consumer, `initialized state provider`);
|
|
940
|
+
return function stateProvider(clientToken, serverData = clientToken) {
|
|
941
|
+
const isStatic = !isReadableToken(serverData);
|
|
942
|
+
const subscriptions = /* @__PURE__ */ new Set();
|
|
943
|
+
const clearSubscriptions = () => {
|
|
944
|
+
for (const unsub of subscriptions) unsub();
|
|
945
|
+
subscriptions.clear();
|
|
946
|
+
};
|
|
947
|
+
const start = () => {
|
|
948
|
+
if (isStatic) store.logger.info(`👀`, `user`, consumer, `will be served`, serverData, `as "${clientToken.key}"`);
|
|
949
|
+
else store.logger.info(`👀`, `user`, consumer, `can subscribe to state "${serverData.key}" as "${clientToken.key}"`);
|
|
950
|
+
subscriptions.add(employSocket(socket, `sub:${clientToken.key}`, () => {
|
|
951
|
+
if (isStatic) {
|
|
952
|
+
store.logger.info(`👀`, `user`, consumer, `requests`, `"${clientToken.key}"`);
|
|
953
|
+
socket.emit(`serve:${clientToken.key}`, serverData);
|
|
954
|
+
} else {
|
|
955
|
+
store.logger.info(`👀`, `user`, consumer, `subscribes to state "${serverData.key}"`, clientToken === serverData ? `directly` : `as "${clientToken.key}"`);
|
|
956
|
+
clearSubscriptions();
|
|
957
|
+
socket.emit(`serve:${clientToken.key}`, getFromStore(store, serverData));
|
|
958
|
+
subscriptions.add(subscribeToState(store, serverData, `expose-single:${socket.id}`, ({ newValue }) => {
|
|
959
|
+
socket.emit(`serve:${clientToken.key}`, newValue);
|
|
960
|
+
}));
|
|
961
|
+
subscriptions.add(employSocket(socket, `unsub:${serverData.key}`, () => {
|
|
962
|
+
store.logger.info(`🙈`, `user`, consumer, `unsubscribes from state "${serverData.key}", served`, clientToken === serverData ? `directly` : `as "${clientToken.key}"`);
|
|
963
|
+
clearSubscriptions();
|
|
964
|
+
start();
|
|
965
|
+
}));
|
|
966
|
+
}
|
|
967
|
+
}));
|
|
968
|
+
};
|
|
969
|
+
start();
|
|
970
|
+
return clearSubscriptions;
|
|
971
|
+
};
|
|
972
|
+
}
|
|
973
|
+
|
|
973
974
|
//#endregion
|
|
974
975
|
//#region src/realtime-server/realtime-state-receiver.ts
|
|
975
976
|
function realtimeStateReceiver({ socket, consumer, store = IMPLICIT.STORE }) {
|