@secrecy/lib 0.1.441 → 1.0.0-dev.12

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,153 @@
1
+ import _defineProperty from "@babel/runtime/helpers/defineProperty";
2
+ import _asyncToGenerator from "@babel/runtime/helpers/asyncToGenerator";
3
+ import _inheritsLoose from "@babel/runtime/helpers/inheritsLoose";
4
+ import _regeneratorRuntime from "@babel/runtime/regenerator";
5
+
6
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
7
+
8
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
9
+
10
+ import { storeBuddy } from "../../utils/store-buddy.js";
11
+ import { BaseClient } from "../../BaseClient.js";
12
+ /*
13
+ - query pour lister les users avec pagination et input optionnel "search" et boolean pour filtrer les bans
14
+ - mutation changer le plan d'un user (sans payer du coup)
15
+ - query pour renvoyer les apps d'un user
16
+ - query pour donner les limites d'un user
17
+ - query pour donner les reports d'un user
18
+ - mutation pour ban un user
19
+ - query pour get les bans d'un user
20
+ - mutation pour delete un user (déjà existant?)
21
+ - mutation changer le role du user (user/admin)
22
+ - mutation pour déco une ou des sessions meta ou app d'un user
23
+ - query afficher les sessions meta ou app d'un user
24
+ - query pour afficher des infos sur le cloud d'un user
25
+ - mutation pour delete, restore, delete trash, dans le cloud d'un user
26
+ - query pour afficher les infos sur les mails d'un user
27
+ - mutation pour delete, restore, delete trash, dans les mails d'un user
28
+ - query pour afficher les limites max et actuels d'un user
29
+ - query de stats?
30
+ */
31
+
32
+ var userSelector = {
33
+ id: true,
34
+ firstname: true,
35
+ lastname: true,
36
+ lang: true,
37
+ publicKey: true,
38
+ email: true,
39
+ phone: true,
40
+ role: true,
41
+ deletedAt: true,
42
+ lastLogin: true
43
+ };
44
+ export var AdminSecrecyClient = /*#__PURE__*/function (_BaseClient) {
45
+ _inheritsLoose(AdminSecrecyClient, _BaseClient);
46
+
47
+ function AdminSecrecyClient() {
48
+ return _BaseClient.apply(this, arguments) || this;
49
+ }
50
+
51
+ var _proto = AdminSecrecyClient.prototype;
52
+
53
+ _proto.userList = /*#__PURE__*/function () {
54
+ var _userList = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee(search) {
55
+ var _yield$this$client$qu, userList;
56
+
57
+ return _regeneratorRuntime.wrap(function _callee$(_context) {
58
+ while (1) {
59
+ switch (_context.prev = _context.next) {
60
+ case 0:
61
+ _context.next = 2;
62
+ return this.client.query({
63
+ userList: [{
64
+ search: search
65
+ }, userSelector]
66
+ });
67
+
68
+ case 2:
69
+ _yield$this$client$qu = _context.sent;
70
+ userList = _yield$this$client$qu.userList;
71
+ return _context.abrupt("return", userList.map(function (user) {
72
+ return _objectSpread(_objectSpread({}, user), {}, {
73
+ lastLogin: new Date(user.lastLogin),
74
+ deletedAt: user.deletedAt ? new Date(user.deletedAt) : null
75
+ });
76
+ }));
77
+
78
+ case 5:
79
+ case "end":
80
+ return _context.stop();
81
+ }
82
+ }
83
+ }, _callee, this);
84
+ }));
85
+
86
+ function userList(_x) {
87
+ return _userList.apply(this, arguments);
88
+ }
89
+
90
+ return userList;
91
+ }();
92
+
93
+ _proto.changeUserPlan = /*#__PURE__*/function () {
94
+ var _changeUserPlan = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee2(userId, plan) {
95
+ var _yield$this$client$mu, changeUserPlan;
96
+
97
+ return _regeneratorRuntime.wrap(function _callee2$(_context2) {
98
+ while (1) {
99
+ switch (_context2.prev = _context2.next) {
100
+ case 0:
101
+ _context2.next = 2;
102
+ return this.client.mutation({
103
+ changeUserPlan: [{
104
+ userId: userId,
105
+ plan: plan
106
+ }, userSelector]
107
+ });
108
+
109
+ case 2:
110
+ _yield$this$client$mu = _context2.sent;
111
+ changeUserPlan = _yield$this$client$mu.changeUserPlan;
112
+
113
+ if (changeUserPlan) {
114
+ _context2.next = 6;
115
+ break;
116
+ }
117
+
118
+ return _context2.abrupt("return", null);
119
+
120
+ case 6:
121
+ return _context2.abrupt("return", _objectSpread(_objectSpread({}, changeUserPlan), {}, {
122
+ lastLogin: new Date(changeUserPlan.lastLogin),
123
+ deletedAt: changeUserPlan.deletedAt ? new Date(changeUserPlan.deletedAt) : null
124
+ }));
125
+
126
+ case 7:
127
+ case "end":
128
+ return _context2.stop();
129
+ }
130
+ }
131
+ }, _callee2, this);
132
+ }));
133
+
134
+ function changeUserPlan(_x2, _x3) {
135
+ return _changeUserPlan.apply(this, arguments);
136
+ }
137
+
138
+ return changeUserPlan;
139
+ }();
140
+
141
+ return AdminSecrecyClient;
142
+ }(BaseClient);
143
+ export function getSecrecyAdminClient(env, session) {
144
+ var userSession = storeBuddy("secrecy.user_session", session).init("");
145
+ var uaSession = userSession.load();
146
+
147
+ if (uaSession === "") {
148
+ return null;
149
+ }
150
+
151
+ return new AdminSecrecyClient(uaSession, env);
152
+ }
153
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jbGllbnQvYWRtaW4vaW5kZXgudHMiXSwibmFtZXMiOlsic3RvcmVCdWRkeSIsIkJhc2VDbGllbnQiLCJ1c2VyU2VsZWN0b3IiLCJpZCIsImZpcnN0bmFtZSIsImxhc3RuYW1lIiwibGFuZyIsInB1YmxpY0tleSIsImVtYWlsIiwicGhvbmUiLCJyb2xlIiwiZGVsZXRlZEF0IiwibGFzdExvZ2luIiwiQWRtaW5TZWNyZWN5Q2xpZW50IiwidXNlckxpc3QiLCJzZWFyY2giLCJjbGllbnQiLCJxdWVyeSIsIm1hcCIsInVzZXIiLCJEYXRlIiwiY2hhbmdlVXNlclBsYW4iLCJ1c2VySWQiLCJwbGFuIiwibXV0YXRpb24iLCJnZXRTZWNyZWN5QWRtaW5DbGllbnQiLCJlbnYiLCJzZXNzaW9uIiwidXNlclNlc3Npb24iLCJpbml0IiwidWFTZXNzaW9uIiwibG9hZCJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7O0FBQ0EsU0FBU0EsVUFBVCxRQUEyQiw0QkFBM0I7QUFDQSxTQUFTQyxVQUFULFFBQTJCLHFCQUEzQjtBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUdBLElBQU1DLFlBQVksR0FBRztBQUNuQkMsRUFBQUEsRUFBRSxFQUFFLElBRGU7QUFFbkJDLEVBQUFBLFNBQVMsRUFBRSxJQUZRO0FBR25CQyxFQUFBQSxRQUFRLEVBQUUsSUFIUztBQUluQkMsRUFBQUEsSUFBSSxFQUFFLElBSmE7QUFLbkJDLEVBQUFBLFNBQVMsRUFBRSxJQUxRO0FBTW5CQyxFQUFBQSxLQUFLLEVBQUUsSUFOWTtBQU9uQkMsRUFBQUEsS0FBSyxFQUFFLElBUFk7QUFRbkJDLEVBQUFBLElBQUksRUFBRSxJQVJhO0FBU25CQyxFQUFBQSxTQUFTLEVBQUUsSUFUUTtBQVVuQkMsRUFBQUEsU0FBUyxFQUFFO0FBVlEsQ0FBckI7QUFhQSxXQUFhQyxrQkFBYjtBQUFBOztBQUFBO0FBQUE7QUFBQTs7QUFBQTs7QUFBQSxTQUNRQyxRQURSO0FBQUEsNkVBQ0UsaUJBQ0VDLE1BREY7QUFBQTs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUEscUJBRzZCLEtBQUtDLE1BQUwsQ0FBWUMsS0FBWixDQUFrQjtBQUMzQ0gsZ0JBQUFBLFFBQVEsRUFBRSxDQUNSO0FBQ0VDLGtCQUFBQSxNQUFNLEVBQU5BO0FBREYsaUJBRFEsRUFJUmIsWUFKUTtBQURpQyxlQUFsQixDQUg3Qjs7QUFBQTtBQUFBO0FBR1VZLGNBQUFBLFFBSFYseUJBR1VBLFFBSFY7QUFBQSwrQ0FZU0EsUUFBUSxDQUFDSSxHQUFULENBQWEsVUFBQUMsSUFBSTtBQUFBLHVEQUNuQkEsSUFEbUI7QUFFdEJQLGtCQUFBQSxTQUFTLEVBQUUsSUFBSVEsSUFBSixDQUFTRCxJQUFJLENBQUNQLFNBQWQsQ0FGVztBQUd0QkQsa0JBQUFBLFNBQVMsRUFBRVEsSUFBSSxDQUFDUixTQUFMLEdBQWlCLElBQUlTLElBQUosQ0FBU0QsSUFBSSxDQUFDUixTQUFkLENBQWpCLEdBQTRDO0FBSGpDO0FBQUEsZUFBakIsQ0FaVDs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQSxLQURGOztBQUFBO0FBQUE7QUFBQTs7QUFBQTtBQUFBOztBQUFBLFNBb0JRVSxjQXBCUjtBQUFBLG1GQW9CRSxrQkFDRUMsTUFERixFQUVFQyxJQUZGO0FBQUE7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBLHFCQUltQyxLQUFLUCxNQUFMLENBQVlRLFFBQVosQ0FBcUI7QUFDcERILGdCQUFBQSxjQUFjLEVBQUUsQ0FDZDtBQUNFQyxrQkFBQUEsTUFBTSxFQUFOQSxNQURGO0FBRUVDLGtCQUFBQSxJQUFJLEVBQUpBO0FBRkYsaUJBRGMsRUFLZHJCLFlBTGM7QUFEb0MsZUFBckIsQ0FKbkM7O0FBQUE7QUFBQTtBQUlVbUIsY0FBQUEsY0FKVix5QkFJVUEsY0FKVjs7QUFBQSxrQkFjT0EsY0FkUDtBQUFBO0FBQUE7QUFBQTs7QUFBQSxnREFlVyxJQWZYOztBQUFBO0FBQUEsZ0ZBbUJPQSxjQW5CUDtBQW9CSVQsZ0JBQUFBLFNBQVMsRUFBRSxJQUFJUSxJQUFKLENBQVNDLGNBQWMsQ0FBQ1QsU0FBeEIsQ0FwQmY7QUFxQklELGdCQUFBQSxTQUFTLEVBQUVVLGNBQWMsQ0FBQ1YsU0FBZixHQUNQLElBQUlTLElBQUosQ0FBU0MsY0FBYyxDQUFDVixTQUF4QixDQURPLEdBRVA7QUF2QlI7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUEsS0FwQkY7O0FBQUE7QUFBQTtBQUFBOztBQUFBO0FBQUE7O0FBQUE7QUFBQSxFQUF3Q1YsVUFBeEM7QUFnREEsT0FBTyxTQUFTd0IscUJBQVQsQ0FDTEMsR0FESyxFQUVMQyxPQUZLLEVBR3NCO0FBQzNCLE1BQU1DLFdBQVcsR0FBRzVCLFVBQVUseUJBQWlDMkIsT0FBakMsQ0FBVixDQUFvREUsSUFBcEQsQ0FDbEIsRUFEa0IsQ0FBcEI7QUFHQSxNQUFNQyxTQUFTLEdBQUdGLFdBQVcsQ0FBQ0csSUFBWixFQUFsQjs7QUFDQSxNQUFJRCxTQUFTLEtBQUssRUFBbEIsRUFBc0I7QUFDcEIsV0FBTyxJQUFQO0FBQ0Q7O0FBRUQsU0FBTyxJQUFJakIsa0JBQUosQ0FBdUJpQixTQUF2QixFQUFrQ0osR0FBbEMsQ0FBUDtBQUNEIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBQbGFuS2luZCwgU2VjcmVjeUVudiwgVXNlciB9IGZyb20gXCIuLi8uLi9pbmRleC5qc1wiO1xuaW1wb3J0IHsgc3RvcmVCdWRkeSB9IGZyb20gXCIuLi8uLi91dGlscy9zdG9yZS1idWRkeS5qc1wiO1xuaW1wb3J0IHsgQmFzZUNsaWVudCB9IGZyb20gXCIuLi8uLi9CYXNlQ2xpZW50LmpzXCI7XG5cbi8qXG4tIHF1ZXJ5IHBvdXIgbGlzdGVyIGxlcyB1c2VycyBhdmVjIHBhZ2luYXRpb24gZXQgaW5wdXQgb3B0aW9ubmVsIFwic2VhcmNoXCIgZXQgYm9vbGVhbiBwb3VyIGZpbHRyZXIgbGVzIGJhbnNcbi0gbXV0YXRpb24gY2hhbmdlciBsZSBwbGFuIGQndW4gdXNlciAoc2FucyBwYXllciBkdSBjb3VwKVxuLSBxdWVyeSBwb3VyIHJlbnZveWVyIGxlcyBhcHBzIGQndW4gdXNlclxuLSBxdWVyeSBwb3VyIGRvbm5lciBsZXMgbGltaXRlcyBkJ3VuIHVzZXJcbi0gcXVlcnkgcG91ciBkb25uZXIgbGVzIHJlcG9ydHMgZCd1biB1c2VyXG4tIG11dGF0aW9uIHBvdXIgYmFuIHVuIHVzZXJcbi0gcXVlcnkgcG91ciBnZXQgbGVzIGJhbnMgZCd1biB1c2VyXG4tIG11dGF0aW9uIHBvdXIgZGVsZXRlIHVuIHVzZXIgKGTDqWrDoCBleGlzdGFudD8pXG4tIG11dGF0aW9uIGNoYW5nZXIgbGUgcm9sZSBkdSB1c2VyICh1c2VyL2FkbWluKVxuLSBtdXRhdGlvbiBwb3VyIGTDqWNvIHVuZSBvdSBkZXMgc2Vzc2lvbnMgbWV0YSBvdSBhcHAgZCd1biB1c2VyXG4tIHF1ZXJ5IGFmZmljaGVyIGxlcyBzZXNzaW9ucyBtZXRhIG91IGFwcCBkJ3VuIHVzZXJcbi0gcXVlcnkgcG91ciBhZmZpY2hlciBkZXMgaW5mb3Mgc3VyIGxlIGNsb3VkIGQndW4gdXNlclxuLSBtdXRhdGlvbiBwb3VyIGRlbGV0ZSwgcmVzdG9yZSwgZGVsZXRlIHRyYXNoLCBkYW5zIGxlIGNsb3VkIGQndW4gdXNlclxuLSBxdWVyeSBwb3VyIGFmZmljaGVyIGxlcyBpbmZvcyBzdXIgbGVzIG1haWxzIGQndW4gdXNlclxuLSBtdXRhdGlvbiBwb3VyIGRlbGV0ZSwgcmVzdG9yZSwgZGVsZXRlIHRyYXNoLCBkYW5zIGxlcyBtYWlscyBkJ3VuIHVzZXJcbi0gcXVlcnkgcG91ciBhZmZpY2hlciBsZXMgbGltaXRlcyBtYXggZXQgYWN0dWVscyBkJ3VuIHVzZXJcbi0gcXVlcnkgZGUgc3RhdHM/XG4qL1xuXG5leHBvcnQgdHlwZSBVc2VyQWRtaW5QYW5lbCA9IFVzZXI8eyB3aXRoUHVibGljS2V5OiB0cnVlIH0+O1xuY29uc3QgdXNlclNlbGVjdG9yID0ge1xuICBpZDogdHJ1ZSxcbiAgZmlyc3RuYW1lOiB0cnVlLFxuICBsYXN0bmFtZTogdHJ1ZSxcbiAgbGFuZzogdHJ1ZSxcbiAgcHVibGljS2V5OiB0cnVlLFxuICBlbWFpbDogdHJ1ZSxcbiAgcGhvbmU6IHRydWUsXG4gIHJvbGU6IHRydWUsXG4gIGRlbGV0ZWRBdDogdHJ1ZSxcbiAgbGFzdExvZ2luOiB0cnVlXG59IGFzIGNvbnN0O1xuXG5leHBvcnQgY2xhc3MgQWRtaW5TZWNyZWN5Q2xpZW50IGV4dGVuZHMgQmFzZUNsaWVudCB7XG4gIGFzeW5jIHVzZXJMaXN0KFxuICAgIHNlYXJjaD86IHN0cmluZyB8IG51bGwgfCB1bmRlZmluZWRcbiAgKTogUHJvbWlzZTxVc2VyQWRtaW5QYW5lbFtdPiB7XG4gICAgY29uc3QgeyB1c2VyTGlzdCB9ID0gYXdhaXQgdGhpcy5jbGllbnQucXVlcnkoe1xuICAgICAgdXNlckxpc3Q6IFtcbiAgICAgICAge1xuICAgICAgICAgIHNlYXJjaFxuICAgICAgICB9LFxuICAgICAgICB1c2VyU2VsZWN0b3JcbiAgICAgIF1cbiAgICB9KTtcblxuICAgIHJldHVybiB1c2VyTGlzdC5tYXAodXNlciA9PiAoe1xuICAgICAgLi4udXNlcixcbiAgICAgIGxhc3RMb2dpbjogbmV3IERhdGUodXNlci5sYXN0TG9naW4pLFxuICAgICAgZGVsZXRlZEF0OiB1c2VyLmRlbGV0ZWRBdCA/IG5ldyBEYXRlKHVzZXIuZGVsZXRlZEF0KSA6IG51bGxcbiAgICB9KSk7XG4gIH1cblxuICBhc3luYyBjaGFuZ2VVc2VyUGxhbihcbiAgICB1c2VySWQ6IHN0cmluZyxcbiAgICBwbGFuOiBQbGFuS2luZFxuICApOiBQcm9taXNlPFVzZXJBZG1pblBhbmVsIHwgbnVsbD4ge1xuICAgIGNvbnN0IHsgY2hhbmdlVXNlclBsYW4gfSA9IGF3YWl0IHRoaXMuY2xpZW50Lm11dGF0aW9uKHtcbiAgICAgIGNoYW5nZVVzZXJQbGFuOiBbXG4gICAgICAgIHtcbiAgICAgICAgICB1c2VySWQsXG4gICAgICAgICAgcGxhblxuICAgICAgICB9LFxuICAgICAgICB1c2VyU2VsZWN0b3JcbiAgICAgIF1cbiAgICB9KTtcblxuICAgIGlmICghY2hhbmdlVXNlclBsYW4pIHtcbiAgICAgIHJldHVybiBudWxsO1xuICAgIH1cblxuICAgIHJldHVybiB7XG4gICAgICAuLi5jaGFuZ2VVc2VyUGxhbixcbiAgICAgIGxhc3RMb2dpbjogbmV3IERhdGUoY2hhbmdlVXNlclBsYW4ubGFzdExvZ2luKSxcbiAgICAgIGRlbGV0ZWRBdDogY2hhbmdlVXNlclBsYW4uZGVsZXRlZEF0XG4gICAgICAgID8gbmV3IERhdGUoY2hhbmdlVXNlclBsYW4uZGVsZXRlZEF0KVxuICAgICAgICA6IG51bGxcbiAgICB9O1xuICB9XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRTZWNyZWN5QWRtaW5DbGllbnQoXG4gIGVudjogU2VjcmVjeUVudixcbiAgc2Vzc2lvbj86IGJvb2xlYW4gfCB1bmRlZmluZWRcbik6IEFkbWluU2VjcmVjeUNsaWVudCB8IG51bGwge1xuICBjb25zdCB1c2VyU2Vzc2lvbiA9IHN0b3JlQnVkZHk8c3RyaW5nPihgc2VjcmVjeS51c2VyX3Nlc3Npb25gLCBzZXNzaW9uKS5pbml0KFxuICAgIFwiXCJcbiAgKTtcbiAgY29uc3QgdWFTZXNzaW9uID0gdXNlclNlc3Npb24ubG9hZCgpO1xuICBpZiAodWFTZXNzaW9uID09PSBcIlwiKSB7XG4gICAgcmV0dXJuIG51bGw7XG4gIH1cblxuICByZXR1cm4gbmV3IEFkbWluU2VjcmVjeUNsaWVudCh1YVNlc3Npb24sIGVudik7XG59XG4iXX0=
@@ -1,8 +1,7 @@
1
1
  import type { KeyPair } from "../../crypto/index.js";
