solid-logic 1.3.17-a2363122 → 1.3.17-c3748797

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 (41) 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 +3 -16
  12. package/lib/index.d.ts.map +1 -1
  13. package/lib/index.js +2 -75
  14. package/lib/index.js.map +1 -1
  15. package/lib/logic/SolidLogic.d.ts +7 -7
  16. package/lib/logic/SolidLogic.d.ts.map +1 -1
  17. package/lib/logic/SolidLogic.js +6 -6
  18. package/lib/logic/SolidLogic.js.map +1 -1
  19. package/lib/profile/profileLogic.d.ts +2 -12
  20. package/lib/profile/profileLogic.d.ts.map +1 -1
  21. package/lib/profile/profileLogic.js +1 -23
  22. package/lib/profile/profileLogic.js.map +1 -1
  23. package/lib/typeIndex/typeIndexLogic.d.ts +2 -18
  24. package/lib/typeIndex/typeIndexLogic.d.ts.map +1 -1
  25. package/lib/typeIndex/typeIndexLogic.js.map +1 -1
  26. package/lib/types.d.ts +52 -0
  27. package/lib/types.d.ts.map +1 -1
  28. package/package.json +1 -1
  29. package/src/acl/aclLogic.ts +5 -4
  30. package/src/chat/chatLogic.ts +7 -7
  31. package/src/inbox/inboxLogic.ts +2 -1
  32. package/src/index.ts +2 -126
  33. package/src/logic/SolidLogic.ts +13 -13
  34. package/src/profile/profileLogic.ts +4 -12
  35. package/src/typeIndex/typeIndexLogic.ts +3 -3
  36. package/src/types.ts +63 -0
  37. package/lib/logic/solidLogicSingletonNew.d.ts +0 -68
  38. package/lib/logic/solidLogicSingletonNew.d.ts.map +0 -1
  39. package/lib/logic/solidLogicSingletonNew.js +0 -221
  40. package/lib/logic/solidLogicSingletonNew.js.map +0 -1
  41. package/src/logic/solidLogicSingletonNew.ts +0 -213
