@thewhateverapp/platform 0.7.25 → 0.8.0

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.
@@ -0,0 +1,143 @@
1
+ /**
2
+ * Client-side Realtime Types
3
+ *
4
+ * Types for the useRealtime React hook and RealtimeClient class.
5
+ */
6
+ import type { RealtimeMessage, RealtimeConnectionState } from '../../realtime/types';
7
+ export type { RealtimeMessage, RealtimeConnectionState };
8
+ /**
9
+ * Configuration for the realtime client
10
+ */
11
+ export interface RealtimeClientConfig {
12
+ /**
13
+ * Base URL for WebSocket connection
14
+ * @default 'wss://realtime.thewhatever.app'
15
+ */
16
+ baseUrl?: string;
17
+ /**
18
+ * App ID for channel isolation
19
+ */
20
+ appId: string;
21
+ /**
22
+ * Initial channels to subscribe to
23
+ */
24
+ channels?: string[];
25
+ /**
26
+ * Auto-reconnect on disconnect
27
+ * @default true
28
+ */
29
+ autoReconnect?: boolean;
30
+ /**
31
+ * Reconnect delay in milliseconds
32
+ * @default 1000
33
+ */
34
+ reconnectDelay?: number;
35
+ /**
36
+ * Maximum reconnect attempts (0 = unlimited)
37
+ * @default 10
38
+ */
39
+ maxReconnectAttempts?: number;
40
+ /**
41
+ * Ping interval in milliseconds (0 = disabled)
42
+ * @default 30000
43
+ */
44
+ pingInterval?: number;
45
+ }
46
+ /**
47
+ * Options for the useRealtime hook
48
+ */
49
+ export interface UseRealtimeOptions {
50
+ /**
51
+ * Base URL for WebSocket connection
52
+ * @default 'wss://realtime.thewhatever.app'
53
+ */
54
+ baseUrl?: string;
55
+ /**
56
+ * Initial channels to subscribe to
57
+ */
58
+ channels?: string[];
59
+ /**
60
+ * Auto-reconnect on disconnect
61
+ * @default true
62
+ */
63
+ autoReconnect?: boolean;
64
+ /**
65
+ * Reconnect delay in milliseconds
66
+ * @default 1000
67
+ */
68
+ reconnectDelay?: number;
69
+ /**
70
+ * Maximum reconnect attempts (0 = unlimited)
71
+ * @default 10
72
+ */
73
+ maxReconnectAttempts?: number;
74
+ /**
75
+ * Callback when connected
76
+ */
77
+ onConnect?: () => void;
78
+ /**
79
+ * Callback when disconnected
80
+ */
81
+ onDisconnect?: () => void;
82
+ /**
83
+ * Callback when reconnecting
84
+ */
85
+ onReconnecting?: (attempt: number) => void;
86
+ /**
87
+ * Callback on error
88
+ */
89
+ onError?: (error: Error) => void;
90
+ }
91
+ /**
92
+ * Return type of the useRealtime hook
93
+ */
94
+ export interface UseRealtimeReturn<T = unknown> {
95
+ /**
96
+ * Current connection state
97
+ */
98
+ state: RealtimeConnectionState;
99
+ /**
100
+ * Whether connected
101
+ */
102
+ isConnected: boolean;
103
+ /**
104
+ * Currently subscribed channels
105
+ */
106
+ channels: string[];
107
+ /**
108
+ * Last received data (generic type)
109
+ */
110
+ lastMessage: {
111
+ channel: string;
112
+ data: T;
113
+ } | null;
114
+ /**
115
+ * Subscribe to a channel
116
+ */
117
+ subscribe: (channel: string) => void;
118
+ /**
119
+ * Unsubscribe from a channel
120
+ */
121
+ unsubscribe: (channel: string) => void;
122
+ /**
123
+ * Publish data to a channel (client-to-server-to-all)
124
+ */
125
+ publish: (channel: string, data: T) => void;
126
+ /**
127
+ * Manually reconnect
128
+ */
129
+ reconnect: () => void;
130
+ /**
131
+ * Disconnect and cleanup
132
+ */
133
+ disconnect: () => void;
134
+ }
135
+ /**
136
+ * Message handler callback type
137
+ */
138
+ export type MessageHandler<T = unknown> = (data: T, channel: string) => void;
139
+ /**
140
+ * Connection state change handler
141
+ */
142
+ export type StateChangeHandler = (state: RealtimeConnectionState) => void;
143
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/client/realtime/types.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EAAE,eAAe,EAAE,uBAAuB,EAAE,MAAM,sBAAsB,CAAC;AAErF,YAAY,EAAE,eAAe,EAAE,uBAAuB,EAAE,CAAC;AAEzD;;GAEG;AACH,MAAM,WAAW,oBAAoB;IACnC;;;OAGG;IACH,OAAO,CAAC,EAAE,MAAM,CAAC;IAEjB;;OAEG;IACH,KAAK,EAAE,MAAM,CAAC;IAEd;;OAEG;IACH,QAAQ,CAAC,EAAE,MAAM,EAAE,CAAC;IAEpB;;;OAGG;IACH,aAAa,CAAC,EAAE,OAAO,CAAC;IAExB;;;OAGG;IACH,cAAc,CAAC,EAAE,MAAM,CAAC;IAExB;;;OAGG;IACH,oBAAoB,CAAC,EAAE,MAAM,CAAC;IAE9B;;;OAGG;IACH,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB;AAED;;GAEG;AACH,MAAM,WAAW,kBAAkB;IACjC;;;OAGG;IACH,OAAO,CAAC,EAAE,MAAM,CAAC;IAEjB;;OAEG;IACH,QAAQ,CAAC,EAAE,MAAM,EAAE,CAAC;IAEpB;;;OAGG;IACH,aAAa,CAAC,EAAE,OAAO,CAAC;IAExB;;;OAGG;IACH,cAAc,CAAC,EAAE,MAAM,CAAC;IAExB;;;OAGG;IACH,oBAAoB,CAAC,EAAE,MAAM,CAAC;IAE9B;;OAEG;IACH,SAAS,CAAC,EAAE,MAAM,IAAI,CAAC;IAEvB;;OAEG;IACH,YAAY,CAAC,EAAE,MAAM,IAAI,CAAC;IAE1B;;OAEG;IACH,cAAc,CAAC,EAAE,CAAC,OAAO,EAAE,MAAM,KAAK,IAAI,CAAC;IAE3C;;OAEG;IACH,OAAO,CAAC,EAAE,CAAC,KAAK,EAAE,KAAK,KAAK,IAAI,CAAC;CAClC;AAED;;GAEG;AACH,MAAM,WAAW,iBAAiB,CAAC,CAAC,GAAG,OAAO;IAC5C;;OAEG;IACH,KAAK,EAAE,uBAAuB,CAAC;IAE/B;;OAEG;IACH,WAAW,EAAE,OAAO,CAAC;IAErB;;OAEG;IACH,QAAQ,EAAE,MAAM,EAAE,CAAC;IAEnB;;OAEG;IACH,WAAW,EAAE;QAAE,OAAO,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,CAAC,CAAA;KAAE,GAAG,IAAI,CAAC;IAEjD;;OAEG;IACH,SAAS,EAAE,CAAC,OAAO,EAAE,MAAM,KAAK,IAAI,CAAC;IAErC;;OAEG;IACH,WAAW,EAAE,CAAC,OAAO,EAAE,MAAM,KAAK,IAAI,CAAC;IAEvC;;OAEG;IACH,OAAO,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC,KAAK,IAAI,CAAC;IAE5C;;OAEG;IACH,SAAS,EAAE,MAAM,IAAI,CAAC;IAEtB;;OAEG;IACH,UAAU,EAAE,MAAM,IAAI,CAAC;CACxB;AAED;;GAEG;AACH,MAAM,MAAM,cAAc,CAAC,CAAC,GAAG,OAAO,IAAI,CAAC,IAAI,EAAE,CAAC,EAAE,OAAO,EAAE,MAAM,KAAK,IAAI,CAAC;AAE7E;;GAEG;AACH,MAAM,MAAM,kBAAkB,GAAG,CAAC,KAAK,EAAE,uBAAuB,KAAK,IAAI,CAAC"}
@@ -0,0 +1,7 @@
1
+ /**
2
+ * Client-side Realtime Types
3
+ *
4
+ * Types for the useRealtime React hook and RealtimeClient class.
5
+ */
6
+ export {};
7
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/client/realtime/types.ts"],"names":[],"mappings":"AAAA;;;;GAIG"}
package/dist/env.d.ts CHANGED
@@ -22,6 +22,7 @@ export interface PlatformEnv {
22
22
  KV?: KVNamespace;
23
23
  DB?: D1Database;
24
24
  STORAGE?: R2Bucket;
25
+ REALTIME?: DurableObjectNamespace;
25
26
  STORAGE_PUBLIC_URL?: string;
26
27
  DB_PROVIDER?: string;
27
28
  KV_PROVIDER?: string;
package/dist/env.d.ts.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"env.d.ts","sourceRoot":"","sources":["../src/env.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;GAmBG;AAEH,MAAM,WAAW,WAAW;IAC1B,EAAE,CAAC,EAAE,WAAW,CAAC;IACjB,EAAE,CAAC,EAAE,UAAU,CAAC;IAChB,OAAO,CAAC,EAAE,QAAQ,CAAC;IACnB,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;CACxB;AAED,KAAK,WAAW,GAAG,MAAM,WAAW,CAAC;AAIrC;;;;;;;;;;;;;;;;GAgBG;AACH,wBAAgB,oBAAoB,CAAC,QAAQ,EAAE,WAAW,GAAG,IAAI,CAEhE;AAED;;;;GAIG;AACH,wBAAgB,cAAc,IAAI,WAAW,CAQ5C;AAED;;GAEG;AACH,wBAAgB,uBAAuB,IAAI,OAAO,CAEjD;AAED;;GAEG;AACH,wBAAgB,gBAAgB,IAAI,IAAI,CAEvC"}
1
+ {"version":3,"file":"env.d.ts","sourceRoot":"","sources":["../src/env.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;GAmBG;AAEH,MAAM,WAAW,WAAW;IAC1B,EAAE,CAAC,EAAE,WAAW,CAAC;IACjB,EAAE,CAAC,EAAE,UAAU,CAAC;IAChB,OAAO,CAAC,EAAE,QAAQ,CAAC;IACnB,QAAQ,CAAC,EAAE,sBAAsB,CAAC;IAClC,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;CACxB;AAED,KAAK,WAAW,GAAG,MAAM,WAAW,CAAC;AAIrC;;;;;;;;;;;;;;;;GAgBG;AACH,wBAAgB,oBAAoB,CAAC,QAAQ,EAAE,WAAW,GAAG,IAAI,CAEhE;AAED;;;;GAIG;AACH,wBAAgB,cAAc,IAAI,WAAW,CAQ5C;AAED;;GAEG;AACH,wBAAgB,uBAAuB,IAAI,OAAO,CAEjD;AAED;;GAEG;AACH,wBAAgB,gBAAgB,IAAI,IAAI,CAEvC"}
package/dist/env.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"env.js","sourceRoot":"","sources":["../src/env.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;GAmBG;AAkBH,IAAI,WAAW,GAAuB,IAAI,CAAC;AAE3C;;;;;;;;;;;;;;;;GAgBG;AACH,MAAM,UAAU,oBAAoB,CAAC,QAAqB;IACxD,WAAW,GAAG,QAAQ,CAAC;AACzB,CAAC;AAED;;;;GAIG;AACH,MAAM,UAAU,cAAc;IAC5B,IAAI,CAAC,WAAW,EAAE,CAAC;QACjB,MAAM,IAAI,KAAK,CACb,mCAAmC;YACjC,mGAAmG,CACtG,CAAC;IACJ,CAAC;IACD,OAAO,WAAW,EAAE,CAAC;AACvB,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,uBAAuB;IACrC,OAAO,WAAW,KAAK,IAAI,CAAC;AAC9B,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,gBAAgB;IAC9B,WAAW,GAAG,IAAI,CAAC;AACrB,CAAC"}
1
+ {"version":3,"file":"env.js","sourceRoot":"","sources":["../src/env.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;GAmBG;AAmBH,IAAI,WAAW,GAAuB,IAAI,CAAC;AAE3C;;;;;;;;;;;;;;;;GAgBG;AACH,MAAM,UAAU,oBAAoB,CAAC,QAAqB;IACxD,WAAW,GAAG,QAAQ,CAAC;AACzB,CAAC;AAED;;;;GAIG;AACH,MAAM,UAAU,cAAc;IAC5B,IAAI,CAAC,WAAW,EAAE,CAAC;QACjB,MAAM,IAAI,KAAK,CACb,mCAAmC;YACjC,mGAAmG,CACtG,CAAC;IACJ,CAAC;IACD,OAAO,WAAW,EAAE,CAAC;AACvB,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,uBAAuB;IACrC,OAAO,WAAW,KAAK,IAAI,CAAC;AAC9B,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,gBAAgB;IAC9B,WAAW,GAAG,IAAI,CAAC;AACrB,CAAC"}
package/dist/index.d.ts CHANGED
@@ -38,6 +38,8 @@ export { getAI, createAI } from './ai';
38
38
  export type { AIServiceProvider, AIProvider, AICapability, AskOptions, PromptRequest, PromptResponse, ImageInput, } from './ai/types';
39
39
  export { getTileState } from './tile-state';
40
40
  export type { TileStateProvider, Comment, Report, } from './tile-state/types';
41
+ export { getRealtime, createRealtime, getRealtimeWebSocketUrl } from './realtime';
42
+ export type { RealtimeProvider, RealtimeEnv, RealtimeMessage, RealtimeMessageType, RealtimeStats, PublishOptions, PublishResult, RealtimeConnectionOptions, RealtimeConnectionState, RealtimeConnection, } from './realtime/types';
41
43
  export { ProductionStorage } from './storage/production';
42
44
  export { MockStorage } from './storage/mock';
43
45
  export { ProductionDB } from './db/production';
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;GAyBG;AAGH,OAAO,EACL,oBAAoB,EACpB,cAAc,EACd,uBAAuB,EACvB,gBAAgB,GACjB,MAAM,OAAO,CAAC;AACf,YAAY,EAAE,WAAW,EAAE,MAAM,OAAO,CAAC;AAGzC,OAAO,EAAE,cAAc,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAG9D,mBAAmB,SAAS,CAAC;AAO7B,OAAO,EAAE,WAAW,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AACzD,YAAY,EACV,gBAAgB,EAChB,UAAU,EACV,KAAK,EACL,MAAM,EACN,WAAW,EACX,eAAe,EACf,gBAAgB,EAChB,YAAY,EACZ,YAAY,GACb,MAAM,kBAAkB,CAAC;AAG1B,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,MAAM,CAAC;AACvC,YAAY,EACV,UAAU,EACV,YAAY,EACZ,aAAa,EACb,YAAY,EACZ,WAAW,EACX,OAAO,EACP,UAAU,GACX,MAAM,YAAY,CAAC;AAGpB,OAAO,EAAE,UAAU,EAAE,aAAa,EAAE,MAAM,MAAM,CAAC;AACjD,YAAY,EACV,eAAe,EACf,aAAa,EACb,eAAe,EACf,WAAW,IAAI,kBAAkB,EACjC,UAAU,IAAI,iBAAiB,EAC/B,UAAU,IAAI,iBAAiB,EAC/B,SAAS,IAAI,gBAAgB,EAC7B,UAAU,IAAI,iBAAiB,GAChC,MAAM,YAAY,CAAC;AAGpB,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,MAAM,CAAC;AACvC,YAAY,EACV,iBAAiB,EACjB,UAAU,EACV,YAAY,EACZ,UAAU,EACV,aAAa,EACb,cAAc,EACd,UAAU,GACX,MAAM,YAAY,CAAC;AAGpB,OAAO,EAAE,YAAY,EAAE,MAAM,cAAc,CAAC;AAC5C,YAAY,EACV,iBAAiB,EACjB,OAAO,EACP,MAAM,GACP,MAAM,oBAAoB,CAAC;AAM5B,OAAO,EAAE,iBAAiB,EAAE,MAAM,sBAAsB,CAAC;AACzD,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC7C,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,MAAM,EAAE,MAAM,WAAW,CAAC;AACnC,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,MAAM,EAAE,MAAM,WAAW,CAAC;AACnC,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAChD,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAC5C,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAChD,OAAO,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAC1D,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAC5C,OAAO,EAAE,OAAO,EAAE,MAAM,eAAe,CAAC;AACxC,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAC5C,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAC1C,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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"}
package/dist/index.js CHANGED
@@ -41,6 +41,8 @@ export { getStorage, createStorage } from './r2';
41
41
  export { getAI, createAI } from './ai';
42
42
  // Tile State - Durable Objects for real-time state
43
43
  export { getTileState } from './tile-state';
44
+ // Realtime - WebSocket pub/sub via Durable Objects
45
+ export { getRealtime, createRealtime, getRealtimeWebSocketUrl } from './realtime';
44
46
  // =============================================================================
45
47
  // Platform API Clients (for web apps, admin tools)
46
48
  // =============================================================================
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;GAyBG;AAEH,0EAA0E;AAC1E,OAAO,EACL,oBAAoB,EACpB,cAAc,EACd,uBAAuB,EACvB,gBAAgB,GACjB,MAAM,OAAO,CAAC;AAGf,eAAe;AACf,OAAO,EAAE,cAAc,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAK9D,gFAAgF;AAChF,mEAAmE;AACnE,gFAAgF;AAEhF,mDAAmD;AACnD,OAAO,EAAE,WAAW,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AAazD,yCAAyC;AACzC,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,MAAM,CAAC;AAWvC,gCAAgC;AAChC,OAAO,EAAE,UAAU,EAAE,aAAa,EAAE,MAAM,MAAM,CAAC;AAYjD,6DAA6D;AAC7D,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,MAAM,CAAC;AAWvC,mDAAmD;AACnD,OAAO,EAAE,YAAY,EAAE,MAAM,cAAc,CAAC;AAO5C,gFAAgF;AAChF,mDAAmD;AACnD,gFAAgF;AAEhF,OAAO,EAAE,iBAAiB,EAAE,MAAM,sBAAsB,CAAC;AACzD,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC7C,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,MAAM,EAAE,MAAM,WAAW,CAAC;AACnC,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,MAAM,EAAE,MAAM,WAAW,CAAC;AACnC,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAChD,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAC5C,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAChD,OAAO,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAC1D,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAC5C,OAAO,EAAE,OAAO,EAAE,MAAM,eAAe,CAAC;AACxC,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAC5C,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAC1C,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;GAyBG;AAEH,0EAA0E;AAC1E,OAAO,EACL,oBAAoB,EACpB,cAAc,EACd,uBAAuB,EACvB,gBAAgB,GACjB,MAAM,OAAO,CAAC;AAGf,eAAe;AACf,OAAO,EAAE,cAAc,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAK9D,gFAAgF;AAChF,mEAAmE;AACnE,gFAAgF;AAEhF,mDAAmD;AACnD,OAAO,EAAE,WAAW,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AAazD,yCAAyC;AACzC,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,MAAM,CAAC;AAWvC,gCAAgC;AAChC,OAAO,EAAE,UAAU,EAAE,aAAa,EAAE,MAAM,MAAM,CAAC;AAYjD,6DAA6D;AAC7D,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,MAAM,CAAC;AAWvC,mDAAmD;AACnD,OAAO,EAAE,YAAY,EAAE,MAAM,cAAc,CAAC;AAO5C,mDAAmD;AACnD,OAAO,EAAE,WAAW,EAAE,cAAc,EAAE,uBAAuB,EAAE,MAAM,YAAY,CAAC;AAclF,gFAAgF;AAChF,mDAAmD;AACnD,gFAAgF;AAEhF,OAAO,EAAE,iBAAiB,EAAE,MAAM,sBAAsB,CAAC;AACzD,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC7C,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,MAAM,EAAE,MAAM,WAAW,CAAC;AACnC,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,MAAM,EAAE,MAAM,WAAW,CAAC;AACnC,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAChD,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAC5C,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAChD,OAAO,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAC1D,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAC5C,OAAO,EAAE,OAAO,EAAE,MAAM,eAAe,CAAC;AACxC,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAC5C,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAC1C,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC"}
@@ -0,0 +1,77 @@
1
+ /**
2
+ * Realtime WebSocket Pub/Sub API
3
+ *
4
+ * Provides real-time messaging capabilities for tiles using
5
+ * Cloudflare Durable Objects with WebSocket hibernation.
6
+ *
7
+ * @example
8
+ * ```typescript
9
+ * import { getCloudflareContext } from '@opennextjs/cloudflare';
10
+ * import { configurePlatformEnv, getRealtime } from '@thewhateverapp/platform';
11
+ *
12
+ * export async function POST(req: NextRequest) {
13
+ * // Configure env once per request
14
+ * configurePlatformEnv(() => getCloudflareContext().env);
15
+ *
16
+ * const realtime = await getRealtime();
17
+ *
18
+ * // Publish to all subscribers
19
+ * await realtime.publish('counter', { count: newCount });
20
+ *
21
+ * return NextResponse.json({ success: true });
22
+ * }
23
+ * ```
24
+ */
25
+ import type { RealtimeProvider, RealtimeEnv } from './types';
26
+ export type * from './types';
27
+ /**
28
+ * Get a Realtime instance for the current request
29
+ *
30
+ * @param reqOrEnv - Optional: object with env property, or env object directly.
31
+ * If not provided, uses the env configured via configurePlatformEnv().
32
+ * @returns Realtime provider instance
33
+ *
34
+ * @example
35
+ * ```typescript
36
+ * // Using configured env (recommended)
37
+ * configurePlatformEnv(() => getCloudflareContext().env);
38
+ * const realtime = await getRealtime();
39
+ *
40
+ * // Or pass env directly
41
+ * const realtime = await getRealtime({ env });
42
+ * const realtime = await getRealtime(env);
43
+ * ```
44
+ */
45
+ export declare function getRealtime(reqOrEnv?: {
46
+ env: RealtimeEnv;
47
+ } | RealtimeEnv): Promise<RealtimeProvider>;
48
+ /**
49
+ * Create a Realtime instance directly (for advanced usage)
50
+ *
51
+ * @param env - Environment with REALTIME binding
52
+ * @param appId - Optional app ID for isolation (defaults to env.APP_ID or 'default')
53
+ *
54
+ * @example
55
+ * ```typescript
56
+ * const realtime = createRealtime({ REALTIME: env.REALTIME }, 'my-app-id');
57
+ * await realtime.publish('channel', { data: 'value' });
58
+ * ```
59
+ */
60
+ export declare function createRealtime(env: RealtimeEnv, appId?: string): RealtimeProvider;
61
+ /**
62
+ * Get the WebSocket URL for connecting to realtime from the client
63
+ *
64
+ * This is typically used by the client SDK's useRealtime hook.
65
+ *
66
+ * @param appId - App ID for channel isolation
67
+ * @param channels - Optional initial channels to subscribe to
68
+ * @param baseUrl - Optional base URL (defaults to production)
69
+ *
70
+ * @example
71
+ * ```typescript
72
+ * const wsUrl = getRealtimeWebSocketUrl('my-app', ['counter', 'chat']);
73
+ * // Returns: wss://realtime.thewhatever.app/ws?appId=my-app&channels=counter,chat
74
+ * ```
75
+ */
76
+ export declare function getRealtimeWebSocketUrl(appId: string, channels?: string[], baseUrl?: string): string;
77
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/realtime/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;GAuBG;AAEH,OAAO,KAAK,EAAE,gBAAgB,EAAE,WAAW,EAAgD,MAAM,SAAS,CAAC;AAI3G,mBAAmB,SAAS,CAAC;AAoD7B;;;;;;;;;;;;;;;;;GAiBG;AACH,wBAAsB,WAAW,CAC/B,QAAQ,CAAC,EAAE;IAAE,GAAG,EAAE,WAAW,CAAA;CAAE,GAAG,WAAW,GAC5C,OAAO,CAAC,gBAAgB,CAAC,CA0C3B;AAED;;;;;;;;;;;GAWG;AACH,wBAAgB,cAAc,CAAC,GAAG,EAAE,WAAW,EAAE,KAAK,CAAC,EAAE,MAAM,GAAG,gBAAgB,CAUjF;AAED;;;;;;;;;;;;;;GAcG;AACH,wBAAgB,uBAAuB,CACrC,KAAK,EAAE,MAAM,EACb,QAAQ,CAAC,EAAE,MAAM,EAAE,EACnB,OAAO,SAAmC,GACzC,MAAM,CASR"}
@@ -0,0 +1,166 @@
1
+ /**
2
+ * Realtime WebSocket Pub/Sub API
3
+ *
4
+ * Provides real-time messaging capabilities for tiles using
5
+ * Cloudflare Durable Objects with WebSocket hibernation.
6
+ *
7
+ * @example
8
+ * ```typescript
9
+ * import { getCloudflareContext } from '@opennextjs/cloudflare';
10
+ * import { configurePlatformEnv, getRealtime } from '@thewhateverapp/platform';
11
+ *
12
+ * export async function POST(req: NextRequest) {
13
+ * // Configure env once per request
14
+ * configurePlatformEnv(() => getCloudflareContext().env);
15
+ *
16
+ * const realtime = await getRealtime();
17
+ *
18
+ * // Publish to all subscribers
19
+ * await realtime.publish('counter', { count: newCount });
20
+ *
21
+ * return NextResponse.json({ success: true });
22
+ * }
23
+ * ```
24
+ */
25
+ import { getPlatformEnv, isPlatformEnvConfigured } from '../env';
26
+ /**
27
+ * Cloudflare Durable Object-backed Realtime Provider
28
+ *
29
+ * Communicates with the RealtimeChannel Durable Object via HTTP
30
+ * to publish messages to connected WebSocket clients.
31
+ */
32
+ class CloudflareRealtime {
33
+ stub;
34
+ constructor(stub) {
35
+ this.stub = stub;
36
+ }
37
+ async publish(channel, data, _options) {
38
+ const response = await this.stub.fetch('http://internal/publish', {
39
+ method: 'POST',
40
+ headers: {
41
+ 'Content-Type': 'application/json',
42
+ },
43
+ body: JSON.stringify({ channel, data }),
44
+ });
45
+ if (!response.ok) {
46
+ const error = await response.json().catch(() => ({ error: 'Unknown error' }));
47
+ throw new Error(`Failed to publish: ${error.error}`);
48
+ }
49
+ return (await response.json());
50
+ }
51
+ async getStats() {
52
+ const response = await this.stub.fetch('http://internal/stats');
53
+ if (!response.ok) {
54
+ throw new Error('Failed to get realtime stats');
55
+ }
56
+ return (await response.json());
57
+ }
58
+ async isHealthy() {
59
+ try {
60
+ const response = await this.stub.fetch('http://internal/health');
61
+ return response.ok;
62
+ }
63
+ catch {
64
+ return false;
65
+ }
66
+ }
67
+ }
68
+ /**
69
+ * Get a Realtime instance for the current request
70
+ *
71
+ * @param reqOrEnv - Optional: object with env property, or env object directly.
72
+ * If not provided, uses the env configured via configurePlatformEnv().
73
+ * @returns Realtime provider instance
74
+ *
75
+ * @example
76
+ * ```typescript
77
+ * // Using configured env (recommended)
78
+ * configurePlatformEnv(() => getCloudflareContext().env);
79
+ * const realtime = await getRealtime();
80
+ *
81
+ * // Or pass env directly
82
+ * const realtime = await getRealtime({ env });
83
+ * const realtime = await getRealtime(env);
84
+ * ```
85
+ */
86
+ export async function getRealtime(reqOrEnv) {
87
+ let env;
88
+ // If no argument provided, use the configured env provider
89
+ if (!reqOrEnv) {
90
+ if (!isPlatformEnvConfigured()) {
91
+ throw new Error('getRealtime() called without env and configurePlatformEnv() was not called. ' +
92
+ 'Either pass env directly: getRealtime({ env }) or call configurePlatformEnv(() => getCloudflareContext().env) first.');
93
+ }
94
+ env = getPlatformEnv();
95
+ }
96
+ else if ('env' in reqOrEnv) {
97
+ env = reqOrEnv.env;
98
+ }
99
+ else if ('REALTIME' in reqOrEnv) {
100
+ // Direct env object
101
+ env = reqOrEnv;
102
+ }
103
+ else {
104
+ env = reqOrEnv.env;
105
+ }
106
+ if (!env) {
107
+ throw new Error('No environment found. Ensure you are running in edge runtime.');
108
+ }
109
+ // Check for REALTIME Durable Object binding
110
+ if (!env.REALTIME) {
111
+ throw new Error('No REALTIME Durable Object binding found. ' +
112
+ 'Add a service binding to the realtime-do worker in your wrangler.jsonc:\n' +
113
+ ' "services": [{ "binding": "REALTIME", "service": "realtime-do", "entrypoint": "RealtimeChannel" }]');
114
+ }
115
+ // Get APP_ID for channel isolation (one DO per app)
116
+ const appId = env.APP_ID || 'default';
117
+ // Get Durable Object ID from app ID (deterministic)
118
+ const id = env.REALTIME.idFromName(appId);
119
+ const stub = env.REALTIME.get(id);
120
+ return new CloudflareRealtime(stub);
121
+ }
122
+ /**
123
+ * Create a Realtime instance directly (for advanced usage)
124
+ *
125
+ * @param env - Environment with REALTIME binding
126
+ * @param appId - Optional app ID for isolation (defaults to env.APP_ID or 'default')
127
+ *
128
+ * @example
129
+ * ```typescript
130
+ * const realtime = createRealtime({ REALTIME: env.REALTIME }, 'my-app-id');
131
+ * await realtime.publish('channel', { data: 'value' });
132
+ * ```
133
+ */
134
+ export function createRealtime(env, appId) {
135
+ if (!env.REALTIME) {
136
+ throw new Error('No REALTIME Durable Object binding found.');
137
+ }
138
+ const resolvedAppId = appId || env.APP_ID || 'default';
139
+ const id = env.REALTIME.idFromName(resolvedAppId);
140
+ const stub = env.REALTIME.get(id);
141
+ return new CloudflareRealtime(stub);
142
+ }
143
+ /**
144
+ * Get the WebSocket URL for connecting to realtime from the client
145
+ *
146
+ * This is typically used by the client SDK's useRealtime hook.
147
+ *
148
+ * @param appId - App ID for channel isolation
149
+ * @param channels - Optional initial channels to subscribe to
150
+ * @param baseUrl - Optional base URL (defaults to production)
151
+ *
152
+ * @example
153
+ * ```typescript
154
+ * const wsUrl = getRealtimeWebSocketUrl('my-app', ['counter', 'chat']);
155
+ * // Returns: wss://realtime.thewhatever.app/ws?appId=my-app&channels=counter,chat
156
+ * ```
157
+ */
158
+ export function getRealtimeWebSocketUrl(appId, channels, baseUrl = 'wss://realtime.thewhatever.app') {
159
+ const url = new URL('/ws', baseUrl);
160
+ url.searchParams.set('appId', appId);
161
+ if (channels && channels.length > 0) {
162
+ url.searchParams.set('channels', channels.join(','));
163
+ }
164
+ return url.toString();
165
+ }
166
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/realtime/index.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,178 @@
1
+ /**
2
+ * Realtime WebSocket Pub/Sub Types
3
+ *
4
+ * Provides type definitions for the realtime messaging system
5
+ * powered by Cloudflare Durable Objects.
6
+ */
7
+ /**
8
+ * Message types for WebSocket communication
9
+ */
10
+ export type RealtimeMessageType = 'subscribe' | 'unsubscribe' | 'publish' | 'ping' | 'pong' | 'data' | 'error' | 'connected' | 'subscribed' | 'unsubscribed';
11
+ /**
12
+ * Base message structure for realtime communication
13
+ */
14
+ export interface RealtimeMessage {
15
+ type: RealtimeMessageType;
16
+ channel?: string;
17
+ channels?: string[];
18
+ data?: unknown;
19
+ timestamp?: number;
20
+ message?: string;
21
+ }
22
+ /**
23
+ * Options for publishing messages
24
+ */
25
+ export interface PublishOptions {
26
+ /**
27
+ * Whether to wait for confirmation
28
+ * @default false
29
+ */
30
+ waitForConfirm?: boolean;
31
+ }
32
+ /**
33
+ * Result of a publish operation
34
+ */
35
+ export interface PublishResult {
36
+ success: boolean;
37
+ channel: string;
38
+ recipients: number;
39
+ }
40
+ /**
41
+ * Environment bindings required for Realtime
42
+ */
43
+ export interface RealtimeEnv {
44
+ /**
45
+ * Durable Object namespace binding for RealtimeChannel
46
+ */
47
+ REALTIME?: DurableObjectNamespace;
48
+ /**
49
+ * App ID for channel isolation
50
+ */
51
+ APP_ID?: string;
52
+ }
53
+ /**
54
+ * Server-side Realtime Provider interface
55
+ *
56
+ * Used in API routes to publish messages to connected clients.
57
+ *
58
+ * @example
59
+ * ```typescript
60
+ * import { getRealtime } from '@thewhateverapp/platform';
61
+ *
62
+ * export async function POST(req: Request) {
63
+ * const realtime = await getRealtime();
64
+ *
65
+ * // Publish to a channel
66
+ * await realtime.publish('counter', { count: 42 });
67
+ *
68
+ * return new Response('OK');
69
+ * }
70
+ * ```
71
+ */
72
+ export interface RealtimeProvider {
73
+ /**
74
+ * Publish a message to a channel
75
+ *
76
+ * All connected clients subscribed to this channel will receive the message.
77
+ *
78
+ * @param channel - Channel name to publish to
79
+ * @param data - Data to send (will be JSON serialized)
80
+ * @param options - Optional publish options
81
+ * @returns Result with recipient count
82
+ */
83
+ publish(channel: string, data: unknown, options?: PublishOptions): Promise<PublishResult>;
84
+ /**
85
+ * Get statistics about connected clients
86
+ *
87
+ * @returns Stats including total connections and per-channel counts
88
+ */
89
+ getStats(): Promise<RealtimeStats>;
90
+ /**
91
+ * Check if the realtime service is healthy
92
+ *
93
+ * @returns True if the service is responding
94
+ */
95
+ isHealthy(): Promise<boolean>;
96
+ }
97
+ /**
98
+ * Statistics about realtime connections
99
+ */
100
+ export interface RealtimeStats {
101
+ totalConnections: number;
102
+ channels: Record<string, number>;
103
+ }
104
+ /**
105
+ * Options for creating a realtime connection (client-side)
106
+ */
107
+ export interface RealtimeConnectionOptions {
108
+ /**
109
+ * Channels to subscribe to immediately on connect
110
+ */
111
+ channels?: string[];
112
+ /**
113
+ * Auto-reconnect on disconnect
114
+ * @default true
115
+ */
116
+ autoReconnect?: boolean;
117
+ /**
118
+ * Reconnect delay in milliseconds
119
+ * @default 1000
120
+ */
121
+ reconnectDelay?: number;
122
+ /**
123
+ * Maximum reconnect attempts (0 = unlimited)
124
+ * @default 10
125
+ */
126
+ maxReconnectAttempts?: number;
127
+ /**
128
+ * Ping interval in milliseconds (0 = disabled)
129
+ * @default 30000
130
+ */
131
+ pingInterval?: number;
132
+ }
133
+ /**
134
+ * Connection state for client-side realtime
135
+ */
136
+ export type RealtimeConnectionState = 'connecting' | 'connected' | 'disconnected' | 'reconnecting';
137
+ /**
138
+ * Client-side realtime connection interface
139
+ */
140
+ export interface RealtimeConnection {
141
+ /**
142
+ * Current connection state
143
+ */
144
+ readonly state: RealtimeConnectionState;
145
+ /**
146
+ * Currently subscribed channels
147
+ */
148
+ readonly channels: readonly string[];
149
+ /**
150
+ * Subscribe to a channel
151
+ */
152
+ subscribe(channel: string): void;
153
+ /**
154
+ * Unsubscribe from a channel
155
+ */
156
+ unsubscribe(channel: string): void;
157
+ /**
158
+ * Publish a message (client-to-server-to-all)
159
+ */
160
+ publish(channel: string, data: unknown): void;
161
+ /**
162
+ * Add a message listener for a channel
163
+ */
164
+ on(channel: string, callback: (data: unknown) => void): () => void;
165
+ /**
166
+ * Add a listener for all messages
167
+ */
168
+ onAny(callback: (channel: string, data: unknown) => void): () => void;
169
+ /**
170
+ * Add a connection state listener
171
+ */
172
+ onStateChange(callback: (state: RealtimeConnectionState) => void): () => void;
173
+ /**
174
+ * Disconnect and cleanup
175
+ */
176
+ disconnect(): void;
177
+ }
178
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/realtime/types.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,8 @@
1
+ /**
2
+ * Realtime WebSocket Pub/Sub Types
3
+ *
4
+ * Provides type definitions for the realtime messaging system
5
+ * powered by Cloudflare Durable Objects.
6
+ */
7
+ export {};
8
+ //# sourceMappingURL=types.js.map