solid-logic 1.3.13-ef4be651 → 1.3.13-f1b5b524

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 (120) hide show
  1. package/.github/workflows/ci.yml +19 -18
  2. package/jest.config.js +4 -1
  3. package/lib/acl/aclLogic.d.ts +32 -0
  4. package/lib/acl/aclLogic.d.ts.map +1 -0
  5. package/lib/acl/aclLogic.js +132 -0
  6. package/lib/acl/aclLogic.js.map +1 -0
  7. package/lib/authSession/authSession.d.ts +3 -0
  8. package/lib/authSession/authSession.d.ts.map +1 -0
  9. package/lib/authSession/authSession.js +8 -0
  10. package/lib/authSession/authSession.js.map +1 -0
  11. package/lib/authn/SolidAuthnLogic.d.ts +26 -5
  12. package/lib/authn/SolidAuthnLogic.d.ts.map +1 -1
  13. package/lib/authn/SolidAuthnLogic.js +167 -5
  14. package/lib/authn/SolidAuthnLogic.js.map +1 -1
  15. package/lib/authn/authUtil.d.ts +17 -0
  16. package/lib/authn/authUtil.d.ts.map +1 -0
  17. package/lib/authn/authUtil.js +88 -0
  18. package/lib/authn/authUtil.js.map +1 -0
  19. package/lib/chat/ChatLogic.d.ts +2 -2
  20. package/lib/chat/ChatLogic.d.ts.map +1 -1
  21. package/lib/chat/ChatLogic.js +1 -1
  22. package/lib/chat/ChatLogic.js.map +1 -1
  23. package/lib/inbox/InboxLogic.d.ts +2 -2
  24. package/lib/inbox/InboxLogic.d.ts.map +1 -1
  25. package/lib/inbox/InboxLogic.js.map +1 -1
  26. package/lib/index.d.ts +14 -67
  27. package/lib/index.d.ts.map +1 -1
  28. package/lib/index.js +39 -387
  29. package/lib/index.js.map +1 -1
  30. package/lib/issuer/issuerLogic.d.ts +8 -0
  31. package/lib/issuer/issuerLogic.d.ts.map +1 -0
  32. package/lib/issuer/issuerLogic.js +53 -0
  33. package/lib/issuer/issuerLogic.js.map +1 -0
  34. package/lib/logic/CustomError.d.ts +17 -0
  35. package/lib/logic/CustomError.d.ts.map +1 -0
  36. package/lib/logic/CustomError.js +73 -0
  37. package/lib/logic/CustomError.js.map +1 -0
  38. package/lib/logic/SolidLogic.d.ts +49 -0
  39. package/lib/logic/SolidLogic.d.ts.map +1 -0
  40. package/lib/logic/SolidLogic.js +316 -0
  41. package/lib/logic/SolidLogic.js.map +1 -0
  42. package/lib/logic/solidLogicSingleton.d.ts +4 -0
  43. package/lib/logic/solidLogicSingleton.d.ts.map +1 -0
  44. package/lib/logic/solidLogicSingleton.js +76 -0
  45. package/lib/logic/solidLogicSingleton.js.map +1 -0
  46. package/lib/profile/ProfileLogic.d.ts +2 -3
  47. package/lib/profile/ProfileLogic.d.ts.map +1 -1
  48. package/lib/profile/ProfileLogic.js.map +1 -1
  49. package/lib/typeIndex/typeIndexLogic.d.ts +22 -0
  50. package/lib/typeIndex/typeIndexLogic.d.ts.map +1 -0
  51. package/lib/typeIndex/typeIndexLogic.js +302 -0
  52. package/lib/typeIndex/typeIndexLogic.js.map +1 -0
  53. package/lib/types.d.ts +31 -0
  54. package/lib/types.d.ts.map +1 -0
  55. package/lib/{authn/index.js → types.js} +1 -1
  56. package/lib/types.js.map +1 -0
  57. package/lib/util/UtilityLogic.d.ts +2 -2
  58. package/lib/util/UtilityLogic.d.ts.map +1 -1
  59. package/lib/util/UtilityLogic.js.map +1 -1
  60. package/lib/{debug.d.ts → util/debug.d.ts} +0 -0
  61. package/lib/util/debug.d.ts.map +1 -0
  62. package/lib/{debug.js → util/debug.js} +0 -0
  63. package/lib/util/debug.js.map +1 -0
  64. package/lib/{uri.d.ts → util/uri.d.ts} +0 -0
  65. package/lib/util/uri.d.ts.map +1 -0
  66. package/lib/{uri.js → util/uri.js} +0 -0
  67. package/lib/util/uri.js.map +1 -0
  68. package/package.json +5 -3
  69. package/src/acl/aclLogic.ts +137 -0
  70. package/src/authSession/authSession.ts +13 -0
  71. package/src/authn/SolidAuthnLogic.ts +114 -9
  72. package/src/authn/authUtil.ts +67 -0
  73. package/src/chat/ChatLogic.ts +3 -3
  74. package/src/inbox/InboxLogic.ts +2 -14
  75. package/src/index.ts +29 -308
  76. package/src/issuer/issuerLogic.ts +40 -0
  77. package/src/logic/CustomError.ts +25 -0
  78. package/src/logic/SolidLogic.ts +264 -0
  79. package/src/logic/solidLogicSingleton.ts +17 -0
  80. package/src/profile/ProfileLogic.ts +2 -3
  81. package/src/typeIndex/typeIndexLogic.ts +170 -0
  82. package/src/types.ts +43 -0
  83. package/src/util/UtilityLogic.ts +2 -14
  84. package/src/{debug.ts → util/debug.ts} +0 -0
  85. package/src/{uri.ts → util/uri.ts} +0 -0
  86. package/test/aclLogic.test.ts +15 -0
  87. package/test/authUtil.test.ts +23 -0
  88. package/{src/chat/integration.test.ts → test/chatLogic.test.ts} +4 -5
  89. package/test/helpers/setup.ts +13 -0
  90. package/{src/inbox/unit.test.ts → test/inboxLogic.test.ts} +5 -6
  91. package/test/logic.test.ts +28 -0
  92. package/test/solidAuthLogic.test.ts +49 -0
  93. package/test/typeIndexLogic.test.ts +26 -0
  94. package/{src/util/unit.test.ts → test/utilityLogic.test.ts} +3 -4
  95. package/jest.setup.ts +0 -2
  96. package/lib/authn/NoAuthnLogic.d.ts +0 -9
  97. package/lib/authn/NoAuthnLogic.d.ts.map +0 -1
  98. package/lib/authn/NoAuthnLogic.js +0 -17
  99. package/lib/authn/NoAuthnLogic.js.map +0 -1
  100. package/lib/authn/index.d.ts +0 -5
  101. package/lib/authn/index.d.ts.map +0 -1
  102. package/lib/authn/index.js.map +0 -1
  103. package/lib/chat/integration.test.d.ts +0 -2
  104. package/lib/chat/integration.test.d.ts.map +0 -1
  105. package/lib/chat/integration.test.js +0 -318
  106. package/lib/chat/integration.test.js.map +0 -1
  107. package/lib/debug.d.ts.map +0 -1
  108. package/lib/debug.js.map +0 -1
  109. package/lib/inbox/unit.test.d.ts +0 -2
  110. package/lib/inbox/unit.test.d.ts.map +0 -1
  111. package/lib/inbox/unit.test.js +0 -264
  112. package/lib/inbox/unit.test.js.map +0 -1
  113. package/lib/uri.d.ts.map +0 -1
  114. package/lib/uri.js.map +0 -1
  115. package/lib/util/unit.test.d.ts +0 -2
  116. package/lib/util/unit.test.d.ts.map +0 -1
  117. package/lib/util/unit.test.js +0 -200
  118. package/lib/util/unit.test.js.map +0 -1
  119. package/src/authn/NoAuthnLogic.ts +0 -16
  120. package/src/authn/index.ts +0 -5