package/lib/types.d.ts CHANGED
@@ -45,4 +45,56 @@ export interface NewPaneOptions {
45
45
  export interface CreatedPaneOptions {
46
46
  newInstance: NamedNode;
47
47
  }
48
+ export interface ChatLogic {
49
+ setAcl: (chatContainer: NamedNode, me: NamedNode, invitee: NamedNode) => Promise<void>;
50
+ addToPrivateTypeIndex: (chatThing: any, me: any) => void | Promise<void>;
51
+ findChat: (invitee: NamedNode) => Promise<Chat>;
52
+ createChatThing: (chatContainer: NamedNode, me: NamedNode) => Promise<NamedNode>;
53
+ mintNew: (newPaneOptions: NewPaneOptions) => Promise<CreatedPaneOptions>;
54
+ getChat: (invitee: NamedNode, boolean: any) => Promise<NamedNode | null>;
55
+ sendInvite: (invitee: NamedNode, chatThing: NamedNode) => void;
56
+ }
57
+ export interface Chat {
58
+ me: NamedNode;
59
+ chatContainer: NamedNode;
60
+ exists: boolean;
61
+ }
62
+ export interface ProfileLogic {
63
+ silencedLoadPreferences: (user: NamedNode) => Promise<NamedNode | undefined>;
64
+ loadPreferences: (user: NamedNode) => Promise<NamedNode>;
65
+ loadProfile: (user: NamedNode) => Promise<NamedNode>;
66
+ loadMe: () => Promise<NamedNode>;
67
+ getPodRoot: (user: NamedNode) => NamedNode;
68
+ getMainInbox: (user: NamedNode) => Promise<NamedNode>;
69
+ findStorage: (me: NamedNode) => Node | null;
70
+ }
71
+ export interface AclLogic {
72
+ findAclDocUrl: (url: string) => Promise<any>;
73
+ setACLUserPublic: (docURI: string, me: NamedNode, options: {
74
+ defaultForNew?: boolean;
75
+ public?: [];
76
+ }) => Promise<NamedNode>;
77
+ genACLText: (docURI: string, me: NamedNode, aclURI: string, options: {
78
+ defaultForNew?: boolean;
79
+ public?: [];
80
+ }) => string | undefined;
81
+ }
82
+ export interface InboxLogic {
83
+ createInboxFor: (peerWebId: string, nick: string) => Promise<string>;
84
+ getNewMessages: (user?: NamedNode) => Promise<string[]>;
85
+ markAsRead: (url: string, date: Date) => void;
86
+ }
87
+ export interface TypeIndexLogic {
88
+ getRegistrations: (instance: any, theClass: any) => Promise<NamedNode>;
89
+ loadTypeIndexesFor: (user: NamedNode) => Promise<Array<TypeIndexScope>>;
90
+ loadCommunityTypeIndexes: (user: NamedNode) => Promise<TypeIndexScope[][]>;
91
+ loadAllTypeIndexes: (user: NamedNode) => Promise<Array<TypeIndexScope>>;
92
+ getScopedAppInstances: (klass: NamedNode, user: NamedNode) => Promise<ScopedApp[]>;
93
+ getAppInstances: (klass: NamedNode) => Promise<NamedNode[]>;
94
+ suggestPublicTypeIndex: (me: NamedNode) => NamedNode;
95
+ suggestPrivateTypeIndex: (preferencesFile: NamedNode) => NamedNode;
96
+ registerInTypeIndex: (instance: NamedNode, index: NamedNode, theClass: NamedNode) => Promise<NamedNode | null>;
97
+ deleteTypeIndexRegistration: (item: any) => Promise<void>;
98
+ getScopedAppsFromIndex: (scope: TypeIndexScope, theClass: NamedNode | null) => Promise<ScopedApp[]>;
99
+ }
48
100
  //# sourceMappingURL=types.d.ts.map
@@ -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-a2363122",
3
+ "version": "1.3.17-c3748797",
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,140 +6,16 @@ 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
- registerInTypeIndex,
25
- getRegistrations,
26
- //NEW function for discovery
27
- loadTypeIndexesFor,
28
- loadCommunityTypeIndexes,
29
- loadAllTypeIndexes,
30
- getScopedAppInstances,
31
- getAppInstances,
32
- suggestPublicTypeIndex,
33
- suggestPrivateTypeIndex,
34
- deleteTypeIndexRegistration,
35
- getScopedAppsFromIndex
36
- } = typeIndexLogic
37
-
38
- const {
39
- setAcl,
40
- addToPrivateTypeIndex,
41
- findChat,
42
- createChatThing,
43
- getChat,
44
- sendInvite,
45
- mintNew
46
- } = chatLogic
47
-
48
- const { createInboxFor, getNewMessages, markAsRead } = inboxLogic
49
- const {
50
- recursiveDelete,
51
- setSinglePeerAccess,
52
- createEmptyRdfDoc,
53
- //NEW function for discovery
54
- followOrCreateLink,
55
- loadOrCreateIfNotExists,
56
- } = utilityLogic
57
-
58
- const {
59
- ensureLoadedPreferences,
60
- loadMe,
61
- getPodRoot,
62
- getMainInbox,
63
- findStorage,
64
- //NEW content from discovery
65
- loadPreferences,
66
- loadProfile,
67
- //NEW function for discovery
68
- silencedLoadPreferences
69
- } = profileLogic
70
-
71
- const {
72
- isContainer,
73
- createContainer,
74
- getContainerElements,
75
- getContainerMembers
76
- } = containerLogic
77
-
78
9
  export { ACL_LINK } from './acl/aclLogic'
79
10
  export { offlineTestID, appContext } from './authn/authUtil'
80
11
  export { getSuggestedIssuers } from './issuer/issuerLogic'
81
12
  export { SolidLogic } from './logic/SolidLogic'
82
13
  export { AppDetails, SolidNamespace, AuthenticationContext } from './types'
83
- // solidLogicSingleton is exported entirely because it is used in solid-panes
84
- export { solidLogicSingleton } from './logic/solidLogicSingleton'
85
14
  export { UnauthorizedError, CrossOriginForbiddenError, SameOriginForbiddenError, NotFoundError, FetchError, NotEditableError, WebOperationError } from './logic/CustomError'
86
15
 
