solid-logic 1.3.17-a27c1702 → 1.3.17-cd4cd566

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 (49) hide show
  1. package/lib/acl/aclLogic.d.ts +2 -11
  2. package/lib/acl/aclLogic.d.ts.map +1 -1
  3. package/lib/acl/aclLogic.js.map +1 -1
  4. package/lib/chat/chatLogic.d.ts +2 -15
  5. package/lib/chat/chatLogic.d.ts.map +1 -1
  6. package/lib/chat/chatLogic.js +8 -7
  7. package/lib/chat/chatLogic.js.map +1 -1
  8. package/lib/inbox/inboxLogic.d.ts +2 -6
  9. package/lib/inbox/inboxLogic.d.ts.map +1 -1
  10. package/lib/inbox/inboxLogic.js.map +1 -1
  11. package/lib/index.d.ts +4 -18
  12. package/lib/index.d.ts.map +1 -1
  13. package/lib/index.js +2 -86
  14. package/lib/index.js.map +1 -1
  15. package/lib/logic/SolidLogic.d.ts +4 -20
  16. package/lib/logic/SolidLogic.d.ts.map +1 -1
  17. package/lib/logic/SolidLogic.js +37 -32
  18. package/lib/logic/SolidLogic.js.map +1 -1
  19. package/lib/logic/solidLogicSingleton.d.ts +1 -2
  20. package/lib/logic/solidLogicSingleton.d.ts.map +1 -1
  21. package/lib/logic/solidLogicSingleton.js +1 -1
  22. package/lib/logic/solidLogicSingleton.js.map +1 -1
  23. package/lib/profile/profileLogic.d.ts +2 -12
  24. package/lib/profile/profileLogic.d.ts.map +1 -1
  25. package/lib/profile/profileLogic.js +1 -23
  26. package/lib/profile/profileLogic.js.map +1 -1
  27. package/lib/typeIndex/typeIndexLogic.d.ts +2 -31
  28. package/lib/typeIndex/typeIndexLogic.d.ts.map +1 -1
  29. package/lib/typeIndex/typeIndexLogic.js +12 -359
  30. package/lib/typeIndex/typeIndexLogic.js.map +1 -1
  31. package/lib/types.d.ts +65 -1
  32. package/lib/types.d.ts.map +1 -1
  33. package/package.json +1 -1
  34. package/src/acl/aclLogic.ts +5 -4
  35. package/src/chat/chatLogic.ts +7 -7
  36. package/src/inbox/inboxLogic.ts +2 -1
  37. package/src/index.ts +3 -146
  38. package/src/logic/SolidLogic.ts +36 -42
  39. package/src/logic/solidLogicSingleton.ts +2 -2
  40. package/src/profile/profileLogic.ts +4 -12
  41. package/src/typeIndex/typeIndexLogic.ts +6 -277
  42. package/src/types.ts +76 -1
  43. package/test/typeIndexLogic.test.ts +484 -54
  44. package/lib/logic/solidLogicSingletonNew.d.ts +0 -80
  45. package/lib/logic/solidLogicSingletonNew.d.ts.map +0 -1
  46. package/lib/logic/solidLogicSingletonNew.js +0 -238
  47. package/lib/logic/solidLogicSingletonNew.js.map +0 -1
  48. package/src/logic/solidLogicSingletonNew.ts +0 -239
  49. package/test/typeIndexLogicPart2.test.ts +0 -485
