@instantdb/core 0.22.88-experimental.drewh-ssr.20249092140.1 → 0.22.88-experimental.drewh-fix-explorer.20249092035.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (49) hide show
  1. package/dist/commonjs/Reactor.d.ts +1 -13
  2. package/dist/commonjs/Reactor.d.ts.map +1 -1
  3. package/dist/commonjs/Reactor.js +5 -64
  4. package/dist/commonjs/Reactor.js.map +1 -1
  5. package/dist/commonjs/index.d.ts +1 -5
  6. package/dist/commonjs/index.d.ts.map +1 -1
  7. package/dist/commonjs/index.js +1 -7
  8. package/dist/commonjs/index.js.map +1 -1
  9. package/dist/esm/Reactor.d.ts +1 -13
  10. package/dist/esm/Reactor.d.ts.map +1 -1
  11. package/dist/esm/Reactor.js +5 -64
  12. package/dist/esm/Reactor.js.map +1 -1
  13. package/dist/esm/index.d.ts +1 -5
  14. package/dist/esm/index.d.ts.map +1 -1
  15. package/dist/esm/index.js +2 -5
  16. package/dist/esm/index.js.map +1 -1
  17. package/dist/standalone/index.js +1372 -1672
  18. package/dist/standalone/index.umd.cjs +3 -3
  19. package/package.json +2 -2
  20. package/src/Reactor.js +9 -74
  21. package/src/index.ts +0 -9
  22. package/__tests__/src/serializeSchema.test.ts +0 -123
  23. package/dist/commonjs/createRouteHandler.d.ts +0 -8
  24. package/dist/commonjs/createRouteHandler.d.ts.map +0 -1
  25. package/dist/commonjs/createRouteHandler.js +0 -57
  26. package/dist/commonjs/createRouteHandler.js.map +0 -1
  27. package/dist/commonjs/framework.d.ts +0 -77
  28. package/dist/commonjs/framework.d.ts.map +0 -1
  29. package/dist/commonjs/framework.js +0 -199
  30. package/dist/commonjs/framework.js.map +0 -1
  31. package/dist/commonjs/parseSchemaFromJSON.d.ts +0 -3
  32. package/dist/commonjs/parseSchemaFromJSON.d.ts.map +0 -1
  33. package/dist/commonjs/parseSchemaFromJSON.js +0 -148
  34. package/dist/commonjs/parseSchemaFromJSON.js.map +0 -1
  35. package/dist/esm/createRouteHandler.d.ts +0 -8
  36. package/dist/esm/createRouteHandler.d.ts.map +0 -1
  37. package/dist/esm/createRouteHandler.js +0 -53
  38. package/dist/esm/createRouteHandler.js.map +0 -1
  39. package/dist/esm/framework.d.ts +0 -77
  40. package/dist/esm/framework.d.ts.map +0 -1
  41. package/dist/esm/framework.js +0 -159
  42. package/dist/esm/framework.js.map +0 -1
  43. package/dist/esm/parseSchemaFromJSON.d.ts +0 -3
  44. package/dist/esm/parseSchemaFromJSON.d.ts.map +0 -1
  45. package/dist/esm/parseSchemaFromJSON.js +0 -144
  46. package/dist/esm/parseSchemaFromJSON.js.map +0 -1
  47. package/src/createRouteHandler.ts +0 -44
  48. package/src/framework.ts +0 -281
  49. package/src/parseSchemaFromJSON.ts +0 -176
