solid-logic 1.3.14-9c8003a0 → 1.3.14-d30bbbcf

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.
@@ -65,11 +65,35 @@ var solid_namespace_1 = __importDefault(require("solid-namespace"));
65
65
  var $rdf = __importStar(require("rdflib"));
66
66
  var uri_1 = require("../util/uri");
67
67
  var solidLogicSingleton_1 = require("../logic/solidLogicSingleton");
68
+ // import { ensureLoadedPreferences } from '../logic/logic'
69
+ var discoveryLogic_1 = require("../discovery/discoveryLogic");
68
70
  exports.ns = (0, solid_namespace_1.default)($rdf);
71
+ var store = solidLogicSingleton_1.solidLogicSingleton.store;
72
+ function ensureLoadedPreferences(context) {
73
+ return __awaiter(this, void 0, void 0, function () {
74
+ var _a, _b;
75
+ return __generator(this, function (_c) {
76
+ switch (_c.label) {
77
+ case 0:
78
+ if (!context.me)
79
+ throw new Error('@@ ensureLoadedPreferences: no user specified');
80
+ _a = context;
81
+ return [4 /*yield*/, (0, discoveryLogic_1.loadProfile)(store, context.me)];
82
+ case 1:
83
+ _a.publicProfile = _c.sent();
84
+ _b = context;
85
+ return [4 /*yield*/, (0, discoveryLogic_1.loadPreferences)(store, context.me)];
86
+ case 2:
87
+ _b.preferencesFile = _c.sent();
88
+ return [2 /*return*/, context];
89
+ }
90
+ });
91
+ });
92
+ }
69
93
  /**
70
94
  * Resolves with the same context, outputting
71
95
  * output: index.public, index.private
72
- *
96
+ * @@ This is a very bizare function
73
97
  * @see https://github.com/solid/solid/blob/main/proposals/data-discovery.md#discoverability
74
98
  */
75
99
  function loadIndex(context, isPublic) {
@@ -86,8 +110,8 @@ function loadIndex(context, isPublic) {
86
110
  case 1:
87
111
  indexes = _a.sent();
88
112
  context.index = context.index || {};
89
- context.index.private = indexes.private || context.index.private;
90
- context.index.public = indexes.public || context.index.public;
113
+ context.index.private = indexes.private.concat(context.index.private);
114
+ context.index.public = indexes.public.concat(context.index.public);
91
115
  return [2 /*return*/, context];
92
116
  }
93
117
  });
