@spooky-sync/core 0.0.1-canary.4 → 0.0.1-canary.41
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/index.d.ts +18 -367
- package/dist/index.js +268 -287
- package/dist/otel/index.d.ts +21 -0
- package/dist/otel/index.js +86 -0
- package/dist/types.d.ts +361 -0
- package/package.json +34 -5
- package/skills/sp00ky-core/SKILL.md +258 -0
- package/skills/sp00ky-core/references/auth.md +98 -0
- package/skills/sp00ky-core/references/config.md +76 -0
- package/src/events/events.test.ts +2 -1
- package/src/index.ts +1 -1
- package/src/modules/auth/events/index.ts +2 -1
- package/src/modules/auth/index.ts +17 -20
- package/src/modules/cache/index.ts +23 -23
- package/src/modules/cache/types.ts +2 -2
- package/src/modules/data/index.ts +61 -43
- package/src/modules/devtools/index.ts +23 -20
- package/src/modules/sync/engine.ts +31 -21
- package/src/modules/sync/events/index.ts +3 -2
- package/src/modules/sync/queue/queue-down.ts +5 -4
- package/src/modules/sync/queue/queue-up.ts +14 -13
- package/src/modules/sync/scheduler.ts +2 -2
- package/src/modules/sync/sync.ts +47 -35
- package/src/modules/sync/utils.test.ts +2 -2
- package/src/modules/sync/utils.ts +15 -17
- package/src/otel/index.ts +127 -0
- package/src/services/database/database.ts +11 -11
- package/src/services/database/events/index.ts +2 -1
- package/src/services/database/local-migrator.ts +21 -21
- package/src/services/database/local.ts +16 -15
- package/src/services/database/remote.ts +13 -13
- package/src/services/logger/index.ts +6 -101
- package/src/services/persistence/localstorage.ts +2 -2
- package/src/services/persistence/resilient.ts +34 -0
- package/src/services/persistence/surrealdb.ts +9 -9
- package/src/services/stream-processor/index.ts +32 -31
- package/src/services/stream-processor/stream-processor.test.ts +1 -1
- package/src/services/stream-processor/wasm-types.ts +2 -2
- package/src/{spooky.ts → sp00ky.ts} +40 -38
- package/src/types.ts +18 -11
- package/src/utils/index.ts +10 -10
- package/src/utils/parser.ts +2 -1
- package/src/utils/surql.ts +15 -15
- package/src/utils/withRetry.test.ts +1 -1
- package/tsdown.config.ts +1 -1
package/dist/index.d.ts
CHANGED
|
@@ -1,132 +1,9 @@
|
|
|
1
|
+
import { C as Logger$1, S as UpdateOptions, T as EventSystem, _ as RunOptions, a as MutationEvent, b as Sp00kyQueryResultPromise, c as PinoTransmit, d as QueryHash, f as QueryState, g as RecordVersionDiff, h as RecordVersionArray, i as MutationCallback, l as QueryConfig, m as QueryUpdateCallback, n as EventSubscriptionOptions, o as MutationEventType, p as QueryTimeToLive, r as Level, s as PersistenceClient, t as DebounceOptions, u as QueryConfigRecord, v as Sp00kyConfig, w as EventDefinition, x as StoreType, y as Sp00kyQueryResult } from "./types.js";
|
|
1
2
|
import * as surrealdb0 from "surrealdb";
|
|
2
|
-
import { Duration, RecordId, Surreal, SurrealTransaction } from "surrealdb";
|
|
3
|
-
import { AccessDefinition, BackendNames, BackendRoutes, BucketNames, ColumnSchema, GetTable, QueryBuilder, QueryOptions,
|
|
4
|
-
import {
|
|
3
|
+
import { Duration, RecordId, Surreal as Surreal$1, SurrealTransaction } from "surrealdb";
|
|
4
|
+
import { AccessDefinition, BackendNames, BackendRoutes, BucketNames, ColumnSchema, GetTable, QueryBuilder, QueryOptions, RoutePayload, SchemaStructure, TableModel, TableNames, TypeNameToTypeMap } from "@spooky-sync/query-builder";
|
|
5
|
+
import { Logger } from "pino";
|
|
5
6
|
|
|
6
|
-
//#region src/events/index.d.ts
|
|
7
|
-
/**
|
|
8
|
-
* Utility type to define the payload structure of an event.
|
|
9
|
-
* If the payload type P is never, it defines payload as undefined.
|
|
10
|
-
*/
|
|
11
|
-
type EventPayloadDefinition<P> = [P] extends [never] ? {
|
|
12
|
-
payload: undefined;
|
|
13
|
-
} : {
|
|
14
|
-
payload: P;
|
|
15
|
-
};
|
|
16
|
-
/**
|
|
17
|
-
* Defines the structure of an event with a specific type and payload.
|
|
18
|
-
* @template T The string literal type of the event.
|
|
19
|
-
* @template P The type of the event payload.
|
|
20
|
-
*/
|
|
21
|
-
type EventDefinition<T extends string, P> = {
|
|
22
|
-
type: T;
|
|
23
|
-
} & EventPayloadDefinition<P>;
|
|
24
|
-
/**
|
|
25
|
-
* A map of event types to their definitions.
|
|
26
|
-
* Keys are event names, values are EventDefinitions.
|
|
27
|
-
*/
|
|
28
|
-
type EventTypeMap = Record<string, EventDefinition<any, unknown> | EventDefinition<any, never>>;
|
|
29
|
-
/**
|
|
30
|
-
* Options for pushing/emitting events.
|
|
31
|
-
*/
|
|
32
|
-
interface PushEventOptions {
|
|
33
|
-
/** Configuration for debouncing the event. */
|
|
34
|
-
debounced?: {
|
|
35
|
-
key: string;
|
|
36
|
-
delay: number;
|
|
37
|
-
};
|
|
38
|
-
}
|
|
39
|
-
/**
|
|
40
|
-
* Extracts the full Event object type from the map for a given key.
|
|
41
|
-
*/
|
|
42
|
-
type Event<E extends EventTypeMap, T extends EventType<E>> = E[T];
|
|
43
|
-
/**
|
|
44
|
-
* Extracts the payload type from the map for a given key.
|
|
45
|
-
*/
|
|
46
|
-
type EventPayload<E extends EventTypeMap, T extends EventType<E>> = E[T]['payload'];
|
|
47
|
-
/**
|
|
48
|
-
* Array of available event type keys.
|
|
49
|
-
*/
|
|
50
|
-
type EventTypes<E extends EventTypeMap> = (keyof E)[];
|
|
51
|
-
/**
|
|
52
|
-
* Represents a valid key (event name) from the EventTypeMap.
|
|
53
|
-
*/
|
|
54
|
-
type EventType<E extends EventTypeMap> = keyof E;
|
|
55
|
-
/**
|
|
56
|
-
* Function signature for an event handler.
|
|
57
|
-
*/
|
|
58
|
-
type EventHandler<E extends EventTypeMap, T extends EventType<E>> = (event: Event<E, T>) => void;
|
|
59
|
-
/**
|
|
60
|
-
* Options when subscribing to an event.
|
|
61
|
-
*/
|
|
62
|
-
type EventSubscriptionOptions$1 = {
|
|
63
|
-
/** If true, the handler will be called immediately with the last emitted event of this type (if any). */
|
|
64
|
-
immediately?: boolean;
|
|
65
|
-
/** If true, the subscription will be automatically removed after the first event is handled. */
|
|
66
|
-
once?: boolean;
|
|
67
|
-
};
|
|
68
|
-
/**
|
|
69
|
-
* A type-safe event system that handles subscription, emission (including debouncing), and buffering of events.
|
|
70
|
-
* @template E The EventTypeMap defining all supported events.
|
|
71
|
-
*/
|
|
72
|
-
declare class EventSystem<E extends EventTypeMap> {
|
|
73
|
-
private _eventTypes;
|
|
74
|
-
private subscriberId;
|
|
75
|
-
private isProcessing;
|
|
76
|
-
private buffer;
|
|
77
|
-
private subscribers;
|
|
78
|
-
private subscribersTypeMap;
|
|
79
|
-
private lastEvents;
|
|
80
|
-
private debouncedEvents;
|
|
81
|
-
constructor(_eventTypes: EventTypes<E>);
|
|
82
|
-
get eventTypes(): EventTypes<E>;
|
|
83
|
-
/**
|
|
84
|
-
* Subscribes a handler to a specific event type.
|
|
85
|
-
* @param type The event type to subscribe to.
|
|
86
|
-
* @param handler The function to call when the event occurs.
|
|
87
|
-
* @param options Subscription options (once, immediately).
|
|
88
|
-
* @returns A subscription ID that can be used to unsubscribe.
|
|
89
|
-
*/
|
|
90
|
-
subscribe<T extends EventType<E>>(type: T, handler: EventHandler<E, T>, options?: EventSubscriptionOptions$1): number;
|
|
91
|
-
/**
|
|
92
|
-
* Subscribes a handler to multiple event types.
|
|
93
|
-
* @param types An array of event types to subscribe to.
|
|
94
|
-
* @param handler The function to call when any of the events occur.
|
|
95
|
-
* @param options Subscription options.
|
|
96
|
-
* @returns An array of subscription IDs.
|
|
97
|
-
*/
|
|
98
|
-
subscribeMany<T extends EventType<E>>(types: T[], handler: EventHandler<E, T>, options?: EventSubscriptionOptions$1): number[];
|
|
99
|
-
/**
|
|
100
|
-
* Unsubscribes a specific subscription by ID.
|
|
101
|
-
* @param id The subscription ID returned by subscribe().
|
|
102
|
-
* @returns True if the subscription was found and removed, false otherwise.
|
|
103
|
-
*/
|
|
104
|
-
unsubscribe(id: number): boolean;
|
|
105
|
-
/**
|
|
106
|
-
* Emits an event with the given type and payload.
|
|
107
|
-
* @param type The type of event to emit.
|
|
108
|
-
* @param payload The data associated with the event.
|
|
109
|
-
*/
|
|
110
|
-
emit<T extends EventType<E>, P extends EventPayload<E, T>>(type: T, payload: P): void;
|
|
111
|
-
/**
|
|
112
|
-
* Adds a fully constructed event object to the system.
|
|
113
|
-
* Similar to emit, but takes the full event object directly.
|
|
114
|
-
* Supports debouncing if options are provided.
|
|
115
|
-
* @param event The event object.
|
|
116
|
-
* @param options Options for the event push (e.g., debouncing).
|
|
117
|
-
*/
|
|
118
|
-
addEvent<T extends EventType<E>>(event: Event<E, T>, options?: PushEventOptions): void;
|
|
119
|
-
private handleDebouncedEvent;
|
|
120
|
-
private scheduleProcessing;
|
|
121
|
-
private processEvents;
|
|
122
|
-
private dequeue;
|
|
123
|
-
private setLastEvent;
|
|
124
|
-
private broadcastEvent;
|
|
125
|
-
}
|
|
126
|
-
//#endregion
|
|
127
|
-
//#region src/services/logger/index.d.ts
|
|
128
|
-
type Logger$1 = Logger;
|
|
129
|
-
//#endregion
|
|
130
7
|
//#region src/services/database/events/index.d.ts
|
|
131
8
|
declare const DatabaseEventTypes: {
|
|
132
9
|
readonly LocalQuery: "DATABASE_LOCAL_QUERY";
|
|
@@ -154,13 +31,13 @@ interface SealedQuery<T = void> {
|
|
|
154
31
|
//#endregion
|
|
155
32
|
//#region src/services/database/database.d.ts
|
|
156
33
|
declare abstract class AbstractDatabaseService {
|
|
157
|
-
protected client: Surreal;
|
|
34
|
+
protected client: Surreal$1;
|
|
158
35
|
protected logger: Logger$1;
|
|
159
36
|
protected events: DatabaseEventSystem;
|
|
160
37
|
protected abstract eventType: typeof DatabaseEventTypes.LocalQuery | typeof DatabaseEventTypes.RemoteQuery;
|
|
161
|
-
constructor(client: Surreal, logger: Logger$1, events: DatabaseEventSystem);
|
|
38
|
+
constructor(client: Surreal$1, logger: Logger$1, events: DatabaseEventSystem);
|
|
162
39
|
abstract connect(): Promise<void>;
|
|
163
|
-
getClient(): Surreal;
|
|
40
|
+
getClient(): Surreal$1;
|
|
164
41
|
getEvents(): DatabaseEventSystem;
|
|
165
42
|
tx(): Promise<SurrealTransaction>;
|
|
166
43
|
private queryQueue;
|
|
@@ -176,8 +53,8 @@ declare abstract class AbstractDatabaseService {
|
|
|
176
53
|
declare class LocalDatabaseService extends AbstractDatabaseService {
|
|
177
54
|
private config;
|
|
178
55
|
protected eventType: "DATABASE_LOCAL_QUERY";
|
|
179
|
-
constructor(config:
|
|
180
|
-
getConfig():
|
|
56
|
+
constructor(config: Sp00kyConfig<any>['database'], logger: Logger$1);
|
|
57
|
+
getConfig(): Sp00kyConfig<any>['database'];
|
|
181
58
|
connect(): Promise<void>;
|
|
182
59
|
}
|
|
183
60
|
//#endregion
|
|
@@ -185,8 +62,8 @@ declare class LocalDatabaseService extends AbstractDatabaseService {
|
|
|
185
62
|
declare class RemoteDatabaseService extends AbstractDatabaseService {
|
|
186
63
|
private config;
|
|
187
64
|
protected eventType: "DATABASE_REMOTE_QUERY";
|
|
188
|
-
constructor(config:
|
|
189
|
-
getConfig():
|
|
65
|
+
constructor(config: Sp00kyConfig<any>['database'], logger: Logger$1);
|
|
66
|
+
getConfig(): Sp00kyConfig<any>['database'];
|
|
190
67
|
connect(): Promise<void>;
|
|
191
68
|
signin(params: any): Promise<any>;
|
|
192
69
|
signup(params: any): Promise<any>;
|
|
@@ -194,33 +71,6 @@ declare class RemoteDatabaseService extends AbstractDatabaseService {
|
|
|
194
71
|
invalidate(): Promise<void>;
|
|
195
72
|
}
|
|
196
73
|
//#endregion
|
|
197
|
-
//#region src/modules/sync/queue/queue-up.d.ts
|
|
198
|
-
type CreateEvent = {
|
|
199
|
-
type: 'create';
|
|
200
|
-
mutation_id: RecordId;
|
|
201
|
-
record_id: RecordId;
|
|
202
|
-
data: Record<string, unknown>;
|
|
203
|
-
record?: Record<string, unknown>;
|
|
204
|
-
tableName?: string;
|
|
205
|
-
options?: PushEventOptions;
|
|
206
|
-
};
|
|
207
|
-
type UpdateEvent = {
|
|
208
|
-
type: 'update';
|
|
209
|
-
mutation_id: RecordId;
|
|
210
|
-
record_id: RecordId;
|
|
211
|
-
data: Record<string, unknown>;
|
|
212
|
-
record?: Record<string, unknown>;
|
|
213
|
-
beforeRecord?: Record<string, unknown>;
|
|
214
|
-
options?: PushEventOptions;
|
|
215
|
-
};
|
|
216
|
-
type DeleteEvent = {
|
|
217
|
-
type: 'delete';
|
|
218
|
-
mutation_id: RecordId;
|
|
219
|
-
record_id: RecordId;
|
|
220
|
-
options?: PushEventOptions;
|
|
221
|
-
};
|
|
222
|
-
type UpEvent = CreateEvent | UpdateEvent | DeleteEvent;
|
|
223
|
-
//#endregion
|
|
224
74
|
//#region src/services/stream-processor/wasm-types.d.ts
|
|
225
75
|
interface WasmStreamUpdate {
|
|
226
76
|
query_id: string;
|
|
@@ -297,205 +147,6 @@ declare class StreamProcessorService {
|
|
|
297
147
|
private normalizeValue;
|
|
298
148
|
}
|
|
299
149
|
//#endregion
|
|
300
|
-
//#region src/types.d.ts
|
|
301
|
-
/**
|
|
302
|
-
* The type of storage backend to use for the local database.
|
|
303
|
-
* - 'memory': In-memory storage (transient).
|
|
304
|
-
* - 'indexeddb': IndexedDB storage (persistent).
|
|
305
|
-
*/
|
|
306
|
-
type StoreType = 'memory' | 'indexeddb';
|
|
307
|
-
/**
|
|
308
|
-
* Interface for a custom persistence client.
|
|
309
|
-
* Allows providing a custom storage mechanism for the local database.
|
|
310
|
-
*/
|
|
311
|
-
interface PersistenceClient {
|
|
312
|
-
/**
|
|
313
|
-
* Sets a value in the storage.
|
|
314
|
-
* @param key The key to set.
|
|
315
|
-
* @param value The value to store.
|
|
316
|
-
*/
|
|
317
|
-
set<T>(key: string, value: T): Promise<void>;
|
|
318
|
-
/**
|
|
319
|
-
* Gets a value from the storage.
|
|
320
|
-
* @param key The key to retrieve.
|
|
321
|
-
* @returns The stored value or null if not found.
|
|
322
|
-
*/
|
|
323
|
-
get<T>(key: string): Promise<T | null>;
|
|
324
|
-
/**
|
|
325
|
-
* Removes a value from the storage.
|
|
326
|
-
* @param key The key to remove.
|
|
327
|
-
*/
|
|
328
|
-
remove(key: string): Promise<void>;
|
|
329
|
-
}
|
|
330
|
-
/**
|
|
331
|
-
* Supported Time-To-Live (TTL) values for cached queries.
|
|
332
|
-
* Format: number + unit (m=minutes, h=hours, d=days).
|
|
333
|
-
*/
|
|
334
|
-
type QueryTimeToLive = '1m' | '5m' | '10m' | '15m' | '20m' | '25m' | '30m' | '1h' | '2h' | '3h' | '4h' | '5h' | '6h' | '7h' | '8h' | '9h' | '10h' | '11h' | '12h' | '1d';
|
|
335
|
-
/**
|
|
336
|
-
* Result object returned when a query is registered or executed.
|
|
337
|
-
*/
|
|
338
|
-
interface SpookyQueryResult {
|
|
339
|
-
/** The unique hash identifier for the query. */
|
|
340
|
-
hash: string;
|
|
341
|
-
}
|
|
342
|
-
type SpookyQueryResultPromise = Promise<SpookyQueryResult>;
|
|
343
|
-
interface EventSubscriptionOptions {
|
|
344
|
-
priority?: number;
|
|
345
|
-
}
|
|
346
|
-
/**
|
|
347
|
-
* Configuration options for the Spooky client.
|
|
348
|
-
* @template S The schema structure type.
|
|
349
|
-
*/
|
|
350
|
-
interface SpookyConfig<S extends SchemaStructure> {
|
|
351
|
-
/** Database connection configuration. */
|
|
352
|
-
database: {
|
|
353
|
-
/** The SurrealDB endpoint URL. */
|
|
354
|
-
endpoint?: string;
|
|
355
|
-
/** The namespace to use. */
|
|
356
|
-
namespace: string;
|
|
357
|
-
/** The database name. */
|
|
358
|
-
database: string;
|
|
359
|
-
/** The local store type implementation. */
|
|
360
|
-
store?: StoreType;
|
|
361
|
-
/** Authentication token. */
|
|
362
|
-
token?: string;
|
|
363
|
-
};
|
|
364
|
-
/** Unique client identifier. If not provided, one will be generated. */
|
|
365
|
-
clientId?: string;
|
|
366
|
-
/** The schema definition. */
|
|
367
|
-
schema: S;
|
|
368
|
-
/** The compiled SURQL schema string. */
|
|
369
|
-
schemaSurql: string;
|
|
370
|
-
/** Logging level. */
|
|
371
|
-
logLevel: Level$1;
|
|
372
|
-
/**
|
|
373
|
-
* Persistence client to use.
|
|
374
|
-
* Can be a custom implementation, 'surrealdb' (default), or 'localstorage'.
|
|
375
|
-
*/
|
|
376
|
-
persistenceClient?: PersistenceClient | 'surrealdb' | 'localstorage';
|
|
377
|
-
/** OpenTelemetry collector endpoint for telemetry data. */
|
|
378
|
-
otelEndpoint?: string;
|
|
379
|
-
/**
|
|
380
|
-
* Debounce time in milliseconds for stream updates.
|
|
381
|
-
* Defaults to 100ms.
|
|
382
|
-
*/
|
|
383
|
-
streamDebounceTime?: number;
|
|
384
|
-
}
|
|
385
|
-
type QueryHash = string;
|
|
386
|
-
type RecordVersionArray = Array<[string, number]>;
|
|
387
|
-
/**
|
|
388
|
-
* Represents the difference between two record version sets.
|
|
389
|
-
* Used for synchronizing local and remote states.
|
|
390
|
-
*/
|
|
391
|
-
interface RecordVersionDiff {
|
|
392
|
-
/** List of records added. */
|
|
393
|
-
added: Array<{
|
|
394
|
-
id: RecordId$1<string>;
|
|
395
|
-
version: number;
|
|
396
|
-
}>;
|
|
397
|
-
/** List of records updated. */
|
|
398
|
-
updated: Array<{
|
|
399
|
-
id: RecordId$1<string>;
|
|
400
|
-
version: number;
|
|
401
|
-
}>;
|
|
402
|
-
/** List of record IDs removed. */
|
|
403
|
-
removed: RecordId$1<string>[];
|
|
404
|
-
}
|
|
405
|
-
/**
|
|
406
|
-
* Configuration for a specific query instance.
|
|
407
|
-
* Stores metadata about the query's state, parameters, and versioning.
|
|
408
|
-
*/
|
|
409
|
-
interface QueryConfig {
|
|
410
|
-
/** The unique ID of the query config record. */
|
|
411
|
-
id: RecordId$1<string>;
|
|
412
|
-
/** The SURQL query string. */
|
|
413
|
-
surql: string;
|
|
414
|
-
/** Parameters used in the query. */
|
|
415
|
-
params: Record<string, any>;
|
|
416
|
-
/** The version array representing the local state of results. */
|
|
417
|
-
localArray: RecordVersionArray;
|
|
418
|
-
/** The version array representing the remote (server) state of results. */
|
|
419
|
-
remoteArray: RecordVersionArray;
|
|
420
|
-
/** Time-To-Live for this query. */
|
|
421
|
-
ttl: QueryTimeToLive;
|
|
422
|
-
/** Timestamp when the query was last accessed/active. */
|
|
423
|
-
lastActiveAt: Date;
|
|
424
|
-
/** The name of the table this query targets (if applicable). */
|
|
425
|
-
tableName: string;
|
|
426
|
-
}
|
|
427
|
-
type QueryConfigRecord = QueryConfig & {
|
|
428
|
-
id: string;
|
|
429
|
-
};
|
|
430
|
-
/**
|
|
431
|
-
* Internal state of a live query.
|
|
432
|
-
*/
|
|
433
|
-
interface QueryState {
|
|
434
|
-
/** The configuration for this query. */
|
|
435
|
-
config: QueryConfig;
|
|
436
|
-
/** The current cached records for this query. */
|
|
437
|
-
records: Record<string, any>[];
|
|
438
|
-
/** Timer for TTL expiration. */
|
|
439
|
-
ttlTimer: NodeJS.Timeout | null;
|
|
440
|
-
/** TTL duration in milliseconds. */
|
|
441
|
-
ttlDurationMs: number;
|
|
442
|
-
/** Number of times the query has been updated. */
|
|
443
|
-
updateCount: number;
|
|
444
|
-
}
|
|
445
|
-
type QueryUpdateCallback = (records: Record<string, any>[]) => void;
|
|
446
|
-
type MutationCallback = (mutations: UpEvent[]) => void;
|
|
447
|
-
type MutationEventType = 'create' | 'update' | 'delete';
|
|
448
|
-
/**
|
|
449
|
-
* Represents a mutation event (create, update, delete) to be synchronized.
|
|
450
|
-
*/
|
|
451
|
-
interface MutationEvent {
|
|
452
|
-
/** Example: 'create', 'update', or 'delete'. */
|
|
453
|
-
type: MutationEventType;
|
|
454
|
-
/** unique id of the mutation */
|
|
455
|
-
mutation_id: RecordId$1<string>;
|
|
456
|
-
/** The ID of the record being mutated. */
|
|
457
|
-
record_id: RecordId$1<string>;
|
|
458
|
-
/** The data payload for create/update operations. */
|
|
459
|
-
data?: any;
|
|
460
|
-
/** The full record data (optional context). */
|
|
461
|
-
record?: any;
|
|
462
|
-
/** Options for the mutation event (e.g., debounce settings). */
|
|
463
|
-
options?: PushEventOptions;
|
|
464
|
-
/** Timestamp when the event was created. */
|
|
465
|
-
createdAt: Date;
|
|
466
|
-
}
|
|
467
|
-
/**
|
|
468
|
-
* Options for run operations.
|
|
469
|
-
*/
|
|
470
|
-
interface RunOptions {
|
|
471
|
-
assignedTo?: string;
|
|
472
|
-
max_retries?: number;
|
|
473
|
-
retry_strategy?: 'linear' | 'exponential';
|
|
474
|
-
}
|
|
475
|
-
/**
|
|
476
|
-
* Options for update operations.
|
|
477
|
-
*/
|
|
478
|
-
interface UpdateOptions {
|
|
479
|
-
/**
|
|
480
|
-
* Debounce configuration for the update.
|
|
481
|
-
* If boolean, enables default debounce behavior.
|
|
482
|
-
*/
|
|
483
|
-
debounced?: boolean | DebounceOptions;
|
|
484
|
-
}
|
|
485
|
-
/**
|
|
486
|
-
* Configuration options for debouncing updates.
|
|
487
|
-
*/
|
|
488
|
-
interface DebounceOptions {
|
|
489
|
-
/**
|
|
490
|
-
* The key to use for debouncing.
|
|
491
|
-
* - 'recordId': Debounce based on the specific record ID. WARNING: IT WILL ONLY ACCEPT THE LATEST CHANGE AND DOES *NOT* MERGE THE PREVIOUS ONCES. IF YOU ARE UNSURE JUST USE 'recordId_x_fields'.
|
|
492
|
-
* - 'recordId_x_fields': Debounce based on record ID and specific fields.
|
|
493
|
-
*/
|
|
494
|
-
key?: 'recordId' | 'recordId_x_fields';
|
|
495
|
-
/** The debounce delay in milliseconds. */
|
|
496
|
-
delay?: number;
|
|
497
|
-
}
|
|
498
|
-
//#endregion
|
|
499
150
|
//#region src/modules/auth/events/index.d.ts
|
|
500
151
|
declare const AuthEventTypes: {
|
|
501
152
|
readonly AuthStateChanged: "AUTH_STATE_CHANGED";
|
|
@@ -543,7 +194,7 @@ declare class AuthService<S extends SchemaStructure> {
|
|
|
543
194
|
signIn<Name extends keyof S['access'] & string>(accessName: Name, params: ExtractAccessParams<S, Name, 'signIn'>): Promise<void>;
|
|
544
195
|
}
|
|
545
196
|
//#endregion
|
|
546
|
-
//#region src/
|
|
197
|
+
//#region src/sp00ky.d.ts
|
|
547
198
|
declare class BucketHandle {
|
|
548
199
|
private bucketName;
|
|
549
200
|
private remote;
|
|
@@ -557,7 +208,7 @@ declare class BucketHandle {
|
|
|
557
208
|
rename(sourcePath: string, targetPath: string): Promise<void>;
|
|
558
209
|
list(prefix?: string): Promise<string[]>;
|
|
559
210
|
}
|
|
560
|
-
declare class
|
|
211
|
+
declare class Sp00kyClient<S extends SchemaStructure> {
|
|
561
212
|
private config;
|
|
562
213
|
private local;
|
|
563
214
|
private remote;
|
|
@@ -570,11 +221,11 @@ declare class SpookyClient<S extends SchemaStructure> {
|
|
|
570
221
|
private logger;
|
|
571
222
|
auth: AuthService<S>;
|
|
572
223
|
streamProcessor: StreamProcessorService;
|
|
573
|
-
get remoteClient(): Surreal;
|
|
574
|
-
get localClient(): Surreal;
|
|
224
|
+
get remoteClient(): surrealdb0.Surreal;
|
|
225
|
+
get localClient(): surrealdb0.Surreal;
|
|
575
226
|
get pendingMutationCount(): number;
|
|
576
227
|
subscribeToPendingMutations(cb: (count: number) => void): () => void;
|
|
577
|
-
constructor(config:
|
|
228
|
+
constructor(config: Sp00kyConfig<S>);
|
|
578
229
|
/**
|
|
579
230
|
* Setup direct callbacks instead of event subscriptions
|
|
580
231
|
*/
|
|
@@ -583,7 +234,7 @@ declare class SpookyClient<S extends SchemaStructure> {
|
|
|
583
234
|
close(): Promise<void>;
|
|
584
235
|
authenticate(token: string): Promise<surrealdb0.Tokens>;
|
|
585
236
|
deauthenticate(): Promise<void>;
|
|
586
|
-
query<Table extends TableNames<S>>(table: Table, options: QueryOptions<TableModel<GetTable<S, Table>>, false>, ttl?: QueryTimeToLive): QueryBuilder<S, Table,
|
|
237
|
+
query<Table extends TableNames<S>>(table: Table, options: QueryOptions<TableModel<GetTable<S, Table>>, false>, ttl?: QueryTimeToLive): QueryBuilder<S, Table, Sp00kyQueryResultPromise>;
|
|
587
238
|
private initQuery;
|
|
588
239
|
queryRaw(sql: string, params: Record<string, any>, ttl: QueryTimeToLive): Promise<string>;
|
|
589
240
|
subscribe(queryHash: string, callback: (records: Record<string, any>[]) => void, options?: {
|
|
@@ -608,4 +259,4 @@ declare function fileToUint8Array(file: File | Blob): Promise<Uint8Array>;
|
|
|
608
259
|
*/
|
|
609
260
|
|
|
610
261
|
//#endregion
|
|
611
|
-
export { AuthEventSystem, AuthEventTypeMap, AuthEventTypes, AuthService, BucketHandle, DebounceOptions, EventSubscriptionOptions,
|
|
262
|
+
export { AuthEventSystem, AuthEventTypeMap, AuthEventTypes, AuthService, BucketHandle, DebounceOptions, EventSubscriptionOptions, Level, MutationCallback, MutationEvent, MutationEventType, PersistenceClient, PinoTransmit, QueryConfig, QueryConfigRecord, QueryHash, QueryState, QueryTimeToLive, QueryUpdateCallback, RecordVersionArray, RecordVersionDiff, RunOptions, Sp00kyClient, Sp00kyConfig, Sp00kyQueryResult, Sp00kyQueryResultPromise, StoreType, UpdateOptions, createAuthEventSystem, fileToUint8Array };
|