@secrecy/lib 1.0.0-dev.39 → 1.0.0-dev.42
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/BaseClient.d.ts +33 -53
- package/dist/BaseClient.js +886 -2093
- package/dist/PopupTools.js +20 -21
- package/dist/ZeusThunder.js +50 -84
- package/dist/cache.d.ts +2 -3
- package/dist/cache.js +4 -5
- package/dist/client/admin/index.js +77 -165
- package/dist/client/convert/file.d.ts +3 -3
- package/dist/client/convert/file.js +18 -23
- package/dist/client/convert/mail.js +13 -13
- package/dist/client/convert/node.d.ts +9 -0
- package/dist/client/convert/node.js +101 -0
- package/dist/client/helpers.js +41 -41
- package/dist/client/index.d.ts +63 -74
- package/dist/client/index.js +2727 -5759
- package/dist/client/storage.js +7 -7
- package/dist/client/types/File.d.ts +6 -13
- package/dist/client/types/File.js +1 -1
- package/dist/client/types/Inputs.d.ts +2 -7
- package/dist/client/types/Inputs.js +1 -1
- package/dist/client/types/Node.d.ts +49 -0
- package/dist/client/types/Node.js +3 -0
- package/dist/client/types/UserAppNotifications.d.ts +1 -1
- package/dist/client/types/UserAppNotifications.js +1 -1
- package/dist/client/types/UserAppSettings.js +1 -1
- package/dist/client/types/index.d.ts +7 -13
- package/dist/client/types/index.js +2 -4
- package/dist/client/types/selectors.d.ts +476 -0
- package/dist/client/types/selectors.js +125 -0
- package/dist/crypto/file.js +122 -203
- package/dist/crypto/index.js +14 -12
- package/dist/error.js +1 -1
- package/dist/index.d.ts +1 -2
- package/dist/index.js +2 -34
- package/dist/minify/index.js +7 -7
- package/dist/minify/lz4.js +87 -93
- package/dist/sodium.js +3 -25
- package/dist/utils/store-buddy.js +11 -15
- package/dist/utils/time.js +4 -12
- package/dist/{utils.d.ts → utils/utils.d.ts} +0 -0
- package/dist/utils/utils.js +57 -0
- package/dist/worker/__mock__/sodium.worker.js +35 -32
- package/dist/worker/md5.js +21 -39
- package/dist/worker/sodium.js +95 -130
- package/dist/worker/workerCodes.js +3 -3
- package/dist/zeus/const.d.ts +5 -0
- package/dist/zeus/const.js +303 -1360
- package/dist/zeus/index.d.ts +1805 -1817
- package/dist/zeus/index.js +542 -434
- package/package.json +40 -39
- package/dist/client/convert/folder.d.ts +0 -8
- package/dist/client/convert/folder.js +0 -264
- package/dist/client/convert/vFile.d.ts +0 -5
- package/dist/client/convert/vFile.js +0 -164
- package/dist/client/types/FilesOnUsersOnApplications.d.ts +0 -9
- package/dist/client/types/FilesOnUsersOnApplications.js +0 -3
- package/dist/client/types/Folder.d.ts +0 -68
- package/dist/client/types/Folder.js +0 -7
- package/dist/client/types/VFile.d.ts +0 -62
- package/dist/client/types/VFile.js +0 -4
- package/dist/client/types/queries.d.ts +0 -535
- package/dist/client/types/queries.js +0 -192
- package/dist/utils.js +0 -188
|
@@ -1,16 +1,7 @@
|
|
|
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); 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 = 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; }
|
|
9
|
-
|
|
10
1
|
/* eslint-disable @typescript-eslint/naming-convention */
|
|
11
2
|
import { storeBuddy } from "../../utils/store-buddy.js";
|
|
12
3
|
import { BaseClient } from "../../BaseClient.js";
|
|
13
|
-
|
|
4
|
+
const userSelector = {
|
|
14
5
|
id: true,
|
|
15
6
|
firstname: true,
|
|
16
7
|
lastname: true,
|
|
@@ -21,173 +12,94 @@ var userSelector = {
|
|
|
21
12
|
deletedAt: true,
|
|
22
13
|
lastLogin: true
|
|
23
14
|
};
|
|
24
|
-
export
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
"...on ErrorAccessDenied": {
|
|
47
|
-
__typename: true,
|
|
48
|
-
message: true
|
|
49
|
-
},
|
|
50
|
-
"...on UserListResponse": {
|
|
51
|
-
__typename: true,
|
|
52
|
-
userList: userSelector
|
|
53
|
-
}
|
|
54
|
-
}]
|
|
55
|
-
});
|
|
56
|
-
|
|
57
|
-
case 2:
|
|
58
|
-
_yield$this$client = _context.sent;
|
|
59
|
-
userList = _yield$this$client.userList;
|
|
60
|
-
|
|
61
|
-
if (userList) {
|
|
62
|
-
_context.next = 6;
|
|
63
|
-
break;
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
return _context.abrupt("return", null);
|
|
67
|
-
|
|
68
|
-
case 6:
|
|
69
|
-
if (!(userList.__typename === "ErrorAccessDenied")) {
|
|
70
|
-
_context.next = 8;
|
|
71
|
-
break;
|
|
72
|
-
}
|
|
73
|
-
|
|
74
|
-
return _context.abrupt("return", userList);
|
|
75
|
-
|
|
76
|
-
case 8:
|
|
77
|
-
result = userList.userList.map(function (user) {
|
|
78
|
-
return _objectSpread(_objectSpread({}, user), {}, {
|
|
79
|
-
lastLogin: new Date(user.lastLogin),
|
|
80
|
-
deletedAt: user.deletedAt ? new Date(user.deletedAt) : null
|
|
81
|
-
});
|
|
82
|
-
});
|
|
83
|
-
return _context.abrupt("return", {
|
|
84
|
-
__typename: "SuccessResponse",
|
|
85
|
-
data: result
|
|
86
|
-
});
|
|
87
|
-
|
|
88
|
-
case 10:
|
|
89
|
-
case "end":
|
|
90
|
-
return _context.stop();
|
|
91
|
-
}
|
|
15
|
+
export class AdminSecrecyClient extends BaseClient {
|
|
16
|
+
async userList(search) {
|
|
17
|
+
const {
|
|
18
|
+
userList
|
|
19
|
+
} = await this.client("query", {
|
|
20
|
+
scalars: {
|
|
21
|
+
DateTime: {
|
|
22
|
+
decode: e => new Date(e),
|
|
23
|
+
encode: e => e.toISOString()
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
})({
|
|
27
|
+
userList: [{
|
|
28
|
+
search
|
|
29
|
+
}, {
|
|
30
|
+
"...on ErrorAccessDenied": {
|
|
31
|
+
__typename: true,
|
|
32
|
+
message: true
|
|
33
|
+
},
|
|
34
|
+
"...on UserListResponse": {
|
|
35
|
+
__typename: true,
|
|
36
|
+
userList: userSelector
|
|
92
37
|
}
|
|
93
|
-
}
|
|
94
|
-
})
|
|
38
|
+
}]
|
|
39
|
+
});
|
|
95
40
|
|
|
96
|
-
|
|
97
|
-
return
|
|
41
|
+
if (!userList) {
|
|
42
|
+
return null;
|
|
98
43
|
}
|
|
99
44
|
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
_proto.changeUserPlan = /*#__PURE__*/function () {
|
|
104
|
-
var _changeUserPlan = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee2(userId, plan) {
|
|
105
|
-
var _yield$this$client2, changeUserPlan;
|
|
106
|
-
|
|
107
|
-
return _regeneratorRuntime.wrap(function _callee2$(_context2) {
|
|
108
|
-
while (1) {
|
|
109
|
-
switch (_context2.prev = _context2.next) {
|
|
110
|
-
case 0:
|
|
111
|
-
_context2.next = 2;
|
|
112
|
-
return this.client("mutation")({
|
|
113
|
-
changeUserPlan: [{
|
|
114
|
-
userId: userId,
|
|
115
|
-
plan: plan
|
|
116
|
-
}, {
|
|
117
|
-
"...on ErrorAccessDenied": {
|
|
118
|
-
__typename: true,
|
|
119
|
-
message: true
|
|
120
|
-
},
|
|
121
|
-
"...on ChangeUserPlanResponse": {
|
|
122
|
-
__typename: true,
|
|
123
|
-
changeUserPlan: userSelector
|
|
124
|
-
}
|
|
125
|
-
}]
|
|
126
|
-
});
|
|
127
|
-
|
|
128
|
-
case 2:
|
|
129
|
-
_yield$this$client2 = _context2.sent;
|
|
130
|
-
changeUserPlan = _yield$this$client2.changeUserPlan;
|
|
131
|
-
|
|
132
|
-
if (changeUserPlan) {
|
|
133
|
-
_context2.next = 6;
|
|
134
|
-
break;
|
|
135
|
-
}
|
|
136
|
-
|
|
137
|
-
return _context2.abrupt("return", null);
|
|
138
|
-
|
|
139
|
-
case 6:
|
|
140
|
-
if (!(changeUserPlan.__typename === "ErrorAccessDenied")) {
|
|
141
|
-
_context2.next = 8;
|
|
142
|
-
break;
|
|
143
|
-
}
|
|
144
|
-
|
|
145
|
-
return _context2.abrupt("return", changeUserPlan);
|
|
45
|
+
if (userList.__typename === "ErrorAccessDenied") {
|
|
46
|
+
return userList;
|
|
47
|
+
}
|
|
146
48
|
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
49
|
+
return {
|
|
50
|
+
__typename: "SuccessResponse",
|
|
51
|
+
data: userList.userList
|
|
52
|
+
};
|
|
53
|
+
}
|
|
152
54
|
|
|
153
|
-
|
|
55
|
+
async changeUserPlan(userId, plan) {
|
|
56
|
+
const {
|
|
57
|
+
changeUserPlan
|
|
58
|
+
} = await this.client("mutation", {
|
|
59
|
+
scalars: {
|
|
60
|
+
DateTime: {
|
|
61
|
+
decode: e => new Date(e),
|
|
62
|
+
encode: e => e.toISOString()
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
})({
|
|
66
|
+
changeUserPlan: [{
|
|
67
|
+
userId,
|
|
68
|
+
plan
|
|
69
|
+
}, {
|
|
70
|
+
"...on ErrorAccessDenied": {
|
|
71
|
+
__typename: true,
|
|
72
|
+
message: true
|
|
73
|
+
},
|
|
74
|
+
"...on ChangeUserPlanResponse": {
|
|
75
|
+
__typename: true,
|
|
76
|
+
changeUserPlan: userSelector
|
|
77
|
+
}
|
|
78
|
+
}]
|
|
79
|
+
});
|
|
154
80
|
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
data: {
|
|
159
|
-
deletedAt: changeUserPlan.changeUserPlan.deletedAt ? new Date(changeUserPlan.changeUserPlan.deletedAt) : null,
|
|
160
|
-
lastLogin: new Date(changeUserPlan.changeUserPlan.lastLogin),
|
|
161
|
-
email: changeUserPlan.changeUserPlan.email,
|
|
162
|
-
firstname: changeUserPlan.changeUserPlan.firstname,
|
|
163
|
-
id: changeUserPlan.changeUserPlan.id,
|
|
164
|
-
lang: changeUserPlan.changeUserPlan.lang,
|
|
165
|
-
lastname: changeUserPlan.changeUserPlan.lastname,
|
|
166
|
-
phone: changeUserPlan.changeUserPlan.phone,
|
|
167
|
-
role: changeUserPlan.changeUserPlan.role
|
|
168
|
-
}
|
|
169
|
-
});
|
|
81
|
+
if (!changeUserPlan) {
|
|
82
|
+
return null;
|
|
83
|
+
}
|
|
170
84
|
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
}
|
|
175
|
-
}
|
|
176
|
-
}, _callee2, this);
|
|
177
|
-
}));
|
|
85
|
+
if (changeUserPlan.__typename === "ErrorAccessDenied") {
|
|
86
|
+
return changeUserPlan;
|
|
87
|
+
}
|
|
178
88
|
|
|
179
|
-
|
|
180
|
-
return
|
|
89
|
+
if (!changeUserPlan.changeUserPlan) {
|
|
90
|
+
return null;
|
|
181
91
|
}
|
|
182
92
|
|
|
183
|
-
return
|
|
184
|
-
|
|
93
|
+
return {
|
|
94
|
+
__typename: "SuccessResponse",
|
|
95
|
+
data: changeUserPlan.changeUserPlan
|
|
96
|
+
};
|
|
97
|
+
}
|
|
185
98
|
|
|
186
|
-
|
|
187
|
-
}(BaseClient);
|
|
99
|
+
}
|
|
188
100
|
export function getSecrecyAdminClient(env, session) {
|
|
189
|
-
|
|
190
|
-
|
|
101
|
+
const userSession = storeBuddy("secrecy.user_session", session).init("");
|
|
102
|
+
const uaSession = userSession.load();
|
|
191
103
|
|
|
192
104
|
if (uaSession === "") {
|
|
193
105
|
return null;
|
|
@@ -195,4 +107,4 @@ export function getSecrecyAdminClient(env, session) {
|
|
|
195
107
|
|
|
196
108
|
return new AdminSecrecyClient(uaSession, env);
|
|
197
109
|
}
|
|
198
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/client/admin/index.ts"],"names":["storeBuddy","BaseClient","userSelector","id","firstname","lastname","lang","email","phone","role","deletedAt","lastLogin","AdminSecrecyClient","userList","search","client","__typename","message","result","map","user","Date","data","changeUserPlan","userId","plan","getSecrecyAdminClient","env","session","userSession","init","uaSession","load"],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/naming-convention */\nimport type {\n  PlanKind,\n  SecrecyEnv,\n  SuccessResponse,\n  User\n} from \"../../index.js\";\nimport { storeBuddy } from \"../../utils/store-buddy.js\";\nimport { BaseClient } from \"../../BaseClient.js\";\nimport type { ErrorAccessDenied } from \"../../error.js\";\n\n/* TODO\n- query pour lister les users avec pagination et input optionnel \"search\" et boolean pour filtrer les bans\n- mutation changer le plan d'un user (sans payer du coup)\n- query pour renvoyer les apps d'un user\n- query pour donner les limites d'un user\n- query pour donner les reports d'un user\n- mutation pour ban un user\n- query pour get les bans d'un user\n- mutation pour delete un user (déjà existant?)\n- mutation changer le role du user (user/admin)\n- mutation pour déco une ou des sessions meta ou app d'un user\n- query afficher les sessions meta ou app d'un user\n- query pour afficher des infos sur le cloud d'un user\n- mutation pour delete, restore, delete trash, dans le cloud d'un user\n- query pour afficher les infos sur les mails d'un user\n- mutation pour delete, restore, delete trash, dans les mails d'un user\n- query pour afficher les limites max et actuels d'un user\n- query de stats?\n*/\n\nexport type UserAdminPanel = User<{ withPublicKey: false }>;\nconst userSelector = {\n  id: true,\n  firstname: true,\n  lastname: true,\n  lang: true,\n  email: true,\n  phone: true,\n  role: true,\n  deletedAt: true,\n  lastLogin: true\n} as const;\n\nexport class AdminSecrecyClient extends BaseClient {\n  async userList(\n    search?: string | null | undefined\n  ): Promise<SuccessResponse<UserAdminPanel[]> | ErrorAccessDenied | null> {\n    const { userList } = await this.client(\"query\")({\n      userList: [\n        {\n          search\n        },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on UserListResponse\": {\n            __typename: true,\n            userList: userSelector\n          }\n        }\n      ]\n    });\n\n    if (!userList) {\n      return null;\n    }\n\n    if (userList.__typename === \"ErrorAccessDenied\") {\n      return userList;\n    }\n\n    const result = userList.userList.map(user => ({\n      ...user,\n      lastLogin: new Date(user.lastLogin),\n      deletedAt: user.deletedAt ? new Date(user.deletedAt) : null\n    }));\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: result\n    };\n  }\n\n  async changeUserPlan(\n    userId: string,\n    plan: PlanKind\n  ): Promise<SuccessResponse<UserAdminPanel> | ErrorAccessDenied | null> {\n    const { changeUserPlan } = await this.client(\"mutation\")({\n      changeUserPlan: [\n        {\n          userId,\n          plan\n        },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ChangeUserPlanResponse\": {\n            __typename: true,\n            changeUserPlan: userSelector\n          }\n        }\n      ]\n    });\n\n    if (!changeUserPlan) {\n      return null;\n    }\n\n    if (changeUserPlan.__typename === \"ErrorAccessDenied\") {\n      return changeUserPlan;\n    }\n\n    if (!changeUserPlan.changeUserPlan) {\n      return null;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: {\n        deletedAt: changeUserPlan.changeUserPlan.deletedAt\n          ? new Date(changeUserPlan.changeUserPlan.deletedAt)\n          : null,\n        lastLogin: new Date(changeUserPlan.changeUserPlan.lastLogin),\n        email: changeUserPlan.changeUserPlan.email,\n        firstname: changeUserPlan.changeUserPlan.firstname,\n        id: changeUserPlan.changeUserPlan.id,\n        lang: changeUserPlan.changeUserPlan.lang,\n        lastname: changeUserPlan.changeUserPlan.lastname,\n        phone: changeUserPlan.changeUserPlan.phone,\n        role: changeUserPlan.changeUserPlan.role\n      }\n    };\n  }\n}\n\nexport function getSecrecyAdminClient(\n  env: SecrecyEnv,\n  session?: boolean | undefined\n): AdminSecrecyClient | null {\n  const userSession = storeBuddy<string>(`secrecy.user_session`, session).init(\n    \"\"\n  );\n  const uaSession = userSession.load();\n  if (uaSession === \"\") {\n    return null;\n  }\n\n  return new AdminSecrecyClient(uaSession, env);\n}\n"]}
|
|
110
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["storeBuddy","BaseClient","userSelector","id","firstname","lastname","lang","email","phone","role","deletedAt","lastLogin","AdminSecrecyClient","userList","search","client","scalars","DateTime","decode","e","Date","encode","toISOString","__typename","message","data","changeUserPlan","userId","plan","getSecrecyAdminClient","env","session","userSession","init","uaSession","load"],"sources":["../../../src/client/admin/index.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/naming-convention */\nimport type {\n  PlanKind,\n  SecrecyEnv,\n  SuccessResponse,\n  User\n} from \"../../index.js\";\nimport { storeBuddy } from \"../../utils/store-buddy.js\";\nimport { BaseClient } from \"../../BaseClient.js\";\nimport type { ErrorAccessDenied } from \"../../error.js\";\n\n/* TODO\n- query pour lister les users avec pagination et input optionnel \"search\" et boolean pour filtrer les bans\n- mutation changer le plan d'un user (sans payer du coup)\n- query pour renvoyer les apps d'un user\n- query pour donner les limites d'un user\n- query pour donner les reports d'un user\n- mutation pour ban un user\n- query pour get les bans d'un user\n- mutation pour delete un user (déjà existant?)\n- mutation changer le role du user (user/admin)\n- mutation pour déco une ou des sessions meta ou app d'un user\n- query afficher les sessions meta ou app d'un user\n- query pour afficher des infos sur le cloud d'un user\n- mutation pour delete, restore, delete trash, dans le cloud d'un user\n- query pour afficher les infos sur les mails d'un user\n- mutation pour delete, restore, delete trash, dans les mails d'un user\n- query pour afficher les limites max et actuels d'un user\n- query de stats?\n*/\n\nexport type UserAdminPanel = User<{ withPublicKey: false }>;\nconst userSelector = {\n  id: true,\n  firstname: true,\n  lastname: true,\n  lang: true,\n  email: true,\n  phone: true,\n  role: true,\n  deletedAt: true,\n  lastLogin: true\n} as const;\n\nexport class AdminSecrecyClient extends BaseClient {\n  async userList(\n    search?: string | null | undefined\n  ): Promise<SuccessResponse<UserAdminPanel[]> | ErrorAccessDenied | null> {\n    const { userList } = await this.client(\"query\", {\n      scalars: {\n        DateTime: {\n          decode: (e: unknown) => new Date(e as string),\n          encode: (e: unknown) => (e as Date).toISOString()\n        }\n      }\n    })({\n      userList: [\n        {\n          search\n        },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on UserListResponse\": {\n            __typename: true,\n            userList: userSelector\n          }\n        }\n      ]\n    });\n\n    if (!userList) {\n      return null;\n    }\n\n    if (userList.__typename === \"ErrorAccessDenied\") {\n      return userList;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: userList.userList\n    };\n  }\n\n  async changeUserPlan(\n    userId: string,\n    plan: PlanKind\n  ): Promise<SuccessResponse<UserAdminPanel> | ErrorAccessDenied | null> {\n    const { changeUserPlan } = await this.client(\"mutation\", {\n      scalars: {\n        DateTime: {\n          decode: (e: unknown) => new Date(e as string),\n          encode: (e: unknown) => (e as Date).toISOString()\n        }\n      }\n    })({\n      changeUserPlan: [\n        {\n          userId,\n          plan\n        },\n        {\n          \"...on ErrorAccessDenied\": {\n            __typename: true,\n            message: true\n          },\n          \"...on ChangeUserPlanResponse\": {\n            __typename: true,\n            changeUserPlan: userSelector\n          }\n        }\n      ]\n    });\n\n    if (!changeUserPlan) {\n      return null;\n    }\n\n    if (changeUserPlan.__typename === \"ErrorAccessDenied\") {\n      return changeUserPlan;\n    }\n\n    if (!changeUserPlan.changeUserPlan) {\n      return null;\n    }\n\n    return {\n      __typename: \"SuccessResponse\",\n      data: changeUserPlan.changeUserPlan\n    };\n  }\n}\n\nexport function getSecrecyAdminClient(\n  env: SecrecyEnv,\n  session?: boolean | undefined\n): AdminSecrecyClient | null {\n  const userSession = storeBuddy<string>(`secrecy.user_session`, session).init(\n    \"\"\n  );\n  const uaSession = userSession.load();\n  if (uaSession === \"\") {\n    return null;\n  }\n\n  return new AdminSecrecyClient(uaSession, env);\n}\n"],"mappings":"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"}
|
|
@@ -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;
|
|
@@ -1,39 +1,34 @@
|
|
|
1
|
-
import _defineProperty from "@babel/runtime/helpers/defineProperty";
|
|
2
|
-
|
|
3
|
-
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
4
|
-
|
|
5
|
-
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
6
|
-
|
|
7
1
|
import { filesCache } from "../../cache.js";
|
|
8
2
|
import { decryptCryptoBox } from "../../crypto/index.js";
|
|
9
3
|
import { sodium } from "../../sodium.js";
|
|
10
4
|
export function gqlFileToInternal(gql, keyPair) {
|
|
11
|
-
|
|
5
|
+
if (!gql.access || !gql.access.sharedBy.keyPair) {
|
|
6
|
+
throw "File " + gql.id + " doesn't have access";
|
|
7
|
+
}
|
|
12
8
|
|
|
13
|
-
|
|
9
|
+
const file = {
|
|
10
|
+
id: gql.id,
|
|
11
|
+
md5: gql.md5,
|
|
12
|
+
md5Encrypted: gql.md5Encrypted,
|
|
14
13
|
createdAt: new Date(gql.createdAt),
|
|
15
14
|
size: BigInt(gql.size),
|
|
16
15
|
sizeBefore: BigInt(gql.sizeBefore),
|
|
17
|
-
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
if ((_gql$user = gql.user) != null && _gql$user.userApp.keyPair) {
|
|
21
|
-
file.user = _objectSpread(_objectSpread({}, gql.user), {}, {
|
|
22
|
-
key: sodium.to_hex(decryptCryptoBox(sodium.from_hex(gql.user.key), gql.user.userApp.keyPair.pub, keyPair.privateKey))
|
|
23
|
-
});
|
|
24
|
-
}
|
|
25
|
-
|
|
16
|
+
key: sodium.to_hex(decryptCryptoBox(sodium.from_hex(gql.access.key), gql.access.sharedBy.keyPair.pub, keyPair.privateKey))
|
|
17
|
+
};
|
|
26
18
|
filesCache.set(file.id, file);
|
|
27
19
|
return file;
|
|
28
20
|
}
|
|
29
21
|
export function internalFileToFile(internal) {
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
22
|
+
return {
|
|
23
|
+
id: internal.id,
|
|
24
|
+
md5: internal.md5,
|
|
25
|
+
md5Encrypted: internal.md5Encrypted,
|
|
26
|
+
createdAt: internal.createdAt,
|
|
27
|
+
size: internal.size,
|
|
28
|
+
sizeBefore: internal.sizeBefore
|
|
29
|
+
};
|
|
35
30
|
}
|
|
36
31
|
export function gqlFileToExternal(gql, keyPair) {
|
|
37
32
|
return internalFileToFile(gqlFileToInternal(gql, keyPair));
|
|
38
33
|
}
|
|
39
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
34
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJmaWxlc0NhY2hlIiwiZGVjcnlwdENyeXB0b0JveCIsInNvZGl1bSIsImdxbEZpbGVUb0ludGVybmFsIiwiZ3FsIiwia2V5UGFpciIsImFjY2VzcyIsInNoYXJlZEJ5IiwiaWQiLCJmaWxlIiwibWQ1IiwibWQ1RW5jcnlwdGVkIiwiY3JlYXRlZEF0IiwiRGF0ZSIsInNpemUiLCJCaWdJbnQiLCJzaXplQmVmb3JlIiwia2V5IiwidG9faGV4IiwiZnJvbV9oZXgiLCJwdWIiLCJwcml2YXRlS2V5Iiwic2V0IiwiaW50ZXJuYWxGaWxlVG9GaWxlIiwiaW50ZXJuYWwiLCJncWxGaWxlVG9FeHRlcm5hbCJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jbGllbnQvY29udmVydC9maWxlLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGZpbGVzQ2FjaGUgfSBmcm9tIFwiLi4vLi4vY2FjaGUuanNcIjtcbmltcG9ydCB0eXBlIHsgS2V5UGFpciB9IGZyb20gXCIuLi8uLi9jcnlwdG8vaW5kZXguanNcIjtcbmltcG9ydCB7IGRlY3J5cHRDcnlwdG9Cb3ggfSBmcm9tIFwiLi4vLi4vY3J5cHRvL2luZGV4LmpzXCI7XG5pbXBvcnQgeyBzb2RpdW0gfSBmcm9tIFwiLi4vLi4vc29kaXVtLmpzXCI7XG5pbXBvcnQgdHlwZSB7IEdRTEZpbGUsIEludGVybmFsRmlsZSwgRmlsZU1ldGFkYXRhIH0gZnJvbSBcIi4uL3R5cGVzL2luZGV4LmpzXCI7XG5cbmV4cG9ydCBmdW5jdGlvbiBncWxGaWxlVG9JbnRlcm5hbChcbiAgZ3FsOiBHUUxGaWxlLFxuICBrZXlQYWlyOiBLZXlQYWlyXG4pOiBJbnRlcm5hbEZpbGUge1xuICBpZiAoIWdxbC5hY2Nlc3MgfHwgIWdxbC5hY2Nlc3Muc2hhcmVkQnkua2V5UGFpcikge1xuICAgIHRocm93IGBGaWxlICR7Z3FsLmlkfSBkb2Vzbid0IGhhdmUgYWNjZXNzYDtcbiAgfVxuXG4gIGNvbnN0IGZpbGU6IEludGVybmFsRmlsZSA9IHtcbiAgICBpZDogZ3FsLmlkLFxuICAgIG1kNTogZ3FsLm1kNSxcbiAgICBtZDVFbmNyeXB0ZWQ6IGdxbC5tZDVFbmNyeXB0ZWQsXG4gICAgY3JlYXRlZEF0OiBuZXcgRGF0ZShncWwuY3JlYXRlZEF0IGFzIHN0cmluZyksXG4gICAgc2l6ZTogQmlnSW50KGdxbC5zaXplIGFzIHN0cmluZyksXG4gICAgc2l6ZUJlZm9yZTogQmlnSW50KGdxbC5zaXplQmVmb3JlIGFzIHN0cmluZyksXG4gICAga2V5OiBzb2RpdW0udG9faGV4KFxuICAgICAgZGVjcnlwdENyeXB0b0JveChcbiAgICAgICAgc29kaXVtLmZyb21faGV4KGdxbC5hY2Nlc3Mua2V5KSxcbiAgICAgICAgZ3FsLmFjY2Vzcy5zaGFyZWRCeS5rZXlQYWlyLnB1YixcbiAgICAgICAga2V5UGFpci5wcml2YXRlS2V5XG4gICAgICApXG4gICAgKVxuICB9O1xuXG4gIGZpbGVzQ2FjaGUuc2V0KGZpbGUuaWQsIGZpbGUpO1xuICByZXR1cm4gZmlsZTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGludGVybmFsRmlsZVRvRmlsZShpbnRlcm5hbDogSW50ZXJuYWxGaWxlKTogRmlsZU1ldGFkYXRhIHtcbiAgcmV0dXJuIHtcbiAgICBpZDogaW50ZXJuYWwuaWQsXG4gICAgbWQ1OiBpbnRlcm5hbC5tZDUsXG4gICAgbWQ1RW5jcnlwdGVkOiBpbnRlcm5hbC5tZDVFbmNyeXB0ZWQsXG4gICAgY3JlYXRlZEF0OiBpbnRlcm5hbC5jcmVhdGVkQXQsXG4gICAgc2l6ZTogaW50ZXJuYWwuc2l6ZSxcbiAgICBzaXplQmVmb3JlOiBpbnRlcm5hbC5zaXplQmVmb3JlXG4gIH07XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBncWxGaWxlVG9FeHRlcm5hbChcbiAgZ3FsOiBHUUxGaWxlLFxuICBrZXlQYWlyOiBLZXlQYWlyXG4pOiBGaWxlTWV0YWRhdGEge1xuICByZXR1cm4gaW50ZXJuYWxGaWxlVG9GaWxlKGdxbEZpbGVUb0ludGVybmFsKGdxbCwga2V5UGFpcikpO1xufVxuIl0sIm1hcHBpbmdzIjoiQUFBQSxTQUFTQSxVQUFULFFBQTJCLGdCQUEzQjtBQUVBLFNBQVNDLGdCQUFULFFBQWlDLHVCQUFqQztBQUNBLFNBQVNDLE1BQVQsUUFBdUIsaUJBQXZCO0FBR0EsT0FBTyxTQUFTQyxpQkFBVCxDQUNMQyxHQURLLEVBRUxDLE9BRkssRUFHUztFQUNkLElBQUksQ0FBQ0QsR0FBRyxDQUFDRSxNQUFMLElBQWUsQ0FBQ0YsR0FBRyxDQUFDRSxNQUFKLENBQVdDLFFBQVgsQ0FBb0JGLE9BQXhDLEVBQWlEO0lBQy9DLGdCQUFjRCxHQUFHLENBQUNJLEVBQWxCO0VBQ0Q7O0VBRUQsTUFBTUMsSUFBa0IsR0FBRztJQUN6QkQsRUFBRSxFQUFFSixHQUFHLENBQUNJLEVBRGlCO0lBRXpCRSxHQUFHLEVBQUVOLEdBQUcsQ0FBQ00sR0FGZ0I7SUFHekJDLFlBQVksRUFBRVAsR0FBRyxDQUFDTyxZQUhPO0lBSXpCQyxTQUFTLEVBQUUsSUFBSUMsSUFBSixDQUFTVCxHQUFHLENBQUNRLFNBQWIsQ0FKYztJQUt6QkUsSUFBSSxFQUFFQyxNQUFNLENBQUNYLEdBQUcsQ0FBQ1UsSUFBTCxDQUxhO0lBTXpCRSxVQUFVLEVBQUVELE1BQU0sQ0FBQ1gsR0FBRyxDQUFDWSxVQUFMLENBTk87SUFPekJDLEdBQUcsRUFBRWYsTUFBTSxDQUFDZ0IsTUFBUCxDQUNIakIsZ0JBQWdCLENBQ2RDLE1BQU0sQ0FBQ2lCLFFBQVAsQ0FBZ0JmLEdBQUcsQ0FBQ0UsTUFBSixDQUFXVyxHQUEzQixDQURjLEVBRWRiLEdBQUcsQ0FBQ0UsTUFBSixDQUFXQyxRQUFYLENBQW9CRixPQUFwQixDQUE0QmUsR0FGZCxFQUdkZixPQUFPLENBQUNnQixVQUhNLENBRGI7RUFQb0IsQ0FBM0I7RUFnQkFyQixVQUFVLENBQUNzQixHQUFYLENBQWViLElBQUksQ0FBQ0QsRUFBcEIsRUFBd0JDLElBQXhCO0VBQ0EsT0FBT0EsSUFBUDtBQUNEO0FBRUQsT0FBTyxTQUFTYyxrQkFBVCxDQUE0QkMsUUFBNUIsRUFBa0U7RUFDdkUsT0FBTztJQUNMaEIsRUFBRSxFQUFFZ0IsUUFBUSxDQUFDaEIsRUFEUjtJQUVMRSxHQUFHLEVBQUVjLFFBQVEsQ0FBQ2QsR0FGVDtJQUdMQyxZQUFZLEVBQUVhLFFBQVEsQ0FBQ2IsWUFIbEI7SUFJTEMsU0FBUyxFQUFFWSxRQUFRLENBQUNaLFNBSmY7SUFLTEUsSUFBSSxFQUFFVSxRQUFRLENBQUNWLElBTFY7SUFNTEUsVUFBVSxFQUFFUSxRQUFRLENBQUNSO0VBTmhCLENBQVA7QUFRRDtBQUVELE9BQU8sU0FBU1MsaUJBQVQsQ0FDTHJCLEdBREssRUFFTEMsT0FGSyxFQUdTO0VBQ2QsT0FBT2tCLGtCQUFrQixDQUFDcEIsaUJBQWlCLENBQUNDLEdBQUQsRUFBTUMsT0FBTixDQUFsQixDQUF6QjtBQUNEIn0=
|
|
@@ -6,26 +6,26 @@ export function convertInternalMailToExternal(data, keys) {
|
|
|
6
6
|
data.type = "draft";
|
|
7
7
|
}
|
|
8
8
|
|
|
9
|
-
|
|
9
|
+
const mI = data.type === "draft" ? data.mailIntegrityDraft : data.mailIntegrity;
|
|
10
10
|
|
|
11
11
|
if (!mI) {
|
|
12
12
|
return null;
|
|
13
13
|
}
|
|
14
14
|
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
body
|
|
20
|
-
subject
|
|
15
|
+
const pubKey = data.type === "received" ? data.sender.publicKey : keys.publicKey;
|
|
16
|
+
const body = sodium.to_string(decryptCryptoBox(sodium.from_hex(data.body), pubKey, keys.privateKey));
|
|
17
|
+
const subject = sodium.to_string(decryptCryptoBox(sodium.from_hex(data.subject), pubKey, keys.privateKey));
|
|
18
|
+
const hash = sodium.crypto_generichash(sodium.crypto_generichash_BYTES, JSON.stringify({
|
|
19
|
+
body,
|
|
20
|
+
subject
|
|
21
21
|
}), mI.hashKey, "hex");
|
|
22
22
|
return {
|
|
23
23
|
type: data.type,
|
|
24
24
|
id: data.id,
|
|
25
25
|
mailIntegrityId: mI.id,
|
|
26
26
|
replyTo: (_mI$replyTo = mI.replyTo) == null ? void 0 : _mI$replyTo.id,
|
|
27
|
-
body
|
|
28
|
-
subject
|
|
27
|
+
body,
|
|
28
|
+
subject,
|
|
29
29
|
createdAt: new Date(data.createdAt),
|
|
30
30
|
deletedAt: data.deletedAt ? new Date(data.deletedAt) : null,
|
|
31
31
|
openedAt: data.openedAt ? new Date(data.openedAt) : null,
|
|
@@ -33,14 +33,14 @@ export function convertInternalMailToExternal(data, keys) {
|
|
|
33
33
|
temporaryRecipients: mI.temporaryRecipients,
|
|
34
34
|
recipients: data.type === "draft" ? mI.recipients : data.recipients,
|
|
35
35
|
sender: data.sender,
|
|
36
|
-
files: data.files.map(
|
|
37
|
-
|
|
36
|
+
files: data.files.map(f => {
|
|
37
|
+
const name = sodium.to_string(decryptCryptoBox(sodium.from_hex(f.filename), pubKey, keys.privateKey));
|
|
38
38
|
return {
|
|
39
39
|
id: f.file.id,
|
|
40
|
-
name
|
|
40
|
+
name,
|
|
41
41
|
key: f.fileKey
|
|
42
42
|
};
|
|
43
43
|
})
|
|
44
44
|
};
|
|
45
45
|
}
|
|
46
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
46
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJzb2RpdW0iLCJkZWNyeXB0Q3J5cHRvQm94IiwiY29udmVydEludGVybmFsTWFpbFRvRXh0ZXJuYWwiLCJkYXRhIiwia2V5cyIsIm1haWxJbnRlZ3JpdHlEcmFmdCIsInR5cGUiLCJtSSIsIm1haWxJbnRlZ3JpdHkiLCJwdWJLZXkiLCJzZW5kZXIiLCJwdWJsaWNLZXkiLCJib2R5IiwidG9fc3RyaW5nIiwiZnJvbV9oZXgiLCJwcml2YXRlS2V5Iiwic3ViamVjdCIsImhhc2giLCJjcnlwdG9fZ2VuZXJpY2hhc2giLCJjcnlwdG9fZ2VuZXJpY2hhc2hfQllURVMiLCJKU09OIiwic3RyaW5naWZ5IiwiaGFzaEtleSIsImlkIiwibWFpbEludGVncml0eUlkIiwicmVwbHlUbyIsImNyZWF0ZWRBdCIsIkRhdGUiLCJkZWxldGVkQXQiLCJvcGVuZWRBdCIsImlzQWx0ZXJlZCIsInRlbXBvcmFyeVJlY2lwaWVudHMiLCJyZWNpcGllbnRzIiwiZmlsZXMiLCJtYXAiLCJmIiwibmFtZSIsImZpbGVuYW1lIiwiZmlsZSIsImtleSIsImZpbGVLZXkiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY2xpZW50L2NvbnZlcnQvbWFpbC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IEtleVBhaXIgfSBmcm9tIFwiLi4vLi4vY3J5cHRvL2luZGV4LmpzXCI7XG5pbXBvcnQgdHlwZSB7IEludGVybmFsTWFpbCwgTWFpbCB9IGZyb20gXCIuLi90eXBlcy9pbmRleC5qc1wiO1xuaW1wb3J0IHsgc29kaXVtLCBkZWNyeXB0Q3J5cHRvQm94IH0gZnJvbSBcIi4uLy4uL2luZGV4LmpzXCI7XG5cbmV4cG9ydCBmdW5jdGlvbiBjb252ZXJ0SW50ZXJuYWxNYWlsVG9FeHRlcm5hbChcbiAgZGF0YTogSW50ZXJuYWxNYWlsLFxuICBrZXlzOiBLZXlQYWlyXG4pOiBNYWlsIHwgbnVsbCB7XG4gIGlmIChkYXRhLm1haWxJbnRlZ3JpdHlEcmFmdCkge1xuICAgIGRhdGEudHlwZSA9IFwiZHJhZnRcIjtcbiAgfVxuXG4gIGNvbnN0IG1JID1cbiAgICBkYXRhLnR5cGUgPT09IFwiZHJhZnRcIiA/IGRhdGEubWFpbEludGVncml0eURyYWZ0IDogZGF0YS5tYWlsSW50ZWdyaXR5O1xuXG4gIGlmICghbUkpIHtcbiAgICByZXR1cm4gbnVsbDtcbiAgfVxuXG4gIGNvbnN0IHB1YktleSA9XG4gICAgZGF0YS50eXBlID09PSBcInJlY2VpdmVkXCIgPyBkYXRhLnNlbmRlci5wdWJsaWNLZXkgOiBrZXlzLnB1YmxpY0tleTtcblxuICBjb25zdCBib2R5ID0gc29kaXVtLnRvX3N0cmluZyhcbiAgICBkZWNyeXB0Q3J5cHRvQm94KHNvZGl1bS5mcm9tX2hleChkYXRhLmJvZHkpLCBwdWJLZXksIGtleXMucHJpdmF0ZUtleSlcbiAgKTtcblxuICBjb25zdCBzdWJqZWN0ID0gc29kaXVtLnRvX3N0cmluZyhcbiAgICBkZWNyeXB0Q3J5cHRvQm94KHNvZGl1bS5mcm9tX2hleChkYXRhLnN1YmplY3QpLCBwdWJLZXksIGtleXMucHJpdmF0ZUtleSlcbiAgKTtcblxuICBjb25zdCBoYXNoID0gc29kaXVtLmNyeXB0b19nZW5lcmljaGFzaChcbiAgICBzb2RpdW0uY3J5cHRvX2dlbmVyaWNoYXNoX0JZVEVTLFxuICAgIEpTT04uc3RyaW5naWZ5KHsgYm9keSwgc3ViamVjdCB9KSxcbiAgICBtSS5oYXNoS2V5LFxuICAgIFwiaGV4XCJcbiAgKTtcblxuICByZXR1cm4ge1xuICAgIHR5cGU6IGRhdGEudHlwZSxcbiAgICBpZDogZGF0YS5pZCxcbiAgICBtYWlsSW50ZWdyaXR5SWQ6IG1JLmlkLFxuICAgIHJlcGx5VG86IG1JLnJlcGx5VG8/LmlkLFxuICAgIGJvZHksXG4gICAgc3ViamVjdCxcbiAgICBjcmVhdGVkQXQ6IG5ldyBEYXRlKGRhdGEuY3JlYXRlZEF0KSxcbiAgICBkZWxldGVkQXQ6IGRhdGEuZGVsZXRlZEF0ID8gbmV3IERhdGUoZGF0YS5kZWxldGVkQXQpIDogbnVsbCxcbiAgICBvcGVuZWRBdDogZGF0YS5vcGVuZWRBdCA/IG5ldyBEYXRlKGRhdGEub3BlbmVkQXQpIDogbnVsbCxcbiAgICBpc0FsdGVyZWQ6IGhhc2ggIT09IG1JLmhhc2gsXG4gICAgdGVtcG9yYXJ5UmVjaXBpZW50czogbUkudGVtcG9yYXJ5UmVjaXBpZW50cyxcbiAgICByZWNpcGllbnRzOiBkYXRhLnR5cGUgPT09IFwiZHJhZnRcIiA/IG1JLnJlY2lwaWVudHMgOiBkYXRhLnJlY2lwaWVudHMsXG4gICAgc2VuZGVyOiBkYXRhLnNlbmRlcixcbiAgICBmaWxlczogZGF0YS5maWxlcy5tYXAoZiA9PiB7XG4gICAgICBjb25zdCBuYW1lID0gc29kaXVtLnRvX3N0cmluZyhcbiAgICAgICAgZGVjcnlwdENyeXB0b0JveChzb2RpdW0uZnJvbV9oZXgoZi5maWxlbmFtZSksIHB1YktleSwga2V5cy5wcml2YXRlS2V5KVxuICAgICAgKTtcblxuICAgICAgcmV0dXJuIHtcbiAgICAgICAgaWQ6IGYuZmlsZS5pZCxcbiAgICAgICAgbmFtZSxcbiAgICAgICAga2V5OiBmLmZpbGVLZXlcbiAgICAgIH07XG4gICAgfSlcbiAgfTtcbn1cbiJdLCJtYXBwaW5ncyI6IkFBRUEsU0FBU0EsTUFBVCxFQUFpQkMsZ0JBQWpCLFFBQXlDLGdCQUF6QztBQUVBLE9BQU8sU0FBU0MsNkJBQVQsQ0FDTEMsSUFESyxFQUVMQyxJQUZLLEVBR1E7RUFBQTs7RUFDYixJQUFJRCxJQUFJLENBQUNFLGtCQUFULEVBQTZCO0lBQzNCRixJQUFJLENBQUNHLElBQUwsR0FBWSxPQUFaO0VBQ0Q7O0VBRUQsTUFBTUMsRUFBRSxHQUNOSixJQUFJLENBQUNHLElBQUwsS0FBYyxPQUFkLEdBQXdCSCxJQUFJLENBQUNFLGtCQUE3QixHQUFrREYsSUFBSSxDQUFDSyxhQUR6RDs7RUFHQSxJQUFJLENBQUNELEVBQUwsRUFBUztJQUNQLE9BQU8sSUFBUDtFQUNEOztFQUVELE1BQU1FLE1BQU0sR0FDVk4sSUFBSSxDQUFDRyxJQUFMLEtBQWMsVUFBZCxHQUEyQkgsSUFB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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,101 @@
|
|
|
1
|
+
import _defineProperty from "@babel/runtime/helpers/defineProperty";
|
|
2
|
+
|
|
3
|
+
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
4
|
+
|
|
5
|
+
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
6
|
+
|
|
7
|
+
import { sodium } from "../../sodium.js";
|
|
8
|
+
import { decryptCryptoBox } from "../../crypto/index.js";
|
|
9
|
+
import { nodesCache } from "../../cache.js";
|
|
10
|
+
import { decryptSecretstream } from "../../crypto/file.js";
|
|
11
|
+
import { gqlFileToInternal, internalFileToFile } from "./file.js";
|
|
12
|
+
export async function gqlNodeToInternal(gql, keyPair) {
|
|
13
|
+
if (!gql.access) {
|
|
14
|
+
throw "Can't access Node " + gql.id;
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
const internal = {
|
|
18
|
+
id: gql.id,
|
|
19
|
+
type: gql.type,
|
|
20
|
+
access: gql.access,
|
|
21
|
+
name: gql.name,
|
|
22
|
+
isFavorite: gql.isFavorite,
|
|
23
|
+
breadcrumb: gql.breadcrumb,
|
|
24
|
+
createdBy: gql.createdBy.user,
|
|
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
|
+
history: gql.history.map(f => gqlFileToInternal(f, keyPair))
|
|
30
|
+
};
|
|
31
|
+
|
|
32
|
+
if (gql.current) {
|
|
33
|
+
internal.current = gqlFileToInternal(gql.current, keyPair);
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
internal.access = _objectSpread({}, gql.access);
|
|
37
|
+
|
|
38
|
+
if (gql.access.nameKey) {
|
|
39
|
+
if (!gql.access.sharedBy.keyPair) {
|
|
40
|
+
throw new Error("Can't find keyPair for access");
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
const key = decryptCryptoBox(sodium.from_hex(gql.access.nameKey), gql.createdBy.user.publicKey, keyPair.privateKey);
|
|
44
|
+
internal.name = sodium.to_string(await decryptSecretstream(key, sodium.from_hex(internal.name)));
|
|
45
|
+
internal.access.nameKey = sodium.to_hex(key);
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
for (const b of internal.breadcrumb) {
|
|
49
|
+
if (!b.nameKey) {
|
|
50
|
+
continue;
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
const key = decryptCryptoBox(sodium.from_hex(b.nameKey), b.pubKey, keyPair.privateKey);
|
|
54
|
+
b.nameKey = sodium.to_hex(key);
|
|
55
|
+
b.name = sodium.to_string(await decryptSecretstream(key, sodium.from_hex(b.name)));
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
nodesCache.set(internal.id, internal);
|
|
59
|
+
return internal;
|
|
60
|
+
}
|
|
61
|
+
export async function gqlNodeFullToInternalFull(gql, keyPair) {
|
|
62
|
+
const f = await gqlNodeToInternal(gql, keyPair);
|
|
63
|
+
return _objectSpread(_objectSpread({}, f), {}, {
|
|
64
|
+
parent: gql.parent ? await gqlNodeToInternal(gql.parent, keyPair) : null,
|
|
65
|
+
children: await Promise.all(gql.children.map(s => gqlNodeToInternal(s, keyPair)))
|
|
66
|
+
});
|
|
67
|
+
}
|
|
68
|
+
export function internalNodeToNode(internal) {
|
|
69
|
+
var _node$access;
|
|
70
|
+
|
|
71
|
+
const node = _objectSpread(_objectSpread({}, internal), {}, {
|
|
72
|
+
access: internal.access ? _objectSpread({}, internal.access) : undefined,
|
|
73
|
+
history: internal.history.map(f => internalFileToFile(f))
|
|
74
|
+
});
|
|
75
|
+
|
|
76
|
+
if (internal.current) {
|
|
77
|
+
node.current = internalFileToFile(internal.current);
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
for (const b of node.breadcrumb) {
|
|
81
|
+
// @ts-ignore
|
|
82
|
+
delete b.pubKey;
|
|
83
|
+
} // @ts-ignore
|
|
84
|
+
|
|
85
|
+
|
|
86
|
+
(_node$access = node.access) == null ? true : delete _node$access.nameKey;
|
|
87
|
+
return node;
|
|
88
|
+
}
|
|
89
|
+
export function internalNodeFullToNodeFull(internal) {
|
|
90
|
+
return _objectSpread(_objectSpread({}, internalNodeToNode(internal)), {}, {
|
|
91
|
+
parent: internal.parent ? internalNodeToNode(internal.parent) : null,
|
|
92
|
+
children: internal.children.map(internalNodeToNode)
|
|
93
|
+
});
|
|
94
|
+
}
|
|
95
|
+
export async function gqlNodeToExternalNodeFull(gql, keyPair) {
|
|
96
|
+
return internalNodeFullToNodeFull(await gqlNodeFullToInternalFull(gql, keyPair));
|
|
97
|
+
}
|
|
98
|
+
export async function gqlNodeToExternal(gql, keyPair) {
|
|
99
|
+
return internalNodeToNode(await gqlNodeToInternal(gql, keyPair));
|
|
100
|
+
}
|
|
101
|
+
//# 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","createdAt","Date","updatedAt","deletedAt","users","accesses","map","u","userApp","rights","history","f","current","nameKey","sharedBy","Error","key","from_hex","publicKey","privateKey","to_string","to_hex","b","pubKey","set","gqlNodeFullToInternalFull","parent","children","Promise","all","s","internalNodeToNode","node","undefined","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    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    history: gql.history.map(f => gqlFileToInternal(f, keyPair))\n  };\n\n  if (gql.current) {\n    internal.current = gqlFileToInternal(gql.current, keyPair);\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    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    parent: gql.parent ? await gqlNodeToInternal(gql.parent, keyPair) : null,\n    children: await Promise.all(\n      gql.children.map(s => gqlNodeToInternal(s, keyPair))\n    )\n  };\n}\n\nexport function internalNodeToNode(internal: InternalNode): Node {\n  const node: Node = {\n    ...internal,\n    access: internal.access ? { ...internal.access } : undefined,\n    history: internal.history.map(f => internalFileToFile(f))\n  };\n\n  if (internal.current) {\n    node.current = internalFileToFile(internal.current);\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  };\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":"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"}
|