@secrecy/lib 1.0.0-dev.3 → 1.0.0-dev.32
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.
- package/{lib → dist}/BaseClient.d.ts +36 -24
- package/dist/BaseClient.js +2325 -0
- package/{lib → dist}/PopupTools.d.ts +1 -1
- package/{lib → dist}/PopupTools.js +3 -3
- package/{lib → dist}/ZeusThunder.d.ts +0 -0
- package/dist/ZeusThunder.js +113 -0
- package/{lib → dist}/cache.d.ts +0 -0
- package/{lib → dist}/cache.js +0 -0
- package/dist/client/admin/index.d.ts +11 -0
- package/dist/client/admin/index.js +198 -0
- package/{lib → dist}/client/convert/file.d.ts +0 -0
- package/{lib → dist}/client/convert/file.js +2 -2
- package/{lib → dist}/client/convert/folder.d.ts +0 -1
- package/dist/client/convert/folder.js +264 -0
- package/{lib → dist}/client/convert/mail.d.ts +0 -0
- package/{lib → dist}/client/convert/mail.js +0 -0
- package/{lib → dist}/client/convert/vFile.d.ts +0 -0
- package/{lib → dist}/client/convert/vFile.js +2 -2
- package/{lib → dist}/client/helpers.d.ts +1 -1
- package/{lib → dist}/client/helpers.js +1 -3
- package/dist/client/index.d.ts +172 -0
- package/dist/client/index.js +6215 -0
- package/{lib → dist}/client/storage.d.ts +0 -0
- package/{lib → dist}/client/storage.js +0 -0
- package/{lib → dist}/client/types/File.d.ts +0 -0
- package/{lib → dist}/client/types/File.js +1 -0
- package/{lib → dist}/client/types/FilesOnUsersOnApplications.d.ts +0 -0
- package/{lib → dist}/client/types/FilesOnUsersOnApplications.js +1 -0
- package/{lib → dist}/client/types/Folder.d.ts +0 -0
- package/{lib → dist}/client/types/Folder.js +0 -0
- package/{lib → dist}/client/types/Inputs.d.ts +0 -0
- package/{lib → dist}/client/types/Inputs.js +1 -0
- package/dist/client/types/UserAppNotifications.d.ts +6 -0
- package/dist/client/types/UserAppNotifications.js +3 -0
- package/{lib → dist}/client/types/UserAppSettings.d.ts +0 -1
- package/{lib → dist}/client/types/UserAppSettings.js +1 -0
- package/{lib → dist}/client/types/VFile.d.ts +0 -0
- package/{lib → dist}/client/types/VFile.js +0 -0
- package/{lib → dist}/client/types/index.d.ts +1 -0
- package/dist/client/types/index.js +10 -0
- package/{lib → dist}/client/types/queries.d.ts +0 -0
- package/{lib → dist}/client/types/queries.js +2 -2
- package/{lib → dist}/crypto/file.d.ts +0 -0
- package/{lib → dist}/crypto/file.js +0 -0
- package/{lib → dist}/crypto/index.d.ts +0 -0
- package/dist/crypto/index.js +45 -0
- package/dist/error.d.ts +30 -0
- package/dist/error.js +3 -0
- package/{lib → dist}/index.d.ts +4 -2
- package/dist/index.js +42 -0
- package/{lib → dist}/minify/index.d.ts +0 -0
- package/{lib → dist}/minify/index.js +0 -0
- package/{lib → dist}/minify/lz4.d.ts +0 -0
- package/{lib → dist}/minify/lz4.js +0 -0
- package/{lib → dist}/sodium.d.ts +0 -0
- package/{lib → dist}/sodium.js +0 -0
- package/{lib → dist}/utils/store-buddy.d.ts +0 -0
- package/{lib → dist}/utils/store-buddy.js +0 -0
- package/{lib → dist}/utils/time.d.ts +0 -0
- package/{lib → dist}/utils/time.js +0 -0
- package/{lib → dist}/utils.d.ts +0 -0
- package/{lib → dist}/utils.js +0 -0
- package/{lib → dist}/worker/__mock__/sodium.worker.d.ts +0 -0
- package/dist/worker/__mock__/sodium.worker.js +46 -0
- package/{lib → dist}/worker/md5.d.ts +0 -0
- package/{lib → dist}/worker/md5.js +0 -0
- package/dist/worker/sodium.d.ts +3 -0
- package/dist/worker/sodium.js +155 -0
- package/{lib → dist}/worker/workerCodes.d.ts +0 -0
- package/{lib → dist}/worker/workerCodes.js +0 -0
- package/{lib → dist}/zeus/const.d.ts +0 -0
- package/dist/zeus/const.js +2287 -0
- package/dist/zeus/index.d.ts +3961 -0
- package/dist/zeus/index.js +549 -0
- package/package.json +45 -42
- package/lib/BaseClient.js +0 -1332
- package/lib/ZeusThunder.js +0 -112
- package/lib/client/convert/folder.js +0 -301
- package/lib/client/index.d.ts +0 -167
- package/lib/client/index.js +0 -3699
- package/lib/client/types/index.js +0 -8
- package/lib/crypto/index.js +0 -37
- package/lib/index.js +0 -40
- package/lib/worker/__mock__/sodium.worker.js +0 -57
- package/lib/worker/sodium.d.ts +0 -3
- package/lib/worker/sodium.js +0 -141
- package/lib/zeus/const.js +0 -1609
- package/lib/zeus/index.d.ts +0 -26109
- package/lib/zeus/index.js +0 -548
|
@@ -0,0 +1,264 @@
|
|
|
1
|
+
import _defineProperty from "@babel/runtime/helpers/defineProperty";
|
|
2
|
+
import _asyncToGenerator from "@babel/runtime/helpers/asyncToGenerator";
|
|
3
|
+
import _regeneratorRuntime from "@babel/runtime/regenerator";
|
|
4
|
+
|
|
5
|
+
function _createForOfIteratorHelperLoose(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (it) return (it = it.call(o)).next.bind(it); if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; return function () { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
6
|
+
|
|
7
|
+
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
|
8
|
+
|
|
9
|
+
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
|
|
10
|
+
|
|
11
|
+
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
12
|
+
|
|
13
|
+
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
14
|
+
|
|
15
|
+
import { sodium } from "../../sodium.js";
|
|
16
|
+
import { decryptCryptoBox } from "../../crypto/index.js";
|
|
17
|
+
import { gqlVFileToInternal, internalVFileToVFile } from "./vFile.js";
|
|
18
|
+
import { foldersCache } from "../../cache.js";
|
|
19
|
+
import { decryptSecretstream } from "../../crypto/file.js";
|
|
20
|
+
export function gqlFolderToInternal(_x, _x2) {
|
|
21
|
+
return _gqlFolderToInternal.apply(this, arguments);
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
function _gqlFolderToInternal() {
|
|
25
|
+
_gqlFolderToInternal = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee(gql, keyPair) {
|
|
26
|
+
var internal, key, _iterator2, _step2, b, _key;
|
|
27
|
+
|
|
28
|
+
return _regeneratorRuntime.wrap(function _callee$(_context) {
|
|
29
|
+
while (1) {
|
|
30
|
+
switch (_context.prev = _context.next) {
|
|
31
|
+
case 0:
|
|
32
|
+
if (gql.userApp) {
|
|
33
|
+
_context.next = 2;
|
|
34
|
+
break;
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
throw "Can't access folder " + gql.id;
|
|
38
|
+
|
|
39
|
+
case 2:
|
|
40
|
+
internal = {
|
|
41
|
+
id: gql.id,
|
|
42
|
+
userApp: gql.userApp,
|
|
43
|
+
name: gql.name,
|
|
44
|
+
isFavorite: gql.isFavorite,
|
|
45
|
+
breadcrumb: gql.breadcrumb,
|
|
46
|
+
createdBy: gql.createdBy.user,
|
|
47
|
+
createdAt: new Date(gql.createdAt),
|
|
48
|
+
updatedAt: new Date(gql.updatedAt),
|
|
49
|
+
deletedAt: gql.deletedAt ? new Date(gql.deletedAt) : null,
|
|
50
|
+
users: gql.userApps.map(function (u) {
|
|
51
|
+
return [u.userApp.user, u.rights];
|
|
52
|
+
})
|
|
53
|
+
};
|
|
54
|
+
internal.userApp = _objectSpread({}, gql.userApp);
|
|
55
|
+
|
|
56
|
+
if (!gql.userApp.nameKey) {
|
|
57
|
+
_context.next = 12;
|
|
58
|
+
break;
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
key = decryptCryptoBox(sodium.from_hex(gql.userApp.nameKey), gql.createdBy.user.publicKey, keyPair.privateKey);
|
|
62
|
+
_context.t0 = sodium;
|
|
63
|
+
_context.next = 9;
|
|
64
|
+
return decryptSecretstream(key, sodium.from_hex(internal.name));
|
|
65
|
+
|
|
66
|
+
case 9:
|
|
67
|
+
_context.t1 = _context.sent;
|
|
68
|
+
internal.name = _context.t0.to_string.call(_context.t0, _context.t1);
|
|
69
|
+
internal.userApp.nameKey = sodium.to_hex(key);
|
|
70
|
+
|
|
71
|
+
case 12:
|
|
72
|
+
_iterator2 = _createForOfIteratorHelperLoose(internal.breadcrumb);
|
|
73
|
+
|
|
74
|
+
case 13:
|
|
75
|
+
if ((_step2 = _iterator2()).done) {
|
|
76
|
+
_context.next = 26;
|
|
77
|
+
break;
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
b = _step2.value;
|
|
81
|
+
|
|
82
|
+
if (b.nameKey) {
|
|
83
|
+
_context.next = 17;
|
|
84
|
+
break;
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
return _context.abrupt("continue", 24);
|
|
88
|
+
|
|
89
|
+
case 17:
|
|
90
|
+
_key = decryptCryptoBox(sodium.from_hex(b.nameKey), b.pubKey, keyPair.privateKey);
|
|
91
|
+
b.nameKey = sodium.to_hex(_key);
|
|
92
|
+
_context.t2 = sodium;
|
|
93
|
+
_context.next = 22;
|
|
94
|
+
return decryptSecretstream(_key, sodium.from_hex(b.name));
|
|
95
|
+
|
|
96
|
+
case 22:
|
|
97
|
+
_context.t3 = _context.sent;
|
|
98
|
+
b.name = _context.t2.to_string.call(_context.t2, _context.t3);
|
|
99
|
+
|
|
100
|
+
case 24:
|
|
101
|
+
_context.next = 13;
|
|
102
|
+
break;
|
|
103
|
+
|
|
104
|
+
case 26:
|
|
105
|
+
foldersCache.set(internal.id, internal);
|
|
106
|
+
return _context.abrupt("return", internal);
|
|
107
|
+
|
|
108
|
+
case 28:
|
|
109
|
+
case "end":
|
|
110
|
+
return _context.stop();
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
}, _callee);
|
|
114
|
+
}));
|
|
115
|
+
return _gqlFolderToInternal.apply(this, arguments);
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
export function gqlFolderFullToInternalFull(_x3, _x4) {
|
|
119
|
+
return _gqlFolderFullToInternalFull.apply(this, arguments);
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
function _gqlFolderFullToInternalFull() {
|
|
123
|
+
_gqlFolderFullToInternalFull = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee2(gql, keyPair) {
|
|
124
|
+
var f;
|
|
125
|
+
return _regeneratorRuntime.wrap(function _callee2$(_context2) {
|
|
126
|
+
while (1) {
|
|
127
|
+
switch (_context2.prev = _context2.next) {
|
|
128
|
+
case 0:
|
|
129
|
+
_context2.next = 2;
|
|
130
|
+
return gqlFolderToInternal(gql, keyPair);
|
|
131
|
+
|
|
132
|
+
case 2:
|
|
133
|
+
f = _context2.sent;
|
|
134
|
+
_context2.t0 = _objectSpread;
|
|
135
|
+
_context2.t1 = _objectSpread({}, f);
|
|
136
|
+
_context2.t2 = {};
|
|
137
|
+
_context2.next = 8;
|
|
138
|
+
return Promise.all(gql.vFiles.filter(function (f) {
|
|
139
|
+
return f.userApp;
|
|
140
|
+
}).map(function (vFile) {
|
|
141
|
+
return gqlVFileToInternal(vFile, keyPair);
|
|
142
|
+
}));
|
|
143
|
+
|
|
144
|
+
case 8:
|
|
145
|
+
_context2.t3 = _context2.sent;
|
|
146
|
+
|
|
147
|
+
if (!gql.parentFolder) {
|
|
148
|
+
_context2.next = 15;
|
|
149
|
+
break;
|
|
150
|
+
}
|
|
151
|
+
|
|
152
|
+
_context2.next = 12;
|
|
153
|
+
return gqlFolderToInternal(gql.parentFolder, keyPair);
|
|
154
|
+
|
|
155
|
+
case 12:
|
|
156
|
+
_context2.t4 = _context2.sent;
|
|
157
|
+
_context2.next = 16;
|
|
158
|
+
break;
|
|
159
|
+
|
|
160
|
+
case 15:
|
|
161
|
+
_context2.t4 = null;
|
|
162
|
+
|
|
163
|
+
case 16:
|
|
164
|
+
_context2.t5 = _context2.t4;
|
|
165
|
+
_context2.next = 19;
|
|
166
|
+
return Promise.all(gql.subfolders.map(function (s) {
|
|
167
|
+
return gqlFolderToInternal(s, keyPair);
|
|
168
|
+
}));
|
|
169
|
+
|
|
170
|
+
case 19:
|
|
171
|
+
_context2.t6 = _context2.sent;
|
|
172
|
+
_context2.t7 = {
|
|
173
|
+
vFiles: _context2.t3,
|
|
174
|
+
parentFolder: _context2.t5,
|
|
175
|
+
subfolders: _context2.t6
|
|
176
|
+
};
|
|
177
|
+
return _context2.abrupt("return", (0, _context2.t0)(_context2.t1, _context2.t2, _context2.t7));
|
|
178
|
+
|
|
179
|
+
case 22:
|
|
180
|
+
case "end":
|
|
181
|
+
return _context2.stop();
|
|
182
|
+
}
|
|
183
|
+
}
|
|
184
|
+
}, _callee2);
|
|
185
|
+
}));
|
|
186
|
+
return _gqlFolderFullToInternalFull.apply(this, arguments);
|
|
187
|
+
}
|
|
188
|
+
|
|
189
|
+
export function internalFolderToFolder(internal) {
|
|
190
|
+
var folder = _objectSpread({}, internal);
|
|
191
|
+
|
|
192
|
+
for (var _iterator = _createForOfIteratorHelperLoose(folder.breadcrumb), _step; !(_step = _iterator()).done;) {
|
|
193
|
+
var b = _step.value;
|
|
194
|
+
// @ts-ignore
|
|
195
|
+
delete b.nameKey;
|
|
196
|
+
} // @ts-ignore
|
|
197
|
+
|
|
198
|
+
|
|
199
|
+
delete folder.nameKey;
|
|
200
|
+
return folder;
|
|
201
|
+
}
|
|
202
|
+
export function internalFolderFullToFolderFull(internal) {
|
|
203
|
+
return _objectSpread(_objectSpread({}, internalFolderToFolder(internal)), {}, {
|
|
204
|
+
vFiles: internal.vFiles.map(internalVFileToVFile),
|
|
205
|
+
parentFolder: internal.parentFolder ? internalFolderToFolder(internal.parentFolder) : null,
|
|
206
|
+
subfolders: internal.subfolders.map(internalFolderToFolder)
|
|
207
|
+
});
|
|
208
|
+
}
|
|
209
|
+
export function gqlFolderToExternalFolderFull(_x5, _x6) {
|
|
210
|
+
return _gqlFolderToExternalFolderFull.apply(this, arguments);
|
|
211
|
+
}
|
|
212
|
+
|
|
213
|
+
function _gqlFolderToExternalFolderFull() {
|
|
214
|
+
_gqlFolderToExternalFolderFull = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee3(gql, keyPair) {
|
|
215
|
+
return _regeneratorRuntime.wrap(function _callee3$(_context3) {
|
|
216
|
+
while (1) {
|
|
217
|
+
switch (_context3.prev = _context3.next) {
|
|
218
|
+
case 0:
|
|
219
|
+
_context3.t0 = internalFolderFullToFolderFull;
|
|
220
|
+
_context3.next = 3;
|
|
221
|
+
return gqlFolderFullToInternalFull(gql, keyPair);
|
|
222
|
+
|
|
223
|
+
case 3:
|
|
224
|
+
_context3.t1 = _context3.sent;
|
|
225
|
+
return _context3.abrupt("return", (0, _context3.t0)(_context3.t1));
|
|
226
|
+
|
|
227
|
+
case 5:
|
|
228
|
+
case "end":
|
|
229
|
+
return _context3.stop();
|
|
230
|
+
}
|
|
231
|
+
}
|
|
232
|
+
}, _callee3);
|
|
233
|
+
}));
|
|
234
|
+
return _gqlFolderToExternalFolderFull.apply(this, arguments);
|
|
235
|
+
}
|
|
236
|
+
|
|
237
|
+
export function gqlFolderToExternal(_x7, _x8) {
|
|
238
|
+
return _gqlFolderToExternal.apply(this, arguments);
|
|
239
|
+
}
|
|
240
|
+
|
|
241
|
+
function _gqlFolderToExternal() {
|
|
242
|
+
_gqlFolderToExternal = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee4(gql, keyPair) {
|
|
243
|
+
return _regeneratorRuntime.wrap(function _callee4$(_context4) {
|
|
244
|
+
while (1) {
|
|
245
|
+
switch (_context4.prev = _context4.next) {
|
|
246
|
+
case 0:
|
|
247
|
+
_context4.t0 = internalFolderToFolder;
|
|
248
|
+
_context4.next = 3;
|
|
249
|
+
return gqlFolderToInternal(gql, keyPair);
|
|
250
|
+
|
|
251
|
+
case 3:
|
|
252
|
+
_context4.t1 = _context4.sent;
|
|
253
|
+
return _context4.abrupt("return", (0, _context4.t0)(_context4.t1));
|
|
254
|
+
|
|
255
|
+
case 5:
|
|
256
|
+
case "end":
|
|
257
|
+
return _context4.stop();
|
|
258
|
+
}
|
|
259
|
+
}
|
|
260
|
+
}, _callee4);
|
|
261
|
+
}));
|
|
262
|
+
return _gqlFolderToExternal.apply(this, arguments);
|
|
263
|
+
}
|
|
264
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/client/convert/folder.ts"],"names":["sodium","decryptCryptoBox","gqlVFileToInternal","internalVFileToVFile","foldersCache","decryptSecretstream","gqlFolderToInternal","gql","keyPair","userApp","id","internal","name","isFavorite","breadcrumb","createdBy","user","createdAt","Date","updatedAt","deletedAt","users","userApps","map","u","rights","nameKey","key","from_hex","publicKey","privateKey","to_string","to_hex","b","pubKey","set","gqlFolderFullToInternalFull","f","Promise","all","vFiles","filter","vFile","parentFolder","subfolders","s","internalFolderToFolder","folder","internalFolderFullToFolderFull","gqlFolderToExternalFolderFull","gqlFolderToExternal"],"mappings":";;;;;;;;;;;;;;AAAA,SAASA,MAAT,QAAuB,iBAAvB;AAEA,SAASC,gBAAT,QAAiC,uBAAjC;AASA,SAASC,kBAAT,EAA6BC,oBAA7B,QAAyD,YAAzD;AACA,SAASC,YAAT,QAA6B,gBAA7B;AACA,SAASC,mBAAT,QAAoC,sBAApC;AAEA,gBAAsBC,mBAAtB;AAAA;AAAA;;;kFAAO,iBACLC,GADK,EAELC,OAFK;AAAA;;AAAA;AAAA;AAAA;AAAA;AAAA,gBAIAD,GAAG,CAACE,OAJJ;AAAA;AAAA;AAAA;;AAAA,2CAK0BF,GAAG,CAACG,EAL9B;;AAAA;AAOCC,YAAAA,QAPD,GAO4B;AAC/BD,cAAAA,EAAE,EAAEH,GAAG,CAACG,EADuB;AAE/BD,cAAAA,OAAO,EAAEF,GAAG,CAACE,OAFkB;AAG/BG,cAAAA,IAAI,EAAEL,GAAG,CAACK,IAHqB;AAI/BC,cAAAA,UAAU,EAAEN,GAAG,CAACM,UAJe;AAK/BC,cAAAA,UAAU,EAAEP,GAAG,CAACO,UALe;AAM/BC,cAAAA,SAAS,EAAER,GAAG,CAACQ,SAAJ,CAAcC,IANM;AAO/BC,cAAAA,SAAS,EAAE,IAAIC,IAAJ,CAASX,GAAG,CAACU,SAAb,CAPoB;AAQ/BE,cAAAA,SAAS,EAAE,IAAID,IAAJ,CAASX,GAAG,CAACY,SAAb,CARoB;AAS/BC,cAAAA,SAAS,EAAEb,GAAG,CAACa,SAAJ,GAAgB,IAAIF,IAAJ,CAASX,GAAG,CAACa,SAAb,CAAhB,GAA0C,IATtB;AAU/BC,cAAAA,KAAK,EAAEd,GAAG,CAACe,QAAJ,CAAaC,GAAb,CAAiB,UAAAC,CAAC;AAAA,uBAAI,CAACA,CAAC,CAACf,OAAF,CAAUO,IAAX,EAAiBQ,CAAC,CAACC,MAAnB,CAAJ;AAAA,eAAlB;AAVwB,aAP5B;AAoBLd,YAAAA,QAAQ,CAACF,OAAT,qBAAwBF,GAAG,CAACE,OAA5B;;AApBK,iBAsBDF,GAAG,CAACE,OAAJ,CAAYiB,OAtBX;AAAA;AAAA;AAAA;;AAuBGC,YAAAA,GAvBH,GAuBS1B,gBAAgB,CAC1BD,MAAM,CAAC4B,QAAP,CAAgBrB,GAAG,CAACE,OAAJ,CAAYiB,OAA5B,CAD0B,EAE1BnB,GAAG,CAACQ,SAAJ,CAAcC,IAAd,CAAmBa,SAFO,EAG1BrB,OAAO,CAACsB,UAHkB,CAvBzB;AAAA,0BA4Ba9B,MA5Bb;AAAA;AAAA,mBA6BKK,mBAAmB,CAACsB,GAAD,EAAM3B,MAAM,CAAC4B,QAAP,CAAgBjB,QAAQ,CAACC,IAAzB,CAAN,CA7BxB;;AAAA;AAAA;AA4BHD,YAAAA,QAAQ,CAACC,IA5BN,eA4BoBmB,SA5BpB;AAgCHpB,YAAAA,QAAQ,CAACF,OAAT,CAAiBiB,OAAjB,GAA2B1B,MAAM,CAACgC,MAAP,CAAcL,GAAd,CAA3B;;AAhCG;AAAA,yDAmCWhB,QAAQ,CAACG,UAnCpB;;AAAA;AAAA;AAAA;AAAA;AAAA;;AAmCMmB,YAAAA,CAnCN;;AAAA,gBAoCEA,CAAC,CAACP,OApCJ;AAAA;AAAA;AAAA;;AAAA;;AAAA;AAuCGC,YAAAA,IAvCH,GAuCS1B,gBAAgB,CAC1BD,MAAM,CAAC4B,QAAP,CAAgBK,CAAC,CAACP,OAAlB,CAD0B,EAE1BO,CAAC,CAACC,MAFwB,EAG1B1B,OAAO,CAACsB,UAHkB,CAvCzB;AA4CHG,YAAAA,CAAC,CAACP,OAAF,GAAY1B,MAAM,CAACgC,MAAP,CAAcL,IAAd,CAAZ;AA5CG,0BA8CM3B,MA9CN;AAAA;AAAA,mBA+CKK,mBAAmB,CAACsB,IAAD,EAAM3B,MAAM,CAAC4B,QAAP,CAAgBK,CAAC,CAACrB,IAAlB,CAAN,CA/CxB;;AAAA;AAAA;AA8CHqB,YAAAA,CAAC,CAACrB,IA9CC,eA8CamB,SA9Cb;;AAAA;AAAA;AAAA;;AAAA;AAmDL3B,YAAAA,YAAY,CAAC+B,GAAb,CAAiBxB,QAAQ,CAACD,EAA1B,EAA8BC,QAA9B;AAnDK,6CAoDEA,QApDF;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,G;;;;AAuDP,gBAAsByB,2BAAtB;AAAA;AAAA;;;0FAAO,kBACL7B,GADK,EAELC,OAFK;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,mBAIWF,mBAAmB,CAACC,GAAD,EAAMC,OAAN,CAJ9B;;AAAA;AAIC6B,YAAAA,CAJD;AAAA;AAAA,6CAMAA,CANA;AAAA;AAAA;AAAA,mBAOWC,OAAO,CAACC,GAAR,CACZhC,GAAG,CAACiC,MAAJ,CACGC,MADH,CACU,UAAAJ,CAAC;AAAA,qBAAIA,CAAC,CAAC5B,OAAN;AAAA,aADX,EAEGc,GAFH,CAEO,UAAAmB,KAAK;AAAA,qBAAIxC,kBAAkB,CAACwC,KAAD,EAAQlC,OAAR,CAAtB;AAAA,aAFZ,CADY,CAPX;;AAAA;AAAA;;AAAA,iBAYWD,GAAG,CAACoC,YAZf;AAAA;AAAA;AAAA;;AAAA;AAAA,mBAaOrC,mBAAmB,CAACC,GAAG,CAACoC,YAAL,EAAmBnC,OAAnB,CAb1B;;AAAA;AAAA;AAAA;AAAA;;AAAA;AAAA,2BAcC,IAdD;;AAAA;AAAA;AAAA;AAAA,mBAee8B,OAAO,CAACC,GAAR,CAChBhC,GAAG,CAACqC,UAAJ,CAAerB,GAAf,CAAmB,UAAAsB,CAAC;AAAA,qBAAIvC,mBAAmB,CAACuC,CAAD,EAAIrC,OAAJ,CAAvB;AAAA,aAApB,CADgB,CAff;;AAAA;AAAA;AAAA;AAOHgC,cAAAA,MAPG;AAYHG,cAAAA,YAZG;AAeHC,cAAAA,UAfG;AAAA;AAAA;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,G;;;;AAqBP,OAAO,SAASE,sBAAT,CAAgCnC,QAAhC,EAAkE;AACvE,MAAMoC,MAAc,qBACfpC,QADe,CAApB;;AAIA,uDAAgBoC,MAAM,CAACjC,UAAvB,wCAAmC;AAAA,QAAxBmB,CAAwB;AACjC;AACA,WAAOA,CAAC,CAACP,OAAT;AACD,GARsE,CASvE;;;AACA,SAAOqB,MAAM,CAACrB,OAAd;AACA,SAAOqB,MAAP;AACD;AAED,OAAO,SAASC,8BAAT,CACLrC,QADK,EAEO;AACZ,yCACKmC,sBAAsB,CAACnC,QAAD,CAD3B;AAEE6B,IAAAA,MAAM,EAAE7B,QAAQ,CAAC6B,MAAT,CAAgBjB,GAAhB,CAAoBpB,oBAApB,CAFV;AAGEwC,IAAAA,YAAY,EAAEhC,QAAQ,CAACgC,YAAT,GACVG,sBAAsB,CAACnC,QAAQ,CAACgC,YAAV,CADZ,GAEV,IALN;AAMEC,IAAAA,UAAU,EAAEjC,QAAQ,CAACiC,UAAT,CAAoBrB,GAApB,CAAwBuB,sBAAxB;AANd;AAQD;AAED,gBAAsBG,6BAAtB;AAAA;AAAA;;;4FAAO,kBACL1C,GADK,EAELC,OAFK;AAAA;AAAA;AAAA;AAAA;AAAA,2BAIEwC,8BAJF;AAAA;AAAA,mBAKGZ,2BAA2B,CAAC7B,GAAD,EAAMC,OAAN,CAL9B;;AAAA;AAAA;AAAA;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,G;;;;AASP,gBAAsB0C,mBAAtB;AAAA;AAAA;;;kFAAO,kBACL3C,GADK,EAELC,OAFK;AAAA;AAAA;AAAA;AAAA;AAAA,2BAIEsC,sBAJF;AAAA;AAAA,mBAI+BxC,mBAAmB,CAACC,GAAD,EAAMC,OAAN,CAJlD;;AAAA;AAAA;AAAA;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,G","sourcesContent":["import { sodium } from \"../../sodium.js\";\nimport type { KeyPair } from \"../../crypto/index.js\";\nimport { decryptCryptoBox } from \"../../crypto/index.js\";\nimport type {\n  GQLFolder,\n  InternalFolder,\n  Folder,\n  GQLFolderFull,\n  InternalFolderFull,\n  FolderFull\n} from \"../types/index.js\";\nimport { gqlVFileToInternal, internalVFileToVFile } from \"./vFile.js\";\nimport { foldersCache } from \"../../cache.js\";\nimport { decryptSecretstream } from \"../../crypto/file.js\";\n\nexport async function gqlFolderToInternal(\n  gql: GQLFolder,\n  keyPair: KeyPair\n): Promise<InternalFolder> {\n  if (!gql.userApp) {\n    throw `Can't access folder ${gql.id}`;\n  }\n  const internal: InternalFolder = {\n    id: gql.id,\n    userApp: gql.userApp,\n    name: gql.name,\n    isFavorite: gql.isFavorite,\n    breadcrumb: gql.breadcrumb,\n    createdBy: gql.createdBy.user,\n    createdAt: new Date(gql.createdAt),\n    updatedAt: new Date(gql.updatedAt),\n    deletedAt: gql.deletedAt ? new Date(gql.deletedAt) : null,\n    users: gql.userApps.map(u => [u.userApp.user, u.rights])\n  };\n\n  internal.userApp = { ...gql.userApp };\n\n  if (gql.userApp.nameKey) {\n    const key = decryptCryptoBox(\n      sodium.from_hex(gql.userApp.nameKey),\n      gql.createdBy.user.publicKey,\n      keyPair.privateKey\n    );\n    internal.name = sodium.to_string(\n      await decryptSecretstream(key, sodium.from_hex(internal.name))\n    );\n\n    internal.userApp.nameKey = sodium.to_hex(key);\n  }\n\n  for (const b of internal.breadcrumb) {\n    if (!b.nameKey) {\n      continue;\n    }\n    const key = decryptCryptoBox(\n      sodium.from_hex(b.nameKey),\n      b.pubKey,\n      keyPair.privateKey\n    );\n    b.nameKey = sodium.to_hex(key);\n\n    b.name = sodium.to_string(\n      await decryptSecretstream(key, sodium.from_hex(b.name))\n    );\n  }\n\n  foldersCache.set(internal.id, internal);\n  return internal;\n}\n\nexport async function gqlFolderFullToInternalFull(\n  gql: GQLFolderFull,\n  keyPair: KeyPair\n): Promise<InternalFolderFull> {\n  const f = await gqlFolderToInternal(gql, keyPair);\n  return {\n    ...f,\n    vFiles: await Promise.all(\n      gql.vFiles\n        .filter(f => f.userApp)\n        .map(vFile => gqlVFileToInternal(vFile, keyPair))\n    ),\n    parentFolder: gql.parentFolder\n      ? await gqlFolderToInternal(gql.parentFolder, keyPair)\n      : null,\n    subfolders: await Promise.all(\n      gql.subfolders.map(s => gqlFolderToInternal(s, keyPair))\n    )\n  };\n}\n\nexport function internalFolderToFolder(internal: InternalFolder): Folder {\n  const folder: Folder = {\n    ...internal\n  };\n\n  for (const b of folder.breadcrumb) {\n    // @ts-ignore\n    delete b.nameKey;\n  }\n  // @ts-ignore\n  delete folder.nameKey;\n  return folder;\n}\n\nexport function internalFolderFullToFolderFull(\n  internal: InternalFolderFull\n): FolderFull {\n  return {\n    ...internalFolderToFolder(internal),\n    vFiles: internal.vFiles.map(internalVFileToVFile),\n    parentFolder: internal.parentFolder\n      ? internalFolderToFolder(internal.parentFolder)\n      : null,\n    subfolders: internal.subfolders.map(internalFolderToFolder)\n  };\n}\n\nexport async function gqlFolderToExternalFolderFull(\n  gql: GQLFolderFull,\n  keyPair: KeyPair\n): Promise<FolderFull> {\n  return internalFolderFullToFolderFull(\n    await gqlFolderFullToInternalFull(gql, keyPair)\n  );\n}\n\nexport async function gqlFolderToExternal(\n  gql: GQLFolder,\n  keyPair: KeyPair\n): Promise<Folder> {\n  return internalFolderToFolder(await gqlFolderToInternal(gql, keyPair));\n}\n"]}
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
@@ -2,9 +2,9 @@ import _defineProperty from "@babel/runtime/helpers/defineProperty";
|
|
|
2
2
|
import _asyncToGenerator from "@babel/runtime/helpers/asyncToGenerator";
|
|
3
3
|
import _regeneratorRuntime from "@babel/runtime/regenerator";
|
|
4
4
|
|
|
5
|
-
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object);
|
|
5
|
+
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
6
6
|
|
|
7
|
-
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]
|
|
7
|
+
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
8
8
|
|
|
9
9
|
import { vFilesCache } from "../../cache.js";
|
|
10
10
|
import { decryptCryptoBox } from "../../crypto/index.js";
|
|
@@ -11,7 +11,7 @@ export declare type HashInfos = {
|
|
|
11
11
|
email: boolean;
|
|
12
12
|
};
|
|
13
13
|
};
|
|
14
|
-
export declare type SecrecyEnv = "dev" | "
|
|
14
|
+
export declare type SecrecyEnv = "dev" | "prod";
|
|
15
15
|
export declare type UseSecrecyParams = Omit<HashInfos, "appUrl"> & {
|
|
16
16
|
env: SecrecyEnv;
|
|
17
17
|
session?: boolean | undefined;
|
|
@@ -71,8 +71,6 @@ export function login(_temp) {
|
|
|
71
71
|
|
|
72
72
|
if (env === "dev") {
|
|
73
73
|
envStr = "dev.";
|
|
74
|
-
} else if (env === "staging") {
|
|
75
|
-
envStr = "staging.";
|
|
76
74
|
}
|
|
77
75
|
|
|
78
76
|
var lang = document.documentElement.lang;
|
|
@@ -113,4 +111,4 @@ export function login(_temp) {
|
|
|
113
111
|
}
|
|
114
112
|
});
|
|
115
113
|
}
|
|
116
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/client/helpers.ts"],"names":["SecrecyClient","popup","getStorage","parseInfos","window","location","hash","substr","res","JSON","parse","atob","getSecrecyClient","env","session","storage","uaSession","userAppSession","load","uaKeys","userAppKeys","uaJwt","jwt","infos","save","keys","login","appCode","path","redirect","scopes","backPath","Promise","resolve","reject","appUrl","origin","includes","client","data","btoa","stringify","replaceAll","envStr","lang","document","documentElement","url","validate","href","err"],"mappings":"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","sourcesContent":["import { SecrecyClient } from \"./index.js\";\nimport { popup } from \"../PopupTools.js\";\nimport type { SecrecyUserApp } from \"./types/index.js\";\nimport { getStorage } from \"./storage.js\";\n\nexport function parseInfos(): SecrecyUserApp | null {\n  if (!window.location.hash) {\n    return null;\n  }\n  const hash = window.location.hash.substr(1);\n  try {\n    const res = JSON.parse(atob(hash));\n    window.location.hash = \"\";\n    // TODO Add object content validation\n    return res;\n  } catch {\n    return null;\n  }\n}\n\nexport type HashInfos = {\n  appUrl: string;\n  backPath?: string;\n  appCode?: string | null | undefined;\n  path?: string | null | undefined;\n  redirect?: boolean;\n  scopes?: {\n    email: boolean;\n  };\n};\nexport type SecrecyEnv = \"dev\" | \"staging\" | \"prod\";\nexport type UseSecrecyParams = Omit<HashInfos, \"appUrl\"> & {\n  env: SecrecyEnv;\n  session?: boolean | undefined;\n};\n\nexport type Value<T extends UseSecrecyParams> = T extends { redirect: true }\n  ? SecrecyClient | null\n  : SecrecyClient;\n\nexport function getSecrecyClient(\n  env: SecrecyEnv,\n  session?: boolean | undefined\n): SecrecyClient | null {\n  const storage = getStorage(session);\n  const uaSession = storage.userAppSession.load();\n  const uaKeys = storage.userAppKeys.load();\n  const uaJwt = storage.jwt.load();\n  if (!uaSession || !uaKeys || !uaJwt) {\n    const infos = parseInfos();\n    if (infos) {\n      storage.userAppKeys.save(infos.keys);\n      storage.userAppSession.save(infos.uaSession);\n      storage.jwt.save(infos.jwt);\n      return new SecrecyClient(infos.uaSession, infos.keys, infos.jwt, env);\n    }\n    return null;\n  }\n\n  return new SecrecyClient(uaSession, uaKeys, uaJwt, env);\n}\n\nexport function login<T extends UseSecrecyParams>(\n  { appCode, path, redirect, scopes, backPath, env, session }: T = {} as T\n): Promise<Value<T>> {\n  return new Promise((resolve, reject) => {\n    const appUrl = window.location.origin;\n    if (appCode && !appUrl.includes(\"localhost\")) {\n      return reject(\"Can't use appCode if not in localhost\");\n    }\n    const client = getSecrecyClient(env);\n\n    if (!client) {\n      const infos: HashInfos = {\n        appUrl,\n        appCode,\n        redirect,\n        path,\n        scopes,\n        backPath\n      };\n      const data = btoa(JSON.stringify(infos)).replaceAll(\"=\", \"\");\n\n      let envStr = \"\";\n      if (env === \"dev\") {\n        envStr = \"dev.\";\n      } else if (env === \"staging\") {\n        envStr = \"staging.\";\n      }\n\n      const lang = document.documentElement.lang;\n\n      const url = `https://auth.${envStr}secrecy.me${\n        lang ? `/${lang}` : \"\"\n      }/login#${data}`;\n\n      const validate = (infos: SecrecyUserApp): void => {\n        const storage = getStorage(session);\n        storage.userAppSession.save(infos.uaSession);\n        storage.userAppKeys.save(infos.keys);\n        storage.jwt.save(infos.jwt);\n        return resolve(\n          new SecrecyClient(\n            infos.uaSession,\n            infos.keys,\n            infos.jwt,\n            env\n          ) as Value<T>\n        );\n      };\n\n      if (redirect) {\n        const infos = parseInfos();\n        if (infos) {\n          return validate(infos);\n        } else {\n          window.location.href = url;\n          return resolve(null as Value<T>);\n        }\n      } else {\n        popup(url, \"Secrecy Login\", {}, (err, data) => {\n          if (err) {\n            return reject(err);\n          } else {\n            const infos = data as SecrecyUserApp;\n            if (infos) {\n              return validate(infos);\n            }\n          }\n        });\n      }\n    } else {\n      return resolve(client as Value<T>);\n    }\n  });\n}\n"]}
|
|
114
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/client/helpers.ts"],"names":["SecrecyClient","popup","getStorage","parseInfos","window","location","hash","substr","res","JSON","parse","atob","getSecrecyClient","env","session","storage","uaSession","userAppSession","load","uaKeys","userAppKeys","uaJwt","jwt","infos","save","keys","login","appCode","path","redirect","scopes","backPath","Promise","resolve","reject","appUrl","origin","includes","client","data","btoa","stringify","replaceAll","envStr","lang","document","documentElement","url","validate","href","err"],"mappings":"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","sourcesContent":["import { SecrecyClient } from \"./index.js\";\nimport { popup } from \"../PopupTools.js\";\nimport type { SecrecyUserApp } from \"./types/index.js\";\nimport { getStorage } from \"./storage.js\";\n\nexport function parseInfos(): SecrecyUserApp | null {\n  if (!window.location.hash) {\n    return null;\n  }\n  const hash = window.location.hash.substr(1);\n  try {\n    const res = JSON.parse(atob(hash));\n    window.location.hash = \"\";\n    // TODO Add object content validation\n    return res;\n  } catch {\n    return null;\n  }\n}\n\nexport type HashInfos = {\n  appUrl: string;\n  backPath?: string;\n  appCode?: string | null | undefined;\n  path?: string | null | undefined;\n  redirect?: boolean;\n  scopes?: {\n    email: boolean;\n  };\n};\nexport type SecrecyEnv = \"dev\" | \"prod\";\nexport type UseSecrecyParams = Omit<HashInfos, \"appUrl\"> & {\n  env: SecrecyEnv;\n  session?: boolean | undefined;\n};\n\nexport type Value<T extends UseSecrecyParams> = T extends { redirect: true }\n  ? SecrecyClient | null\n  : SecrecyClient;\n\nexport function getSecrecyClient(\n  env: SecrecyEnv,\n  session?: boolean | undefined\n): SecrecyClient | null {\n  const storage = getStorage(session);\n  const uaSession = storage.userAppSession.load();\n  const uaKeys = storage.userAppKeys.load();\n  const uaJwt = storage.jwt.load();\n  if (!uaSession || !uaKeys || !uaJwt) {\n    const infos = parseInfos();\n    if (infos) {\n      storage.userAppKeys.save(infos.keys);\n      storage.userAppSession.save(infos.uaSession);\n      storage.jwt.save(infos.jwt);\n      return new SecrecyClient(infos.uaSession, infos.keys, infos.jwt, env);\n    }\n    return null;\n  }\n\n  return new SecrecyClient(uaSession, uaKeys, uaJwt, env);\n}\n\nexport function login<T extends UseSecrecyParams>(\n  { appCode, path, redirect, scopes, backPath, env, session }: T = {} as T\n): Promise<Value<T>> {\n  return new Promise((resolve, reject) => {\n    const appUrl = window.location.origin;\n    if (appCode && !appUrl.includes(\"localhost\")) {\n      return reject(\"Can't use appCode if not in localhost\");\n    }\n    const client = getSecrecyClient(env);\n\n    if (!client) {\n      const infos: HashInfos = {\n        appUrl,\n        appCode,\n        redirect,\n        path,\n        scopes,\n        backPath\n      };\n      const data = btoa(JSON.stringify(infos)).replaceAll(\"=\", \"\");\n\n      let envStr = \"\";\n      if (env === \"dev\") {\n        envStr = \"dev.\";\n      }\n\n      const lang = document.documentElement.lang;\n\n      const url = `https://auth.${envStr}secrecy.me${\n        lang ? `/${lang}` : \"\"\n      }/login#${data}`;\n\n      const validate = (infos: SecrecyUserApp): void => {\n        const storage = getStorage(session);\n        storage.userAppSession.save(infos.uaSession);\n        storage.userAppKeys.save(infos.keys);\n        storage.jwt.save(infos.jwt);\n        return resolve(\n          new SecrecyClient(\n            infos.uaSession,\n            infos.keys,\n            infos.jwt,\n            env\n          ) as Value<T>\n        );\n      };\n\n      if (redirect) {\n        const infos = parseInfos();\n        if (infos) {\n          return validate(infos);\n        } else {\n          window.location.href = url;\n          return resolve(null as Value<T>);\n        }\n      } else {\n        popup(url, \"Secrecy Login\", {}, (err, data) => {\n          if (err) {\n            return reject(err);\n          } else {\n            const infos = data as SecrecyUserApp;\n            if (infos) {\n              return validate(infos);\n            }\n          }\n        });\n      }\n    } else {\n      return resolve(client as Value<T>);\n    }\n  });\n}\n"]}
|
|
@@ -0,0 +1,172 @@
|
|
|
1
|
+
import type { MailType } from "./../zeus/index";
|
|
2
|
+
import type { DownloadProgress } from "ky";
|
|
3
|
+
import type { SuccessResponse } from "../BaseClient.js";
|
|
4
|
+
import { BaseClient } from "../BaseClient.js";
|
|
5
|
+
import type { Progress } from "../crypto/file.js";
|
|
6
|
+
import type { ReceivedMail, SentMail, Folder, VFileWithFolder, FolderFull, UserAppSettings, UserAppNotifications, File as SecrecyFile, WaitingReceivedMail, DraftMail, VFile, Mail } from "./types/index.js";
|
|
7
|
+
import type { KeyPair } from "../crypto/index.js";
|
|
8
|
+
import type { SecrecyEnv } from "./helpers.js";
|
|
9
|
+
import type { Rights } from "../zeus/index.js";
|
|
10
|
+
import type { ErrorAccessDenied, ErrorNotFound, ErrorBasic, ErrorNotExist, ErrorLimit } from "../error.js";
|
|
11
|
+
export declare type NewMail = {
|
|
12
|
+
body: string;
|
|
13
|
+
subject: string;
|
|
14
|
+
files: {
|
|
15
|
+
id: string;
|
|
16
|
+
name: string;
|
|
17
|
+
}[];
|
|
18
|
+
recipientsIds: string[];
|
|
19
|
+
replyTo?: string | null | undefined;
|
|
20
|
+
};
|
|
21
|
+
export declare type ProgressCallback = (progress: Progress) => Promise<void>;
|
|
22
|
+
export declare class SecrecyClient extends BaseClient {
|
|
23
|
+
#private;
|
|
24
|
+
jwt: string;
|
|
25
|
+
constructor(uaSession: string, uaKeys: KeyPair, uaJwt: string, env: SecrecyEnv);
|
|
26
|
+
get publicKey(): string;
|
|
27
|
+
addFileToHistory({ fileId, vFileId }: {
|
|
28
|
+
fileId: string;
|
|
29
|
+
vFileId: string;
|
|
30
|
+
}): Promise<SuccessResponse<VFile> | ErrorAccessDenied | ErrorNotExist | null>;
|
|
31
|
+
uploadFile({ file, encryptProgress, uploadProgress, signal }: {
|
|
32
|
+
file: globalThis.File | Uint8Array;
|
|
33
|
+
encryptProgress?: ProgressCallback;
|
|
34
|
+
uploadProgress?: ProgressCallback;
|
|
35
|
+
signal?: AbortSignal;
|
|
36
|
+
}): Promise<SuccessResponse<string> | ErrorAccessDenied | ErrorLimit | ErrorNotFound | null>;
|
|
37
|
+
uploadFileInCloud({ file, name, folderId, encryptProgress, uploadProgress, signal }: {
|
|
38
|
+
file: globalThis.File | Uint8Array;
|
|
39
|
+
name: string;
|
|
40
|
+
folderId?: string;
|
|
41
|
+
encryptProgress?: ProgressCallback;
|
|
42
|
+
uploadProgress?: ProgressCallback;
|
|
43
|
+
signal?: AbortSignal;
|
|
44
|
+
}): Promise<SuccessResponse<VFileWithFolder<SecrecyFile>> | ErrorAccessDenied | ErrorLimit | ErrorNotFound | ErrorBasic | ErrorNotExist | null>;
|
|
45
|
+
logout(sessionId?: string | null | undefined): Promise<void>;
|
|
46
|
+
createFolder({ name, parentFolderId }: {
|
|
47
|
+
name: string;
|
|
48
|
+
parentFolderId?: string | null;
|
|
49
|
+
}): Promise<SuccessResponse<FolderFull> | ErrorAccessDenied | ErrorNotExist | null>;
|
|
50
|
+
folder({ id, deleted }?: {
|
|
51
|
+
id?: string | null | undefined;
|
|
52
|
+
deleted?: boolean | null | undefined;
|
|
53
|
+
}): Promise<SuccessResponse<FolderFull> | ErrorAccessDenied | null>;
|
|
54
|
+
file({ id }: {
|
|
55
|
+
id: string;
|
|
56
|
+
}): Promise<SuccessResponse<SecrecyFile> | ErrorAccessDenied | null>;
|
|
57
|
+
vFile({ id }: {
|
|
58
|
+
id: string;
|
|
59
|
+
}): Promise<SuccessResponse<VFileWithFolder> | ErrorAccessDenied | null>;
|
|
60
|
+
mail({ id }: {
|
|
61
|
+
id: string;
|
|
62
|
+
}): Promise<SuccessResponse<Mail> | ErrorAccessDenied | null>;
|
|
63
|
+
shareVFile({ vFileId, userId, rights }: {
|
|
64
|
+
vFileId: string;
|
|
65
|
+
userId: string;
|
|
66
|
+
rights: Rights;
|
|
67
|
+
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorNotExist | ErrorNotFound | null>;
|
|
68
|
+
sharedVFiles(): Promise<SuccessResponse<VFileWithFolder[]> | ErrorAccessDenied | null>;
|
|
69
|
+
vFilesSharedWithMe(): Promise<SuccessResponse<VFileWithFolder[]> | ErrorAccessDenied | null>;
|
|
70
|
+
deletedVFiles(): Promise<SuccessResponse<VFile[]> | ErrorAccessDenied | null>;
|
|
71
|
+
sharedFolders(): Promise<SuccessResponse<Folder[]> | ErrorAccessDenied | null>;
|
|
72
|
+
foldersSharedWithMe(): Promise<SuccessResponse<Folder[]> | ErrorAccessDenied | null>;
|
|
73
|
+
deletedFolders(): Promise<SuccessResponse<Folder[]> | ErrorAccessDenied | null>;
|
|
74
|
+
deletedMails({ mailType }: {
|
|
75
|
+
mailType: MailType;
|
|
76
|
+
}): Promise<SuccessResponse<Mail[]> | ErrorAccessDenied | null>;
|
|
77
|
+
shareFolder({ folderId, userId, rights }: {
|
|
78
|
+
folderId: string;
|
|
79
|
+
userId: string;
|
|
80
|
+
rights: Rights;
|
|
81
|
+
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorNotFound | null>;
|
|
82
|
+
updateFolder({ folderId, name, isFavorite, deletedAt }: {
|
|
83
|
+
folderId: string;
|
|
84
|
+
name?: string | null | undefined;
|
|
85
|
+
isFavorite?: boolean | null | undefined;
|
|
86
|
+
deletedAt?: Date | null | undefined;
|
|
87
|
+
}): Promise<SuccessResponse<FolderFull> | ErrorAccessDenied | ErrorNotExist | null>;
|
|
88
|
+
updateAppNotifications(notifications: Partial<UserAppNotifications>): Promise<SuccessResponse<UserAppNotifications> | ErrorAccessDenied | null>;
|
|
89
|
+
appNotifications(): Promise<SuccessResponse<UserAppNotifications> | ErrorAccessDenied | ErrorNotFound | null>;
|
|
90
|
+
createMail(data: NewMail, customMessage?: string | null | undefined): Promise<SuccessResponse<boolean> | ErrorBasic | ErrorAccessDenied | null>;
|
|
91
|
+
waitingReceivedMails(): Promise<SuccessResponse<WaitingReceivedMail[]> | ErrorNotFound | null>;
|
|
92
|
+
updateDraftMail(draftId: string, { body, subject, files, recipientsIds, replyTo }: Partial<NewMail>): Promise<SuccessResponse<DraftMail> | ErrorNotFound | ErrorAccessDenied | ErrorBasic | null>;
|
|
93
|
+
deleteDraftMail(draftId: string): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null>;
|
|
94
|
+
deleteVFileSharing({ vFileId, userId }: {
|
|
95
|
+
vFileId: string;
|
|
96
|
+
userId: string;
|
|
97
|
+
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorNotExist | null>;
|
|
98
|
+
deleteFolderSharing({ folderId, userId }: {
|
|
99
|
+
folderId: string;
|
|
100
|
+
userId: string;
|
|
101
|
+
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null>;
|
|
102
|
+
duplicateVFile({ vFileId, folderId, customName }: {
|
|
103
|
+
vFileId: string;
|
|
104
|
+
folderId?: string | null | undefined;
|
|
105
|
+
customName?: string | null | undefined;
|
|
106
|
+
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorNotFound | null>;
|
|
107
|
+
deleteFolderCloudTrash({ ids }: {
|
|
108
|
+
ids: Array<string>;
|
|
109
|
+
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null>;
|
|
110
|
+
deleteVFileCloudTrash({ ids }: {
|
|
111
|
+
ids: Array<string>;
|
|
112
|
+
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null>;
|
|
113
|
+
deleteMailTrash({ ids }: {
|
|
114
|
+
ids: Array<string>;
|
|
115
|
+
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null>;
|
|
116
|
+
emptyMailTrash(): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null>;
|
|
117
|
+
emptyCloudTrash(): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null>;
|
|
118
|
+
recoverVFile({ vFileId }: {
|
|
119
|
+
vFileId: string;
|
|
120
|
+
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorNotExist | null>;
|
|
121
|
+
recoverFolder({ id }: {
|
|
122
|
+
id: string;
|
|
123
|
+
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorNotExist | null>;
|
|
124
|
+
recoverMail({ mailId }: {
|
|
125
|
+
mailId: string;
|
|
126
|
+
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorBasic | null>;
|
|
127
|
+
deleteFile({ fileId, vFileId }: {
|
|
128
|
+
fileId: string;
|
|
129
|
+
vFileId: string;
|
|
130
|
+
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorNotExist | null>;
|
|
131
|
+
deleteVFile({ fileId }: {
|
|
132
|
+
fileId: string;
|
|
133
|
+
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorNotExist | null>;
|
|
134
|
+
deleteMail({ mailId }: {
|
|
135
|
+
mailId: string;
|
|
136
|
+
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null>;
|
|
137
|
+
saveInCloud({ fileId, name, folderId }: {
|
|
138
|
+
fileId: string;
|
|
139
|
+
name: string;
|
|
140
|
+
folderId?: string;
|
|
141
|
+
}): Promise<SuccessResponse<VFileWithFolder> | ErrorAccessDenied | ErrorBasic | ErrorLimit | ErrorNotFound | ErrorNotExist | null>;
|
|
142
|
+
sendDraftMail(draftId: string, customMessage?: string | null | undefined): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorBasic | null>;
|
|
143
|
+
sendWaitingEmails(): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorBasic | null>;
|
|
144
|
+
createDraftMail({ body, subject, files, recipientsIds, replyTo }: NewMail): Promise<SuccessResponse<DraftMail> | ErrorAccessDenied | ErrorBasic | null>;
|
|
145
|
+
fileContent({ fileId, onDownloadProgress, progressDecrypt, signal }: {
|
|
146
|
+
fileId: string;
|
|
147
|
+
onDownloadProgress?: (progress: DownloadProgress) => void;
|
|
148
|
+
progressDecrypt?: ProgressCallback;
|
|
149
|
+
signal?: AbortSignal;
|
|
150
|
+
}): Promise<SuccessResponse<Uint8Array> | ErrorAccessDenied | ErrorBasic | null>;
|
|
151
|
+
updateFile({ fileId, filename, isFavorite, deletedAt }: {
|
|
152
|
+
fileId: string;
|
|
153
|
+
filename?: string | null | undefined;
|
|
154
|
+
isFavorite?: boolean | null | undefined;
|
|
155
|
+
deletedAt?: Date | null | undefined;
|
|
156
|
+
}): Promise<SuccessResponse<VFile> | ErrorAccessDenied | ErrorBasic | ErrorNotExist | null>;
|
|
157
|
+
readMail({ mailId }: {
|
|
158
|
+
mailId: string;
|
|
159
|
+
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorBasic | ErrorNotFound | null>;
|
|
160
|
+
unreadMail({ mailId }: {
|
|
161
|
+
mailId: string;
|
|
162
|
+
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorBasic | ErrorNotFound | null>;
|
|
163
|
+
appSettings(): Promise<SuccessResponse<UserAppSettings> | ErrorNotFound | null>;
|
|
164
|
+
updateAppSettings(settings: Partial<UserAppSettings>): Promise<SuccessResponse<UserAppSettings> | ErrorAccessDenied | ErrorBasic | null>;
|
|
165
|
+
receivedMails(): Promise<SuccessResponse<ReceivedMail[]> | ErrorNotFound | null>;
|
|
166
|
+
sentMails(): Promise<SuccessResponse<SentMail[]> | ErrorNotFound | null>;
|
|
167
|
+
draftMails(): Promise<SuccessResponse<DraftMail[]> | ErrorNotFound | null>;
|
|
168
|
+
private perFolder;
|
|
169
|
+
private perVFile;
|
|
170
|
+
unreadReceivedMailsCount(): Promise<SuccessResponse<number> | ErrorAccessDenied | null>;
|
|
171
|
+
private _eachUser;
|
|
172
|
+
}
|