@secrecy/lib 1.0.0-dev.9 → 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/{lib → dist}/BaseClient.d.ts +62 -69
- package/dist/BaseClient.js +1124 -0
- package/{lib → dist}/PopupTools.d.ts +1 -1
- package/dist/PopupTools.js +212 -0
- package/{lib → dist}/ZeusThunder.d.ts +0 -0
- package/dist/ZeusThunder.js +79 -0
- package/dist/cache.d.ts +6 -0
- package/dist/cache.js +4 -0
- package/dist/client/admin/index.d.ts +11 -0
- package/dist/client/admin/index.js +110 -0
- package/{lib → dist}/client/convert/file.d.ts +3 -3
- package/dist/client/convert/file.js +34 -0
- package/{lib → dist}/client/convert/mail.d.ts +0 -0
- package/dist/client/convert/mail.js +46 -0
- package/dist/client/convert/node.d.ts +9 -0
- package/dist/client/convert/node.js +101 -0
- package/{lib → dist}/client/helpers.d.ts +1 -1
- package/dist/client/helpers.js +114 -0
- package/dist/client/index.d.ts +164 -0
- package/dist/client/index.js +3206 -0
- package/{lib → dist}/client/storage.d.ts +0 -0
- package/dist/client/storage.js +12 -0
- package/dist/client/types/File.d.ts +14 -0
- package/dist/client/types/File.js +3 -0
- package/{lib → dist}/client/types/Inputs.d.ts +2 -7
- package/dist/client/types/Inputs.js +3 -0
- package/dist/client/types/Node.d.ts +49 -0
- package/dist/client/types/Node.js +3 -0
- package/{lib → dist}/client/types/UserAppNotifications.d.ts +1 -1
- package/dist/client/types/UserAppNotifications.js +3 -0
- package/{lib → dist}/client/types/UserAppSettings.d.ts +0 -1
- package/dist/client/types/UserAppSettings.js +3 -0
- package/{lib → dist}/client/types/index.d.ts +7 -13
- package/dist/client/types/index.js +8 -0
- package/dist/client/types/selectors.d.ts +476 -0
- package/dist/client/types/selectors.js +125 -0
- package/{lib → dist}/crypto/file.d.ts +0 -0
- package/dist/crypto/file.js +210 -0
- package/{lib → dist}/crypto/index.d.ts +0 -0
- package/dist/crypto/index.js +47 -0
- package/dist/error.d.ts +30 -0
- package/dist/error.js +3 -0
- package/{lib → dist}/index.d.ts +3 -3
- package/dist/index.js +10 -0
- package/{lib → dist}/minify/index.d.ts +0 -0
- package/dist/minify/index.js +28 -0
- package/{lib → dist}/minify/lz4.d.ts +0 -0
- package/dist/minify/lz4.js +627 -0
- package/{lib → dist}/sodium.d.ts +0 -0
- package/dist/sodium.js +6 -0
- package/{lib → dist}/utils/store-buddy.d.ts +0 -0
- package/dist/utils/store-buddy.js +65 -0
- package/{lib → dist}/utils/time.d.ts +0 -0
- package/dist/utils/time.js +14 -0
- package/{lib → dist/utils}/utils.d.ts +0 -0
- package/dist/utils/utils.js +57 -0
- package/{lib → dist}/worker/__mock__/sodium.worker.d.ts +0 -0
- package/dist/worker/__mock__/sodium.worker.js +49 -0
- package/{lib → dist}/worker/md5.d.ts +0 -0
- package/dist/worker/md5.js +25 -0
- package/{lib → dist}/worker/sodium.d.ts +0 -0
- package/dist/worker/sodium.js +120 -0
- package/{lib → dist}/worker/workerCodes.d.ts +0 -0
- package/dist/worker/workerCodes.js +3 -0
- package/{lib → dist}/zeus/const.d.ts +5 -0
- package/dist/zeus/const.js +1230 -0
- package/dist/zeus/index.d.ts +4069 -0
- package/dist/zeus/index.js +657 -0
- package/package.json +64 -57
- package/lib/BaseClient.js +0 -1332
- package/lib/PopupTools.js +0 -213
- package/lib/ZeusThunder.js +0 -115
- package/lib/cache.d.ts +0 -7
- package/lib/cache.js +0 -5
- package/lib/client/admin/index.d.ts +0 -10
- package/lib/client/admin/index.js +0 -145
- package/lib/client/convert/file.js +0 -39
- package/lib/client/convert/folder.d.ts +0 -8
- package/lib/client/convert/folder.js +0 -264
- package/lib/client/convert/mail.js +0 -46
- package/lib/client/convert/vFile.d.ts +0 -5
- package/lib/client/convert/vFile.js +0 -164
- package/lib/client/helpers.js +0 -116
- package/lib/client/index.d.ts +0 -169
- package/lib/client/index.js +0 -3803
- package/lib/client/storage.js +0 -12
- package/lib/client/types/File.d.ts +0 -21
- package/lib/client/types/File.js +0 -2
- package/lib/client/types/FilesOnUsersOnApplications.d.ts +0 -9
- package/lib/client/types/FilesOnUsersOnApplications.js +0 -2
- package/lib/client/types/Folder.d.ts +0 -68
- package/lib/client/types/Folder.js +0 -7
- package/lib/client/types/Inputs.js +0 -2
- package/lib/client/types/UserAppNotifications.js +0 -2
- package/lib/client/types/UserAppSettings.js +0 -2
- package/lib/client/types/VFile.d.ts +0 -62
- package/lib/client/types/VFile.js +0 -4
- package/lib/client/types/index.js +0 -9
- package/lib/client/types/queries.d.ts +0 -535
- package/lib/client/types/queries.js +0 -192
- package/lib/crypto/file.js +0 -291
- package/lib/crypto/index.js +0 -37
- package/lib/index.js +0 -41
- package/lib/minify/index.js +0 -28
- package/lib/minify/lz4.js +0 -633
- package/lib/sodium.js +0 -28
- package/lib/utils/store-buddy.js +0 -69
- package/lib/utils/time.js +0 -22
- package/lib/utils.js +0 -188
- package/lib/worker/__mock__/sodium.worker.js +0 -57
- package/lib/worker/md5.js +0 -43
- package/lib/worker/sodium.js +0 -155
- package/lib/worker/workerCodes.js +0 -3
- package/lib/zeus/const.js +0 -1671
- package/lib/zeus/index.d.ts +0 -33302
- package/lib/zeus/index.js +0 -558
|
@@ -13,5 +13,5 @@ declare type Options = {
|
|
|
13
13
|
declare type Callback = (err?: Error, data?: unknown) => void;
|
|
14
14
|
export declare function popup(url: string, name: string, options: Partial<Options>, callback: Callback): Window | null;
|
|
15
15
|
export declare function popupWithPost(url: string, postData: Record<string, string>, name: string, options: Partial<Options>, callback: Callback): Window | null;
|
|
16
|
-
export declare function popupResponse<T
|
|
16
|
+
export declare function popupResponse<T>(data: T): string;
|
|
17
17
|
export {};
|
|
@@ -0,0 +1,212 @@
|
|
|
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
|
+
/**
|
|
8
|
+
* TS Rewrite of https://github.com/enhancv/popup-tools
|
|
9
|
+
*/
|
|
10
|
+
const defaultOptions = {
|
|
11
|
+
width: 700,
|
|
12
|
+
height: 520,
|
|
13
|
+
menubar: "no",
|
|
14
|
+
resizable: "yes",
|
|
15
|
+
location: "yes",
|
|
16
|
+
scrollbars: "no",
|
|
17
|
+
centered: true
|
|
18
|
+
};
|
|
19
|
+
let popupCount = 1;
|
|
20
|
+
/**
|
|
21
|
+
* Return options converted to a string
|
|
22
|
+
*
|
|
23
|
+
* @param {Object} options
|
|
24
|
+
* @return {String}
|
|
25
|
+
*/
|
|
26
|
+
|
|
27
|
+
function optionsToString(options) {
|
|
28
|
+
return Object.entries(options).map(_ref => {
|
|
29
|
+
let [k, v] = _ref;
|
|
30
|
+
return k + "=" + v;
|
|
31
|
+
}).join(",");
|
|
32
|
+
}
|
|
33
|
+
/**
|
|
34
|
+
* Get a unique name on each call
|
|
35
|
+
* @return {String}
|
|
36
|
+
*/
|
|
37
|
+
|
|
38
|
+
|
|
39
|
+
function defaultPopupName() {
|
|
40
|
+
popupCount += 1;
|
|
41
|
+
return "Popup " + popupCount;
|
|
42
|
+
}
|
|
43
|
+
/**
|
|
44
|
+
* Convert "centered: true" key into concrete left and top arguments
|
|
45
|
+
* Both can be overwritten
|
|
46
|
+
*
|
|
47
|
+
* @param {Object} options
|
|
48
|
+
* @return {Object}
|
|
49
|
+
*/
|
|
50
|
+
|
|
51
|
+
|
|
52
|
+
function optionsResolveCentered(options) {
|
|
53
|
+
if (!options.width || !options.height) {
|
|
54
|
+
throw new Error("Should have width and height");
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
const result = _objectSpread({}, options);
|
|
58
|
+
|
|
59
|
+
const width = window.outerWidth - options.width;
|
|
60
|
+
const height = window.outerHeight - options.height;
|
|
61
|
+
|
|
62
|
+
if (options.centered) {
|
|
63
|
+
result.left = options.left || Math.round(window.screenX + width / 2);
|
|
64
|
+
result.top = options.top || Math.round(window.screenY + height / 2.5);
|
|
65
|
+
delete result.centered;
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
return result;
|
|
69
|
+
}
|
|
70
|
+
/**
|
|
71
|
+
* Create a form element, add hidden inputs for all the post data
|
|
72
|
+
* and post it into a newly opened popup
|
|
73
|
+
*
|
|
74
|
+
* @param {String} url
|
|
75
|
+
* @param {Object} postData
|
|
76
|
+
* @param {String} name
|
|
77
|
+
* @param {Object} options
|
|
78
|
+
* @return {Object}
|
|
79
|
+
*/
|
|
80
|
+
|
|
81
|
+
|
|
82
|
+
function openPopupWithPost(url, postData, name, options) {
|
|
83
|
+
var _win;
|
|
84
|
+
|
|
85
|
+
const form = document.createElement("form");
|
|
86
|
+
let win = null;
|
|
87
|
+
form.setAttribute("method", "post");
|
|
88
|
+
form.setAttribute("action", url);
|
|
89
|
+
form.setAttribute("target", name);
|
|
90
|
+
Object.keys(postData).forEach(function addFormItem(key) {
|
|
91
|
+
const input = document.createElement("input");
|
|
92
|
+
input.type = "hidden";
|
|
93
|
+
input.name = key;
|
|
94
|
+
input.value = postData[key];
|
|
95
|
+
form.appendChild(input);
|
|
96
|
+
});
|
|
97
|
+
document.body.appendChild(form);
|
|
98
|
+
win = window.open("/", name, options);
|
|
99
|
+
(_win = win) == null ? void 0 : _win.document.write("Loading...");
|
|
100
|
+
form.submit();
|
|
101
|
+
document.body.removeChild(form);
|
|
102
|
+
return win;
|
|
103
|
+
}
|
|
104
|
+
/**
|
|
105
|
+
* Open a popup using the first argument. Wait for it to close.
|
|
106
|
+
* Returns the window object
|
|
107
|
+
*
|
|
108
|
+
* @param {Function}
|
|
109
|
+
* @param {String}
|
|
110
|
+
* @param {String}
|
|
111
|
+
* @param {Object}
|
|
112
|
+
* @param {Function}
|
|
113
|
+
* @return {Object}
|
|
114
|
+
*/
|
|
115
|
+
|
|
116
|
+
|
|
117
|
+
function popupExecute(execute, url, name, options, callback) {
|
|
118
|
+
const popupName = name || defaultPopupName();
|
|
119
|
+
const popupOptions = optionsResolveCentered(Object.assign({}, defaultOptions, options));
|
|
120
|
+
|
|
121
|
+
const popupCallback = callback || function noop() {//
|
|
122
|
+
};
|
|
123
|
+
|
|
124
|
+
const optionsString = optionsToString(popupOptions);
|
|
125
|
+
const win = execute(url, popupName, optionsString);
|
|
126
|
+
let isMessageSent = false;
|
|
127
|
+
let interval;
|
|
128
|
+
|
|
129
|
+
function popupCallbackOnce(err, data) {
|
|
130
|
+
if (!isMessageSent) {
|
|
131
|
+
isMessageSent = true;
|
|
132
|
+
popupCallback(err, data);
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
|
|
136
|
+
function onMessage(message) {
|
|
137
|
+
const data = message ? message.data : undefined;
|
|
138
|
+
|
|
139
|
+
if (data) {
|
|
140
|
+
popupCallbackOnce(undefined, data);
|
|
141
|
+
window.removeEventListener("message", onMessage);
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
|
|
145
|
+
window.addEventListener("message", onMessage, false);
|
|
146
|
+
|
|
147
|
+
if (win) {
|
|
148
|
+
interval = window.setInterval(function closePopupCallback() {
|
|
149
|
+
if (win === null || win.closed) {
|
|
150
|
+
setTimeout(function delayWindowClosing() {
|
|
151
|
+
clearInterval(interval);
|
|
152
|
+
popupCallbackOnce(new Error("Popup closed"));
|
|
153
|
+
}, 500);
|
|
154
|
+
}
|
|
155
|
+
}, 100);
|
|
156
|
+
} else {
|
|
157
|
+
popupCallbackOnce(new Error("Popup blocked"));
|
|
158
|
+
}
|
|
159
|
+
|
|
160
|
+
return win;
|
|
161
|
+
}
|
|
162
|
+
/**
|
|
163
|
+
* Open a popup using the first argument.
|
|
164
|
+
* Wait for it to close and call the callback.
|
|
165
|
+
* Set the options string using the options object
|
|
166
|
+
* Returns the window object
|
|
167
|
+
*
|
|
168
|
+
* @param {String} url
|
|
169
|
+
* @param {String} name
|
|
170
|
+
* @param {Object} options
|
|
171
|
+
* @param {Function} callback
|
|
172
|
+
* @return {Object}
|
|
173
|
+
*/
|
|
174
|
+
|
|
175
|
+
|
|
176
|
+
export function popup(url, name, options, callback) {
|
|
177
|
+
return popupExecute(window.open, url, name, options, callback);
|
|
178
|
+
}
|
|
179
|
+
/**
|
|
180
|
+
* Open a popup using the first argument.
|
|
181
|
+
* Post the data into the open popup.
|
|
182
|
+
* Wait for it to close and call the callback.
|
|
183
|
+
* Set the options string using the options object
|
|
184
|
+
* Returns the window object
|
|
185
|
+
*
|
|
186
|
+
* @param {String} url
|
|
187
|
+
* @param {Object} postData
|
|
188
|
+
* @param {String} name
|
|
189
|
+
* @param {Object} options
|
|
190
|
+
* @param {Function} callback
|
|
191
|
+
* @return {Object}
|
|
192
|
+
*/
|
|
193
|
+
|
|
194
|
+
export function popupWithPost(url, postData, name, options, callback) {
|
|
195
|
+
function openWithPostData(popupUrl, popupName, optionsString) {
|
|
196
|
+
return openPopupWithPost(popupUrl, postData, popupName, optionsString);
|
|
197
|
+
}
|
|
198
|
+
|
|
199
|
+
return popupExecute(openWithPostData, url, name, options, callback);
|
|
200
|
+
}
|
|
201
|
+
/**
|
|
202
|
+
* Return html that when executed, will trigger the popup to callback with a response
|
|
203
|
+
*
|
|
204
|
+
* @param {Object}
|
|
205
|
+
* @return {String}
|
|
206
|
+
*/
|
|
207
|
+
|
|
208
|
+
export function popupResponse(data) {
|
|
209
|
+
const jsonData = JSON.stringify(data);
|
|
210
|
+
return "<script>window.opener.postMessage(" + jsonData + ", \"*\");setTimeout(function() { window.close(); }, 50);</script>";
|
|
211
|
+
}
|
|
212
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["defaultOptions","width","height","menubar","resizable","location","scrollbars","centered","popupCount","optionsToString","options","Object","entries","map","k","v","join","defaultPopupName","optionsResolveCentered","Error","result","window","outerWidth","outerHeight","left","Math","round","screenX","top","screenY","openPopupWithPost","url","postData","name","form","document","createElement","win","setAttribute","keys","forEach","addFormItem","key","input","type","value","appendChild","body","open","write","submit","removeChild","popupExecute","execute","callback","popupName","popupOptions","assign","popupCallback","noop","optionsString","isMessageSent","interval","popupCallbackOnce","err","data","onMessage","message","undefined","removeEventListener","addEventListener","setInterval","closePopupCallback","closed","setTimeout","delayWindowClosing","clearInterval","popup","popupWithPost","openWithPostData","popupUrl","popupResponse","jsonData","JSON","stringify"],"sources":["../src/PopupTools.ts"],"sourcesContent":["/**\n * TS Rewrite of https://github.com/enhancv/popup-tools\n */\n\ntype YesNo = \"yes\" | \"no\";\ntype Options = {\n  width?: number;\n  height?: number;\n  menubar: YesNo;\n  resizable: YesNo;\n  location: YesNo;\n  scrollbars: YesNo;\n  centered?: boolean;\n  left?: number;\n  top?: number;\n};\n\nconst defaultOptions: Options = {\n  width: 700,\n  height: 520,\n  menubar: \"no\",\n  resizable: \"yes\",\n  location: \"yes\",\n  scrollbars: \"no\",\n  centered: true\n};\n\ntype Callback = (err?: Error, data?: unknown) => void;\n\ntype WindowOpen = (\n  popupUrl: string,\n  popupName: string,\n  optionsString: string\n) => Window | null;\n\nlet popupCount = 1;\n\n/**\n * Return options converted to a string\n *\n * @param  {Object} options\n * @return {String}\n */\nfunction optionsToString<T extends Options>(options: T): string {\n  return Object.entries(options)\n    .map(([k, v]) => `${k}=${v}`)\n    .join(\",\");\n}\n\n/**\n * Get a unique name on each call\n * @return {String}\n */\nfunction defaultPopupName(): string {\n  popupCount += 1;\n  return `Popup ${popupCount}`;\n}\n\n/**\n * Convert \"centered: true\" key into concrete left and top arguments\n * Both can be overwritten\n *\n * @param  {Object} options\n * @return {Object}\n */\nfunction optionsResolveCentered(options: Options): Options {\n  if (!options.width || !options.height) {\n    throw new Error(\"Should have width and height\");\n  }\n  const result = { ...options };\n  const width = window.outerWidth - options.width;\n  const height = window.outerHeight - options.height;\n\n  if (options.centered) {\n    result.left = options.left || Math.round(window.screenX + width / 2);\n    result.top = options.top || Math.round(window.screenY + height / 2.5);\n    delete result.centered;\n  }\n  return result;\n}\n\n/**\n * Create a form element, add hidden inputs for all the post data\n * and post it into a newly opened popup\n *\n * @param  {String} url\n * @param  {Object} postData\n * @param  {String} name\n * @param  {Object} options\n * @return {Object}\n */\nfunction openPopupWithPost(\n  url: string,\n  postData: Record<string, string>,\n  name: string,\n  options: string\n): Window | null {\n  const form = document.createElement(\"form\");\n  let win: Window | null = null;\n\n  form.setAttribute(\"method\", \"post\");\n  form.setAttribute(\"action\", url);\n  form.setAttribute(\"target\", name);\n\n  Object.keys(postData).forEach(function addFormItem(key) {\n    const input = document.createElement(\"input\");\n    input.type = \"hidden\";\n    input.name = key;\n    input.value = postData[key];\n    form.appendChild(input);\n  });\n\n  document.body.appendChild(form);\n\n  win = window.open(\"/\", name, options);\n  win?.document.write(\"Loading...\");\n\n  form.submit();\n  document.body.removeChild(form);\n\n  return win;\n}\n\n/**\n * Open a popup using the first argument. Wait for it to close.\n * Returns the window object\n *\n * @param  {Function}\n * @param  {String}\n * @param  {String}\n * @param  {Object}\n * @param  {Function}\n * @return {Object}\n */\nfunction popupExecute(\n  execute: WindowOpen,\n  url: string,\n  name: string,\n  options: Partial<Options>,\n  callback: Callback\n): Window | null {\n  const popupName = name || defaultPopupName();\n  const popupOptions = optionsResolveCentered(\n    Object.assign({}, defaultOptions, options)\n  );\n  const popupCallback =\n    callback ||\n    function noop(): void {\n      //\n    };\n  const optionsString = optionsToString(popupOptions);\n  const win = execute(url, popupName, optionsString);\n  let isMessageSent = false;\n  let interval: number;\n\n  function popupCallbackOnce(err?: Error, data?: unknown): void {\n    if (!isMessageSent) {\n      isMessageSent = true;\n      popupCallback(err, data);\n    }\n  }\n\n  function onMessage(message?: MessageEvent): void {\n    const data = message ? message.data : undefined;\n\n    if (data) {\n      popupCallbackOnce(undefined, data);\n      window.removeEventListener(\"message\", onMessage);\n    }\n  }\n\n  window.addEventListener(\"message\", onMessage, false);\n\n  if (win) {\n    interval = window.setInterval(function closePopupCallback() {\n      if (win === null || win.closed) {\n        setTimeout(function delayWindowClosing() {\n          clearInterval(interval);\n          popupCallbackOnce(new Error(\"Popup closed\"));\n        }, 500);\n      }\n    }, 100);\n  } else {\n    popupCallbackOnce(new Error(\"Popup blocked\"));\n  }\n\n  return win;\n}\n\n/**\n * Open a popup using the first argument.\n * Wait for it to close and call the callback.\n * Set the options string using the options object\n * Returns the window object\n *\n * @param  {String} url\n * @param  {String} name\n * @param  {Object} options\n * @param  {Function} callback\n * @return {Object}\n */\nexport function popup(\n  url: string,\n  name: string,\n  options: Partial<Options>,\n  callback: Callback\n): Window | null {\n  return popupExecute(window.open, url, name, options, callback);\n}\n\n/**\n * Open a popup using the first argument.\n * Post the data into the open popup.\n * Wait for it to close and call the callback.\n * Set the options string using the options object\n * Returns the window object\n *\n * @param  {String} url\n * @param  {Object} postData\n * @param  {String} name\n * @param  {Object} options\n * @param  {Function} callback\n * @return {Object}\n */\nexport function popupWithPost(\n  url: string,\n  postData: Record<string, string>,\n  name: string,\n  options: Partial<Options>,\n  callback: Callback\n): Window | null {\n  function openWithPostData(\n    popupUrl: string,\n    popupName: string,\n    optionsString: string\n  ): Window | null {\n    return openPopupWithPost(popupUrl, postData, popupName, optionsString);\n  }\n\n  return popupExecute(openWithPostData, url, name, options, callback);\n}\n\n/**\n * Return html that when executed, will trigger the popup to callback with a response\n *\n * @param  {Object}\n * @return {String}\n */\nexport function popupResponse<T>(data: T): string {\n  const jsonData = JSON.stringify(data);\n\n  return `<script>window.opener.postMessage(${jsonData}, \"*\");setTimeout(function() { window.close(); }, 50);</script>`;\n}\n"],"mappings":"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"}
|
|
File without changes
|
|
@@ -0,0 +1,79 @@
|
|
|
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 { GraphQLError, Thunder } from "./zeus/index.js";
|
|
8
|
+
|
|
9
|
+
const handleFetchResponse = response => {
|
|
10
|
+
if (!response.ok) {
|
|
11
|
+
return new Promise((_, reject) => {
|
|
12
|
+
response.text().then(text => {
|
|
13
|
+
try {
|
|
14
|
+
reject(JSON.parse(text));
|
|
15
|
+
} catch (err) {
|
|
16
|
+
reject(text);
|
|
17
|
+
}
|
|
18
|
+
}).catch(reject);
|
|
19
|
+
});
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
return response.json();
|
|
23
|
+
};
|
|
24
|
+
|
|
25
|
+
const apiFetch = (options, session) => async function (query, variables) {
|
|
26
|
+
if (variables === void 0) {
|
|
27
|
+
variables = {};
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
const fetchFunction = fetch;
|
|
31
|
+
let queryString = query;
|
|
32
|
+
const fetchOptions = options[1] || {};
|
|
33
|
+
|
|
34
|
+
if (fetchOptions.method && fetchOptions.method === "GET") {
|
|
35
|
+
queryString = encodeURIComponent(query);
|
|
36
|
+
return fetchFunction(options[0] + "?query=" + queryString, fetchOptions).then(handleFetchResponse).then(response => {
|
|
37
|
+
if (response.errors) {
|
|
38
|
+
throw new GraphQLError(response);
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
return response.data;
|
|
42
|
+
});
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
const headers = {
|
|
46
|
+
"content-type": "application/json",
|
|
47
|
+
"accept-language": navigator.language
|
|
48
|
+
};
|
|
49
|
+
|
|
50
|
+
if (session) {
|
|
51
|
+
headers["secrecy-session"] = session;
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
const controller = new AbortController();
|
|
55
|
+
const id = setTimeout(() => controller.abort(), 20000);
|
|
56
|
+
const res = await fetchFunction("" + options[0], _objectSpread({
|
|
57
|
+
body: JSON.stringify({
|
|
58
|
+
query: queryString,
|
|
59
|
+
variables
|
|
60
|
+
}),
|
|
61
|
+
method: "POST",
|
|
62
|
+
headers,
|
|
63
|
+
signal: controller.signal
|
|
64
|
+
}, fetchOptions)).then(handleFetchResponse).then(response => {
|
|
65
|
+
if (response.errors) {
|
|
66
|
+
throw new GraphQLError(response);
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
return response.data;
|
|
70
|
+
});
|
|
71
|
+
clearTimeout(id);
|
|
72
|
+
return res;
|
|
73
|
+
};
|
|
74
|
+
|
|
75
|
+
export const createThunder = (url, session) => Thunder(apiFetch([url, {
|
|
76
|
+
mode: "cors",
|
|
77
|
+
credentials: "same-origin"
|
|
78
|
+
}], session));
|
|
79
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJHcmFwaFFMRXJyb3IiLCJUaHVuZGVyIiwiaGFuZGxlRmV0Y2hSZXNwb25zZSIsInJlc3BvbnNlIiwib2siLCJQcm9taXNlIiwiXyIsInJlamVjdCIsInRleHQiLCJ0aGVuIiwiSlNPTiIsInBhcnNlIiwiZXJyIiwiY2F0Y2giLCJqc29uIiwiYXBpRmV0Y2giLCJvcHRpb25zIiwic2Vzc2lvbiIsInF1ZXJ5IiwidmFyaWFibGVzIiwiZmV0Y2hGdW5jdGlvbiIsImZldGNoIiwicXVlcnlTdHJpbmciLCJmZXRjaE9wdGlvbnMiLCJtZXRob2QiLCJlbmNvZGVVUklDb21wb25lbnQiLCJlcnJvcnMiLCJkYXRhIiwiaGVhZGVycyIsIm5hdmlnYXRvciIsImxhbmd1YWdlIiwiY29udHJvbGxlciIsIkFib3J0Q29udHJvbGxlciIsImlkIiwic2V0VGltZW91dCIsImFib3J0IiwicmVzIiwiYm9keSIsInN0cmluZ2lmeSIsInNpZ25hbCIsImNsZWFyVGltZW91dCIsImNyZWF0ZVRodW5kZXIiLCJ1cmwiLCJtb2RlIiwiY3JlZGVudGlhbHMiXSwic291cmNlcyI6WyIuLi9zcmMvWmV1c1RodW5kZXIudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBmZXRjaE9wdGlvbnMsIEdyYXBoUUxSZXNwb25zZSB9IGZyb20gXCIuL3pldXMvaW5kZXguanNcIjtcbmltcG9ydCB7IEdyYXBoUUxFcnJvciwgVGh1bmRlciB9IGZyb20gXCIuL3pldXMvaW5kZXguanNcIjtcblxuY29uc3QgaGFuZGxlRmV0Y2hSZXNwb25zZSA9IChcbiAgcmVzcG9uc2U6IFBhcmFtZXRlcnM8XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9iYW4tdHlwZXNcbiAgICBFeHRyYWN0PFBhcmFtZXRlcnM8UmV0dXJuVHlwZTx0eXBlb2YgZmV0Y2g+W1widGhlblwiXT5bMF0sIEZ1bmN0aW9uPlxuICA+WzBdXG4pOiBQcm9taXNlPEdyYXBoUUxSZXNwb25zZT4gPT4ge1xuICBpZiAoIXJlc3BvbnNlLm9rKSB7XG4gICAgcmV0dXJuIG5ldyBQcm9taXNlKChfLCByZWplY3QpID0+IHtcbiAgICAgIHJlc3BvbnNlXG4gICAgICAgIC50ZXh0KClcbiAgICAgICAgLnRoZW4odGV4dCA9PiB7XG4gICAgICAgICAgdHJ5IHtcbiAgICAgICAgICAgIHJlamVjdChKU09OLnBhcnNlKHRleHQpKTtcbiAgICAgICAgICB9IGNhdGNoIChlcnIpIHtcbiAgICAgICAgICAgIHJlamVjdCh0ZXh0KTtcbiAgICAgICAgICB9XG4gICAgICAgIH0pXG4gICAgICAgIC5jYXRjaChyZWplY3QpO1xuICAgIH0pO1xuICB9XG4gIHJldHVybiByZXNwb25zZS5qc29uKCkgYXMgUHJvbWlzZTxHcmFwaFFMUmVzcG9uc2U+O1xufTtcblxuY29uc3QgYXBpRmV0Y2ggPVxuICAob3B0aW9uczogZmV0Y2hPcHRpb25zLCBzZXNzaW9uPzogc3RyaW5nIHwgbnVsbCB8IHVuZGVmaW5lZCkgPT5cbiAgYXN5bmMgKFxuICAgIHF1ZXJ5OiBzdHJpbmcsXG4gICAgdmFyaWFibGVzOiBSZWNvcmQ8c3RyaW5nLCBhbnk+ID0ge31cbiAgKTogUHJvbWlzZTxSZWNvcmQ8c3RyaW5nLCBhbnk+IHwgdW5kZWZpbmVkPiA9PiB7XG4gICAgY29uc3QgZmV0Y2hGdW5jdGlvbiA9IGZldGNoO1xuICAgIGxldCBxdWVyeVN0cmluZyA9IHF1ZXJ5O1xuICAgIGNvbnN0IGZldGNoT3B0aW9ucyA9IG9wdGlvbnNbMV0gfHwge307XG4gICAgaWYgKGZldGNoT3B0aW9ucy5tZXRob2QgJiYgZmV0Y2hPcHRpb25zLm1ldGhvZCA9PT0gXCJHRVRcIikge1xuICAgICAgcXVlcnlTdHJpbmcgPSBlbmNvZGVVUklDb21wb25lbnQocXVlcnkpO1xuICAgICAgcmV0dXJuIGZldGNoRnVuY3Rpb24oYCR7b3B0aW9uc1swXX0/cXVlcnk9JHtxdWVyeVN0cmluZ31gLCBmZXRjaE9wdGlvbnMpXG4gICAgICAgIC50aGVuKGhhbmRsZUZldGNoUmVzcG9uc2UpXG4gICAgICAgIC50aGVuKChyZXNwb25zZTogR3JhcGhRTFJlc3BvbnNlKSA9PiB7XG4gICAgICAgICAgaWYgKHJlc3BvbnNlLmVycm9ycykge1xuICAgICAgICAgICAgdGhyb3cgbmV3IEdyYXBoUUxFcnJvcihyZXNwb25zZSk7XG4gICAgICAgICAgfVxuICAgICAgICAgIHJldHVybiByZXNwb25zZS5kYXRhO1xuICAgICAgICB9KTtcbiAgICB9XG4gICAgY29uc3QgaGVhZGVyczogUmVjb3JkPHN0cmluZywgc3RyaW5nPiA9IHtcbiAgICAgIFwiY29udGVudC10eXBlXCI6IFwiYXBwbGljYXRpb24vanNvblwiLFxuICAgICAgXCJhY2NlcHQtbGFuZ3VhZ2VcIjogbmF2aWdhdG9yLmxhbmd1YWdlXG4gICAgfTtcblxuICAgIGlmIChzZXNzaW9uKSB7XG4gICAgICBoZWFkZXJzW1wic2VjcmVjeS1zZXNzaW9uXCJdID0gc2Vzc2lvbjtcbiAgICB9XG4gICAgY29uc3QgY29udHJvbGxlciA9IG5ldyBBYm9ydENvbnRyb2xsZXIoKTtcbiAgICBjb25zdCBpZCA9IHNldFRpbWVvdXQoKCkgPT4gY29udHJvbGxlci5hYm9ydCgpLCAyMDAwMCk7XG4gICAgY29uc3QgcmVzID0gYXdhaXQgZmV0Y2hGdW5jdGlvbihgJHtvcHRpb25zWzBdfWAsIHtcbiAgICAgIGJvZHk6IEpTT04uc3RyaW5naWZ5KHsgcXVlcnk6IHF1ZXJ5U3RyaW5nLCB2YXJpYWJsZXMgfSksXG4gICAgICBtZXRob2Q6IFwiUE9TVFwiLFxuICAgICAgaGVhZGVycyxcbiAgICAgIHNpZ25hbDogY29udHJvbGxlci5zaWduYWwsXG4gICAgICAuLi5mZXRjaE9wdGlvbnNcbiAgICB9KVxuICAgICAgLnRoZW4oaGFuZGxlRmV0Y2hSZXNwb25zZSlcbiAgICAgIC50aGVuKChyZXNwb25zZTogR3JhcGhRTFJlc3BvbnNlKSA9PiB7XG4gICAgICAgIGlmIChyZXNwb25zZS5lcnJvcnMpIHtcbiAgICAgICAgICB0aHJvdyBuZXcgR3JhcGhRTEVycm9yKHJlc3BvbnNlKTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gcmVzcG9uc2UuZGF0YTtcbiAgICAgIH0pO1xuICAgIGNsZWFyVGltZW91dChpZCk7XG4gICAgcmV0dXJuIHJlcztcbiAgfTtcblxuZXhwb3J0IGNvbnN0IGNyZWF0ZVRodW5kZXIgPSAoXG4gIHVybDogc3RyaW5nLFxuICBzZXNzaW9uPzogc3RyaW5nIHwgbnVsbCB8IHVuZGVmaW5lZFxuKTogUmV0dXJuVHlwZTx0eXBlb2YgVGh1bmRlcj4gPT5cbiAgVGh1bmRlcihcbiAgICBhcGlGZXRjaChcbiAgICAgIFtcbiAgICAgICAgdXJsLFxuICAgICAgICB7XG4gICAgICAgICAgbW9kZTogXCJjb3JzXCIsXG4gICAgICAgICAgY3JlZGVudGlhbHM6IFwic2FtZS1vcmlnaW5cIlxuICAgICAgICB9XG4gICAgICBdLFxuICAgICAgc2Vzc2lvblxuICAgIClcbiAgKTtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQ0EsU0FBU0EsWUFBVCxFQUF1QkMsT0FBdkIsUUFBc0MsaUJBQXRDOztBQUVBLE1BQU1DLG1CQUFtQixHQUN2QkMsUUFEMEIsSUFLRztFQUM3QixJQUFJLENBQUNBLFFBQVEsQ0FBQ0MsRUFBZCxFQUFrQjtJQUNoQixPQUFPLElBQUlDLE9BQUosQ0FBWSxDQUFDQyxDQUFELEVBQUlDLE1BQUosS0FBZTtNQUNoQ0osUUFBUSxDQUNMSyxJQURILEdBRUdDLElBRkgsQ0FFUUQsSUFBSSxJQUFJO1FBQ1osSUFBSTtVQUNGRCxNQUFNLENBQUNHLElBQUksQ0FBQ0MsS0FBTCxDQUFXSCxJQUFYLENBQUQsQ0FBTjtRQUNELENBRkQsQ0FFRSxPQUFPSSxHQUFQLEVBQVk7VUFDWkwsTUFBTSxDQUFDQyxJQUFELENBQU47UUFDRDtNQUNGLENBUkgsRUFTR0ssS0FUSCxDQVNTTixNQVRUO0lBVUQsQ0FYTSxDQUFQO0VBWUQ7O0VBQ0QsT0FBT0osUUFBUSxDQUFDVyxJQUFULEVBQVA7QUFDRCxDQXJCRDs7QUF1QkEsTUFBTUMsUUFBUSxHQUNaLENBQUNDLE9BQUQsRUFBd0JDLE9BQXhCLEtBQ0EsZ0JBQ0VDLEtBREYsRUFFRUMsU0FGRixFQUcrQztFQUFBLElBRDdDQSxTQUM2QztJQUQ3Q0EsU0FDNkMsR0FEWixFQUNZO0VBQUE7O0VBQzdDLE1BQU1DLGFBQWEsR0FBR0MsS0FBdEI7RUFDQSxJQUFJQyxXQUFXLEdBQUdKLEtBQWxCO0VBQ0EsTUFBTUssWUFBWSxHQUFHUCxPQUFPLENBQUMsQ0FBRCxDQUFQLElBQWMsRUFBbkM7O0VBQ0EsSUFBSU8sWUFBWSxDQUFDQyxNQUFiLElBQXVCRCxZQUFZLENBQUNDLE1BQWIsS0FBd0IsS0FBbkQsRUFBMEQ7SUFDeERGLFdBQVcsR0FBR0csa0JBQWtCLENBQUNQLEtBQUQsQ0FBaEM7SUFDQSxPQUFPRSxhQUFhLENBQUlKLE9BQU8sQ0FBQyxDQUFELENBQVgsZUFBd0JNLFdBQXhCLEVBQXVDQyxZQUF2QyxDQUFiLENBQ0pkLElBREksQ0FDQ1AsbUJBREQsRUFFSk8sSUFGSSxDQUVFTixRQUFELElBQStCO01BQ25DLElBQUlBLFFBQVEsQ0FBQ3VCLE1BQWIsRUFBcUI7UUFDbkIsTUFBTSxJQUFJMUIsWUFBSixDQUFpQkcsUUFBakIsQ0FBTjtNQUNEOztNQUNELE9BQU9BLFFBQVEsQ0FBQ3dCLElBQWhCO0lBQ0QsQ0FQSSxDQUFQO0VBUUQ7O0VBQ0QsTUFBTUMsT0FBK0IsR0FBRztJQUN0QyxnQkFBZ0Isa0JBRHNCO0lBRXRDLG1CQUFtQkMsU0FBUyxDQUFDQztFQUZTLENBQXhDOztFQUtBLElBQUliLE9BQUosRUFBYTtJQUNYVyxPQUFPLENBQUMsaUJBQUQsQ0FBUCxHQUE2QlgsT0FBN0I7RUFDRDs7RUFDRCxNQUFNYyxVQUFVLEdBQUcsSUFBSUMsZUFBSixFQUFuQjtFQUNBLE1BQU1DLEVBQUUsR0FBR0MsVUFBVSxDQUFDLE1BQU1ILFVBQVUsQ0FBQ0ksS0FBWCxFQUFQLEVBQTJCLEtBQTNCLENBQXJCO0VBQ0EsTUFBTUMsR0FBRyxHQUFHLE1BQU1oQixhQUFhLE1BQUlKLE9BQU8sQ0FBQyxDQUFELENBQVg7SUFDN0JxQixJQUFJLEVBQUUzQixJQUFJLENBQUM0QixTQUFMLENBQWU7TUFBRXBCLEtBQUssRUFBRUksV0FBVDtNQUFzQkg7SUFBdEIsQ0FBZixDQUR1QjtJQUU3QkssTUFBTSxFQUFFLE1BRnFCO0lBRzdCSSxPQUg2QjtJQUk3QlcsTUFBTSxFQUFFUixVQUFVLENBQUNRO0VBSlUsR0FLMUJoQixZQUwwQixFQUFiLENBT2ZkLElBUGUsQ0FPVlAsbUJBUFUsRUFRZk8sSUFSZSxDQVFUTixRQUFELElBQStCO0lBQ25DLElBQUlBLFFBQVEsQ0FBQ3VCLE1BQWIsRUFBcUI7TUFDbkIsTUFBTSxJQUFJMUIsWUFBSixDQUFpQkcsUUFBakIsQ0FBTjtJQUNEOztJQUNELE9BQU9BLFFBQVEsQ0FBQ3dCLElBQWhCO0VBQ0QsQ0FiZSxDQUFsQjtFQWNBYSxZQUFZLENBQUNQLEVBQUQsQ0FBWjtFQUNBLE9BQU9HLEdBQVA7QUFDRCxDQTlDSDs7QUFnREEsT0FBTyxNQUFNSyxhQUFhLEdBQUcsQ0FDM0JDLEdBRDJCLEVBRTNCekIsT0FGMkIsS0FJM0JoQixPQUFPLENBQ0xjLFFBQVEsQ0FDTixDQUNFMkIsR0FERixFQUVFO0VBQ0VDLElBQUksRUFBRSxNQURSO0VBRUVDLFdBQVcsRUFBRTtBQUZmLENBRkYsQ0FETSxFQVFOM0IsT0FSTSxDQURILENBSkYifQ==
|
package/dist/cache.d.ts
ADDED
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import type { InternalNode, InternalFile, InternalNodeFull } from "./client/types/index.js";
|
|
2
|
+
export declare const filesCache: Map<string, InternalFile>;
|
|
3
|
+
export declare const nodesCache: Map<string, InternalNode | InternalNodeFull>;
|
|
4
|
+
export declare const usersCache: Map<string, import("./BaseClient.js").UserBase | (import("./BaseClient.js").UserBase & {
|
|
5
|
+
publicKey: string;
|
|
6
|
+
})>;
|
package/dist/cache.js
ADDED
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
export const filesCache = new Map();
|
|
2
|
+
export const nodesCache = new Map();
|
|
3
|
+
export const usersCache = new Map();
|
|
4
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJmaWxlc0NhY2hlIiwiTWFwIiwibm9kZXNDYWNoZSIsInVzZXJzQ2FjaGUiXSwic291cmNlcyI6WyIuLi9zcmMvY2FjaGUudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBVc2VyIH0gZnJvbSBcIi4vaW5kZXguanNcIjtcbmltcG9ydCB0eXBlIHtcbiAgSW50ZXJuYWxOb2RlLFxuICBJbnRlcm5hbEZpbGUsXG4gIEludGVybmFsTm9kZUZ1bGxcbn0gZnJvbSBcIi4vY2xpZW50L3R5cGVzL2luZGV4LmpzXCI7XG5cbmV4cG9ydCBjb25zdCBmaWxlc0NhY2hlID0gbmV3IE1hcDxzdHJpbmcsIEludGVybmFsRmlsZT4oKTtcblxuZXhwb3J0IGNvbnN0IG5vZGVzQ2FjaGUgPSBuZXcgTWFwPHN0cmluZywgSW50ZXJuYWxOb2RlIHwgSW50ZXJuYWxOb2RlRnVsbD4oKTtcblxuZXhwb3J0IGNvbnN0IHVzZXJzQ2FjaGUgPSBuZXcgTWFwPFxuICBzdHJpbmcsXG4gIFVzZXIgfCBVc2VyPHsgd2l0aFB1YmxpY0tleTogdHJ1ZSB9PlxuPigpO1xuIl0sIm1hcHBpbmdzIjoiQUFPQSxPQUFPLE1BQU1BLFVBQVUsR0FBRyxJQUFJQyxHQUFKLEVBQW5CO0FBRVAsT0FBTyxNQUFNQyxVQUFVLEdBQUcsSUFBSUQsR0FBSixFQUFuQjtBQUVQLE9BQU8sTUFBTUUsVUFBVSxHQUFHLElBQUlGLEdBQUosRUFBbkIifQ==
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { PlanKind, SecrecyEnv, SuccessResponse, User } from "../../index.js";
|
|
2
|
+
import { BaseClient } from "../../BaseClient.js";
|
|
3
|
+
import type { ErrorAccessDenied } from "../../error.js";
|
|
4
|
+
export declare type UserAdminPanel = User<{
|
|
5
|
+
withPublicKey: false;
|
|
6
|
+
}>;
|
|
7
|
+
export declare class AdminSecrecyClient extends BaseClient {
|
|
8
|
+
userList(search?: string | null | undefined): Promise<SuccessResponse<UserAdminPanel[]> | ErrorAccessDenied | null>;
|
|
9
|
+
changeUserPlan(userId: string, plan: PlanKind): Promise<SuccessResponse<UserAdminPanel> | ErrorAccessDenied | null>;
|
|
10
|
+
}
|
|
11
|
+
export declare function getSecrecyAdminClient(env: SecrecyEnv, session?: boolean | undefined): AdminSecrecyClient | null;
|
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
/* eslint-disable @typescript-eslint/naming-convention */
|
|
2
|
+
import { storeBuddy } from "../../utils/store-buddy.js";
|
|
3
|
+
import { BaseClient } from "../../BaseClient.js";
|
|
4
|
+
const userSelector = {
|
|
5
|
+
id: true,
|
|
6
|
+
firstname: true,
|
|
7
|
+
lastname: true,
|
|
8
|
+
lang: true,
|
|
9
|
+
email: true,
|
|
10
|
+
phone: true,
|
|
11
|
+
role: true,
|
|
12
|
+
deletedAt: true,
|
|
13
|
+
lastLogin: true
|
|
14
|
+
};
|
|
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
|
|
37
|
+
}
|
|
38
|
+
}]
|
|
39
|
+
});
|
|
40
|
+
|
|
41
|
+
if (!userList) {
|
|
42
|
+
return null;
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
if (userList.__typename === "ErrorAccessDenied") {
|
|
46
|
+
return userList;
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
return {
|
|
50
|
+
__typename: "SuccessResponse",
|
|
51
|
+
data: userList.userList
|
|
52
|
+
};
|
|
53
|
+
}
|
|
54
|
+
|
|
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
|
+
});
|
|
80
|
+
|
|
81
|
+
if (!changeUserPlan) {
|
|
82
|
+
return null;
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
if (changeUserPlan.__typename === "ErrorAccessDenied") {
|
|
86
|
+
return changeUserPlan;
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
if (!changeUserPlan.changeUserPlan) {
|
|
90
|
+
return null;
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
return {
|
|
94
|
+
__typename: "SuccessResponse",
|
|
95
|
+
data: changeUserPlan.changeUserPlan
|
|
96
|
+
};
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
}
|
|
100
|
+
export function getSecrecyAdminClient(env, session) {
|
|
101
|
+
const userSession = storeBuddy("secrecy.user_session", session).init("");
|
|
102
|
+
const uaSession = userSession.load();
|
|
103
|
+
|
|
104
|
+
if (uaSession === "") {
|
|
105
|
+
return null;
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
return new AdminSecrecyClient(uaSession, env);
|
|
109
|
+
}
|
|
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;
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { filesCache } from "../../cache.js";
|
|
2
|
+
import { decryptCryptoBox } from "../../crypto/index.js";
|
|
3
|
+
import { sodium } from "../../sodium.js";
|
|
4
|
+
export function gqlFileToInternal(gql, keyPair) {
|
|
5
|
+
if (!gql.access || !gql.access.sharedBy.keyPair) {
|
|
6
|
+
throw "File " + gql.id + " doesn't have access";
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
const file = {
|
|
10
|
+
id: gql.id,
|
|
11
|
+
md5: gql.md5,
|
|
12
|
+
md5Encrypted: gql.md5Encrypted,
|
|
13
|
+
createdAt: new Date(gql.createdAt),
|
|
14
|
+
size: BigInt(gql.size),
|
|
15
|
+
sizeBefore: BigInt(gql.sizeBefore),
|
|
16
|
+
key: sodium.to_hex(decryptCryptoBox(sodium.from_hex(gql.access.key), gql.access.sharedBy.keyPair.pub, keyPair.privateKey))
|
|
17
|
+
};
|
|
18
|
+
filesCache.set(file.id, file);
|
|
19
|
+
return file;
|
|
20
|
+
}
|
|
21
|
+
export function internalFileToFile(internal) {
|
|
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
|
+
};
|
|
30
|
+
}
|
|
31
|
+
export function gqlFileToExternal(gql, keyPair) {
|
|
32
|
+
return internalFileToFile(gqlFileToInternal(gql, keyPair));
|
|
33
|
+
}
|
|
34
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJmaWxlc0NhY2hlIiwiZGVjcnlwdENyeXB0b0JveCIsInNvZGl1bSIsImdxbEZpbGVUb0ludGVybmFsIiwiZ3FsIiwia2V5UGFpciIsImFjY2VzcyIsInNoYXJlZEJ5IiwiaWQiLCJmaWxlIiwibWQ1IiwibWQ1RW5jcnlwdGVkIiwiY3JlYXRlZEF0IiwiRGF0ZSIsInNpemUiLCJCaWdJbnQiLCJzaXplQmVmb3JlIiwia2V5IiwidG9faGV4IiwiZnJvbV9oZXgiLCJwdWIiLCJwcml2YXRlS2V5Iiwic2V0IiwiaW50ZXJuYWxGaWxlVG9GaWxlIiwiaW50ZXJuYWwiLCJncWxGaWxlVG9FeHRlcm5hbCJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jbGllbnQvY29udmVydC9maWxlLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGZpbGVzQ2FjaGUgfSBmcm9tIFwiLi4vLi4vY2FjaGUuanNcIjtcbmltcG9ydCB0eXBlIHsgS2V5UGFpciB9IGZyb20gXCIuLi8uLi9jcnlwdG8vaW5kZXguanNcIjtcbmltcG9ydCB7IGRlY3J5cHRDcnlwdG9Cb3ggfSBmcm9tIFwiLi4vLi4vY3J5cHRvL2luZGV4LmpzXCI7XG5pbXBvcnQgeyBzb2RpdW0gfSBmcm9tIFwiLi4vLi4vc29kaXVtLmpzXCI7XG5pbXBvcnQgdHlwZSB7IEdRTEZpbGUsIEludGVybmFsRmlsZSwgRmlsZU1ldGFkYXRhIH0gZnJvbSBcIi4uL3R5cGVzL2luZGV4LmpzXCI7XG5cbmV4cG9ydCBmdW5jdGlvbiBncWxGaWxlVG9JbnRlcm5hbChcbiAgZ3FsOiBHUUxGaWxlLFxuICBrZXlQYWlyOiBLZXlQYWlyXG4pOiBJbnRlcm5hbEZpbGUge1xuICBpZiAoIWdxbC5hY2Nlc3MgfHwgIWdxbC5hY2Nlc3Muc2hhcmVkQnkua2V5UGFpcikge1xuICAgIHRocm93IGBGaWxlICR7Z3FsLmlkfSBkb2Vzbid0IGhhdmUgYWNjZXNzYDtcbiAgfVxuXG4gIGNvbnN0IGZpbGU6IEludGVybmFsRmlsZSA9IHtcbiAgICBpZDogZ3FsLmlkLFxuICAgIG1kNTogZ3FsLm1kNSxcbiAgICBtZDVFbmNyeXB0ZWQ6IGdxbC5tZDVFbmNyeXB0ZWQsXG4gICAgY3JlYXRlZEF0OiBuZXcgRGF0ZShncWwuY3JlYXRlZEF0IGFzIHN0cmluZyksXG4gICAgc2l6ZTogQmlnSW50KGdxbC5zaXplIGFzIHN0cmluZyksXG4gICAgc2l6ZUJlZm9yZTogQmlnSW50KGdxbC5zaXplQmVmb3JlIGFzIHN0cmluZyksXG4gICAga2V5OiBzb2RpdW0udG9faGV4KFxuICAgICAgZGVjcnlwdENyeXB0b0JveChcbiAgICAgICAgc29kaXVtLmZyb21faGV4KGdxbC5hY2Nlc3Mua2V5KSxcbiAgICAgICAgZ3FsLmFjY2Vzcy5zaGFyZWRCeS5rZXlQYWlyLnB1YixcbiAgICAgICAga2V5UGFpci5wcml2YXRlS2V5XG4gICAgICApXG4gICAgKVxuICB9O1xuXG4gIGZpbGVzQ2FjaGUuc2V0KGZpbGUuaWQsIGZpbGUpO1xuICByZXR1cm4gZmlsZTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGludGVybmFsRmlsZVRvRmlsZShpbnRlcm5hbDogSW50ZXJuYWxGaWxlKTogRmlsZU1ldGFkYXRhIHtcbiAgcmV0dXJuIHtcbiAgICBpZDogaW50ZXJuYWwuaWQsXG4gICAgbWQ1OiBpbnRlcm5hbC5tZDUsXG4gICAgbWQ1RW5jcnlwdGVkOiBpbnRlcm5hbC5tZDVFbmNyeXB0ZWQsXG4gICAgY3JlYXRlZEF0OiBpbnRlcm5hbC5jcmVhdGVkQXQsXG4gICAgc2l6ZTogaW50ZXJuYWwuc2l6ZSxcbiAgICBzaXplQmVmb3JlOiBpbnRlcm5hbC5zaXplQmVmb3JlXG4gIH07XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBncWxGaWxlVG9FeHRlcm5hbChcbiAgZ3FsOiBHUUxGaWxlLFxuICBrZXlQYWlyOiBLZXlQYWlyXG4pOiBGaWxlTWV0YWRhdGEge1xuICByZXR1cm4gaW50ZXJuYWxGaWxlVG9GaWxlKGdxbEZpbGVUb0ludGVybmFsKGdxbCwga2V5UGFpcikpO1xufVxuIl0sIm1hcHBpbmdzIjoiQUFBQSxTQUFTQSxVQUFULFFBQTJCLGdCQUEzQjtBQUVBLFNBQVNDLGdCQUFULFFBQWlDLHVCQUFqQztBQUNBLFNBQVNDLE1BQVQsUUFBdUIsaUJBQXZCO0FBR0EsT0FBTyxTQUFTQyxpQkFBVCxDQUNMQyxHQURLLEVBRUxDLE9BRkssRUFHUztFQUNkLElBQUksQ0FBQ0QsR0FBRyxDQUFDRSxNQUFMLElBQWUsQ0FBQ0YsR0FBRyxDQUFDRSxNQUFKLENBQVdDLFFBQVgsQ0FBb0JGLE9BQXhDLEVBQWlEO0lBQy9DLGdCQUFjRCxHQUFHLENBQUNJLEVBQWxCO0VBQ0Q7O0VBRUQsTUFBTUMsSUFBa0IsR0FBRztJQUN6QkQsRUFBRSxFQUFFSixHQUFHLENBQUNJLEVBRGlCO0lBRXpCRSxHQUFHLEVBQUVOLEdBQUcsQ0FBQ00sR0FGZ0I7SUFHekJDLFlBQVksRUFBRVAsR0FBRyxDQUFDTyxZQUhPO0lBSXpCQyxTQUFTLEVBQUUsSUFBSUMsSUFBSixDQUFTVCxHQUFHLENBQUNRLFNBQWIsQ0FKYztJQUt6QkUsSUFBSSxFQUFFQyxNQUFNLENBQUNYLEdBQUcsQ0FBQ1UsSUFBTCxDQUxhO0lBTXpCRSxVQUFVLEVBQUVELE1BQU0sQ0FBQ1gsR0FBRyxDQUFDWSxVQUFMLENBTk87SUFPekJDLEdBQUcsRUFBRWYsTUFBTSxDQUFDZ0IsTUFBUCxDQUNIakIsZ0JBQWdCLENBQ2RDLE1BQU0sQ0FBQ2lCLFFBQVAsQ0FBZ0JmLEdBQUcsQ0FBQ0UsTUFBSixDQUFXVyxHQUEzQixDQURjLEVBRWRiLEdBQUcsQ0FBQ0UsTUFBSixDQUFXQyxRQUFYLENBQW9CRixPQUFwQixDQUE0QmUsR0FGZCxFQUdkZixPQUFPLENBQUNnQixVQUhNLENBRGI7RUFQb0IsQ0FBM0I7RUFnQkFyQixVQUFVLENBQUNzQixHQUFYLENBQWViLElBQUksQ0FBQ0QsRUFBcEIsRUFBd0JDLElBQXhCO0VBQ0EsT0FBT0EsSUFBUDtBQUNEO0FBRUQsT0FBTyxTQUFTYyxrQkFBVCxDQUE0QkMsUUFBNUIsRUFBa0U7RUFDdkUsT0FBTztJQUNMaEIsRUFBRSxFQUFFZ0IsUUFBUSxDQUFDaEIsRUFEUjtJQUVMRSxHQUFHLEVBQUVjLFFBQVEsQ0FBQ2QsR0FGVDtJQUdMQyxZQUFZLEVBQUVhLFFBQVEsQ0FBQ2IsWUFIbEI7SUFJTEMsU0FBUyxFQUFFWSxRQUFRLENBQUNaLFNBSmY7SUFLTEUsSUFBSSxFQUFFVSxRQUFRLENBQUNWLElBTFY7SUFNTEUsVUFBVSxFQUFFUSxRQUFRLENBQUNSO0VBTmhCLENBQVA7QUFRRDtBQUVELE9BQU8sU0FBU1MsaUJBQVQsQ0FDTHJCLEdBREssRUFFTEMsT0FGSyxFQUdTO0VBQ2QsT0FBT2tCLGtCQUFrQixDQUFDcEIsaUJBQWlCLENBQUNDLEdBQUQsRUFBTUMsT0FBTixDQUFsQixDQUF6QjtBQUNEIn0=
|
|
File without changes
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import { sodium, decryptCryptoBox } from "../../index.js";
|
|
2
|
+
export function convertInternalMailToExternal(data, keys) {
|
|
3
|
+
var _mI$replyTo;
|
|
4
|
+
|
|
5
|
+
if (data.mailIntegrityDraft) {
|
|
6
|
+
data.type = "draft";
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
const mI = data.type === "draft" ? data.mailIntegrityDraft : data.mailIntegrity;
|
|
10
|
+
|
|
11
|
+
if (!mI) {
|
|
12
|
+
return null;
|
|
13
|
+
}
|
|
14
|
+
|
|
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
|
+
}), mI.hashKey, "hex");
|
|
22
|
+
return {
|
|
23
|
+
type: data.type,
|
|
24
|
+
id: data.id,
|
|
25
|
+
mailIntegrityId: mI.id,
|
|
26
|
+
replyTo: (_mI$replyTo = mI.replyTo) == null ? void 0 : _mI$replyTo.id,
|
|
27
|
+
body,
|
|
28
|
+
subject,
|
|
29
|
+
createdAt: new Date(data.createdAt),
|
|
30
|
+
deletedAt: data.deletedAt ? new Date(data.deletedAt) : null,
|
|
31
|
+
openedAt: data.openedAt ? new Date(data.openedAt) : null,
|
|
32
|
+
isAltered: hash !== mI.hash,
|
|
33
|
+
temporaryRecipients: mI.temporaryRecipients,
|
|
34
|
+
recipients: data.type === "draft" ? mI.recipients : data.recipients,
|
|
35
|
+
sender: data.sender,
|
|
36
|
+
files: data.files.map(f => {
|
|
37
|
+
const name = sodium.to_string(decryptCryptoBox(sodium.from_hex(f.filename), pubKey, keys.privateKey));
|
|
38
|
+
return {
|
|
39
|
+
id: f.file.id,
|
|
40
|
+
name,
|
|
41
|
+
key: f.fileKey
|
|
42
|
+
};
|
|
43
|
+
})
|
|
44
|
+
};
|
|
45
|
+
}
|
|
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>;
|