@secrecy/lib 1.0.0-dev.8 → 1.0.0-dev.81
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/README.md +1 -1
- package/dist/BaseClient.d.ts +104 -0
- package/dist/BaseClient.js +430 -0
- package/{lib → dist}/PopupTools.d.ts +1 -1
- package/dist/PopupTools.js +196 -0
- package/{lib → dist}/ZeusThunder.d.ts +0 -0
- package/dist/ZeusThunder.js +65 -0
- package/dist/cache.d.ts +6 -0
- package/dist/cache.js +4 -0
- package/dist/client/SecrecyAppClient.d.ts +17 -0
- package/dist/client/SecrecyAppClient.js +227 -0
- package/dist/client/SecrecyCloudClient.d.ts +89 -0
- package/dist/client/SecrecyCloudClient.js +1411 -0
- package/dist/client/SecrecyDbClient.d.ts +21 -0
- package/dist/client/SecrecyDbClient.js +177 -0
- package/dist/client/SecrecyMailClient.d.ts +42 -0
- package/dist/client/SecrecyMailClient.js +1022 -0
- package/dist/client/SecrecyPayClient.d.ts +28 -0
- package/dist/client/SecrecyPayClient.js +68 -0
- package/dist/client/SecrecyWalletClient.d.ts +30 -0
- package/dist/client/SecrecyWalletClient.js +73 -0
- package/{lib → dist}/client/convert/file.d.ts +3 -3
- package/dist/client/convert/file.js +33 -0
- package/dist/client/convert/mail.d.ts +3 -0
- package/dist/client/convert/mail.js +43 -0
- package/dist/client/convert/node.d.ts +9 -0
- package/dist/client/convert/node.js +88 -0
- package/{lib → dist}/client/helpers.d.ts +6 -1
- package/dist/client/helpers.js +119 -0
- package/dist/client/index.d.ts +34 -0
- package/dist/client/index.js +46 -0
- package/{lib → dist}/client/storage.d.ts +0 -0
- package/dist/client/storage.js +12 -0
- package/dist/client/types/File.d.ts +14 -0
- package/dist/client/types/File.js +3 -0
- package/{lib → dist}/client/types/Inputs.d.ts +2 -7
- package/dist/client/types/Inputs.js +3 -0
- package/dist/client/types/Node.d.ts +56 -0
- package/dist/client/types/Node.js +3 -0
- package/{lib → dist}/client/types/UserAppNotifications.d.ts +1 -1
- package/dist/client/types/UserAppNotifications.js +3 -0
- package/{lib → dist}/client/types/UserAppSettings.d.ts +1 -3
- package/dist/client/types/UserAppSettings.js +3 -0
- package/{lib → dist}/client/types/index.d.ts +9 -43
- package/dist/client/types/index.js +8 -0
- package/dist/client/types/selectors.d.ts +400 -0
- package/dist/client/types/selectors.js +135 -0
- package/{lib → dist}/crypto/file.d.ts +0 -0
- package/dist/crypto/file.js +195 -0
- package/{lib → dist}/crypto/index.d.ts +0 -0
- package/dist/crypto/index.js +45 -0
- package/dist/error.d.ts +33 -0
- package/dist/error.js +3 -0
- package/dist/index.d.ts +14 -0
- package/dist/index.js +10 -0
- package/{lib → dist}/minify/index.d.ts +0 -0
- package/dist/minify/index.js +23 -0
- package/{lib → dist}/minify/lz4.d.ts +0 -0
- package/dist/minify/lz4.js +539 -0
- package/{lib → dist}/sodium.d.ts +0 -0
- package/dist/sodium.js +6 -0
- package/{lib → dist}/utils/store-buddy.d.ts +0 -0
- package/dist/utils/store-buddy.js +58 -0
- package/{lib → dist}/utils/time.d.ts +0 -0
- package/dist/utils/time.js +12 -0
- package/{lib → dist/utils}/utils.d.ts +0 -0
- package/dist/utils/utils.js +47 -0
- package/{lib → dist}/worker/md5.d.ts +0 -0
- package/dist/worker/md5.js +24 -0
- package/{lib → dist}/worker/sodium.d.ts +0 -0
- package/dist/worker/sodium.js +118 -0
- package/{lib → dist}/worker/workerCodes.d.ts +0 -0
- package/dist/worker/workerCodes.js +255 -0
- package/{lib → dist}/zeus/const.d.ts +5 -0
- package/dist/zeus/const.js +1670 -0
- package/dist/zeus/index.d.ts +7896 -0
- package/dist/zeus/index.js +602 -0
- package/package.json +64 -54
- package/lib/BaseClient.d.ts +0 -266
- package/lib/BaseClient.js +0 -1332
- package/lib/PopupTools.js +0 -213
- package/lib/ZeusThunder.js +0 -112
- package/lib/cache.d.ts +0 -7
- package/lib/cache.js +0 -5
- package/lib/client/convert/file.js +0 -39
- package/lib/client/convert/folder.d.ts +0 -8
- package/lib/client/convert/folder.js +0 -264
- package/lib/client/convert/mail.d.ts +0 -3
- package/lib/client/convert/mail.js +0 -46
- package/lib/client/convert/vFile.d.ts +0 -5
- package/lib/client/convert/vFile.js +0 -164
- package/lib/client/helpers.js +0 -116
- package/lib/client/index.d.ts +0 -168
- package/lib/client/index.js +0 -3795
- package/lib/client/storage.js +0 -12
- package/lib/client/types/File.d.ts +0 -21
- package/lib/client/types/File.js +0 -2
- package/lib/client/types/FilesOnUsersOnApplications.d.ts +0 -9
- package/lib/client/types/FilesOnUsersOnApplications.js +0 -2
- package/lib/client/types/Folder.d.ts +0 -68
- package/lib/client/types/Folder.js +0 -7
- package/lib/client/types/Inputs.js +0 -2
- package/lib/client/types/UserAppNotifications.js +0 -2
- package/lib/client/types/UserAppSettings.js +0 -2
- package/lib/client/types/VFile.d.ts +0 -62
- package/lib/client/types/VFile.js +0 -4
- package/lib/client/types/index.js +0 -9
- package/lib/client/types/queries.d.ts +0 -535
- package/lib/client/types/queries.js +0 -192
- package/lib/crypto/file.js +0 -291
- package/lib/crypto/index.js +0 -37
- package/lib/index.d.ts +0 -11
- package/lib/index.js +0 -40
- package/lib/minify/index.js +0 -28
- package/lib/minify/lz4.js +0 -633
- package/lib/sodium.js +0 -28
- package/lib/utils/store-buddy.js +0 -69
- package/lib/utils/time.js +0 -22
- package/lib/utils.js +0 -188
- package/lib/worker/__mock__/sodium.worker.d.ts +0 -19
- package/lib/worker/__mock__/sodium.worker.js +0 -57
- package/lib/worker/md5.js +0 -43
- package/lib/worker/sodium.js +0 -155
- package/lib/worker/workerCodes.js +0 -3
- package/lib/zeus/const.js +0 -1644
- package/lib/zeus/index.d.ts +0 -26279
- package/lib/zeus/index.js +0 -552
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import type { SecrecyClient, SecrecyEnv } from "../index.js";
|
|
2
|
+
import type { KeyPair } from "../crypto/index.js";
|
|
3
|
+
import type { Thunder } from "../zeus/index.js";
|
|
4
|
+
declare type SuccessPayResponse<T> = {
|
|
5
|
+
success: true;
|
|
6
|
+
data: T;
|
|
7
|
+
};
|
|
8
|
+
declare type ErrorPayResponse = {
|
|
9
|
+
success: false;
|
|
10
|
+
error: string;
|
|
11
|
+
};
|
|
12
|
+
export declare type SecrecyPayResponse<T> = SuccessPayResponse<T> | ErrorPayResponse;
|
|
13
|
+
export declare class SecrecyPayClient {
|
|
14
|
+
#private;
|
|
15
|
+
constructor(client: SecrecyClient, keys: KeyPair, thunder: ReturnType<typeof Thunder>);
|
|
16
|
+
confirmPaymentIntent({ env, paymentIntentId, secrecyIdWhoCreatedPaymentIntent, secrecyIdWhoNeedToConfirmPaymentIntent, amount, currency }: {
|
|
17
|
+
env?: SecrecyEnv;
|
|
18
|
+
paymentIntentId: string;
|
|
19
|
+
secrecyIdWhoCreatedPaymentIntent: string;
|
|
20
|
+
secrecyIdWhoNeedToConfirmPaymentIntent: string;
|
|
21
|
+
amount: number;
|
|
22
|
+
currency: "eur" | "usd";
|
|
23
|
+
}): Promise<SecrecyPayResponse<{
|
|
24
|
+
id: string;
|
|
25
|
+
message: string;
|
|
26
|
+
}>>;
|
|
27
|
+
}
|
|
28
|
+
export {};
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
import _classPrivateFieldLooseBase from "@babel/runtime/helpers/classPrivateFieldLooseBase";
|
|
2
|
+
import _classPrivateFieldLooseKey from "@babel/runtime/helpers/classPrivateFieldLooseKey";
|
|
3
|
+
/* eslint-disable @typescript-eslint/naming-convention */
|
|
4
|
+
|
|
5
|
+
import { getUrl } from "../index.js";
|
|
6
|
+
import { popup } from "../PopupTools.js";
|
|
7
|
+
var _client = /*#__PURE__*/_classPrivateFieldLooseKey("client");
|
|
8
|
+
var _keys = /*#__PURE__*/_classPrivateFieldLooseKey("keys");
|
|
9
|
+
var _thunder = /*#__PURE__*/_classPrivateFieldLooseKey("thunder");
|
|
10
|
+
export class SecrecyPayClient {
|
|
11
|
+
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
|
|
12
|
+
// @ts-ignore
|
|
13
|
+
|
|
14
|
+
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
|
|
15
|
+
// @ts-ignore
|
|
16
|
+
|
|
17
|
+
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
|
|
18
|
+
// @ts-ignore
|
|
19
|
+
|
|
20
|
+
constructor(client, keys, thunder) {
|
|
21
|
+
Object.defineProperty(this, _client, {
|
|
22
|
+
writable: true,
|
|
23
|
+
value: void 0
|
|
24
|
+
});
|
|
25
|
+
Object.defineProperty(this, _keys, {
|
|
26
|
+
writable: true,
|
|
27
|
+
value: void 0
|
|
28
|
+
});
|
|
29
|
+
Object.defineProperty(this, _thunder, {
|
|
30
|
+
writable: true,
|
|
31
|
+
value: void 0
|
|
32
|
+
});
|
|
33
|
+
_classPrivateFieldLooseBase(this, _client)[_client] = client;
|
|
34
|
+
_classPrivateFieldLooseBase(this, _keys)[_keys] = keys;
|
|
35
|
+
_classPrivateFieldLooseBase(this, _thunder)[_thunder] = thunder;
|
|
36
|
+
}
|
|
37
|
+
async confirmPaymentIntent(_ref) {
|
|
38
|
+
let {
|
|
39
|
+
env = "prod",
|
|
40
|
+
paymentIntentId,
|
|
41
|
+
secrecyIdWhoCreatedPaymentIntent,
|
|
42
|
+
secrecyIdWhoNeedToConfirmPaymentIntent,
|
|
43
|
+
amount,
|
|
44
|
+
currency
|
|
45
|
+
} = _ref;
|
|
46
|
+
const url = getUrl({
|
|
47
|
+
env,
|
|
48
|
+
hash: Buffer.from(JSON.stringify({
|
|
49
|
+
appSession: _classPrivateFieldLooseBase(this, _client)[_client].sessionId,
|
|
50
|
+
paymentIntentId,
|
|
51
|
+
secrecyIdWhoCreatedPaymentIntent,
|
|
52
|
+
secrecyIdWhoNeedToConfirmPaymentIntent,
|
|
53
|
+
amount,
|
|
54
|
+
currency
|
|
55
|
+
})).toString("base64"),
|
|
56
|
+
path: "/account/iframe/pay-confirm"
|
|
57
|
+
});
|
|
58
|
+
return new Promise((resolve, reject) => popup(url, "Secrecy Pay - Confirm Payment Intent", {
|
|
59
|
+
width: 500
|
|
60
|
+
}, (err, data) => {
|
|
61
|
+
if (err) {
|
|
62
|
+
return reject(err);
|
|
63
|
+
}
|
|
64
|
+
return resolve(data);
|
|
65
|
+
}));
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJnZXRVcmwiLCJwb3B1cCIsIlNlY3JlY3lQYXlDbGllbnQiLCJjb25zdHJ1Y3RvciIsImNsaWVudCIsImtleXMiLCJ0aHVuZGVyIiwiY29uZmlybVBheW1lbnRJbnRlbnQiLCJlbnYiLCJwYXltZW50SW50ZW50SWQiLCJzZWNyZWN5SWRXaG9DcmVhdGVkUGF5bWVudEludGVudCIsInNlY3JlY3lJZFdob05lZWRUb0NvbmZpcm1QYXltZW50SW50ZW50IiwiYW1vdW50IiwiY3VycmVuY3kiLCJ1cmwiLCJoYXNoIiwiQnVmZmVyIiwiZnJvbSIsIkpTT04iLCJzdHJpbmdpZnkiLCJhcHBTZXNzaW9uIiwic2Vzc2lvbklkIiwidG9TdHJpbmciLCJwYXRoIiwiUHJvbWlzZSIsInJlc29sdmUiLCJyZWplY3QiLCJ3aWR0aCIsImVyciIsImRhdGEiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvY2xpZW50L1NlY3JlY3lQYXlDbGllbnQudHMiXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgQHR5cGVzY3JpcHQtZXNsaW50L25hbWluZy1jb252ZW50aW9uICovXG5pbXBvcnQgdHlwZSB7IFNlY3JlY3lDbGllbnQsIFNlY3JlY3lFbnYgfSBmcm9tIFwiLi4vaW5kZXguanNcIjtcbmltcG9ydCB7IGdldFVybCB9IGZyb20gXCIuLi9pbmRleC5qc1wiO1xuaW1wb3J0IHR5cGUgeyBLZXlQYWlyIH0gZnJvbSBcIi4uL2NyeXB0by9pbmRleC5qc1wiO1xuaW1wb3J0IHR5cGUgeyBUaHVuZGVyIH0gZnJvbSBcIi4uL3pldXMvaW5kZXguanNcIjtcbmltcG9ydCB7IHBvcHVwIH0gZnJvbSBcIi4uL1BvcHVwVG9vbHMuanNcIjtcblxudHlwZSBTdWNjZXNzUGF5UmVzcG9uc2U8VD4gPSB7XG4gIHN1Y2Nlc3M6IHRydWU7XG4gIGRhdGE6IFQ7XG59O1xuXG50eXBlIEVycm9yUGF5UmVzcG9uc2UgPSB7XG4gIHN1Y2Nlc3M6IGZhbHNlO1xuICBlcnJvcjogc3RyaW5nO1xufTtcblxuZXhwb3J0IHR5cGUgU2VjcmVjeVBheVJlc3BvbnNlPFQ+ID0gU3VjY2Vzc1BheVJlc3BvbnNlPFQ+IHwgRXJyb3JQYXlSZXNwb25zZTtcblxuZXhwb3J0IGNsYXNzIFNlY3JlY3lQYXlDbGllbnQge1xuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L2Jhbi10cy1jb21tZW50XG4gIC8vIEB0cy1pZ25vcmVcbiAgI2NsaWVudDogU2VjcmVjeUNsaWVudDtcblxuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L2Jhbi10cy1jb21tZW50XG4gIC8vIEB0cy1pZ25vcmVcbiAgI2tleXM6IEtleVBhaXI7XG5cbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9iYW4tdHMtY29tbWVudFxuICAvLyBAdHMtaWdub3JlXG4gICN0aHVuZGVyOiBSZXR1cm5UeXBlPHR5cGVvZiBUaHVuZGVyPjtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBjbGllbnQ6IFNlY3JlY3lDbGllbnQsXG4gICAga2V5czogS2V5UGFpcixcbiAgICB0aHVuZGVyOiBSZXR1cm5UeXBlPHR5cGVvZiBUaHVuZGVyPlxuICApIHtcbiAgICB0aGlzLiNjbGllbnQgPSBjbGllbnQ7XG4gICAgdGhpcy4ja2V5cyA9IGtleXM7XG4gICAgdGhpcy4jdGh1bmRlciA9IHRodW5kZXI7XG4gIH1cblxuICBhc3luYyBjb25maXJtUGF5bWVudEludGVudCh7XG4gICAgZW52ID0gXCJwcm9kXCIsXG4gICAgcGF5bWVudEludGVudElkLFxuICAgIHNlY3JlY3lJZFdob0NyZWF0ZWRQYXltZW50SW50ZW50LFxuICAgIHNlY3JlY3lJZFdob05lZWRUb0NvbmZpcm1QYXltZW50SW50ZW50LFxuICAgIGFtb3VudCxcbiAgICBjdXJyZW5jeVxuICB9OiB7XG4gICAgZW52PzogU2VjcmVjeUVudjtcbiAgICBwYXltZW50SW50ZW50SWQ6IHN0cmluZztcbiAgICBzZWNyZWN5SWRXaG9DcmVhdGVkUGF5bWVudEludGVudDogc3RyaW5nO1xuICAgIHNlY3JlY3lJZFdob05lZWRUb0NvbmZpcm1QYXltZW50SW50ZW50OiBzdHJpbmc7XG4gICAgYW1vdW50OiBudW1iZXI7XG4gICAgY3VycmVuY3k6IFwiZXVyXCIgfCBcInVzZFwiO1xuICB9KTogUHJvbWlzZTxTZWNyZWN5UGF5UmVzcG9uc2U8eyBpZDogc3RyaW5nOyBtZXNzYWdlOiBzdHJpbmcgfT4+IHtcbiAgICBjb25zdCB1cmwgPSBnZXRVcmwoe1xuICAgICAgZW52LFxuICAgICAgaGFzaDogQnVmZmVyLmZyb20oXG4gICAgICAgIEpTT04uc3RyaW5naWZ5KHtcbiAgICAgICAgICBhcHBTZXNzaW9uOiB0aGlzLiNjbGllbnQuc2Vzc2lvbklkLFxuICAgICAgICAgIHBheW1lbnRJbnRlbnRJZCxcbiAgICAgICAgICBzZWNyZWN5SWRXaG9DcmVhdGVkUGF5bWVudEludGVudCxcbiAgICAgICAgICBzZWNyZWN5SWRXaG9OZWVkVG9Db25maXJtUGF5bWVudEludGVudCxcbiAgICAgICAgICBhbW91bnQsXG4gICAgICAgICAgY3VycmVuY3lcbiAgICAgICAgfSlcbiAgICAgICkudG9TdHJpbmcoXCJiYXNlNjRcIiksXG4gICAgICBwYXRoOiBcIi9hY2NvdW50L2lmcmFtZS9wYXktY29uZmlybVwiXG4gICAgfSk7XG4gICAgcmV0dXJuIG5ldyBQcm9taXNlKChyZXNvbHZlLCByZWplY3QpID0+XG4gICAgICBwb3B1cChcbiAgICAgICAgdXJsLFxuICAgICAgICBcIlNlY3JlY3kgUGF5IC0gQ29uZmlybSBQYXltZW50IEludGVudFwiLFxuICAgICAgICB7XG4gICAgICAgICAgd2lkdGg6IDUwMFxuICAgICAgICB9LFxuICAgICAgICAoZXJyLCBkYXRhKSA9PiB7XG4gICAgICAgICAgaWYgKGVycikge1xuICAgICAgICAgICAgcmV0dXJuIHJlamVjdChlcnIpO1xuICAgICAgICAgIH1cbiAgICAgICAgICByZXR1cm4gcmVzb2x2ZShcbiAgICAgICAgICAgIGRhdGEgYXMgU2VjcmVjeVBheVJlc3BvbnNlPHsgaWQ6IHN0cmluZzsgbWVzc2FnZTogc3RyaW5nIH0+XG4gICAgICAgICAgKTtcbiAgICAgICAgfVxuICAgICAgKVxuICAgICk7XG4gIH1cbn1cbiJdLCJtYXBwaW5ncyI6Ijs7QUFBQTs7QUFFQSxTQUFTQSxNQUFNLFFBQVEsYUFBYTtBQUdwQyxTQUFTQyxLQUFLLFFBQVEsa0JBQWtCO0FBQUM7QUFBQTtBQUFBO0FBY3pDLE9BQU8sTUFBTUMsZ0JBQWdCLENBQUM7RUFDNUI7RUFDQTs7RUFHQTtFQUNBOztFQUdBO0VBQ0E7O0VBR0FDLFdBQVcsQ0FDVEMsTUFBcUIsRUFDckJDLElBQWEsRUFDYkMsT0FBbUMsRUFDbkM7SUFBQTtNQUFBO01BQUE7SUFBQTtJQUFBO01BQUE7TUFBQTtJQUFBO0lBQUE7TUFBQTtNQUFBO0lBQUE7SUFDQSxnQ0FBSSxzQkFBV0YsTUFBTTtJQUNyQixnQ0FBSSxrQkFBU0MsSUFBSTtJQUNqQixnQ0FBSSx3QkFBWUMsT0FBTztFQUN6QjtFQUVBLE1BQU1DLG9CQUFvQixPQWN1QztJQUFBLElBZHRDO01BQ3pCQyxHQUFHLEdBQUcsTUFBTTtNQUNaQyxlQUFlO01BQ2ZDLGdDQUFnQztNQUNoQ0Msc0NBQXNDO01BQ3RDQyxNQUFNO01BQ05DO0lBUUYsQ0FBQztJQUNDLE1BQU1DLEdBQUcsR0FBR2QsTUFBTSxDQUFDO01BQ2pCUSxHQUFHO01BQ0hPLElBQUksRUFBRUMsTUFBTSxDQUFDQyxJQUFJLENBQ2ZDLElBQUksQ0FBQ0MsU0FBUyxDQUFDO1FBQ2JDLFVBQVUsRUFBRSxnQ0FBSSxvQkFBU0MsU0FBUztRQUNsQ1osZUFBZTtRQUNmQyxnQ0FBZ0M7UUFDaENDLHNDQUFzQztRQUN0Q0MsTUFBTTtRQUNOQztNQUNGLENBQUMsQ0FBQyxDQUNILENBQUNTLFFBQVEsQ0FBQyxRQUFRLENBQUM7TUFDcEJDLElBQUksRUFBRTtJQUNSLENBQUMsQ0FBQztJQUNGLE9BQU8sSUFBSUMsT0FBTyxDQUFDLENBQUNDLE9BQU8sRUFBRUMsTUFBTSxLQUNqQ3pCLEtBQUssQ0FDSGEsR0FBRyxFQUNILHNDQUFzQyxFQUN0QztNQUNFYSxLQUFLLEVBQUU7SUFDVCxDQUFDLEVBQ0QsQ0FBQ0MsR0FBRyxFQUFFQyxJQUFJLEtBQUs7TUFDYixJQUFJRCxHQUFHLEVBQUU7UUFDUCxPQUFPRixNQUFNLENBQUNFLEdBQUcsQ0FBQztNQUNwQjtNQUNBLE9BQU9ILE9BQU8sQ0FDWkksSUFBSSxDQUNMO0lBQ0gsQ0FBQyxDQUNGLENBQ0Y7RUFDSDtBQUNGIn0=
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import type { SecrecyClient, SecrecyEnv } from "../index.js";
|
|
2
|
+
import { InfuraNetwork } from "../zeus/index.js";
|
|
3
|
+
import type { providers } from "ethers";
|
|
4
|
+
declare type SuccessWalletResponse<T> = {
|
|
5
|
+
success: true;
|
|
6
|
+
data: T;
|
|
7
|
+
};
|
|
8
|
+
declare type ErrorWalletResponse = {
|
|
9
|
+
success: false;
|
|
10
|
+
error: string;
|
|
11
|
+
};
|
|
12
|
+
export declare type SecrecyWalletResponse<T> = SuccessWalletResponse<T> | ErrorWalletResponse;
|
|
13
|
+
export declare class SecrecyWalletClient {
|
|
14
|
+
#private;
|
|
15
|
+
constructor(client: SecrecyClient);
|
|
16
|
+
createTransaction({ env, network, tx }: {
|
|
17
|
+
env?: SecrecyEnv;
|
|
18
|
+
network?: InfuraNetwork;
|
|
19
|
+
tx: providers.TransactionRequest;
|
|
20
|
+
}): Promise<SecrecyWalletResponse<{
|
|
21
|
+
id: string;
|
|
22
|
+
hash: string;
|
|
23
|
+
}>>;
|
|
24
|
+
createSignature({ env, network, message }: {
|
|
25
|
+
env?: SecrecyEnv;
|
|
26
|
+
network?: InfuraNetwork;
|
|
27
|
+
message: string;
|
|
28
|
+
}): Promise<SecrecyWalletResponse<string>>;
|
|
29
|
+
}
|
|
30
|
+
export {};
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
import _classPrivateFieldLooseBase from "@babel/runtime/helpers/classPrivateFieldLooseBase";
|
|
2
|
+
import _classPrivateFieldLooseKey from "@babel/runtime/helpers/classPrivateFieldLooseKey";
|
|
3
|
+
/* eslint-disable @typescript-eslint/naming-convention */
|
|
4
|
+
|
|
5
|
+
import { getUrl } from "../index.js";
|
|
6
|
+
import { InfuraNetwork } from "../zeus/index.js";
|
|
7
|
+
import { popup } from "../PopupTools.js";
|
|
8
|
+
var _client = /*#__PURE__*/_classPrivateFieldLooseKey("client");
|
|
9
|
+
export class SecrecyWalletClient {
|
|
10
|
+
// #keys: KeyPair;
|
|
11
|
+
|
|
12
|
+
// #thunder: ReturnType<typeof Thunder>;
|
|
13
|
+
|
|
14
|
+
constructor(client) {
|
|
15
|
+
Object.defineProperty(this, _client, {
|
|
16
|
+
writable: true,
|
|
17
|
+
value: void 0
|
|
18
|
+
});
|
|
19
|
+
_classPrivateFieldLooseBase(this, _client)[_client] = client;
|
|
20
|
+
// this.#keys = keys;
|
|
21
|
+
// this.#thunder = thunder;
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
async createTransaction(_ref) {
|
|
25
|
+
let {
|
|
26
|
+
env = "prod",
|
|
27
|
+
network = InfuraNetwork.mainnet,
|
|
28
|
+
tx
|
|
29
|
+
} = _ref;
|
|
30
|
+
const url = getUrl({
|
|
31
|
+
env,
|
|
32
|
+
hash: Buffer.from(JSON.stringify({
|
|
33
|
+
appSession: _classPrivateFieldLooseBase(this, _client)[_client].sessionId,
|
|
34
|
+
network,
|
|
35
|
+
tx
|
|
36
|
+
})).toString("base64"),
|
|
37
|
+
path: "/account/iframe/wallet-transaction"
|
|
38
|
+
});
|
|
39
|
+
return new Promise((resolve, reject) => popup(url, "Secrecy Wallet - Transaction", {
|
|
40
|
+
width: 500
|
|
41
|
+
}, (err, data) => {
|
|
42
|
+
if (err) {
|
|
43
|
+
return reject(err);
|
|
44
|
+
}
|
|
45
|
+
return resolve(data);
|
|
46
|
+
}));
|
|
47
|
+
}
|
|
48
|
+
async createSignature(_ref2) {
|
|
49
|
+
let {
|
|
50
|
+
env = "prod",
|
|
51
|
+
network = InfuraNetwork.mainnet,
|
|
52
|
+
message
|
|
53
|
+
} = _ref2;
|
|
54
|
+
const url = getUrl({
|
|
55
|
+
env,
|
|
56
|
+
hash: Buffer.from(JSON.stringify({
|
|
57
|
+
appSession: _classPrivateFieldLooseBase(this, _client)[_client].sessionId,
|
|
58
|
+
network,
|
|
59
|
+
message
|
|
60
|
+
})).toString("base64"),
|
|
61
|
+
path: "/account/iframe/wallet-signature"
|
|
62
|
+
});
|
|
63
|
+
return new Promise((resolve, reject) => popup(url, "Secrecy Wallet - Signature", {
|
|
64
|
+
width: 500
|
|
65
|
+
}, (err, data) => {
|
|
66
|
+
if (err) {
|
|
67
|
+
return reject(err);
|
|
68
|
+
}
|
|
69
|
+
return resolve(data);
|
|
70
|
+
}));
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJnZXRVcmwiLCJJbmZ1cmFOZXR3b3JrIiwicG9wdXAiLCJTZWNyZWN5V2FsbGV0Q2xpZW50IiwiY29uc3RydWN0b3IiLCJjbGllbnQiLCJjcmVhdGVUcmFuc2FjdGlvbiIsImVudiIsIm5ldHdvcmsiLCJtYWlubmV0IiwidHgiLCJ1cmwiLCJoYXNoIiwiQnVmZmVyIiwiZnJvbSIsIkpTT04iLCJzdHJpbmdpZnkiLCJhcHBTZXNzaW9uIiwic2Vzc2lvbklkIiwidG9TdHJpbmciLCJwYXRoIiwiUHJvbWlzZSIsInJlc29sdmUiLCJyZWplY3QiLCJ3aWR0aCIsImVyciIsImRhdGEiLCJjcmVhdGVTaWduYXR1cmUiLCJtZXNzYWdlIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL2NsaWVudC9TZWNyZWN5V2FsbGV0Q2xpZW50LnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIEB0eXBlc2NyaXB0LWVzbGludC9uYW1pbmctY29udmVudGlvbiAqL1xuaW1wb3J0IHR5cGUgeyBTZWNyZWN5Q2xpZW50LCBTZWNyZWN5RW52IH0gZnJvbSBcIi4uL2luZGV4LmpzXCI7XG5pbXBvcnQgeyBnZXRVcmwgfSBmcm9tIFwiLi4vaW5kZXguanNcIjtcbmltcG9ydCB7IEluZnVyYU5ldHdvcmsgfSBmcm9tIFwiLi4vemV1cy9pbmRleC5qc1wiO1xuaW1wb3J0IHsgcG9wdXAgfSBmcm9tIFwiLi4vUG9wdXBUb29scy5qc1wiO1xuaW1wb3J0IHR5cGUgeyBwcm92aWRlcnMgfSBmcm9tIFwiZXRoZXJzXCI7XG5cbnR5cGUgU3VjY2Vzc1dhbGxldFJlc3BvbnNlPFQ+ID0ge1xuICBzdWNjZXNzOiB0cnVlO1xuICBkYXRhOiBUO1xufTtcblxudHlwZSBFcnJvcldhbGxldFJlc3BvbnNlID0ge1xuICBzdWNjZXNzOiBmYWxzZTtcbiAgZXJyb3I6IHN0cmluZztcbn07XG5cbmV4cG9ydCB0eXBlIFNlY3JlY3lXYWxsZXRSZXNwb25zZTxUPiA9XG4gIHwgU3VjY2Vzc1dhbGxldFJlc3BvbnNlPFQ+XG4gIHwgRXJyb3JXYWxsZXRSZXNwb25zZTtcblxuZXhwb3J0IGNsYXNzIFNlY3JlY3lXYWxsZXRDbGllbnQge1xuICAjY2xpZW50OiBTZWNyZWN5Q2xpZW50O1xuXG4gIC8vICNrZXlzOiBLZXlQYWlyO1xuXG4gIC8vICN0aHVuZGVyOiBSZXR1cm5UeXBlPHR5cGVvZiBUaHVuZGVyPjtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBjbGllbnQ6IFNlY3JlY3lDbGllbnRcbiAgICAvLyBfa2V5czogS2V5UGFpcixcbiAgICAvLyBfdGh1bmRlcjogUmV0dXJuVHlwZTx0eXBlb2YgVGh1bmRlcj5cbiAgKSB7XG4gICAgdGhpcy4jY2xpZW50ID0gY2xpZW50O1xuICAgIC8vIHRoaXMuI2tleXMgPSBrZXlzO1xuICAgIC8vIHRoaXMuI3RodW5kZXIgPSB0aHVuZGVyO1xuICB9XG5cbiAgYXN5bmMgY3JlYXRlVHJhbnNhY3Rpb24oe1xuICAgIGVudiA9IFwicHJvZFwiLFxuICAgIG5ldHdvcmsgPSBJbmZ1cmFOZXR3b3JrLm1haW5uZXQsXG4gICAgdHhcbiAgfToge1xuICAgIGVudj86IFNlY3JlY3lFbnY7XG4gICAgbmV0d29yaz86IEluZnVyYU5ldHdvcms7XG4gICAgdHg6IHByb3ZpZGVycy5UcmFuc2FjdGlvblJlcXVlc3Q7XG4gIH0pOiBQcm9taXNlPFNlY3JlY3lXYWxsZXRSZXNwb25zZTx7IGlkOiBzdHJpbmc7IGhhc2g6IHN0cmluZyB9Pj4ge1xuICAgIGNvbnN0IHVybCA9IGdldFVybCh7XG4gICAgICBlbnYsXG4gICAgICBoYXNoOiBCdWZmZXIuZnJvbShcbiAgICAgICAgSlNPTi5zdHJpbmdpZnkoe1xuICAgICAgICAgIGFwcFNlc3Npb246IHRoaXMuI2NsaWVudC5zZXNzaW9uSWQsXG4gICAgICAgICAgbmV0d29yayxcbiAgICAgICAgICB0eFxuICAgICAgICB9KVxuICAgICAgKS50b1N0cmluZyhcImJhc2U2NFwiKSxcbiAgICAgIHBhdGg6IFwiL2FjY291bnQvaWZyYW1lL3dhbGxldC10cmFuc2FjdGlvblwiXG4gICAgfSk7XG4gICAgcmV0dXJuIG5ldyBQcm9taXNlKChyZXNvbHZlLCByZWplY3QpID0+XG4gICAgICBwb3B1cChcbiAgICAgICAgdXJsLFxuICAgICAgICBcIlNlY3JlY3kgV2FsbGV0IC0gVHJhbnNhY3Rpb25cIixcbiAgICAgICAge1xuICAgICAgICAgIHdpZHRoOiA1MDBcbiAgICAgICAgfSxcbiAgICAgICAgKGVyciwgZGF0YSkgPT4ge1xuICAgICAgICAgIGlmIChlcnIpIHtcbiAgICAgICAgICAgIHJldHVybiByZWplY3QoZXJyKTtcbiAgICAgICAgICB9XG4gICAgICAgICAgcmV0dXJuIHJlc29sdmUoXG4gICAgICAgICAgICBkYXRhIGFzIFNlY3JlY3lXYWxsZXRSZXNwb25zZTx7IGlkOiBzdHJpbmc7IGhhc2g6IHN0cmluZyB9PlxuICAgICAgICAgICk7XG4gICAgICAgIH1cbiAgICAgIClcbiAgICApO1xuICB9XG5cbiAgYXN5bmMgY3JlYXRlU2lnbmF0dXJlKHtcbiAgICBlbnYgPSBcInByb2RcIixcbiAgICBuZXR3b3JrID0gSW5mdXJhTmV0d29yay5tYWlubmV0LFxuICAgIG1lc3NhZ2VcbiAgfToge1xuICAgIGVudj86IFNlY3JlY3lFbnY7XG4gICAgbmV0d29yaz86IEluZnVyYU5ldHdvcms7XG4gICAgbWVzc2FnZTogc3RyaW5nO1xuICB9KTogUHJvbWlzZTxTZWNyZWN5V2FsbGV0UmVzcG9uc2U8c3RyaW5nPj4ge1xuICAgIGNvbnN0IHVybCA9IGdldFVybCh7XG4gICAgICBlbnYsXG4gICAgICBoYXNoOiBCdWZmZXIuZnJvbShcbiAgICAgICAgSlNPTi5zdHJpbmdpZnkoe1xuICAgICAgICAgIGFwcFNlc3Npb246IHRoaXMuI2NsaWVudC5zZXNzaW9uSWQsXG4gICAgICAgICAgbmV0d29yayxcbiAgICAgICAgICBtZXNzYWdlXG4gICAgICAgIH0pXG4gICAgICApLnRvU3RyaW5nKFwiYmFzZTY0XCIpLFxuICAgICAgcGF0aDogXCIvYWNjb3VudC9pZnJhbWUvd2FsbGV0LXNpZ25hdHVyZVwiXG4gICAgfSk7XG4gICAgcmV0dXJuIG5ldyBQcm9taXNlKChyZXNvbHZlLCByZWplY3QpID0+XG4gICAgICBwb3B1cChcbiAgICAgICAgdXJsLFxuICAgICAgICBcIlNlY3JlY3kgV2FsbGV0IC0gU2lnbmF0dXJlXCIsXG4gICAgICAgIHtcbiAgICAgICAgICB3aWR0aDogNTAwXG4gICAgICAgIH0sXG4gICAgICAgIChlcnIsIGRhdGEpID0+IHtcbiAgICAgICAgICBpZiAoZXJyKSB7XG4gICAgICAgICAgICByZXR1cm4gcmVqZWN0KGVycik7XG4gICAgICAgICAgfVxuICAgICAgICAgIHJldHVybiByZXNvbHZlKGRhdGEgYXMgU2VjcmVjeVdhbGxldFJlc3BvbnNlPHN0cmluZz4pO1xuICAgICAgICB9XG4gICAgICApXG4gICAgKTtcbiAgfVxufVxuIl0sIm1hcHBpbmdzIjoiOztBQUFBOztBQUVBLFNBQVNBLE1BQU0sUUFBUSxhQUFhO0FBQ3BDLFNBQVNDLGFBQWEsUUFBUSxrQkFBa0I7QUFDaEQsU0FBU0MsS0FBSyxRQUFRLGtCQUFrQjtBQUFDO0FBaUJ6QyxPQUFPLE1BQU1DLG1CQUFtQixDQUFDO0VBRy9COztFQUVBOztFQUVBQyxXQUFXLENBQ1RDLE1BQXFCLEVBR3JCO0lBQUE7TUFBQTtNQUFBO0lBQUE7SUFDQSxnQ0FBSSxzQkFBV0EsTUFBTTtJQUNyQjtJQUNBO0VBQ0Y7O0VBRUEsTUFBTUMsaUJBQWlCLE9BUTBDO0lBQUEsSUFSekM7TUFDdEJDLEdBQUcsR0FBRyxNQUFNO01BQ1pDLE9BQU8sR0FBR1AsYUFBYSxDQUFDUSxPQUFPO01BQy9CQztJQUtGLENBQUM7SUFDQyxNQUFNQyxHQUFHLEdBQUdYLE1BQU0sQ0FBQztNQUNqQk8sR0FBRztNQUNISyxJQUFJLEVBQUVDLE1BQU0sQ0FBQ0MsSUFBSSxDQUNmQyxJQUFJLENBQUNDLFNBQVMsQ0FBQztRQUNiQyxVQUFVLEVBQUUsZ0NBQUksb0JBQVNDLFNBQVM7UUFDbENWLE9BQU87UUFDUEU7TUFDRixDQUFDLENBQUMsQ0FDSCxDQUFDUyxRQUFRLENBQUMsUUFBUSxDQUFDO01BQ3BCQyxJQUFJLEVBQUU7SUFDUixDQUFDLENBQUM7SUFDRixPQUFPLElBQUlDLE9BQU8sQ0FBQyxDQUFDQyxPQUFPLEVBQUVDLE1BQU0sS0FDakNyQixLQUFLLENBQ0hTLEdBQUcsRUFDSCw4QkFBOEIsRUFDOUI7TUFDRWEsS0FBSyxFQUFFO0lBQ1QsQ0FBQyxFQUNELENBQUNDLEdBQUcsRUFBRUMsSUFBSSxLQUFLO01BQ2IsSUFBSUQsR0FBRyxFQUFFO1FBQ1AsT0FBT0YsTUFBTSxDQUFDRSxHQUFHLENBQUM7TUFDcEI7TUFDQSxPQUFPSCxPQUFPLENBQ1pJLElBQUksQ0FDTDtJQUNILENBQUMsQ0FDRixDQUNGO0VBQ0g7RUFFQSxNQUFNQyxlQUFlLFFBUXNCO0lBQUEsSUFSckI7TUFDcEJwQixHQUFHLEdBQUcsTUFBTTtNQUNaQyxPQUFPLEdBQUdQLGFBQWEsQ0FBQ1EsT0FBTztNQUMvQm1CO0lBS0YsQ0FBQztJQUNDLE1BQU1qQixHQUFHLEdBQUdYLE1BQU0sQ0FBQztNQUNqQk8sR0FBRztNQUNISyxJQUFJLEVBQUVDLE1BQU0sQ0FBQ0MsSUFBSSxDQUNmQyxJQUFJLENBQUNDLFNBQVMsQ0FBQztRQUNiQyxVQUFVLEVBQUUsZ0NBQUksb0JBQVNDLFNBQVM7UUFDbENWLE9BQU87UUFDUG9CO01BQ0YsQ0FBQyxDQUFDLENBQ0gsQ0FBQ1QsUUFBUSxDQUFDLFFBQVEsQ0FBQztNQUNwQkMsSUFBSSxFQUFFO0lBQ1IsQ0FBQyxDQUFDO0lBQ0YsT0FBTyxJQUFJQyxPQUFPLENBQUMsQ0FBQ0MsT0FBTyxFQUFFQyxNQUFNLEtBQ2pDckIsS0FBSyxDQUNIUyxHQUFHLEVBQ0gsNEJBQTRCLEVBQzVCO01BQ0VhLEtBQUssRUFBRTtJQUNULENBQUMsRUFDRCxDQUFDQyxHQUFHLEVBQUVDLElBQUksS0FBSztNQUNiLElBQUlELEdBQUcsRUFBRTtRQUNQLE9BQU9GLE1BQU0sQ0FBQ0UsR0FBRyxDQUFDO01BQ3BCO01BQ0EsT0FBT0gsT0FBTyxDQUFDSSxJQUFJLENBQWtDO0lBQ3ZELENBQUMsQ0FDRixDQUNGO0VBQ0g7QUFDRiJ9
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import type { KeyPair } from "../../crypto/index.js";
|
|
2
|
-
import type { GQLFile, InternalFile,
|
|
2
|
+
import type { GQLFile, InternalFile, FileMetadata } from "../types/index.js";
|
|
3
3
|
export declare function gqlFileToInternal(gql: GQLFile, keyPair: KeyPair): InternalFile;
|
|
4
|
-
export declare function internalFileToFile(internal: InternalFile):
|
|
5
|
-
export declare function gqlFileToExternal(gql: GQLFile, keyPair: KeyPair):
|
|
4
|
+
export declare function internalFileToFile(internal: InternalFile): FileMetadata;
|
|
5
|
+
export declare function gqlFileToExternal(gql: GQLFile, keyPair: KeyPair): FileMetadata;
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { filesCache } from "../../cache.js";
|
|
2
|
+
import { decryptCryptoBox } from "../../crypto/index.js";
|
|
3
|
+
import { sodium } from "../../sodium.js";
|
|
4
|
+
export function gqlFileToInternal(gql, keyPair) {
|
|
5
|
+
if (!gql.access || !gql.access.sharedBy.keyPair) {
|
|
6
|
+
throw `File ${gql.id} doesn't have access`;
|
|
7
|
+
}
|
|
8
|
+
const file = {
|
|
9
|
+
id: gql.id,
|
|
10
|
+
md5: gql.md5,
|
|
11
|
+
md5Encrypted: gql.md5Encrypted,
|
|
12
|
+
createdAt: new Date(gql.createdAt),
|
|
13
|
+
size: BigInt(gql.size),
|
|
14
|
+
sizeBefore: BigInt(gql.sizeBefore),
|
|
15
|
+
key: sodium.to_hex(decryptCryptoBox(sodium.from_hex(gql.access.key), gql.access.sharedBy.keyPair.pub, keyPair.privateKey))
|
|
16
|
+
};
|
|
17
|
+
filesCache.set(file.id, file);
|
|
18
|
+
return file;
|
|
19
|
+
}
|
|
20
|
+
export function internalFileToFile(internal) {
|
|
21
|
+
return {
|
|
22
|
+
id: internal.id,
|
|
23
|
+
md5: internal.md5,
|
|
24
|
+
md5Encrypted: internal.md5Encrypted,
|
|
25
|
+
createdAt: internal.createdAt,
|
|
26
|
+
size: internal.size,
|
|
27
|
+
sizeBefore: internal.sizeBefore
|
|
28
|
+
};
|
|
29
|
+
}
|
|
30
|
+
export function gqlFileToExternal(gql, keyPair) {
|
|
31
|
+
return internalFileToFile(gqlFileToInternal(gql, keyPair));
|
|
32
|
+
}
|
|
33
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJmaWxlc0NhY2hlIiwiZGVjcnlwdENyeXB0b0JveCIsInNvZGl1bSIsImdxbEZpbGVUb0ludGVybmFsIiwiZ3FsIiwia2V5UGFpciIsImFjY2VzcyIsInNoYXJlZEJ5IiwiaWQiLCJmaWxlIiwibWQ1IiwibWQ1RW5jcnlwdGVkIiwiY3JlYXRlZEF0IiwiRGF0ZSIsInNpemUiLCJCaWdJbnQiLCJzaXplQmVmb3JlIiwia2V5IiwidG9faGV4IiwiZnJvbV9oZXgiLCJwdWIiLCJwcml2YXRlS2V5Iiwic2V0IiwiaW50ZXJuYWxGaWxlVG9GaWxlIiwiaW50ZXJuYWwiLCJncWxGaWxlVG9FeHRlcm5hbCJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jbGllbnQvY29udmVydC9maWxlLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGZpbGVzQ2FjaGUgfSBmcm9tIFwiLi4vLi4vY2FjaGUuanNcIjtcbmltcG9ydCB0eXBlIHsgS2V5UGFpciB9IGZyb20gXCIuLi8uLi9jcnlwdG8vaW5kZXguanNcIjtcbmltcG9ydCB7IGRlY3J5cHRDcnlwdG9Cb3ggfSBmcm9tIFwiLi4vLi4vY3J5cHRvL2luZGV4LmpzXCI7XG5pbXBvcnQgeyBzb2RpdW0gfSBmcm9tIFwiLi4vLi4vc29kaXVtLmpzXCI7XG5pbXBvcnQgdHlwZSB7IEdRTEZpbGUsIEludGVybmFsRmlsZSwgRmlsZU1ldGFkYXRhIH0gZnJvbSBcIi4uL3R5cGVzL2luZGV4LmpzXCI7XG5cbmV4cG9ydCBmdW5jdGlvbiBncWxGaWxlVG9JbnRlcm5hbChcbiAgZ3FsOiBHUUxGaWxlLFxuICBrZXlQYWlyOiBLZXlQYWlyXG4pOiBJbnRlcm5hbEZpbGUge1xuICBpZiAoIWdxbC5hY2Nlc3MgfHwgIWdxbC5hY2Nlc3Muc2hhcmVkQnkua2V5UGFpcikge1xuICAgIHRocm93IGBGaWxlICR7Z3FsLmlkfSBkb2Vzbid0IGhhdmUgYWNjZXNzYDtcbiAgfVxuXG4gIGNvbnN0IGZpbGU6IEludGVybmFsRmlsZSA9IHtcbiAgICBpZDogZ3FsLmlkLFxuICAgIG1kNTogZ3FsLm1kNSxcbiAgICBtZDVFbmNyeXB0ZWQ6IGdxbC5tZDVFbmNyeXB0ZWQsXG4gICAgY3JlYXRlZEF0OiBuZXcgRGF0ZShncWwuY3JlYXRlZEF0IGFzIHN0cmluZyksXG4gICAgc2l6ZTogQmlnSW50KGdxbC5zaXplIGFzIHN0cmluZyksXG4gICAgc2l6ZUJlZm9yZTogQmlnSW50KGdxbC5zaXplQmVmb3JlIGFzIHN0cmluZyksXG4gICAga2V5OiBzb2RpdW0udG9faGV4KFxuICAgICAgZGVjcnlwdENyeXB0b0JveChcbiAgICAgICAgc29kaXVtLmZyb21faGV4KGdxbC5hY2Nlc3Mua2V5KSxcbiAgICAgICAgZ3FsLmFjY2Vzcy5zaGFyZWRCeS5rZXlQYWlyLnB1YixcbiAgICAgICAga2V5UGFpci5wcml2YXRlS2V5XG4gICAgICApXG4gICAgKVxuICB9O1xuXG4gIGZpbGVzQ2FjaGUuc2V0KGZpbGUuaWQsIGZpbGUpO1xuXG4gIHJldHVybiBmaWxlO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gaW50ZXJuYWxGaWxlVG9GaWxlKGludGVybmFsOiBJbnRlcm5hbEZpbGUpOiBGaWxlTWV0YWRhdGEge1xuICByZXR1cm4ge1xuICAgIGlkOiBpbnRlcm5hbC5pZCxcbiAgICBtZDU6IGludGVybmFsLm1kNSxcbiAgICBtZDVFbmNyeXB0ZWQ6IGludGVybmFsLm1kNUVuY3J5cHRlZCxcbiAgICBjcmVhdGVkQXQ6IGludGVybmFsLmNyZWF0ZWRBdCxcbiAgICBzaXplOiBpbnRlcm5hbC5zaXplLFxuICAgIHNpemVCZWZvcmU6IGludGVybmFsLnNpemVCZWZvcmVcbiAgfTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGdxbEZpbGVUb0V4dGVybmFsKFxuICBncWw6IEdRTEZpbGUsXG4gIGtleVBhaXI6IEtleVBhaXJcbik6IEZpbGVNZXRhZGF0YSB7XG4gIHJldHVybiBpbnRlcm5hbEZpbGVUb0ZpbGUoZ3FsRmlsZVRvSW50ZXJuYWwoZ3FsLCBrZXlQYWlyKSk7XG59XG4iXSwibWFwcGluZ3MiOiJBQUFBLFNBQVNBLFVBQVUsUUFBUSxnQkFBZ0I7QUFFM0MsU0FBU0MsZ0JBQWdCLFFBQVEsdUJBQXVCO0FBQ3hELFNBQVNDLE1BQU0sUUFBUSxpQkFBaUI7QUFHeEMsT0FBTyxTQUFTQyxpQkFBaUIsQ0FDL0JDLEdBQVksRUFDWkMsT0FBZ0IsRUFDRjtFQUNkLElBQUksQ0FBQ0QsR0FBRyxDQUFDRSxNQUFNLElBQUksQ0FBQ0YsR0FBRyxDQUFDRSxNQUFNLENBQUNDLFFBQVEsQ0FBQ0YsT0FBTyxFQUFFO0lBQy9DLE1BQU8sUUFBT0QsR0FBRyxDQUFDSSxFQUFHLHNCQUFxQjtFQUM1QztFQUVBLE1BQU1DLElBQWtCLEdBQUc7SUFDekJELEVBQUUsRUFBRUosR0FBRyxDQUFDSSxFQUFFO0lBQ1ZFLEdBQUcsRUFBRU4sR0FBRyxDQUFDTSxHQUFHO0lBQ1pDLFlBQVksRUFBRVAsR0FBRyxDQUFDTyxZQUFZO0lBQzlCQyxTQUFTLEVBQUUsSUFBSUMsSUFBSSxDQUFDVCxHQUFHLENBQUNRLFNBQVMsQ0FBVztJQUM1Q0UsSUFBSSxFQUFFQyxNQUFNLENBQUNYLEdBQUcsQ0FBQ1UsSUFBSSxDQUFXO0lBQ2hDRSxVQUFVLEVBQUVELE1BQU0sQ0FBQ1gsR0FBRyxDQUFDWSxVQUFVLENBQVc7SUFDNUNDLEdBQUcsRUFBRWYsTUFBTSxDQUFDZ0IsTUFBTSxDQUNoQmpCLGdCQUFnQixDQUNkQyxNQUFNLENBQUNpQixRQUFRLENBQUNmLEdBQUcsQ0FBQ0UsTUFBTSxDQUFDVyxHQUFHLENBQUMsRUFDL0JiLEdBQUcsQ0FBQ0UsTUFBTSxDQUFDQyxRQUFRLENBQUNGLE9BQU8sQ0FBQ2UsR0FBRyxFQUMvQmYsT0FBTyxDQUFDZ0IsVUFBVSxDQUNuQjtFQUVMLENBQUM7RUFFRHJCLFVBQVUsQ0FBQ3NCLEdBQUcsQ0FBQ2IsSUFBSSxDQUFDRCxFQUFFLEVBQUVDLElBQUksQ0FBQztFQUU3QixPQUFPQSxJQUFJO0FBQ2I7QUFFQSxPQUFPLFNBQVNjLGtCQUFrQixDQUFDQyxRQUFzQixFQUFnQjtFQUN2RSxPQUFPO0lBQ0xoQixFQUFFLEVBQUVnQixRQUFRLENBQUNoQixFQUFFO0lBQ2ZFLEdBQUcsRUFBRWMsUUFBUSxDQUFDZCxHQUFHO0lBQ2pCQyxZQUFZLEVBQUVhLFFBQVEsQ0FBQ2IsWUFBWTtJQUNuQ0MsU0FBUyxFQUFFWSxRQUFRLENBQUNaLFNBQVM7SUFDN0JFLElBQUksRUFBRVUsUUFBUSxDQUFDVixJQUFJO0lBQ25CRSxVQUFVLEVBQUVRLFFBQVEsQ0FBQ1I7RUFDdkIsQ0FBQztBQUNIO0FBRUEsT0FBTyxTQUFTUyxpQkFBaUIsQ0FDL0JyQixHQUFZLEVBQ1pDLE9BQWdCLEVBQ0Y7RUFDZCxPQUFPa0Isa0JBQWtCLENBQUNwQixpQkFBaUIsQ0FBQ0MsR0FBRyxFQUFFQyxPQUFPLENBQUMsQ0FBQztBQUM1RCJ9
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { sodium, decryptCryptoBox } from "../../index.js";
|
|
2
|
+
export function convertInternalMailToExternal(data, keys) {
|
|
3
|
+
var _mI$replyTo;
|
|
4
|
+
let type = data.type;
|
|
5
|
+
if (data.mailIntegrityDraft) {
|
|
6
|
+
type = "draft";
|
|
7
|
+
}
|
|
8
|
+
const mI = type === "draft" ? data.mailIntegrityDraft : data.mailIntegrity;
|
|
9
|
+
if (!mI) {
|
|
10
|
+
return null;
|
|
11
|
+
}
|
|
12
|
+
const pubKey = data.type === "received" ? data.sender.publicKey : keys.publicKey;
|
|
13
|
+
const body = sodium.to_string(decryptCryptoBox(sodium.from_hex(data.body), pubKey, keys.privateKey));
|
|
14
|
+
const subject = sodium.to_string(decryptCryptoBox(sodium.from_hex(data.subject), pubKey, keys.privateKey));
|
|
15
|
+
const hash = sodium.crypto_generichash(sodium.crypto_generichash_BYTES, JSON.stringify({
|
|
16
|
+
body,
|
|
17
|
+
subject
|
|
18
|
+
}), mI.hashKey, "hex");
|
|
19
|
+
return {
|
|
20
|
+
type,
|
|
21
|
+
id: data.id,
|
|
22
|
+
mailIntegrityId: mI.id,
|
|
23
|
+
replyTo: (_mI$replyTo = mI.replyTo) == null ? void 0 : _mI$replyTo.id,
|
|
24
|
+
body,
|
|
25
|
+
subject,
|
|
26
|
+
createdAt: new Date(data.createdAt),
|
|
27
|
+
deletedAt: data.deletedAt ? new Date(data.deletedAt) : null,
|
|
28
|
+
openedAt: data.openedAt ? new Date(data.openedAt) : null,
|
|
29
|
+
isAltered: hash !== mI.hash,
|
|
30
|
+
temporaryRecipients: mI.temporaryRecipients,
|
|
31
|
+
recipients: type === "draft" ? mI.recipients : data.recipients,
|
|
32
|
+
sender: data.sender,
|
|
33
|
+
files: data.files.map(f => {
|
|
34
|
+
const name = sodium.to_string(decryptCryptoBox(sodium.from_hex(f.filename), pubKey, keys.privateKey));
|
|
35
|
+
return {
|
|
36
|
+
id: f.file.id,
|
|
37
|
+
name,
|
|
38
|
+
key: f.fileKey
|
|
39
|
+
};
|
|
40
|
+
})
|
|
41
|
+
};
|
|
42
|
+
}
|
|
43
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJzb2RpdW0iLCJkZWNyeXB0Q3J5cHRvQm94IiwiY29udmVydEludGVybmFsTWFpbFRvRXh0ZXJuYWwiLCJkYXRhIiwia2V5cyIsInR5cGUiLCJtYWlsSW50ZWdyaXR5RHJhZnQiLCJtSSIsIm1haWxJbnRlZ3JpdHkiLCJwdWJLZXkiLCJzZW5kZXIiLCJwdWJsaWNLZXkiLCJib2R5IiwidG9fc3RyaW5nIiwiZnJvbV9oZXgiLCJwcml2YXRlS2V5Iiwic3ViamVjdCIsImhhc2giLCJjcnlwdG9fZ2VuZXJpY2hhc2giLCJjcnlwdG9fZ2VuZXJpY2hhc2hfQllURVMiLCJKU09OIiwic3RyaW5naWZ5IiwiaGFzaEtleSIsImlkIiwibWFpbEludGVncml0eUlkIiwicmVwbHlUbyIsImNyZWF0ZWRBdCIsIkRhdGUiLCJkZWxldGVkQXQiLCJvcGVuZWRBdCIsImlzQWx0ZXJlZCIsInRlbXBvcmFyeVJlY2lwaWVudHMiLCJyZWNpcGllbnRzIiwiZmlsZXMiLCJtYXAiLCJmIiwibmFtZSIsImZpbGVuYW1lIiwiZmlsZSIsImtleSIsImZpbGVLZXkiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY2xpZW50L2NvbnZlcnQvbWFpbC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IEtleVBhaXIgfSBmcm9tIFwiLi4vLi4vY3J5cHRvL2luZGV4LmpzXCI7XG5pbXBvcnQgdHlwZSB7IEdRTE1haWwsIE1haWwsIE1haWxUeXBlIH0gZnJvbSBcIi4uL3R5cGVzL2luZGV4LmpzXCI7XG5pbXBvcnQgeyBzb2RpdW0sIGRlY3J5cHRDcnlwdG9Cb3ggfSBmcm9tIFwiLi4vLi4vaW5kZXguanNcIjtcblxuZXhwb3J0IGZ1bmN0aW9uIGNvbnZlcnRJbnRlcm5hbE1haWxUb0V4dGVybmFsKFxuICBkYXRhOiBHUUxNYWlsLFxuICBrZXlzOiBLZXlQYWlyXG4pOiBNYWlsIHwgbnVsbCB7XG4gIGxldCB0eXBlOiBNYWlsVHlwZSA9IGRhdGEudHlwZTtcbiAgaWYgKGRhdGEubWFpbEludGVncml0eURyYWZ0KSB7XG4gICAgdHlwZSA9IFwiZHJhZnRcIjtcbiAgfVxuXG4gIGNvbnN0IG1JID0gdHlwZSA9PT0gXCJkcmFmdFwiID8gZGF0YS5tYWlsSW50ZWdyaXR5RHJhZnQgOiBkYXRhLm1haWxJbnRlZ3JpdHk7XG5cbiAgaWYgKCFtSSkge1xuICAgIHJldHVybiBudWxsO1xuICB9XG5cbiAgY29uc3QgcHViS2V5ID1cbiAgICBkYXRhLnR5cGUgPT09IFwicmVjZWl2ZWRcIiA/IGRhdGEuc2VuZGVyLnB1YmxpY0tleSA6IGtleXMucHVibGljS2V5O1xuXG4gIGNvbnN0IGJvZHkgPSBzb2RpdW0udG9fc3RyaW5nKFxuICAgIGRlY3J5cHRDcnlwdG9Cb3goc29kaXVtLmZyb21faGV4KGRhdGEuYm9keSksIHB1YktleSwga2V5cy5wcml2YXRlS2V5KVxuICApO1xuXG4gIGNvbnN0IHN1YmplY3QgPSBzb2RpdW0udG9fc3RyaW5nKFxuICAgIGRlY3J5cHRDcnlwdG9Cb3goc29kaXVtLmZyb21faGV4KGRhdGEuc3ViamVjdCksIHB1YktleSwga2V5cy5wcml2YXRlS2V5KVxuICApO1xuXG4gIGNvbnN0IGhhc2ggPSBzb2RpdW0uY3J5cHRvX2dlbmVyaWNoYXNoKFxuICAgIHNvZGl1bS5jcnlwdG9fZ2VuZXJpY2hhc2hfQllURVMsXG4gICAgSlNPTi5zdHJpbmdpZnkoeyBib2R5LCBzdWJqZWN0IH0pLFxuICAgIG1JLmhhc2hLZXksXG4gICAgXCJoZXhcIlxuICApO1xuXG4gIHJldHVybiB7XG4gICAgdHlwZSxcbiAgICBpZDogZGF0YS5pZCxcbiAgICBtYWlsSW50ZWdyaXR5SWQ6IG1JLmlkLFxuICAgIHJlcGx5VG86IG1JLnJlcGx5VG8/LmlkLFxuICAgIGJvZHksXG4gICAgc3ViamVjdCxcbiAgICBjcmVhdGVkQXQ6IG5ldyBEYXRlKGRhdGEuY3JlYXRlZEF0IGFzIHN0cmluZyksXG4gICAgZGVsZXRlZEF0OiBkYXRhLmRlbGV0ZWRBdCA/IG5ldyBEYXRlKGRhdGEuZGVsZXRlZEF0IGFzIHN0cmluZykgOiBudWxsLFxuICAgIG9wZW5lZEF0OiBkYXRhLm9wZW5lZEF0ID8gbmV3IERhdGUoZGF0YS5vcGVuZWRBdCBhcyBzdHJpbmcpIDogbnVsbCxcbiAgICBpc0FsdGVyZWQ6IGhhc2ggIT09IG1JLmhhc2gsXG4gICAgdGVtcG9yYXJ5UmVjaXBpZW50czogbUkudGVtcG9yYXJ5UmVjaXBpZW50cyxcbiAgICByZWNpcGllbnRzOiB0eXBlID09PSBcImRyYWZ0XCIgPyBtSS5yZWNpcGllbnRzIDogZGF0YS5yZWNpcGllbnRzLFxuICAgIHNlbmRlcjogZGF0YS5zZW5kZXIsXG4gICAgZmlsZXM6IGRhdGEuZmlsZXMubWFwKGYgPT4ge1xuICAgICAgY29uc3QgbmFtZSA9IHNvZGl1bS50b19zdHJpbmcoXG4gICAgICAgIGRlY3J5cHRDcnlwdG9Cb3goc29kaXVtLmZyb21faGV4KGYuZmlsZW5hbWUpLCBwdWJLZXksIGtleXMucHJpdmF0ZUtleSlcbiAgICAgICk7XG5cbiAgICAgIHJldHVybiB7XG4gICAgICAgIGlkOiBmLmZpbGUuaWQsXG4gICAgICAgIG5hbWUsXG4gICAgICAgIGtleTogZi5maWxlS2V5XG4gICAgICB9O1xuICAgIH0pXG4gIH07XG59XG4iXSwibWFwcGluZ3MiOiJBQUVBLFNBQVNBLE1BQU0sRUFBRUMsZ0JBQWdCLFFBQVEsZ0JBQWdCO0FBRXpELE9BQU8sU0FBU0MsNkJBQTZCLENBQzNDQyxJQUFhLEVBQ2JDLElBQWEsRUFDQTtFQUFBO0VBQ2IsSUFBSUMsSUFBYyxHQUFHRixJQUFJLENBQUNFLElBQUk7RUFDOUIsSUFBSUYsSUFBSSxDQUFDRyxrQkFBa0IsRUFBRTtJQUMzQkQsSUFBSSxHQUFHLE9BQU87RUFDaEI7RUFFQSxNQUFNRSxFQUFFLEdBQUdGLElBQUksS0FBSyxPQUFPLEdBQUdGLElBQUksQ0FBQ0csa0JBQWtCLEdBQUdILElBQUksQ0FBQ0ssYUFBYTtFQUUxRSxJQUFJLENBQUNELEVBQUUsRUFBRTtJQUNQLE9BQU8sSUFBSTtFQUNiO0VBRUEsTUFBTUUs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
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { KeyPair } from "../../crypto/index.js";
|
|
2
|
+
import type { Node } from "../types/index.js";
|
|
3
|
+
import type { GQLNode, InternalNode, GQLNodeFull, InternalNodeFull, NodeFull } from "../types/index.js";
|
|
4
|
+
export declare function gqlNodeToInternal(gql: GQLNode, keyPair: KeyPair): Promise<InternalNode>;
|
|
5
|
+
export declare function gqlNodeFullToInternalFull(gql: GQLNodeFull, keyPair: KeyPair): Promise<InternalNodeFull>;
|
|
6
|
+
export declare function internalNodeToNode(internal: InternalNode): Node;
|
|
7
|
+
export declare function internalNodeFullToNodeFull(internal: InternalNodeFull): NodeFull;
|
|
8
|
+
export declare function gqlNodeToExternalNodeFull(gql: GQLNodeFull, keyPair: KeyPair): Promise<NodeFull>;
|
|
9
|
+
export declare function gqlNodeToExternal(gql: GQLNode, keyPair: KeyPair): Promise<Node>;
|
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
import _defineProperty from "@babel/runtime/helpers/defineProperty";
|
|
2
|
+
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; }
|
|
3
|
+
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; }
|
|
4
|
+
import { sodium } from "../../sodium.js";
|
|
5
|
+
import { decryptCryptoBox } from "../../crypto/index.js";
|
|
6
|
+
import { nodesCache } from "../../cache.js";
|
|
7
|
+
import { decryptSecretstream } from "../../crypto/file.js";
|
|
8
|
+
import { gqlFileToInternal, internalFileToFile } from "./file.js";
|
|
9
|
+
export async function gqlNodeToInternal(gql, keyPair) {
|
|
10
|
+
if (!gql.access) {
|
|
11
|
+
throw `Can't access Node ${gql.id}`;
|
|
12
|
+
}
|
|
13
|
+
const internal = {
|
|
14
|
+
id: gql.id,
|
|
15
|
+
type: gql.type,
|
|
16
|
+
access: gql.access,
|
|
17
|
+
name: gql.name,
|
|
18
|
+
isFavorite: gql.isFavorite,
|
|
19
|
+
breadcrumb: gql.breadcrumb,
|
|
20
|
+
createdBy: gql.createdBy.user,
|
|
21
|
+
sizes: {
|
|
22
|
+
size: BigInt(gql.sizes.size),
|
|
23
|
+
sizeBefore: BigInt(gql.sizes.sizeBefore)
|
|
24
|
+
},
|
|
25
|
+
createdAt: new Date(gql.createdAt),
|
|
26
|
+
updatedAt: new Date(gql.updatedAt),
|
|
27
|
+
deletedAt: gql.deletedAt ? new Date(gql.deletedAt) : null,
|
|
28
|
+
users: gql.accesses.map(u => [u.userApp.user, u.rights]),
|
|
29
|
+
parentId: gql.parentId ?? null,
|
|
30
|
+
currentFileId: gql.currentFileId ?? null
|
|
31
|
+
};
|
|
32
|
+
internal.access = _objectSpread({}, gql.access);
|
|
33
|
+
if (gql.access.nameKey) {
|
|
34
|
+
if (!gql.access.sharedBy.keyPair) {
|
|
35
|
+
throw new Error(`Can't find keyPair for access`);
|
|
36
|
+
}
|
|
37
|
+
const key = decryptCryptoBox(sodium.from_hex(gql.access.nameKey), gql.createdBy.user.publicKey, keyPair.privateKey);
|
|
38
|
+
internal.name = sodium.to_string(await decryptSecretstream(key, sodium.from_hex(internal.name)));
|
|
39
|
+
internal.access.nameKey = sodium.to_hex(key);
|
|
40
|
+
}
|
|
41
|
+
for (const b of internal.breadcrumb) {
|
|
42
|
+
if (!b.nameKey) {
|
|
43
|
+
continue;
|
|
44
|
+
}
|
|
45
|
+
const key = decryptCryptoBox(sodium.from_hex(b.nameKey), b.pubKey, keyPair.privateKey);
|
|
46
|
+
b.nameKey = sodium.to_hex(key);
|
|
47
|
+
b.name = sodium.to_string(await decryptSecretstream(key, sodium.from_hex(b.name)));
|
|
48
|
+
}
|
|
49
|
+
nodesCache.set(internal.id, internal);
|
|
50
|
+
return internal;
|
|
51
|
+
}
|
|
52
|
+
export async function gqlNodeFullToInternalFull(gql, keyPair) {
|
|
53
|
+
const f = await gqlNodeToInternal(gql, keyPair);
|
|
54
|
+
return _objectSpread(_objectSpread({}, f), {}, {
|
|
55
|
+
current: gql.current ? gqlFileToInternal(gql.current, keyPair) : undefined,
|
|
56
|
+
parent: gql.parent ? await gqlNodeToInternal(gql.parent, keyPair) : null,
|
|
57
|
+
children: await Promise.all(gql.children.map(s => gqlNodeToInternal(s, keyPair))),
|
|
58
|
+
history: gql.history.map(f => gqlFileToInternal(f, keyPair))
|
|
59
|
+
});
|
|
60
|
+
}
|
|
61
|
+
export function internalNodeToNode(internal) {
|
|
62
|
+
var _node$access;
|
|
63
|
+
const node = _objectSpread(_objectSpread({}, internal), {}, {
|
|
64
|
+
access: internal.access ? _objectSpread({}, internal.access) : undefined
|
|
65
|
+
});
|
|
66
|
+
for (const b of node.breadcrumb) {
|
|
67
|
+
// @ts-ignore
|
|
68
|
+
delete b.pubKey;
|
|
69
|
+
}
|
|
70
|
+
// @ts-ignore
|
|
71
|
+
(_node$access = node.access) == null ? true : delete _node$access.nameKey;
|
|
72
|
+
return node;
|
|
73
|
+
}
|
|
74
|
+
export function internalNodeFullToNodeFull(internal) {
|
|
75
|
+
return _objectSpread(_objectSpread({}, internalNodeToNode(internal)), {}, {
|
|
76
|
+
parent: internal.parent ? internalNodeToNode(internal.parent) : null,
|
|
77
|
+
children: internal.children.map(internalNodeToNode),
|
|
78
|
+
history: internal.history.map(f => internalFileToFile(f)),
|
|
79
|
+
current: internal.current ? internalFileToFile(internal.current) : undefined
|
|
80
|
+
});
|
|
81
|
+
}
|
|
82
|
+
export async function gqlNodeToExternalNodeFull(gql, keyPair) {
|
|
83
|
+
return internalNodeFullToNodeFull(await gqlNodeFullToInternalFull(gql, keyPair));
|
|
84
|
+
}
|
|
85
|
+
export async function gqlNodeToExternal(gql, keyPair) {
|
|
86
|
+
return internalNodeToNode(await gqlNodeToInternal(gql, keyPair));
|
|
87
|
+
}
|
|
88
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["sodium","decryptCryptoBox","nodesCache","decryptSecretstream","gqlFileToInternal","internalFileToFile","gqlNodeToInternal","gql","keyPair","access","id","internal","type","name","isFavorite","breadcrumb","createdBy","user","sizes","size","BigInt","sizeBefore","createdAt","Date","updatedAt","deletedAt","users","accesses","map","u","userApp","rights","parentId","currentFileId","nameKey","sharedBy","Error","key","from_hex","publicKey","privateKey","to_string","to_hex","b","pubKey","set","gqlNodeFullToInternalFull","f","current","undefined","parent","children","Promise","all","s","history","internalNodeToNode","node","internalNodeFullToNodeFull","gqlNodeToExternalNodeFull","gqlNodeToExternal"],"sources":["../../../src/client/convert/node.ts"],"sourcesContent":["import { sodium } from \"../../sodium.js\";\nimport type { KeyPair } from \"../../crypto/index.js\";\nimport { decryptCryptoBox } from \"../../crypto/index.js\";\nimport type { Node } from \"../types/index.js\";\nimport type {\n  GQLNode,\n  InternalNode,\n  GQLNodeFull,\n  InternalNodeFull,\n  NodeFull\n} from \"../types/index.js\";\nimport { nodesCache } from \"../../cache.js\";\nimport { decryptSecretstream } from \"../../crypto/file.js\";\nimport { gqlFileToInternal, internalFileToFile } from \"./file.js\";\n\nexport async function gqlNodeToInternal(\n  gql: GQLNode,\n  keyPair: KeyPair\n): Promise<InternalNode> {\n  if (!gql.access) {\n    throw `Can't access Node ${gql.id}`;\n  }\n\n  const internal: InternalNode = {\n    id: gql.id,\n    type: gql.type,\n    access: gql.access,\n    name: gql.name,\n    isFavorite: gql.isFavorite,\n    breadcrumb: gql.breadcrumb,\n    createdBy: gql.createdBy.user,\n    sizes: {\n      size: BigInt(gql.sizes.size as string),\n      sizeBefore: BigInt(gql.sizes.sizeBefore as string)\n    },\n    createdAt: new Date(gql.createdAt as string),\n    updatedAt: new Date(gql.updatedAt as string),\n    deletedAt: gql.deletedAt ? new Date(gql.deletedAt as string) : null,\n    users: gql.accesses.map(u => [u.userApp.user, u.rights]),\n    parentId: gql.parentId ?? null,\n    currentFileId: gql.currentFileId ?? null\n  };\n\n  internal.access = { ...gql.access };\n\n  if (gql.access.nameKey) {\n    if (!gql.access.sharedBy.keyPair) {\n      throw new Error(`Can't find keyPair for access`);\n    }\n    const key = decryptCryptoBox(\n      sodium.from_hex(gql.access.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.access.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\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  nodesCache.set(internal.id, internal);\n  return internal;\n}\n\nexport async function gqlNodeFullToInternalFull(\n  gql: GQLNodeFull,\n  keyPair: KeyPair\n): Promise<InternalNodeFull> {\n  const f = await gqlNodeToInternal(gql, keyPair);\n  return {\n    ...f,\n    current: gql.current ? gqlFileToInternal(gql.current, keyPair) : undefined,\n    parent: gql.parent ? await gqlNodeToInternal(gql.parent, keyPair) : null,\n    children: await Promise.all(\n      gql.children.map(s => gqlNodeToInternal(s, keyPair))\n    ),\n    history: gql.history.map(f => gqlFileToInternal(f, keyPair))\n  };\n}\n\nexport function internalNodeToNode(internal: InternalNode): Node {\n  const node: Node = {\n    ...internal,\n    access: internal.access ? { ...internal.access } : undefined\n  };\n\n  for (const b of node.breadcrumb) {\n    // @ts-ignore\n    delete b.pubKey;\n  }\n  // @ts-ignore\n  delete node.access?.nameKey;\n  return node;\n}\n\nexport function internalNodeFullToNodeFull(\n  internal: InternalNodeFull\n): NodeFull {\n  return {\n    ...internalNodeToNode(internal),\n    parent: internal.parent ? internalNodeToNode(internal.parent) : null,\n    children: internal.children.map(internalNodeToNode),\n    history: internal.history.map(f => internalFileToFile(f)),\n    current: internal.current ? internalFileToFile(internal.current) : undefined\n  };\n}\n\nexport async function gqlNodeToExternalNodeFull(\n  gql: GQLNodeFull,\n  keyPair: KeyPair\n): Promise<NodeFull> {\n  return internalNodeFullToNodeFull(\n    await gqlNodeFullToInternalFull(gql, keyPair)\n  );\n}\n\nexport async function gqlNodeToExternal(\n  gql: GQLNode,\n  keyPair: KeyPair\n): Promise<Node> {\n  return internalNodeToNode(await gqlNodeToInternal(gql, keyPair));\n}\n"],"mappings":";;;AAAA,SAASA,MAAM,QAAQ,iBAAiB;AAExC,SAASC,gBAAgB,QAAQ,uBAAuB;AASxD,SAASC,UAAU,QAAQ,gBAAgB;AAC3C,SAASC,mBAAmB,QAAQ,sBAAsB;AAC1D,SAASC,iBAAiB,EAAEC,kBAAkB,QAAQ,WAAW;AAEjE,OAAO,eAAeC,iBAAiB,CACrCC,GAAY,EACZC,OAAgB,EACO;EACvB,IAAI,CAACD,GAAG,CAACE,MAAM,EAAE;IACf,MAAO,qBAAoBF,GAAG,CAACG,EAAG,EAAC;EACrC;EAEA,MAAMC,QAAsB,GAAG;IAC7BD,EAAE,EAAEH,GAAG,CAACG,EAAE;IACVE,IAAI,EAAEL,GAAG,CAACK,IAAI;IACdH,MAAM,EAAEF,GAAG,CAACE,MAAM;IAClBI,IAAI,EAAEN,GAAG,CAACM,IAAI;IACdC,UAAU,EAAEP,GAAG,CAACO,UAAU;IAC1BC,UAAU,EAAER,GAAG,CAACQ,UAAU;IAC1BC,SAAS,EAAET,GAAG,CAACS,SAAS,CAACC,IAAI;IAC7BC,KAAK,EAAE;MACLC,IAAI,EAAEC,MAAM,CAACb,GAAG,CAACW,KAAK,CAACC,IAAI,CAAW;MACtCE,UAAU,EAAED,MAAM,CAACb,GAAG,CAACW,KAAK,CAACG,UAAU;IACzC,CAAC;IACDC,SAAS,EAAE,IAAIC,IAAI,CAAChB,GAAG,CAACe,SAAS,CAAW;IAC5CE,SAAS,EAAE,IAAID,IAAI,CAAChB,GAAG,CAACiB,SAAS,CAAW;IAC5CC,SAAS,EAAElB,GAAG,CAACkB,SAAS,GAAG,IAAIF,IAAI,CAAChB,GAAG,CAACkB,SAAS,CAAW,GAAG,IAAI;IACnEC,KAAK,EAAEnB,GAAG,CAACoB,QAAQ,CAACC,GAAG,CAACC,CAAC,IAAI,CAACA,CAAC,CAACC,OAAO,CAACb,IAAI,EAAEY,CAAC,CAACE,MAAM,CAAC,CAAC;IACxDC,QAAQ,EAAEzB,GAAG,CAACyB,QAAQ,IAAI,IAAI;IAC9BC,aAAa,EAAE1B,GAAG,CAAC0B,aAAa,IAAI;EACtC,CAAC;EAEDtB,QAAQ,CAACF,MAAM,qBAAQF,GAAG,CAACE,MAAM,CAAE;EAEnC,IAAIF,GAAG,CAACE,MAAM,CAACyB,OAAO,EAAE;IACtB,IAAI,CAAC3B,GAAG,CAACE,MAAM,CAAC0B,QAAQ,CAAC3B,OAAO,EAAE;MAChC,MAAM,IAAI4B,KAAK,CAAE,+BAA8B,CAAC;IAClD;IACA,MAAMC,GAAG,GAAGpC,gBAAgB,CAC1BD,MAAM,CAACsC,QAAQ,CAAC/B,GAAG,CAACE,MAAM,CAACyB,OAAO,CAAC,EACnC3B,GAAG,CAACS,SAAS,CAACC,IAAI,CAACsB,SAAS,EAC5B/B,OAAO,CAACgC,UAAU,CACnB;IACD7B,QAAQ,CAACE,IAAI,GAAGb,MAAM,CAACyC,SAAS,CAC9B,MAAMtC,mBAAmB,CAACkC,GAAG,EAAErC,MAAM,CAACsC,QAAQ,CAAC3B,QAAQ,CAACE,IAAI,CAAC,CAAC,CAC/D;IAEDF,QAAQ,CAACF,MAAM,CAACyB,OAAO,GAAGlC,MAAM,CAAC0C,MAAM,CAACL,GAAG,CAAC;EAC9C;EAEA,KAAK,MAAMM,CAAC,IAAIhC,QAAQ,CAACI,UAAU,EAAE;IACnC,IAAI,CAAC4B,CAAC,CAACT,OAAO,EAAE;MACd;IACF;IACA,MAAMG,GAAG,GAAGpC,gBAAgB,CAC1BD,MAAM,CAACsC,QAAQ,CAACK,CAAC,CAACT,OAAO,CAAC,EAC1BS,CAAC,CAACC,MAAM,EACRpC,OAAO,CAACgC,UAAU,CACnB;IAEDG,CAAC,CAACT,OAAO,GAAGlC,MAAM,CAAC0C,MAAM,CAACL,GAAG,CAAC;IAE9BM,CAAC,CAAC9B,IAAI,GAAGb,MAAM,CAACyC,SAAS,CACvB,MAAMtC,mBAAmB,CAACkC,GAAG,EAAErC,MAAM,CAACsC,QAAQ,CAACK,CAAC,CAAC9B,IAAI,CAAC,CAAC,CACxD;EACH;EAEAX,UAAU,CAAC2C,GAAG,CAAClC,QAAQ,CAACD,EAAE,EAAEC,QAAQ,CAAC;EACrC,OAAOA,QAAQ;AACjB;AAEA,OAAO,eAAemC,yBAAyB,CAC7CvC,GAAgB,EAChBC,OAAgB,EACW;EAC3B,MAAMuC,CAAC,GAAG,MAAMzC,iBAAiB,CAACC,GAAG,EAAEC,OAAO,CAAC;EAC/C,uCACKuC,CAAC;IACJC,OAAO,EAAEzC,GAAG,CAACyC,OAAO,GAAG5C,iBAAiB,CAACG,GAAG,CAACyC,OAAO,EAAExC,OAAO,CAAC,GAAGyC,SAAS;IAC1EC,MAAM,EAAE3C,GAAG,CAAC2C,MAAM,GAAG,MAAM5C,iBAAiB,CAACC,GAAG,CAAC2C,MAAM,EAAE1C,OAAO,CAAC,GAAG,IAAI;IACxE2C,QAAQ,EAAE,MAAMC,OAAO,CAACC,GAAG,CACzB9C,GAAG,CAAC4C,QAAQ,CAACvB,GAAG,CAAC0B,CAAC,IAAIhD,iBAAiB,CAACgD,CAAC,EAAE9C,OAAO,CAAC,CAAC,CACrD;IACD+C,OAAO,EAAEhD,GAAG,CAACgD,OAAO,CAAC3B,GAAG,CAACmB,CAAC,IAAI3C,iBAAiB,CAAC2C,CAAC,EAAEvC,OAAO,CAAC;EAAC;AAEhE;AAEA,OAAO,SAASgD,kBAAkB,CAAC7C,QAAsB,EAAQ;EAAA;EAC/D,MAAM8C,IAAU,mCACX9C,QAAQ;IACXF,MAAM,EAAEE,QAAQ,CAACF,MAAM,qBAAQE,QAAQ,CAACF,MAAM,IAAKwC;EAAS,EAC7D;EAED,KAAK,MAAMN,CAAC,IAAIc,IAAI,CAAC1C,UAAU,EAAE;IAC/B;IACA,OAAO4B,CAAC,CAACC,MAAM;EACjB;EACA;EACA,gBAAOa,IAAI,CAAChD,MAAM,mBAAlB,OAAO,aAAayB,OAAO;EAC3B,OAAOuB,IAAI;AACb;AAEA,OAAO,SAASC,0BAA0B,CACxC/C,QAA0B,EAChB;EACV,uCACK6C,kBAAkB,CAAC7C,QAAQ,CAAC;IAC/BuC,MAAM,EAAEvC,QAAQ,CAACuC,MAAM,GAAGM,kBAAkB,CAAC7C,QAAQ,CAACuC,MAAM,CAAC,GAAG,IAAI;IACpEC,QAAQ,EAAExC,QAAQ,CAACwC,QAAQ,CAACvB,GAAG,CAAC4B,kBAAkB,CAAC;IACnDD,OAAO,EAAE5C,QAAQ,CAAC4C,OAAO,CAAC3B,GAAG,CAACmB,CAAC,IAAI1C,kBAAkB,CAAC0C,CAAC,CAAC,CAAC;IACzDC,OAAO,EAAErC,QAAQ,CAACqC,OAAO,GAAG3C,kBAAkB,CAACM,QAAQ,CAACqC,OAAO,CAAC,GAAGC;EAAS;AAEhF;AAEA,OAAO,eAAeU,yBAAyB,CAC7CpD,GAAgB,EAChBC,OAAgB,EACG;EACnB,OAAOkD,0BAA0B,CAC/B,MAAMZ,yBAAyB,CAACvC,GAAG,EAAEC,OAAO,CAAC,CAC9C;AACH;AAEA,OAAO,eAAeoD,iBAAiB,CACrCrD,GAAY,EACZC,OAAgB,EACD;EACf,OAAOgD,kBAAkB,CAAC,MAAMlD,iBAAiB,CAACC,GAAG,EAAEC,OAAO,CAAC,CAAC;AAClE"}
|
|
@@ -1,6 +1,11 @@
|
|
|
1
1
|
import { SecrecyClient } from "./index.js";
|
|
2
2
|
import type { SecrecyUserApp } from "./types/index.js";
|
|
3
3
|
export declare function parseInfos(): SecrecyUserApp | null;
|
|
4
|
+
export declare const getUrl: ({ env, hash, path }: {
|
|
5
|
+
env: string;
|
|
6
|
+
hash: string;
|
|
7
|
+
path: string;
|
|
8
|
+
}) => string;
|
|
4
9
|
export declare type HashInfos = {
|
|
5
10
|
appUrl: string;
|
|
6
11
|
backPath?: string;
|
|
@@ -11,7 +16,7 @@ export declare type HashInfos = {
|
|
|
11
16
|
email: boolean;
|
|
12
17
|
};
|
|
13
18
|
};
|
|
14
|
-
export declare type SecrecyEnv = "dev" | "
|
|
19
|
+
export declare type SecrecyEnv = "dev" | "prod";
|
|
15
20
|
export declare type UseSecrecyParams = Omit<HashInfos, "appUrl"> & {
|
|
16
21
|
env: SecrecyEnv;
|
|
17
22
|
session?: boolean | undefined;
|
|
@@ -0,0 +1,119 @@
|
|
|
1
|
+
import { SecrecyClient } from "./index.js";
|
|
2
|
+
import { popup } from "../PopupTools.js";
|
|
3
|
+
import { getStorage } from "./storage.js";
|
|
4
|
+
export function parseInfos() {
|
|
5
|
+
if (!window.location.hash) {
|
|
6
|
+
return null;
|
|
7
|
+
}
|
|
8
|
+
const hash = window.location.hash.substr(1);
|
|
9
|
+
try {
|
|
10
|
+
const res = JSON.parse(atob(hash));
|
|
11
|
+
window.location.hash = "";
|
|
12
|
+
// TODO Add object content validation
|
|
13
|
+
return res;
|
|
14
|
+
} catch {
|
|
15
|
+
return null;
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
export const getUrl = _ref => {
|
|
19
|
+
let {
|
|
20
|
+
env,
|
|
21
|
+
hash,
|
|
22
|
+
path
|
|
23
|
+
} = _ref;
|
|
24
|
+
let envStr = "";
|
|
25
|
+
if (env === "dev") {
|
|
26
|
+
envStr = "dev.";
|
|
27
|
+
}
|
|
28
|
+
const lang = document.documentElement.lang;
|
|
29
|
+
return process.env.NEXT_PUBLIC_SECRECY_API_URL ? `http://localhost:3002${lang ? `/${lang}` : ""}${path.startsWith("/") ? path : `/${path}`}#${hash}` : `https://auth.${envStr}secrecy.me${lang ? `/${lang}` : ""}${path.startsWith("/") ? path : `/${path}`}#${hash}`;
|
|
30
|
+
};
|
|
31
|
+
export function getSecrecyClient(env, session) {
|
|
32
|
+
const storage = getStorage(session);
|
|
33
|
+
const uaSession = storage.userAppSession.load();
|
|
34
|
+
const uaKeys = storage.userAppKeys.load();
|
|
35
|
+
const uaJwt = storage.jwt.load();
|
|
36
|
+
if (!uaSession || !uaKeys || !uaJwt) {
|
|
37
|
+
const infos = parseInfos();
|
|
38
|
+
if (infos) {
|
|
39
|
+
storage.userAppKeys.save(infos.keys);
|
|
40
|
+
storage.userAppSession.save(infos.uaSession);
|
|
41
|
+
storage.jwt.save(infos.jwt);
|
|
42
|
+
return new SecrecyClient(infos.uaSession, infos.keys, infos.jwt, env);
|
|
43
|
+
}
|
|
44
|
+
return null;
|
|
45
|
+
}
|
|
46
|
+
return new SecrecyClient(uaSession, uaKeys, uaJwt, env);
|
|
47
|
+
}
|
|
48
|
+
export function login(_temp) {
|
|
49
|
+
let {
|
|
50
|
+
appCode,
|
|
51
|
+
path,
|
|
52
|
+
redirect,
|
|
53
|
+
scopes,
|
|
54
|
+
backPath,
|
|
55
|
+
env,
|
|
56
|
+
session
|
|
57
|
+
} = _temp === void 0 ? {} : _temp;
|
|
58
|
+
return new Promise((resolve, reject) => {
|
|
59
|
+
const appUrl = window.location.origin;
|
|
60
|
+
if (appCode && !appUrl.includes("localhost")) {
|
|
61
|
+
return reject("Can't use appCode if not in localhost");
|
|
62
|
+
}
|
|
63
|
+
const client = getSecrecyClient(env);
|
|
64
|
+
if (!client) {
|
|
65
|
+
const infos = {
|
|
66
|
+
appUrl,
|
|
67
|
+
appCode,
|
|
68
|
+
redirect,
|
|
69
|
+
path,
|
|
70
|
+
scopes,
|
|
71
|
+
backPath
|
|
72
|
+
};
|
|
73
|
+
const data = btoa(JSON.stringify(infos)).replaceAll("=", "");
|
|
74
|
+
const url = getUrl({
|
|
75
|
+
env,
|
|
76
|
+
hash: data,
|
|
77
|
+
path: "login"
|
|
78
|
+
});
|
|
79
|
+
const validate = infos => {
|
|
80
|
+
const storage = getStorage(session);
|
|
81
|
+
storage.userAppSession.save(infos.uaSession);
|
|
82
|
+
storage.userAppKeys.save(infos.keys);
|
|
83
|
+
storage.jwt.save(infos.jwt);
|
|
84
|
+
return resolve(new SecrecyClient(infos.uaSession, infos.keys, infos.jwt, env));
|
|
85
|
+
};
|
|
86
|
+
if (redirect) {
|
|
87
|
+
const infos = parseInfos();
|
|
88
|
+
if (infos) {
|
|
89
|
+
return validate(infos);
|
|
90
|
+
} else {
|
|
91
|
+
window.location.href = url;
|
|
92
|
+
return resolve(null);
|
|
93
|
+
}
|
|
94
|
+
} else {
|
|
95
|
+
popup(url, "Secrecy Login", {
|
|
96
|
+
width: 500,
|
|
97
|
+
height: 750,
|
|
98
|
+
resizable: "no",
|
|
99
|
+
menubar: "no",
|
|
100
|
+
location: "no",
|
|
101
|
+
centered: true,
|
|
102
|
+
scrollbars: "no"
|
|
103
|
+
}, (err, data) => {
|
|
104
|
+
if (err) {
|
|
105
|
+
return reject(err);
|
|
106
|
+
} else {
|
|
107
|
+
const infos = data;
|
|
108
|
+
if (infos) {
|
|
109
|
+
return validate(infos);
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
});
|
|
113
|
+
}
|
|
114
|
+
} else {
|
|
115
|
+
return resolve(client);
|
|
116
|
+
}
|
|
117
|
+
});
|
|
118
|
+
}
|
|
119
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["SecrecyClient","popup","getStorage","parseInfos","window","location","hash","substr","res","JSON","parse","atob","getUrl","env","path","envStr","lang","document","documentElement","process","NEXT_PUBLIC_SECRECY_API_URL","startsWith","getSecrecyClient","session","storage","uaSession","userAppSession","load","uaKeys","userAppKeys","uaJwt","jwt","infos","save","keys","login","appCode","redirect","scopes","backPath","Promise","resolve","reject","appUrl","origin","includes","client","data","btoa","stringify","replaceAll","url","validate","href","width","height","resizable","menubar","centered","scrollbars","err"],"sources":["../../src/client/helpers.ts"],"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 const getUrl = ({\n  env,\n  hash,\n  path\n}: {\n  env: string;\n  hash: string;\n  path: string;\n}): string => {\n  let envStr = \"\";\n  if (env === \"dev\") {\n    envStr = \"dev.\";\n  }\n  const lang = document.documentElement.lang;\n  return process.env.NEXT_PUBLIC_SECRECY_API_URL\n    ? `http://localhost:3002${lang ? `/${lang}` : \"\"}${\n        path.startsWith(\"/\") ? path : `/${path}`\n      }#${hash}`\n    : `https://auth.${envStr}secrecy.me${lang ? `/${lang}` : \"\"}${\n        path.startsWith(\"/\") ? path : `/${path}`\n      }#${hash}`;\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      const url = getUrl({\n        env,\n        hash: data,\n        path: \"login\"\n      });\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(\n          url,\n          \"Secrecy Login\",\n          {\n            width: 500,\n            height: 750,\n            resizable: \"no\",\n            menubar: \"no\",\n            location: \"no\",\n            centered: true,\n            scrollbars: \"no\"\n          },\n          (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      }\n    } else {\n      return resolve(client as Value<T>);\n    }\n  });\n}\n"],"mappings":"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"}
|