87
16
  export {
17
+ solidLogicSingleton, // solidLogicSingleton is exported entirely because it is used in solid-panes
88
18
  store,
89
19
  authn,
90
- authSession,
91
- aclLogic,
92
- utilityLogic,
93
- containerLogic,
94
- profileLogic,
95
- inboxLogic,
96
- typeIndexLogic,
97
- chatLogic,
98
- //aclLogic
99
- findAclDocUrl,
100
- setACLUserPublic,
101
- genACLText,
102
- //typeIndexLogic
103
- registerInTypeIndex,
104
- getRegistrations,
105
- loadTypeIndexesFor,
106
- loadCommunityTypeIndexes,
107
- loadAllTypeIndexes,
108
- getScopedAppInstances,
109
- getAppInstances,
110
- suggestPublicTypeIndex,
111
- suggestPrivateTypeIndex,
112
- deleteTypeIndexRegistration,
113
- getScopedAppsFromIndex,
114
- setAcl,
115
- addToPrivateTypeIndex,
116
- findChat,
117
- createChatThing,
118
- getChat,
119
- sendInvite,
120
- //inboxLogic
121
- mintNew,
122
- createInboxFor,
123
- getNewMessages,
124
- markAsRead,
125
- //utilityLogic
126
- recursiveDelete,
127
- setSinglePeerAccess,
128
- createEmptyRdfDoc,
129
- followOrCreateLink,
130
- loadOrCreateIfNotExists,
131
- //profileLogic
132
- ensureLoadedPreferences,
133
- loadMe,
134
- getPodRoot,
135
- getMainInbox,
136
- findStorage,
137
- loadPreferences,
138
- loadProfile,
139
- silencedLoadPreferences,
140
- //containerLogic
141
- isContainer,
142
- createContainer,
143
- getContainerElements,
144
- getContainerMembers
20
+ authSession
145
21
  }