@@ -1 +1 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,oCAAoC,CAAA;AAC5D,OAAO,EAAE,SAAS,EAAE,MAAM,QAAQ,CAAA;AAElC,oBAAY,UAAU,GAAG;IACrB,IAAI,EAAE,MAAM,CAAA;IACZ,cAAc,EAAE,MAAM,CAAA;CACzB,CAAA;AAED,oBAAY,qBAAqB,GAAG;IAChC,UAAU,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC,CAAA;IAC7B,GAAG,CAAC,EAAE,WAAW,CAAA;IACjB,GAAG,CAAC,EAAE,YAAY,CAAA;IAClB,KAAK,CAAC,EAAE;QAAE,CAAC,GAAG,EAAE,MAAM,GAAG,KAAK,CAAC,SAAS,CAAC,CAAA;KAAE,CAAA;IAC3C,SAAS,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC,CAAA;IAC5B,EAAE,CAAC,EAAE,SAAS,GAAG,IAAI,CAAA;IACrB,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,eAAe,CAAC,EAAE,SAAS,CAAA;IAC3B,oBAAoB,CAAC,EAAE,MAAM,CAAA;IAC7B,aAAa,CAAC,EAAE,SAAS,CAAA;IACzB,UAAU,CAAC,EAAE,WAAW,CAAA;CAC3B,CAAA;AAED,MAAM,WAAW,UAAU;IACvB,WAAW,EAAE,OAAO,CAAA;IACpB,WAAW,EAAE,MAAM,SAAS,GAAG,IAAI,CAAA;IACnC,SAAS,EAAE,CAAC,CAAC,EAAE,eAAe,CAAC,EAAE,CAAC,EAAE,EAAE,SAAS,GAAG,IAAI,KAAK,CAAC,KAAK,OAAO,CAAC,SAAS,GAAG,CAAC,GAAG,IAAI,CAAC,CAAA;IAC9F,QAAQ,EAAE,CAAC,KAAK,EAAE,SAAS,GAAG,MAAM,GAAG,IAAI,EACvC,OAAO,CAAC,EAAE,qBAAqB,KAAK,SAAS,GAAG,IAAI,CAAA;CAC3D;AAED,MAAM,WAAW,cAAc;IAC3B,CAAC,GAAG,EAAE,MAAM,GAAG,CAAC,IAAI,EAAE,MAAM,KAAK,SAAS,CAAA;CAC7C;AAED,oBAAY,cAAc,GAAG;IAAE,KAAK,EAAE,MAAM,CAAC;IAAC,KAAK,EAAE,SAAS,CAAC;IAAC,KAAK,EAAE,SAAS,CAAA;CAAE,CAAA;AAClF,oBAAY,SAAS,GAAG;IAAE,QAAQ,EAAE,SAAS,CAAC;IAAC,KAAK,EAAE,cAAc,CAAA;CAAE,CAAA;AAEtE,MAAM,WAAW,cAAc;IAC3B,EAAE,CAAC,EAAE,SAAS,CAAC;IACf,WAAW,CAAC,EAAE,SAAS,CAAC;IACxB,OAAO,EAAE,MAAM,CAAC;CACnB;AAED,MAAM,WAAW,kBAAkB;IACnC,WAAW,EAAE,SAAS,CAAC;CACtB"}
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.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.17-a27c1702",
3
+ "version": "1.3.17-cd4cd566",
4
4
  "description": "Core business logic of Solid OS",
5
5
  "main": "lib/index.js",
