@secrecy/lib 1.0.0-dev.27 → 1.0.0-dev.28
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/dist/BaseClient.d.ts +274 -0
- package/dist/BaseClient.js +2227 -0
- package/dist/PopupTools.d.ts +17 -0
- package/dist/PopupTools.js +213 -0
- package/dist/ZeusThunder.d.ts +2 -0
- package/dist/ZeusThunder.js +113 -0
- package/dist/cache.d.ts +7 -0
- package/dist/cache.js +5 -0
- package/dist/client/admin/index.d.ts +11 -0
- package/dist/client/admin/index.js +198 -0
- package/dist/client/convert/file.d.ts +5 -0
- package/dist/client/convert/file.js +39 -0
- package/dist/client/convert/folder.d.ts +8 -0
- package/dist/client/convert/folder.js +264 -0
- package/dist/client/convert/mail.d.ts +3 -0
- package/dist/client/convert/mail.js +46 -0
- package/dist/client/convert/vFile.d.ts +5 -0
- package/dist/client/convert/vFile.js +164 -0
- package/dist/client/helpers.d.ts +23 -0
- package/dist/client/helpers.js +114 -0
- package/dist/client/index.d.ts +172 -0
- package/dist/client/index.js +6169 -0
- package/dist/client/storage.d.ts +7 -0
- package/dist/client/storage.js +12 -0
- package/dist/client/types/File.d.ts +21 -0
- package/dist/client/types/File.js +3 -0
- package/dist/client/types/FilesOnUsersOnApplications.d.ts +9 -0
- package/dist/client/types/FilesOnUsersOnApplications.js +3 -0
- package/dist/client/types/Folder.d.ts +68 -0
- package/dist/client/types/Folder.js +7 -0
- package/dist/client/types/Inputs.d.ts +21 -0
- package/dist/client/types/Inputs.js +3 -0
- package/dist/client/types/UserAppNotifications.d.ts +6 -0
- package/dist/client/types/UserAppNotifications.js +3 -0
- package/dist/client/types/UserAppSettings.d.ts +7 -0
- package/dist/client/types/UserAppSettings.js +3 -0
- package/dist/client/types/VFile.d.ts +62 -0
- package/dist/client/types/VFile.js +4 -0
- package/dist/client/types/index.d.ts +154 -0
- package/dist/client/types/index.js +10 -0
- package/dist/client/types/queries.d.ts +535 -0
- package/dist/client/types/queries.js +192 -0
- package/dist/crypto/file.d.ts +14 -0
- package/dist/crypto/file.js +291 -0
- package/dist/crypto/index.d.ts +12 -0
- package/dist/crypto/index.js +45 -0
- package/dist/error.d.ts +30 -0
- package/dist/error.js +3 -0
- package/dist/index.d.ts +13 -3857
- package/dist/index.js +42 -255
- package/dist/minify/index.d.ts +2 -0
- package/dist/minify/index.js +28 -0
- package/dist/minify/lz4.d.ts +5 -0
- package/dist/minify/lz4.js +633 -0
- package/dist/sodium.d.ts +3 -0
- package/dist/sodium.js +28 -0
- package/dist/utils/store-buddy.d.ts +14 -0
- package/dist/utils/store-buddy.js +69 -0
- package/dist/utils/time.d.ts +10 -0
- package/dist/utils/time.js +22 -0
- package/dist/utils.d.ts +4 -0
- package/dist/utils.js +188 -0
- package/dist/worker/__mock__/sodium.worker.d.ts +19 -0
- package/dist/worker/__mock__/sodium.worker.js +46 -0
- package/dist/worker/md5.d.ts +1 -0
- package/dist/worker/md5.js +43 -0
- package/dist/worker/sodium.d.ts +3 -0
- package/dist/worker/sodium.js +155 -0
- package/dist/worker/workerCodes.d.ts +2 -0
- package/dist/worker/workerCodes.js +3 -0
- package/dist/zeus/const.d.ts +2 -0
- package/dist/zeus/const.js +2267 -0
- package/dist/zeus/index.d.ts +4043 -0
- package/dist/zeus/index.js +549 -0
- package/package.json +23 -14
- package/__tests__/client/client.test.ts +0 -81
- package/__tests__/client/folder.test.ts +0 -302
- package/__tests__/client/mail.test.ts +0 -476
- package/__tests__/client/timing.test.ts +0 -35
- package/__tests__/client/utils.ts +0 -41
- package/__tests__/client/vFile.test.ts +0 -207
- package/__tests__/index.test.ts +0 -171
- package/commitlint.config.cjs +0 -3
- package/dist/index.js.map +0 -1
- package/dist/index.mjs +0 -255
- package/dist/index.mjs.map +0 -1
- package/docs/assets/css/main.css +0 -2660
- package/docs/assets/images/icons.png +0 -0
- package/docs/assets/images/icons@2x.png +0 -0
- package/docs/assets/images/widgets.png +0 -0
- package/docs/assets/images/widgets@2x.png +0 -0
- package/docs/assets/js/main.js +0 -248
- package/docs/assets/js/search.js +0 -1
- package/docs/classes/baseclient.baseclient-1.html +0 -1165
- package/docs/classes/client.secrecyclient.html +0 -2527
- package/docs/enums/index.sodium.base64_variants.html +0 -205
- package/docs/index.html +0 -198
- package/docs/interfaces/client_types.draftmail.html +0 -335
- package/docs/interfaces/client_types.filecontentbase.html +0 -231
- package/docs/interfaces/client_types.filecontentcloud.html +0 -244
- package/docs/interfaces/client_types.filecontentreceivedmail.html +0 -244
- package/docs/interfaces/client_types.filecontentsentmail.html +0 -230
- package/docs/interfaces/client_types.receivedmail.html +0 -363
- package/docs/interfaces/client_types.sentmail.html +0 -335
- package/docs/interfaces/crypto.keypair.html +0 -202
- package/docs/interfaces/index.sodium.cryptobox.html +0 -185
- package/docs/interfaces/index.sodium.cryptokx.html +0 -185
- package/docs/interfaces/index.sodium.keypair.html +0 -199
- package/docs/interfaces/index.sodium.messagetag.html +0 -185
- package/docs/interfaces/index.sodium.secretbox.html +0 -185
- package/docs/interfaces/index.sodium.stateaddress.html +0 -171
- package/docs/interfaces/index.sodium.stringcryptobox.html +0 -185
- package/docs/interfaces/index.sodium.stringcryptokx.html +0 -185
- package/docs/interfaces/index.sodium.stringkeypair.html +0 -199
- package/docs/interfaces/index.sodium.stringmessagetag.html +0 -185
- package/docs/interfaces/index.sodium.stringsecretbox.html +0 -185
- package/docs/interfaces/utils_store_buddy.storebuddy.html +0 -333
- package/docs/modules/baseclient.html +0 -929
- package/docs/modules/cache.html +0 -185
- package/docs/modules/client.html +0 -207
- package/docs/modules/client_convert_file.html +0 -216
- package/docs/modules/client_convert_folder.html +0 -303
- package/docs/modules/client_convert_vfile.html +0 -216
- package/docs/modules/client_helpers.html +0 -311
- package/docs/modules/client_storage.html +0 -167
- package/docs/modules/client_types.html +0 -1227
- package/docs/modules/client_types_file.html +0 -233
- package/docs/modules/client_types_filesonusersonapplications.html +0 -168
- package/docs/modules/client_types_folder.html +0 -383
- package/docs/modules/client_types_inputs.html +0 -263
- package/docs/modules/client_types_mail.html +0 -181
- package/docs/modules/client_types_queries.html +0 -199
- package/docs/modules/client_types_userappsettings.html +0 -163
- package/docs/modules/client_types_vfile.html +0 -364
- package/docs/modules/crypto.html +0 -366
- package/docs/modules/crypto_file.html +0 -344
- package/docs/modules/index.html +0 -779
- package/docs/modules/index.sodium.html +0 -6039
- package/docs/modules/minify.html +0 -183
- package/docs/modules/minify_lz4.html +0 -279
- package/docs/modules/popuptools.html +0 -259
- package/docs/modules/sodium.html +0 -167
- package/docs/modules/utils.html +0 -219
- package/docs/modules/utils_store_buddy.html +0 -208
- package/docs/modules/utils_time.html +0 -330
- package/docs/modules/worker_md5.html +0 -156
- package/docs/modules/worker_sodium.html +0 -231
- package/docs/modules/worker_workercodes.html +0 -157
- package/docs/modules.html +0 -235
- package/index.html +0 -21
- package/jest.config.ts +0 -27
- package/jest.setup.ts +0 -6
- package/release.config.cjs +0 -15
- package/tsup.config.ts +0 -26
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import _defineProperty from "@babel/runtime/helpers/defineProperty";
|
|
2
|
+
|
|
3
|
+
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; }
|
|
4
|
+
|
|
5
|
+
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; }
|
|
6
|
+
|
|
7
|
+
import { filesCache } from "../../cache.js";
|
|
8
|
+
import { decryptCryptoBox } from "../../crypto/index.js";
|
|
9
|
+
import { sodium } from "../../sodium.js";
|
|
10
|
+
export function gqlFileToInternal(gql, keyPair) {
|
|
11
|
+
var _gql$user;
|
|
12
|
+
|
|
13
|
+
var file = _objectSpread(_objectSpread({}, gql), {}, {
|
|
14
|
+
createdAt: new Date(gql.createdAt),
|
|
15
|
+
size: BigInt(gql.size),
|
|
16
|
+
sizeBefore: BigInt(gql.sizeBefore),
|
|
17
|
+
user: null
|
|
18
|
+
});
|
|
19
|
+
|
|
20
|
+
if ((_gql$user = gql.user) != null && _gql$user.userApp.keyPair) {
|
|
21
|
+
file.user = _objectSpread(_objectSpread({}, gql.user), {}, {
|
|
22
|
+
key: sodium.to_hex(decryptCryptoBox(sodium.from_hex(gql.user.key), gql.user.userApp.keyPair.pub, keyPair.privateKey))
|
|
23
|
+
});
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
filesCache.set(file.id, file);
|
|
27
|
+
return file;
|
|
28
|
+
}
|
|
29
|
+
export function internalFileToFile(internal) {
|
|
30
|
+
var file = _objectSpread({}, internal); // @ts-ignore
|
|
31
|
+
|
|
32
|
+
|
|
33
|
+
delete file.user;
|
|
34
|
+
return file;
|
|
35
|
+
}
|
|
36
|
+
export function gqlFileToExternal(gql, keyPair) {
|
|
37
|
+
return internalFileToFile(gqlFileToInternal(gql, keyPair));
|
|
38
|
+
}
|
|
39
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jbGllbnQvY29udmVydC9maWxlLnRzIl0sIm5hbWVzIjpbImZpbGVzQ2FjaGUiLCJkZWNyeXB0Q3J5cHRvQm94Iiwic29kaXVtIiwiZ3FsRmlsZVRvSW50ZXJuYWwiLCJncWwiLCJrZXlQYWlyIiwiZmlsZSIsImNyZWF0ZWRBdCIsIkRhdGUiLCJzaXplIiwiQmlnSW50Iiwic2l6ZUJlZm9yZSIsInVzZXIiLCJ1c2VyQXBwIiwia2V5IiwidG9faGV4IiwiZnJvbV9oZXgiLCJwdWIiLCJwcml2YXRlS2V5Iiwic2V0IiwiaWQiLCJpbnRlcm5hbEZpbGVUb0ZpbGUiLCJpbnRlcm5hbCIsImdxbEZpbGVUb0V4dGVybmFsIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQSxTQUFTQSxVQUFULFFBQTJCLGdCQUEzQjtBQUVBLFNBQVNDLGdCQUFULFFBQWlDLHVCQUFqQztBQUNBLFNBQVNDLE1BQVQsUUFBdUIsaUJBQXZCO0FBR0EsT0FBTyxTQUFTQyxpQkFBVCxDQUNMQyxHQURLLEVBRUxDLE9BRkssRUFHUztBQUFBOztBQUNkLE1BQU1DLElBQWtCLG1DQUNuQkYsR0FEbUI7QUFFdEJHLElBQUFBLFNBQVMsRUFBRSxJQUFJQyxJQUFKLENBQVNKLEdBQUcsQ0FBQ0csU0FBYixDQUZXO0FBR3RCRSxJQUFBQSxJQUFJLEVBQUVDLE1BQU0sQ0FBQ04sR0FBRyxDQUFDSyxJQUFMLENBSFU7QUFJdEJFLElBQUFBLFVBQVUsRUFBRUQsTUFBTSxDQUFDTixHQUFHLENBQUNPLFVBQUwsQ0FKSTtBQUt0QkMsSUFBQUEsSUFBSSxFQUFFO0FBTGdCLElBQXhCOztBQVFBLG1CQUFJUixHQUFHLENBQUNRLElBQVIsYUFBSSxVQUFVQyxPQUFWLENBQWtCUixPQUF0QixFQUErQjtBQUM3QkMsSUFBQUEsSUFBSSxDQUFDTSxJQUFMLG1DQUNLUixHQUFHLENBQUNRLElBRFQ7QUFFRUUsTUFBQUEsR0FBRyxFQUFFWixNQUFNLENBQUNhLE1BQVAsQ0FDSGQsZ0JBQWdCLENBQ2RDLE1BQU0sQ0FBQ2MsUUFBUCxDQUFnQlosR0FBRyxDQUFDUSxJQUFKLENBQVNFLEdBQXpCLENBRGMsRUFFZFYsR0FBRyxDQUFDUSxJQUFKLENBQVNDLE9BQVQsQ0FBaUJSLE9BQWpCLENBQXlCWSxHQUZYLEVBR2RaLE9BQU8sQ0FBQ2EsVUFITSxDQURiO0FBRlA7QUFVRDs7QUFDRGxCLEVBQUFBLFVBQVUsQ0FBQ21CLEdBQVgsQ0FBZWIsSUFBSSxDQUFDYyxFQUFwQixFQUF3QmQsSUFBeEI7QUFDQSxTQUFPQSxJQUFQO0FBQ0Q7QUFFRCxPQUFPLFNBQVNlLGtCQUFULENBQTRCQyxRQUE1QixFQUEwRDtBQUMvRCxNQUFNaEIsSUFBVSxxQkFBUWdCLFFBQVIsQ0FBaEIsQ0FEK0QsQ0FFL0Q7OztBQUNBLFNBQU9oQixJQUFJLENBQUNNLElBQVo7QUFDQSxTQUFPTixJQUFQO0FBQ0Q7QUFFRCxPQUFPLFNBQVNpQixpQkFBVCxDQUEyQm5CLEdBQTNCLEVBQXlDQyxPQUF6QyxFQUFpRTtBQUN0RSxTQUFPZ0Isa0JBQWtCLENBQUNsQixpQkFBaUIsQ0FBQ0MsR0FBRCxFQUFNQyxPQUFOLENBQWxCLENBQXpCO0FBQ0QiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBmaWxlc0NhY2hlIH0gZnJvbSBcIi4uLy4uL2NhY2hlLmpzXCI7XG5pbXBvcnQgdHlwZSB7IEtleVBhaXIgfSBmcm9tIFwiLi4vLi4vY3J5cHRvL2luZGV4LmpzXCI7XG5pbXBvcnQgeyBkZWNyeXB0Q3J5cHRvQm94IH0gZnJvbSBcIi4uLy4uL2NyeXB0by9pbmRleC5qc1wiO1xuaW1wb3J0IHsgc29kaXVtIH0gZnJvbSBcIi4uLy4uL3NvZGl1bS5qc1wiO1xuaW1wb3J0IHR5cGUgeyBHUUxGaWxlLCBJbnRlcm5hbEZpbGUsIEZpbGUgfSBmcm9tIFwiLi4vdHlwZXMvaW5kZXguanNcIjtcblxuZXhwb3J0IGZ1bmN0aW9uIGdxbEZpbGVUb0ludGVybmFsKFxuICBncWw6IEdRTEZpbGUsXG4gIGtleVBhaXI6IEtleVBhaXJcbik6IEludGVybmFsRmlsZSB7XG4gIGNvbnN0IGZpbGU6IEludGVybmFsRmlsZSA9IHtcbiAgICAuLi5ncWwsXG4gICAgY3JlYXRlZEF0OiBuZXcgRGF0ZShncWwuY3JlYXRlZEF0KSxcbiAgICBzaXplOiBCaWdJbnQoZ3FsLnNpemUpLFxuICAgIHNpemVCZWZvcmU6IEJpZ0ludChncWwuc2l6ZUJlZm9yZSksXG4gICAgdXNlcjogbnVsbFxuICB9O1xuXG4gIGlmIChncWwudXNlcj8udXNlckFwcC5rZXlQYWlyKSB7XG4gICAgZmlsZS51c2VyID0ge1xuICAgICAgLi4uZ3FsLnVzZXIsXG4gICAgICBrZXk6IHNvZGl1bS50b19oZXgoXG4gICAgICAgIGRlY3J5cHRDcnlwdG9Cb3goXG4gICAgICAgICAgc29kaXVtLmZyb21faGV4KGdxbC51c2VyLmtleSksXG4gICAgICAgICAgZ3FsLnVzZXIudXNlckFwcC5rZXlQYWlyLnB1YixcbiAgICAgICAgICBrZXlQYWlyLnByaXZhdGVLZXlcbiAgICAgICAgKVxuICAgICAgKVxuICAgIH07XG4gIH1cbiAgZmlsZXNDYWNoZS5zZXQoZmlsZS5pZCwgZmlsZSk7XG4gIHJldHVybiBmaWxlO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gaW50ZXJuYWxGaWxlVG9GaWxlKGludGVybmFsOiBJbnRlcm5hbEZpbGUpOiBGaWxlIHtcbiAgY29uc3QgZmlsZTogRmlsZSA9IHsgLi4uaW50ZXJuYWwgfTtcbiAgLy8gQHRzLWlnbm9yZVxuICBkZWxldGUgZmlsZS51c2VyO1xuICByZXR1cm4gZmlsZTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGdxbEZpbGVUb0V4dGVybmFsKGdxbDogR1FMRmlsZSwga2V5UGFpcjogS2V5UGFpcik6IEZpbGUge1xuICByZXR1cm4gaW50ZXJuYWxGaWxlVG9GaWxlKGdxbEZpbGVUb0ludGVybmFsKGdxbCwga2V5UGFpcikpO1xufVxuIl19
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { KeyPair } from "../../crypto/index.js";
|
|
2
|
+
import type { GQLFolder, InternalFolder, Folder, GQLFolderFull, InternalFolderFull, FolderFull } from "../types/index.js";
|
|
3
|
+
export declare function gqlFolderToInternal(gql: GQLFolder, keyPair: KeyPair): Promise<InternalFolder>;
|
|
4
|
+
export declare function gqlFolderFullToInternalFull(gql: GQLFolderFull, keyPair: KeyPair): Promise<InternalFolderFull>;
|
|
5
|
+
export declare function internalFolderToFolder(internal: InternalFolder): Folder;
|
|
6
|
+
export declare function internalFolderFullToFolderFull(internal: InternalFolderFull): FolderFull;
|
|
7
|
+
export declare function gqlFolderToExternalFolderFull(gql: GQLFolderFull, keyPair: KeyPair): Promise<FolderFull>;
|
|
8
|
+
export declare function gqlFolderToExternal(gql: GQLFolder, keyPair: KeyPair): Promise<Folder>;
|
|
@@ -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":"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","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"]}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import { sodium, decryptCryptoBox } from "../../index.js";
|
|
2
|
+
export function convertInternalMailToExternal(data, keys) {
|
|
3
|
+
var _mI$replyTo;
|
|
4
|
+
|
|
5
|
+
if (data.mailIntegrityDraft) {
|
|
6
|
+
data.type = "draft";
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
var mI = data.type === "draft" ? data.mailIntegrityDraft : data.mailIntegrity;
|
|
10
|
+
|
|
11
|
+
if (!mI) {
|
|
12
|
+
return null;
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
var pubKey = data.type === "received" ? data.sender.publicKey : keys.publicKey;
|
|
16
|
+
var body = sodium.to_string(decryptCryptoBox(sodium.from_hex(data.body), pubKey, keys.privateKey));
|
|
17
|
+
var subject = sodium.to_string(decryptCryptoBox(sodium.from_hex(data.subject), pubKey, keys.privateKey));
|
|
18
|
+
var hash = sodium.crypto_generichash(sodium.crypto_generichash_BYTES, JSON.stringify({
|
|
19
|
+
body: body,
|
|
20
|
+
subject: subject
|
|
21
|
+
}), mI.hashKey, "hex");
|
|
22
|
+
return {
|
|
23
|
+
type: data.type,
|
|
24
|
+
id: data.id,
|
|
25
|
+
mailIntegrityId: mI.id,
|
|
26
|
+
replyTo: (_mI$replyTo = mI.replyTo) == null ? void 0 : _mI$replyTo.id,
|
|
27
|
+
body: body,
|
|
28
|
+
subject: subject,
|
|
29
|
+
createdAt: new Date(data.createdAt),
|
|
30
|
+
deletedAt: data.deletedAt ? new Date(data.deletedAt) : null,
|
|
31
|
+
openedAt: data.openedAt ? new Date(data.openedAt) : null,
|
|
32
|
+
isAltered: hash !== mI.hash,
|
|
33
|
+
temporaryRecipients: mI.temporaryRecipients,
|
|
34
|
+
recipients: data.type === "draft" ? mI.recipients : data.recipients,
|
|
35
|
+
sender: data.sender,
|
|
36
|
+
files: data.files.map(function (f) {
|
|
37
|
+
var name = sodium.to_string(decryptCryptoBox(sodium.from_hex(f.filename), pubKey, keys.privateKey));
|
|
38
|
+
return {
|
|
39
|
+
id: f.file.id,
|
|
40
|
+
name: name,
|
|
41
|
+
key: f.fileKey
|
|
42
|
+
};
|
|
43
|
+
})
|
|
44
|
+
};
|
|
45
|
+
}
|
|
46
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jbGllbnQvY29udmVydC9tYWlsLnRzIl0sIm5hbWVzIjpbInNvZGl1bSIsImRlY3J5cHRDcnlwdG9Cb3giLCJjb252ZXJ0SW50ZXJuYWxNYWlsVG9FeHRlcm5hbCIsImRhdGEiLCJrZXlzIiwibWFpbEludGVncml0eURyYWZ0IiwidHlwZSIsIm1JIiwibWFpbEludGVncml0eSIsInB1YktleSIsInNlbmRlciIsInB1YmxpY0tleSIsImJvZHkiLCJ0b19zdHJpbmciLCJmcm9tX2hleCIsInByaXZhdGVLZXkiLCJzdWJqZWN0IiwiaGFzaCIsImNyeXB0b19nZW5lcmljaGFzaCIsImNyeXB0b19nZW5lcmljaGFzaF9CWVRFUyIsIkpTT04iLCJzdHJpbmdpZnkiLCJoYXNoS2V5IiwiaWQiLCJtYWlsSW50ZWdyaXR5SWQiLCJyZXBseVRvIiwiY3JlYXRlZEF0IiwiRGF0ZSIsImRlbGV0ZWRBdCIsIm9wZW5lZEF0IiwiaXNBbHRlcmVkIiwidGVtcG9yYXJ5UmVjaXBpZW50cyIsInJlY2lwaWVudHMiLCJmaWxlcyIsIm1hcCIsImYiLCJuYW1lIiwiZmlsZW5hbWUiLCJmaWxlIiwia2V5IiwiZmlsZUtleSJdLCJtYXBwaW5ncyI6IkFBRUEsU0FBU0EsTUFBVCxFQUFpQkMsZ0JBQWpCLFFBQXlDLGdCQUF6QztBQUVBLE9BQU8sU0FBU0MsNkJBQVQsQ0FDTEMsSUFESyxFQUVMQyxJQUZLLEVBR1E7QUFBQTs7QUFDYixNQUFJRCxJQUFJLENBQUNFLGtCQUFULEVBQTZCO0FBQzNCRixJQUFBQSxJQUFJLENBQUNHLElBQUwsR0FBWSxPQUFaO0FBQ0Q7O0FBRUQsTUFBTUMsRUFBRSxHQUNOSixJQUFJLENBQUNHLElBQUwsS0FBYyxPQUFkLEdBQXdCSCxJQUFJLENBQUNFLGtCQUE3QixHQUFrREYsSUFBSSxDQUFDSyxhQUR6RDs7QUFHQSxNQUFJLENBQUNELEVBQUwsRUFBUztBQUNQLFdBQU8sSUFBUDtBQUNEOztBQUVELE1BQU1FLE1BQU0sR0FDVk4sSUFBSSxDQUFDRyxJQUFMLEtBQWMsVUFBZCxHQUEyQkgsSUFBSSxDQUFDTyxNQUFMLENBQVlDLFNBQXZDLEdBQW1EUCxJQUFJLENBQUNPLFNBRDFEO0FBR0EsTUFBTUMsSUFBSSxHQUFHWixNQUFNLENBQUNhLFNBQVAsQ0FDWFosZ0JBQWdCLENBQUNELE1BQU0sQ0FBQ2MsUUFBUCxDQUFnQlgsSUFBSSxDQUFDUyxJQUFyQixDQUFELEVBQTZCSCxNQUE3QixFQUFxQ0wsSUFBSSxDQUFDVyxVQUExQyxDQURMLENBQWI7QUFJQSxNQUFNQyxPQUFPLEdBQUdoQixNQUFNLENBQUNhLFNBQVAsQ0FDZFosZ0JBQWdCLENBQUNELE1BQU0sQ0FBQ2MsUUFBUCxDQUFnQlgsSUFBSSxDQUFDYSxPQUFyQixDQUFELEVBQWdDUCxNQUFoQyxFQUF3Q0wsSUFBSSxDQUFDVyxVQUE3QyxDQURGLENBQWhCO0FBSUEsTUFBTUUsSUFBSSxHQUFHakIsTUFBTSxDQUFDa0Isa0JBQVAsQ0FDWGxCLE1BQU0sQ0FBQ21CLHdCQURJLEVBRVhDLElBQUksQ0FBQ0MsU0FBTCxDQUFlO0FBQUVULElBQUFBLElBQUksRUFBSkEsSUFBRjtBQUFRSSxJQUFBQSxPQUFPLEVBQVBBO0FBQVIsR0FBZixDQUZXLEVBR1hULEVBQUUsQ0FBQ2UsT0FIUSxFQUlYLEtBSlcsQ0FBYjtBQU9BLFNBQU87QUFDTGhCLElBQUFBLElBQUksRUFBRUgsSUFBSSxDQUFDRyxJQUROO0FBRUxpQixJQUFBQSxFQUFFLEVBQUVwQixJQUFJLENBQUNvQixFQUZKO0FBR0xDLElBQUFBLGVBQWUsRUFBRWpCLEVBQUUsQ0FBQ2dCLEVBSGY7QUFJTEUsSUFBQUEsT0FBTyxpQkFBRWxCLEVBQUUsQ0FBQ2tCLE9BQUwscUJBQUUsWUFBWUYsRUFKaEI7QUFLTFgsSUFBQUEsSUFBSSxFQUFKQSxJQUxLO0FBTUxJLElBQUFBLE9BQU8sRUFBUEEsT0FOSztBQU9MVSxJQUFBQSxTQUFTLEVBQUUsSUFBSUMsSUFBSixDQUFTeEIsSUFBSSxDQUFDdUIsU0FBZCxDQVBOO0FBUUxFLElBQUFBLFNBQVMsRUFBRXpCLElBQUksQ0FBQ3lCLFNBQUwsR0FBaUIsSUFBSUQsSUFBSixDQUFTeEIsSUFBSSxDQUFDeUIsU0FBZCxDQUFqQixHQUE0QyxJQVJsRDtBQVNMQyxJQUFBQSxRQUFRLEVBQUUxQixJQUFJLENBQUMwQixRQUFMLEdBQWdCLElBQUlGLElBQUosQ0FBU3hCLElBQUksQ0FBQzBCLFFBQWQsQ0FBaEIsR0FBMEMsSUFUL0M7QUFVTEMsSUFBQUEsU0FBUyxFQUFFYixJQUFJLEtBQUtWLEVBQUUsQ0FBQ1UsSUFWbEI7QUFXTGMsSUFBQUEsbUJBQW1CLEVBQUV4QixFQUFFLENBQUN3QixtQkFYbkI7QUFZTEMsSUFBQUEsVUFBVSxFQUFFN0IsSUFBSSxDQUFDRyxJQUFMLEtBQWMsT0FBZCxHQUF3QkMsRUFBRSxDQUFDeUIsVUFBM0IsR0FBd0M3QixJQUFJLENBQUM2QixVQVpwRDtBQWFMdEIsSUFBQUEsTUFBTSxFQUFFUCxJQUFJLENBQUNPLE1BYlI7QUFjTHVCLElBQUFBLEtBQUssRUFBRTlCLElBQUksQ0FBQzhCLEtBQUwsQ0FBV0MsR0FBWCxDQUFlLFVBQUFDLENBQUMsRUFBSTtBQUN6QixVQUFNQyxJQUFJLEdBQUdwQyxNQUFNLENBQUNhLFNBQVAsQ0FDWFosZ0JBQWdCLENBQUNELE1BQU0sQ0FBQ2MsUUFBUCxDQUFnQnFCLENBQUMsQ0FBQ0UsUUFBbEIsQ0FBRCxFQUE4QjVCLE1BQTlCLEVBQXNDTCxJQUFJLENBQUNXLFVBQTNDLENBREwsQ0FBYjtBQUlBLGFBQU87QUFDTFEsUUFBQUEsRUFBRSxFQUFFWSxDQUFDLENBQUNHLElBQUYsQ0FBT2YsRUFETjtBQUVMYSxRQUFBQSxJQUFJLEVBQUpBLElBRks7QUFHTEcsUUFBQUEsR0FBRyxFQUFFSixDQUFDLENBQUNLO0FBSEYsT0FBUDtBQUtELEtBVk07QUFkRixHQUFQO0FBMEJEIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBLZXlQYWlyIH0gZnJvbSBcIi4uLy4uL2NyeXB0by9pbmRleC5qc1wiO1xuaW1wb3J0IHR5cGUgeyBJbnRlcm5hbE1haWwsIE1haWwgfSBmcm9tIFwiLi4vdHlwZXMvaW5kZXguanNcIjtcbmltcG9ydCB7IHNvZGl1bSwgZGVjcnlwdENyeXB0b0JveCB9IGZyb20gXCIuLi8uLi9pbmRleC5qc1wiO1xuXG5leHBvcnQgZnVuY3Rpb24gY29udmVydEludGVybmFsTWFpbFRvRXh0ZXJuYWwoXG4gIGRhdGE6IEludGVybmFsTWFpbCxcbiAga2V5czogS2V5UGFpclxuKTogTWFpbCB8IG51bGwge1xuICBpZiAoZGF0YS5tYWlsSW50ZWdyaXR5RHJhZnQpIHtcbiAgICBkYXRhLnR5cGUgPSBcImRyYWZ0XCI7XG4gIH1cblxuICBjb25zdCBtSSA9XG4gICAgZGF0YS50eXBlID09PSBcImRyYWZ0XCIgPyBkYXRhLm1haWxJbnRlZ3JpdHlEcmFmdCA6IGRhdGEubWFpbEludGVncml0eTtcblxuICBpZiAoIW1JKSB7XG4gICAgcmV0dXJuIG51bGw7XG4gIH1cblxuICBjb25zdCBwdWJLZXkgPVxuICAgIGRhdGEudHlwZSA9PT0gXCJyZWNlaXZlZFwiID8gZGF0YS5zZW5kZXIucHVibGljS2V5IDoga2V5cy5wdWJsaWNLZXk7XG5cbiAgY29uc3QgYm9keSA9IHNvZGl1bS50b19zdHJpbmcoXG4gICAgZGVjcnlwdENyeXB0b0JveChzb2RpdW0uZnJvbV9oZXgoZGF0YS5ib2R5KSwgcHViS2V5LCBrZXlzLnByaXZhdGVLZXkpXG4gICk7XG5cbiAgY29uc3Qgc3ViamVjdCA9IHNvZGl1bS50b19zdHJpbmcoXG4gICAgZGVjcnlwdENyeXB0b0JveChzb2RpdW0uZnJvbV9oZXgoZGF0YS5zdWJqZWN0KSwgcHViS2V5LCBrZXlzLnByaXZhdGVLZXkpXG4gICk7XG5cbiAgY29uc3QgaGFzaCA9IHNvZGl1bS5jcnlwdG9fZ2VuZXJpY2hhc2goXG4gICAgc29kaXVtLmNyeXB0b19nZW5lcmljaGFzaF9CWVRFUyxcbiAgICBKU09OLnN0cmluZ2lmeSh7IGJvZHksIHN1YmplY3QgfSksXG4gICAgbUkuaGFzaEtleSxcbiAgICBcImhleFwiXG4gICk7XG5cbiAgcmV0dXJuIHtcbiAgICB0eXBlOiBkYXRhLnR5cGUsXG4gICAgaWQ6IGRhdGEuaWQsXG4gICAgbWFpbEludGVncml0eUlkOiBtSS5pZCxcbiAgICByZXBseVRvOiBtSS5yZXBseVRvPy5pZCxcbiAgICBib2R5LFxuICAgIHN1YmplY3QsXG4gICAgY3JlYXRlZEF0OiBuZXcgRGF0ZShkYXRhLmNyZWF0ZWRBdCksXG4gICAgZGVsZXRlZEF0OiBkYXRhLmRlbGV0ZWRBdCA/IG5ldyBEYXRlKGRhdGEuZGVsZXRlZEF0KSA6IG51bGwsXG4gICAgb3BlbmVkQXQ6IGRhdGEub3BlbmVkQXQgPyBuZXcgRGF0ZShkYXRhLm9wZW5lZEF0KSA6IG51bGwsXG4gICAgaXNBbHRlcmVkOiBoYXNoICE9PSBtSS5oYXNoLFxuICAgIHRlbXBvcmFyeVJlY2lwaWVudHM6IG1JLnRlbXBvcmFyeVJlY2lwaWVudHMsXG4gICAgcmVjaXBpZW50czogZGF0YS50eXBlID09PSBcImRyYWZ0XCIgPyBtSS5yZWNpcGllbnRzIDogZGF0YS5yZWNpcGllbnRzLFxuICAgIHNlbmRlcjogZGF0YS5zZW5kZXIsXG4gICAgZmlsZXM6IGRhdGEuZmlsZXMubWFwKGYgPT4ge1xuICAgICAgY29uc3QgbmFtZSA9IHNvZGl1bS50b19zdHJpbmcoXG4gICAgICAgIGRlY3J5cHRDcnlwdG9Cb3goc29kaXVtLmZyb21faGV4KGYuZmlsZW5hbWUpLCBwdWJLZXksIGtleXMucHJpdmF0ZUtleSlcbiAgICAgICk7XG5cbiAgICAgIHJldHVybiB7XG4gICAgICAgIGlkOiBmLmZpbGUuaWQsXG4gICAgICAgIG5hbWUsXG4gICAgICAgIGtleTogZi5maWxlS2V5XG4gICAgICB9O1xuICAgIH0pXG4gIH07XG59XG4iXX0=
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import type { KeyPair } from "../../crypto/index.js";
|
|
2
|
+
import type { GQLVFile, GQLVFileWithFolder, InternalVFile, InternalVFileWithFolder, VFile, VFileWithFolder } from "../types/index.js";
|
|
3
|
+
export declare function gqlVFileToInternal(gql: GQLVFile | GQLVFileWithFolder, keyPair: KeyPair): Promise<InternalVFile | InternalVFileWithFolder>;
|
|
4
|
+
export declare function internalVFileToVFile(internal: InternalVFile | InternalVFileWithFolder): VFile | VFileWithFolder;
|
|
5
|
+
export declare function gqlVFileToExternal(gql: GQLVFile | GQLVFileWithFolder, keyPair: KeyPair): Promise<VFile | VFileWithFolder>;
|
|
@@ -0,0 +1,164 @@
|
|
|
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 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
|
+
|
|
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
|
+
|
|
9
|
+
import { vFilesCache } from "../../cache.js";
|
|
10
|
+
import { decryptCryptoBox } from "../../crypto/index.js";
|
|
11
|
+
import { decryptSecretstream } from "../../crypto/file.js";
|
|
12
|
+
import { sodium } from "../../sodium.js";
|
|
13
|
+
import { gqlFileToInternal, internalFileToFile } from "./file.js";
|
|
14
|
+
import { gqlFolderToInternal, internalFolderToFolder } from "./folder.js";
|
|
15
|
+
export function gqlVFileToInternal(_x, _x2) {
|
|
16
|
+
return _gqlVFileToInternal.apply(this, arguments);
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
function _gqlVFileToInternal() {
|
|
20
|
+
_gqlVFileToInternal = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee(gql, keyPair) {
|
|
21
|
+
var nameKey, internal, internalWithFolder;
|
|
22
|
+
return _regeneratorRuntime.wrap(function _callee$(_context) {
|
|
23
|
+
while (1) {
|
|
24
|
+
switch (_context.prev = _context.next) {
|
|
25
|
+
case 0:
|
|
26
|
+
if (gql.current) {
|
|
27
|
+
_context.next = 2;
|
|
28
|
+
break;
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
throw "VFile " + gql.id + " doesn't have current file";
|
|
32
|
+
|
|
33
|
+
case 2:
|
|
34
|
+
if (gql.userApp) {
|
|
35
|
+
_context.next = 4;
|
|
36
|
+
break;
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
throw "VFile " + gql.id + " doesn't have userApp";
|
|
40
|
+
|
|
41
|
+
case 4:
|
|
42
|
+
// console.dir(gql, { depth: Infinity })
|
|
43
|
+
nameKey = decryptCryptoBox(sodium.from_hex(gql.userApp.nameKey), gql.createdBy.user.publicKey, keyPair.privateKey);
|
|
44
|
+
_context.t0 = _objectSpread;
|
|
45
|
+
_context.t1 = _objectSpread({}, gql);
|
|
46
|
+
_context.t2 = {};
|
|
47
|
+
_context.t3 = gql.createdBy.user;
|
|
48
|
+
_context.t4 = sodium;
|
|
49
|
+
_context.next = 12;
|
|
50
|
+
return decryptSecretstream(nameKey, sodium.from_hex(gql.filename));
|
|
51
|
+
|
|
52
|
+
case 12:
|
|
53
|
+
_context.t5 = _context.sent;
|
|
54
|
+
_context.t6 = _context.t4.to_string.call(_context.t4, _context.t5);
|
|
55
|
+
_context.t7 = {
|
|
56
|
+
userApp: gql.userApp.userApp,
|
|
57
|
+
rights: gql.userApp.rights,
|
|
58
|
+
isRoot: gql.userApp.isRoot,
|
|
59
|
+
nameKey: sodium.to_hex(nameKey)
|
|
60
|
+
};
|
|
61
|
+
_context.t8 = gql.userApps.map(function (u) {
|
|
62
|
+
return [u.userApp.user, u.rights];
|
|
63
|
+
});
|
|
64
|
+
_context.t9 = new Date(gql.createdAt);
|
|
65
|
+
_context.t10 = new Date(gql.updatedAt);
|
|
66
|
+
_context.t11 = gql.deletedAt ? new Date(gql.deletedAt) : null;
|
|
67
|
+
_context.t12 = gqlFileToInternal(gql.current, keyPair);
|
|
68
|
+
_context.t13 = gql.history.map(function (f) {
|
|
69
|
+
return gqlFileToInternal(f, keyPair);
|
|
70
|
+
});
|
|
71
|
+
_context.t14 = {
|
|
72
|
+
createdBy: _context.t3,
|
|
73
|
+
filename: _context.t6,
|
|
74
|
+
userApp: _context.t7,
|
|
75
|
+
users: _context.t8,
|
|
76
|
+
createdAt: _context.t9,
|
|
77
|
+
updatedAt: _context.t10,
|
|
78
|
+
deletedAt: _context.t11,
|
|
79
|
+
current: _context.t12,
|
|
80
|
+
history: _context.t13
|
|
81
|
+
};
|
|
82
|
+
internal = (0, _context.t0)(_context.t1, _context.t2, _context.t14);
|
|
83
|
+
|
|
84
|
+
if (!("folder" in gql)) {
|
|
85
|
+
_context.next = 34;
|
|
86
|
+
break;
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
_context.t15 = _objectSpread;
|
|
90
|
+
_context.t16 = _objectSpread({}, internal);
|
|
91
|
+
_context.t17 = {};
|
|
92
|
+
_context.next = 29;
|
|
93
|
+
return gqlFolderToInternal(gql.folder, keyPair);
|
|
94
|
+
|
|
95
|
+
case 29:
|
|
96
|
+
_context.t18 = _context.sent;
|
|
97
|
+
_context.t19 = {
|
|
98
|
+
folder: _context.t18
|
|
99
|
+
};
|
|
100
|
+
internalWithFolder = (0, _context.t15)(_context.t16, _context.t17, _context.t19);
|
|
101
|
+
vFilesCache.set(internal.id, internalWithFolder);
|
|
102
|
+
return _context.abrupt("return", internalWithFolder);
|
|
103
|
+
|
|
104
|
+
case 34:
|
|
105
|
+
// @ts-expect-error
|
|
106
|
+
delete internal.userApps;
|
|
107
|
+
vFilesCache.set(internal.id, internal);
|
|
108
|
+
return _context.abrupt("return", internal);
|
|
109
|
+
|
|
110
|
+
case 37:
|
|
111
|
+
case "end":
|
|
112
|
+
return _context.stop();
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
}, _callee);
|
|
116
|
+
}));
|
|
117
|
+
return _gqlVFileToInternal.apply(this, arguments);
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
export function internalVFileToVFile(internal) {
|
|
121
|
+
var vFile = _objectSpread(_objectSpread({}, internal), {}, {
|
|
122
|
+
current: internalFileToFile(internal.current),
|
|
123
|
+
history: internal.history.map(internalFileToFile)
|
|
124
|
+
}); // @ts-ignore
|
|
125
|
+
|
|
126
|
+
|
|
127
|
+
delete vFile.nameKey;
|
|
128
|
+
|
|
129
|
+
if ("folder" in internal) {
|
|
130
|
+
return _objectSpread(_objectSpread({}, internal), {}, {
|
|
131
|
+
folder: internalFolderToFolder(internal.folder)
|
|
132
|
+
});
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
return vFile;
|
|
136
|
+
}
|
|
137
|
+
export function gqlVFileToExternal(_x3, _x4) {
|
|
138
|
+
return _gqlVFileToExternal.apply(this, arguments);
|
|
139
|
+
}
|
|
140
|
+
|
|
141
|
+
function _gqlVFileToExternal() {
|
|
142
|
+
_gqlVFileToExternal = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee2(gql, keyPair) {
|
|
143
|
+
return _regeneratorRuntime.wrap(function _callee2$(_context2) {
|
|
144
|
+
while (1) {
|
|
145
|
+
switch (_context2.prev = _context2.next) {
|
|
146
|
+
case 0:
|
|
147
|
+
_context2.t0 = internalVFileToVFile;
|
|
148
|
+
_context2.next = 3;
|
|
149
|
+
return gqlVFileToInternal(gql, keyPair);
|
|
150
|
+
|
|
151
|
+
case 3:
|
|
152
|
+
_context2.t1 = _context2.sent;
|
|
153
|
+
return _context2.abrupt("return", (0, _context2.t0)(_context2.t1));
|
|
154
|
+
|
|
155
|
+
case 5:
|
|
156
|
+
case "end":
|
|
157
|
+
return _context2.stop();
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
}, _callee2);
|
|
161
|
+
}));
|
|
162
|
+
return _gqlVFileToExternal.apply(this, arguments);
|
|
163
|
+
}
|
|
164
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/client/convert/vFile.ts"],"names":["vFilesCache","decryptCryptoBox","decryptSecretstream","sodium","gqlFileToInternal","internalFileToFile","gqlFolderToInternal","internalFolderToFolder","gqlVFileToInternal","gql","keyPair","current","id","userApp","nameKey","from_hex","createdBy","user","publicKey","privateKey","filename","to_string","rights","isRoot","to_hex","userApps","map","u","Date","createdAt","updatedAt","deletedAt","history","f","users","internal","folder","internalWithFolder","set","internalVFileToVFile","vFile","gqlVFileToExternal"],"mappings":"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","sourcesContent":["import { vFilesCache } from \"../../cache.js\";\nimport type { KeyPair } from \"../../crypto/index.js\";\nimport { decryptCryptoBox } from \"../../crypto/index.js\";\nimport { decryptSecretstream } from \"../../crypto/file.js\";\nimport { sodium } from \"../../sodium.js\";\nimport type {\n  GQLVFile,\n  GQLVFileWithFolder,\n  InternalVFile,\n  InternalVFileWithFolder,\n  VFile,\n  VFileWithFolder\n} from \"../types/index.js\";\nimport { gqlFileToInternal, internalFileToFile } from \"./file.js\";\nimport { gqlFolderToInternal, internalFolderToFolder } from \"./folder.js\";\n\nexport async function gqlVFileToInternal(\n  gql: GQLVFile | GQLVFileWithFolder,\n  keyPair: KeyPair\n): Promise<InternalVFile | InternalVFileWithFolder> {\n  if (!gql.current) {\n    throw `VFile ${gql.id} doesn't have current file`;\n  }\n\n  if (!gql.userApp) {\n    throw `VFile ${gql.id} doesn't have userApp`;\n  }\n\n  // console.dir(gql, { depth: Infinity })\n\n  const nameKey = decryptCryptoBox(\n    sodium.from_hex(gql.userApp.nameKey),\n    gql.createdBy.user.publicKey,\n    keyPair.privateKey\n  );\n  const internal: InternalVFile = {\n    ...gql,\n    createdBy: gql.createdBy.user,\n    filename: sodium.to_string(\n      await decryptSecretstream(nameKey, sodium.from_hex(gql.filename))\n    ),\n    userApp: {\n      userApp: gql.userApp.userApp,\n      rights: gql.userApp.rights,\n      isRoot: gql.userApp.isRoot,\n      nameKey: sodium.to_hex(nameKey)\n    },\n    users: gql.userApps.map(u => [u.userApp.user, u.rights]),\n    createdAt: new Date(gql.createdAt),\n    updatedAt: new Date(gql.updatedAt),\n    deletedAt: gql.deletedAt ? new Date(gql.deletedAt) : null,\n    current: gqlFileToInternal(gql.current, keyPair),\n    history: gql.history.map(f => gqlFileToInternal(f, keyPair))\n  };\n  if (\"folder\" in gql) {\n    const internalWithFolder: InternalVFileWithFolder = {\n      ...internal,\n      folder: await gqlFolderToInternal(gql.folder, keyPair)\n    };\n    vFilesCache.set(internal.id, internalWithFolder);\n    return internalWithFolder;\n  }\n\n  // @ts-expect-error\n  delete internal.userApps;\n\n  vFilesCache.set(internal.id, internal);\n  return internal;\n}\n\nexport function internalVFileToVFile(\n  internal: InternalVFile | InternalVFileWithFolder\n): VFile | VFileWithFolder {\n  const vFile: VFile = {\n    ...internal,\n    current: internalFileToFile(internal.current),\n    history: internal.history.map(internalFileToFile)\n  };\n  // @ts-ignore\n  delete vFile.nameKey;\n\n  if (\"folder\" in internal) {\n    return {\n      ...internal,\n      folder: internalFolderToFolder(internal.folder)\n    };\n  }\n\n  return vFile;\n}\n\nexport async function gqlVFileToExternal(\n  gql: GQLVFile | GQLVFileWithFolder,\n  keyPair: KeyPair\n): Promise<VFile | VFileWithFolder> {\n  return internalVFileToVFile(await gqlVFileToInternal(gql, keyPair));\n}\n"]}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { SecrecyClient } from "./index.js";
|
|
2
|
+
import type { SecrecyUserApp } from "./types/index.js";
|
|
3
|
+
export declare function parseInfos(): SecrecyUserApp | null;
|
|
4
|
+
export declare type HashInfos = {
|
|
5
|
+
appUrl: string;
|
|
6
|
+
backPath?: string;
|
|
7
|
+
appCode?: string | null | undefined;
|
|
8
|
+
path?: string | null | undefined;
|
|
9
|
+
redirect?: boolean;
|
|
10
|
+
scopes?: {
|
|
11
|
+
email: boolean;
|
|
12
|
+
};
|
|
13
|
+
};
|
|
14
|
+
export declare type SecrecyEnv = "dev" | "prod";
|
|
15
|
+
export declare type UseSecrecyParams = Omit<HashInfos, "appUrl"> & {
|
|
16
|
+
env: SecrecyEnv;
|
|
17
|
+
session?: boolean | undefined;
|
|
18
|
+
};
|
|
19
|
+
export declare type Value<T extends UseSecrecyParams> = T extends {
|
|
20
|
+
redirect: true;
|
|
21
|
+
} ? SecrecyClient | null : SecrecyClient;
|
|
22
|
+
export declare function getSecrecyClient(env: SecrecyEnv, session?: boolean | undefined): SecrecyClient | null;
|
|
23
|
+
export declare function login<T extends UseSecrecyParams>({ appCode, path, redirect, scopes, backPath, env, session }?: T): Promise<Value<T>>;
|