2
2
  import type { GQLFolder, InternalFolder, Folder, GQLFolderFull, InternalFolderFull, FolderFull } from "../types/index.js";
3
3
  export declare function gqlFolderToInternal(gql: GQLFolder, keyPair: KeyPair): Promise<InternalFolder>;
4
- export declare function gqlFolderFullToInternal(gql: GQLFolderFull, keyPair: KeyPair): Promise<InternalFolderFull>;
5
- export declare function gqlFolderFullToInternalFolderFull(gql: GQLFolderFull, keyPair: KeyPair): Promise<InternalFolderFull>;
4
+ export declare function gqlFolderFullToInternalFull(gql: GQLFolderFull, keyPair: KeyPair): Promise<InternalFolderFull>;
6
5
  export declare function internalFolderToFolder(internal: InternalFolder): Folder;
7
6
  export declare function internalFolderFullToFolderFull(internal: InternalFolderFull): FolderFull;
8
7
  export declare function gqlFolderToExternalFolderFull(gql: GQLFolderFull, keyPair: KeyPair): Promise<FolderFull>;
@@ -115,12 +115,12 @@ function _gqlFolderToInternal() {
115
115
  return _gqlFolderToInternal.apply(this, arguments);
116
116
  }
117
117
 
118
- export function gqlFolderFullToInternal(_x3, _x4) {
119
- return _gqlFolderFullToInternal.apply(this, arguments);
118
+ export function gqlFolderFullToInternalFull(_x3, _x4) {
119
+ return _gqlFolderFullToInternalFull.apply(this, arguments);
120
120
  }
121
121
 
122
- function _gqlFolderFullToInternal() {
123
- _gqlFolderFullToInternal = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee2(gql, keyPair) {
122
+ function _gqlFolderFullToInternalFull() {
123
+ _gqlFolderFullToInternalFull = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee2(gql, keyPair) {
124
124
  var f;
125
125
  return _regeneratorRuntime.wrap(function _callee2$(_context2) {
126
126
  while (1) {
@@ -183,64 +183,7 @@ function _gqlFolderFullToInternal() {
183
183
  }
184
184
  }, _callee2);
185
185
  }));
186
- return _gqlFolderFullToInternal.apply(this, arguments);
187
- }
188
-
189
- export function gqlFolderFullToInternalFolderFull(_x5, _x6) {
190
- return _gqlFolderFullToInternalFolderFull.apply(this, arguments);
191
- }
192
-
193
- function _gqlFolderFullToInternalFolderFull() {
194
- _gqlFolderFullToInternalFolderFull = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee3(gql, keyPair) {
195
- var f, subfolders, parentFolder;
196
- return _regeneratorRuntime.wrap(function _callee3$(_context3) {
197
- while (1) {
198
- switch (_context3.prev = _context3.next) {
199
- case 0:
200
- _context3.next = 2;
201
- return gqlFolderFullToInternal(gql, keyPair);
202
-
203
- case 2:
204
- f = _context3.sent;
205
- _context3.next = 5;
206
- return Promise.all(gql.subfolders.map(function (f) {
207
- return gqlFolderToInternal(f, keyPair);
208
- }));
209
-
210
- case 5:
211
- subfolders = _context3.sent;
212
-
213
- if (!gql.parentFolder) {
214
- _context3.next = 12;
215
- break;
216
- }
217
-
218
- _context3.next = 9;
219
- return gqlFolderToInternal(gql.parentFolder, keyPair);
220
-
221
- case 9:
222
- _context3.t0 = _context3.sent;
223
- _context3.next = 13;
224
- break;
225
-
226
- case 12:
227
- _context3.t0 = null;
228
-
229
- case 13:
230
- parentFolder = _context3.t0;
231
- return _context3.abrupt("return", _objectSpread(_objectSpread({}, f), {}, {
232
- parentFolder: parentFolder,
233
- subfolders: subfolders
234
- }));
235
-
236
- case 15:
237
- case "end":
238
- return _context3.stop();
239
- }
240
- }
241
- }, _callee3);
242
- }));
243
- return _gqlFolderFullToInternalFolderFull.apply(this, arguments);
186
+ return _gqlFolderFullToInternalFull.apply(this, arguments);
244
187
  }
