@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.
- package/dist/commonjs/Reactor.d.ts +1 -13
- package/dist/commonjs/Reactor.d.ts.map +1 -1
- package/dist/commonjs/Reactor.js +5 -64
- package/dist/commonjs/Reactor.js.map +1 -1
- package/dist/commonjs/index.d.ts +1 -5
- package/dist/commonjs/index.d.ts.map +1 -1
- package/dist/commonjs/index.js +1 -7
- package/dist/commonjs/index.js.map +1 -1
- package/dist/esm/Reactor.d.ts +1 -13
- package/dist/esm/Reactor.d.ts.map +1 -1
- package/dist/esm/Reactor.js +5 -64
- package/dist/esm/Reactor.js.map +1 -1
- package/dist/esm/index.d.ts +1 -5
- package/dist/esm/index.d.ts.map +1 -1
- package/dist/esm/index.js +2 -5
- package/dist/esm/index.js.map +1 -1
- package/dist/standalone/index.js +1372 -1672
- package/dist/standalone/index.umd.cjs +3 -3
- package/package.json +2 -2
- package/src/Reactor.js +9 -74
- package/src/index.ts +0 -9
- package/__tests__/src/serializeSchema.test.ts +0 -123
- package/dist/commonjs/createRouteHandler.d.ts +0 -8
- package/dist/commonjs/createRouteHandler.d.ts.map +0 -1
- package/dist/commonjs/createRouteHandler.js +0 -57
- package/dist/commonjs/createRouteHandler.js.map +0 -1
- package/dist/commonjs/framework.d.ts +0 -77
- package/dist/commonjs/framework.d.ts.map +0 -1
- package/dist/commonjs/framework.js +0 -199
- package/dist/commonjs/framework.js.map +0 -1
- package/dist/commonjs/parseSchemaFromJSON.d.ts +0 -3
- package/dist/commonjs/parseSchemaFromJSON.d.ts.map +0 -1
- package/dist/commonjs/parseSchemaFromJSON.js +0 -148
- package/dist/commonjs/parseSchemaFromJSON.js.map +0 -1
- package/dist/esm/createRouteHandler.d.ts +0 -8
- package/dist/esm/createRouteHandler.d.ts.map +0 -1
- package/dist/esm/createRouteHandler.js +0 -53
- package/dist/esm/createRouteHandler.js.map +0 -1
- package/dist/esm/framework.d.ts +0 -77
- package/dist/esm/framework.d.ts.map +0 -1
- package/dist/esm/framework.js +0 -159
- package/dist/esm/framework.js.map +0 -1
- package/dist/esm/parseSchemaFromJSON.d.ts +0 -3
- package/dist/esm/parseSchemaFromJSON.d.ts.map +0 -1
- package/dist/esm/parseSchemaFromJSON.js +0 -144
- package/dist/esm/parseSchemaFromJSON.js.map +0 -1
- package/src/createRouteHandler.ts +0 -44
- package/src/framework.ts +0 -281
- 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":"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","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
|
-
};
|