@@ -1,144 +0,0 @@
1
- import { i } from "./schema.js";
2
- export const parseSchemaFromJSON = (s) => {
3
- var _a, _b, _c, _d, _e, _f;
4
- // Parse entities
5
- const entities = {};
6
- for (const [entityName, entityInfo] of Object.entries(s.entities)) {
7
- const entityDef = entityInfo;
8
- const attrs = {};
9
- // Parse attributes
10
- for (const [attrName, attrInfo] of Object.entries(entityDef.attrs)) {
11
- const attrDef = attrInfo;
12
- let attr;
13
- // Create the appropriate attribute type
14
- switch (attrDef.valueType) {
15
- case 'string':
16
- attr = i.string();
17
- break;
18
- case 'number':
19
- attr = i.number();
20
- break;
21
- case 'boolean':
22
- attr = i.boolean();
23
- break;
24
- case 'date':
25
- attr = i.date();
26
- break;
27
- case 'json':
28
- attr = i.json();
29
- break;
30
- default:
31
- attr = i.json();
32
- }
33
- // Apply modifiers
34
- if (!attrDef.required) {
35
- attr = attr.optional();
36
- }
37
- if ((_a = attrDef.config) === null || _a === void 0 ? void 0 : _a.indexed) {
38
- attr = attr.indexed();
39
- }
40
- if ((_b = attrDef.config) === null || _b === void 0 ? void 0 : _b.unique) {
41
- attr = attr.unique();
42
- }
43
- attrs[attrName] = attr;
44
- }
45
- entities[entityName] = i.entity(attrs);
46
- }
47
- // Parse links
48
- const links = s.links || {};
49
- // Parse rooms
50
- const rooms = {};
51
- if (s.rooms) {
52
- for (const [roomName, roomInfo] of Object.entries(s.rooms)) {
53
- const roomDef = roomInfo;
54
- // Parse presence
55
- const presenceAttrs = {};
56
- for (const [attrName, attrInfo] of Object.entries(roomDef.presence.attrs)) {
57
- const attrDef = attrInfo;
58
- let attr;
59
- switch (attrDef.valueType) {
60
- case 'string':
61
- attr = i.string();
62
- break;
63
- case 'number':
64
- attr = i.number();
65
- break;
66
- case 'boolean':
67
- attr = i.boolean();
68
- break;
69
- case 'date':
70
- attr = i.date();
71
- break;
72
- case 'json':
73
- attr = i.json();
74
- break;
75
- default:
76
- attr = i.json();
77
- }
78
- if (!attrDef.required) {
79
- attr = attr.optional();
80
- }
81
- if ((_c = attrDef.config) === null || _c === void 0 ? void 0 : _c.indexed) {
82
- attr = attr.indexed();
83
- }
84
- if ((_d = attrDef.config) === null || _d === void 0 ? void 0 : _d.unique) {
85
- attr = attr.unique();
86
- }
87
- presenceAttrs[attrName] = attr;
88
- }
89
- // Parse topics
90
- const topics = {};
91
- if (roomDef.topics) {
92
- for (const [topicName, topicInfo] of Object.entries(roomDef.topics)) {
93
- const topicDef = topicInfo;
94
- const topicAttrs = {};
95
- for (const [attrName, attrInfo] of Object.entries(topicDef.attrs)) {
96
- const attrDef = attrInfo;
97
- let attr;
98
- switch (attrDef.valueType) {
99
- case 'string':
100
- attr = i.string();
101
- break;
102
- case 'number':
103
- attr = i.number();
104
- break;
105
- case 'boolean':
106
- attr = i.boolean();
107
- break;
108
- case 'date':
109
- attr = i.date();
110
- break;
111
- case 'json':
112
- attr = i.json();
113
- break;
114
- default:
115
- attr = i.json();
116
- }
117
- if (!attrDef.required) {
118
- attr = attr.optional();
119
- }
120
- if ((_e = attrDef.config) === null || _e === void 0 ? void 0 : _e.indexed) {
121
- attr = attr.indexed();
122
- }
123
- if ((_f = attrDef.config) === null || _f === void 0 ? void 0 : _f.unique) {
124
- attr = attr.unique();
125
- }
126
- topicAttrs[attrName] = attr;
127
- }
128
- topics[topicName] = i.entity(topicAttrs);
129
- }
130
- }
131
- rooms[roomName] = {
132
- presence: i.entity(presenceAttrs),
133
- topics,
134
- };
135
- }
136
- }
137
- const resultingSchema = i.schema({
138
- entities,
139
- links,
140
- rooms,
141
- });
142
- return resultingSchema;
143
- };
144
- //# sourceMappingURL=parseSchemaFromJSON.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"parseSchemaFromJSON.js","sourceRoot":"","sources":["../../src/parseSchemaFromJSON.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,aAAa,CAAC;AAGhC,MAAM,CAAC,MAAM,mBAAmB,GAAG,CACjC,CAAM,EAC2B,EAAE;;IACnC,iBAAiB;IACjB,MAAM,QAAQ,GAAwB,EAAE,CAAC;IAEzC,KAAK,MAAM,CAAC,UAAU,EAAE,UAAU,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC;QAClE,MAAM,SAAS,GAAG,UAAiB,CAAC;QACpC,MAAM,KAAK,GAAwB,EAAE,CAAC;QAEtC,mBAAmB;QACnB,KAAK,MAAM,CAAC,QAAQ,EAAE,QAAQ,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,CAAC;YACnE,MAAM,OAAO,GAAG,QAAe,CAAC;YAChC,IAAI,IAAgC,CAAC;YAErC,wCAAwC;YACxC,QAAQ,OAAO,CAAC,SAAS,EAAE,CAAC;gBAC1B,KAAK,QAAQ;oBACX,IAAI,GAAG,CAAC,CAAC,MAAM,EAAE,CAAC;oBAClB,MAAM;gBACR,KAAK,QAAQ;oBACX,IAAI,GAAG,CAAC,CAAC,MAAM,EAAE,CAAC;oBAClB,MAAM;gBACR,KAAK,SAAS;oBACZ,IAAI,GAAG,CAAC,CAAC,OAAO,EAAE,CAAC;oBACnB,MAAM;gBACR,KAAK,MAAM;oBACT,IAAI,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC;oBAChB,MAAM;gBACR,KAAK,MAAM;oBACT,IAAI,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC;oBAChB,MAAM;gBACR;oBACE,IAAI,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC;YACpB,CAAC;YAED,kBAAkB;YAClB,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;gBACtB,IAAI,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC;YACzB,CAAC;YAED,IAAI,MAAA,OAAO,CAAC,MAAM,0CAAE,OAAO,EAAE,CAAC;gBAC5B,IAAI,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC;YACxB,CAAC;YAED,IAAI,MAAA,OAAO,CAAC,MAAM,0CAAE,MAAM,EAAE,CAAC;gBAC3B,IAAI,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;YACvB,CAAC;YAED,KAAK,CAAC,QAAQ,CAAC,GAAG,IAAI,CAAC;QACzB,CAAC;QAED,QAAQ,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IACzC,CAAC;IAED,cAAc;IACd,MAAM,KAAK,GAAwB,CAAC,CAAC,KAAK,IAAI,EAAE,CAAC;IAEjD,cAAc;IACd,MAAM,KAAK,GAAwB,EAAE,CAAC;IAEtC,IAAI,CAAC,CAAC,KAAK,EAAE,CAAC;QACZ,KAAK,MAAM,CAAC,QAAQ,EAAE,QAAQ,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC;YAC3D,MAAM,OAAO,GAAG,QAAe,CAAC;YAEhC,iBAAiB;YACjB,MAAM,aAAa,GAAwB,EAAE,CAAC;YAC9C,KAAK,MAAM,CAAC,QAAQ,EAAE,QAAQ,CAAC,IAAI,MAAM,CAAC,OAAO,CAC/C,OAAO,CAAC,QAAQ,CAAC,KAAK,CACvB,EAAE,CAAC;gBACF,MAAM,OAAO,GAAG,QAAe,CAAC;gBAChC,IAAI,IAAgC,CAAC;gBAErC,QAAQ,OAAO,CAAC,SAAS,EAAE,CAAC;oBAC1B,KAAK,QAAQ;wBACX,IAAI,GAAG,CAAC,CAAC,MAAM,EAAE,CAAC;wBAClB,MAAM;oBACR,KAAK,QAAQ;wBACX,IAAI,GAAG,CAAC,CAAC,MAAM,EAAE,CAAC;wBAClB,MAAM;oBACR,KAAK,SAAS;wBACZ,IAAI,GAAG,CAAC,CAAC,OAAO,EAAE,CAAC;wBACnB,MAAM;oBACR,KAAK,MAAM;wBACT,IAAI,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC;wBAChB,MAAM;oBACR,KAAK,MAAM;wBACT,IAAI,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC;wBAChB,MAAM;oBACR;wBACE,IAAI,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC;gBACpB,CAAC;gBAED,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;oBACtB,IAAI,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC;gBACzB,CAAC;gBAED,IAAI,MAAA,OAAO,CAAC,MAAM,0CAAE,OAAO,EAAE,CAAC;oBAC5B,IAAI,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC;gBACxB,CAAC;gBAED,IAAI,MAAA,OAAO,CAAC,MAAM,0CAAE,MAAM,EAAE,CAAC;oBAC3B,IAAI,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;gBACvB,CAAC;gBAED,aAAa,CAAC,QAAQ,CAAC,GAAG,IAAI,CAAC;YACjC,CAAC;YAED,eAAe;YACf,MAAM,MAAM,GAAwB,EAAE,CAAC;YACvC,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;gBACnB,KAAK,MAAM,CAAC,SAAS,EAAE,SAAS,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC;oBACpE,MAAM,QAAQ,GAAG,SAAgB,CAAC;oBAClC,MAAM,UAAU,GAAwB,EAAE,CAAC;oBAE3C,KAAK,MAAM,CAAC,QAAQ,EAAE,QAAQ,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC;wBAClE,MAAM,OAAO,GAAG,QAAe,CAAC;wBAChC,IAAI,IAAgC,CAAC;wBAErC,QAAQ,OAAO,CAAC,SAAS,EAAE,CAAC;4BAC1B,KAAK,QAAQ;gCACX,IAAI,GAAG,CAAC,CAAC,MAAM,EAAE,CAAC;gCAClB,MAAM;4BACR,KAAK,QAAQ;gCACX,IAAI,GAAG,CAAC,CAAC,MAAM,EAAE,CAAC;gCAClB,MAAM;4BACR,KAAK,SAAS;gCACZ,IAAI,GAAG,CAAC,CAAC,OAAO,EAAE,CAAC;gCACnB,MAAM;4BACR,KAAK,MAAM;gCACT,IAAI,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC;gCAChB,MAAM;4BACR,KAAK,MAAM;gCACT,IAAI,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC;gCAChB,MAAM;4BACR;gCACE,IAAI,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC;wBACpB,CAAC;wBAED,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;4BACtB,IAAI,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC;wBACzB,CAAC;wBAED,IAAI,MAAA,OAAO,CAAC,MAAM,0CAAE,OAAO,EAAE,CAAC;4BAC5B,IAAI,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC;wBACxB,CAAC;wBAED,IAAI,MAAA,OAAO,CAAC,MAAM,0CAAE,MAAM,EAAE,CAAC;4BAC3B,IAAI,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;wBACvB,CAAC;wBAED,UAAU,CAAC,QAAQ,CAAC,GAAG,IAAI,CAAC;oBAC9B,CAAC;oBAED,MAAM,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;gBAC3C,CAAC;YACH,CAAC;YAED,KAAK,CAAC,QAAQ,CAAC,GAAG;gBAChB,QAAQ,EAAE,CAAC,CAAC,MAAM,CAAC,aAAa,CAAC;gBACjC,MAAM;aACP,CAAC;QACJ,CAAC;IACH,CAAC;IAED,MAAM,eAAe,GAAG,CAAC,CAAC,MAAM,CAAC;QAC/B,QAAQ;QACR,KAAK;QACL,KAAK;KACN,CAAC,CAAC;IAEH,OAAO,eAAe,CAAC;AACzB,CAAC,CAAC","sourcesContent":["import { i } from './schema.ts';\nimport { DataAttrDef, InstantSchemaDef } from './schemaTypes.ts';\n\nexport const parseSchemaFromJSON = (\n s: any,\n): InstantSchemaDef<any, any, any> => {\n // Parse entities\n const entities: Record<string, any> = {};\n\n for (const [entityName, entityInfo] of Object.entries(s.entities)) {\n const entityDef = entityInfo as any;\n const attrs: Record<string, any> = {};\n\n // Parse attributes\n for (const [attrName, attrInfo] of Object.entries(entityDef.attrs)) {\n const attrDef = attrInfo as any;\n let attr: DataAttrDef<any, any, any>;\n\n // Create the appropriate attribute type\n switch (attrDef.valueType) {\n case 'string':\n attr = i.string();\n break;\n case 'number':\n attr = i.number();\n break;\n case 'boolean':\n attr = i.boolean();\n break;\n case 'date':\n attr = i.date();\n break;\n case 'json':\n attr = i.json();\n break;\n default:\n attr = i.json();\n }\n\n // Apply modifiers\n if (!attrDef.required) {\n attr = attr.optional();\n }\n\n if (attrDef.config?.indexed) {\n attr = attr.indexed();\n }\n\n if (attrDef.config?.unique) {\n attr = attr.unique();\n }\n\n attrs[attrName] = attr;\n }\n\n entities[entityName] = i.entity(attrs);\n }\n\n // Parse links\n const links: Record<string, any> = s.links || {};\n\n // Parse rooms\n const rooms: Record<string, any> = {};\n\n if (s.rooms) {\n for (const [roomName, roomInfo] of Object.entries(s.rooms)) {\n const roomDef = roomInfo as any;\n\n // Parse presence\n const presenceAttrs: Record<string, any> = {};\n for (const [attrName, attrInfo] of Object.entries(\n roomDef.presence.attrs,\n )) {\n const attrDef = attrInfo as any;\n let attr: DataAttrDef<any, any, any>;\n\n switch (attrDef.valueType) {\n case 'string':\n attr = i.string();\n break;\n case 'number':\n attr = i.number();\n break;\n case 'boolean':\n attr = i.boolean();\n break;\n case 'date':\n attr = i.date();\n break;\n case 'json':\n attr = i.json();\n break;\n default:\n attr = i.json();\n }\n\n if (!attrDef.required) {\n attr = attr.optional();\n }\n\n if (attrDef.config?.indexed) {\n attr = attr.indexed();\n }\n\n if (attrDef.config?.unique) {\n attr = attr.unique();\n }\n\n presenceAttrs[attrName] = attr;\n }\n\n // Parse topics\n const topics: Record<string, any> = {};\n if (roomDef.topics) {\n for (const [topicName, topicInfo] of Object.entries(roomDef.topics)) {\n const topicDef = topicInfo as any;\n const topicAttrs: Record<string, any> = {};\n\n for (const [attrName, attrInfo] of Object.entries(topicDef.attrs)) {\n const attrDef = attrInfo as any;\n let attr: DataAttrDef<any, any, any>;\n\n switch (attrDef.valueType) {\n case 'string':\n attr = i.string();\n break;\n case 'number':\n attr = i.number();\n break;\n case 'boolean':\n attr = i.boolean();\n break;\n case 'date':\n attr = i.date();\n break;\n case 'json':\n attr = i.json();\n break;\n default:\n attr = i.json();\n }\n\n if (!attrDef.required) {\n attr = attr.optional();\n }\n\n if (attrDef.config?.indexed) {\n attr = attr.indexed();\n }\n\n if (attrDef.config?.unique) {\n attr = attr.unique();\n }\n\n topicAttrs[attrName] = attr;\n }\n\n topics[topicName] = i.entity(topicAttrs);\n }\n }\n\n rooms[roomName] = {\n presence: i.entity(presenceAttrs),\n topics,\n };\n }\n }\n\n const resultingSchema = i.schema({\n entities,\n links,\n rooms,\n });\n\n return resultingSchema;\n};\n"]}
@@ -1,44 +0,0 @@
1
- export const createInstantRouteHandler = (config: {
2
- appId: string;
3
- apiURI?: string;
4
- }) => {
5
- async function handleUserSync(req: Request) {
6
- const body = await req.json();
7
- if (body.user && body.user.refresh_token) {
8
- return new Response('sync', {
9
- headers: {
10
- // 7 day expiry
11
- 'Set-Cookie': `instant_user=${JSON.stringify(body.user)}; Path=/; HttpOnly; Secure; SameSite=Strict; Max-Age=604800`,
12
- },
13
- });
14
- } else {
15
- return new Response('sync', {
16
- headers: {
17
- // remove the cookie (some browsers)
18
- 'Set-Cookie': `instant_user=; Path=/; HttpOnly; Secure; SameSite=Strict; Max-Age=-1`,
19
- },
20
- });
21
- }
22
- }
23
-
24
- return {
25
- GET: async (_req: Request) => {
26
- return new Response('Method not allowed', {
27
- status: 405,
28
- statusText: 'Method Not Allowed',
29
- });
30
- },
31
- POST: async (req: Request) => {
32
- const url = new URL(req.url);
33
- const pathname = url.pathname;
34
- const route = pathname.split('/')[pathname.split('/').length - 1];
35
- switch (route) {
36
- case 'sync-auth':
37
- return await handleUserSync(req);
38
- }
39
- return new Response('Route not found', {
40
- status: 404,
41
- });
42
- },
43
- };
44
- };
package/src/framework.ts DELETED
@@ -1,281 +0,0 @@
1
- import {
2
- coerceQuery,
3
- InstantCoreDatabase,
4
- InstantDBAttr,
5
- weakHash,
6
- } from './index.ts';
7
- import * as s from './store.js';
8
- import instaql from './instaql.js';
9
- import { RuleParams } from './schemaTypes.ts';
10
-
11
- export const isServer = typeof window === 'undefined' || 'Deno' in globalThis;
12
-
13
- export type FrameworkConfig = {
14
- token?: string | null;
15
- db: InstantCoreDatabase<any, any>;
16
- };
17
-
18
- type QueryPromise =
19
- | {
20
- type: 'http';
21
- triples: any;
22
- attrs: any;
23
- queryHash: any;
24
- query: any;
25
- pageInfo?: any;
26
- }
27
- | {
28
- type: 'session';
29
- queryResult: any;
30
- };
31
-
32
- export class FrameworkClient {
33
- private params: FrameworkConfig;
34
- private db: InstantCoreDatabase<any, any>;
35
- public resultMap: Map<
36
- string,
37
- {
38
- status: 'pending' | 'success' | 'error';
39
- type: 'http' | 'session';
40
- promise?: Promise<QueryPromise> | null;
41
- data?: any;
42
- error?: any;
43
- }
44
- > = new Map();
45
-
46
- private queryResolvedCallbacks: ((result: {
47
- triples: any;
48
- attrs: any;
49
- queryHash: any;
50
- query: any;
51
- pageInfo?: any;
52
- }) => void)[] = [];
53
-
54
- constructor(params: FrameworkConfig) {
55
- this.params = params;
56
- this.db = params.db;
57
- this.resultMap = new Map<
58
- string,
59
- {
60
- type: 'http' | 'session';
61
- status: 'pending' | 'success' | 'error';
62
- promise?: Promise<QueryPromise>;
63
- data?: any;
64
- error?: any;
65
- }
66
- >();
67
- }
68
-
69
- public subscribe = (
70
- callback: (result: {
71
- triples: any;
72
- attrs: any;
73
- queryHash: string;
74
- pageInfo?: any;
75
- }) => void,
76
- ) => {
77
- this.queryResolvedCallbacks.push(callback);
78
- };
79
-
80
- // Runs on the client when ssr gets html script tags
81
- public addQueryResult = (queryKey: string, value: any) => {
82
- this.resultMap.set(queryKey, {
83
- type: value.type,
84
- status: 'success',
85
- data: value,
86
- promise: null,
87
- error: null,
88
- });
89
- // send the result to the client
90
- if (!isServer) {
91
- // make sure the attrs are there to create stores
92
- if (!this.db._reactor.attrs) {
93
- this.db._reactor._setAttrs(value.attrs);
94
- }
95
- this.db._reactor._addQueryData(
96
- value.query,
97
- value,
98
- !!this.db._reactor.config.schema,
99
- );
100
- }
101
- };
102
-
103
- public query = (
104
- _query: any,
105
- opts?: {
106
- ruleParams: RuleParams;
107
- },
108
- ): {
109
- type: 'http' | 'session';
110
- status: 'pending' | 'success' | 'error';
111
- promise?: Promise<QueryPromise>;
112
- data?: any;
113
- error?: any;
114
- } => {
115
- const { hash, query } = this.hashQuery(_query, opts);
116
-
117
- if (this.db._reactor.status === 'authenticated') {
118
- const promise = this.db.queryOnce(_query, opts);
119
- let entry = {
120
- status: 'pending' as 'pending' | 'success' | 'error',
121
- type: 'session' as 'http' | 'session',
122
- data: undefined as any,
123
- error: undefined as any,
124
- promise: promise as any,
125
- };
126
- promise.then((result) => {
127
- entry.status = 'success';
128
- entry.data = result;
129
- entry.promise = null;
130
- });
131
- promise.catch((error) => {
132
- entry.status = 'error';
133
- entry.error = error;
134
- entry.promise = null;
135
- });
136
- return entry as any;
137
- }
138
-
139
- const promise = this.getTriplesAndAttrsForQuery(query);
140
- let entry = {
141
- status: 'pending' as 'pending' | 'success' | 'error',
142
- type: 'http' as 'http' | 'session',
143
- data: undefined as any,
144
- error: undefined as any,
145
- promise: promise as any,
146
- };
147
-
148
- promise.then((result) => {
149
- entry.status = 'success';
150
- entry.data = result;
151
- entry.promise = null;
152
- });
153
- promise.catch((error) => {
154
- entry.status = 'error';
155
- entry.error = error;
156
- entry.promise = null;
157
- });
158
-
159
- promise.then((result) => {
160
- this.queryResolvedCallbacks.forEach((callback) => {
161
- callback({
162
- queryHash: hash,
163
- query: query,
164
- attrs: result.attrs,
165
- triples: result.triples,
166
- pageInfo: result.pageInfo,
167
- });
168
- });
169
- });
170
-
171
- this.resultMap.set(hash, entry);
172
- return entry;
173
- };
174
-
175
- public getExistingResultForQuery = (
176
- _query: any,
177
- opts?: {
178
- ruleParams: RuleParams;
179
- },
180
- ) => {
181
- const { hash } = this.hashQuery(_query, opts);
182
- return this.resultMap.get(hash);
183
- };
184
-
185
- public completeIsomorphic = (
186
- query: any,
187
- triples: any[],
188
- attrs: InstantDBAttr[],
189
- pageInfo?: any,
190
- ) => {
191
- const attrMap = {};
192
- attrs.forEach((attr) => {
193
- attrMap[attr.id] = attr;
194
- });
195
-
196
- const enableCardinalityInference =
197
- Boolean(this.db?._reactor?.config?.schema) &&
198
- ('cardinalityInference' in this.db?._reactor?.config
199
- ? Boolean(this.db?._reactor.config?.cardinalityInference)
200
- : true);
201
-
202
- const store = s.createStore(
203
- attrMap,
204
- triples,
205
- enableCardinalityInference,
206
- null,
207
- this.params.db._reactor.config.useDateObjects || false,
208
- );
209
- const resp = instaql(
210
- { store: store, pageInfo: pageInfo, aggregate: undefined },
211
- query,
212
- );
213
- return resp;
214
- };
215
-
216
- public hashQuery = (
217
- _query: any,
218
- opts?: {
219
- ruleParams: RuleParams;
220
- },
221
- ): { hash: string; query: any } => {
222
- if (_query && opts && 'ruleParams' in opts) {
223
- _query = { $$ruleParams: opts['ruleParams'], ..._query };
224
- }
225
- const query = _query ? coerceQuery(_query) : null;
226
- return { hash: weakHash(query), query: query };
227
- };
228
-
229
- public getTriplesAndAttrsForQuery = async (
230
- query: any,
231
- ): Promise<{
232
- triples: any[];
233
- attrs: InstantDBAttr[];
234
- query: any;
235
- queryHash: string;
236
- type: 'http';
237
- pageInfo?: any;
238
- }> => {
239
- const response = await fetch(
240
- `${this.db._reactor.config.apiURI}/runtime/query`,
241
- {
242
- method: 'POST',
243
- headers: {
244
- 'app-id': this.params.db._reactor.config.appId,
245
- 'Content-Type': 'application/json',
246
- Authorization: this.params.token
247
- ? `Bearer ${this.params.token}`
248
- : undefined,
249
- } as Record<string, string>,
250
- body: JSON.stringify({
251
- query: query,
252
- }),
253
- },
254
- );
255
-
256
- if (!response.ok) {
257
- throw new Error('Error getting triples from server');
258
- }
259
-
260
- const data = await response.json();
261
-
262
- const attrs = data?.attrs;
263
- if (!attrs) {
264
- throw new Error('No attrs');
265
- }
266
-
267
- // TODO: make safer
268
- const triples = data.result?.[0].data?.['datalog-result']?.['join-rows'][0];
269
-
270
- const pageInfo = data.result?.[0]?.data?.['page-info'];
271
-
272
- return {
273
- attrs,
274
- triples,
275
- type: 'http',
276
- queryHash: this.hashQuery(query).hash,
277
- query,
278
- pageInfo,
279
- };
280
- };
281
- }
@@ -1,176 +0,0 @@
1
- import { i } from './schema.ts';
2
- import { DataAttrDef, InstantSchemaDef } from './schemaTypes.ts';
3
-
4
- export const parseSchemaFromJSON = (
5
- s: any,
6
- ): InstantSchemaDef<any, any, any> => {
7
- // Parse entities
8
- const entities: Record<string, any> = {};
9
-
10
- for (const [entityName, entityInfo] of Object.entries(s.entities)) {
11
- const entityDef = entityInfo as any;
12
- const attrs: Record<string, any> = {};
13
-
14
- // Parse attributes
15
- for (const [attrName, attrInfo] of Object.entries(entityDef.attrs)) {
16
- const attrDef = attrInfo as any;
17
- let attr: DataAttrDef<any, any, any>;
18
-
19
- // Create the appropriate attribute type
20
- switch (attrDef.valueType) {
21
- case 'string':
22
- attr = i.string();
23
- break;
24
- case 'number':
25
- attr = i.number();
26
- break;
27
- case 'boolean':
28
- attr = i.boolean();
29
- break;
30
- case 'date':
31
- attr = i.date();
32
- break;
33
- case 'json':
34
- attr = i.json();
35
- break;
36
- default:
37
- attr = i.json();
38
- }
39
-
40
- // Apply modifiers
41
- if (!attrDef.required) {
42
- attr = attr.optional();
43
- }
44
-
45
- if (attrDef.config?.indexed) {
46
- attr = attr.indexed();
47
- }
48
-
49
- if (attrDef.config?.unique) {
50
- attr = attr.unique();
51
- }
52
-
53
- attrs[attrName] = attr;
54
- }
55
-
56
- entities[entityName] = i.entity(attrs);
57
- }
58
-
59
- // Parse links
60
- const links: Record<string, any> = s.links || {};
61
-
62
- // Parse rooms
63
- const rooms: Record<string, any> = {};
64
-
65
- if (s.rooms) {
66
- for (const [roomName, roomInfo] of Object.entries(s.rooms)) {
67
- const roomDef = roomInfo as any;
68
-
69
- // Parse presence
70
- const presenceAttrs: Record<string, any> = {};
71
- for (const [attrName, attrInfo] of Object.entries(
72
- roomDef.presence.attrs,
73
- )) {
74
- const attrDef = attrInfo as any;
75
- let attr: DataAttrDef<any, any, any>;
76
-
77
- switch (attrDef.valueType) {
78
- case 'string':
79
- attr = i.string();
80
- break;
81
- case 'number':
82
- attr = i.number();
83
- break;
84
- case 'boolean':
85
- attr = i.boolean();
86
- break;
87
- case 'date':
88
- attr = i.date();
89
- break;
90
- case 'json':
91
- attr = i.json();
92
- break;
93
- default:
94
- attr = i.json();
95
- }
96
-
97
- if (!attrDef.required) {
98
- attr = attr.optional();
99
- }
100
-
101
- if (attrDef.config?.indexed) {
102
- attr = attr.indexed();
103
- }
104
-
105
- if (attrDef.config?.unique) {
106
- attr = attr.unique();
107
- }
108
-
109
- presenceAttrs[attrName] = attr;
110
- }
111
-
112
- // Parse topics
113
- const topics: Record<string, any> = {};
114
- if (roomDef.topics) {
115
- for (const [topicName, topicInfo] of Object.entries(roomDef.topics)) {
116
- const topicDef = topicInfo as any;
117
- const topicAttrs: Record<string, any> = {};
118
-
119
- for (const [attrName, attrInfo] of Object.entries(topicDef.attrs)) {
120
- const attrDef = attrInfo as any;
121
- let attr: DataAttrDef<any, any, any>;
122
-
123
- switch (attrDef.valueType) {
124
- case 'string':
125
- attr = i.string();
126
- break;
127
- case 'number':
128
- attr = i.number();
129
- break;
130
- case 'boolean':
131
- attr = i.boolean();
132
- break;
133
- case 'date':
134
- attr = i.date();
135
- break;
136
- case 'json':
137
- attr = i.json();
138
- break;
139
- default:
140
- attr = i.json();
141
- }
142
-
143
- if (!attrDef.required) {
144
- attr = attr.optional();
145
- }
146
-
147
- if (attrDef.config?.indexed) {
148
- attr = attr.indexed();
149
- }
150
-
151
- if (attrDef.config?.unique) {
152
- attr = attr.unique();
153
- }
154
-
155
- topicAttrs[attrName] = attr;
156
- }
157
-
158
- topics[topicName] = i.entity(topicAttrs);
159
- }
160
- }
161
-
162
- rooms[roomName] = {
163
- presence: i.entity(presenceAttrs),
164
- topics,
165
- };
166
- }
167
- }
168
-
169
- const resultingSchema = i.schema({
170
- entities,
171
- links,
172
- rooms,
173
- });
174
-
175
- return resultingSchema;
176
- };