245
188
 
246
189
  export function internalFolderToFolder(internal) {
@@ -263,59 +206,59 @@ export function internalFolderFullToFolderFull(internal) {
263
206
  subfolders: internal.subfolders.map(internalFolderToFolder)
264
207
  });
265
208
  }
266
- export function gqlFolderToExternalFolderFull(_x7, _x8) {
209
+ export function gqlFolderToExternalFolderFull(_x5, _x6) {
267
210
  return _gqlFolderToExternalFolderFull.apply(this, arguments);
268
211
  }
269
212
 
270
213
  function _gqlFolderToExternalFolderFull() {
271
- _gqlFolderToExternalFolderFull = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee4(gql, keyPair) {
272
- return _regeneratorRuntime.wrap(function _callee4$(_context4) {
214
+ _gqlFolderToExternalFolderFull = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee3(gql, keyPair) {
215
+ return _regeneratorRuntime.wrap(function _callee3$(_context3) {
273
216
  while (1) {
274
- switch (_context4.prev = _context4.next) {
217
+ switch (_context3.prev = _context3.next) {
275
218
  case 0:
276
- _context4.t0 = internalFolderFullToFolderFull;
277
- _context4.next = 3;
278
- return gqlFolderFullToInternalFolderFull(gql, keyPair);
219
+ _context3.t0 = internalFolderFullToFolderFull;
220
+ _context3.next = 3;
221
+ return gqlFolderFullToInternalFull(gql, keyPair);
279
222
 
280
223
  case 3:
281
- _context4.t1 = _context4.sent;
282
- return _context4.abrupt("return", (0, _context4.t0)(_context4.t1));
224
+ _context3.t1 = _context3.sent;
225
+ return _context3.abrupt("return", (0, _context3.t0)(_context3.t1));
283
226
 
284
227
  case 5:
285
228
  case "end":
286
- return _context4.stop();
229
+ return _context3.stop();
287
230
  }
288
231
  }
289
- }, _callee4);
232
+ }, _callee3);
290
233
  }));
291
234
  return _gqlFolderToExternalFolderFull.apply(this, arguments);
292
235
  }
293
236
 
294
- export function gqlFolderToExternal(_x9, _x10) {
237
+ export function gqlFolderToExternal(_x7, _x8) {
295
238
  return _gqlFolderToExternal.apply(this, arguments);
296
239
  }
297
240
 
298
241
  function _gqlFolderToExternal() {
299
- _gqlFolderToExternal = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee5(gql, keyPair) {
300
- return _regeneratorRuntime.wrap(function _callee5$(_context5) {
242
+ _gqlFolderToExternal = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee4(gql, keyPair) {
243
+ return _regeneratorRuntime.wrap(function _callee4$(_context4) {
301
244
  while (1) {
302
- switch (_context5.prev = _context5.next) {
245
+ switch (_context4.prev = _context4.next) {
303
246
  case 0:
304
- _context5.t0 = internalFolderToFolder;
305
- _context5.next = 3;
247
+ _context4.t0 = internalFolderToFolder;
248
+ _context4.next = 3;
306
249
  return gqlFolderToInternal(gql, keyPair);
307
250
 
308
251
  case 3:
309
- _context5.t1 = _context5.sent;
310
- return _context5.abrupt("return", (0, _context5.t0)(_context5.t1));
252
+ _context4.t1 = _context4.sent;
253
+ return _context4.abrupt("return", (0, _context4.t0)(_context4.t1));
311
254
 
312
255
  case 5:
313
256
  case "end":
314
- return _context5.stop();
257
+ return _context4.stop();
315
258
  }
316
259
  }
317
- }, _callee5);
260
+ }, _callee4);
318
261
  }));
319
262
  return _gqlFolderToExternal.apply(this, arguments);
320
263
  }
321
- //# 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","gqlFolderFullToInternal","f","Promise","all","vFiles","filter","vFile","parentFolder","subfolders","s","gqlFolderFullToInternalFolderFull","internalFolderToFolder","folder","internalFolderFullToFolderFull","gqlFolderToExternalFolderFull","gqlFolderToExternal"],"mappings":";;;;;;;;;;;;;;AAAA,SAASA,MAAT,QAAuB,iBAAvB;AAEA,SAASC,gBAAT,QAAiC,uBAAjC;AASA,SAASC,kBAAT,EAA6BC,oBAA7B,QAAyD,YAAzD;AACA,SAASC,YAAT,QAA6B,gBAA7B;AACA,SAASC,mBAAT,QAAoC,sBAApC;AAEA,gBAAsBC,mBAAtB;AAAA;AAAA;;;kFAAO,iBACLC,GADK,EAELC,OAFK;AAAA;;AAAA;AAAA;AAAA;AAAA;AAAA,gBAIAD,GAAG,CAACE,OAJJ;AAAA;AAAA;AAAA;;AAAA,2CAK0BF,GAAG,CAACG,EAL9B;;AAAA;AAOCC,YAAAA,QAPD,GAO4B;AAC/BD,cAAAA,EAAE,EAAEH,GAAG,CAACG,EADuB;AAE/BD,cAAAA,OAAO,EAAEF,GAAG,CAACE,OAFkB;AAG/BG,cAAAA,IAAI,EAAEL,GAAG,CAACK,IAHqB;AAI/BC,cAAAA,UAAU,EAAEN,GAAG,CAACM,UAJe;AAK/BC,cAAAA,UAAU,EAAEP,GAAG,CAACO,UALe;AAM/BC,cAAAA,SAAS,EAAER,GAAG,CAACQ,SAAJ,CAAcC,IANM;AAO/BC,cAAAA,SAAS,EAAE,IAAIC,IAAJ,CAASX,GAAG,CAACU,SAAb,CAPoB;AAQ/BE,cAAAA,SAAS,EAAE,IAAID,IAAJ,CAASX,GAAG,CAACY,SAAb,CARoB;AAS/BC,cAAAA,SAAS,EAAEb,GAAG,CAACa,SAAJ,GAAgB,IAAIF,IAAJ,CAASX,GAAG,CAACa,SAAb,CAAhB,GAA0C,IATtB;AAU/BC,cAAAA,KAAK,EAAEd,GAAG,CAACe,QAAJ,CAAaC,GAAb,CAAiB,UAAAC,CAAC;AAAA,uBAAI,CAACA,CAAC,CAACf,OAAF,CAAUO,IAAX,EAAiBQ,CAAC,CAACC,MAAnB,CAAJ;AAAA,eAAlB;AAVwB,aAP5B;AAoBLd,YAAAA,QAAQ,CAACF,OAAT,qBAAwBF,GAAG,CAACE,OAA5B;;AApBK,iBAsBDF,GAAG,CAACE,OAAJ,CAAYiB,OAtBX;AAAA;AAAA;AAAA;;AAuBGC,YAAAA,GAvBH,GAuBS1B,gBAAgB,CAC1BD,MAAM,CAAC4B,QAAP,CAAgBrB,GAAG,CAACE,OAAJ,CAAYiB,OAA5B,CAD0B,EAE1BnB,GAAG,CAACQ,SAAJ,CAAcC,IAAd,CAAmBa,SAFO,EAG1BrB,OAAO,CAACsB,UAHkB,CAvBzB;AAAA,0BA4Ba9B,MA5Bb;AAAA;AAAA,mBA6BKK,mBAAmB,CAACsB,GAAD,EAAM3B,MAAM,CAAC4B,QAAP,CAAgBjB,QAAQ,CAACC,IAAzB,CAAN,CA7BxB;;AAAA;AAAA;AA4BHD,YAAAA,QAAQ,CAACC,IA5BN,eA4BoBmB,SA5BpB;AAgCHpB,YAAAA,QAAQ,CAACF,OAAT,CAAiBiB,OAAjB,GAA2B1B,MAAM,CAACgC,MAAP,CAAcL,GAAd,CAA3B;;AAhCG;AAAA,yDAmCWhB,QAAQ,CAACG,UAnCpB;;AAAA;AAAA;AAAA;AAAA;AAAA;;AAmCMmB,YAAAA,CAnCN;;AAAA,gBAoCEA,CAAC,CAACP,OApCJ;AAAA;AAAA;AAAA;;AAAA;;AAAA;AAwCGC,YAAAA,IAxCH,GAwCS1B,gBAAgB,CAC1BD,MAAM,CAAC4B,QAAP,CAAgBK,CAAC,CAACP,OAAlB,CAD0B,EAE1BO,CAAC,CAACC,MAFwB,EAG1B1B,OAAO,CAACsB,UAHkB,CAxCzB;AA6CHG,YAAAA,CAAC,CAACP,OAAF,GAAY1B,MAAM,CAACgC,MAAP,CAAcL,IAAd,CAAZ;AA7CG,0BA+CM3B,MA/CN;AAAA;AAAA,mBAgDKK,mBAAmB,CAACsB,IAAD,EAAM3B,MAAM,CAAC4B,QAAP,CAAgBK,CAAC,CAACrB,IAAlB,CAAN,CAhDxB;;AAAA;AAAA;AA+CHqB,YAAAA,CAAC,CAACrB,IA/CC,eA+CamB,SA/Cb;;AAAA;AAAA;AAAA;;AAAA;AAoDL3B,YAAAA,YAAY,CAAC+B,GAAb,CAAiBxB,QAAQ,CAACD,EAA1B,EAA8BC,QAA9B;AApDK,6CAqDEA,QArDF;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,G;;;;AAwDP,gBAAsByB,uBAAtB;AAAA;AAAA;;;sFAAO,kBACL7B,GADK,EAELC,OAFK;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,mBAIWF,mBAAmB,CAACC,GAAD,EAAMC,OAAN,CAJ9B;;AAAA;AAIC6B,YAAAA,CAJD;AAAA;AAAA,6CAMAA,CANA;AAAA;AAAA;AAAA,mBAOWC,OAAO,CAACC,GAAR,CACZhC,GAAG,CAACiC,MAAJ,CACGC,MADH,CACU,UAAAJ,CAAC;AAAA,qBAAIA,CAAC,CAAC5B,OAAN;AAAA,aADX,EAEGc,GAFH,CAEO,UAAAmB,KAAK;AAAA,qBAAIxC,kBAAkB,CAACwC,KAAD,EAAQlC,OAAR,CAAtB;AAAA,aAFZ,CADY,CAPX;;AAAA;AAAA;;AAAA,iBAYWD,GAAG,CAACoC,YAZf;AAAA;AAAA;AAAA;;AAAA;AAAA,mBAaOrC,mBAAmB,CAACC,GAAG,CAACoC,YAAL,EAAmBnC,OAAnB,CAb1B;;AAAA;AAAA;AAAA;AAAA;;AAAA;AAAA,2BAcC,IAdD;;AAAA;AAAA;AAAA;AAAA,mBAee8B,OAAO,CAACC,GAAR,CAChBhC,GAAG,CAACqC,UAAJ,CAAerB,GAAf,CAAmB,UAAAsB,CAAC;AAAA,qBAAIvC,mBAAmB,CAACuC,CAAD,EAAIrC,OAAJ,CAAvB;AAAA,aAApB,CADgB,CAff;;AAAA;AAAA;AAAA;AAOHgC,cAAAA,MAPG;AAYHG,cAAAA,YAZG;AAeHC,cAAAA,UAfG;AAAA;AAAA;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,G;;;;AAqBP,gBAAsBE,iCAAtB;AAAA;AAAA;;;gGAAO,kBACLvC,GADK,EAELC,OAFK;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,mBAIW4B,uBAAuB,CAAC7B,GAAD,EAAMC,OAAN,CAJlC;;AAAA;AAIC6B,YAAAA,CAJD;AAAA;AAAA,mBAKoBC,OAAO,CAACC,GAAR,CACvBhC,GAAG,CAACqC,UAAJ,CAAerB,GAAf,CAAmB,UAAAc,CAAC;AAAA,qBAAI/B,mBAAmB,CAAC+B,CAAD,EAAI7B,OAAJ,CAAvB;AAAA,aAApB,CADuB,CALpB;;AAAA;AAKCoC,YAAAA,UALD;;AAAA,iBAQgBrC,GAAG,CAACoC,YARpB;AAAA;AAAA;AAAA;;AAAA;AAAA,mBASKrC,mBAAmB,CAACC,GAAG,CAACoC,YAAL,EAAmBnC,OAAnB,CATxB;;AAAA;AAAA;AAAA;AAAA;;AAAA;AAAA,2BAUD,IAVC;;AAAA;AAQCmC,YAAAA,YARD;AAAA,8EAaAN,CAbA;AAcHM,cAAAA,YAAY,EAAZA,YAdG;AAeHC,cAAAA,UAAU,EAAVA;AAfG;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,G;;;;AAmBP,OAAO,SAASG,sBAAT,CAAgCpC,QAAhC,EAAkE;AACvE,MAAMqC,MAAc,qBACfrC,QADe,CAApB;;AAIA,uDAAgBqC,MAAM,CAAClC,UAAvB,wCAAmC;AAAA,QAAxBmB,CAAwB;AACjC;AACA,WAAOA,CAAC,CAACP,OAAT;AACD,GARsE,CASvE;;;AACA,SAAOsB,MAAM,CAACtB,OAAd;AACA,SAAOsB,MAAP;AACD;AAED,OAAO,SAASC,8BAAT,CACLtC,QADK,EAEO;AACZ,yCACKoC,sBAAsB,CAACpC,QAAD,CAD3B;AAEE6B,IAAAA,MAAM,EAAE7B,QAAQ,CAAC6B,MAAT,CAAgBjB,GAAhB,CAAoBpB,oBAApB,CAFV;AAGEwC,IAAAA,YAAY,EAAEhC,QAAQ,CAACgC,YAAT,GACVI,sBAAsB,CAACpC,QAAQ,CAACgC,YAAV,CADZ,GAEV,IALN;AAMEC,IAAAA,UAAU,EAAEjC,QAAQ,CAACiC,UAAT,CAAoBrB,GAApB,CAAwBwB,sBAAxB;AANd;AAQD;AAED,gBAAsBG,6BAAtB;AAAA;AAAA;;;4FAAO,kBACL3C,GADK,EAELC,OAFK;AAAA;AAAA;AAAA;AAAA;AAAA,2BAIEyC,8BAJF;AAAA;AAAA,mBAKGH,iCAAiC,CAACvC,GAAD,EAAMC,OAAN,CALpC;;AAAA;AAAA;AAAA;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,G;;;;AASP,gBAAsB2C,mBAAtB;AAAA;AAAA;;;kFAAO,kBACL5C,GADK,EAELC,OAFK;AAAA;AAAA;AAAA;AAAA;AAAA,2BAIEuC,sBAJF;AAAA;AAAA,mBAI+BzC,mBAAmB,CAACC,GAAD,EAAMC,OAAN,CAJlD;;AAAA;AAAA;AAAA;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,G","sourcesContent":["import { sodium } from \"../../sodium.js\";\nimport type { KeyPair } from \"../../crypto/index.js\";\nimport { decryptCryptoBox } from \"../../crypto/index.js\";\nimport type {\n  GQLFolder,\n  InternalFolder,\n  Folder,\n  GQLFolderFull,\n  InternalFolderFull,\n  FolderFull\n} from \"../types/index.js\";\nimport { gqlVFileToInternal, internalVFileToVFile } from \"./vFile.js\";\nimport { foldersCache } from \"../../cache.js\";\nimport { decryptSecretstream } from \"../../crypto/file.js\";\n\nexport async function gqlFolderToInternal(\n  gql: GQLFolder,\n  keyPair: KeyPair\n): Promise<InternalFolder> {\n  if (!gql.userApp) {\n    throw `Can't access folder ${gql.id}`;\n  }\n  const internal: InternalFolder = {\n    id: gql.id,\n    userApp: gql.userApp,\n    name: gql.name,\n    isFavorite: gql.isFavorite,\n    breadcrumb: gql.breadcrumb,\n    createdBy: gql.createdBy.user,\n    createdAt: new Date(gql.createdAt),\n    updatedAt: new Date(gql.updatedAt),\n    deletedAt: gql.deletedAt ? new Date(gql.deletedAt) : null,\n    users: gql.userApps.map(u => [u.userApp.user, u.rights])\n  };\n\n  internal.userApp = { ...gql.userApp };\n\n  if (gql.userApp.nameKey) {\n    const key = decryptCryptoBox(\n      sodium.from_hex(gql.userApp.nameKey),\n      gql.createdBy.user.publicKey,\n      keyPair.privateKey\n    );\n    internal.name = sodium.to_string(\n      await decryptSecretstream(key, sodium.from_hex(internal.name))\n    );\n\n    internal.userApp.nameKey = sodium.to_hex(key);\n  }\n\n  for (const b of internal.breadcrumb) {\n    if (!b.nameKey) {\n      continue;\n    }\n\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 gqlFolderFullToInternal(\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 async function gqlFolderFullToInternalFolderFull(\n  gql: GQLFolderFull,\n  keyPair: KeyPair\n): Promise<InternalFolderFull> {\n  const f = await gqlFolderFullToInternal(gql, keyPair);\n  const subfolders = await Promise.all(\n    gql.subfolders.map(f => gqlFolderToInternal(f, keyPair))\n  );\n  const parentFolder = gql.parentFolder\n    ? await gqlFolderToInternal(gql.parentFolder, keyPair)\n    : null;\n\n  return {\n    ...f,\n    parentFolder,\n    subfolders\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 gqlFolderFullToInternalFolderFull(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"]}
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"]}
@@ -76,7 +76,7 @@ export function login(_temp) {
76
76
  }
77
77
 
78
78
  var lang = document.documentElement.lang;
79
- var url = "https://" + envStr + "auth.secrecy.me" + (lang ? "/" + lang : "") + "/login#" + data;
79
+ var url = "https://auth." + envStr + "secrecy.me" + (lang ? "/" + lang : "") + "/login#" + data;
80
80
 
81
81
  var validate = function validate(infos) {
82
82
  var storage = getStorage(session);
@@ -113,4 +113,4 @@ export function login(_temp) {
113
113
  }
114
114
  });
115
115
  }
