solid-logic 1.3.10 → 1.3.11

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.
@@ -0,0 +1,75 @@
1
+ import { Session } from "@inrupt/solid-client-authn-browser";
2
+ import * as rdf from "rdflib";
3
+ import { Fetcher, NamedNode, Statement, Store, UpdateManager } from "rdflib";
4
+ import { AuthnLogic } from "./authn";
5
+ import { ChatLogic } from "./chat/ChatLogic";
6
+ import { ProfileLogic } from "./profile/ProfileLogic";
7
+ import { UtilityLogic } from "./util/UtilityLogic";
8
+ export { ACL_LINK } from './util/UtilityLogic';
9
+ interface ConnectedStore extends Store {
10
+ fetcher: Fetcher;
11
+ }
12
+ export interface LiveStore extends ConnectedStore {
13
+ updater: UpdateManager;
14
+ }
15
+ export interface SolidNamespace {
16
+ [key: string]: (term: string) => NamedNode;
17
+ }
18
+ export declare class SolidLogic {
19
+ cache: {
20
+ profileDocument: {
21
+ [WebID: string]: NamedNode;
22
+ };
23
+ preferencesFile: {
24
+ [WebID: string]: NamedNode;
25
+ };
26
+ };
27
+ store: LiveStore;
28
+ me: string | undefined;
29
+ fetcher: {
30
+ fetch: (url: string, options?: any) => any;
31
+ };
32
+ _fetch: Function;
33
+ chat: ChatLogic;
34
+ profile: ProfileLogic;
35
+ authn: AuthnLogic;
36
+ util: UtilityLogic;
37
+ constructor(fetcher: {
38
+ fetch: (url: any, requestInit: any) => any;
39
+ }, solidAuthSession: Session);
40
+ findAclDocUrl(url: string): Promise<string>;
41
+ loadDoc(doc: NamedNode): Promise<void>;
42
+ loadProfile(me: NamedNode): Promise<NamedNode>;
43
+ loadPreferences(me: NamedNode): Promise<NamedNode>;
44
+ getTypeIndex(me: NamedNode | string, preferencesFile: NamedNode | string, isPublic: boolean): NamedNode[];
45
+ getRegistrations(instance: any, theClass: any): rdf.Node[];
46
+ load(doc: NamedNode | NamedNode[] | string): Promise<Response> | Promise<Response[]>;
47
+ loadIndexes(me: NamedNode | string, publicProfile: NamedNode | string | null, preferencesFile: NamedNode | string | null, onWarning?: (_err: Error) => Promise<undefined>): Promise<{
48
+ private: any;
49
+ public: any;
50
+ }>;
51
+ createEmptyRdfDoc(doc: NamedNode, comment: string): Promise<void>;
52
+ updatePromise(del: Array<Statement>, ins?: Array<Statement>): Promise<void>;
53
+ isContainer(url: string): boolean;
54
+ getContainerElements(containerNode: NamedNode): NamedNode[];
55
+ getContainerMembers(containerUrl: string): Promise<string[]>;
56
+ recursiveDelete(url: string): Promise<any>;
57
+ clearStore(): void;
58
+ fetch(url: string, options?: any): Promise<any>;
59
+ }
60
+ declare class CustomError extends Error {
61
+ constructor(message?: string);
62
+ }
63
+ export declare class UnauthorizedError extends CustomError {
64
+ }
65
+ export declare class CrossOriginForbiddenError extends CustomError {
66
+ }
67
+ export declare class SameOriginForbiddenError extends CustomError {
68
+ }
69
+ export declare class NotFoundError extends CustomError {
70
+ }
71
+ export declare class FetchError extends CustomError {
72
+ status: number;
73
+ constructor(status: number, message?: string);
74
+ }
75
+ //# sourceMappingURL=index-alain.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index-alain.d.ts","sourceRoot":"","sources":["../src/index-alain.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,398 @@
1
+ "use strict";
2
+ var __extends = (this && this.__extends) || (function () {
3
+ var extendStatics = function (d, b) {
4
+ extendStatics = Object.setPrototypeOf ||
5
+ ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
6
+ function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
7
+ return extendStatics(d, b);
8
+ };
9
+ return function (d, b) {
10
+ if (typeof b !== "function" && b !== null)
11
+ throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
12
+ extendStatics(d, b);
13
+ function __() { this.constructor = d; }
14
+ d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
15
+ };
16
+ })();
17
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
18
+ if (k2 === undefined) k2 = k;
19
+ Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
20
+ }) : (function(o, m, k, k2) {
21
+ if (k2 === undefined) k2 = k;
22
+ o[k2] = m[k];
23
+ }));
24
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
25
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
26
+ }) : function(o, v) {
27
+ o["default"] = v;
28
+ });
29
+ var __importStar = (this && this.__importStar) || function (mod) {
30
+ if (mod && mod.__esModule) return mod;
31
+ var result = {};
32
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
33
+ __setModuleDefault(result, mod);
34
+ return result;
35
+ };
36
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
37
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
38
+ return new (P || (P = Promise))(function (resolve, reject) {
39
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
40
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
41
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
42
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
43
+ });
44
+ };
45
+ var __generator = (this && this.__generator) || function (thisArg, body) {
46
+ var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
47
+ return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
48
+ function verb(n) { return function (v) { return step([n, v]); }; }
49
+ function step(op) {
50
+ if (f) throw new TypeError("Generator is already executing.");
51
+ while (_) try {
52
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
53
+ if (y = 0, t) op = [op[0] & 2, t.value];
54
+ switch (op[0]) {
55
+ case 0: case 1: t = op; break;
56
+ case 4: _.label++; return { value: op[1], done: false };
57
+ case 5: _.label++; y = op[1]; op = [0]; continue;
58
+ case 7: op = _.ops.pop(); _.trys.pop(); continue;
59
+ default:
60
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
61
+ if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
62
+ if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
63
+ if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
64
+ if (t[2]) _.ops.pop();
65
+ _.trys.pop(); continue;
66
+ }
67
+ op = body.call(thisArg, _);
68
+ } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
69
+ if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
70
+ }
71
+ };
72
+ var __importDefault = (this && this.__importDefault) || function (mod) {
73
+ return (mod && mod.__esModule) ? mod : { "default": mod };
74
+ };
75
+ Object.defineProperty(exports, "__esModule", { value: true });
76
+ exports.FetchError = exports.NotFoundError = exports.SameOriginForbiddenError = exports.CrossOriginForbiddenError = exports.UnauthorizedError = exports.SolidLogic = exports.ACL_LINK = void 0;
77
+ var rdf = __importStar(require("rdflib"));
78
+ var solid_namespace_1 = __importDefault(require("solid-namespace"));
79
+ var NoAuthnLogic_1 = require("./authn/NoAuthnLogic");
80
+ var SolidAuthnLogic_1 = require("./authn/SolidAuthnLogic");
81
+ var ChatLogic_1 = require("./chat/ChatLogic");
82
+ var debug = __importStar(require("./debug"));
83
+ var ProfileLogic_1 = require("./profile/ProfileLogic");
84
+ var UtilityLogic_1 = require("./util/UtilityLogic");
85
+ var UtilityLogic_2 = require("./util/UtilityLogic");
86
+ Object.defineProperty(exports, "ACL_LINK", { enumerable: true, get: function () { return UtilityLogic_2.ACL_LINK; } });
87
+ var ns = (0, solid_namespace_1.default)(rdf);
88
+ var SolidLogic = /** @class */ (function () {
89
+ function SolidLogic(fetcher, solidAuthSession) {
90
+ this.store = rdf.graph(); // Make a Quad store
91
+ rdf.fetcher(this.store, fetcher); // Attach a web I/O module, store.fetcher
92
+ this.store.updater = new rdf.UpdateManager(this.store); // Add real-time live updates store.updater
93
+ this.cache = {
94
+ profileDocument: {},
95
+ preferencesFile: {},
96
+ };
97
+ this.fetcher = fetcher;
98
+ /*this._fetch = this.fetcher.fetch
99
+ || typeof global !== 'undefined' && global.solidFetch
100
+ || typeof window !== 'undefined' && window.solidFetch
101
+ || crossFetch
102
+ if (!this._fetch) {
103
+ throw new Error('No _fetch function available for Fetcher')
104
+ } */
105
+ if (solidAuthSession) {
106
+ this.authn = new SolidAuthnLogic_1.SolidAuthnLogic(solidAuthSession);
107
+ }
108
+ else {
109
+ this.authn = new NoAuthnLogic_1.NoAuthnLogic();
110
+ }
111
+ this.profile = new ProfileLogic_1.ProfileLogic(this.store, ns, this.authn);
112
+ this.chat = new ChatLogic_1.ChatLogic(this.store, ns, this.profile);
113
+ this.util = new UtilityLogic_1.UtilityLogic(this.store, ns, this.fetcher);
114
+ }
115
+ SolidLogic.prototype.findAclDocUrl = function (url) {
116
+ return this.util.findAclDocUrl(url);
117
+ };
118
+ SolidLogic.prototype.loadDoc = function (doc) {
119
+ return this.util.loadDoc(doc);
120
+ };
121
+ SolidLogic.prototype.loadProfile = function (me) {
122
+ return __awaiter(this, void 0, void 0, function () {
123
+ var profileDocument, err_1, message;
124
+ return __generator(this, function (_a) {
125
+ switch (_a.label) {
126
+ case 0:
127
+ // console.log('loadProfile', me)
128
+ if (this.cache.profileDocument[me.value]) {
129
+ return [2 /*return*/, this.cache.profileDocument[me.value]];
130
+ }
131
+ _a.label = 1;
132
+ case 1:
133
+ _a.trys.push([1, 3, , 4]);
134
+ profileDocument = me.doc();
135
+ return [4 /*yield*/, this.loadDoc(profileDocument)];
136
+ case 2:
137
+ _a.sent();
138
+ return [2 /*return*/, profileDocument];
139
+ case 3:
140
+ err_1 = _a.sent();
141
+ message = "Logged in but cannot load profile ".concat(profileDocument, " : ").concat(err_1);
142
+ throw new Error(message);
143
+ case 4: return [2 /*return*/];
144
+ }
145
+ });
146
+ });
147
+ };
148
+ SolidLogic.prototype.loadPreferences = function (me) {
149
+ return __awaiter(this, void 0, void 0, function () {
150
+ // console.log('this.store.any()', this.store.any())
151
+ /**
152
+ * Are we working cross-origin?
153
+ * Returns True if we are in a webapp at an origin, and the file origin is different
154
+ */
155
+ function differentOrigin() {
156
+ if (!preferencesFile) {
157
+ return true;
158
+ }
159
+ return ("".concat(window.location.origin, "/") !== new URL(preferencesFile.value).origin);
160
+ }
161
+ var preferencesFile, err_2, status_1;
162
+ return __generator(this, function (_a) {
163
+ switch (_a.label) {
164
+ case 0:
165
+ // console.log('loadPreferences', me)
166
+ if (this.cache.preferencesFile[me.value]) {
167
+ return [2 /*return*/, this.cache.preferencesFile[me.value]];
168
+ }
169
+ preferencesFile = this.store.any(me, ns.space("preferencesFile"));
170
+ if (!preferencesFile) {
171
+ throw new Error("Can't find a preference file pointer in profile ".concat(me.doc()));
172
+ }
173
+ if (!this.store.fetcher) {
174
+ throw new Error("Cannot load doc, have no fetcher");
175
+ }
176
+ _a.label = 1;
177
+ case 1:
178
+ _a.trys.push([1, 3, , 4]);
179
+ return [4 /*yield*/, this.store.fetcher.load(preferencesFile, {
180
+ withCredentials: true,
181
+ })];
182
+ case 2:
183
+ _a.sent();
184
+ return [3 /*break*/, 4];
185
+ case 3:
186
+ err_2 = _a.sent();
187
+ status_1 = err_2.status;
188
+ debug.log("HTTP status ".concat(status_1, " for preference file ").concat(preferencesFile));
189
+ if (status_1 === 401) {
190
+ throw new UnauthorizedError();
191
+ }
192
+ if (status_1 === 403) {
193
+ if (differentOrigin()) {
194
+ throw new CrossOriginForbiddenError();
195
+ }
196
+ throw new SameOriginForbiddenError();
197
+ }
198
+ if (status_1 === 404) {
199
+ throw new NotFoundError(preferencesFile.value);
200
+ }
201
+ throw new FetchError(err_2.status, err_2.message);
202
+ case 4: return [2 /*return*/, preferencesFile];
203
+ }
204
+ });
205
+ });
206
+ };
207
+ SolidLogic.prototype.getTypeIndex = function (me, preferencesFile, isPublic) {
208
+ // console.log('getTypeIndex', this.store.each(me, undefined, undefined, preferencesFile), isPublic, preferencesFile)
209
+ return this.store.each(me, isPublic ? ns.solid("publicTypeIndex") : ns.solid("privateTypeIndex"), undefined, preferencesFile);
210
+ };
211
+ SolidLogic.prototype.getRegistrations = function (instance, theClass) {
212
+ var _this = this;
213
+ return this.store
214
+ .each(undefined, ns.solid("instance"), instance)
215
+ .filter(function (r) {
216
+ return _this.store.holds(r, ns.solid("forClass"), theClass);
217
+ });
218
+ };
219
+ SolidLogic.prototype.load = function (doc) {
220
+ if (!this.store.fetcher) {
221
+ throw new Error("Cannot load doc(s), have no fetcher");
222
+ }
223
+ return this.store.fetcher.load(doc);
224
+ };
225
+ SolidLogic.prototype.loadIndexes = function (me, publicProfile, preferencesFile, onWarning) {
226
+ var _this = this;
227
+ if (onWarning === void 0) { onWarning = function (_err) { return __awaiter(_this, void 0, void 0, function () {
228
+ return __generator(this, function (_a) {
229
+ return [2 /*return*/, undefined];
230
+ });
231
+ }); }; }
232
+ return __awaiter(this, void 0, void 0, function () {
233
+ var privateIndexes, publicIndexes, err_3, err_4;
234
+ return __generator(this, function (_a) {
235
+ switch (_a.label) {
236
+ case 0:
237
+ privateIndexes = [];
238
+ publicIndexes = [];
239
+ if (!publicProfile) return [3 /*break*/, 4];
240
+ publicIndexes = this.getTypeIndex(me, publicProfile, true);
241
+ _a.label = 1;
242
+ case 1:
243
+ _a.trys.push([1, 3, , 4]);
244
+ return [4 /*yield*/, this.load(publicIndexes)];
245
+ case 2:
246
+ _a.sent();
247
+ return [3 /*break*/, 4];
248
+ case 3:
249
+ err_3 = _a.sent();
250
+ onWarning(new Error("loadIndex: loading public type index(es) ".concat(err_3)));
251
+ return [3 /*break*/, 4];
252
+ case 4:
253
+ if (!preferencesFile) return [3 /*break*/, 9];
254
+ privateIndexes = this.getTypeIndex(me, preferencesFile, false);
255
+ if (!(privateIndexes.length === 0)) return [3 /*break*/, 6];
256
+ return [4 /*yield*/, onWarning(new Error("Your preference file ".concat(preferencesFile, " does not point to a private type index.")))];
257
+ case 5:
258
+ _a.sent();
259
+ return [3 /*break*/, 9];
260
+ case 6:
261
+ _a.trys.push([6, 8, , 9]);
262
+ return [4 /*yield*/, this.load(privateIndexes)];
263
+ case 7:
264
+ _a.sent();
265
+ return [3 /*break*/, 9];
266
+ case 8:
267
+ err_4 = _a.sent();
268
+ onWarning(new Error("loadIndex: loading private type index(es) ".concat(err_4)));
269
+ return [3 /*break*/, 9];
270
+ case 9: return [2 /*return*/, {
271
+ private: privateIndexes,
272
+ public: publicIndexes,
273
+ }];
274
+ }
275
+ });
276
+ });
277
+ };
278
+ SolidLogic.prototype.createEmptyRdfDoc = function (doc, comment) {
279
+ return __awaiter(this, void 0, void 0, function () {
280
+ return __generator(this, function (_a) {
281
+ switch (_a.label) {
282
+ case 0:
283
+ if (!this.store.fetcher) {
284
+ throw new Error("Cannot create empty rdf doc, have no fetcher");
285
+ }
286
+ return [4 /*yield*/, this.store.fetcher.webOperation("PUT", doc.uri, {
287
+ data: "# ".concat(new Date(), " ").concat(comment, "\n"),
288
+ contentType: "text/turtle",
289
+ })];
290
+ case 1:
291
+ _a.sent();
292
+ return [2 /*return*/];
293
+ }
294
+ });
295
+ });
296
+ };
297
+ // @@@@ use the one in rdflib.js when it is available and delete this
298
+ SolidLogic.prototype.updatePromise = function (del, ins) {
299
+ var _this = this;
300
+ if (ins === void 0) { ins = []; }
301
+ return new Promise(function (resolve, reject) {
302
+ if (!_this.store.updater) {
303
+ throw new Error("Cannot updatePromise, have no updater");
304
+ }
305
+ _this.store.updater.update(del, ins, function (_uri, ok, errorBody) {
306
+ if (!ok) {
307
+ reject(new Error(errorBody));
308
+ }
309
+ else {
310
+ resolve();
311
+ }
312
+ }); // callback
313
+ }); // promise
314
+ };
315
+ SolidLogic.prototype.isContainer = function (url) {
316
+ return this.util.isContainer(url);
317
+ };
318
+ SolidLogic.prototype.getContainerElements = function (containerNode) {
319
+ return this.util.getContainerElements(containerNode);
320
+ };
321
+ SolidLogic.prototype.getContainerMembers = function (containerUrl) {
322
+ return this.util.getContainerMembers(containerUrl);
323
+ };
324
+ SolidLogic.prototype.recursiveDelete = function (url) {
325
+ return __awaiter(this, void 0, void 0, function () {
326
+ return __generator(this, function (_a) {
327
+ return [2 /*return*/, this.util.recursiveDelete(url)];
328
+ });
329
+ });
330
+ };
331
+ SolidLogic.prototype.clearStore = function () {
332
+ return this.util.clearStore();
333
+ };
334
+ SolidLogic.prototype.fetch = function (url, options) {
335
+ return __awaiter(this, void 0, void 0, function () {
336
+ return __generator(this, function (_a) {
337
+ return [2 /*return*/, this.fetcher.fetch(url, options)];
338
+ });
339
+ });
340
+ };
341
+ return SolidLogic;
342
+ }());
343
+ exports.SolidLogic = SolidLogic;
344
+ var CustomError = /** @class */ (function (_super) {
345
+ __extends(CustomError, _super);
346
+ function CustomError(message) {
347
+ var _newTarget = this.constructor;
348
+ var _this = _super.call(this, message) || this;
349
+ // see: typescriptlang.org/docs/handbook/release-notes/typescript-2-2.html
350
+ Object.setPrototypeOf(_this, _newTarget.prototype); // restore prototype chain
351
+ _this.name = _newTarget.name; // stack traces display correctly now
352
+ return _this;
353
+ }
354
+ return CustomError;
355
+ }(Error));
356
+ var UnauthorizedError = /** @class */ (function (_super) {
357
+ __extends(UnauthorizedError, _super);
358
+ function UnauthorizedError() {
359
+ return _super !== null && _super.apply(this, arguments) || this;
360
+ }
361
+ return UnauthorizedError;
362
+ }(CustomError));
363
+ exports.UnauthorizedError = UnauthorizedError;
364
+ var CrossOriginForbiddenError = /** @class */ (function (_super) {
365
+ __extends(CrossOriginForbiddenError, _super);
366
+ function CrossOriginForbiddenError() {
367
+ return _super !== null && _super.apply(this, arguments) || this;
368
+ }
369
+ return CrossOriginForbiddenError;
370
+ }(CustomError));
371
+ exports.CrossOriginForbiddenError = CrossOriginForbiddenError;
372
+ var SameOriginForbiddenError = /** @class */ (function (_super) {
373
+ __extends(SameOriginForbiddenError, _super);
374
+ function SameOriginForbiddenError() {
375
+ return _super !== null && _super.apply(this, arguments) || this;
376
+ }
377
+ return SameOriginForbiddenError;
378
+ }(CustomError));
379
+ exports.SameOriginForbiddenError = SameOriginForbiddenError;
380
+ var NotFoundError = /** @class */ (function (_super) {
381
+ __extends(NotFoundError, _super);
382
+ function NotFoundError() {
383
+ return _super !== null && _super.apply(this, arguments) || this;
384
+ }
385
+ return NotFoundError;
386
+ }(CustomError));
387
+ exports.NotFoundError = NotFoundError;
388
+ var FetchError = /** @class */ (function (_super) {
389
+ __extends(FetchError, _super);
390
+ function FetchError(status, message) {
391
+ var _this = _super.call(this, message) || this;
392
+ _this.status = status;
393
+ return _this;
394
+ }
395
+ return FetchError;
396
+ }(CustomError));
397
+ exports.FetchError = FetchError;
398
+ //# sourceMappingURL=index-alain.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index-alain.js","sourceRoot":"","sources":["../src/index-alain.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,32 @@
1
+ import { NamedNode } from "rdflib";
2
+ import { LiveStore, SolidNamespace } from "../index";
3
+ export declare const ACL_LINK: NamedNode;
4
+ /**
5
+ * Utility-related logic
6
+ */
7
+ export declare class UtilityLogic {
8
+ store: LiveStore;
9
+ ns: SolidNamespace;
10
+ fetcher: any;
11
+ _fetch: Function;
12
+ constructor(store: LiveStore, ns: SolidNamespace, fetcher: {
13
+ fetch: (url: string, options?: any) => any;
14
+ });
15
+ findAclDocUrl(url: string): Promise<string>;
16
+ setSinglePeerAccess(options: {
17
+ ownerWebId: string;
18
+ peerWebId: string;
19
+ accessToModes?: string;
20
+ defaultModes?: string;
21
+ target: string;
22
+ }): Promise<any>;
23
+ loadDoc(doc: NamedNode): Promise<void>;
24
+ isContainer(url: string): boolean;
25
+ createContainer(url: string): Promise<void>;
26
+ getContainerElements(containerNode: NamedNode): NamedNode[];
27
+ getContainerMembers(containerUrl: string): Promise<string[]>;
28
+ recursiveDelete(url: string): Promise<any>;
29
+ clearStore(): void;
30
+ getArchiveUrl(baseUrl: string, date: Date): string;
31
+ }
32
+ //# sourceMappingURL=UtilityLogic-alain.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"UtilityLogic-alain.d.ts","sourceRoot":"","sources":["../../src/util/UtilityLogic-alain.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAkC,MAAM,QAAQ,CAAC;AACnE,OAAO,EAAE,SAAS,EAAE,cAAc,EAAE,MAAM,UAAU,CAAC;AAKrD,eAAO,MAAM,QAAQ,WAEpB,CAAC;AAYF;;GAEG;AACH,qBAAa,YAAY;IACvB,KAAK,EAAE,SAAS,CAAC;IACjB,EAAE,EAAE,cAAc,CAAC;IACnB,OAAO,EAAE,GAAG,CAAC;IACb,MAAM,EAAE,QAAQ,CAAC;gBAEL,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;IAYnG,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"}
@@ -0,0 +1,248 @@
1
+ "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
11
+ var __generator = (this && this.__generator) || function (thisArg, body) {
12
+ var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
13
+ return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
14
+ function verb(n) { return function (v) { return step([n, v]); }; }
15
+ function step(op) {
16
+ if (f) throw new TypeError("Generator is already executing.");
17
+ while (_) try {
18
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
19
+ if (y = 0, t) op = [op[0] & 2, t.value];
20
+ switch (op[0]) {
21
+ case 0: case 1: t = op; break;
22
+ case 4: _.label++; return { value: op[1], done: false };
23
+ case 5: _.label++; y = op[1]; op = [0]; continue;
24
+ case 7: op = _.ops.pop(); _.trys.pop(); continue;
25
+ default:
26
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
27
+ if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
28
+ if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
29
+ if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
30
+ if (t[2]) _.ops.pop();
31
+ _.trys.pop(); continue;
32
+ }
33
+ op = body.call(thisArg, _);
34
+ } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
35
+ if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
36
+ }
37
+ };
38
+ var __importDefault = (this && this.__importDefault) || function (mod) {
39
+ return (mod && mod.__esModule) ? mod : { "default": mod };
40
+ };
41
+ Object.defineProperty(exports, "__esModule", { value: true });
42
+ exports.UtilityLogic = exports.ACL_LINK = void 0;
43
+ var rdflib_1 = require("rdflib");
44
+ var cross_fetch_1 = __importDefault(require("cross-fetch"));
45
+ exports.ACL_LINK = (0, rdflib_1.sym)("http://www.iana.org/assignments/link-relations/acl");
46
+ /**
47
+ * Utility-related logic
48
+ */
49
+ var UtilityLogic = /** @class */ (function () {
50
+ function UtilityLogic(store, ns, fetcher) {
51
+ this.store = store;
52
+ this.ns = ns;
53
+ this._fetch = fetcher.fetch
54
+ || (typeof global !== 'undefined' && global.solidFetch)
55
+ || (typeof window !== 'undefined' && window.solidFetch)
56
+ || cross_fetch_1.default;
57
+ if (!this._fetch) {
58
+ throw new Error('No _fetch function available for Fetcher');
59
+ }
60
+ }
61
+ UtilityLogic.prototype.findAclDocUrl = function (url) {
62
+ return __awaiter(this, void 0, void 0, function () {
63
+ var doc, docNode;
64
+ return __generator(this, function (_a) {
65
+ switch (_a.label) {
66
+ case 0:
67
+ doc = this.store.sym(url);
68
+ return [4 /*yield*/, this.store.fetcher.load(doc)];
69
+ case 1:
70
+ _a.sent();
71
+ docNode = this.store.any(doc, exports.ACL_LINK);
72
+ if (!docNode) {
73
+ throw new Error("No ACL link discovered for ".concat(url));
74
+ }
75
+ return [2 /*return*/, docNode.value];
76
+ }
77
+ });
78
+ });
79
+ };
80
+ // Copied from https://github.com/solid/web-access-control-tests/blob/v3.0.0/test/surface/delete.test.ts#L5
81
+ UtilityLogic.prototype.setSinglePeerAccess = function (options) {
82
+ return __awaiter(this, void 0, void 0, function () {
83
+ var str, aclDocUrl;
84
+ return __generator(this, function (_a) {
85
+ switch (_a.label) {
86
+ case 0:
87
+ str = [
88
+ '@prefix acl: <http://www.w3.org/ns/auth/acl#>.',
89
+ '',
90
+ "<#alice> a acl:Authorization;\n acl:agent <".concat(options.ownerWebId, ">;"),
91
+ " acl:accessTo <".concat(options.target, ">;"),
92
+ " acl:default <".concat(options.target, ">;"),
93
+ ' acl:mode acl:Read, acl:Write, acl:Control.',
94
+ ''
95
+ ].join('\n');
96
+ if (options.accessToModes) {
97
+ str += [
98
+ '<#bobAccessTo> a acl:Authorization;',
99
+ " acl:agent <".concat(options.peerWebId, ">;"),
100
+ " acl:accessTo <".concat(options.target, ">;"),
101
+ " acl:mode ".concat(options.accessToModes, "."),
102
+ ''
103
+ ].join('\n');
104
+ }
105
+ if (options.defaultModes) {
106
+ str += [
107
+ '<#bobDefault> a acl:Authorization;',
108
+ " acl:agent <".concat(options.peerWebId, ">;"),
109
+ " acl:default <".concat(options.target, ">;"),
110
+ " acl:mode ".concat(options.defaultModes, "."),
111
+ ''
112
+ ].join('\n');
113
+ }
114
+ return [4 /*yield*/, this.findAclDocUrl(options.target)];
115
+ case 1:
116
+ aclDocUrl = _a.sent();
117
+ return [2 /*return*/, this._fetch(aclDocUrl, {
118
+ method: 'PUT',
119
+ body: str,
120
+ headers: [
121
+ ['Content-Type', 'text/turtle']
122
+ ]
123
+ })];
124
+ }
125
+ });
126
+ });
127
+ };
128
+ UtilityLogic.prototype.loadDoc = function (doc) {
129
+ return __awaiter(this, void 0, void 0, function () {
130
+ return __generator(this, function (_a) {
131
+ switch (_a.label) {
132
+ case 0:
133
+ // Load a document into the knowledge base (fetcher.store)
134
+ // withCredentials: Web arch should let us just load by turning off creds helps CORS
135
+ // reload: Gets around a specific old Chrome bug caching/origin/cors
136
+ // console.log('loading', profileDocument)
137
+ if (!this.store.fetcher) {
138
+ throw new Error("Cannot load doc, have no fetcher");
139
+ }
140
+ return [4 /*yield*/, this.store.fetcher.load(doc, {
141
+ withCredentials: false,
142
+ cache: "reload",
143
+ })];
144
+ case 1:
145
+ _a.sent();
146
+ return [2 /*return*/];
147
+ }
148
+ });
149
+ });
150
+ };
151
+ UtilityLogic.prototype.isContainer = function (url) {
152
+ return url.substr(-1) === "/";
153
+ };
154
+ UtilityLogic.prototype.createContainer = function (url) {
155
+ return __awaiter(this, void 0, void 0, function () {
156
+ var result;
157
+ return __generator(this, function (_a) {
158
+ switch (_a.label) {
159
+ case 0:
160
+ if (!this.isContainer(url)) {
161
+ throw new Error("Not a container URL ".concat(url));
162
+ }
163
+ return [4 /*yield*/, this._fetch(url, {
164
+ method: "PUT",
165
+ headers: {
166
+ "Content-Type": "text/turtle",
167
+ "If-None-Match": "*",
168
+ Link: '<http://www.w3.org/ns/ldp#BasicContainer>; rel="type"', // See https://github.com/solid/node-solid-server/issues/1465
169
+ },
170
+ body: " ", // work around https://github.com/michielbdejong/community-server/issues/4#issuecomment-776222863
171
+ })];
172
+ case 1:
173
+ result = _a.sent();
174
+ if (result.status.toString()[0] !== '2') {
175
+ throw new Error("Not OK: got ".concat(result.status, " response while creating container at ").concat(url));
176
+ }
177
+ return [2 /*return*/];
178
+ }
179
+ });
180
+ });
181
+ };
182
+ UtilityLogic.prototype.getContainerElements = function (containerNode) {
183
+ return this.store
184
+ .statementsMatching(containerNode, this.store.sym("http://www.w3.org/ns/ldp#contains"), undefined, containerNode.doc())
185
+ .map(function (st) { return st.object; });
186
+ };
187
+ UtilityLogic.prototype.getContainerMembers = function (containerUrl) {
188
+ return __awaiter(this, void 0, void 0, function () {
189
+ var containerNode, nodes;
190
+ return __generator(this, function (_a) {
191
+ switch (_a.label) {
192
+ case 0:
193
+ containerNode = this.store.sym(containerUrl);
194
+ return [4 /*yield*/, this.store.fetcher.load(containerNode)];
195
+ case 1:
196
+ _a.sent();
197
+ nodes = this.getContainerElements(containerNode);
198
+ return [2 /*return*/, nodes.map(function (node) { return node.value; })];
199
+ }
200
+ });
201
+ });
202
+ };
203
+ UtilityLogic.prototype.recursiveDelete = function (url) {
204
+ return __awaiter(this, void 0, void 0, function () {
205
+ var aclDocUrl, containerMembers, e_1;
206
+ var _this = this;
207
+ return __generator(this, function (_a) {
208
+ switch (_a.label) {
209
+ case 0:
210
+ _a.trys.push([0, 6, , 7]);
211
+ if (!this.isContainer(url)) return [3 /*break*/, 5];
212
+ return [4 /*yield*/, this.findAclDocUrl(url)];
213
+ case 1:
214
+ aclDocUrl = _a.sent();
215
+ return [4 /*yield*/, this._fetch(aclDocUrl, { method: "DELETE" })];
216
+ case 2:
217
+ _a.sent();
218
+ return [4 /*yield*/, this.getContainerMembers(url)];
219
+ case 3:
220
+ containerMembers = _a.sent();
221
+ return [4 /*yield*/, Promise.all(containerMembers.map(function (url) { return _this.recursiveDelete(url); }))];
222
+ case 4:
223
+ _a.sent();
224
+ _a.label = 5;
225
+ case 5: return [2 /*return*/, this._fetch(url, { method: "DELETE" })];
226
+ case 6:
227
+ e_1 = _a.sent();
228
+ return [3 /*break*/, 7];
229
+ case 7: return [2 /*return*/];
230
+ }
231
+ });
232
+ });
233
+ };
234
+ UtilityLogic.prototype.clearStore = function () {
235
+ this.store.statements.slice().forEach(this.store.remove.bind(this.store));
236
+ };
237
+ UtilityLogic.prototype.getArchiveUrl = function (baseUrl, date) {
238
+ var year = date.getUTCFullYear();
239
+ var month = ('0' + (date.getUTCMonth() + 1)).slice(-2);
240
+ var day = ('0' + (date.getUTCDate())).slice(-2);
241
+ var parts = baseUrl.split('/');
242
+ var filename = parts[parts.length - 1];
243
+ return new URL("./archive/".concat(year, "/").concat(month, "/").concat(day, "/").concat(filename), baseUrl).toString();
244
+ };
245
+ return UtilityLogic;
246
+ }());
247
+ exports.UtilityLogic = UtilityLogic;
248
+ //# sourceMappingURL=UtilityLogic-alain.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"UtilityLogic-alain.js","sourceRoot":"","sources":["../../src/util/UtilityLogic-alain.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.10",
3
+ "version": "1.3.11",
4
4
  "description": "Core business logic of Solid OS",
