@instantdb/core 0.22.88-experimental.drewh-ssr.20250906484.1 → 0.22.88-experimental.drewh-entity-caching.20250906397.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 (60) hide show
  1. package/__tests__/src/instaql.bench.js +80 -2
  2. package/__tests__/src/instaqlCache.test.ts +78 -0
  3. package/dist/commonjs/Reactor.d.ts +1 -13
  4. package/dist/commonjs/Reactor.d.ts.map +1 -1
  5. package/dist/commonjs/Reactor.js +5 -64
  6. package/dist/commonjs/Reactor.js.map +1 -1
  7. package/dist/commonjs/index.d.ts +1 -5
  8. package/dist/commonjs/index.d.ts.map +1 -1
  9. package/dist/commonjs/index.js +1 -7
  10. package/dist/commonjs/index.js.map +1 -1
  11. package/dist/commonjs/store.d.ts +1 -1
  12. package/dist/commonjs/store.d.ts.map +1 -1
  13. package/dist/commonjs/store.js +5 -0
  14. package/dist/commonjs/store.js.map +1 -1
  15. package/dist/esm/Reactor.d.ts +1 -13
  16. package/dist/esm/Reactor.d.ts.map +1 -1
  17. package/dist/esm/Reactor.js +5 -64
  18. package/dist/esm/Reactor.js.map +1 -1
  19. package/dist/esm/index.d.ts +1 -5
  20. package/dist/esm/index.d.ts.map +1 -1
  21. package/dist/esm/index.js +2 -5
  22. package/dist/esm/index.js.map +1 -1
  23. package/dist/esm/store.d.ts +1 -1
  24. package/dist/esm/store.d.ts.map +1 -1
  25. package/dist/esm/store.js +5 -0
  26. package/dist/esm/store.js.map +1 -1
  27. package/dist/standalone/index.js +1107 -1404
  28. package/dist/standalone/index.umd.cjs +3 -3
  29. package/package.json +2 -2
  30. package/src/Reactor.js +9 -74
  31. package/src/index.ts +0 -9
  32. package/src/store.ts +6 -0
  33. package/__tests__/src/serializeSchema.test.ts +0 -123
  34. package/dist/commonjs/createRouteHandler.d.ts +0 -8
  35. package/dist/commonjs/createRouteHandler.d.ts.map +0 -1
  36. package/dist/commonjs/createRouteHandler.js +0 -57
  37. package/dist/commonjs/createRouteHandler.js.map +0 -1
  38. package/dist/commonjs/framework.d.ts +0 -77
  39. package/dist/commonjs/framework.d.ts.map +0 -1
  40. package/dist/commonjs/framework.js +0 -199
  41. package/dist/commonjs/framework.js.map +0 -1
  42. package/dist/commonjs/parseSchemaFromJSON.d.ts +0 -3
  43. package/dist/commonjs/parseSchemaFromJSON.d.ts.map +0 -1
  44. package/dist/commonjs/parseSchemaFromJSON.js +0 -148
  45. package/dist/commonjs/parseSchemaFromJSON.js.map +0 -1
  46. package/dist/esm/createRouteHandler.d.ts +0 -8
  47. package/dist/esm/createRouteHandler.d.ts.map +0 -1
  48. package/dist/esm/createRouteHandler.js +0 -53
  49. package/dist/esm/createRouteHandler.js.map +0 -1
  50. package/dist/esm/framework.d.ts +0 -77
  51. package/dist/esm/framework.d.ts.map +0 -1
  52. package/dist/esm/framework.js +0 -159
  53. package/dist/esm/framework.js.map +0 -1
  54. package/dist/esm/parseSchemaFromJSON.d.ts +0 -3
  55. package/dist/esm/parseSchemaFromJSON.d.ts.map +0 -1
  56. package/dist/esm/parseSchemaFromJSON.js +0 -144
  57. package/dist/esm/parseSchemaFromJSON.js.map +0 -1
  58. package/src/createRouteHandler.ts +0 -44
  59. package/src/framework.ts +0 -281
  60. package/src/parseSchemaFromJSON.ts +0 -176