116
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/client/helpers.ts"],"names":["SecrecyClient","popup","getStorage","parseInfos","window","location","hash","substr","res","JSON","parse","atob","getSecrecyClient","env","session","storage","uaSession","userAppSession","load","uaKeys","userAppKeys","uaJwt","jwt","infos","save","keys","login","appCode","path","redirect","scopes","backPath","Promise","resolve","reject","appUrl","origin","includes","client","data","btoa","stringify","replaceAll","envStr","lang","document","documentElement","url","validate","href","err"],"mappings":"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","sourcesContent":["import { SecrecyClient } from \"./index.js\";\nimport { popup } from \"../PopupTools.js\";\nimport type { SecrecyUserApp } from \"./types/index.js\";\nimport { getStorage } from \"./storage.js\";\n\nexport function parseInfos(): SecrecyUserApp | null {\n  if (!window.location.hash) {\n    return null;\n  }\n  const hash = window.location.hash.substr(1);\n  try {\n    const res = JSON.parse(atob(hash));\n    window.location.hash = \"\";\n    // TODO Add object content validation\n    return res;\n  } catch {\n    return null;\n  }\n}\n\nexport type HashInfos = {\n  appUrl: string;\n  backPath?: string;\n  appCode?: string | null | undefined;\n  path?: string | null | undefined;\n  redirect?: boolean;\n  scopes?: {\n    email: boolean;\n  };\n};\nexport type SecrecyEnv = \"dev\" | \"staging\" | \"prod\";\nexport type UseSecrecyParams = Omit<HashInfos, \"appUrl\"> & {\n  env: SecrecyEnv;\n  session?: boolean | undefined;\n};\n\nexport type Value<T extends UseSecrecyParams> = T extends { redirect: true }\n  ? SecrecyClient | null\n  : SecrecyClient;\n\nexport function getSecrecyClient(\n  env: SecrecyEnv,\n  session?: boolean | undefined\n): SecrecyClient | null {\n  const storage = getStorage(session);\n  const uaSession = storage.userAppSession.load();\n  const uaKeys = storage.userAppKeys.load();\n  const uaJwt = storage.jwt.load();\n  if (!uaSession || !uaKeys || !uaJwt) {\n    const infos = parseInfos();\n    if (infos) {\n      storage.userAppKeys.save(infos.keys);\n      storage.userAppSession.save(infos.uaSession);\n      storage.jwt.save(infos.jwt);\n      return new SecrecyClient(infos.uaSession, infos.keys, infos.jwt, env);\n    }\n    return null;\n  }\n\n  return new SecrecyClient(uaSession, uaKeys, uaJwt, env);\n}\n\nexport function login<T extends UseSecrecyParams>(\n  { appCode, path, redirect, scopes, backPath, env, session }: T = {} as T\n): Promise<Value<T>> {\n  return new Promise((resolve, reject) => {\n    const appUrl = window.location.origin;\n    if (appCode && !appUrl.includes(\"localhost\")) {\n      return reject(\"Can't use appCode if not in localhost\");\n    }\n    const client = getSecrecyClient(env);\n\n    if (!client) {\n      const infos: HashInfos = {\n        appUrl,\n        appCode,\n        redirect,\n        path,\n        scopes,\n        backPath\n      };\n      const data = btoa(JSON.stringify(infos)).replaceAll(\"=\", \"\");\n\n      let envStr = \"\";\n      if (env === \"dev\") {\n        envStr = \"dev.\";\n      } else if (env === \"staging\") {\n        envStr = \"staging.\";\n      }\n\n      const lang = document.documentElement.lang;\n\n      const url = `https://${envStr}auth.secrecy.me${\n        lang ? `/${lang}` : \"\"\n      }/login#${data}`;\n\n      const validate = (infos: SecrecyUserApp): void => {\n        const storage = getStorage(session);\n        storage.userAppSession.save(infos.uaSession);\n        storage.userAppKeys.save(infos.keys);\n        storage.jwt.save(infos.jwt);\n        return resolve(\n          new SecrecyClient(\n            infos.uaSession,\n            infos.keys,\n            infos.jwt,\n            env\n          ) as Value<T>\n        );\n      };\n\n      if (redirect) {\n        const infos = parseInfos();\n        if (infos) {\n          return validate(infos);\n        } else {\n          window.location.href = url;\n          return resolve(null as Value<T>);\n        }\n      } else {\n        popup(url, \"Secrecy Login\", {}, (err, data) => {\n          if (err) {\n            return reject(err);\n          } else {\n            const infos = data as SecrecyUserApp;\n            if (infos) {\n              return validate(infos);\n            }\n          }\n        });\n      }\n    } else {\n      return resolve(client as Value<T>);\n    }\n  });\n}\n"]}
116
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/client/helpers.ts"],"names":["SecrecyClient","popup","getStorage","parseInfos","window","location","hash","substr","res","JSON","parse","atob","getSecrecyClient","env","session","storage","uaSession","userAppSession","load","uaKeys","userAppKeys","uaJwt","jwt","infos","save","keys","login","appCode","path","redirect","scopes","backPath","Promise","resolve","reject","appUrl","origin","includes","client","data","btoa","stringify","replaceAll","envStr","lang","document","documentElement","url","validate","href","err"],"mappings":"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","sourcesContent":["import { SecrecyClient } from \"./index.js\";\nimport { popup } from \"../PopupTools.js\";\nimport type { SecrecyUserApp } from \"./types/index.js\";\nimport { getStorage } from \"./storage.js\";\n\nexport function parseInfos(): SecrecyUserApp | null {\n  if (!window.location.hash) {\n    return null;\n  }\n  const hash = window.location.hash.substr(1);\n  try {\n    const res = JSON.parse(atob(hash));\n    window.location.hash = \"\";\n    // TODO Add object content validation\n    return res;\n  } catch {\n    return null;\n  }\n}\n\nexport type HashInfos = {\n  appUrl: string;\n  backPath?: string;\n  appCode?: string | null | undefined;\n  path?: string | null | undefined;\n  redirect?: boolean;\n  scopes?: {\n    email: boolean;\n  };\n};\nexport type SecrecyEnv = \"dev\" | \"staging\" | \"prod\";\nexport type UseSecrecyParams = Omit<HashInfos, \"appUrl\"> & {\n  env: SecrecyEnv;\n  session?: boolean | undefined;\n};\n\nexport type Value<T extends UseSecrecyParams> = T extends { redirect: true }\n  ? SecrecyClient | null\n  : SecrecyClient;\n\nexport function getSecrecyClient(\n  env: SecrecyEnv,\n  session?: boolean | undefined\n): SecrecyClient | null {\n  const storage = getStorage(session);\n  const uaSession = storage.userAppSession.load();\n  const uaKeys = storage.userAppKeys.load();\n  const uaJwt = storage.jwt.load();\n  if (!uaSession || !uaKeys || !uaJwt) {\n    const infos = parseInfos();\n    if (infos) {\n      storage.userAppKeys.save(infos.keys);\n      storage.userAppSession.save(infos.uaSession);\n      storage.jwt.save(infos.jwt);\n      return new SecrecyClient(infos.uaSession, infos.keys, infos.jwt, env);\n    }\n    return null;\n  }\n\n  return new SecrecyClient(uaSession, uaKeys, uaJwt, env);\n}\n\nexport function login<T extends UseSecrecyParams>(\n  { appCode, path, redirect, scopes, backPath, env, session }: T = {} as T\n): Promise<Value<T>> {\n  return new Promise((resolve, reject) => {\n    const appUrl = window.location.origin;\n    if (appCode && !appUrl.includes(\"localhost\")) {\n      return reject(\"Can't use appCode if not in localhost\");\n    }\n    const client = getSecrecyClient(env);\n\n    if (!client) {\n      const infos: HashInfos = {\n        appUrl,\n        appCode,\n        redirect,\n        path,\n        scopes,\n        backPath\n      };\n      const data = btoa(JSON.stringify(infos)).replaceAll(\"=\", \"\");\n\n      let envStr = \"\";\n      if (env === \"dev\") {\n        envStr = \"dev.\";\n      } else if (env === \"staging\") {\n        envStr = \"staging.\";\n      }\n\n      const lang = document.documentElement.lang;\n\n      const url = `https://auth.${envStr}secrecy.me${\n        lang ? `/${lang}` : \"\"\n      }/login#${data}`;\n\n      const validate = (infos: SecrecyUserApp): void => {\n        const storage = getStorage(session);\n        storage.userAppSession.save(infos.uaSession);\n        storage.userAppKeys.save(infos.keys);\n        storage.jwt.save(infos.jwt);\n        return resolve(\n          new SecrecyClient(\n            infos.uaSession,\n            infos.keys,\n            infos.jwt,\n            env\n          ) as Value<T>\n        );\n      };\n\n      if (redirect) {\n        const infos = parseInfos();\n        if (infos) {\n          return validate(infos);\n        } else {\n          window.location.href = url;\n          return resolve(null as Value<T>);\n        }\n      } else {\n        popup(url, \"Secrecy Login\", {}, (err, data) => {\n          if (err) {\n            return reject(err);\n          } else {\n            const infos = data as SecrecyUserApp;\n            if (infos) {\n              return validate(infos);\n            }\n          }\n        });\n      }\n    } else {\n      return resolve(client as Value<T>);\n    }\n  });\n}\n"]}
@@ -1,8 +1,8 @@
1
+ import type { MailType } from "./../zeus/index";
1
2
  import type { DownloadProgress } from "ky";