6
6
  "scripts": {
@@ -1,4 +1,5 @@
1
1
  import { graph, NamedNode, Namespace, serialize, sym } from "rdflib"
2
+ import { AclLogic } from "../types";
2
3
  import { ns as namespace } from '../util/ns'
3
4
 
4
5
 
@@ -6,7 +7,7 @@ export const ACL_LINK = sym(
6
7
  "http://www.iana.org/assignments/link-relations/acl"
7
8
  );
8
9
 
9
- export function createAclLogic(store) {
10
+ export function createAclLogic(store): AclLogic {
10
11
 
11
12
  const ns = namespace
12
13
 
@@ -116,9 +117,9 @@ export function createAclLogic(store) {
116
117
  me: NamedNode,
117
118
  aclURI: string,
118
119
  options: {
119
- defaultForNew?: boolean,
120
- public?: []
121
- } = {}
120
+ defaultForNew?: boolean,
121
+ public?: []
122
+ } = {}
122
123
  ): string | undefined {
123
124
  const optPublic = options.public || []
124
125
  const g = graph()
@@ -1,13 +1,13 @@
1
1
  import { NamedNode, Node, st, term } from "rdflib"
2
- import { CreatedPaneOptions, NewPaneOptions } from "../types"
2
+ import { ChatLogic, CreatedPaneOptions, NewPaneOptions, Chat } from "../types"
3
+ import { ns as namespace } from "../util/ns";
3
4
  import { determineChatContainer, newThing } from "../util/utils"
4
- import { ns as namespace } from '../util/ns'
5
5
 
6
- const CHAT_LOCATION_IN_CONTAINER = "index.ttl#this";
6
+ const CHAT_LOCATION_IN_CONTAINER = "index.ttl#this"
7
7
 
8
- export function createChatLogic(store, profileLogic) {
8
+ export function createChatLogic(store, profileLogic): ChatLogic {
9
9
  const ns = namespace
10
-
10
+
11
11
  async function setAcl(
12
12
  chatContainer: NamedNode,
13
13
  me: NamedNode,
@@ -87,7 +87,7 @@ export function createChatLogic(store, profileLogic) {
87
87
  });
88
88
  }
89
89
 
90
- async function findChat(invitee: NamedNode) {
90
+ async function findChat(invitee: NamedNode): Promise<Chat> {
91
91
  const me = await profileLogic.loadMe();
92
92
  const podRoot = await profileLogic.getPodRoot(me);
93
93
  const chatContainer = determineChatContainer(invitee, podRoot);
@@ -206,7 +206,7 @@ export function createChatLogic(store, profileLogic) {
206
206
  ${ns.rdf("seeAlso")} <${chatThing.value}> .
207
207
  `;
208
208
 
209
- const inviteResponse = await store.fetcher.webOperation(
209
+ const inviteResponse = await store.fetcher?.webOperation(
210
210
  "POST",
211
211
  inviteeInbox.value,
212
212
  {
@@ -1,7 +1,8 @@
1
1
  import { NamedNode } from "rdflib";
2
+ import { InboxLogic } from "../types";
2
3
  import { getArchiveUrl } from "../util/utils";
3
4
 
4
- export function createInboxLogic(store, profileLogic, utilityLogic, containerLogic, aclLogic) {
5
+ export function createInboxLogic(store, profileLogic, utilityLogic, containerLogic, aclLogic): InboxLogic {
5
6
 
6
7
  async function createInboxFor(peerWebId: string, nick: string) {
7
8
  const myWebId: NamedNode = await profileLogic.loadMe();
package/src/index.ts CHANGED
@@ -6,158 +6,15 @@ const authn = solidLogicSingleton.authn
6
6
  const authSession = solidLogicSingleton.authn.authSession
7
7
  const store = solidLogicSingleton.store
8
8
 
9
- const aclLogic = solidLogicSingleton.aclLogic
10
- const utilityLogic = solidLogicSingleton.utilityLogic
11
- const containerLogic = solidLogicSingleton.containerLogic
12
- const profileLogic = solidLogicSingleton.profileLogic
13
- const inboxLogic = solidLogicSingleton.inboxLogic
14
- const typeIndexLogic = solidLogicSingleton.typeIndexLogic
15
- const chatLogic = solidLogicSingleton.chatLogic
16
-
17
- const {
18
- findAclDocUrl,
19
- setACLUserPublic,
20
- genACLText,
21
- } = aclLogic
22
-
23
- const {
24
- ensureTypeIndexes,
25
- loadTypeIndexes,
26
- registerInTypeIndex,
27
- loadIndex,
28
- ensureOneTypeIndex,
29
- putIndex,
30
- makeIndexIfNecessary,
31
- loadIndexes,
32
- getTypeIndex,
33
- getRegistrations,
34
- //NEW function for discovery
35
- loadTypeIndexesFor,
36
- loadCommunityTypeIndexes,
37
- loadAllTypeIndexes,
38
- getScopedAppInstances,
39
- getAppInstances,
40
- suggestPublicTypeIndex,
41
- suggestPrivateTypeIndex,
42
- registerInstanceInTypeIndex,
43
- deleteTypeIndexRegistration,
44
- getScopedAppsFromIndex
45
- } = typeIndexLogic
46
-
47
- const {
48
- setAcl,
49
- addToPrivateTypeIndex,
50
- findChat,
51
- createChatThing,
52
- getChat,
53
- sendInvite,
54
- mintNew
55
- } = chatLogic
56
-
57
- const { createInboxFor, getNewMessages, markAsRead } = inboxLogic
58
- const {
59
- recursiveDelete,
60
- setSinglePeerAccess,
61
- createEmptyRdfDoc,
62
- //NEW function for discovery
63
- followOrCreateLink,
64
- loadOrCreateIfNotExists,
65
- } = utilityLogic
66
-
67
- const {
68
- ensureLoadedPreferences,
69
- loadMe,
70
- getPodRoot,
71
- getMainInbox,
72
- findStorage,
73
- //NEW content from discovery
74
- loadPreferences,
75
- loadProfile,
76
- //NEW function for discovery
77
- silencedLoadPreferences
78
- } = profileLogic
79
-
80
- const {
81
- isContainer,
82
- createContainer,
83
- getContainerElements,
84
- getContainerMembers
85
- } = containerLogic
86
-
87
9
  export { ACL_LINK } from './acl/aclLogic'
88
10
  export { offlineTestID, appContext } from './authn/authUtil'
89
11
  export { getSuggestedIssuers } from './issuer/issuerLogic'
90
- export { SolidLogic } from './logic/SolidLogic'
91
- export { AppDetails, SolidNamespace, AuthenticationContext } from './types'
92
- // solidLogicSingleton is exported entirely because it is used in solid-panes
93
- export { solidLogicSingleton } from './logic/solidLogicSingleton'
12
+ export { AppDetails, SolidNamespace, AuthenticationContext, SolidLogic } from './types'
94
13
  export { UnauthorizedError, CrossOriginForbiddenError, SameOriginForbiddenError, NotFoundError, FetchError, NotEditableError, WebOperationError } from './logic/CustomError'
95
14
 
96
15
  export {
16
+ solidLogicSingleton, // solidLogicSingleton is exported entirely because it is used in solid-panes
97
17
  store,
98
18
  authn,
99
- authSession,
100
- aclLogic,
101
- utilityLogic,
102
- containerLogic,
103
- profileLogic,
104
- inboxLogic,
105
- typeIndexLogic,
106
- chatLogic,
107
- //aclLogic
108
- findAclDocUrl,
109
- setACLUserPublic,
110
- genACLText,
111
- //typeIndexLogic
112
- ensureTypeIndexes,
113
- loadTypeIndexes,
114
- registerInTypeIndex,
115
- loadIndex,
116
- ensureOneTypeIndex,
117
- putIndex,
118
- makeIndexIfNecessary,
119
- loadIndexes,
120
- getTypeIndex,
121
- getRegistrations,
122
- loadTypeIndexesFor,
123
- loadCommunityTypeIndexes,
124
- loadAllTypeIndexes,
125
- getScopedAppInstances,
126
- getAppInstances,
127
- suggestPublicTypeIndex,
128
- suggestPrivateTypeIndex,
129
- registerInstanceInTypeIndex,
130
- deleteTypeIndexRegistration,
131
- getScopedAppsFromIndex,
132
- setAcl,
133
- addToPrivateTypeIndex,
134
- findChat,
135
- createChatThing,
136
- getChat,
137
- sendInvite,
138
- //inboxLogic
139
- mintNew,
140
- createInboxFor,
141
- getNewMessages,
142
- markAsRead,
143
- //utilityLogic
144
- recursiveDelete,
145
- setSinglePeerAccess,
146
- createEmptyRdfDoc,
147
- followOrCreateLink,
148
- loadOrCreateIfNotExists,
149
- //profileLogic
150
- ensureLoadedPreferences,
151
- loadMe,
152
- getPodRoot,
153
- getMainInbox,
154
- findStorage,
155
- loadPreferences,
156
- loadProfile,
157
- silencedLoadPreferences,
158
- //containerLogic
159
- isContainer,
160
- createContainer,
161
- getContainerElements,
162
- getContainerMembers
19
+ authSession
163
20
  }
@@ -9,7 +9,7 @@ import { createProfileLogic } from "../profile/profileLogic";
9
9
  import { createTypeIndexLogic } from "../typeIndex/typeIndexLogic";
10
10
  import { createContainerLogic } from "../util/containerLogic";
11
11
  import { createUtilityLogic } from "../util/utilityLogic";
12
- import { AuthnLogic } from "../types";
12
+ import { AuthnLogic, SolidLogic } from "../types";
13
13
  import * as debug from "../util/debug";
14
14
  /*
15
15
  ** It is important to distinquish `fetch`, a function provided by the browser
@@ -17,55 +17,36 @@ import * as debug from "../util/debug";
17
17
  ** into a `ConnectedStore` or a `LiveStore`. A Fetcher object is
18
18
  ** available at store.fetcher, and `fetch` function at `store.fetcher._fetch`,
19
19
  */
20
- export class SolidLogic {
20
+ export function createSolidLogic(specialFetch: { fetch: (url: any, requestInit: any) => any }, session: Session): SolidLogic {
21
21
 
22
- store: LiveStore;
23
- me: string | undefined;
24
- authn: AuthnLogic;
22
+ debug.log("SolidLogic: Unique instance created. There should only be one of these.")
23
+ const store: LiveStore = rdf.graph() as LiveStore
24
+ rdf.fetcher(store, {fetch: specialFetch.fetch}); // Attach a web I/O module, store.fetcher
25
+ store.updater = new rdf.UpdateManager(store); // Add real-time live updates store.updater
26
+ store.features = [] // disable automatic node merging on store load
25
27
 
26
- aclLogic
27
- utilityLogic
28
- containerLogic
29
- profileLogic
30
- inboxLogic
31
- typeIndexLogic
32
- chatLogic
28
+ const authn: AuthnLogic = new SolidAuthnLogic(session)
29
+
30
+ const acl = createAclLogic(store)
31
+ const containerLogic = createContainerLogic(store)
32
+ const utilityLogic = createUtilityLogic(store, acl, containerLogic)
33
+ const profile = createProfileLogic(store, authn, utilityLogic)
34
+ const chat = createChatLogic(store, profile)
35
+ const inbox = createInboxLogic(store, profile, utilityLogic, containerLogic, acl)
36
+ const typeIndex = createTypeIndexLogic(store, authn, profile, utilityLogic)
37
+ debug.log('SolidAuthnLogic initialized')
33
38
 
34
-
35
- constructor(specialFetch: { fetch: (url: any, requestInit: any) => any }, session: Session) {
36
- // would xpect to be able to do it this way: but get TypeError: Failed to execute 'fetch' on 'Window': Illegal invocation status: 999
37
- // this.store = new rdf.LiveStore({})
38
- // this.store.fetcher._fetch = fetch
39
- debug.log("SolidLogic: Unique instance created. There should only be one of these.")
40
- this.store = rdf.graph() as LiveStore; // Make a Quad store
41
- rdf.fetcher(this.store, { fetch: specialFetch.fetch}); // Attach a web I/O module, store.fetcher
42
- this.store.updater = new rdf.UpdateManager(this.store); // Add real-time live updates store.updater
43
- this.store.features = [] // disable automatic node merging on store load
44
-
45
- this.authn = new SolidAuthnLogic(session)
46
-
47
- debug.log('SolidAuthnLogic initialized')
48
-
49
- this.aclLogic = createAclLogic(this.store)
50
- this.containerLogic = createContainerLogic(this.store)
51
- this.utilityLogic = createUtilityLogic(this.store, this.aclLogic, this.containerLogic)
52
- this.profileLogic = createProfileLogic(this.store, this.authn, this.utilityLogic)
53
- this.chatLogic = createChatLogic(this.store, this.profileLogic)
54
- this.inboxLogic = createInboxLogic(this.store, this.profileLogic, this.utilityLogic, this.containerLogic, this.aclLogic)
55
- this.typeIndexLogic = createTypeIndexLogic(this.store, this.authn, this.profileLogic, this.utilityLogic)
56
- }
57
-
58
- load(doc: NamedNode | NamedNode[] | string) {
59
- return this.store.fetcher.load(doc);
39
+ function load(doc: NamedNode | NamedNode[] | string) {
40
+ return store.fetcher.load(doc);
60
41
  }
61
42
 
62
43
  // @@@@ use the one in rdflib.js when it is available and delete this
63
- updatePromise(
44
+ function updatePromise(
64
45
  del: Array<Statement>,
65
46
  ins: Array<Statement> = []
66
47
  ): Promise<void> {
67
48
  return new Promise((resolve, reject) => {
68
- this.store.updater.update(del, ins, function (_uri, ok, errorBody) {
49
+ store.updater.update(del, ins, function (_uri, ok, errorBody) {
69
50
  if (!ok) {
70
51
  reject(new Error(errorBody));
71
52
  } else {
@@ -75,7 +56,20 @@ export class SolidLogic {
75
56
  }); // promise
76
57
  }
77
58
 
78
- clearStore() {
79
- this.store.statements.slice().forEach(this.store.remove.bind(this.store));
59
+ function clearStore() {
60
+ store.statements.slice().forEach(store.remove.bind(store));
61
+ }
62
+
63
+ return {
64
+ store,
65
+ authn,
66
+ acl,
67
+ inbox,
68
+ chat,
69
+ profile,
70
+ typeIndex,
71
+ load,
72
+ updatePromise,
73
+ clearStore
80
74
  }
81
75
  }
@@ -1,6 +1,6 @@
1
1
  import * as debug from "../util/debug"
2
2
  import { authSession } from "../authSession/authSession"
3
- import { SolidLogic } from "./SolidLogic"
3
+ import { createSolidLogic } from "./SolidLogic"
4
4
 
5
5
  const _fetch = async (url, requestInit) => {
6
6
  const omitCreds = requestInit && requestInit.credentials && requestInit.credentials == 'omit'
@@ -13,7 +13,7 @@ const _fetch = async (url, requestInit) => {
13
13
  }
14
14
 
15
15
  //this const makes solidLogicSingleton global accessible in mashlib
16
- const solidLogicSingleton = new SolidLogic({ fetch: _fetch }, authSession)
16
+ const solidLogicSingleton = createSolidLogic({ fetch: _fetch }, authSession)
17
17
 
18
18
  debug.log('Unique quadstore initialized.')
19
19
 
@@ -1,20 +1,13 @@
1
1
  import { NamedNode } from "rdflib";
2
2
  import { CrossOriginForbiddenError, FetchError, NotEditableError, SameOriginForbiddenError, UnauthorizedError, WebOperationError } from "../logic/CustomError";
3
- import { AuthenticationContext } from "../types";
4
3
  import * as debug from "../util/debug";
5
- import { differentOrigin, suggestPreferencesFile } from "../util/utils";
6
- import { ns as namespace } from '../util/ns'
4
+ import { ns as namespace } from '../util/ns';
5
+ import { differentOrigin, suggestPreferencesFile } from "../util/utils"
6
+ import { ProfileLogic } from "../types"
7
7
 
8
- export function createProfileLogic(store, authn, utilityLogic) {
8
+ export function createProfileLogic(store, authn, utilityLogic): ProfileLogic {
9
9
  const ns = namespace
10
10
 
11
- async function ensureLoadedPreferences (context: AuthenticationContext) {
12
- if (!context.me) throw new Error('@@ ensureLoadedPreferences: no user specified')
13
- context.publicProfile = await loadProfile(context.me)
14
- context.preferencesFile = await silencedLoadPreferences(context.me)
15
- return context
16
- }
17
-
18
11
  /**
19
12
  * loads the preference without throwing errors - if it can create it it does so.
20
13
  * remark: it still throws error if it cannot load profile.
@@ -121,7 +114,6 @@ export function createProfileLogic(store, authn, utilityLogic) {
121
114
  }
122
115
 
123
116
  return {
124
- ensureLoadedPreferences,
125
117
  loadMe,
126
118
  getPodRoot,
127
119
  getMainInbox,