@@ -1,159 +0,0 @@
1
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
2
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
3
- return new (P || (P = Promise))(function (resolve, reject) {
4
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
5
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
6
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
7
- step((generator = generator.apply(thisArg, _arguments || [])).next());
8
- });
9
- };
10
- import { coerceQuery, weakHash, } from "./index.js";
11
- import * as s from './store.js';
12
- import instaql from './instaql.js';
13
- export const isServer = typeof window === 'undefined' || 'Deno' in globalThis;
14
- export class FrameworkClient {
15
- constructor(params) {
16
- this.resultMap = new Map();
17
- this.queryResolvedCallbacks = [];
18
- this.subscribe = (callback) => {
19
- this.queryResolvedCallbacks.push(callback);
20
- };
21
- // Runs on the client when ssr gets html script tags
22
- this.addQueryResult = (queryKey, value) => {
23
- this.resultMap.set(queryKey, {
24
- type: value.type,
25
- status: 'success',
26
- data: value,
27
- promise: null,
28
- error: null,
29
- });
30
- // send the result to the client
31
- if (!isServer) {
32
- // make sure the attrs are there to create stores
33
- if (!this.db._reactor.attrs) {
34
- this.db._reactor._setAttrs(value.attrs);
35
- }
36
- this.db._reactor._addQueryData(value.query, value, !!this.db._reactor.config.schema);
37
- }
38
- };
39
- this.query = (_query, opts) => {
40
- const { hash, query } = this.hashQuery(_query, opts);
41
- if (this.db._reactor.status === 'authenticated') {
42
- const promise = this.db.queryOnce(_query, opts);
43
- let entry = {
44
- status: 'pending',
45
- type: 'session',
46
- data: undefined,
47
- error: undefined,
48
- promise: promise,
49
- };
50
- promise.then((result) => {
51
- entry.status = 'success';
52
- entry.data = result;
53
- entry.promise = null;
54
- });
55
- promise.catch((error) => {
56
- entry.status = 'error';
57
- entry.error = error;
58
- entry.promise = null;
59
- });
60
- return entry;
61
- }
62
- const promise = this.getTriplesAndAttrsForQuery(query);
63
- let entry = {
64
- status: 'pending',
65
- type: 'http',
66
- data: undefined,
67
- error: undefined,
68
- promise: promise,
69
- };
70
- promise.then((result) => {
71
- entry.status = 'success';
72
- entry.data = result;
73
- entry.promise = null;
74
- });
75
- promise.catch((error) => {
76
- entry.status = 'error';
77
- entry.error = error;
78
- entry.promise = null;
79
- });
80
- promise.then((result) => {
81
- this.queryResolvedCallbacks.forEach((callback) => {
82
- callback({
83
- queryHash: hash,
84
- query: query,
85
- attrs: result.attrs,
86
- triples: result.triples,
87
- pageInfo: result.pageInfo,
88
- });
89
- });
90
- });
91
- this.resultMap.set(hash, entry);
92
- return entry;
93
- };
94
- this.getExistingResultForQuery = (_query, opts) => {
95
- const { hash } = this.hashQuery(_query, opts);
96
- return this.resultMap.get(hash);
97
- };
98
- this.completeIsomorphic = (query, triples, attrs, pageInfo) => {
99
- var _a, _b, _c, _d, _e, _f, _g;
100
- const attrMap = {};
101
- attrs.forEach((attr) => {
102
- attrMap[attr.id] = attr;
103
- });
104
- const enableCardinalityInference = Boolean((_c = (_b = (_a = this.db) === null || _a === void 0 ? void 0 : _a._reactor) === null || _b === void 0 ? void 0 : _b.config) === null || _c === void 0 ? void 0 : _c.schema) &&
105
- ('cardinalityInference' in ((_e = (_d = this.db) === null || _d === void 0 ? void 0 : _d._reactor) === null || _e === void 0 ? void 0 : _e.config)
106
- ? Boolean((_g = (_f = this.db) === null || _f === void 0 ? void 0 : _f._reactor.config) === null || _g === void 0 ? void 0 : _g.cardinalityInference)
107
- : true);
108
- const store = s.createStore(attrMap, triples, enableCardinalityInference, null, this.params.db._reactor.config.useDateObjects || false);
109
- const resp = instaql({ store: store, pageInfo: pageInfo, aggregate: undefined }, query);
110
- return resp;
111
- };
112
- this.hashQuery = (_query, opts) => {
113
- if (_query && opts && 'ruleParams' in opts) {
114
- _query = Object.assign({ $$ruleParams: opts['ruleParams'] }, _query);
115
- }
116
- const query = _query ? coerceQuery(_query) : null;
117
- return { hash: weakHash(query), query: query };
118
- };
119
- this.getTriplesAndAttrsForQuery = (query) => __awaiter(this, void 0, void 0, function* () {
120
- var _a, _b, _c, _d, _e, _f;
121
- const response = yield fetch(`${this.db._reactor.config.apiURI}/runtime/framework/query`, {
122
- method: 'POST',
123
- headers: {
124
- 'app-id': this.params.db._reactor.config.appId,
125
- 'Content-Type': 'application/json',
126
- Authorization: this.params.token
127
- ? `Bearer ${this.params.token}`
128
- : undefined,
129
- },
130
- body: JSON.stringify({
131
- query: query,
132
- }),
133
- });
134
- if (!response.ok) {
135
- throw new Error('Error getting triples from server');
136
- }
137
- const data = yield response.json();
138
- const attrs = data === null || data === void 0 ? void 0 : data.attrs;
139
- if (!attrs) {
140
- throw new Error('No attrs');
141
- }
142
- // TODO: make safer
143
- const triples = (_c = (_b = (_a = data.result) === null || _a === void 0 ? void 0 : _a[0].data) === null || _b === void 0 ? void 0 : _b['datalog-result']) === null || _c === void 0 ? void 0 : _c['join-rows'][0];
144
- const pageInfo = (_f = (_e = (_d = data.result) === null || _d === void 0 ? void 0 : _d[0]) === null || _e === void 0 ? void 0 : _e.data) === null || _f === void 0 ? void 0 : _f['page-info'];
145
- return {
146
- attrs,
147
- triples,
148
- type: 'http',
149
- queryHash: this.hashQuery(query).hash,
150
- query,
151
- pageInfo,
152
- };
153
- });
154
- this.params = params;
155
- this.db = params.db;
156
- this.resultMap = new Map();
157
- }
158
- }
159
- //# sourceMappingURL=framework.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"framework.js","sourceRoot":"","sources":["../../src/framework.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EACL,WAAW,EAGX,QAAQ,GACT,MAAM,YAAY,CAAC;AACpB,OAAO,KAAK,CAAC,MAAM,YAAY,CAAC;AAChC,OAAO,OAAO,MAAM,cAAc,CAAC;AAGnC,MAAM,CAAC,MAAM,QAAQ,GAAG,OAAO,MAAM,KAAK,WAAW,IAAI,MAAM,IAAI,UAAU,CAAC;AAqB9E,MAAM,OAAO,eAAe;IAsB1B,YAAY,MAAuB;QAnB5B,cAAS,GASZ,IAAI,GAAG,EAAE,CAAC;QAEN,2BAAsB,GAMd,EAAE,CAAC;QAiBZ,cAAS,GAAG,CACjB,QAKU,EACV,EAAE;YACF,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC7C,CAAC,CAAC;QAEF,oDAAoD;QAC7C,mBAAc,GAAG,CAAC,QAAgB,EAAE,KAAU,EAAE,EAAE;YACvD,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,QAAQ,EAAE;gBAC3B,IAAI,EAAE,KAAK,CAAC,IAAI;gBAChB,MAAM,EAAE,SAAS;gBACjB,IAAI,EAAE,KAAK;gBACX,OAAO,EAAE,IAAI;gBACb,KAAK,EAAE,IAAI;aACZ,CAAC,CAAC;YACH,gCAAgC;YAChC,IAAI,CAAC,QAAQ,EAAE,CAAC;gBACd,iDAAiD;gBACjD,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC;oBAC5B,IAAI,CAAC,EAAE,CAAC,QAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;gBAC1C,CAAC;gBACD,IAAI,CAAC,EAAE,CAAC,QAAQ,CAAC,aAAa,CAC5B,KAAK,CAAC,KAAK,EACX,KAAK,EACL,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC,MAAM,CACjC,CAAC;YACJ,CAAC;QACH,CAAC,CAAC;QAEK,UAAK,GAAG,CACb,MAAW,EACX,IAEC,EAOD,EAAE;YACF,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;YAErD,IAAI,IAAI,CAAC,EAAE,CAAC,QAAQ,CAAC,MAAM,KAAK,eAAe,EAAE,CAAC;gBAChD,MAAM,OAAO,GAAG,IAAI,CAAC,EAAE,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;gBAChD,IAAI,KAAK,GAAG;oBACV,MAAM,EAAE,SAA4C;oBACpD,IAAI,EAAE,SAA+B;oBACrC,IAAI,EAAE,SAAgB;oBACtB,KAAK,EAAE,SAAgB;oBACvB,OAAO,EAAE,OAAc;iBACxB,CAAC;gBACF,OAAO,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE;oBACtB,KAAK,CAAC,MAAM,GAAG,SAAS,CAAC;oBACzB,KAAK,CAAC,IAAI,GAAG,MAAM,CAAC;oBACpB,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC;gBACvB,CAAC,CAAC,CAAC;gBACH,OAAO,CAAC,KAAK,CAAC,CAAC,KAAK,EAAE,EAAE;oBACtB,KAAK,CAAC,MAAM,GAAG,OAAO,CAAC;oBACvB,KAAK,CAAC,KAAK,GAAG,KAAK,CAAC;oBACpB,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC;gBACvB,CAAC,CAAC,CAAC;gBACH,OAAO,KAAY,CAAC;YACtB,CAAC;YAED,MAAM,OAAO,GAAG,IAAI,CAAC,0BAA0B,CAAC,KAAK,CAAC,CAAC;YACvD,IAAI,KAAK,GAAG;gBACV,MAAM,EAAE,SAA4C;gBACpD,IAAI,EAAE,MAA4B;gBAClC,IAAI,EAAE,SAAgB;gBACtB,KAAK,EAAE,SAAgB;gBACvB,OAAO,EAAE,OAAc;aACxB,CAAC;YAEF,OAAO,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE;gBACtB,KAAK,CAAC,MAAM,GAAG,SAAS,CAAC;gBACzB,KAAK,CAAC,IAAI,GAAG,MAAM,CAAC;gBACpB,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC;YACvB,CAAC,CAAC,CAAC;YACH,OAAO,CAAC,KAAK,CAAC,CAAC,KAAK,EAAE,EAAE;gBACtB,KAAK,CAAC,MAAM,GAAG,OAAO,CAAC;gBACvB,KAAK,CAAC,KAAK,GAAG,KAAK,CAAC;gBACpB,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC;YACvB,CAAC,CAAC,CAAC;YAEH,OAAO,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE;gBACtB,IAAI,CAAC,sBAAsB,CAAC,OAAO,CAAC,CAAC,QAAQ,EAAE,EAAE;oBAC/C,QAAQ,CAAC;wBACP,SAAS,EAAE,IAAI;wBACf,KAAK,EAAE,KAAK;wBACZ,KAAK,EAAE,MAAM,CAAC,KAAK;wBACnB,OAAO,EAAE,MAAM,CAAC,OAAO;wBACvB,QAAQ,EAAE,MAAM,CAAC,QAAQ;qBAC1B,CAAC,CAAC;gBACL,CAAC,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;YAEH,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;YAChC,OAAO,KAAK,CAAC;QACf,CAAC,CAAC;QAEK,8BAAyB,GAAG,CACjC,MAAW,EACX,IAEC,EACD,EAAE;YACF,MAAM,EAAE,IAAI,EAAE,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;YAC9C,OAAO,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QAClC,CAAC,CAAC;QAEK,uBAAkB,GAAG,CAC1B,KAAU,EACV,OAAc,EACd,KAAsB,EACtB,QAAc,EACd,EAAE;;YACF,MAAM,OAAO,GAAG,EAAE,CAAC;YACnB,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;gBACrB,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC;YAC1B,CAAC,CAAC,CAAC;YAEH,MAAM,0BAA0B,GAC9B,OAAO,CAAC,MAAA,MAAA,MAAA,IAAI,CAAC,EAAE,0CAAE,QAAQ,0CAAE,MAAM,0CAAE,MAAM,CAAC;gBAC1C,CAAC,sBAAsB,KAAI,MAAA,MAAA,IAAI,CAAC,EAAE,0CAAE,QAAQ,0CAAE,MAAM,CAAA;oBAClD,CAAC,CAAC,OAAO,CAAC,MAAA,MAAA,IAAI,CAAC,EAAE,0CAAE,QAAQ,CAAC,MAAM,0CAAE,oBAAoB,CAAC;oBACzD,CAAC,CAAC,IAAI,CAAC,CAAC;YAEZ,MAAM,KAAK,GAAG,CAAC,CAAC,WAAW,CACzB,OAAO,EACP,OAAO,EACP,0BAA0B,EAC1B,IAAI,EACJ,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC,cAAc,IAAI,KAAK,CACvD,CAAC;YACF,MAAM,IAAI,GAAG,OAAO,CAClB,EAAE,KAAK,EAAE,KAAK,EAAE,QAAQ,EAAE,QAAQ,EAAE,SAAS,EAAE,SAAS,EAAE,EAC1D,KAAK,CACN,CAAC;YACF,OAAO,IAAI,CAAC;QACd,CAAC,CAAC;QAEK,cAAS,GAAG,CACjB,MAAW,EACX,IAEC,EAC6B,EAAE;YAChC,IAAI,MAAM,IAAI,IAAI,IAAI,YAAY,IAAI,IAAI,EAAE,CAAC;gBAC3C,MAAM,mBAAK,YAAY,EAAE,IAAI,CAAC,YAAY,CAAC,IAAK,MAAM,CAAE,CAAC;YAC3D,CAAC;YACD,MAAM,KAAK,GAAG,MAAM,CAAC,CAAC,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;YAClD,OAAO,EAAE,IAAI,EAAE,QAAQ,CAAC,KAAK,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC;QACjD,CAAC,CAAC;QAEK,+BAA0B,GAAG,CAClC,KAAU,EAQT,EAAE;;YACH,MAAM,QAAQ,GAAG,MAAM,KAAK,CAC1B,GAAG,IAAI,CAAC,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC,MAAM,0BAA0B,EAC3D;gBACE,MAAM,EAAE,MAAM;gBACd,OAAO,EAAE;oBACP,QAAQ,EAAE,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC,KAAK;oBAC9C,cAAc,EAAE,kBAAkB;oBAClC,aAAa,EAAE,IAAI,CAAC,MAAM,CAAC,KAAK;wBAC9B,CAAC,CAAC,UAAU,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE;wBAC/B,CAAC,CAAC,SAAS;iBACY;gBAC3B,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC;oBACnB,KAAK,EAAE,KAAK;iBACb,CAAC;aACH,CACF,CAAC;YAEF,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE,CAAC;gBACjB,MAAM,IAAI,KAAK,CAAC,mCAAmC,CAAC,CAAC;YACvD,CAAC;YAED,MAAM,IAAI,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAC;YAEnC,MAAM,KAAK,GAAG,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,KAAK,CAAC;YAC1B,IAAI,CAAC,KAAK,EAAE,CAAC;gBACX,MAAM,IAAI,KAAK,CAAC,UAAU,CAAC,CAAC;YAC9B,CAAC;YAED,mBAAmB;YACnB,MAAM,OAAO,GAAG,MAAA,MAAA,MAAA,IAAI,CAAC,MAAM,0CAAG,CAAC,EAAE,IAAI,0CAAG,gBAAgB,CAAC,0CAAG,WAAW,EAAE,CAAC,CAAC,CAAC;YAE5E,MAAM,QAAQ,GAAG,MAAA,MAAA,MAAA,IAAI,CAAC,MAAM,0CAAG,CAAC,CAAC,0CAAE,IAAI,0CAAG,WAAW,CAAC,CAAC;YAEvD,OAAO;gBACL,KAAK;gBACL,OAAO;gBACP,IAAI,EAAE,MAAM;gBACZ,SAAS,EAAE,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,IAAI;gBACrC,KAAK;gBACL,QAAQ;aACT,CAAC;QACJ,CAAC,CAAA,CAAC;QAjOA,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,EAAE,GAAG,MAAM,CAAC,EAAE,CAAC;QACpB,IAAI,CAAC,SAAS,GAAG,IAAI,GAAG,EASrB,CAAC;IACN,CAAC;CAsNF","sourcesContent":["import {\n coerceQuery,\n InstantCoreDatabase,\n InstantDBAttr,\n weakHash,\n} from './index.ts';\nimport * as s from './store.js';\nimport instaql from './instaql.js';\nimport { RuleParams } from './schemaTypes.ts';\n\nexport const isServer = typeof window === 'undefined' || 'Deno' in globalThis;\n\nexport type FrameworkConfig = {\n token?: string | null;\n db: InstantCoreDatabase<any, any>;\n};\n\ntype QueryPromise =\n | {\n type: 'http';\n triples: any;\n attrs: any;\n queryHash: any;\n query: any;\n pageInfo?: any;\n }\n | {\n type: 'session';\n queryResult: any;\n };\n\nexport class FrameworkClient {\n private params: FrameworkConfig;\n private db: InstantCoreDatabase<any, any>;\n public resultMap: Map<\n string,\n {\n status: 'pending' | 'success' | 'error';\n type: 'http' | 'session';\n promise?: Promise<QueryPromise> | null;\n data?: any;\n error?: any;\n }\n > = new Map();\n\n private queryResolvedCallbacks: ((result: {\n triples: any;\n attrs: any;\n queryHash: any;\n query: any;\n pageInfo?: any;\n }) => void)[] = [];\n\n constructor(params: FrameworkConfig) {\n this.params = params;\n this.db = params.db;\n this.resultMap = new Map<\n string,\n {\n type: 'http' | 'session';\n status: 'pending' | 'success' | 'error';\n promise?: Promise<QueryPromise>;\n data?: any;\n error?: any;\n }\n >();\n }\n\n public subscribe = (\n callback: (result: {\n triples: any;\n attrs: any;\n queryHash: string;\n pageInfo?: any;\n }) => void,\n ) => {\n this.queryResolvedCallbacks.push(callback);\n };\n\n // Runs on the client when ssr gets html script tags\n public addQueryResult = (queryKey: string, value: any) => {\n this.resultMap.set(queryKey, {\n type: value.type,\n status: 'success',\n data: value,\n promise: null,\n error: null,\n });\n // send the result to the client\n if (!isServer) {\n // make sure the attrs are there to create stores\n if (!this.db._reactor.attrs) {\n this.db._reactor._setAttrs(value.attrs);\n }\n this.db._reactor._addQueryData(\n value.query,\n value,\n !!this.db._reactor.config.schema,\n );\n }\n };\n\n public query = (\n _query: any,\n opts?: {\n ruleParams: RuleParams;\n },\n ): {\n type: 'http' | 'session';\n status: 'pending' | 'success' | 'error';\n promise?: Promise<QueryPromise>;\n data?: any;\n error?: any;\n } => {\n const { hash, query } = this.hashQuery(_query, opts);\n\n if (this.db._reactor.status === 'authenticated') {\n const promise = this.db.queryOnce(_query, opts);\n let entry = {\n status: 'pending' as 'pending' | 'success' | 'error',\n type: 'session' as 'http' | 'session',\n data: undefined as any,\n error: undefined as any,\n promise: promise as any,\n };\n promise.then((result) => {\n entry.status = 'success';\n entry.data = result;\n entry.promise = null;\n });\n promise.catch((error) => {\n entry.status = 'error';\n entry.error = error;\n entry.promise = null;\n });\n return entry as any;\n }\n\n const promise = this.getTriplesAndAttrsForQuery(query);\n let entry = {\n status: 'pending' as 'pending' | 'success' | 'error',\n type: 'http' as 'http' | 'session',\n data: undefined as any,\n error: undefined as any,\n promise: promise as any,\n };\n\n promise.then((result) => {\n entry.status = 'success';\n entry.data = result;\n entry.promise = null;\n });\n promise.catch((error) => {\n entry.status = 'error';\n entry.error = error;\n entry.promise = null;\n });\n\n promise.then((result) => {\n this.queryResolvedCallbacks.forEach((callback) => {\n callback({\n queryHash: hash,\n query: query,\n attrs: result.attrs,\n triples: result.triples,\n pageInfo: result.pageInfo,\n });\n });\n });\n\n this.resultMap.set(hash, entry);\n return entry;\n };\n\n public getExistingResultForQuery = (\n _query: any,\n opts?: {\n ruleParams: RuleParams;\n },\n ) => {\n const { hash } = this.hashQuery(_query, opts);\n return this.resultMap.get(hash);\n };\n\n public completeIsomorphic = (\n query: any,\n triples: any[],\n attrs: InstantDBAttr[],\n pageInfo?: any,\n ) => {\n const attrMap = {};\n attrs.forEach((attr) => {\n attrMap[attr.id] = attr;\n });\n\n const enableCardinalityInference =\n Boolean(this.db?._reactor?.config?.schema) &&\n ('cardinalityInference' in this.db?._reactor?.config\n ? Boolean(this.db?._reactor.config?.cardinalityInference)\n : true);\n\n const store = s.createStore(\n attrMap,\n triples,\n enableCardinalityInference,\n null,\n this.params.db._reactor.config.useDateObjects || false,\n );\n const resp = instaql(\n { store: store, pageInfo: pageInfo, aggregate: undefined },\n query,\n );\n return resp;\n };\n\n public hashQuery = (\n _query: any,\n opts?: {\n ruleParams: RuleParams;\n },\n ): { hash: string; query: any } => {\n if (_query && opts && 'ruleParams' in opts) {\n _query = { $$ruleParams: opts['ruleParams'], ..._query };\n }\n const query = _query ? coerceQuery(_query) : null;\n return { hash: weakHash(query), query: query };\n };\n\n public getTriplesAndAttrsForQuery = async (\n query: any,\n ): Promise<{\n triples: any[];\n attrs: InstantDBAttr[];\n query: any;\n queryHash: string;\n type: 'http';\n pageInfo?: any;\n }> => {\n const response = await fetch(\n `${this.db._reactor.config.apiURI}/runtime/framework/query`,\n {\n method: 'POST',\n headers: {\n 'app-id': this.params.db._reactor.config.appId,\n 'Content-Type': 'application/json',\n Authorization: this.params.token\n ? `Bearer ${this.params.token}`\n : undefined,\n } as Record<string, string>,\n body: JSON.stringify({\n query: query,\n }),\n },\n );\n\n if (!response.ok) {\n throw new Error('Error getting triples from server');\n }\n\n const data = await response.json();\n\n const attrs = data?.attrs;\n if (!attrs) {\n throw new Error('No attrs');\n }\n\n // TODO: make safer\n const triples = data.result?.[0].data?.['datalog-result']?.['join-rows'][0];\n\n const pageInfo = data.result?.[0]?.data?.['page-info'];\n\n return {\n attrs,\n triples,\n type: 'http',\n queryHash: this.hashQuery(query).hash,\n query,\n pageInfo,\n };\n };\n}\n"]}
@@ -1,3 +0,0 @@
1
- import { InstantSchemaDef } from './schemaTypes.ts';
2
- export declare const parseSchemaFromJSON: (s: any) => InstantSchemaDef<any, any, any>;
3
- //# sourceMappingURL=parseSchemaFromJSON.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"parseSchemaFromJSON.d.ts","sourceRoot":"","sources":["../../src/parseSchemaFromJSON.ts"],"names":[],"mappings":"AACA,OAAO,EAAe,gBAAgB,EAAE,MAAM,kBAAkB,CAAC;AAEjE,eAAO,MAAM,mBAAmB,GAC9B,GAAG,GAAG,KACL,gBAAgB,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CA0KhC,CAAC"}
@@ -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/framework/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
- }