5
5
  "main": "lib/index.js",
6
6
  "scripts": {
@@ -41,7 +41,7 @@
41
41
  "typescript": "4.5.2"
42
42
  },
43
43
  "dependencies": {
44
- "rdflib": "^2.2.12",
44
+ "rdflib": "^2.2.14",
45
45
  "solid-namespace": "^0.5.2"
46
46
  }
47
47
  }
@@ -0,0 +1,316 @@
1
+ import { Session } from "@inrupt/solid-client-authn-browser";
2
+ import * as rdf from "rdflib";
3
+ import { Fetcher, NamedNode, Statement, Store, UpdateManager } from "rdflib";
4
+ import solidNamespace from "solid-namespace";
5
+ import { AuthnLogic } from "./authn";
6
+ import { NoAuthnLogic } from "./authn/NoAuthnLogic";
7
+ import { SolidAuthnLogic } from "./authn/SolidAuthnLogic";
8
+ import crossFetch from 'cross-fetch';
9
+
10
+ import { ChatLogic } from "./chat/ChatLogic";
11
+ import * as debug from "./debug";
12
+ import { ProfileLogic } from "./profile/ProfileLogic";
13
+ import { UtilityLogic } from "./util/UtilityLogic";
14
+
15
+ export { ACL_LINK } from './util/UtilityLogic';
16
+
17
+ const ns: SolidNamespace = solidNamespace(rdf);
18
+
19
+ interface ConnectedStore extends Store {
20
+ fetcher: Fetcher;
21
+ }
22
+
23
+ export interface LiveStore extends ConnectedStore {
24
+ updater: UpdateManager;
25
+ }
26
+
27
+ export interface SolidNamespace {
28
+ [key: string]: (term: string) => NamedNode;
29
+ }
30
+
31
+ export class SolidLogic {
32
+ cache: {
33
+ profileDocument: {
34
+ [WebID: string]: NamedNode;
35
+ };
36
+ preferencesFile: {
37
+ [WebID: string]: NamedNode;
38
+ };
39
+ };
40
+
41
+ store: LiveStore;
42
+ me: string | undefined;
43
+ fetcher: { fetch: (url: string, options?: any) => any };
44
+ _fetch: Function;
45
+
46
+ chat: ChatLogic;
47
+ profile: ProfileLogic;
48
+ authn: AuthnLogic;
49
+ util: UtilityLogic;
50
+
51
+ constructor(fetcher: { fetch: (url: any, requestInit: any) => any }, solidAuthSession: Session) {
52
+ this.store = rdf.graph() as LiveStore; // Make a Quad store
53
+ rdf.fetcher(this.store, fetcher); // Attach a web I/O module, store.fetcher
54
+ this.store.updater = new rdf.UpdateManager(this.store); // Add real-time live updates store.updater
55
+ this.cache = {
56
+ profileDocument: {},
57
+ preferencesFile: {},
58
+ };
59
+ this.fetcher = fetcher
60
+ /*this._fetch = this.fetcher.fetch
61
+ || typeof global !== 'undefined' && global.solidFetch
62
+ || typeof window !== 'undefined' && window.solidFetch
63
+ || crossFetch
64
+ if (!this._fetch) {
65
+ throw new Error('No _fetch function available for Fetcher')
66
+ } */
67
+ if (solidAuthSession) {
68
+ this.authn = new SolidAuthnLogic(solidAuthSession);
69
+ } else {
70
+ this.authn = new NoAuthnLogic();
71
+ }
72
+ this.profile = new ProfileLogic(this.store, ns, this.authn);
73
+ this.chat = new ChatLogic(this.store, ns, this.profile);
74
+ this.util = new UtilityLogic(this.store, ns, this.fetcher);
75
+ }
76
+
77
+ findAclDocUrl(url: string) {
78
+ return this.util.findAclDocUrl(url);
79
+ }
80
+
81
+ loadDoc(doc: NamedNode): Promise<void> {
82
+ return this.util.loadDoc(doc);
83
+ }
84
+
85
+ async loadProfile(me: NamedNode): Promise<NamedNode> {
86
+ // console.log('loadProfile', me)
87
+ if (this.cache.profileDocument[me.value]) {
88
+ return this.cache.profileDocument[me.value];
89
+ }
90
+ let profileDocument;
91
+ try {
92
+ profileDocument = me.doc();
93
+ await this.loadDoc(profileDocument);
94
+ return profileDocument;
95
+ } catch (err) {
96
+ const message = `Logged in but cannot load profile ${profileDocument} : ${err}`;
97
+ throw new Error(message);
98
+ }
99
+ }
100
+
101
+ async loadPreferences(me: NamedNode): Promise<NamedNode> {
102
+ // console.log('loadPreferences', me)
103
+ if (this.cache.preferencesFile[me.value]) {
104
+ return this.cache.preferencesFile[me.value];
105
+ }
106
+ const preferencesFile = this.store.any(me, ns.space("preferencesFile"));
107
+
108
+ // console.log('this.store.any()', this.store.any())
109
+ /**
110
+ * Are we working cross-origin?
111
+ * Returns True if we are in a webapp at an origin, and the file origin is different
112
+ */
113
+ function differentOrigin(): boolean {
114
+ if (!preferencesFile) {
115
+ return true;
116
+ }
117
+ return (
118
+ `${window.location.origin}/` !== new URL(preferencesFile.value).origin
119
+ );
120
+ }
121
+
122
+ if (!preferencesFile) {
123
+ throw new Error(
124
+ `Can't find a preference file pointer in profile ${me.doc()}`
125
+ );
126
+ }
127
+
128
+ if (!this.store.fetcher) {
129
+ throw new Error("Cannot load doc, have no fetcher");
130
+ }
131
+ // //// Load preference file
132
+ try {
133
+ await this.store.fetcher.load(preferencesFile as NamedNode, {
134
+ withCredentials: true,
135
+ });
136
+ } catch (err) {
137
+ // Really important to look at why
138
+ const status = err.status;
139
+ debug.log(`HTTP status ${status} for preference file ${preferencesFile}`);
140
+ if (status === 401) {
141
+ throw new UnauthorizedError();
142
+ }
143
+ if (status === 403) {
144
+ if (differentOrigin()) {
145
+ throw new CrossOriginForbiddenError();
146
+ }
147
+ throw new SameOriginForbiddenError();
148
+ }
149
+ if (status === 404) {
150
+ throw new NotFoundError(preferencesFile.value);
151
+ }
152
+ throw new FetchError(err.status, err.message);
153
+ }
154
+ return preferencesFile as NamedNode;
155
+ }
156
+
157
+ getTypeIndex(
158
+ me: NamedNode | string,
159
+ preferencesFile: NamedNode | string,
160
+ isPublic: boolean
161
+ ): NamedNode[] {
162
+ // console.log('getTypeIndex', this.store.each(me, undefined, undefined, preferencesFile), isPublic, preferencesFile)
163
+ return this.store.each(
164
+ me as NamedNode,
165
+ isPublic ? ns.solid("publicTypeIndex") : ns.solid("privateTypeIndex"),
166
+ undefined,
167
+ preferencesFile as NamedNode
168
+ ) as NamedNode[];
169
+ }
170
+
171
+ getRegistrations(instance, theClass) {
172
+ return this.store
173
+ .each(undefined, ns.solid("instance"), instance)
174
+ .filter((r) => {
175
+ return this.store.holds(r, ns.solid("forClass"), theClass);
176
+ });
177
+ }
178
+
179
+ load(doc: NamedNode | NamedNode[] | string) {
180
+ if (!this.store.fetcher) {
181
+ throw new Error("Cannot load doc(s), have no fetcher");
182
+ }
183
+ return this.store.fetcher.load(doc);
184
+ }
185
+
186
+ async loadIndexes(
187
+ me: NamedNode | string,
188
+ publicProfile: NamedNode | string | null,
189
+ preferencesFile: NamedNode | string | null,
190
+ onWarning = async (_err: Error) => {
191
+ return undefined;
192
+ }
193
+ ): Promise<{
194
+ private: any;
195
+ public: any;
196
+ }> {
197
+ let privateIndexes: any[] = [];
198
+ let publicIndexes: any[] = [];
199
+ if (publicProfile) {
200
+ publicIndexes = this.getTypeIndex(me, publicProfile, true);
201
+ try {
202
+ await this.load(publicIndexes as NamedNode[]);
203
+ } catch (err) {
204
+ onWarning(new Error(`loadIndex: loading public type index(es) ${err}`));
205
+ }
206
+ }
207
+ if (preferencesFile) {
208
+ privateIndexes = this.getTypeIndex(me, preferencesFile, false);
209
+ // console.log({ privateIndexes })
210
+ if (privateIndexes.length === 0) {
211
+ await onWarning(
212
+ new Error(
213
+ `Your preference file ${preferencesFile} does not point to a private type index.`
214
+ )
215
+ );
216
+ } else {
217
+ try {
218
+ await this.load(privateIndexes);
219
+ } catch (err) {
220
+ onWarning(
221
+ new Error(`loadIndex: loading private type index(es) ${err}`)
222
+ );
223
+ }
224
+ }
225
+ // } else {
226
+ // debug.log(
227
+ // 'We know your preference file is not available, so we are not bothering with private type indexes.'
228
+ // )
229
+ }
230
+
231
+ return {
232
+ private: privateIndexes,
233
+ public: publicIndexes,
234
+ };
235
+ }
236
+
237
+ async createEmptyRdfDoc(doc: NamedNode, comment: string) {
238
+ if (!this.store.fetcher) {
239
+ throw new Error("Cannot create empty rdf doc, have no fetcher");
240
+ }
241
+ await this.store.fetcher.webOperation("PUT", doc.uri, {
242
+ data: `# ${new Date()} ${comment}
243
+ `,
244
+ contentType: "text/turtle",
245
+ });
246
+ }
247
+
248
+ // @@@@ use the one in rdflib.js when it is available and delete this
249
+ updatePromise(
250
+ del: Array<Statement>,
251
+ ins: Array<Statement> = []
252
+ ): Promise<void> {
253
+ return new Promise((resolve, reject) => {
254
+ if (!this.store.updater) {
255
+ throw new Error("Cannot updatePromise, have no updater");
256
+ }
257
+ this.store.updater.update(del, ins, function (_uri, ok, errorBody) {
258
+ if (!ok) {
259
+ reject(new Error(errorBody));
260
+ } else {
261
+ resolve();
262
+ }
263
+ }); // callback
264
+ }); // promise
265
+ }
266
+
267
+ isContainer(url: string) {
268
+ return this.util.isContainer(url);
269
+ }
270
+
271
+ getContainerElements(containerNode: NamedNode): NamedNode[] {
272
+ return this.util.getContainerElements(containerNode);
273
+ }
274
+
275
+ getContainerMembers(containerUrl: string): Promise<string[]> {
276
+ return this.util.getContainerMembers(containerUrl);
277
+ }
278
+
279
+ async recursiveDelete(url: string) {
280
+ return this.util.recursiveDelete(url);
281
+ }
282
+
283
+ clearStore() {
284
+ return this.util.clearStore();
285
+ }
286
+
287
+ async fetch(url: string, options?: any) {
288
+ return this.fetcher.fetch(url, options);
289
+ }
290
+ }
291
+
292
+ class CustomError extends Error {
293
+ constructor(message?: string) {
294
+ super(message);
295
+ // see: typescriptlang.org/docs/handbook/release-notes/typescript-2-2.html
296
+ Object.setPrototypeOf(this, new.target.prototype); // restore prototype chain
297
+ this.name = new.target.name; // stack traces display correctly now
298
+ }
299
+ }
300
+
301
+ export class UnauthorizedError extends CustomError {}
302
+
303
+ export class CrossOriginForbiddenError extends CustomError {}
304
+
305
+ export class SameOriginForbiddenError extends CustomError {}
306
+
307
+ export class NotFoundError extends CustomError {}
308
+
309
+ export class FetchError extends CustomError {
310
+ status: number;
311
+
312
+ constructor(status: number, message?: string) {
313
+ super(message);
314
+ this.status = status;
315
+ }
316
+ }
@@ -0,0 +1,181 @@
1
+ import { NamedNode, Node, st, term, sym, Statement } from "rdflib";
2
+ import { LiveStore, SolidNamespace } from "../index";
3
+ import { ProfileLogic } from "../profile/ProfileLogic";
4
+ import { newThing } from "../uri";
5
+ import crossFetch from 'cross-fetch';
6
+
7
+ export const ACL_LINK = sym(
8
+ "http://www.iana.org/assignments/link-relations/acl"
9
+ );
10
+
11
+ interface NewPaneOptions {
12
+ me?: NamedNode;
13
+ newInstance?: NamedNode;
14
+ newBase: string;
15
+ }
16
+
17
+ interface CreatedPaneOptions {
18
+ newInstance: NamedNode;
19
+ }
20
+
21
+ /**
22
+ * Utility-related logic
23
+ */
24
+ export class UtilityLogic {
25
+ store: LiveStore;
26
+ ns: SolidNamespace;
27
+ fetcher: any; // { fetch: (url: string, options?: any) => any };
28
+ _fetch: Function;
29
+
30
+ constructor(store: LiveStore, ns: SolidNamespace, fetcher: { fetch: (url: string, options?: any) => any }) {
31
+ this.store = store;
32
+ this.ns = ns;
33
+ this._fetch = fetcher.fetch
34
+ || (typeof global !== 'undefined' && global.solidFetch)
35
+ || (typeof window !== 'undefined' && window.solidFetch)
36
+ || crossFetch
37
+ if (!this._fetch) {
38
+ throw new Error('No _fetch function available for Fetcher')
39
+ }
40
+ }
41
+
42
+ async findAclDocUrl(url: string) {
43
+ const doc = this.store.sym(url);
44
+ await this.store.fetcher.load(doc);
45
+ const docNode = this.store.any(doc, ACL_LINK);
46
+ if (!docNode) {
47
+ throw new Error(`No ACL link discovered for ${url}`);
48
+ }
49
+ return docNode.value;
50
+ }
51
+
52
+ // Copied from https://github.com/solid/web-access-control-tests/blob/v3.0.0/test/surface/delete.test.ts#L5
53
+ async setSinglePeerAccess(options: {
54
+ ownerWebId: string,
55
+ peerWebId: string,
56
+ accessToModes?: string,
57
+ defaultModes?: string,
58
+ target: string
59
+ }) {
60
+ let str = [
61
+ '@prefix acl: <http://www.w3.org/ns/auth/acl#>.',
62
+ '',
63
+ `<#alice> a acl:Authorization;\n acl:agent <${options.ownerWebId}>;`,
64
+ ` acl:accessTo <${options.target}>;`,
65
+ ` acl:default <${options.target}>;`,
66
+ ' acl:mode acl:Read, acl:Write, acl:Control.',
67
+ ''
68
+ ].join('\n')
69
+ if (options.accessToModes) {
70
+ str += [
71
+ '<#bobAccessTo> a acl:Authorization;',
72
+ ` acl:agent <${options.peerWebId}>;`,
73
+ ` acl:accessTo <${options.target}>;`,
74
+ ` acl:mode ${options.accessToModes}.`,
75
+ ''
76
+ ].join('\n')
77
+ }
78
+ if (options.defaultModes) {
79
+ str += [
80
+ '<#bobDefault> a acl:Authorization;',
81
+ ` acl:agent <${options.peerWebId}>;`,
82
+ ` acl:default <${options.target}>;`,
83
+ ` acl:mode ${options.defaultModes}.`,
84
+ ''
85
+ ].join('\n')
86
+ }
87
+ const aclDocUrl = await this.findAclDocUrl(options.target);
88
+ return this._fetch(aclDocUrl, {
89
+ method: 'PUT',
90
+ body: str,
91
+ headers: [
92
+ [ 'Content-Type', 'text/turtle' ]
93
+ ]
94
+ });
95
+ }
96
+
97
+ async loadDoc(doc: NamedNode): Promise<void> {
98
+ // Load a document into the knowledge base (fetcher.store)
99
+ // withCredentials: Web arch should let us just load by turning off creds helps CORS
100
+ // reload: Gets around a specific old Chrome bug caching/origin/cors
101
+ // console.log('loading', profileDocument)
102
+ if (!this.store.fetcher) {
103
+ throw new Error("Cannot load doc, have no fetcher");
104
+ }
105
+ await this.store.fetcher.load(doc, {
106
+ withCredentials: false,
107
+ cache: "reload",
108
+ });
109
+ // console.log('loaded', profileDocument, this.store)
110
+ }
111
+
112
+ isContainer(url: string) {
113
+ return url.substr(-1) === "/";
114
+ }
115
+
116
+ async createContainer(url: string) {
117
+ if (!this.isContainer(url)) {
118
+ throw new Error(`Not a container URL ${url}`);
119
+ }
120
+ // Copied from https://github.com/solid/solid-crud-tests/blob/v3.1.0/test/surface/create-container.test.ts#L56-L64
121
+ const result = await this._fetch(url, {
122
+ method: "PUT",
123
+ headers: {
124
+ "Content-Type": "text/turtle",
125
+ "If-None-Match": "*",
126
+ Link: '<http://www.w3.org/ns/ldp#BasicContainer>; rel="type"', // See https://github.com/solid/node-solid-server/issues/1465
127
+ },
128
+ body: " ", // work around https://github.com/michielbdejong/community-server/issues/4#issuecomment-776222863
129
+ });
130
+ if (result.status.toString()[0] !== '2') {
131
+ throw new Error(`Not OK: got ${result.status} response while creating container at ${url}`);
132
+ }
133
+ }
134
+
135
+ getContainerElements(containerNode: NamedNode): NamedNode[] {
136
+ return this.store
137
+ .statementsMatching(
138
+ containerNode,
139
+ this.store.sym("http://www.w3.org/ns/ldp#contains"),
140
+ undefined,
141
+ containerNode.doc()
142
+ )
143
+ .map((st: Statement) => st.object as NamedNode);
144
+ }
145
+
146
+ async getContainerMembers(containerUrl: string): Promise<string[]> {
147
+ const containerNode = this.store.sym(containerUrl);
148
+ await this.store.fetcher.load(containerNode);
149
+ const nodes = this.getContainerElements(containerNode);
150
+ return nodes.map(node => node.value);
151
+ }
152
+
153
+ async recursiveDelete(url: string) {
154
+ try {
155
+ if (this.isContainer(url)) {
156
+ const aclDocUrl = await this.findAclDocUrl(url);
157
+ await this._fetch(aclDocUrl, { method: "DELETE" });
158
+ const containerMembers = await this.getContainerMembers(url);
159
+ await Promise.all(
160
+ containerMembers.map((url) => this.recursiveDelete(url))
161
+ );
162
+ }
163
+ return this._fetch(url, { method: "DELETE" });
164
+ } catch (e) {
165
+ // console.log(`Please manually remove ${url} from your system under test.`, e);
166
+ }
167
+ }
168
+
169
+ clearStore() {
170
+ this.store.statements.slice().forEach(this.store.remove.bind(this.store));
171
+ }
172
+
173
+ getArchiveUrl(baseUrl: string, date: Date) {
174
+ const year = date.getUTCFullYear();
175
+ const month = ('0' + (date.getUTCMonth()+1)).slice(-2);
176
+ const day = ('0' + (date.getUTCDate())).slice(-2);
177
+ const parts = baseUrl.split('/');
178
+ const filename = parts[parts.length -1 ];
179
+ return new URL(`./archive/${year}/${month}/${day}/${filename}`, baseUrl).toString();
180
+ }
181
+ }