@@ -1,18 +1,123 @@
1
- import { NamedNode, sym } from "rdflib";
2
- import { AuthnLogic } from "./index";
1
+ import { namedNode, NamedNode, sym } from "rdflib";
2
+ import { appContext, offlineTestID } from "./authUtil";
3
+ import * as debug from '../util/debug'
3
4
  import { Session } from "@inrupt/solid-client-authn-browser";
4
-
5
- /**
6
- * Implements AuthnLogic relying on solid-auth-client
7
- */
5
+ import { AuthenticationContext, AuthnLogic } from "../types";
8
6
  export class SolidAuthnLogic implements AuthnLogic {
9
- private session?: Session;
7
+ private session: Session;
10
8
 
11
9
  constructor(solidAuthSession: Session) {
12
10
  this.session = solidAuthSession;
13
11
  }
12
+
13
+ // we created authSession getter because we want to access it as authn.authSession externally
14
+ get authSession():Session { return this.session }
14
15
 
15
16
  currentUser(): NamedNode | null {
16
- return this.session?.info.webId ? sym(this.session.info.webId) : null;
17
+ const app = appContext()
18
+ if (app.viewingNoAuthPage) {
19
+ return sym(app.webId)
20
+ }
21
+ if (this.session.info.webId && this.session.info.isLoggedIn) {
22
+ return sym(this.session.info.webId)
23
+ }
24
+ return offlineTestID() // null unless testing
25
+ }
26
+
27
+ /**
28
+ * Retrieves currently logged in webId from either
29
+ * defaultTestUser or SolidAuth
30
+ * Also activates a session after login
31
+ * @param [setUserCallback] Optional callback
32
+ * @returns Resolves with webId uri, if no callback provided
33
+ */
34
+ async checkUser<T> (
35
+ setUserCallback?: (me: NamedNode | null) => T
36
+ ): Promise<NamedNode | T | null> {
37
+ // Save hash for "restorePreviousSession"
38
+ const preLoginRedirectHash = new URL(window.location.href).hash
39
+ if (preLoginRedirectHash) {
40
+ window.localStorage.setItem('preLoginRedirectHash', preLoginRedirectHash)
41
+ }
42
+ this.session.onSessionRestore((url) => {
43
+ if (document.location.toString() !== url) history.replaceState(null, '', url)
44
+ })
45
+
46
+ /**
47
+ * Handle a successful authentication redirect
48
+ */
49
+ await this.session
50
+ .handleIncomingRedirect({
51
+ restorePreviousSession: true,
52
+ url: window.location.href
53
+ })
54
+
55
+ // Check to see if a hash was stored in local storage
56
+ const postLoginRedirectHash = window.localStorage.getItem('preLoginRedirectHash')
57
+ if (postLoginRedirectHash) {
58
+ const curUrl = new URL(window.location.href)
59
+ if (curUrl.hash !== postLoginRedirectHash) {
60
+ if (history.pushState) {
61
+ // console.log('Setting window.location.has using pushState')
62
+ history.pushState(null, document.title, postLoginRedirectHash)
63
+ } else {
64
+ // console.warn('Setting window.location.has using location.hash')
65
+ location.hash = postLoginRedirectHash
66
+ }
67
+ curUrl.hash = postLoginRedirectHash
68
+ }
69
+ // See https://stackoverflow.com/questions/3870057/how-can-i-update-window-location-hash-without-jumping-the-document
70
+ // window.location.href = curUrl.toString()// @@ See https://developer.mozilla.org/en-US/docs/Web/API/Window/location
71
+ window.localStorage.setItem('preLoginRedirectHash', '')
72
+ }
73
+
74
+ // Check to see if already logged in / have the WebID
75
+ let me = offlineTestID()
76
+ if (me) {
77
+ return Promise.resolve(setUserCallback ? setUserCallback(me) : me)
78
+ }
79
+
80
+ const webId = this.webIdFromSession(this.session.info)
81
+ if (webId) {
82
+ me = this.saveUser(webId)
83
+ }
84
+
85
+ if (me) {
86
+ debug.log(`(Logged in as ${me} by authentication)`)
87
+ }
88
+
89
+ return Promise.resolve(setUserCallback ? setUserCallback(me) : me)
90
+ }
91
+
92
+ /**
93
+ * Saves `webId` in `context.me`
94
+ * @param webId
95
+ * @param context
96
+ *
97
+ * @returns Returns the WebID, after setting it
98
+ */
99
+ saveUser (
100
+ webId: NamedNode | string | null,
101
+ context?: AuthenticationContext
102
+ ): NamedNode | null {
103
+ let webIdUri: string
104
+ if (webId) {
105
+ webIdUri = (typeof webId === 'string') ? webId : webId.uri
106
+ const me = namedNode(webIdUri)
107
+ if (context) {
108
+ context.me = me
109
+ }
110
+ return me
111
+ }
112
+ return null
17
113
  }
18
- }
114
+
115
+ /**
116
+ * @returns {Promise<string|null>} Resolves with WebID URI or null
117
+ */
118
+ webIdFromSession (session?: { webId?: string, isLoggedIn: boolean }): string | null {
119
+ const webId = session?.webId && session.isLoggedIn ? session.webId : null
120
+ return webId
121
+ }
122
+
123
+ }
@@ -0,0 +1,67 @@
1
+ import { NamedNode, sym } from "rdflib"
2
+ import * as debug from '../util/debug'
3
+
4
+ /**
5
+ * find a user or app's context as set in window.SolidAppContext
6
+ * this is a const, not a function, because we have problems to jest mock it otherwise
7
+ * see: https://github.com/facebook/jest/issues/936#issuecomment-545080082 for more
8
+ * @return {any} - an appContext object
9
+ */
10
+ export const appContext = ():any => {
11
+ let { SolidAppContext }: any = window
12
+ SolidAppContext ||= {}
13
+ SolidAppContext.viewingNoAuthPage = false
14
+ if (SolidAppContext.noAuth && window.document) {
15
+ const currentPage = window.document.location.href
16
+ if (currentPage.startsWith(SolidAppContext.noAuth)) {
17
+ SolidAppContext.viewingNoAuthPage = true
18
+ const params = new URLSearchParams(window.document.location.search)
19
+ if (params) {
20
+ let viewedPage = SolidAppContext.viewedPage = params.get('uri') || null
21
+ if (viewedPage) {
22
+ viewedPage = decodeURI(viewedPage)
23
+ if (!viewedPage.startsWith(SolidAppContext.noAuth)) {
24
+ const ary = viewedPage.split(/\//)
25
+ SolidAppContext.idp = ary[0] + '//' + ary[2]
26
+ SolidAppContext.viewingNoAuthPage = false
27
+ }
28
+ }
29
+ }
30
+ }
31
+ }
32
+ return SolidAppContext
33
+ }
34
+
35
+ /**
36
+ * Returns `sym($SolidTestEnvironment.username)` if
37
+ * `$SolidTestEnvironment.username` is defined as a global
38
+ * or
39
+ * returns testID defined in the HTML page
40
+ * @returns {NamedNode|null}
41
+ */
42
+ export function offlineTestID (): NamedNode | null {
43
+ const { $SolidTestEnvironment }: any = window
44
+ if (
45
+ typeof $SolidTestEnvironment !== 'undefined' &&
46
+ $SolidTestEnvironment.username
47
+ ) {
48
+ // Test setup
49
+ debug.log('Assuming the user is ' + $SolidTestEnvironment.username)
50
+ return sym($SolidTestEnvironment.username)
51
+ }
52
+ // hack that makes SolidOS work in offline mode by adding the webId directly in html
53
+ // example usage: https://github.com/solid/mashlib/blob/29b8b53c46bf02e0e219f0bacd51b0e9951001dd/test/contact/local.html#L37
54
+ if (
55
+ typeof document !== 'undefined' &&
56
+ document.location &&
57
+ ('' + document.location).slice(0, 16) === 'http://localhost'
58
+ ) {
59
+ const div = document.getElementById('appTarget')
60
+ if (!div) return null
61
+ const id = div.getAttribute('testID')
62
+ if (!id) return null
63
+ debug.log('Assuming user is ' + id)
64
+ return sym(id)
65
+ }
66
+ return null
67
+ }
@@ -1,7 +1,7 @@
1
- import { LiveStore, NamedNode, Node, st, term } from "rdflib";
2
- import { SolidNamespace } from "../index";
1
+ import { NamedNode, Node, st, term, LiveStore } from "rdflib";
3
2
  import { ProfileLogic } from "../profile/ProfileLogic";
4
- import { newThing } from "../uri";
3
+ import { SolidNamespace } from "../types";
4
+ import { newThing } from "../util/uri";
5
5
  import { determineChatContainer } from "./determineChatContainer";
6
6
 
7
7
  const CHAT_LOCATION_IN_CONTAINER = "index.ttl#this";
@@ -1,19 +1,7 @@
1
- // import { v4 as uuid } from "uuid";
2
- import { LiveStore, NamedNode, Node, st, term } from "rdflib";
3
- import { SolidNamespace } from "../index";
1
+ import { NamedNode, LiveStore } from "rdflib";
4
2
  import { ProfileLogic } from "../profile/ProfileLogic";
3
+ import { SolidNamespace } from "../types";
5
4
  import { UtilityLogic } from "../util/UtilityLogic";
6
- // import { newThing } from "../uri";
7
-
8
- interface NewPaneOptions {
9
- me?: NamedNode;
10
- newInstance?: NamedNode;
11
- newBase: string;
12
- }
13
-
14
- interface CreatedPaneOptions {
15
- newInstance: NamedNode;
16
- }
17
5
 
18
6
  /**
19
7
  * Inbox-related logic
package/src/index.ts CHANGED
@@ -1,308 +1,29 @@
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
-
9
- import { ChatLogic } from "./chat/ChatLogic";
10
- import * as debug from "./debug";
11
- import { ProfileLogic } from "./profile/ProfileLogic";
12
- import { UtilityLogic } from "./util/UtilityLogic";
13
- import { ConnectedStore, LiveStore } from 'rdflib'
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
-
45
- chat: ChatLogic;
46
- profile: ProfileLogic;
47
- authn: AuthnLogic;
48
- util: UtilityLogic;
49
-
50
- constructor(fetcher: { fetch: (url: any, requestInit: any) => any }, solidAuthSession: Session) {
51
- this.store = rdf.graph() as LiveStore; // Make a Quad store
52
- rdf.fetcher(this.store, fetcher); // Attach a web I/O module, store.fetcher
53
- this.store.updater = new rdf.UpdateManager(this.store); // Add real-time live updates store.updater
54
- this.cache = {
55
- profileDocument: {},
56
- preferencesFile: {},
57
- };
58
- this.fetcher = fetcher;
59
- if (solidAuthSession) {
60
- this.authn = new SolidAuthnLogic(solidAuthSession);
61
- } else {
62
- this.authn = new NoAuthnLogic();
63
- }
64
- this.profile = new ProfileLogic(this.store, ns, this.authn);
65
- this.chat = new ChatLogic(this.store, ns, this.profile);
66
- this.util = new UtilityLogic(this.store, ns, this.fetcher);
67
- }
68
-
69
- findAclDocUrl(url: string) {
70
- return this.util.findAclDocUrl(url);
71
- }
72
-
73
- loadDoc(doc: NamedNode): Promise<void> {
74
- return this.util.loadDoc(doc);
75
- }
76
-
77
- async loadProfile(me: NamedNode): Promise<NamedNode> {
78
- // console.log('loadProfile', me)
79
- if (this.cache.profileDocument[me.value]) {
80
- return this.cache.profileDocument[me.value];
81
- }
82
- let profileDocument;
83
- try {
84
- profileDocument = me.doc();
85
- await this.loadDoc(profileDocument);
86
- return profileDocument;
87
- } catch (err) {
88
- const message = `Logged in but cannot load profile ${profileDocument} : ${err}`;
89
- throw new Error(message);
90
- }
91
- }
92
-
93
- async loadPreferences(me: NamedNode): Promise<NamedNode> {
94
- // console.log('loadPreferences', me)
95
- if (this.cache.preferencesFile[me.value]) {
96
- return this.cache.preferencesFile[me.value];
97
- }
98
- const preferencesFile = this.store.any(me, ns.space("preferencesFile"));
99
-
100
- // console.log('this.store.any()', this.store.any())
101
- /**
102
- * Are we working cross-origin?
103
- * Returns True if we are in a webapp at an origin, and the file origin is different
104
- */
105
- function differentOrigin(): boolean {
106
- if (!preferencesFile) {
107
- return true;
108
- }
109
- return (
110
- `${window.location.origin}/` !== new URL(preferencesFile.value).origin
111
- );
112
- }
113
-
114
- if (!preferencesFile) {
115
- throw new Error(
116
- `Can't find a preference file pointer in profile ${me.doc()}`
117
- );
118
- }
119
-
120
- if (!this.store.fetcher) {
121
- throw new Error("Cannot load doc, have no fetcher");
122
- }
123
- // //// Load preference file
124
- try {
125
- await this.store.fetcher.load(preferencesFile as NamedNode, {
126
- withCredentials: true,
127
- });
128
- } catch (err) {
129
- // Really important to look at why
130
- const status = err.status;
131
- debug.log(`HTTP status ${status} for preference file ${preferencesFile}`);
132
- if (status === 401) {
133
- throw new UnauthorizedError();
134
- }
135
- if (status === 403) {
136
- if (differentOrigin()) {
137
- throw new CrossOriginForbiddenError();
138
- }
139
- throw new SameOriginForbiddenError();
140
- }
141
- if (status === 404) {
142
- throw new NotFoundError(preferencesFile.value);
143
- }
144
- throw new FetchError(err.status, err.message);
145
- }
146
- return preferencesFile as NamedNode;
147
- }
148
-
149
- getTypeIndex(
150
- me: NamedNode | string,
151
- preferencesFile: NamedNode | string,
152
- isPublic: boolean
153
- ): NamedNode[] {
154
- // console.log('getTypeIndex', this.store.each(me, undefined, undefined, preferencesFile), isPublic, preferencesFile)
155
- return this.store.each(
156
- me as NamedNode,
157
- isPublic ? ns.solid("publicTypeIndex") : ns.solid("privateTypeIndex"),
158
- undefined,
159
- preferencesFile as NamedNode
160
- ) as NamedNode[];
161
- }
162
-
163
- getRegistrations(instance, theClass) {
164
- return this.store
165
- .each(undefined, ns.solid("instance"), instance)
166
- .filter((r) => {
167
- return this.store.holds(r, ns.solid("forClass"), theClass);
168
- });
169
- }
170
-
171
- load(doc: NamedNode | NamedNode[] | string) {
172
- if (!this.store.fetcher) {
173
- throw new Error("Cannot load doc(s), have no fetcher");
174
- }
175
- return this.store.fetcher.load(doc);
176
- }
177
-
178
- async loadIndexes(
179
- me: NamedNode | string,
180
- publicProfile: NamedNode | string | null,
181
- preferencesFile: NamedNode | string | null,
182
- onWarning = async (_err: Error) => {
183
- return undefined;
184
- }
185
- ): Promise<{
186
- private: any;
187
- public: any;
188
- }> {
189
- let privateIndexes: any[] = [];
190
- let publicIndexes: any[] = [];
191
- if (publicProfile) {
192
- publicIndexes = this.getTypeIndex(me, publicProfile, true);
193
- try {
194
- await this.load(publicIndexes as NamedNode[]);
195
- } catch (err) {
196
- onWarning(new Error(`loadIndex: loading public type index(es) ${err}`));
197
- }
198
- }
199
- if (preferencesFile) {
200
- privateIndexes = this.getTypeIndex(me, preferencesFile, false);
201
- // console.log({ privateIndexes })
202
- if (privateIndexes.length === 0) {
203
- await onWarning(
204
- new Error(
205
- `Your preference file ${preferencesFile} does not point to a private type index.`
206
- )
207
- );
208
- } else {
209
- try {
210
- await this.load(privateIndexes);
211
- } catch (err) {
212
- onWarning(
213
- new Error(`loadIndex: loading private type index(es) ${err}`)
214
- );
215
- }
216
- }
217
- // } else {
218
- // debug.log(
219
- // 'We know your preference file is not available, so we are not bothering with private type indexes.'
220
- // )
221
- }
222
-
223
- return {
224
- private: privateIndexes,
225
- public: publicIndexes,
226
- };
227
- }
228
-
229
- async createEmptyRdfDoc(doc: NamedNode, comment: string) {
230
- if (!this.store.fetcher) {
231
- throw new Error("Cannot create empty rdf doc, have no fetcher");
232
- }
233
- await this.store.fetcher.webOperation("PUT", doc.uri, {
234
- data: `# ${new Date()} ${comment}
235
- `,
236
- contentType: "text/turtle",
237
- });
238
- }
239
-
240
- // @@@@ use the one in rdflib.js when it is available and delete this
241
- updatePromise(
242
- del: Array<Statement>,
243
- ins: Array<Statement> = []
244
- ): Promise<void> {
245
- return new Promise((resolve, reject) => {
246
- if (!this.store.updater) {
247
- throw new Error("Cannot updatePromise, have no updater");
248
- }
249
- this.store.updater.update(del, ins, function (_uri, ok, errorBody) {
250
- if (!ok) {
251
- reject(new Error(errorBody));
252
- } else {
253
- resolve();
254
- }
255
- }); // callback
256
- }); // promise
257
- }
258
-
259
- isContainer(url: string) {
260
- return this.util.isContainer(url);
261
- }
262
-
263
- getContainerElements(containerNode: NamedNode): NamedNode[] {
264
- return this.util.getContainerElements(containerNode);
265
- }
266
-
267
- getContainerMembers(containerUrl: string): Promise<string[]> {
268
- return this.util.getContainerMembers(containerUrl);
269
- }
270
-
271
- async recursiveDelete(url: string) {
272
- return this.util.recursiveDelete(url);
273
- }
274
-
275
- clearStore() {
276
- return this.util.clearStore();
277
- }
278
-
279
- async fetch(url: string, options?: any) {
280
- return this.fetcher.fetch(url, options);
281
- }
282
- }
283
-
284
- class CustomError extends Error {
285
- constructor(message?: string) {
286
- super(message);
287
- // see: typescriptlang.org/docs/handbook/release-notes/typescript-2-2.html
288
- Object.setPrototypeOf(this, new.target.prototype); // restore prototype chain
289
- this.name = new.target.name; // stack traces display correctly now
290
- }
291
- }
292
-
293
- export class UnauthorizedError extends CustomError {}
294
-
295
- export class CrossOriginForbiddenError extends CustomError {}
296
-
297
- export class SameOriginForbiddenError extends CustomError {}
298
-
299
- export class NotFoundError extends CustomError {}
300
-
301
- export class FetchError extends CustomError {
302
- status: number;
303
-
304
- constructor(status: number, message?: string) {
305
- super(message);
306
- this.status = status;
307
- }
308
- }
1
+ // Make these variables directly accessible as it is what you need most of the time
2
+ // This also makes these variable globaly accesible in mashlib
3
+ import { solidLogicSingleton } from './logic/solidLogicSingleton'
4
+ const authn = solidLogicSingleton.authn
5
+ const authSession = solidLogicSingleton.authn.authSession
6
+ const store = solidLogicSingleton.store
7
+
8
+ const chat = solidLogicSingleton.chat
9
+ const profile = solidLogicSingleton.profile
10
+
11
+ export {
12
+ setACLUserPublic,
13
+ genACLText
14
+ } from './acl/aclLogic'
15
+ export {
16
+ ensureTypeIndexes,
17
+ loadTypeIndexes,
18
+ registerInTypeIndex,
19
+ loadIndex
20
+ } from './typeIndex/typeIndexLogic'
21
+ export { SolidLogic } from './logic/SolidLogic'
22
+ export { offlineTestID, appContext } from './authn/authUtil'
23
+ export { ACL_LINK } from './util/UtilityLogic'
24
+ export { getSuggestedIssuers } from './issuer/issuerLogic'
25
+ export { AppDetails, SolidNamespace, AuthenticationContext } from './types'
26
+ // solidLogicSingleton is exported entirely because it is used in solid-panes
27
+ export { solidLogicSingleton } from './logic/solidLogicSingleton'
28
+ export { UnauthorizedError, CrossOriginForbiddenError, SameOriginForbiddenError, NotFoundError, FetchError } from './logic/CustomError'
29
+ export { authn, authSession, store, chat, profile }
@@ -0,0 +1,40 @@
1
+ const DEFAULT_ISSUERS = [
2
+ {
3
+ name: 'Solid Community',
4
+ uri: 'https://solidcommunity.net'
5
+ },
6
+ {
7
+ name: 'Solid Web',
8
+ uri: 'https://solidweb.org'
9
+ },
10
+ {
11
+ name: 'Inrupt.net',
12
+ uri: 'https://inrupt.net'
13
+ },
14
+ {
15
+ name: 'pod.Inrupt.com',
16
+ uri: 'https://broker.pod.inrupt.com'
17
+ }
18
+ ]
19
+
20
+ /**
21
+ * @returns - A list of suggested OIDC issuers
22
+ */
23
+ export function getSuggestedIssuers (): { name: string, uri: string }[] {
24
+ // Suggest a default list of OIDC issuers
25
+ const issuers = [...DEFAULT_ISSUERS]
26
+
27
+ // Suggest the current host if not already included
28
+ const { host, origin } = new URL(location.href)
29
+ const hosts = issuers.map(({ uri }) => new URL(uri).host)
30
+ if (!hosts.includes(host) && !hosts.some(existing => isSubdomainOf(host, existing))) {
31
+ issuers.unshift({ name: host, uri: origin })
32
+ }
33
+
34
+ return issuers
35
+ }
36
+
37
+ function isSubdomainOf (subdomain: string, domain: string): boolean {
38
+ const dot = subdomain.length - domain.length - 1
39
+ return dot > 0 && subdomain[dot] === '.' && subdomain.endsWith(domain)
40
+ }
@@ -0,0 +1,25 @@
1
+ class CustomError extends Error {
2
+ constructor(message?: string) {
3
+ super(message);
4
+ // see: typescriptlang.org/docs/handbook/release-notes/typescript-2-2.html
5
+ Object.setPrototypeOf(this, new.target.prototype); // restore prototype chain
6
+ this.name = new.target.name; // stack traces display correctly now
7
+ }
8
+ }
9
+
10
+ export class UnauthorizedError extends CustomError {}
11
+
12
+ export class CrossOriginForbiddenError extends CustomError {}
13
+
14
+ export class SameOriginForbiddenError extends CustomError {}
15
+
16
+ export class NotFoundError extends CustomError {}
17
+
18
+ export class FetchError extends CustomError {
19
+ status: number;
20
+
21
+ constructor(status: number, message?: string) {
22
+ super(message);
23
+ this.status = status;
24
+ }
25
+ }