2
- import type { CancelToken } from "axios";
3
3
  import { BaseClient } from "../BaseClient.js";
4
4
  import type { Progress } from "../crypto/file.js";
5
- import type { ReceivedMail, SentMail, Folder, VFileWithFolder, FolderFull, UserAppSettings, File as SecrecyFile, WaitingReceivedMail, DraftMail, VFile, Mail } from "./types/index.js";
5
+ import type { ReceivedMail, SentMail, Folder, VFileWithFolder, FolderFull, UserAppSettings, UserAppNotifications, File as SecrecyFile, WaitingReceivedMail, DraftMail, VFile, Mail } from "./types/index.js";
6
6
  import type { KeyPair } from "../crypto/index.js";
7
7
  import type { SecrecyEnv } from "./helpers.js";
8
8
  import type { Rights } from "../zeus/index.js";
@@ -21,23 +21,24 @@ export declare class SecrecyClient extends BaseClient {
21
21
  #private;
22
22
  jwt: string;
23
23
  constructor(uaSession: string, uaKeys: KeyPair, uaJwt: string, env: SecrecyEnv);
24
+ get publicKey(): string;
24
25
  addFileToHistory({ fileId, vFileId }: {
25
26
  fileId: string;
26
27
  vFileId: string;
27
28
  }): Promise<VFile>;
28
- uploadFile({ file, encryptProgress, uploadProgress, cancelToken }: {
29
+ uploadFile({ file, encryptProgress, uploadProgress, signal }: {
29
30
  file: globalThis.File | Uint8Array;
30
- cancelToken?: CancelToken;
31
31
  encryptProgress?: ProgressCallback;
32
32
  uploadProgress?: ProgressCallback;
33
+ signal?: AbortSignal;
33
34
  }): Promise<string | null>;
34
- uploadFileInCloud({ file, name, folderId, cancelToken, encryptProgress, uploadProgress }: {
35
+ uploadFileInCloud({ file, name, folderId, encryptProgress, uploadProgress, signal }: {
35
36
  file: globalThis.File | Uint8Array;
36
37
  name: string;
37
- cancelToken?: CancelToken;
38
38
  folderId?: string;
39
39
  encryptProgress?: ProgressCallback;
40
40
  uploadProgress?: ProgressCallback;
41
+ signal?: AbortSignal;
41
42
  }): Promise<VFileWithFolder>;
42
43
  logout(sessionId?: string | null | undefined): Promise<void>;
43
44
  createFolder({ name, parentFolderId }: {
@@ -68,6 +69,9 @@ export declare class SecrecyClient extends BaseClient {
68
69
  sharedFolders(): Promise<Folder[]>;
69
70
  foldersSharedWithMe(): Promise<Folder[]>;
70
71
  deletedFolders(): Promise<Folder[]>;
72
+ deletedMails({ mailType }: {
73
+ mailType: MailType;
74
+ }): Promise<Mail[]>;
71
75
  shareFolder({ folderId, userId, rights }: {
72
76
  folderId: string;
73
77
  userId: string;
@@ -79,6 +83,8 @@ export declare class SecrecyClient extends BaseClient {
79
83
  isFavorite?: boolean | null | undefined;
80
84
  deletedAt?: Date | null | undefined;
81
85
  }): Promise<FolderFull>;
86
+ updateAppNotifications(notifications: Partial<UserAppNotifications>): Promise<UserAppNotifications | null>;
87
+ appNotifications(): Promise<UserAppNotifications | null>;
82
88
  createMail(data: NewMail, customMessage?: string | null | undefined): Promise<boolean>;
83
89
  waitingReceivedMails(): Promise<WaitingReceivedMail[]>;
84
90
  updateDraftMail(draftId: string, { body, subject, files, recipientsIds, replyTo }: Partial<NewMail>): Promise<DraftMail | null>;
@@ -91,8 +97,8 @@ export declare class SecrecyClient extends BaseClient {
91
97
  folderId: string;
92
98
  userId: string;
93
99
  }): Promise<boolean>;
94
- duplicateVFile({ fileId, folderId, customName }: {
95
- fileId: string;
100
+ duplicateVFile({ vFileId, folderId, customName }: {
101
+ vFileId: string;
96
102
  folderId?: string | null | undefined;
97
103
  customName?: string | null | undefined;
98
104
  }): Promise<boolean>;
@@ -107,8 +113,8 @@ export declare class SecrecyClient extends BaseClient {
107
113
  }): Promise<boolean>;
108
114
  emptyMailTrash(): Promise<boolean>;
109
115
  emptyCloudTrash(): Promise<boolean>;
110
- recoverFile({ fileId }: {
111
- fileId: string;
116
+ recoverVFile({ vFileId }: {
117
+ vFileId: string;
112
118
  }): Promise<boolean>;
113
119
  recoverFolder({ id }: {
114
120
  id: string;
@@ -134,11 +140,11 @@ export declare class SecrecyClient extends BaseClient {
134
140
  sendDraftMail(draftId: string, customMessage?: string | null | undefined): Promise<boolean>;
135
141
  sendWaitingEmails(): Promise<boolean>;
136
142
  createDraftMail({ body, subject, files, recipientsIds, replyTo }: NewMail): Promise<DraftMail | null>;
137
- fileContent({ fileId, onDownloadProgress, progressDecrypt, abort }: {
143
+ fileContent({ fileId, onDownloadProgress, progressDecrypt, signal }: {
138
144
  fileId: string;
139
145
  onDownloadProgress?: (progress: DownloadProgress) => void;
140
146
  progressDecrypt?: ProgressCallback;
141
- abort?: AbortController;
147
+ signal?: AbortSignal;
142
148
  }): Promise<Uint8Array>;
143
149
  updateFile({ fileId, filename, isFavorite, deletedAt }: {
144
150
  fileId: string;