@@ -23,13 +23,13 @@ export class SolidLogic {
23
23
  me: string | undefined;
24
24
  authn: AuthnLogic;
25
25
 
26
- aclLogic
27
- utilityLogic
28
- containerLogic
29
- profileLogic
30
- inboxLogic
31
- typeIndexLogic
32
- chatLogic
26
+ readonly acl
27
+ readonly profile
28
+ readonly inbox
29
+ readonly typeIndex
30
+ readonly chat
31
+ private readonly containerLogic
32
+ private readonly utilityLogic
33
33
 
34
34
 
35
35
  constructor(specialFetch: { fetch: (url: any, requestInit: any) => any }, session: Session) {
@@ -46,13 +46,13 @@ export class SolidLogic {
46
46
 
47
47
  debug.log('SolidAuthnLogic initialized')
48
48
 
49
- this.aclLogic = createAclLogic(this.store)
49
+ this.acl = createAclLogic(this.store)
50
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)
51
+ this.utilityLogic = createUtilityLogic(this.store, this.acl, this.containerLogic)
52
+ this.profile = createProfileLogic(this.store, this.authn, this.utilityLogic)
53
+ this.chat = createChatLogic(this.store, this.profile)
54
+ this.inbox = createInboxLogic(this.store, this.profile, this.utilityLogic, this.containerLogic, this.acl)
55
+ this.typeIndex = createTypeIndexLogic(this.store, this.authn, this.profile, this.utilityLogic)
56
56
  }
57
57
 
58
58
  load(doc: NamedNode | NamedNode[] | string) {
@@ -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,
@@ -1,10 +1,10 @@
1
1
  import { NamedNode, st, sym } from 'rdflib'
2
- import { ScopedApp, TypeIndexScope } from '../types'
2
+ import { ScopedApp, TypeIndexLogic, TypeIndexScope } from '../types'
3
3
  import * as debug from "../util/debug"
4
4
  import { ns as namespace } from '../util/ns'
5
5
  import { newThing, uniqueNodes } from "../util/utils"
6
6
 
7
- export function createTypeIndexLogic(store, authn, profileLogic, utilityLogic) {
7
+ export function createTypeIndexLogic(store, authn, profileLogic, utilityLogic): TypeIndexLogic {
8
8
  const ns = namespace
9
9
 
10
10
  function getRegistrations(instance, theClass) {
@@ -153,7 +153,7 @@ export function createTypeIndexLogic(store, authn, profileLogic, utilityLogic) {
153
153
  await store.updater.update(statements, [])
154
154
  }
155
155
 
156
- async function getScopedAppsFromIndex(scope, theClass: NamedNode | null) {
156
+ async function getScopedAppsFromIndex(scope: TypeIndexScope, theClass: NamedNode | null): Promise<ScopedApp[]> {
157
157
  const index = scope.index
158
158
  const registrations = store.statementsMatching(null, ns.solid('instance'), null, index)
159
159
  .concat(store.statementsMatching(null, ns.solid('instanceContainer'), null, index))
package/src/types.ts CHANGED
@@ -45,3 +45,66 @@ export interface CreatedPaneOptions {
45
45
  newInstance: NamedNode;
46
46
  }
47
47
 
48
+ export interface ChatLogic {
49
+ setAcl: (chatContainer: NamedNode, me: NamedNode, invitee: NamedNode) => Promise<void>,
50
+ addToPrivateTypeIndex: (chatThing, me) => void | Promise<void>,
51
+ findChat: (invitee: NamedNode) => Promise<Chat>,
52
+ createChatThing: (chatContainer: NamedNode, me: NamedNode) => Promise<NamedNode>,
53
+ mintNew: (newPaneOptions: NewPaneOptions) => Promise<CreatedPaneOptions>,
54
+ getChat: (invitee: NamedNode, boolean) => Promise<NamedNode | null>,
55
+ sendInvite: (invitee: NamedNode, chatThing: NamedNode) => void
56
+ }
57
+
58
+ export interface Chat {
59
+ me: NamedNode,
60
+ chatContainer: NamedNode,
61
+ exists: boolean
62
+ }
63
+
64
+ export interface ProfileLogic {
65
+ silencedLoadPreferences: (user: NamedNode) => Promise<NamedNode | undefined>,
66
+ loadPreferences: (user: NamedNode) => Promise<NamedNode>,
67
+ loadProfile: (user: NamedNode) => Promise<NamedNode>,
68
+ loadMe: () => Promise<NamedNode>,
69
+ getPodRoot: (user: NamedNode) => NamedNode,
70
+ getMainInbox: (user: NamedNode) => Promise<NamedNode>,
71
+ findStorage: (me: NamedNode) => Node | null
72
+ }
73
+
74
+ export interface AclLogic {
75
+ findAclDocUrl: (url: string) => Promise<any>,
76
+ setACLUserPublic: (docURI: string, me: NamedNode,
77
+ options: {
78
+ defaultForNew?: boolean,
79
+ public?: []
80
+ }
81
+ ) => Promise<NamedNode>,
82
+ genACLText: (docURI: string, me: NamedNode, aclURI: string,
83
+ options: {
84
+ defaultForNew?: boolean,
85
+ public?: []
86
+ }
87
+ ) => string | undefined
88
+ }
89
+
90
+ export interface InboxLogic {
91
+ createInboxFor: (peerWebId: string, nick: string) => Promise<string>,
92
+ getNewMessages: (user?: NamedNode) => Promise<string[]>,
93
+ markAsRead: (url: string, date: Date) => void
94
+ }
95
+
96
+ export interface TypeIndexLogic {
97
+ getRegistrations: (instance, theClass) => Promise<NamedNode>,
98
+ loadTypeIndexesFor: (user: NamedNode) => Promise<Array<TypeIndexScope>>,
99
+ loadCommunityTypeIndexes: (user: NamedNode) => Promise<TypeIndexScope[][]>,
100
+ loadAllTypeIndexes: (user: NamedNode) => Promise<Array<TypeIndexScope>>,
101
+ getScopedAppInstances: (klass: NamedNode, user: NamedNode) => Promise<ScopedApp[]>,
102
+ getAppInstances: (klass: NamedNode) => Promise<NamedNode[]>,
103
+ suggestPublicTypeIndex: (me: NamedNode) => NamedNode,
104
+ suggestPrivateTypeIndex: (preferencesFile: NamedNode) => NamedNode,
105
+ registerInTypeIndex: (instance: NamedNode, index: NamedNode, theClass: NamedNode) => Promise<NamedNode | null>,
106
+ deleteTypeIndexRegistration: (item: any) => Promise<void>
107
+ getScopedAppsFromIndex: (scope: TypeIndexScope, theClass: NamedNode | null) => Promise<ScopedApp[]>
108
+
109
+ }
110
+
@@ -1,68 +0,0 @@
1
- import * as rdf from "rdflib";
2
- import { SolidAuthnLogic } from "../authn/SolidAuthnLogic";
3
- export declare function solidLogicSingleton(): {
4
- store: rdf.LiveStore;
5
- authn: SolidAuthnLogic;
6
- authSession: import("@inrupt/solid-client-authn-browser").Session;
7
- recursiveDelete: (url: string) => Promise<any>;
8
- setSinglePeerAccess: (options: {
9
- ownerWebId: string;
10
- peerWebId: string;
11
- accessToModes?: string | undefined;
12
- defaultModes?: string | undefined;
13
- target: string;
14
- }) => Promise<any>;
15
- createEmptyRdfDoc: (doc: rdf.NamedNode, comment: string) => Promise<void>;
16
- followOrCreateLink: (subject: rdf.NamedNode, predicate: rdf.NamedNode, object: rdf.NamedNode, doc: rdf.NamedNode) => Promise<rdf.NamedNode | null>;
17
- loadOrCreateIfNotExists: (doc: rdf.NamedNode) => Promise<any>;
18
- isContainer: (url: string) => boolean;
19
- createContainer: (url: string) => Promise<void>;
20
- getContainerElements: (containerNode: rdf.NamedNode) => rdf.NamedNode[];
21
- getContainerMembers: (containerUrl: string) => Promise<string[]>;
22
- registerInTypeIndex: (instance: rdf.NamedNode, index: rdf.NamedNode, theClass: rdf.NamedNode) => Promise<rdf.NamedNode | null>;
23
- getRegistrations: (instance: any, theClass: any) => any;
24
- loadTypeIndexesFor: (user: rdf.NamedNode) => Promise<import("../types").TypeIndexScope[]>;
25
- loadCommunityTypeIndexes: (user: rdf.NamedNode) => Promise<import("../types").TypeIndexScope[][]>;
26
- loadAllTypeIndexes: (user: rdf.NamedNode) => Promise<import("../types").TypeIndexScope[]>;
27
- getScopedAppInstances: (klass: rdf.NamedNode, user: rdf.NamedNode) => Promise<import("../types").ScopedApp[]>;
28
- getAppInstances: (klass: rdf.NamedNode) => Promise<rdf.NamedNode[]>;
29
- suggestPublicTypeIndex: (me: rdf.NamedNode) => rdf.NamedNode;
30
- suggestPrivateTypeIndex: (preferencesFile: rdf.NamedNode) => rdf.NamedNode;
31
- deleteTypeIndexRegistration: (item: any) => Promise<void>;
32
- getScopedAppsFromIndex: (scope: any, theClass: rdf.NamedNode | null) => Promise<{
33
- instance: rdf.NamedNode;
34
- scope: any;
35
- }[]>;
36
- ensureLoadedPreferences: (context: import("..").AuthenticationContext) => Promise<import("..").AuthenticationContext>;
37
- loadMe: () => Promise<rdf.NamedNode>;
38
- getPodRoot: (user: rdf.NamedNode) => rdf.NamedNode;
39
- getMainInbox: (user: rdf.NamedNode) => Promise<rdf.NamedNode>;
40
- findStorage: (me: rdf.NamedNode) => any;
41
- loadPreferences: (user: rdf.NamedNode) => Promise<rdf.NamedNode>;
42
- loadProfile: (user: rdf.NamedNode) => Promise<rdf.NamedNode>;
43
- silencedLoadPreferences: (user: rdf.NamedNode) => Promise<rdf.NamedNode | undefined>;
44
- createInboxFor: (peerWebId: string, nick: string) => Promise<string>;
45
- getNewMessages: (user?: rdf.NamedNode | undefined) => Promise<string[]>;
46
- markAsRead: (url: string, date: Date) => Promise<void>;
47
- setAcl: (chatContainer: rdf.NamedNode, me: rdf.NamedNode, invitee: rdf.NamedNode) => Promise<void>;
48
- addToPrivateTypeIndex: (chatThing: any, me: any) => Promise<void>;
49
- findChat: (invitee: rdf.NamedNode) => Promise<{
50
- me: any;
51
- chatContainer: rdf.NamedNode;
52
- exists: boolean;
53
- }>;
54
- createChatThing: (chatContainer: rdf.NamedNode, me: rdf.NamedNode) => Promise<rdf.NamedNode>;
55
- getChat: (invitee: rdf.NamedNode, createIfMissing?: boolean) => Promise<rdf.NamedNode | null>;
56
- sendInvite: (invitee: rdf.NamedNode, chatThing: rdf.NamedNode) => Promise<void>;
57
- mintNew: (newPaneOptions: import("../types").NewPaneOptions) => Promise<import("../types").CreatedPaneOptions>;
58
- findAclDocUrl: (url: string) => Promise<any>;
59
- setACLUserPublic: (docURI: string, me: rdf.NamedNode, options: {
60
- defaultForNew?: boolean | undefined;
61
- public?: [] | undefined;
62
- }) => Promise<rdf.NamedNode>;
63
- genACLText: (docURI: string, me: rdf.NamedNode, aclURI: string, options?: {
64
- defaultForNew?: boolean | undefined;
65
- public?: [] | undefined;
66
- }) => string | undefined;
67
- };
68
- //# sourceMappingURL=solidLogicSingletonNew.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"solidLogicSingletonNew.d.ts","sourceRoot":"","sources":["../../src/logic/solidLogicSingletonNew.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,GAAG,MAAM,QAAQ,CAAA;AAC7B,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAA;AAW1D,wBAAgB,mBAAmB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAgJlC"}