@secrecy/lib 1.0.0-dev.54 → 1.0.0-dev.55

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,17 @@
1
+ import type { SecrecyClient, SuccessResponse, UserAppNotifications, UserAppSettings } from "../index.js";
2
+ import type { KeyPair } from "../crypto/index.js";
3
+ import type { ErrorAccessDenied, ErrorBasic, ErrorNotFound } from "../error.js";
4
+ import type { Thunder } from "../zeus/index.js";
5
+ import type { JwtPayload } from "jsonwebtoken";
6
+ export declare class SecrecyAppClient {
7
+ #private;
8
+ jwt: string;
9
+ jwtDecoded: JwtPayload;
10
+ constructor(uaJwt: string, _client: SecrecyClient, _keys: KeyPair, thunder: ReturnType<typeof Thunder>);
11
+ get userId(): string;
12
+ getJwt(): Promise<string>;
13
+ updateNotifications(notifications: Partial<UserAppNotifications>): Promise<SuccessResponse<UserAppNotifications> | ErrorAccessDenied | null>;
14
+ notifications(): Promise<SuccessResponse<UserAppNotifications> | ErrorAccessDenied | ErrorNotFound | null>;
15
+ settings(): Promise<SuccessResponse<UserAppSettings> | ErrorNotFound | null>;
16
+ updateSettings(settings: Partial<UserAppSettings>): Promise<SuccessResponse<UserAppSettings> | ErrorAccessDenied | ErrorBasic | null>;
17
+ }
@@ -0,0 +1,258 @@
1
+ import _classPrivateFieldLooseBase from "@babel/runtime/helpers/classPrivateFieldLooseBase";
2
+ import _classPrivateFieldLooseKey from "@babel/runtime/helpers/classPrivateFieldLooseKey";
3
+
4
+ /* eslint-disable @typescript-eslint/naming-convention */
5
+ import { decode } from "jsonwebtoken";
6
+ import { getStorage } from "./storage.js";
7
+
8
+ var _thunder = /*#__PURE__*/_classPrivateFieldLooseKey("thunder");
9
+
10
+ export class SecrecyAppClient {
11
+ // #client: SecrecyClient;
12
+ // #keys: KeyPair;
13
+ constructor(uaJwt, _client, _keys, thunder) {
14
+ Object.defineProperty(this, _thunder, {
15
+ writable: true,
16
+ value: void 0
17
+ });
18
+ this.jwt = uaJwt;
19
+ this.jwtDecoded = decode(uaJwt); // this.#client = client;
20
+ // this.#keys = keys;
21
+
22
+ _classPrivateFieldLooseBase(this, _thunder)[_thunder] = thunder;
23
+ }
24
+
25
+ get userId() {
26
+ var _this$jwtDecoded$sub;
27
+
28
+ return (_this$jwtDecoded$sub = this.jwtDecoded.sub) != null ? _this$jwtDecoded$sub : "";
29
+ }
30
+
31
+ async getJwt() {
32
+ // TODO useful?
33
+ // if (this.jwtDecoded.exp && this.jwtDecoded.exp * 1000 < Date.now()) {
34
+ // return this.jwt;
35
+ // }
36
+ const {
37
+ getJwt
38
+ } = await _classPrivateFieldLooseBase(this, _thunder)[_thunder]("query")({
39
+ getJwt: [{
40
+ includeEmail: !!this.jwtDecoded.email
41
+ }, {
42
+ "...on ErrorAccessDenied": {
43
+ __typename: true,
44
+ message: true
45
+ },
46
+ "...on JwtResponse": {
47
+ __typename: true,
48
+ jwt: true
49
+ }
50
+ }]
51
+ });
52
+
53
+ if (!getJwt) {
54
+ return this.jwt;
55
+ }
56
+
57
+ if (getJwt.__typename === "ErrorAccessDenied") {
58
+ throw new Error(getJwt.message);
59
+ }
60
+
61
+ this.jwt = getJwt.jwt;
62
+ this.jwtDecoded = decode(getJwt.jwt);
63
+ const sessionStorage = getStorage(true);
64
+ const localStorage = getStorage(false);
65
+ const sessionJwt = sessionStorage.jwt.load();
66
+ const localJwt = localStorage.jwt.load();
67
+
68
+ if (sessionJwt) {
69
+ sessionStorage.jwt.save(getJwt.jwt);
70
+ }
71
+
72
+ if (localJwt) {
73
+ localStorage.jwt.save(getJwt.jwt);
74
+ }
75
+
76
+ return getJwt.jwt;
77
+ }
78
+
79
+ async updateNotifications(notifications) {
80
+ const {
81
+ updateAppNotifications
82
+ } = await _classPrivateFieldLooseBase(this, _thunder)[_thunder]("mutation", {
83
+ scalars: {
84
+ DateTime: {
85
+ decode: e => new Date(e),
86
+ encode: e => e.toISOString()
87
+ }
88
+ }
89
+ })({
90
+ updateAppNotifications: [notifications, {
91
+ "...on ErrorAccessDenied": {
92
+ __typename: true,
93
+ message: true
94
+ },
95
+ "...on UpdateAppNotificationsResponse": {
96
+ __typename: true,
97
+ updateAppNotifications: {
98
+ enableAll: true,
99
+ mail: true,
100
+ cloud: true,
101
+ disableAllUntil: true
102
+ }
103
+ }
104
+ }]
105
+ });
106
+
107
+ if (!updateAppNotifications) {
108
+ return null;
109
+ }
110
+
111
+ if (updateAppNotifications.__typename === "ErrorAccessDenied") {
112
+ return updateAppNotifications;
113
+ }
114
+
115
+ if (!updateAppNotifications.updateAppNotifications) {
116
+ return null;
117
+ }
118
+
119
+ return {
120
+ __typename: "SuccessResponse",
121
+ data: updateAppNotifications.updateAppNotifications
122
+ };
123
+ }
124
+
125
+ async notifications() {
126
+ const {
127
+ appNotifications
128
+ } = await _classPrivateFieldLooseBase(this, _thunder)[_thunder]("query", {
129
+ scalars: {
130
+ DateTime: {
131
+ decode: e => new Date(e),
132
+ encode: e => e.toISOString()
133
+ }
134
+ }
135
+ })({
136
+ appNotifications: {
137
+ "...on ErrorAccessDenied": {
138
+ __typename: true,
139
+ message: true
140
+ },
141
+ "...on ErrorNotFound": {
142
+ __typename: true,
143
+ message: true
144
+ },
145
+ "...on UserAppNotifications": {
146
+ __typename: true,
147
+ enableAll: true,
148
+ mail: true,
149
+ cloud: true,
150
+ disableAllUntil: true
151
+ }
152
+ }
153
+ });
154
+
155
+ if (!appNotifications) {
156
+ return null;
157
+ }
158
+
159
+ if (appNotifications.__typename === "ErrorAccessDenied") {
160
+ return appNotifications;
161
+ }
162
+
163
+ if (appNotifications.__typename === "ErrorNotFound") {
164
+ return appNotifications;
165
+ }
166
+
167
+ return {
168
+ __typename: "SuccessResponse",
169
+ data: appNotifications
170
+ };
171
+ }
172
+
173
+ async settings() {
174
+ var _user$user;
175
+
176
+ const {
177
+ user
178
+ } = await _classPrivateFieldLooseBase(this, _thunder)[_thunder]("query")({
179
+ user: [{}, {
180
+ "...on ErrorNotFound": {
181
+ __typename: true,
182
+ message: true
183
+ },
184
+ "...on UserResponse": {
185
+ __typename: true,
186
+ user: {
187
+ appSettings: {
188
+ cloudNodeDaysForDelete: true,
189
+ historyFileDaysForDelete: true,
190
+ historyMaxFileCount: true
191
+ }
192
+ }
193
+ }
194
+ }]
195
+ });
196
+
197
+ if (!user) {
198
+ return null;
199
+ }
200
+
201
+ if (user.__typename === "ErrorNotFound") {
202
+ return user;
203
+ }
204
+
205
+ if (!((_user$user = user.user) != null && _user$user.appSettings)) {
206
+ return null;
207
+ }
208
+
209
+ return {
210
+ __typename: "SuccessResponse",
211
+ data: user.user.appSettings
212
+ };
213
+ }
214
+
215
+ async updateSettings(settings) {
216
+ const {
217
+ updateAppSettings
218
+ } = await _classPrivateFieldLooseBase(this, _thunder)[_thunder]("mutation")({
219
+ updateAppSettings: [settings, {
220
+ "...on ErrorAccessDenied": {
221
+ __typename: true,
222
+ message: true
223
+ },
224
+ "...on ErrorBasic": {
225
+ __typename: true,
226
+ message: true
227
+ },
228
+ "...on UpdateAppSettingsResponse": {
229
+ __typename: true,
230
+ updateAppSettings: {
231
+ cloudNodeDaysForDelete: true,
232
+ historyFileDaysForDelete: true,
233
+ historyMaxFileCount: true
234
+ }
235
+ }
236
+ }]
237
+ });
238
+
239
+ if (!updateAppSettings) {
240
+ return null;
241
+ }
242
+
243
+ if (updateAppSettings.__typename === "ErrorAccessDenied") {
244
+ return updateAppSettings;
245
+ }
246
+
247
+ if (updateAppSettings.__typename === "ErrorBasic") {
248
+ return updateAppSettings;
249
+ }
250
+
251
+ return {
252
+ __typename: "SuccessResponse",
253
+ data: updateAppSettings.updateAppSettings
254
+ };
255
+ }
256
+
257
+ }
258
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["decode","getStorage","SecrecyAppClient","constructor","uaJwt","_client","_keys","thunder","jwt","jwtDecoded","userId","sub","getJwt","includeEmail","email","__typename","message","Error","sessionStorage","localStorage","sessionJwt","load","localJwt","save","updateNotifications","notifications","updateAppNotifications","scalars","DateTime","e","Date","encode","toISOString","enableAll","mail","cloud","disableAllUntil","data","appNotifications","settings","user","appSettings","cloudNodeDaysForDelete","historyFileDaysForDelete","historyMaxFileCount","updateSettings","updateAppSettings"],"sources":["../../src/client/SecrecyAppClient.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/naming-convention */\nimport type {\n  SecrecyClient,\n  SuccessResponse,\n  UserAppNotifications,\n  UserAppSettings\n} from \"../index.js\";\nimport type { KeyPair } from \"../crypto/index.js\";\nimport type { ErrorAccessDenied, ErrorBasic, ErrorNotFound } from \"../error.js\";\nimport type { Thunder } from \"../zeus/index.js\";\nimport type { JwtPayload } from \"jsonwebtoken\";\nimport { decode } from \"jsonwebtoken\";\nimport { getStorage } from \"./storage.js\";\n\nexport class SecrecyAppClient {\n  jwt: string;\n\n  jwtDecoded: JwtPayload;\n\n  // #client: SecrecyClient;\n\n  // #keys: KeyPair;\n\n  #thunder: ReturnType<typeof Thunder>;\n\n  constructor(\n    uaJwt: string,\n    _client: SecrecyClient,\n    _keys: KeyPair,\n    thunder: ReturnType<typeof Thunder>\n  ) {\n    this.jwt = uaJwt;\n    this.jwtDecoded = decode(uaJwt) as JwtPayload;\n    // this.#client = client;\n    // this.#keys = keys;\n    this.#thunder = thunder;\n  }\n\n  get userId(): string {\n    return this.jwtDecoded.sub ?? \"\";\n  }\n\n  async getJwt(): Promise<string> {\n    // TODO useful?\n    // if (this.jwtDecoded.exp && this.jwtDecoded.exp * 1000 < Date.now()) {\n    //   return this.jwt;\n    // }\n\n    const { getJwt } = await this.#thunder(\"query\")({\n      getJwt: [\n        {\n          includeEmail: !!this.jwtDecoded.email\n        },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on JwtResponse\": {\n            __typename: true,\n            jwt: true\n          }\n        }\n      ]\n    });\n\n    if (!getJwt) {\n      return this.jwt;\n    }\n\n    if (getJwt.__typename === \"ErrorAccessDenied\") {\n      throw new Error(getJwt.message);\n    }\n\n    this.jwt = getJwt.jwt;\n    this.jwtDecoded = decode(getJwt.jwt) as JwtPayload;\n\n    const sessionStorage = getStorage(true);\n    const localStorage = getStorage(false);\n\n    const sessionJwt = sessionStorage.jwt.load();\n    const localJwt = localStorage.jwt.load();\n\n    if (sessionJwt) {\n      sessionStorage.jwt.save(getJwt.jwt);\n    }\n\n    if (localJwt) {\n      localStorage.jwt.save(getJwt.jwt);\n    }\n\n    return getJwt.jwt;\n  }\n\n  async updateNotifications(\n    notifications: Partial<UserAppNotifications>\n  ): Promise<SuccessResponse<UserAppNotifications> | ErrorAccessDenied | null> {\n    const { updateAppNotifications } = await this.#thunder(\"mutation\", {\n      scalars: {\n        DateTime: {\n          decode: (e: unknown) => new Date(e as string),\n          encode: (e: unknown) => (e as Date).toISOString()\n        }\n      }\n    })({\n      updateAppNotifications: [\n        notifications,\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on UpdateAppNotificationsResponse\": {\n            __typename: true,\n            updateAppNotifications: {\n              enableAll: true,\n              mail: true,\n              cloud: true,\n              disableAllUntil: true\n            }\n          }\n        }\n      ]\n    });\n\n    if (!updateAppNotifications) {\n      return null;\n    }\n\n    if (updateAppNotifications.__typename === \"ErrorAccessDenied\") {\n      return updateAppNotifications;\n    }\n\n    if (!updateAppNotifications.updateAppNotifications) {\n      return null;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: updateAppNotifications.updateAppNotifications\n    };\n  }\n\n  async notifications(): Promise<\n    | SuccessResponse<UserAppNotifications>\n    | ErrorAccessDenied\n    | ErrorNotFound\n    | null\n  > {\n    const { appNotifications } = await this.#thunder(\"query\", {\n      scalars: {\n        DateTime: {\n          decode: (e: unknown) => new Date(e as string),\n          encode: (e: unknown) => (e as Date).toISOString()\n        }\n      }\n    })({\n      appNotifications: {\n        \"...on ErrorAccessDenied\": {\n          __typename: true,\n          message: true\n        },\n        \"...on ErrorNotFound\": {\n          __typename: true,\n          message: true\n        },\n        \"...on UserAppNotifications\": {\n          __typename: true,\n          enableAll: true,\n          mail: true,\n          cloud: true,\n          disableAllUntil: true\n        }\n      }\n    });\n\n    if (!appNotifications) {\n      return null;\n    }\n\n    if (appNotifications.__typename === \"ErrorAccessDenied\") {\n      return appNotifications;\n    }\n\n    if (appNotifications.__typename === \"ErrorNotFound\") {\n      return appNotifications;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: appNotifications\n    };\n  }\n\n  async settings(): Promise<\n    SuccessResponse<UserAppSettings> | ErrorNotFound | null\n  > {\n    const { user } = await this.#thunder(\"query\")({\n      user: [\n        {},\n        {\n          \"...on ErrorNotFound\": {\n            __typename: true,\n            message: true\n          },\n          \"...on UserResponse\": {\n            __typename: true,\n            user: {\n              appSettings: {\n                cloudNodeDaysForDelete: true,\n                historyFileDaysForDelete: true,\n                historyMaxFileCount: true\n              }\n            }\n          }\n        }\n      ]\n    });\n\n    if (!user) {\n      return null;\n    }\n\n    if (user.__typename === \"ErrorNotFound\") {\n      return user;\n    }\n\n    if (!user.user?.appSettings) {\n      return null;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: user.user.appSettings\n    };\n  }\n\n  async updateSettings(\n    settings: Partial<UserAppSettings>\n  ): Promise<\n    SuccessResponse<UserAppSettings> | ErrorAccessDenied | ErrorBasic | null\n  > {\n    const { updateAppSettings } = await this.#thunder(\"mutation\")({\n      updateAppSettings: [\n        settings,\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ErrorBasic\": {\n            __typename: true,\n            message: true\n          },\n          \"...on UpdateAppSettingsResponse\": {\n            __typename: true,\n            updateAppSettings: {\n              cloudNodeDaysForDelete: true,\n              historyFileDaysForDelete: true,\n              historyMaxFileCount: true\n            }\n          }\n        }\n      ]\n    });\n\n    if (!updateAppSettings) {\n      return null;\n    }\n\n    if (updateAppSettings.__typename === \"ErrorAccessDenied\") {\n      return updateAppSettings;\n    }\n\n    if (updateAppSettings.__typename === \"ErrorBasic\") {\n      return updateAppSettings;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: updateAppSettings.updateAppSettings\n    };\n  }\n}\n"],"mappings":"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"}
@@ -0,0 +1,89 @@
1
+ import type { DownloadProgress, ProgressCallback, SecrecyClient, SuccessResponse } from "../index.js";
2
+ import type { KeyPair } from "../crypto/index.js";
3
+ import type { ErrorAccessDenied, ErrorBasic, ErrorLimit, ErrorNotExist, ErrorNotFound } from "../error.js";
4
+ import type { NodeType, Rights, Thunder } from "../zeus/index.js";
5
+ import type { FileMetadata, Node, NodeFull } from "./types/index.js";
6
+ export declare class SecrecyCloudClient {
7
+ #private;
8
+ constructor(client: SecrecyClient, keys: KeyPair, thunder: ReturnType<typeof Thunder>);
9
+ addFileToHistory({ fileId, nodeId }: {
10
+ fileId: string;
11
+ nodeId: string;
12
+ }): Promise<SuccessResponse<Node> | ErrorAccessDenied | ErrorNotExist | null>;
13
+ uploadFile({ file, encryptProgress, uploadProgress, signal }: {
14
+ file: globalThis.File | Uint8Array;
15
+ encryptProgress?: ProgressCallback;
16
+ uploadProgress?: ProgressCallback;
17
+ signal?: AbortSignal;
18
+ }): Promise<SuccessResponse<string> | ErrorAccessDenied | ErrorLimit | ErrorNotFound | null>;
19
+ uploadFileInCloud({ file, name, nodeId, encryptProgress, uploadProgress, signal }: {
20
+ file: globalThis.File | Uint8Array;
21
+ name: string;
22
+ nodeId?: string;
23
+ encryptProgress?: ProgressCallback;
24
+ uploadProgress?: ProgressCallback;
25
+ signal?: AbortSignal;
26
+ }): Promise<SuccessResponse<NodeFull> | ErrorAccessDenied | ErrorLimit | ErrorNotFound | ErrorBasic | ErrorNotExist | null>;
27
+ deletedNodes(): Promise<SuccessResponse<Node[]> | ErrorAccessDenied | null>;
28
+ sharedNodes(): Promise<SuccessResponse<Node[]> | ErrorAccessDenied | null>;
29
+ nodesSharedWithMe(type?: NodeType | null | undefined): Promise<SuccessResponse<Node[]> | ErrorAccessDenied | null>;
30
+ deleteNodeSharing({ nodeId, userId }: {
31
+ nodeId: string;
32
+ userId: string;
33
+ }): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null>;
34
+ duplicateNode({ nodeId, folderId, customName }: {
35
+ nodeId: string;
36
+ folderId?: string | null | undefined;
37
+ customName?: string | null | undefined;
38
+ }): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorNotFound | null>;
39
+ deleteNodeCloudTrash({ ids }: {
40
+ ids: Array<string>;
41
+ }): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null>;
42
+ createFolder({ name, parentFolderId }: {
43
+ name: string;
44
+ parentFolderId?: string | null;
45
+ }): Promise<SuccessResponse<NodeFull> | ErrorAccessDenied | ErrorNotExist | null>;
46
+ node({ id, deleted }?: {
47
+ id?: string | null | undefined;
48
+ deleted?: boolean | null | undefined;
49
+ }): Promise<SuccessResponse<NodeFull> | ErrorAccessDenied | null>;
50
+ file({ id }: {
51
+ id: string;
52
+ }): Promise<SuccessResponse<FileMetadata> | ErrorAccessDenied | null>;
53
+ shareNode({ nodeId, userId, rights }: {
54
+ nodeId: string;
55
+ userId: string;
56
+ rights: Rights;
57
+ }): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorNotFound | null>;
58
+ updateNode({ nodeId, name, isFavorite, deletedAt }: {
59
+ nodeId: string;
60
+ name?: string | null | undefined;
61
+ isFavorite?: boolean | null | undefined;
62
+ deletedAt?: Date | null | undefined;
63
+ }): Promise<SuccessResponse<NodeFull> | ErrorAccessDenied | ErrorNotExist | null>;
64
+ fileContent({ fileId, onDownloadProgress, progressDecrypt, signal }: {
65
+ fileId: string;
66
+ onDownloadProgress?: (progress: DownloadProgress) => void;
67
+ progressDecrypt?: ProgressCallback;
68
+ signal?: AbortSignal;
69
+ }): Promise<SuccessResponse<Uint8Array> | ErrorAccessDenied | ErrorBasic | null>;
70
+ deleteFile({ fileId, nodeId }: {
71
+ fileId: string;
72
+ nodeId: string;
73
+ }): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorNotExist | null>;
74
+ deleteNode({ nodeId }: {
75
+ nodeId: string;
76
+ }): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null>;
77
+ emptyTrash(): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null>;
78
+ recoverNode(id: string): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorNotExist | null>;
79
+ moveNodes({ nodeIds, parentNodeId }: {
80
+ nodeIds: string[];
81
+ parentNodeId?: string | null | undefined;
82
+ }): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null>;
83
+ saveInCloud({ fileId, name, nodeId }: {
84
+ fileId: string;
85
+ name: string;
86
+ nodeId?: string;
87
+ }): Promise<SuccessResponse<NodeFull> | ErrorAccessDenied | ErrorBasic | ErrorLimit | ErrorNotFound | ErrorNotExist | null>;
88
+ private perNode;
89
+ }