@secrecy/lib 1.0.0-dev.20 → 1.0.0-dev.24
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +0 -1
- package/lib/BaseClient.d.ts +29 -24
- package/lib/BaseClient.js +1109 -258
- package/lib/ZeusThunder.js +3 -2
- package/lib/client/admin/index.d.ts +4 -3
- package/lib/client/admin/index.js +78 -32
- package/lib/client/helpers.d.ts +1 -1
- package/lib/client/helpers.js +1 -3
- package/lib/client/index.d.ts +54 -52
- package/lib/client/index.js +2904 -548
- package/lib/error.d.ts +30 -0
- package/lib/error.js +3 -0
- package/lib/index.d.ts +2 -1
- package/lib/index.js +3 -2
- package/lib/zeus/const.js +670 -75
- package/lib/zeus/index.d.ts +2370 -444
- package/lib/zeus/index.js +44 -44
- package/package.json +27 -27
package/lib/ZeusThunder.js
CHANGED
|
@@ -56,7 +56,8 @@ var apiFetch = function apiFetch(options, session) {
|
|
|
56
56
|
|
|
57
57
|
case 7:
|
|
58
58
|
headers = {
|
|
59
|
-
"content-type": "application/json"
|
|
59
|
+
"content-type": "application/json",
|
|
60
|
+
"accept-language": navigator.language
|
|
60
61
|
};
|
|
61
62
|
|
|
62
63
|
if (session) {
|
|
@@ -109,4 +110,4 @@ export var createThunder = function createThunder(url, session) {
|
|
|
109
110
|
credentials: "same-origin"
|
|
110
111
|
}], session));
|
|
111
112
|
};
|
|
112
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
113
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9aZXVzVGh1bmRlci50cyJdLCJuYW1lcyI6WyJHcmFwaFFMRXJyb3IiLCJUaHVuZGVyIiwiaGFuZGxlRmV0Y2hSZXNwb25zZSIsInJlc3BvbnNlIiwib2siLCJQcm9taXNlIiwiXyIsInJlamVjdCIsInRleHQiLCJ0aGVuIiwiSlNPTiIsInBhcnNlIiwiZXJyIiwiY2F0Y2giLCJqc29uIiwiYXBpRmV0Y2giLCJvcHRpb25zIiwic2Vzc2lvbiIsInF1ZXJ5IiwidmFyaWFibGVzIiwiZmV0Y2hGdW5jdGlvbiIsImZldGNoIiwicXVlcnlTdHJpbmciLCJmZXRjaE9wdGlvbnMiLCJtZXRob2QiLCJlbmNvZGVVUklDb21wb25lbnQiLCJlcnJvcnMiLCJkYXRhIiwiaGVhZGVycyIsIm5hdmlnYXRvciIsImxhbmd1YWdlIiwiY29udHJvbGxlciIsIkFib3J0Q29udHJvbGxlciIsImlkIiwic2V0VGltZW91dCIsImFib3J0IiwiYm9keSIsInN0cmluZ2lmeSIsInNpZ25hbCIsInJlcyIsImNsZWFyVGltZW91dCIsImNyZWF0ZVRodW5kZXIiLCJ1cmwiLCJtb2RlIiwiY3JlZGVudGlhbHMiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7O0FBQ0EsU0FBU0EsWUFBVCxFQUF1QkMsT0FBdkIsUUFBc0MsaUJBQXRDOztBQUVBLElBQU1DLG1CQUFtQixHQUFHLFNBQXRCQSxtQkFBc0IsQ0FDMUJDLFFBRDBCLEVBTUc7QUFDN0IsTUFBSSxDQUFDQSxRQUFRLENBQUNDLEVBQWQsRUFBa0I7QUFDaEIsV0FBTyxJQUFJQyxPQUFKLENBQVksVUFBQ0MsQ0FBRCxFQUFJQyxNQUFKLEVBQWU7QUFDaENKLE1BQUFBLFFBQVEsQ0FDTEssSUFESCxHQUVHQyxJQUZILENBRVEsVUFBQUQsSUFBSSxFQUFJO0FBQ1osWUFBSTtBQUNGRCxVQUFBQSxNQUFNLENBQUNHLElBQUksQ0FBQ0MsS0FBTCxDQUFXSCxJQUFYLENBQUQsQ0FBTjtBQUNELFNBRkQsQ0FFRSxPQUFPSSxHQUFQLEVBQVk7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QixFQUUzQnpCLE9BRjJCO0FBQUEsU0FJM0JoQixPQUFPLENBQ0xjLFFBQVEsQ0FDTixDQUNFMkIsR0FERixFQUVFO0FBQ0VDLElBQUFBLElBQUksRUFBRSxNQURSO0FBRUVDLElBQUFBLFdBQVcsRUFBRTtBQUZmLEdBRkYsQ0FETSxFQVFOM0IsT0FSTSxDQURILENBSm9CO0FBQUEsQ0FBdEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IGZldGNoT3B0aW9ucywgR3JhcGhRTFJlc3BvbnNlIH0gZnJvbSBcIi4vemV1cy9pbmRleC5qc1wiO1xuaW1wb3J0IHsgR3JhcGhRTEVycm9yLCBUaHVuZGVyIH0gZnJvbSBcIi4vemV1cy9pbmRleC5qc1wiO1xuXG5jb25zdCBoYW5kbGVGZXRjaFJlc3BvbnNlID0gKFxuICByZXNwb25zZTogUGFyYW1ldGVyczxcbiAgICAvLyBUT0RPOiBjZXR0ZSBlcnJldXJcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L2Jhbi10eXBlc1xuICAgIEV4dHJhY3Q8UGFyYW1ldGVyczxSZXR1cm5UeXBlPHR5cGVvZiBmZXRjaD5bXCJ0aGVuXCJdPlswXSwgRnVuY3Rpb24+XG4gID5bMF1cbik6IFByb21pc2U8R3JhcGhRTFJlc3BvbnNlPiA9PiB7XG4gIGlmICghcmVzcG9uc2Uub2spIHtcbiAgICByZXR1cm4gbmV3IFByb21pc2UoKF8sIHJlamVjdCkgPT4ge1xuICAgICAgcmVzcG9uc2VcbiAgICAgICAgLnRleHQoKVxuICAgICAgICAudGhlbih0ZXh0ID0+IHtcbiAgICAgICAgICB0cnkge1xuICAgICAgICAgICAgcmVqZWN0KEpTT04ucGFyc2UodGV4dCkpO1xuICAgICAgICAgIH0gY2F0Y2ggKGVycikge1xuICAgICAgICAgICAgcmVqZWN0KHRleHQpO1xuICAgICAgICAgIH1cbiAgICAgICAgfSlcbiAgICAgICAgLmNhdGNoKHJlamVjdCk7XG4gICAgfSk7XG4gIH1cbiAgcmV0dXJuIHJlc3BvbnNlLmpzb24oKSBhcyBQcm9taXNlPEdyYXBoUUxSZXNwb25zZT47XG59O1xuXG5jb25zdCBhcGlGZXRjaCA9XG4gIChvcHRpb25zOiBmZXRjaE9wdGlvbnMsIHNlc3Npb24/OiBzdHJpbmcgfCBudWxsIHwgdW5kZWZpbmVkKSA9PlxuICBhc3luYyAoXG4gICAgcXVlcnk6IHN0cmluZyxcbiAgICB2YXJpYWJsZXM6IFJlY29yZDxzdHJpbmcsIGFueT4gPSB7fVxuICApOiBQcm9taXNlPFJlY29yZDxzdHJpbmcsIGFueT4gfCB1bmRlZmluZWQ+ID0+IHtcbiAgICBjb25zdCBmZXRjaEZ1bmN0aW9uID0gZmV0Y2g7XG4gICAgbGV0IHF1ZXJ5U3RyaW5nID0gcXVlcnk7XG4gICAgY29uc3QgZmV0Y2hPcHRpb25zID0gb3B0aW9uc1sxXSB8fCB7fTtcbiAgICBpZiAoZmV0Y2hPcHRpb25zLm1ldGhvZCAmJiBmZXRjaE9wdGlvbnMubWV0aG9kID09PSBcIkdFVFwiKSB7XG4gICAgICBxdWVyeVN0cmluZyA9IGVuY29kZVVSSUNvbXBvbmVudChxdWVyeSk7XG4gICAgICByZXR1cm4gZmV0Y2hGdW5jdGlvbihgJHtvcHRpb25zWzBdfT9xdWVyeT0ke3F1ZXJ5U3RyaW5nfWAsIGZldGNoT3B0aW9ucylcbiAgICAgICAgLnRoZW4oaGFuZGxlRmV0Y2hSZXNwb25zZSlcbiAgICAgICAgLnRoZW4oKHJlc3BvbnNlOiBHcmFwaFFMUmVzcG9uc2UpID0+IHtcbiAgICAgICAgICBpZiAocmVzcG9uc2UuZXJyb3JzKSB7XG4gICAgICAgICAgICB0aHJvdyBuZXcgR3JhcGhRTEVycm9yKHJlc3BvbnNlKTtcbiAgICAgICAgICB9XG4gICAgICAgICAgcmV0dXJuIHJlc3BvbnNlLmRhdGE7XG4gICAgICAgIH0pO1xuICAgIH1cbiAgICBjb25zdCBoZWFkZXJzOiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+ID0ge1xuICAgICAgXCJjb250ZW50LXR5cGVcIjogXCJhcHBsaWNhdGlvbi9qc29uXCIsXG4gICAgICBcImFjY2VwdC1sYW5ndWFnZVwiOiBuYXZpZ2F0b3IubGFuZ3VhZ2VcbiAgICB9O1xuXG4gICAgaWYgKHNlc3Npb24pIHtcbiAgICAgIGhlYWRlcnNbXCJzZWNyZWN5LXNlc3Npb25cIl0gPSBzZXNzaW9uO1xuICAgIH1cbiAgICBjb25zdCBjb250cm9sbGVyID0gbmV3IEFib3J0Q29udHJvbGxlcigpO1xuICAgIGNvbnN0IGlkID0gc2V0VGltZW91dCgoKSA9PiBjb250cm9sbGVyLmFib3J0KCksIDIwMDAwKTtcbiAgICBjb25zdCByZXMgPSBhd2FpdCBmZXRjaEZ1bmN0aW9uKGAke29wdGlvbnNbMF19YCwge1xuICAgICAgYm9keTogSlNPTi5zdHJpbmdpZnkoeyBxdWVyeTogcXVlcnlTdHJpbmcsIHZhcmlhYmxlcyB9KSxcbiAgICAgIG1ldGhvZDogXCJQT1NUXCIsXG4gICAgICBoZWFkZXJzLFxuICAgICAgc2lnbmFsOiBjb250cm9sbGVyLnNpZ25hbCxcbiAgICAgIC4uLmZldGNoT3B0aW9uc1xuICAgIH0pXG4gICAgICAudGhlbihoYW5kbGVGZXRjaFJlc3BvbnNlKVxuICAgICAgLnRoZW4oKHJlc3BvbnNlOiBHcmFwaFFMUmVzcG9uc2UpID0+IHtcbiAgICAgICAgaWYgKHJlc3BvbnNlLmVycm9ycykge1xuICAgICAgICAgIHRocm93IG5ldyBHcmFwaFFMRXJyb3IocmVzcG9uc2UpO1xuICAgICAgICB9XG4gICAgICAgIHJldHVybiByZXNwb25zZS5kYXRhO1xuICAgICAgfSk7XG4gICAgY2xlYXJUaW1lb3V0KGlkKTtcbiAgICByZXR1cm4gcmVzO1xuICB9O1xuXG5leHBvcnQgY29uc3QgY3JlYXRlVGh1bmRlciA9IChcbiAgdXJsOiBzdHJpbmcsXG4gIHNlc3Npb24/OiBzdHJpbmcgfCBudWxsIHwgdW5kZWZpbmVkXG4pOiBSZXR1cm5UeXBlPHR5cGVvZiBUaHVuZGVyPiA9PlxuICBUaHVuZGVyKFxuICAgIGFwaUZldGNoKFxuICAgICAgW1xuICAgICAgICB1cmwsXG4gICAgICAgIHtcbiAgICAgICAgICBtb2RlOiBcImNvcnNcIixcbiAgICAgICAgICBjcmVkZW50aWFsczogXCJzYW1lLW9yaWdpblwiXG4gICAgICAgIH1cbiAgICAgIF0sXG4gICAgICBzZXNzaW9uXG4gICAgKVxuICApO1xuIl19
|
|
@@ -1,10 +1,11 @@
|
|
|
1
|
-
import type { PlanKind, SecrecyEnv, User } from "../../index.js";
|
|
1
|
+
import type { PlanKind, SecrecyEnv, SuccessResponse, User } from "../../index.js";
|
|
2
2
|
import { BaseClient } from "../../BaseClient.js";
|
|
3
|
+
import type { ErrorAccessDenied } from "../../error.js";
|
|
3
4
|
export declare type UserAdminPanel = User<{
|
|
4
5
|
withPublicKey: false;
|
|
5
6
|
}>;
|
|
6
7
|
export declare class AdminSecrecyClient extends BaseClient {
|
|
7
|
-
userList(search?: string | null | undefined): Promise<UserAdminPanel[]>;
|
|
8
|
-
changeUserPlan(userId: string, plan: PlanKind): Promise<UserAdminPanel | null>;
|
|
8
|
+
userList(search?: string | null | undefined): Promise<SuccessResponse<UserAdminPanel[]> | ErrorAccessDenied | null>;
|
|
9
|
+
changeUserPlan(userId: string, plan: PlanKind): Promise<SuccessResponse<UserAdminPanel> | ErrorAccessDenied | null>;
|
|
9
10
|
}
|
|
10
11
|
export declare function getSecrecyAdminClient(env: SecrecyEnv, session?: boolean | undefined): AdminSecrecyClient | null;
|
|
@@ -7,28 +7,9 @@ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (O
|
|
|
7
7
|
|
|
8
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
9
|
|
|
10
|
+
/* eslint-disable @typescript-eslint/naming-convention */
|
|
10
11
|
import { storeBuddy } from "../../utils/store-buddy.js";
|
|
11
12
|
import { BaseClient } from "../../BaseClient.js";
|
|
12
|
-
/* TODO
|
|
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
13
|
var userSelector = {
|
|
33
14
|
id: true,
|
|
34
15
|
firstname: true,
|
|
@@ -51,7 +32,7 @@ export var AdminSecrecyClient = /*#__PURE__*/function (_BaseClient) {
|
|
|
51
32
|
|
|
52
33
|
_proto.userList = /*#__PURE__*/function () {
|
|
53
34
|
var _userList = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee(search) {
|
|
54
|
-
var _yield$this$client, userList;
|
|
35
|
+
var _yield$this$client, userList, result;
|
|
55
36
|
|
|
56
37
|
return _regeneratorRuntime.wrap(function _callee$(_context) {
|
|
57
38
|
while (1) {
|
|
@@ -61,20 +42,50 @@ export var AdminSecrecyClient = /*#__PURE__*/function (_BaseClient) {
|
|
|
61
42
|
return this.client("query")({
|
|
62
43
|
userList: [{
|
|
63
44
|
search: search
|
|
64
|
-
},
|
|
45
|
+
}, {
|
|
46
|
+
"...on ErrorAccessDenied": {
|
|
47
|
+
__typename: true,
|
|
48
|
+
message: true
|
|
49
|
+
},
|
|
50
|
+
"...on UserListResponse": {
|
|
51
|
+
__typename: true,
|
|
52
|
+
userList: userSelector
|
|
53
|
+
}
|
|
54
|
+
}]
|
|
65
55
|
});
|
|
66
56
|
|
|
67
57
|
case 2:
|
|
68
58
|
_yield$this$client = _context.sent;
|
|
69
59
|
userList = _yield$this$client.userList;
|
|
70
|
-
|
|
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) {
|
|
71
78
|
return _objectSpread(_objectSpread({}, user), {}, {
|
|
72
79
|
lastLogin: new Date(user.lastLogin),
|
|
73
80
|
deletedAt: user.deletedAt ? new Date(user.deletedAt) : null
|
|
74
81
|
});
|
|
75
|
-
})
|
|
82
|
+
});
|
|
83
|
+
return _context.abrupt("return", {
|
|
84
|
+
__typename: "SuccessResponse",
|
|
85
|
+
data: result
|
|
86
|
+
});
|
|
76
87
|
|
|
77
|
-
case
|
|
88
|
+
case 10:
|
|
78
89
|
case "end":
|
|
79
90
|
return _context.stop();
|
|
80
91
|
}
|
|
@@ -102,7 +113,16 @@ export var AdminSecrecyClient = /*#__PURE__*/function (_BaseClient) {
|
|
|
102
113
|
changeUserPlan: [{
|
|
103
114
|
userId: userId,
|
|
104
115
|
plan: plan
|
|
105
|
-
},
|
|
116
|
+
}, {
|
|
117
|
+
"...on ErrorAccessDenied": {
|
|
118
|
+
__typename: true,
|
|
119
|
+
message: true
|
|
120
|
+
},
|
|
121
|
+
"...on ChangeUserPlanResponse": {
|
|
122
|
+
__typename: true,
|
|
123
|
+
changeUserPlan: userSelector
|
|
124
|
+
}
|
|
125
|
+
}]
|
|
106
126
|
});
|
|
107
127
|
|
|
108
128
|
case 2:
|
|
@@ -117,12 +137,38 @@ export var AdminSecrecyClient = /*#__PURE__*/function (_BaseClient) {
|
|
|
117
137
|
return _context2.abrupt("return", null);
|
|
118
138
|
|
|
119
139
|
case 6:
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
}
|
|
140
|
+
if (!(changeUserPlan.__typename === "ErrorAccessDenied")) {
|
|
141
|
+
_context2.next = 8;
|
|
142
|
+
break;
|
|
143
|
+
}
|
|
144
|
+
|
|
145
|
+
return _context2.abrupt("return", changeUserPlan);
|
|
146
|
+
|
|
147
|
+
case 8:
|
|
148
|
+
if (changeUserPlan.changeUserPlan) {
|
|
149
|
+
_context2.next = 10;
|
|
150
|
+
break;
|
|
151
|
+
}
|
|
152
|
+
|
|
153
|
+
return _context2.abrupt("return", null);
|
|
154
|
+
|
|
155
|
+
case 10:
|
|
156
|
+
return _context2.abrupt("return", {
|
|
157
|
+
__typename: "SuccessResponse",
|
|
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
|
+
});
|
|
124
170
|
|
|
125
|
-
case
|
|
171
|
+
case 11:
|
|
126
172
|
case "end":
|
|
127
173
|
return _context2.stop();
|
|
128
174
|
}
|
|
@@ -149,4 +195,4 @@ export function getSecrecyAdminClient(env, session) {
|
|
|
149
195
|
|
|
150
196
|
return new AdminSecrecyClient(uaSession, env);
|
|
151
197
|
}
|
|
152
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jbGllbnQvYWRtaW4vaW5kZXgudHMiXSwibmFtZXMiOlsic3RvcmVCdWRkeSIsIkJhc2VDbGllbnQiLCJ1c2VyU2VsZWN0b3IiLCJpZCIsImZpcnN0bmFtZSIsImxhc3RuYW1lIiwibGFuZyIsImVtYWlsIiwicGhvbmUiLCJyb2xlIiwiZGVsZXRlZEF0IiwibGFzdExvZ2luIiwiQWRtaW5TZWNyZWN5Q2xpZW50IiwidXNlckxpc3QiLCJzZWFyY2giLCJjbGllbnQiLCJtYXAiLCJ1c2VyIiwiRGF0ZSIsImNoYW5nZVVzZXJQbGFuIiwidXNlcklkIiwicGxhbiIsImdldFNlY3JlY3lBZG1pbkNsaWVudCIsImVudiIsInNlc3Npb24iLCJ1c2VyU2Vzc2lvbiIsImluaXQiLCJ1YVNlc3Npb24iLCJsb2FkIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7QUFDQSxTQUFTQSxVQUFULFFBQTJCLDRCQUEzQjtBQUNBLFNBQVNDLFVBQVQsUUFBMkIscUJBQTNCO0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBR0EsSUFBTUMsWUFBWSxHQUFHO0FBQ25CQyxFQUFBQSxFQUFFLEVBQUUsSUFEZTtBQUVuQkMsRUFBQUEsU0FBUyxFQUFFLElBRlE7QUFHbkJDLEVBQUFBLFFBQVEsRUFBRSxJQUhTO0FBSW5CQyxFQUFBQSxJQUFJLEVBQUUsSUFKYTtBQUtuQkMsRUFBQUEsS0FBSyxFQUFFLElBTFk7QUFNbkJDLEVBQUFBLEtBQUssRUFBRSxJQU5ZO0FBT25CQyxFQUFBQSxJQUFJLEVBQUUsSUFQYTtBQVFuQkMsRUFBQUEsU0FBUyxFQUFFLElBUlE7QUFTbkJDLEVBQUFBLFNBQVMsRUFBRTtBQVRRLENBQXJCO0FBWUEsV0FBYUMsa0JBQWI7QUFBQTs7QUFBQTtBQUFBO0FBQUE7O0FBQUE7O0FBQUEsU0FDUUMsUUFEUjtBQUFBLDZFQUNFLGlCQUNFQyxNQURGO0FBQUE7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBLHFCQUc2QixLQUFLQyxNQUFMLENBQVksT0FBWixFQUFxQjtBQUM5Q0YsZ0JBQUFBLFFBQVEsRUFBRSxDQUNSO0FBQ0VDLGtCQUFBQSxNQUFNLEVBQU5BO0FBREYsaUJBRFEsRUFJUlosWUFKUTtBQURvQyxlQUFyQixDQUg3Qjs7QUFBQTtBQUFBO0FBR1VXLGNBQUFBLFFBSFYsc0JBR1VBLFFBSFY7QUFBQSwrQ0FZU0EsUUFBUSxDQUFDRyxHQUFULENBQWEsVUFBQUMsSUFBSTtBQUFBLHVEQUNuQkEsSUFEbUI7QUFFdEJOLGtCQUFBQSxTQUFTLEVBQUUsSUFBSU8sSUFBSixDQUFTRCxJQUFJLENBQUNOLFNBQWQsQ0FGVztBQUd0QkQsa0JBQUFBLFNBQVMsRUFBRU8sSUFBSSxDQUFDUCxTQUFMLEdBQWlCLElBQUlRLElBQUosQ0FBU0QsSUFBSSxDQUFDUCxTQUFkLENBQWpCLEdBQTRDO0FBSGpDO0FBQUEsZUFBakIsQ0FaVDs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQSxLQURGOztBQUFBO0FBQUE7QUFBQTs7QUFBQTtBQUFBOztBQUFBLFNBb0JRUyxjQXBCUjtBQUFBLG1GQW9CRSxrQkFDRUMsTUFERixFQUVFQyxJQUZGO0FBQUE7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBLHFCQUltQyxLQUFLTixNQUFMLENBQVksVUFBWixFQUF3QjtBQUN2REksZ0JBQUFBLGNBQWMsRUFBRSxDQUNkO0FBQ0VDLGtCQUFBQSxNQUFNLEVBQU5BLE1BREY7QUFFRUMsa0JBQUFBLElBQUksRUFBSkE7QUFGRixpQkFEYyxFQUtkbkIsWUFMYztBQUR1QyxlQUF4QixDQUpuQzs7QUFBQTtBQUFBO0FBSVVpQixjQUFBQSxjQUpWLHVCQUlVQSxjQUpWOztBQUFBLGtCQWNPQSxjQWRQO0FBQUE7QUFBQTtBQUFBOztBQUFBLGdEQWVXLElBZlg7O0FBQUE7QUFBQSxnRkFtQk9BLGNBbkJQO0FBb0JJUixnQkFBQUEsU0FBUyxFQUFFLElBQUlPLElBQUosQ0FBU0MsY0FBYyxDQUFDUixTQUF4QixDQXBCZjtBQXFCSUQsZ0JBQUFBLFNBQVMsRUFBRVMsY0FBYyxDQUFDVCxTQUFmLEdBQ1AsSUFBSVEsSUFBSixDQUFTQyxjQUFjLENBQUNULFNBQXhCLENBRE8sR0FFUDtBQXZCUjs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQSxLQXBCRjs7QUFBQTtBQUFBO0FBQUE7O0FBQUE7QUFBQTs7QUFBQTtBQUFBLEVBQXdDVCxVQUF4QztBQWdEQSxPQUFPLFNBQVNxQixxQkFBVCxDQUNMQyxHQURLLEVBRUxDLE9BRkssRUFHc0I7QUFDM0IsTUFBTUMsV0FBVyxHQUFHekIsVUFBVSx5QkFBaUN3QixPQUFqQyxDQUFWLENBQW9ERSxJQUFwRCxDQUNsQixFQURrQixDQUFwQjtBQUdBLE1BQU1DLFNBQVMsR0FBR0YsV0FBVyxDQUFDRyxJQUFaLEVBQWxCOztBQUNBLE1BQUlELFNBQVMsS0FBSyxFQUFsQixFQUFzQjtBQUNwQixXQUFPLElBQVA7QUFDRDs7QUFFRCxTQUFPLElBQUlmLGtCQUFKLENBQXVCZSxTQUF2QixFQUFrQ0osR0FBbEMsQ0FBUDtBQUNEIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBQbGFuS2luZCwgU2VjcmVjeUVudiwgVXNlciB9IGZyb20gXCIuLi8uLi9pbmRleC5qc1wiO1xuaW1wb3J0IHsgc3RvcmVCdWRkeSB9IGZyb20gXCIuLi8uLi91dGlscy9zdG9yZS1idWRkeS5qc1wiO1xuaW1wb3J0IHsgQmFzZUNsaWVudCB9IGZyb20gXCIuLi8uLi9CYXNlQ2xpZW50LmpzXCI7XG5cbi8qIFRPRE9cbi0gcXVlcnkgcG91ciBsaXN0ZXIgbGVzIHVzZXJzIGF2ZWMgcGFnaW5hdGlvbiBldCBpbnB1dCBvcHRpb25uZWwgXCJzZWFyY2hcIiBldCBib29sZWFuIHBvdXIgZmlsdHJlciBsZXMgYmFuc1xuLSBtdXRhdGlvbiBjaGFuZ2VyIGxlIHBsYW4gZCd1biB1c2VyIChzYW5zIHBheWVyIGR1IGNvdXApXG4tIHF1ZXJ5IHBvdXIgcmVudm95ZXIgbGVzIGFwcHMgZCd1biB1c2VyXG4tIHF1ZXJ5IHBvdXIgZG9ubmVyIGxlcyBsaW1pdGVzIGQndW4gdXNlclxuLSBxdWVyeSBwb3VyIGRvbm5lciBsZXMgcmVwb3J0cyBkJ3VuIHVzZXJcbi0gbXV0YXRpb24gcG91ciBiYW4gdW4gdXNlclxuLSBxdWVyeSBwb3VyIGdldCBsZXMgYmFucyBkJ3VuIHVzZXJcbi0gbXV0YXRpb24gcG91ciBkZWxldGUgdW4gdXNlciAoZMOpasOgIGV4aXN0YW50Pylcbi0gbXV0YXRpb24gY2hhbmdlciBsZSByb2xlIGR1IHVzZXIgKHVzZXIvYWRtaW4pXG4tIG11dGF0aW9uIHBvdXIgZMOpY28gdW5lIG91IGRlcyBzZXNzaW9ucyBtZXRhIG91IGFwcCBkJ3VuIHVzZXJcbi0gcXVlcnkgYWZmaWNoZXIgbGVzIHNlc3Npb25zIG1ldGEgb3UgYXBwIGQndW4gdXNlclxuLSBxdWVyeSBwb3VyIGFmZmljaGVyIGRlcyBpbmZvcyBzdXIgbGUgY2xvdWQgZCd1biB1c2VyXG4tIG11dGF0aW9uIHBvdXIgZGVsZXRlLCByZXN0b3JlLCBkZWxldGUgdHJhc2gsIGRhbnMgbGUgY2xvdWQgZCd1biB1c2VyXG4tIHF1ZXJ5IHBvdXIgYWZmaWNoZXIgbGVzIGluZm9zIHN1ciBsZXMgbWFpbHMgZCd1biB1c2VyXG4tIG11dGF0aW9uIHBvdXIgZGVsZXRlLCByZXN0b3JlLCBkZWxldGUgdHJhc2gsIGRhbnMgbGVzIG1haWxzIGQndW4gdXNlclxuLSBxdWVyeSBwb3VyIGFmZmljaGVyIGxlcyBsaW1pdGVzIG1heCBldCBhY3R1ZWxzIGQndW4gdXNlclxuLSBxdWVyeSBkZSBzdGF0cz9cbiovXG5cbmV4cG9ydCB0eXBlIFVzZXJBZG1pblBhbmVsID0gVXNlcjx7IHdpdGhQdWJsaWNLZXk6IGZhbHNlIH0+O1xuY29uc3QgdXNlclNlbGVjdG9yID0ge1xuICBpZDogdHJ1ZSxcbiAgZmlyc3RuYW1lOiB0cnVlLFxuICBsYXN0bmFtZTogdHJ1ZSxcbiAgbGFuZzogdHJ1ZSxcbiAgZW1haWw6IHRydWUsXG4gIHBob25lOiB0cnVlLFxuICByb2xlOiB0cnVlLFxuICBkZWxldGVkQXQ6IHRydWUsXG4gIGxhc3RMb2dpbjogdHJ1ZVxufSBhcyBjb25zdDtcblxuZXhwb3J0IGNsYXNzIEFkbWluU2VjcmVjeUNsaWVudCBleHRlbmRzIEJhc2VDbGllbnQge1xuICBhc3luYyB1c2VyTGlzdChcbiAgICBzZWFyY2g/OiBzdHJpbmcgfCBudWxsIHwgdW5kZWZpbmVkXG4gICk6IFByb21pc2U8VXNlckFkbWluUGFuZWxbXT4ge1xuICAgIGNvbnN0IHsgdXNlckxpc3QgfSA9IGF3YWl0IHRoaXMuY2xpZW50KFwicXVlcnlcIikoe1xuICAgICAgdXNlckxpc3Q6IFtcbiAgICAgICAge1xuICAgICAgICAgIHNlYXJjaFxuICAgICAgICB9LFxuICAgICAgICB1c2VyU2VsZWN0b3JcbiAgICAgIF1cbiAgICB9KTtcblxuICAgIHJldHVybiB1c2VyTGlzdC5tYXAodXNlciA9PiAoe1xuICAgICAgLi4udXNlcixcbiAgICAgIGxhc3RMb2dpbjogbmV3IERhdGUodXNlci5sYXN0TG9naW4pLFxuICAgICAgZGVsZXRlZEF0OiB1c2VyLmRlbGV0ZWRBdCA/IG5ldyBEYXRlKHVzZXIuZGVsZXRlZEF0KSA6IG51bGxcbiAgICB9KSk7XG4gIH1cblxuICBhc3luYyBjaGFuZ2VVc2VyUGxhbihcbiAgICB1c2VySWQ6IHN0cmluZyxcbiAgICBwbGFuOiBQbGFuS2luZFxuICApOiBQcm9taXNlPFVzZXJBZG1pblBhbmVsIHwgbnVsbD4ge1xuICAgIGNvbnN0IHsgY2hhbmdlVXNlclBsYW4gfSA9IGF3YWl0IHRoaXMuY2xpZW50KFwibXV0YXRpb25cIikoe1xuICAgICAgY2hhbmdlVXNlclBsYW46IFtcbiAgICAgICAge1xuICAgICAgICAgIHVzZXJJZCxcbiAgICAgICAgICBwbGFuXG4gICAgICAgIH0sXG4gICAgICAgIHVzZXJTZWxlY3RvclxuICAgICAgXVxuICAgIH0pO1xuXG4gICAgaWYgKCFjaGFuZ2VVc2VyUGxhbikge1xuICAgICAgcmV0dXJuIG51bGw7XG4gICAgfVxuXG4gICAgcmV0dXJuIHtcbiAgICAgIC4uLmNoYW5nZVVzZXJQbGFuLFxuICAgICAgbGFzdExvZ2luOiBuZXcgRGF0ZShjaGFuZ2VVc2VyUGxhbi5sYXN0TG9naW4pLFxuICAgICAgZGVsZXRlZEF0OiBjaGFuZ2VVc2VyUGxhbi5kZWxldGVkQXRcbiAgICAgICAgPyBuZXcgRGF0ZShjaGFuZ2VVc2VyUGxhbi5kZWxldGVkQXQpXG4gICAgICAgIDogbnVsbFxuICAgIH07XG4gIH1cbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGdldFNlY3JlY3lBZG1pbkNsaWVudChcbiAgZW52OiBTZWNyZWN5RW52LFxuICBzZXNzaW9uPzogYm9vbGVhbiB8IHVuZGVmaW5lZFxuKTogQWRtaW5TZWNyZWN5Q2xpZW50IHwgbnVsbCB7XG4gIGNvbnN0IHVzZXJTZXNzaW9uID0gc3RvcmVCdWRkeTxzdHJpbmc+KGBzZWNyZWN5LnVzZXJfc2Vzc2lvbmAsIHNlc3Npb24pLmluaXQoXG4gICAgXCJcIlxuICApO1xuICBjb25zdCB1YVNlc3Npb24gPSB1c2VyU2Vzc2lvbi5sb2FkKCk7XG4gIGlmICh1YVNlc3Npb24gPT09IFwiXCIpIHtcbiAgICByZXR1cm4gbnVsbDtcbiAgfVxuXG4gIHJldHVybiBuZXcgQWRtaW5TZWNyZWN5Q2xpZW50KHVhU2Vzc2lvbiwgZW52KTtcbn1cbiJdfQ==
|
|
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"]}
|
package/lib/client/helpers.d.ts
CHANGED
|
@@ -11,7 +11,7 @@ export declare type HashInfos = {
|
|
|
11
11
|
email: boolean;
|
|
12
12
|
};
|
|
13
13
|
};
|
|
14
|
-
export declare type SecrecyEnv = "dev" | "
|
|
14
|
+
export declare type SecrecyEnv = "dev" | "prod";
|
|
15
15
|
export declare type UseSecrecyParams = Omit<HashInfos, "appUrl"> & {
|
|
16
16
|
env: SecrecyEnv;
|
|
17
17
|
session?: boolean | undefined;
|
package/lib/client/helpers.js
CHANGED
|
@@ -71,8 +71,6 @@ export function login(_temp) {
|
|
|
71
71
|
|
|
72
72
|
if (env === "dev") {
|
|
73
73
|
envStr = "dev.";
|
|
74
|
-
} else if (env === "staging") {
|
|
75
|
-
envStr = "staging.";
|
|
76
74
|
}
|
|
77
75
|
|
|
78
76
|
var lang = document.documentElement.lang;
|
|
@@ -113,4 +111,4 @@ export function login(_temp) {
|
|
|
113
111
|
}
|
|
114
112
|
});
|
|
115
113
|
}
|
|
116
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/client/helpers.ts"],"names":["SecrecyClient","popup","getStorage","parseInfos","window","location","hash","substr","res","JSON","parse","atob","getSecrecyClient","env","session","storage","uaSession","userAppSession","load","uaKeys","userAppKeys","uaJwt","jwt","infos","save","keys","login","appCode","path","redirect","scopes","backPath","Promise","resolve","reject","appUrl","origin","includes","client","data","btoa","stringify","replaceAll","envStr","lang","document","documentElement","url","validate","href","err"],"mappings":"AAAA,SAASA,aAAT,QAA8B,YAA9B;AACA,SAASC,KAAT,QAAsB,kBAAtB;AAEA,SAASC,UAAT,QAA2B,cAA3B;AAEA,OAAO,SAASC,UAAT,GAA6C;AAClD,MAAI,CAACC,MAAM,CAACC,QAAP,CAAgBC,IAArB,EAA2B;AACzB,WAAO,IAAP;AACD;;AACD,MAAMA,IAAI,GAAGF,MAAM,CAACC,QAAP,CAAgBC,IAAhB,CAAqBC,MAArB,CAA4B,CAA5B,CAAb;;AACA,MAAI;AACF,QAAMC,GAAG,GAAGC,IAAI,CAACC,KAAL,CAAWC,IAAI,CAACL,IAAD,CAAf,CAAZ;AACAF,IAAAA,MAAM,CAACC,QAAP,CAAgBC,IAAhB,GAAuB,EAAvB,CAFE,CAGF;;AACA,WAAOE,GAAP;AACD,GALD,CAKE,gBAAM;AACN,WAAO,IAAP;AACD;AACF;AAsBD,OAAO,SAASI,gBAAT,CACLC,GADK,EAELC,OAFK,EAGiB;AACtB,MAAMC,OAAO,GAAGb,UAAU,CAACY,OAAD,CAA1B;AACA,MAAME,SAAS,GAAGD,OAAO,CAACE,cAAR,CAAuBC,IAAvB,EAAlB;AACA,MAAMC,MAAM,GAAGJ,OAAO,CAACK,WAAR,CAAoBF,IAApB,EAAf;AACA,MAAMG,KAAK,GAAGN,OAAO,CAACO,GAAR,CAAYJ,IAAZ,EAAd;;AACA,MAAI,CAACF,SAAD,IAAc,CAACG,MAAf,IAAyB,CAACE,KAA9B,EAAqC;AACnC,QAAME,KAAK,GAAGpB,UAAU,EAAxB;;AACA,QAAIoB,KAAJ,EAAW;AACTR,MAAAA,OAAO,CAACK,WAAR,CAAoBI,IAApB,CAAyBD,KAAK,CAACE,IAA/B;AACAV,MAAAA,OAAO,CAACE,cAAR,CAAuBO,IAAvB,CAA4BD,KAAK,CAACP,SAAlC;AACAD,MAAAA,OAAO,CAACO,GAAR,CAAYE,IAAZ,CAAiBD,KAAK,CAACD,GAAvB;AACA,aAAO,IAAItB,aAAJ,CAAkBuB,KAAK,CAACP,SAAxB,EAAmCO,KAAK,CAACE,IAAzC,EAA+CF,KAAK,CAACD,GAArD,EAA0DT,GAA1D,CAAP;AACD;;AACD,WAAO,IAAP;AACD;;AAED,SAAO,IAAIb,aAAJ,CAAkBgB,SAAlB,EAA6BG,MAA7B,EAAqCE,KAArC,EAA4CR,GAA5C,CAAP;AACD;AAED,OAAO,SAASa,KAAT,QAEc;AAAA,gCAD8C,EAC9C;AAAA,MADjBC,OACiB,QADjBA,OACiB;AAAA,MADRC,IACQ,QADRA,IACQ;AAAA,MADFC,QACE,QADFA,QACE;AAAA,MADQC,MACR,QADQA,MACR;AAAA,MADgBC,QAChB,QADgBA,QAChB;AAAA,MAD0BlB,GAC1B,QAD0BA,GAC1B;AAAA,MAD+BC,OAC/B,QAD+BA,OAC/B;;AACnB,SAAO,IAAIkB,OAAJ,CAAY,UAACC,OAAD,EAAUC,MAAV,EAAqB;AACtC,QAAMC,MAAM,GAAG/B,MAAM,CAACC,QAAP,CAAgB+B,MAA/B;;AACA,QAAIT,OAAO,IAAI,CAACQ,MAAM,CAACE,QAAP,CAAgB,WAAhB,CAAhB,EAA8C;AAC5C,aAAOH,MAAM,CAAC,uCAAD,CAAb;AACD;;AACD,QAAMI,MAAM,GAAG1B,gBAAgB,CAACC,GAAD,CAA/B;;AAEA,QAAI,CAACyB,MAAL,EAAa;AACX,UAAMf,KAAgB,GAAG;AACvBY,QAAAA,MAAM,EAANA,MADuB;AAEvBR,QAAAA,OAAO,EAAPA,OAFuB;AAGvBE,QAAAA,QAAQ,EAARA,QAHuB;AAIvBD,QAAAA,IAAI,EAAJA,IAJuB;AAKvBE,QAAAA,MAAM,EAANA,MALuB;AAMvBC,QAAAA,QAAQ,EAARA;AANuB,OAAzB;AAQA,UAAMQ,IAAI,GAAGC,IAAI,CAAC/B,IAAI,CAACgC,SAAL,CAAelB,KAAf,CAAD,CAAJ,CAA4BmB,UAA5B,CAAuC,GAAvC,EAA4C,EAA5C,CAAb;AAEA,UAAIC,MAAM,GAAG,EAAb;;AACA,UAAI9B,GAAG,KAAK,KAAZ,EAAmB;AACjB8B,QAAAA,MAAM,GAAG,MAAT;AACD,OAFD,MAEO,IAAI9B,GAAG,KAAK,SAAZ,EAAuB;AAC5B8B,QAAAA,MAAM,GAAG,UAAT;AACD;;AAED,UAAMC,IAAI,GAAGC,QAAQ,CAACC,eAAT,CAAyBF,IAAtC;AAEA,UAAMG,GAAG,qBAAmBJ,MAAnB,mBACPC,IAAI,SAAOA,IAAP,GAAgB,EADb,gBAECL,IAFV;;AAIA,UAAMS,QAAQ,GAAG,SAAXA,QAAW,CAACzB,KAAD,EAAiC;AAChD,YAAMR,OAAO,GAAGb,UAAU,CAACY,OAAD,CAA1B;AACAC,QAAAA,OAAO,CAACE,cAAR,CAAuBO,IAAvB,CAA4BD,KAAK,CAACP,SAAlC;AACAD,QAAAA,OAAO,CAACK,WAAR,CAAoBI,IAApB,CAAyBD,KAAK,CAACE,IAA/B;AACAV,QAAAA,OAAO,CAACO,GAAR,CAAYE,IAAZ,CAAiBD,KAAK,CAACD,GAAvB;AACA,eAAOW,OAAO,CACZ,IAAIjC,aAAJ,CACEuB,KAAK,CAACP,SADR,EAEEO,KAAK,CAACE,IAFR,EAGEF,KAAK,CAACD,GAHR,EAIET,GAJF,CADY,CAAd;AAQD,OAbD;;AAeA,UAAIgB,QAAJ,EAAc;AACZ,YAAMN,MAAK,GAAGpB,UAAU,EAAxB;;AACA,YAAIoB,MAAJ,EAAW;AACT,iBAAOyB,QAAQ,CAACzB,MAAD,CAAf;AACD,SAFD,MAEO;AACLnB,UAAAA,MAAM,CAACC,QAAP,CAAgB4C,IAAhB,GAAuBF,GAAvB;AACA,iBAAOd,OAAO,CAAC,IAAD,CAAd;AACD;AACF,OARD,MAQO;AACLhC,QAAAA,KAAK,CAAC8C,GAAD,EAAM,eAAN,EAAuB,EAAvB,EAA2B,UAACG,GAAD,EAAMX,IAAN,EAAe;AAC7C,cAAIW,GAAJ,EAAS;AACP,mBAAOhB,MAAM,CAACgB,GAAD,CAAb;AACD,WAFD,MAEO;AACL,gBAAM3B,OAAK,GAAGgB,IAAd;;AACA,gBAAIhB,OAAJ,EAAW;AACT,qBAAOyB,QAAQ,CAACzB,OAAD,CAAf;AACD;AACF;AACF,SATI,CAAL;AAUD;AACF,KA3DD,MA2DO;AACL,aAAOU,OAAO,CAACK,MAAD,CAAd;AACD;AACF,GArEM,CAAP;AAsED","sourcesContent":["import { SecrecyClient } from \"./index.js\";\nimport { popup } from \"../PopupTools.js\";\nimport type { SecrecyUserApp } from \"./types/index.js\";\nimport { getStorage } from \"./storage.js\";\n\nexport function parseInfos(): SecrecyUserApp | null {\n  if (!window.location.hash) {\n    return null;\n  }\n  const hash = window.location.hash.substr(1);\n  try {\n    const res = JSON.parse(atob(hash));\n    window.location.hash = \"\";\n    // TODO Add object content validation\n    return res;\n  } catch {\n    return null;\n  }\n}\n\nexport type HashInfos = {\n  appUrl: string;\n  backPath?: string;\n  appCode?: string | null | undefined;\n  path?: string | null | undefined;\n  redirect?: boolean;\n  scopes?: {\n    email: boolean;\n  };\n};\nexport type SecrecyEnv = \"dev\" | \"staging\" | \"prod\";\nexport type UseSecrecyParams = Omit<HashInfos, \"appUrl\"> & {\n  env: SecrecyEnv;\n  session?: boolean | undefined;\n};\n\nexport type Value<T extends UseSecrecyParams> = T extends { redirect: true }\n  ? SecrecyClient | null\n  : SecrecyClient;\n\nexport function getSecrecyClient(\n  env: SecrecyEnv,\n  session?: boolean | undefined\n): SecrecyClient | null {\n  const storage = getStorage(session);\n  const uaSession = storage.userAppSession.load();\n  const uaKeys = storage.userAppKeys.load();\n  const uaJwt = storage.jwt.load();\n  if (!uaSession || !uaKeys || !uaJwt) {\n    const infos = parseInfos();\n    if (infos) {\n      storage.userAppKeys.save(infos.keys);\n      storage.userAppSession.save(infos.uaSession);\n      storage.jwt.save(infos.jwt);\n      return new SecrecyClient(infos.uaSession, infos.keys, infos.jwt, env);\n    }\n    return null;\n  }\n\n  return new SecrecyClient(uaSession, uaKeys, uaJwt, env);\n}\n\nexport function login<T extends UseSecrecyParams>(\n  { appCode, path, redirect, scopes, backPath, env, session }: T = {} as T\n): Promise<Value<T>> {\n  return new Promise((resolve, reject) => {\n    const appUrl = window.location.origin;\n    if (appCode && !appUrl.includes(\"localhost\")) {\n      return reject(\"Can't use appCode if not in localhost\");\n    }\n    const client = getSecrecyClient(env);\n\n    if (!client) {\n      const infos: HashInfos = {\n        appUrl,\n        appCode,\n        redirect,\n        path,\n        scopes,\n        backPath\n      };\n      const data = btoa(JSON.stringify(infos)).replaceAll(\"=\", \"\");\n\n      let envStr = \"\";\n      if (env === \"dev\") {\n        envStr = \"dev.\";\n      } else if (env === \"staging\") {\n        envStr = \"staging.\";\n      }\n\n      const lang = document.documentElement.lang;\n\n      const url = `https://auth.${envStr}secrecy.me${\n        lang ? `/${lang}` : \"\"\n      }/login#${data}`;\n\n      const validate = (infos: SecrecyUserApp): void => {\n        const storage = getStorage(session);\n        storage.userAppSession.save(infos.uaSession);\n        storage.userAppKeys.save(infos.keys);\n        storage.jwt.save(infos.jwt);\n        return resolve(\n          new SecrecyClient(\n            infos.uaSession,\n            infos.keys,\n            infos.jwt,\n            env\n          ) as Value<T>\n        );\n      };\n\n      if (redirect) {\n        const infos = parseInfos();\n        if (infos) {\n          return validate(infos);\n        } else {\n          window.location.href = url;\n          return resolve(null as Value<T>);\n        }\n      } else {\n        popup(url, \"Secrecy Login\", {}, (err, data) => {\n          if (err) {\n            return reject(err);\n          } else {\n            const infos = data as SecrecyUserApp;\n            if (infos) {\n              return validate(infos);\n            }\n          }\n        });\n      }\n    } else {\n      return resolve(client as Value<T>);\n    }\n  });\n}\n"]}
|
|
114
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/client/helpers.ts"],"names":["SecrecyClient","popup","getStorage","parseInfos","window","location","hash","substr","res","JSON","parse","atob","getSecrecyClient","env","session","storage","uaSession","userAppSession","load","uaKeys","userAppKeys","uaJwt","jwt","infos","save","keys","login","appCode","path","redirect","scopes","backPath","Promise","resolve","reject","appUrl","origin","includes","client","data","btoa","stringify","replaceAll","envStr","lang","document","documentElement","url","validate","href","err"],"mappings":"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","sourcesContent":["import { SecrecyClient } from \"./index.js\";\nimport { popup } from \"../PopupTools.js\";\nimport type { SecrecyUserApp } from \"./types/index.js\";\nimport { getStorage } from \"./storage.js\";\n\nexport function parseInfos(): SecrecyUserApp | null {\n  if (!window.location.hash) {\n    return null;\n  }\n  const hash = window.location.hash.substr(1);\n  try {\n    const res = JSON.parse(atob(hash));\n    window.location.hash = \"\";\n    // TODO Add object content validation\n    return res;\n  } catch {\n    return null;\n  }\n}\n\nexport type HashInfos = {\n  appUrl: string;\n  backPath?: string;\n  appCode?: string | null | undefined;\n  path?: string | null | undefined;\n  redirect?: boolean;\n  scopes?: {\n    email: boolean;\n  };\n};\nexport type SecrecyEnv = \"dev\" | \"prod\";\nexport type UseSecrecyParams = Omit<HashInfos, \"appUrl\"> & {\n  env: SecrecyEnv;\n  session?: boolean | undefined;\n};\n\nexport type Value<T extends UseSecrecyParams> = T extends { redirect: true }\n  ? SecrecyClient | null\n  : SecrecyClient;\n\nexport function getSecrecyClient(\n  env: SecrecyEnv,\n  session?: boolean | undefined\n): SecrecyClient | null {\n  const storage = getStorage(session);\n  const uaSession = storage.userAppSession.load();\n  const uaKeys = storage.userAppKeys.load();\n  const uaJwt = storage.jwt.load();\n  if (!uaSession || !uaKeys || !uaJwt) {\n    const infos = parseInfos();\n    if (infos) {\n      storage.userAppKeys.save(infos.keys);\n      storage.userAppSession.save(infos.uaSession);\n      storage.jwt.save(infos.jwt);\n      return new SecrecyClient(infos.uaSession, infos.keys, infos.jwt, env);\n    }\n    return null;\n  }\n\n  return new SecrecyClient(uaSession, uaKeys, uaJwt, env);\n}\n\nexport function login<T extends UseSecrecyParams>(\n  { appCode, path, redirect, scopes, backPath, env, session }: T = {} as T\n): Promise<Value<T>> {\n  return new Promise((resolve, reject) => {\n    const appUrl = window.location.origin;\n    if (appCode && !appUrl.includes(\"localhost\")) {\n      return reject(\"Can't use appCode if not in localhost\");\n    }\n    const client = getSecrecyClient(env);\n\n    if (!client) {\n      const infos: HashInfos = {\n        appUrl,\n        appCode,\n        redirect,\n        path,\n        scopes,\n        backPath\n      };\n      const data = btoa(JSON.stringify(infos)).replaceAll(\"=\", \"\");\n\n      let envStr = \"\";\n      if (env === \"dev\") {\n        envStr = \"dev.\";\n      }\n\n      const lang = document.documentElement.lang;\n\n      const url = `https://auth.${envStr}secrecy.me${\n        lang ? `/${lang}` : \"\"\n      }/login#${data}`;\n\n      const validate = (infos: SecrecyUserApp): void => {\n        const storage = getStorage(session);\n        storage.userAppSession.save(infos.uaSession);\n        storage.userAppKeys.save(infos.keys);\n        storage.jwt.save(infos.jwt);\n        return resolve(\n          new SecrecyClient(\n            infos.uaSession,\n            infos.keys,\n            infos.jwt,\n            env\n          ) as Value<T>\n        );\n      };\n\n      if (redirect) {\n        const infos = parseInfos();\n        if (infos) {\n          return validate(infos);\n        } else {\n          window.location.href = url;\n          return resolve(null as Value<T>);\n        }\n      } else {\n        popup(url, \"Secrecy Login\", {}, (err, data) => {\n          if (err) {\n            return reject(err);\n          } else {\n            const infos = data as SecrecyUserApp;\n            if (infos) {\n              return validate(infos);\n            }\n          }\n        });\n      }\n    } else {\n      return resolve(client as Value<T>);\n    }\n  });\n}\n"]}
|
package/lib/client/index.d.ts
CHANGED
|
@@ -1,11 +1,13 @@
|
|
|
1
1
|
import type { MailType } from "./../zeus/index";
|
|
2
2
|
import type { DownloadProgress } from "ky";
|
|
3
|
+
import type { SuccessResponse } from "../BaseClient.js";
|
|
3
4
|
import { BaseClient } from "../BaseClient.js";
|
|
4
5
|
import type { Progress } from "../crypto/file.js";
|
|
5
6
|
import type { ReceivedMail, SentMail, Folder, VFileWithFolder, FolderFull, UserAppSettings, UserAppNotifications, File as SecrecyFile, WaitingReceivedMail, DraftMail, VFile, Mail } from "./types/index.js";
|
|
6
7
|
import type { KeyPair } from "../crypto/index.js";
|
|
7
8
|
import type { SecrecyEnv } from "./helpers.js";
|
|
8
9
|
import type { Rights } from "../zeus/index.js";
|
|
10
|
+
import type { ErrorAccessDenied, ErrorNotFound, ErrorBasic, ErrorNotExist, ErrorLimit } from "../error.js";
|
|
9
11
|
export declare type NewMail = {
|
|
10
12
|
body: string;
|
|
11
13
|
subject: string;
|
|
@@ -25,13 +27,13 @@ export declare class SecrecyClient extends BaseClient {
|
|
|
25
27
|
addFileToHistory({ fileId, vFileId }: {
|
|
26
28
|
fileId: string;
|
|
27
29
|
vFileId: string;
|
|
28
|
-
}): Promise<VFile>;
|
|
30
|
+
}): Promise<SuccessResponse<VFile> | ErrorAccessDenied | ErrorNotExist | null>;
|
|
29
31
|
uploadFile({ file, encryptProgress, uploadProgress, signal }: {
|
|
30
32
|
file: globalThis.File | Uint8Array;
|
|
31
33
|
encryptProgress?: ProgressCallback;
|
|
32
34
|
uploadProgress?: ProgressCallback;
|
|
33
35
|
signal?: AbortSignal;
|
|
34
|
-
}): Promise<string | null>;
|
|
36
|
+
}): Promise<SuccessResponse<string> | ErrorAccessDenied | ErrorLimit | ErrorNotFound | null>;
|
|
35
37
|
uploadFileInCloud({ file, name, folderId, encryptProgress, uploadProgress, signal }: {
|
|
36
38
|
file: globalThis.File | Uint8Array;
|
|
37
39
|
name: string;
|
|
@@ -39,132 +41,132 @@ export declare class SecrecyClient extends BaseClient {
|
|
|
39
41
|
encryptProgress?: ProgressCallback;
|
|
40
42
|
uploadProgress?: ProgressCallback;
|
|
41
43
|
signal?: AbortSignal;
|
|
42
|
-
}): Promise<VFileWithFolder>;
|
|
44
|
+
}): Promise<SuccessResponse<VFileWithFolder<SecrecyFile>> | ErrorAccessDenied | ErrorLimit | ErrorNotFound | ErrorBasic | ErrorNotExist | null>;
|
|
43
45
|
logout(sessionId?: string | null | undefined): Promise<void>;
|
|
44
46
|
createFolder({ name, parentFolderId }: {
|
|
45
47
|
name: string;
|
|
46
48
|
parentFolderId?: string | null;
|
|
47
|
-
}): Promise<FolderFull>;
|
|
49
|
+
}): Promise<SuccessResponse<FolderFull> | ErrorAccessDenied | ErrorNotExist | null>;
|
|
48
50
|
folder({ id, deleted }?: {
|
|
49
51
|
id?: string | null | undefined;
|
|
50
52
|
deleted?: boolean | null | undefined;
|
|
51
|
-
}): Promise<FolderFull | null>;
|
|
53
|
+
}): Promise<SuccessResponse<FolderFull> | ErrorAccessDenied | null>;
|
|
52
54
|
file({ id }: {
|
|
53
55
|
id: string;
|
|
54
|
-
}): Promise<SecrecyFile | null>;
|
|
56
|
+
}): Promise<SuccessResponse<SecrecyFile> | ErrorAccessDenied | null>;
|
|
55
57
|
vFile({ id }: {
|
|
56
58
|
id: string;
|
|
57
|
-
}): Promise<VFileWithFolder | null>;
|
|
59
|
+
}): Promise<SuccessResponse<VFileWithFolder> | ErrorAccessDenied | null>;
|
|
58
60
|
mail({ id }: {
|
|
59
61
|
id: string;
|
|
60
|
-
}): Promise<Mail | null>;
|
|
62
|
+
}): Promise<SuccessResponse<Mail> | ErrorAccessDenied | null>;
|
|
61
63
|
shareVFile({ vFileId, userId, rights }: {
|
|
62
64
|
vFileId: string;
|
|
63
65
|
userId: string;
|
|
64
66
|
rights: Rights;
|
|
65
|
-
}): Promise<boolean>;
|
|
66
|
-
sharedVFiles(): Promise<VFileWithFolder[]>;
|
|
67
|
-
vFilesSharedWithMe(): Promise<VFileWithFolder[]>;
|
|
68
|
-
deletedVFiles(): Promise<VFile[]>;
|
|
69
|
-
sharedFolders(): Promise<Folder[]>;
|
|
70
|
-
foldersSharedWithMe(): Promise<Folder[]>;
|
|
71
|
-
deletedFolders(): Promise<Folder[]>;
|
|
67
|
+
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorNotExist | ErrorNotFound | null>;
|
|
68
|
+
sharedVFiles(): Promise<SuccessResponse<VFileWithFolder[]> | ErrorAccessDenied | null>;
|
|
69
|
+
vFilesSharedWithMe(): Promise<SuccessResponse<VFileWithFolder[]> | ErrorAccessDenied | null>;
|
|
70
|
+
deletedVFiles(): Promise<SuccessResponse<VFile[]> | ErrorAccessDenied | null>;
|
|
71
|
+
sharedFolders(): Promise<SuccessResponse<Folder[]> | ErrorAccessDenied | null>;
|
|
72
|
+
foldersSharedWithMe(): Promise<SuccessResponse<Folder[]> | ErrorAccessDenied | null>;
|
|
73
|
+
deletedFolders(): Promise<SuccessResponse<Folder[]> | ErrorAccessDenied | null>;
|
|
72
74
|
deletedMails({ mailType }: {
|
|
73
75
|
mailType: MailType;
|
|
74
|
-
}): Promise<Mail[]>;
|
|
76
|
+
}): Promise<SuccessResponse<Mail[]> | ErrorAccessDenied | null>;
|
|
75
77
|
shareFolder({ folderId, userId, rights }: {
|
|
76
78
|
folderId: string;
|
|
77
79
|
userId: string;
|
|
78
80
|
rights: Rights;
|
|
79
|
-
}): Promise<boolean>;
|
|
81
|
+
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorNotFound | null>;
|
|
80
82
|
updateFolder({ folderId, name, isFavorite, deletedAt }: {
|
|
81
83
|
folderId: string;
|
|
82
84
|
name?: string | null | undefined;
|
|
83
85
|
isFavorite?: boolean | null | undefined;
|
|
84
86
|
deletedAt?: Date | null | undefined;
|
|
85
|
-
}): Promise<FolderFull>;
|
|
86
|
-
updateAppNotifications(notifications: Partial<UserAppNotifications>): Promise<UserAppNotifications | null>;
|
|
87
|
-
appNotifications(): Promise<UserAppNotifications | null>;
|
|
88
|
-
createMail(data: NewMail, customMessage?: string | null | undefined): Promise<boolean>;
|
|
89
|
-
waitingReceivedMails(): Promise<WaitingReceivedMail[]>;
|
|
90
|
-
updateDraftMail(draftId: string, { body, subject, files, recipientsIds, replyTo }: Partial<NewMail>): Promise<DraftMail | null>;
|
|
91
|
-
deleteDraftMail(draftId: string): Promise<boolean>;
|
|
87
|
+
}): Promise<SuccessResponse<FolderFull> | ErrorAccessDenied | ErrorNotExist | null>;
|
|
88
|
+
updateAppNotifications(notifications: Partial<UserAppNotifications>): Promise<SuccessResponse<UserAppNotifications> | ErrorAccessDenied | null>;
|
|
89
|
+
appNotifications(): Promise<SuccessResponse<UserAppNotifications> | ErrorAccessDenied | ErrorNotFound | null>;
|
|
90
|
+
createMail(data: NewMail, customMessage?: string | null | undefined): Promise<SuccessResponse<boolean> | ErrorBasic | ErrorAccessDenied | null>;
|
|
91
|
+
waitingReceivedMails(): Promise<SuccessResponse<WaitingReceivedMail[]> | ErrorNotFound | null>;
|
|
92
|
+
updateDraftMail(draftId: string, { body, subject, files, recipientsIds, replyTo }: Partial<NewMail>): Promise<SuccessResponse<DraftMail> | ErrorNotFound | ErrorAccessDenied | ErrorBasic | null>;
|
|
93
|
+
deleteDraftMail(draftId: string): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null>;
|
|
92
94
|
deleteVFileSharing({ vFileId, userId }: {
|
|
93
95
|
vFileId: string;
|
|
94
96
|
userId: string;
|
|
95
|
-
}): Promise<boolean>;
|
|
97
|
+
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorNotExist | null>;
|
|
96
98
|
deleteFolderSharing({ folderId, userId }: {
|
|
97
99
|
folderId: string;
|
|
98
100
|
userId: string;
|
|
99
|
-
}): Promise<boolean>;
|
|
101
|
+
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null>;
|
|
100
102
|
duplicateVFile({ vFileId, folderId, customName }: {
|
|
101
103
|
vFileId: string;
|
|
102
104
|
folderId?: string | null | undefined;
|
|
103
105
|
customName?: string | null | undefined;
|
|
104
|
-
}): Promise<boolean>;
|
|
106
|
+
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorNotFound | null>;
|
|
105
107
|
deleteFolderCloudTrash({ ids }: {
|
|
106
108
|
ids: Array<string>;
|
|
107
|
-
}): Promise<boolean>;
|
|
109
|
+
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null>;
|
|
108
110
|
deleteVFileCloudTrash({ ids }: {
|
|
109
111
|
ids: Array<string>;
|
|
110
|
-
}): Promise<boolean>;
|
|
112
|
+
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null>;
|
|
111
113
|
deleteMailTrash({ ids }: {
|
|
112
114
|
ids: Array<string>;
|
|
113
|
-
}): Promise<boolean>;
|
|
114
|
-
emptyMailTrash(): Promise<boolean>;
|
|
115
|
-
emptyCloudTrash(): Promise<boolean>;
|
|
115
|
+
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null>;
|
|
116
|
+
emptyMailTrash(): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null>;
|
|
117
|
+
emptyCloudTrash(): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null>;
|
|
116
118
|
recoverVFile({ vFileId }: {
|
|
117
119
|
vFileId: string;
|
|
118
|
-
}): Promise<boolean>;
|
|
120
|
+
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorNotExist | null>;
|
|
119
121
|
recoverFolder({ id }: {
|
|
120
122
|
id: string;
|
|
121
|
-
}): Promise<boolean>;
|
|
123
|
+
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorNotExist | null>;
|
|
122
124
|
recoverMail({ mailId }: {
|
|
123
125
|
mailId: string;
|
|
124
|
-
}): Promise<boolean>;
|
|
126
|
+
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorBasic | null>;
|
|
125
127
|
deleteFile({ fileId, vFileId }: {
|
|
126
128
|
fileId: string;
|
|
127
129
|
vFileId: string;
|
|
128
|
-
}): Promise<boolean>;
|
|
130
|
+
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorNotExist | null>;
|
|
129
131
|
deleteVFile({ fileId }: {
|
|
130
132
|
fileId: string;
|
|
131
|
-
}): Promise<boolean>;
|
|
133
|
+
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorNotExist | null>;
|
|
132
134
|
deleteMail({ mailId }: {
|
|
133
135
|
mailId: string;
|
|
134
|
-
}): Promise<boolean>;
|
|
136
|
+
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | null>;
|
|
135
137
|
saveInCloud({ fileId, name, folderId }: {
|
|
136
138
|
fileId: string;
|
|
137
139
|
name: string;
|
|
138
140
|
folderId?: string;
|
|
139
|
-
}): Promise<VFileWithFolder>;
|
|
140
|
-
sendDraftMail(draftId: string, customMessage?: string | null | undefined): Promise<boolean>;
|
|
141
|
-
sendWaitingEmails(): Promise<boolean>;
|
|
142
|
-
createDraftMail({ body, subject, files, recipientsIds, replyTo }: NewMail): Promise<DraftMail | null>;
|
|
141
|
+
}): Promise<SuccessResponse<VFileWithFolder> | ErrorAccessDenied | ErrorBasic | ErrorNotExist | null>;
|
|
142
|
+
sendDraftMail(draftId: string, customMessage?: string | null | undefined): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorBasic | null>;
|
|
143
|
+
sendWaitingEmails(): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorBasic | null>;
|
|
144
|
+
createDraftMail({ body, subject, files, recipientsIds, replyTo }: NewMail): Promise<SuccessResponse<DraftMail> | ErrorAccessDenied | ErrorBasic | null>;
|
|
143
145
|
fileContent({ fileId, onDownloadProgress, progressDecrypt, signal }: {
|
|
144
146
|
fileId: string;
|
|
145
147
|
onDownloadProgress?: (progress: DownloadProgress) => void;
|
|
146
148
|
progressDecrypt?: ProgressCallback;
|
|
147
149
|
signal?: AbortSignal;
|
|
148
|
-
}): Promise<Uint8Array>;
|
|
150
|
+
}): Promise<SuccessResponse<Uint8Array> | ErrorAccessDenied | ErrorBasic | null>;
|
|
149
151
|
updateFile({ fileId, filename, isFavorite, deletedAt }: {
|
|
150
152
|
fileId: string;
|
|
151
153
|
filename?: string | null | undefined;
|
|
152
154
|
isFavorite?: boolean | null | undefined;
|
|
153
155
|
deletedAt?: Date | null | undefined;
|
|
154
|
-
}): Promise<VFile>;
|
|
156
|
+
}): Promise<SuccessResponse<VFile> | ErrorAccessDenied | ErrorBasic | ErrorNotExist | null>;
|
|
155
157
|
readMail({ mailId }: {
|
|
156
158
|
mailId: string;
|
|
157
|
-
}): Promise<boolean>;
|
|
159
|
+
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorBasic | ErrorNotFound | null>;
|
|
158
160
|
unreadMail({ mailId }: {
|
|
159
161
|
mailId: string;
|
|
160
|
-
}): Promise<boolean>;
|
|
161
|
-
appSettings(): Promise<UserAppSettings | null>;
|
|
162
|
-
updateAppSettings(settings: Partial<UserAppSettings>): Promise<UserAppSettings>;
|
|
163
|
-
receivedMails(): Promise<ReceivedMail[]>;
|
|
164
|
-
sentMails(): Promise<SentMail[]>;
|
|
165
|
-
draftMails(): Promise<DraftMail[]>;
|
|
162
|
+
}): Promise<SuccessResponse<boolean> | ErrorAccessDenied | ErrorBasic | ErrorNotFound | null>;
|
|
163
|
+
appSettings(): Promise<SuccessResponse<UserAppSettings> | ErrorNotFound | null>;
|
|
164
|
+
updateAppSettings(settings: Partial<UserAppSettings>): Promise<SuccessResponse<UserAppSettings> | ErrorAccessDenied | ErrorBasic | null>;
|
|
165
|
+
receivedMails(): Promise<SuccessResponse<ReceivedMail[]> | ErrorNotFound | null>;
|
|
166
|
+
sentMails(): Promise<SuccessResponse<SentMail[]> | ErrorNotFound | null>;
|
|
167
|
+
draftMails(): Promise<SuccessResponse<DraftMail[]> | ErrorNotFound | null>;
|
|
166
168
|
private perFolder;
|
|
167
169
|
private perVFile;
|
|
168
|
-
unreadReceivedMailsCount(): Promise<number>;
|
|
170
|
+
unreadReceivedMailsCount(): Promise<SuccessResponse<number> | ErrorAccessDenied | null>;
|
|
169
171
|
private _eachUser;
|
|
170
172
|
}
|