@@ -96,21 +120,36 @@ function loadIndex(context, isPublic) {
96
120
  exports.loadIndex = loadIndex;
97
121
  function loadTypeIndexes(context) {
98
122
  return __awaiter(this, void 0, void 0, function () {
99
- var indexes;
123
+ var error_1, indexes, error_2;
100
124
  var _this = this;
101
125
  return __generator(this, function (_a) {
102
126
  switch (_a.label) {
103
- case 0: return [4 /*yield*/, solidLogicSingleton_1.solidLogicSingleton.loadIndexes(context.me, context.publicProfile || null, context.preferencesFile || null,
104
- // async (err: Error) => widgets.complain(context, err.message)
105
- function (err) { return __awaiter(_this, void 0, void 0, function () { return __generator(this, function (_a) {
106
- return [2 /*return*/, debug.warn(err.message)];
107
- }); }); })];
127
+ case 0:
128
+ _a.trys.push([0, 2, , 3]);
129
+ return [4 /*yield*/, (0, discoveryLogic_1.loadPreferences)(solidLogicSingleton_1.solidLogicSingleton.store, context.me)];
108
130
  case 1:
131
+ _a.sent();
132
+ return [3 /*break*/, 3];
133
+ case 2:
134
+ error_1 = _a.sent();
135
+ debug.warn(error_1.message);
136
+ return [3 /*break*/, 3];
137
+ case 3:
138
+ _a.trys.push([3, 5, , 6]);
139
+ return [4 /*yield*/, solidLogicSingleton_1.solidLogicSingleton.loadIndexes(context.me, context.publicProfile || null, context.preferencesFile || null)];
140
+ case 4:
109
141
  indexes = _a.sent();
110
142
  context.index = context.index || {};
111
143
  context.index.private = indexes.private || context.index.private;
112
144
  context.index.public = indexes.public || context.index.public;
113
145
  return [2 /*return*/, context];
146
+ case 5:
147
+ error_2 = _a.sent();
148
+ (function (error) { return __awaiter(_this, void 0, void 0, function () { return __generator(this, function (_a) {
149
+ return [2 /*return*/, debug.warn(error.message)];
150
+ }); }); });
151
+ return [3 /*break*/, 6];
152
+ case 6: return [2 /*return*/];
114
153
  }
115
154
  });
116
155
  });
@@ -120,14 +159,18 @@ exports.loadTypeIndexes = loadTypeIndexes;
120
159
  * Resolves with the same context, outputting
121
160
  * @see https://github.com/solid/solid/blob/main/proposals/data-discovery.md#discoverability
122
161
  */
123
- function ensureTypeIndexes(context) {
162
+ function ensureTypeIndexes(context, agent) {
124
163
  return __awaiter(this, void 0, void 0, function () {
125
164
  return __generator(this, function (_a) {
126
165
  switch (_a.label) {
127
- case 0: return [4 /*yield*/, ensureOneTypeIndex(context, true)];
166
+ case 0:
167
+ if (!context.me) {
168
+ throw new Error("ensureTypeIndexes: @@ no user");
169
+ }
170
+ return [4 /*yield*/, ensureOneTypeIndex(context, true, agent)];
128
171
  case 1:
129
172
  _a.sent();
130
- return [4 /*yield*/, ensureOneTypeIndex(context, false)];
173
+ return [4 /*yield*/, ensureOneTypeIndex(context, false, agent)];
131
174
  case 2:
132
175
  _a.sent();
133
176
  return [2 /*return*/, context];
@@ -144,7 +187,7 @@ exports.ensureTypeIndexes = ensureTypeIndexes;
144
187
  * Adds its output to the context
145
188
  * @see https://github.com/solid/solid/blob/main/proposals/data-discovery.md#discoverability
146
189
  */
147
- function ensureOneTypeIndex(context, isPublic) {
190
+ function ensureOneTypeIndex(context, isPublic, agent) {
148
191
  return __awaiter(this, void 0, void 0, function () {
149
192
  function makeIndexIfNecessary(context, isPublic) {
150
193
  return __awaiter(this, void 0, void 0, function () {
@@ -175,10 +218,16 @@ function ensureOneTypeIndex(context, isPublic) {
175
218
  switch (_a.label) {
176
219
  case 0:
177
220
  relevant = isPublic ? context.publicProfile : context.preferencesFile;
221
+ if (!relevant)
222
+ alert('@@@@ relevent null');
178
223
  visibility = isPublic ? 'public' : 'private';
179
224
  context.index = context.index || {};
180
225
  context.index[visibility] = context.index[visibility] || [];
181
226
  if (!(context.index[visibility].length === 0)) return [3 /*break*/, 6];
227
+ if (!store.updater.editable(relevant)) {
228
+ debug.log("Not adding new type index as ".concat(relevant, " is not editable"));
229
+ return [2 /*return*/];
230
+ }
182
231
  newIndex = (0, rdflib_1.sym)("".concat(relevant.dir().uri + visibility, "TypeIndex.ttl"));
183
232
  debug.log("Linking to new fresh type index ".concat(newIndex));
184
233
  if (!confirm("OK to create a new empty index file at ".concat(newIndex, ", overwriting anything that is now there?"))) {
@@ -227,29 +276,41 @@ function ensureOneTypeIndex(context, isPublic) {
227
276
  });
228
277
  });
229
278
  } // makeIndexIfNecessary
230
- var error_1;
279
+ var context2, relevant, pp, error_3;
231
280
  return __generator(this, function (_a) {
232
281
  switch (_a.label) {
233
- case 0:
234
- _a.trys.push([0, 2, , 4]);
235
- return [4 /*yield*/, loadIndex(context, isPublic)];
282
+ case 0: return [4 /*yield*/, ensureLoadedPreferences(context)];
236
283
  case 1:
284
+ context2 = _a.sent();
285
+ if (!context2.publicProfile)
286
+ throw new Error("@@ type index: no publicProfile");
287
+ if (!context2.preferencesFile)
288
+ throw new Error("@@ type index: no preferencesFile for profile ".concat(context2.publicProfile));
289
+ relevant = isPublic ? context2.publicProfile : context2.preferencesFile;
290
+ _a.label = 2;
291
+ case 2:
292
+ _a.trys.push([2, 5, , 7]);
293
+ return [4 /*yield*/, loadIndex(context2, isPublic)];
294
+ case 3:
237
295
  _a.sent();
238
- if (context.index) {
239
- debug.log("ensureOneTypeIndex: Type index exists already ".concat(isPublic
240
- ? context.index.public[0]
241
- : context.index.private[0]));
296
+ pp = isPublic ? 'public' : 'private';
297
+ if (context2.index && context2.index[pp] && context2.index[pp].length > 0) {
298
+ debug.log("ensureOneTypeIndex: Type index exists already ".concat(context2.index[pp]));
299
+ return [2 /*return*/, context2];
242
300
  }
243
- return [2 /*return*/, context];
244
- case 2:
245
- error_1 = _a.sent();
246
- return [4 /*yield*/, makeIndexIfNecessary(context, isPublic)
247
- // widgets.complain(context, 'calling loadIndex:' + error)
301
+ return [4 /*yield*/, makeIndexIfNecessary(context2, isPublic)];
302
+ case 4:
303
+ _a.sent();
304
+ return [3 /*break*/, 7];
305
+ case 5:
306
+ error_3 = _a.sent();
307
+ return [4 /*yield*/, makeIndexIfNecessary(context2, isPublic)
308
+ // widgets.complain(context2, 'calling loadIndex:' + error)
248
309
  ];
249
- case 3:
310
+ case 6:
250
311
  _a.sent();
251
- return [3 /*break*/, 4];
252
- case 4: return [2 /*return*/];
312
+ return [3 /*break*/, 7];
313
+ case 7: return [2 /*return*/];
253
314
  }
254
315
  });
255
316
  });
@@ -258,12 +319,13 @@ function ensureOneTypeIndex(context, isPublic) {
258
319
  * Register a new app in a type index
259
320
  * used in chat in bookmark.js (solid-ui)
260
321
  */
261
- function registerInTypeIndex(context, instance, theClass, isPublic) {
322
+ function registerInTypeIndex(context, instance, theClass, isPublic, agent // Defaults to current user
323
+ ) {
262
324
  return __awaiter(this, void 0, void 0, function () {
263
325
  var indexes, index, registration, ins, e_2;
264
326
  return __generator(this, function (_a) {
265
327
  switch (_a.label) {
266
- case 0: return [4 /*yield*/, ensureOneTypeIndex(context, isPublic)];
328
+ case 0: return [4 /*yield*/, ensureOneTypeIndex(context, isPublic, agent)];
267
329
  case 1:
268
330
  _a.sent();
269
331
  if (!context.index) {
@@ -1 +1 @@
1
- {"version":3,"file":"typeIndexLogic.js","sourceRoot":"","sources":["../../src/typeIndex/typeIndexLogic.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"typeIndexLogic.js","sourceRoot":"","sources":["../../src/typeIndex/typeIndexLogic.ts"],"names":[],"mappings":"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"}
@@ -7,10 +7,10 @@ export declare const ACL_LINK: NamedNode;
7
7
  export declare class UtilityLogic {
8
8
  store: LiveStore;
9
9
  ns: SolidNamespace;
10
- fetcher: {
10
+ underlyingFetch: {
11
11
  fetch: (url: string, options?: any) => any;
12
12
  };
13
- constructor(store: LiveStore, ns: SolidNamespace, fetcher: {
13
+ constructor(store: LiveStore, ns: SolidNamespace, underlyingFetch: {
14
14
  fetch: (url: string, options?: any) => any;
15
15
  });
16
16
  findAclDocUrl(url: string): Promise<string>;
@@ -1 +1 @@
1
- {"version":3,"file":"UtilityLogic.d.ts","sourceRoot":"","sources":["../../src/util/UtilityLogic.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAkB,SAAS,EAAE,MAAM,QAAQ,CAAC;AAC9D,OAAO,EAAE,cAAc,EAAE,MAAM,UAAU,CAAC;AAE1C,eAAO,MAAM,QAAQ,WAEpB,CAAC;AAEF;;GAEG;AACH,qBAAa,YAAY;IACvB,KAAK,EAAE,SAAS,CAAC;IACjB,EAAE,EAAE,cAAc,CAAC;IACnB,OAAO,EAAE;QAAE,KAAK,EAAE,CAAC,GAAG,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,KAAK,GAAG,CAAA;KAAE,CAAC;gBAE5C,KAAK,EAAE,SAAS,EAAE,EAAE,EAAE,cAAc,EAAE,OAAO,EAAE;QAAE,KAAK,EAAE,CAAC,GAAG,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,KAAK,GAAG,CAAA;KAAE;IAMnG,aAAa,CAAC,GAAG,EAAE,MAAM;IAWzB,mBAAmB,CAAC,OAAO,EAAE;QACjC,UAAU,EAAE,MAAM,CAAC;QACnB,SAAS,EAAE,MAAM,CAAC;QAClB,aAAa,CAAC,EAAE,MAAM,CAAC;QACvB,YAAY,CAAC,EAAE,MAAM,CAAC;QACtB,MAAM,EAAE,MAAM,CAAA;KACf;IAsCK,OAAO,CAAC,GAAG,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC;IAe5C,WAAW,CAAC,GAAG,EAAE,MAAM;IAIjB,eAAe,CAAC,GAAG,EAAE,MAAM;IAmBjC,oBAAoB,CAAC,aAAa,EAAE,SAAS,GAAG,SAAS,EAAE;IAWrD,mBAAmB,CAAC,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;IAO5D,eAAe,CAAC,GAAG,EAAE,MAAM;IAgBjC,UAAU;IAIV,aAAa,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI;CAQ1C"}
1
+ {"version":3,"file":"UtilityLogic.d.ts","sourceRoot":"","sources":["../../src/util/UtilityLogic.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAkB,SAAS,EAAE,MAAM,QAAQ,CAAC;AAC9D,OAAO,EAAE,cAAc,EAAE,MAAM,UAAU,CAAC;AAE1C,eAAO,MAAM,QAAQ,WAEpB,CAAC;AAEF;;GAEG;AACH,qBAAa,YAAY;IACvB,KAAK,EAAE,SAAS,CAAC;IACjB,EAAE,EAAE,cAAc,CAAC;IACnB,eAAe,EAAE;QAAE,KAAK,EAAE,CAAC,GAAG,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,KAAK,GAAG,CAAA;KAAE,CAAC;gBAEpD,KAAK,EAAE,SAAS,EAAE,EAAE,EAAE,cAAc,EAAE,eAAe,EAAE;QAAE,KAAK,EAAE,CAAC,GAAG,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,KAAK,GAAG,CAAA;KAAE;IAM3G,aAAa,CAAC,GAAG,EAAE,MAAM;IAWzB,mBAAmB,CAAC,OAAO,EAAE;QACjC,UAAU,EAAE,MAAM,CAAC;QACnB,SAAS,EAAE,MAAM,CAAC;QAClB,aAAa,CAAC,EAAE,MAAM,CAAC;QACvB,YAAY,CAAC,EAAE,MAAM,CAAC;QACtB,MAAM,EAAE,MAAM,CAAA;KACf;IAsCK,OAAO,CAAC,GAAG,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC;IAe5C,WAAW,CAAC,GAAG,EAAE,MAAM;IAIjB,eAAe,CAAC,GAAG,EAAE,MAAM;IAmBjC,oBAAoB,CAAC,aAAa,EAAE,SAAS,GAAG,SAAS,EAAE;IAWrD,mBAAmB,CAAC,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;IAO5D,eAAe,CAAC,GAAG,EAAE,MAAM;IAgBjC,UAAU;IAIV,aAAa,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI;CAQ1C"}
@@ -43,10 +43,10 @@ exports.ACL_LINK = (0, rdflib_1.sym)("http://www.iana.org/assignments/link-relat
43
43
  * Utility-related logic
44
44
  */
45
45
  var UtilityLogic = /** @class */ (function () {
46
- function UtilityLogic(store, ns, fetcher) {
46
+ function UtilityLogic(store, ns, underlyingFetch) {
47
47
  this.store = store;
48
48
  this.ns = ns;
49
- this.fetcher = fetcher;
49
+ this.underlyingFetch = underlyingFetch;
50
50
  }
51
51
  UtilityLogic.prototype.findAclDocUrl = function (url) {
52
52
  var _a;
@@ -105,7 +105,7 @@ var UtilityLogic = /** @class */ (function () {
105
105
  return [4 /*yield*/, this.findAclDocUrl(options.target)];
106
106
  case 1:
107
107
  aclDocUrl = _a.sent();
108
- return [2 /*return*/, this.fetcher.fetch(aclDocUrl, {
108
+ return [2 /*return*/, this.underlyingFetch.fetch(aclDocUrl, {
109
109
  method: 'PUT',
110
110
  body: str,
111
111
  headers: [
@@ -151,7 +151,7 @@ var UtilityLogic = /** @class */ (function () {
151
151
  if (!this.isContainer(url)) {
152
152
  throw new Error("Not a container URL ".concat(url));
153
153
  }
154
- return [4 /*yield*/, this.fetcher.fetch(url, {
154
+ return [4 /*yield*/, this.underlyingFetch.fetch(url, {
155
155
  method: "PUT",
156
156
  headers: {
157
157
  "Content-Type": "text/turtle",
@@ -204,7 +204,7 @@ var UtilityLogic = /** @class */ (function () {
204
204
  return [4 /*yield*/, this.findAclDocUrl(url)];
205
205
  case 1:
206
206
  aclDocUrl = _a.sent();
207
- return [4 /*yield*/, this.fetcher.fetch(aclDocUrl, { method: "DELETE" })];
207
+ return [4 /*yield*/, this.underlyingFetch.fetch(aclDocUrl, { method: "DELETE" })];
208
208
  case 2:
209
209
  _a.sent();
210
210
  return [4 /*yield*/, this.getContainerMembers(url)];
@@ -214,7 +214,7 @@ var UtilityLogic = /** @class */ (function () {
214
214
  case 4:
215
215
  _a.sent();
216
216
  _a.label = 5;
217
- case 5: return [2 /*return*/, this.fetcher.fetch(url, { method: "DELETE" })];
217
+ case 5: return [2 /*return*/, this.underlyingFetch.fetch(url, { method: "DELETE" })];
218
218
  case 6:
219
219
  e_1 = _a.sent();
220
220
  return [3 /*break*/, 7];
@@ -1 +1 @@
1
- {"version":3,"file":"UtilityLogic.js","sourceRoot":"","sources":["../../src/util/UtilityLogic.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"UtilityLogic.js","sourceRoot":"","sources":["../../src/util/UtilityLogic.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "solid-logic",
3
- "version": "1.3.14-9c8003a0",
3
+ "version": "1.3.14-d30bbbcf",
4
4
  "description": "Core business logic of Solid OS",
5
5
  "main": "lib/index.js",
6
6
  "scripts": {
@@ -43,7 +43,7 @@
43
43
  },
44
44
  "dependencies": {
45
45
  "@inrupt/solid-client-authn-browser": "^1.11.5",
46
- "rdflib": "^2.2.17",
46
+ "rdflib": "^2.2.18",
47
47
  "solid-namespace": "^0.5.2"
48
48
  }
49
49
  }
@@ -0,0 +1,90 @@
1
+ import { NamedNode, Namespace, LiveStore } from "rdflib";
2
+
3
+ type TypeIndex = { label: string, index: NamedNode, agent: NamedNode } ;
4
+
5
+ const ns ={
6
+ solid: Namespace('http://www.w3.org/ns/solid/terms#'),
7
+ space: Namespace('http://www.w3.org/ns/pim/space#')
8
+ }
9
+
10
+ export async function loadProfile(store: LiveStore, user) {
11
+ if (!user) {
12
+ throw new Error(`loadProfile: no user given.`)
13
+ }
14
+ try {
15
+ await store.fetcher.load(user.doc())
16
+ } catch (err) {
17
+ throw new Error(`Unable to load profile of user <${user}>: ${err}`)
18
+ }
19
+ return user.doc()
20
+ }
21
+
22
+ export async function loadPreferences(store: LiveStore, user): Promise <NamedNode | undefined > {
23
+ const profile = await loadProfile(store as LiveStore, user)
24
+ const preferencesFile = store.any(user, ns.space('preferencesFile'), undefined, profile)
25
+ if (!preferencesFile) {
26
+ // throw new Error(`USer ${user} has no pointer in profile to preferences file.`)
27
+ return undefined
28
+ }
29
+ try {
30
+ store.fetcher.load(preferencesFile as NamedNode)
31
+ } catch (err) { // Mabeb a permission propblem or origin problem
32
+ return undefined
33
+ // throw new Error(`Unable to load preferences file ${preferencesFile} of user <${user}>: ${err}`)
34
+ }
35
+ return preferencesFile as NamedNode
36
+ }
37
+
38
+ export async function loadTypeIndexesFor(store: LiveStore, user:NamedNode): Promise<Array<TypeIndex>> {
39
+ if (!user) throw new Error(`loadTypeIndexesFor: No user given`)
40
+ const profile = await loadProfile(store, user)
41
+ const publicTypeIndex = store.any(user, ns.solid('publicTypeIndex'), undefined, profile)
42
+ if (publicTypeIndex) {
43
+ try {
44
+ await store.fetcher.load(publicTypeIndex as NamedNode)
45
+ } catch {
46
+ // never mind
47
+ }
48
+ }
49
+ const pub = publicTypeIndex ? [ { label: 'public', index: publicTypeIndex as NamedNode, agent: user } ] : []
50
+
51
+ const preferencesFile = await loadPreferences(store, user)
52
+ if (preferencesFile) { // watch out - can be in either as spec was not clear
53
+ const privateTypeIndexes = store.each(user, ns.solid('privateTypeIndex'), undefined, preferencesFile as NamedNode)
54
+ .concat(store.each(user, ns.solid('privateTypeIndex'), undefined, profile))
55
+ const priv = privateTypeIndexes.length > 0 ? [ { label: 'priSo @@@@@vate', index: privateTypeIndexes[0] as NamedNode, agent: user } ] : []
56
+ return pub.concat(priv)
57
+ }
58
+ return pub
59
+ }
60
+
61
+ export async function loadCommunityTypeIndexes (store:LiveStore, user:NamedNode): Promise<TypeIndex[][]> {
62
+ const preferencesFile = await loadPreferences(store, user)
63
+ if (preferencesFile) {
64
+ const communities = store.each(user, ns.solid('community'), undefined, preferencesFile as NamedNode)
65
+ const communityTypeIndexesPromise = communities.map(async community => await loadTypeIndexesFor(store, community as NamedNode))
66
+ const result1 = Promise.all(communityTypeIndexesPromise)
67
+ // const result2 = Promise.all(result1)
68
+ // const flat = result2.flat()
69
+ return result1
70
+ // const communityTypeIndexes = await Promise.all(communityTypeIndexesPromise)
71
+ /*
72
+ let result = [] as TypeIndex[]
73
+ for(const community of communities) {
74
+ result = result.concat(await loadTypeIndexesFor(store, community as NamedNode)) as TypeIndex[] // @@ how oto make functional with async?
75
+ }
76
+ */
77
+ // return communityTypeIndexesPromise.resolve()
78
+ }
79
+ return []
80
+ }
81
+
82
+ export async function loadAllTypeIndexes (store:LiveStore, user:NamedNode) {
83
+ return (await loadTypeIndexesFor(store, user)).concat((await loadCommunityTypeIndexes(store, user)).flat())
84
+ }
85
+
86
+ /*
87
+ export async function getAppInstances (store:LiveStore, klass: NamedNode) {
88
+
89
+ }
90
+ */
@@ -44,7 +44,7 @@ export class InboxLogic {
44
44
  return ourInbox;
45
45
  }
46
46
  async markAsRead(url: string, date: Date) {
47
- const downloaded = await this.util.fetcher.fetch(url);
47
+ const downloaded = await this.util.underlyingFetch.fetch(url);
48
48
  if (downloaded.status !== 200) {
49
49
  throw new Error(`Not OK! ${url}`);
50
50
  }
@@ -56,7 +56,7 @@ export class InboxLogic {
56
56
  [ 'Content-Type', downloaded.headers.get('Content-Type') || 'application/octet-stream' ]
57
57
  ]
58
58
  };
59
- const uploaded = await this.util.fetcher.fetch(archiveUrl, options);
59
+ const uploaded = await this.util.underlyingFetch.fetch(archiveUrl, options);
60
60
  if (uploaded.status.toString()[0] === '2') {
61
61
  await this.store.fetcher?._fetch(url, {
62
62
  method: 'DELETE'
package/src/index.ts CHANGED
@@ -12,12 +12,22 @@ export {
12
12
  setACLUserPublic,
13
13
  genACLText
14
14
  } from './acl/aclLogic'
15
+
15
16
  export {
16
17
  ensureTypeIndexes,
17
18
  loadTypeIndexes,
18
19
  registerInTypeIndex,
19
20
  loadIndex
20
21
  } from './typeIndex/typeIndexLogic'
22
+
23
+ export {
24
+ loadProfile,
25
+ loadPreferences,
26
+ loadTypeIndexesFor,
27
+ loadCommunityTypeIndexes,
28
+ loadAllTypeIndexes
29
+ } from './discovery/discoveryLogic'
30
+
21
31
  export { SolidLogic } from './logic/SolidLogic'
22
32
  export { offlineTestID, appContext } from './authn/authUtil'
23
33
  export { ACL_LINK } from './util/UtilityLogic'
@@ -9,7 +9,12 @@ import { AuthnLogic, SolidNamespace } from "../types";
9
9
  import * as debug from "../util/debug";
10
10
  import { UtilityLogic } from "../util/UtilityLogic";
11
11
  import { CrossOriginForbiddenError, FetchError, NotFoundError, SameOriginForbiddenError, UnauthorizedError } from "./CustomError";
12
-
12
+ /*
13
+ ** It is important to distinquish `fetch`, a function provided by the browser
14
+ ** and `Fetcher`, a helper object for the rdflib Store which turns it
15
+ ** into a `ConnectedStore` or a `LiveStore`. A Fetcher object is
16
+ ** available at store.fetcher, and `fetch` function at `store.fetcher._fetch`,
17
+ */
13
18
 
14
19
  const ns: SolidNamespace = solidNamespace(rdf);
15
20
 
@@ -25,7 +30,7 @@ export class SolidLogic {
25
30
 
26
31
  store: LiveStore;
27
32
  me: string | undefined;
28
- fetcher: { fetch: (url: string, options?: any) => any };
33
+ underlyingFetch: { fetch: (url: string, options?: any) => any };
29
34
 
30
35
  chat: ChatLogic;
31
36
  profile: ProfileLogic;
@@ -33,52 +38,56 @@ export class SolidLogic {
33
38
  util: UtilityLogic;
34
39
 
35
40
  constructor(fetcher: { fetch: (url: any, requestInit: any) => any }, session: Session) {
41
+ // would xpect to be able to do it this way: but get TypeError: Failed to execute 'fetch' on 'Window': Illegal invocation status: 999
42
+ // this.store = new rdf.LiveStore({})
43
+ // this.store.fetcher._fetch = fetch
44
+
36
45
  this.store = rdf.graph() as LiveStore; // Make a Quad store
37
- rdf.fetcher(this.store, fetcher); // Attach a web I/O module, store.fetcher
46
+ rdf.fetcher(this.store, fetch); // Attach a web I/O module, store.fetcher
38
47
  this.store.updater = new rdf.UpdateManager(this.store); // Add real-time live updates store.updater
48
+
39
49
  this.store.features = [] // disable automatic node merging on store load
40
50
  this.cache = {
41
51
  profileDocument: {},
42
52
  preferencesFile: {},
43
53
  };
44
- this.fetcher = fetcher;
54
+ this.underlyingFetch = { fetch: fetch };
45
55
  this.authn = new SolidAuthnLogic(session);
46
56
  debug.log('SolidAuthnLogic initialized')
47
57
  this.profile = new ProfileLogic(this.store, ns, this.authn);
48
58
  this.chat = new ChatLogic(this.store, ns, this.profile);
49
- this.util = new UtilityLogic(this.store, ns, this.fetcher);
59
+ this.util = new UtilityLogic(this.store, ns, this.underlyingFetch);
50
60
  }
51
61
 
52
62
  findAclDocUrl(url: string) {
53
63
  return this.util.findAclDocUrl(url);
54
64
  }
55
65
 
56
- loadDoc(doc: NamedNode): Promise<void> {
57
- return this.util.loadDoc(doc);
58
- }
59
-
60
66
  async loadProfile(me: NamedNode): Promise<NamedNode> {
61
- // console.log('loadProfile', me)
67
+ /*
68
+ // console.log('loadProfile cache ', this.cache)
62
69
  if (this.cache.profileDocument[me.value]) {
63
70
  return this.cache.profileDocument[me.value];
64
- }
65
- let profileDocument;
71
+ } @@ just use the cache in the store
72
+ */
73
+ console.log('loadProfile me ', me)
74
+ const profileDocument = me.doc()
66
75
  try {
67
- profileDocument = me.doc();
68
- await this.loadDoc(profileDocument);
69
- return profileDocument;
76
+ await this.store.fetcher.load(profileDocument);
77
+ return profileDocument;
70
78
  } catch (err) {
71
- const message = `Logged in but cannot load profile ${profileDocument} : ${err}`;
79
+ const message = `Cannot load profile ${profileDocument} : ${err}`;
72
80
  throw new Error(message);
73
81
  }
74
82
  }
75
83
 
76
84
  async loadPreferences(me: NamedNode): Promise<NamedNode> {
77
- // console.log('loadPreferences', me)
85
+ console.log('loadPreferences cache ', this.cache)
78
86
  if (this.cache.preferencesFile[me.value]) {
79
87
  return this.cache.preferencesFile[me.value];
80
88
  }
81
- const preferencesFile = this.store.any(me, ns.space("preferencesFile"));
89
+ await this.loadProfile(me) // Load pointer to pref file
90
+ const preferencesFile = this.store.any(me, ns.space('preferencesFile'), null, me.doc());
82
91
 
83
92
  // console.log('this.store.any()', this.store.any())
84
93
  /**
@@ -100,9 +109,6 @@ export class SolidLogic {
100
109
  );
101
110
  }
102
111
 
103
- if (!this.store.fetcher) {
104
- throw new Error("Cannot load doc, have no fetcher");
105
- }
106
112
  // //// Load preference file
107
113
  try {
108
114
  await this.store.fetcher.load(preferencesFile as NamedNode, {
@@ -152,9 +158,6 @@ export class SolidLogic {
152
158
  }
153
159
 
154
160
  load(doc: NamedNode | NamedNode[] | string) {
155
- if (!this.store.fetcher) {
156
- throw new Error("Cannot load doc(s), have no fetcher");
157
- }
158
161
  return this.store.fetcher.load(doc);
159
162
  }
160
163
 
@@ -210,9 +213,6 @@ export class SolidLogic {
210
213
  }
211
214
 
212
215
  async createEmptyRdfDoc(doc: NamedNode, comment: string) {
213
- if (!this.store.fetcher) {
214
- throw new Error("Cannot create empty rdf doc, have no fetcher");
215
- }
216
216
  await this.store.fetcher.webOperation("PUT", doc.uri, {
217
217
  data: `# ${new Date()} ${comment}
218
218
  `,
@@ -226,9 +226,6 @@ export class SolidLogic {
226
226
  ins: Array<Statement> = []
227
227
  ): Promise<void> {
228
228
  return new Promise((resolve, reject) => {
229
- if (!this.store.updater) {
230
- throw new Error("Cannot updatePromise, have no updater");
231
- }
232
229
  this.store.updater.update(del, ins, function (_uri, ok, errorBody) {
233
230
  if (!ok) {
234
231
  reject(new Error(errorBody));
@@ -260,6 +257,6 @@ export class SolidLogic {
260
257
  }
261
258
 
262
259
  async fetch(url: string, options?: any) {
263
- return this.fetcher.fetch(url, options);
260
+ return this.underlyingFetch.fetch(url, options);
264
261
  }
265
262
  }