@secrecy/lib 1.0.0-dev.27 → 1.0.0-dev.28
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/BaseClient.d.ts +274 -0
- package/dist/BaseClient.js +2227 -0
- package/dist/PopupTools.d.ts +17 -0
- package/dist/PopupTools.js +213 -0
- package/dist/ZeusThunder.d.ts +2 -0
- package/dist/ZeusThunder.js +113 -0
- package/dist/cache.d.ts +7 -0
- package/dist/cache.js +5 -0
- package/dist/client/admin/index.d.ts +11 -0
- package/dist/client/admin/index.js +198 -0
- package/dist/client/convert/file.d.ts +5 -0
- package/dist/client/convert/file.js +39 -0
- package/dist/client/convert/folder.d.ts +8 -0
- package/dist/client/convert/folder.js +264 -0
- package/dist/client/convert/mail.d.ts +3 -0
- package/dist/client/convert/mail.js +46 -0
- package/dist/client/convert/vFile.d.ts +5 -0
- package/dist/client/convert/vFile.js +164 -0
- package/dist/client/helpers.d.ts +23 -0
- package/dist/client/helpers.js +114 -0
- package/dist/client/index.d.ts +172 -0
- package/dist/client/index.js +6169 -0
- package/dist/client/storage.d.ts +7 -0
- package/dist/client/storage.js +12 -0
- package/dist/client/types/File.d.ts +21 -0
- package/dist/client/types/File.js +3 -0
- package/dist/client/types/FilesOnUsersOnApplications.d.ts +9 -0
- package/dist/client/types/FilesOnUsersOnApplications.js +3 -0
- package/dist/client/types/Folder.d.ts +68 -0
- package/dist/client/types/Folder.js +7 -0
- package/dist/client/types/Inputs.d.ts +21 -0
- package/dist/client/types/Inputs.js +3 -0
- package/dist/client/types/UserAppNotifications.d.ts +6 -0
- package/dist/client/types/UserAppNotifications.js +3 -0
- package/dist/client/types/UserAppSettings.d.ts +7 -0
- package/dist/client/types/UserAppSettings.js +3 -0
- package/dist/client/types/VFile.d.ts +62 -0
- package/dist/client/types/VFile.js +4 -0
- package/dist/client/types/index.d.ts +154 -0
- package/dist/client/types/index.js +10 -0
- package/dist/client/types/queries.d.ts +535 -0
- package/dist/client/types/queries.js +192 -0
- package/dist/crypto/file.d.ts +14 -0
- package/dist/crypto/file.js +291 -0
- package/dist/crypto/index.d.ts +12 -0
- package/dist/crypto/index.js +45 -0
- package/dist/error.d.ts +30 -0
- package/dist/error.js +3 -0
- package/dist/index.d.ts +13 -3857
- package/dist/index.js +42 -255
- package/dist/minify/index.d.ts +2 -0
- package/dist/minify/index.js +28 -0
- package/dist/minify/lz4.d.ts +5 -0
- package/dist/minify/lz4.js +633 -0
- package/dist/sodium.d.ts +3 -0
- package/dist/sodium.js +28 -0
- package/dist/utils/store-buddy.d.ts +14 -0
- package/dist/utils/store-buddy.js +69 -0
- package/dist/utils/time.d.ts +10 -0
- package/dist/utils/time.js +22 -0
- package/dist/utils.d.ts +4 -0
- package/dist/utils.js +188 -0
- package/dist/worker/__mock__/sodium.worker.d.ts +19 -0
- package/dist/worker/__mock__/sodium.worker.js +46 -0
- package/dist/worker/md5.d.ts +1 -0
- package/dist/worker/md5.js +43 -0
- package/dist/worker/sodium.d.ts +3 -0
- package/dist/worker/sodium.js +155 -0
- package/dist/worker/workerCodes.d.ts +2 -0
- package/dist/worker/workerCodes.js +3 -0
- package/dist/zeus/const.d.ts +2 -0
- package/dist/zeus/const.js +2267 -0
- package/dist/zeus/index.d.ts +4043 -0
- package/dist/zeus/index.js +549 -0
- package/package.json +23 -14
- package/__tests__/client/client.test.ts +0 -81
- package/__tests__/client/folder.test.ts +0 -302
- package/__tests__/client/mail.test.ts +0 -476
- package/__tests__/client/timing.test.ts +0 -35
- package/__tests__/client/utils.ts +0 -41
- package/__tests__/client/vFile.test.ts +0 -207
- package/__tests__/index.test.ts +0 -171
- package/commitlint.config.cjs +0 -3
- package/dist/index.js.map +0 -1
- package/dist/index.mjs +0 -255
- package/dist/index.mjs.map +0 -1
- package/docs/assets/css/main.css +0 -2660
- package/docs/assets/images/icons.png +0 -0
- package/docs/assets/images/icons@2x.png +0 -0
- package/docs/assets/images/widgets.png +0 -0
- package/docs/assets/images/widgets@2x.png +0 -0
- package/docs/assets/js/main.js +0 -248
- package/docs/assets/js/search.js +0 -1
- package/docs/classes/baseclient.baseclient-1.html +0 -1165
- package/docs/classes/client.secrecyclient.html +0 -2527
- package/docs/enums/index.sodium.base64_variants.html +0 -205
- package/docs/index.html +0 -198
- package/docs/interfaces/client_types.draftmail.html +0 -335
- package/docs/interfaces/client_types.filecontentbase.html +0 -231
- package/docs/interfaces/client_types.filecontentcloud.html +0 -244
- package/docs/interfaces/client_types.filecontentreceivedmail.html +0 -244
- package/docs/interfaces/client_types.filecontentsentmail.html +0 -230
- package/docs/interfaces/client_types.receivedmail.html +0 -363
- package/docs/interfaces/client_types.sentmail.html +0 -335
- package/docs/interfaces/crypto.keypair.html +0 -202
- package/docs/interfaces/index.sodium.cryptobox.html +0 -185
- package/docs/interfaces/index.sodium.cryptokx.html +0 -185
- package/docs/interfaces/index.sodium.keypair.html +0 -199
- package/docs/interfaces/index.sodium.messagetag.html +0 -185
- package/docs/interfaces/index.sodium.secretbox.html +0 -185
- package/docs/interfaces/index.sodium.stateaddress.html +0 -171
- package/docs/interfaces/index.sodium.stringcryptobox.html +0 -185
- package/docs/interfaces/index.sodium.stringcryptokx.html +0 -185
- package/docs/interfaces/index.sodium.stringkeypair.html +0 -199
- package/docs/interfaces/index.sodium.stringmessagetag.html +0 -185
- package/docs/interfaces/index.sodium.stringsecretbox.html +0 -185
- package/docs/interfaces/utils_store_buddy.storebuddy.html +0 -333
- package/docs/modules/baseclient.html +0 -929
- package/docs/modules/cache.html +0 -185
- package/docs/modules/client.html +0 -207
- package/docs/modules/client_convert_file.html +0 -216
- package/docs/modules/client_convert_folder.html +0 -303
- package/docs/modules/client_convert_vfile.html +0 -216
- package/docs/modules/client_helpers.html +0 -311
- package/docs/modules/client_storage.html +0 -167
- package/docs/modules/client_types.html +0 -1227
- package/docs/modules/client_types_file.html +0 -233
- package/docs/modules/client_types_filesonusersonapplications.html +0 -168
- package/docs/modules/client_types_folder.html +0 -383
- package/docs/modules/client_types_inputs.html +0 -263
- package/docs/modules/client_types_mail.html +0 -181
- package/docs/modules/client_types_queries.html +0 -199
- package/docs/modules/client_types_userappsettings.html +0 -163
- package/docs/modules/client_types_vfile.html +0 -364
- package/docs/modules/crypto.html +0 -366
- package/docs/modules/crypto_file.html +0 -344
- package/docs/modules/index.html +0 -779
- package/docs/modules/index.sodium.html +0 -6039
- package/docs/modules/minify.html +0 -183
- package/docs/modules/minify_lz4.html +0 -279
- package/docs/modules/popuptools.html +0 -259
- package/docs/modules/sodium.html +0 -167
- package/docs/modules/utils.html +0 -219
- package/docs/modules/utils_store_buddy.html +0 -208
- package/docs/modules/utils_time.html +0 -330
- package/docs/modules/worker_md5.html +0 -156
- package/docs/modules/worker_sodium.html +0 -231
- package/docs/modules/worker_workercodes.html +0 -157
- package/docs/modules.html +0 -235
- package/index.html +0 -21
- package/jest.config.ts +0 -27
- package/jest.setup.ts +0 -6
- package/release.config.cjs +0 -15
- package/tsup.config.ts +0 -26
|
@@ -0,0 +1,192 @@
|
|
|
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
|
+
export var gqlFileQuery = {
|
|
8
|
+
id: true,
|
|
9
|
+
size: true,
|
|
10
|
+
sizeBefore: true,
|
|
11
|
+
createdAt: true,
|
|
12
|
+
md5: true,
|
|
13
|
+
md5Encrypted: true,
|
|
14
|
+
user: {
|
|
15
|
+
key: true,
|
|
16
|
+
userApp: {
|
|
17
|
+
keyPair: {
|
|
18
|
+
pub: true
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
};
|
|
23
|
+
export var gqlVFileQuery = {
|
|
24
|
+
id: true,
|
|
25
|
+
filename: true,
|
|
26
|
+
createdBy: {
|
|
27
|
+
user: {
|
|
28
|
+
id: true,
|
|
29
|
+
firstname: true,
|
|
30
|
+
lastname: true,
|
|
31
|
+
email: true,
|
|
32
|
+
publicKey: true
|
|
33
|
+
}
|
|
34
|
+
},
|
|
35
|
+
userApps: {
|
|
36
|
+
rights: true,
|
|
37
|
+
isRoot: true,
|
|
38
|
+
userApp: {
|
|
39
|
+
user: {
|
|
40
|
+
id: true,
|
|
41
|
+
firstname: true,
|
|
42
|
+
lastname: true,
|
|
43
|
+
email: true,
|
|
44
|
+
publicKey: true
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
},
|
|
48
|
+
userApp: {
|
|
49
|
+
userApp: {
|
|
50
|
+
user: {
|
|
51
|
+
id: true
|
|
52
|
+
}
|
|
53
|
+
},
|
|
54
|
+
nameKey: true,
|
|
55
|
+
rights: true,
|
|
56
|
+
isRoot: true
|
|
57
|
+
},
|
|
58
|
+
isFavorite: true,
|
|
59
|
+
createdAt: true,
|
|
60
|
+
deletedAt: true,
|
|
61
|
+
updatedAt: true,
|
|
62
|
+
current: _objectSpread({}, gqlFileQuery),
|
|
63
|
+
history: _objectSpread({}, gqlFileQuery)
|
|
64
|
+
};
|
|
65
|
+
export var gqlFolderQuery = {
|
|
66
|
+
id: true,
|
|
67
|
+
isFavorite: true,
|
|
68
|
+
createdAt: true,
|
|
69
|
+
deletedAt: true,
|
|
70
|
+
updatedAt: true,
|
|
71
|
+
name: true,
|
|
72
|
+
createdBy: {
|
|
73
|
+
user: {
|
|
74
|
+
id: true,
|
|
75
|
+
firstname: true,
|
|
76
|
+
lastname: true,
|
|
77
|
+
email: true,
|
|
78
|
+
publicKey: true
|
|
79
|
+
}
|
|
80
|
+
},
|
|
81
|
+
userApps: {
|
|
82
|
+
rights: true,
|
|
83
|
+
isRoot: true,
|
|
84
|
+
userApp: {
|
|
85
|
+
user: {
|
|
86
|
+
id: true,
|
|
87
|
+
firstname: true,
|
|
88
|
+
lastname: true,
|
|
89
|
+
email: true,
|
|
90
|
+
publicKey: true
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
},
|
|
94
|
+
userApp: {
|
|
95
|
+
userApp: {
|
|
96
|
+
user: {
|
|
97
|
+
id: true
|
|
98
|
+
}
|
|
99
|
+
},
|
|
100
|
+
nameKey: true,
|
|
101
|
+
rights: true,
|
|
102
|
+
isRoot: true
|
|
103
|
+
},
|
|
104
|
+
breadcrumb: {
|
|
105
|
+
id: true,
|
|
106
|
+
name: true,
|
|
107
|
+
nameKey: true,
|
|
108
|
+
pubKey: true
|
|
109
|
+
}
|
|
110
|
+
};
|
|
111
|
+
export var gqlFolderFullQuery = _objectSpread(_objectSpread({}, gqlFolderQuery), {}, {
|
|
112
|
+
vFiles: _objectSpread({}, gqlVFileQuery),
|
|
113
|
+
parentFolder: gqlFolderQuery,
|
|
114
|
+
subfolders: gqlFolderQuery
|
|
115
|
+
});
|
|
116
|
+
export var gqlVFileWithFolderQuery = _objectSpread(_objectSpread({}, gqlVFileQuery), {}, {
|
|
117
|
+
folder: _objectSpread({}, gqlFolderQuery)
|
|
118
|
+
});
|
|
119
|
+
export var gqlMailQuery = {
|
|
120
|
+
id: true,
|
|
121
|
+
type: true,
|
|
122
|
+
body: true,
|
|
123
|
+
subject: true,
|
|
124
|
+
openedAt: true,
|
|
125
|
+
createdAt: true,
|
|
126
|
+
deletedAt: true,
|
|
127
|
+
recipients: {
|
|
128
|
+
id: true,
|
|
129
|
+
firstname: true,
|
|
130
|
+
lastname: true,
|
|
131
|
+
email: true,
|
|
132
|
+
publicKey: true
|
|
133
|
+
},
|
|
134
|
+
recipient: {
|
|
135
|
+
id: true,
|
|
136
|
+
firstname: true,
|
|
137
|
+
lastname: true,
|
|
138
|
+
email: true,
|
|
139
|
+
publicKey: true
|
|
140
|
+
},
|
|
141
|
+
sender: {
|
|
142
|
+
id: true,
|
|
143
|
+
firstname: true,
|
|
144
|
+
lastname: true,
|
|
145
|
+
email: true,
|
|
146
|
+
publicKey: true
|
|
147
|
+
},
|
|
148
|
+
mailIntegrity: {
|
|
149
|
+
temporaryRecipients: {
|
|
150
|
+
email: true
|
|
151
|
+
},
|
|
152
|
+
recipients: {
|
|
153
|
+
id: true,
|
|
154
|
+
firstname: true,
|
|
155
|
+
lastname: true,
|
|
156
|
+
email: true,
|
|
157
|
+
publicKey: true
|
|
158
|
+
},
|
|
159
|
+
id: true,
|
|
160
|
+
hash: true,
|
|
161
|
+
hashKey: true,
|
|
162
|
+
replyTo: {
|
|
163
|
+
id: true
|
|
164
|
+
}
|
|
165
|
+
},
|
|
166
|
+
mailIntegrityDraft: {
|
|
167
|
+
temporaryRecipients: {
|
|
168
|
+
email: true
|
|
169
|
+
},
|
|
170
|
+
recipients: {
|
|
171
|
+
id: true,
|
|
172
|
+
firstname: true,
|
|
173
|
+
lastname: true,
|
|
174
|
+
email: true,
|
|
175
|
+
publicKey: true
|
|
176
|
+
},
|
|
177
|
+
id: true,
|
|
178
|
+
hash: true,
|
|
179
|
+
hashKey: true,
|
|
180
|
+
replyTo: {
|
|
181
|
+
id: true
|
|
182
|
+
}
|
|
183
|
+
},
|
|
184
|
+
files: {
|
|
185
|
+
fileKey: true,
|
|
186
|
+
filename: true,
|
|
187
|
+
file: {
|
|
188
|
+
id: true
|
|
189
|
+
}
|
|
190
|
+
}
|
|
191
|
+
};
|
|
192
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/client/types/queries.ts"],"names":["gqlFileQuery","id","size","sizeBefore","createdAt","md5","md5Encrypted","user","key","userApp","keyPair","pub","gqlVFileQuery","filename","createdBy","firstname","lastname","email","publicKey","userApps","rights","isRoot","nameKey","isFavorite","deletedAt","updatedAt","current","history","gqlFolderQuery","name","breadcrumb","pubKey","gqlFolderFullQuery","vFiles","parentFolder","subfolders","gqlVFileWithFolderQuery","folder","gqlMailQuery","type","body","subject","openedAt","recipients","recipient","sender","mailIntegrity","temporaryRecipients","hash","hashKey","replyTo","mailIntegrityDraft","files","fileKey","file"],"mappings":"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","sourcesContent":["export const gqlFileQuery = {\n  id: true,\n  size: true,\n  sizeBefore: true,\n  createdAt: true,\n  md5: true,\n  md5Encrypted: true,\n  user: {\n    key: true,\n    userApp: {\n      keyPair: {\n        pub: true\n      }\n    }\n  }\n} as const;\n\nexport const gqlVFileQuery = {\n  id: true,\n  filename: true,\n  createdBy: {\n    user: {\n      id: true,\n      firstname: true,\n      lastname: true,\n      email: true,\n      publicKey: true\n    }\n  },\n  userApps: {\n    rights: true,\n    isRoot: true,\n    userApp: {\n      user: {\n        id: true,\n        firstname: true,\n        lastname: true,\n        email: true,\n        publicKey: true\n      }\n    }\n  },\n  userApp: {\n    userApp: {\n      user: {\n        id: true\n      }\n    },\n    nameKey: true,\n    rights: true,\n    isRoot: true\n  },\n  isFavorite: true,\n  createdAt: true,\n  deletedAt: true,\n  updatedAt: true,\n  current: {\n    ...gqlFileQuery\n  },\n  history: {\n    ...gqlFileQuery\n  }\n} as const;\n\nexport const gqlFolderQuery = {\n  id: true,\n  isFavorite: true,\n  createdAt: true,\n  deletedAt: true,\n  updatedAt: true,\n  name: true,\n  createdBy: {\n    user: {\n      id: true,\n      firstname: true,\n      lastname: true,\n      email: true,\n      publicKey: true\n    }\n  },\n  userApps: {\n    rights: true,\n    isRoot: true,\n    userApp: {\n      user: {\n        id: true,\n        firstname: true,\n        lastname: true,\n        email: true,\n        publicKey: true\n      }\n    }\n  },\n  userApp: {\n    userApp: {\n      user: {\n        id: true\n      }\n    },\n    nameKey: true,\n    rights: true,\n    isRoot: true\n  },\n  breadcrumb: {\n    id: true,\n    name: true,\n    nameKey: true,\n    pubKey: true\n  }\n} as const;\n\nexport const gqlFolderFullQuery = {\n  ...gqlFolderQuery,\n  vFiles: {\n    ...gqlVFileQuery\n  },\n  parentFolder: gqlFolderQuery,\n  subfolders: gqlFolderQuery\n} as const;\n\nexport const gqlVFileWithFolderQuery = {\n  ...gqlVFileQuery,\n  folder: {\n    ...gqlFolderQuery\n  }\n} as const;\n\nexport const gqlMailQuery = {\n  id: true,\n  type: true,\n  body: true,\n  subject: true,\n  openedAt: true,\n  createdAt: true,\n  deletedAt: true,\n  recipients: {\n    id: true,\n    firstname: true,\n    lastname: true,\n    email: true,\n    publicKey: true\n  },\n  recipient: {\n    id: true,\n    firstname: true,\n    lastname: true,\n    email: true,\n    publicKey: true\n  },\n  sender: {\n    id: true,\n    firstname: true,\n    lastname: true,\n    email: true,\n    publicKey: true\n  },\n  mailIntegrity: {\n    temporaryRecipients: {\n      email: true\n    },\n    recipients: {\n      id: true,\n      firstname: true,\n      lastname: true,\n      email: true,\n      publicKey: true\n    },\n    id: true,\n    hash: true,\n    hashKey: true,\n    replyTo: {\n      id: true\n    }\n  },\n  mailIntegrityDraft: {\n    temporaryRecipients: {\n      email: true\n    },\n    recipients: {\n      id: true,\n      firstname: true,\n      lastname: true,\n      email: true,\n      publicKey: true\n    },\n    id: true,\n    hash: true,\n    hashKey: true,\n    replyTo: {\n      id: true\n    }\n  },\n  files: {\n    fileKey: true,\n    filename: true,\n    file: {\n      id: true\n    }\n  }\n} as const;\n"]}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
export declare type EncryptedFile = {
|
|
2
|
+
data: Uint8Array;
|
|
3
|
+
md5: string;
|
|
4
|
+
md5Encrypted: string;
|
|
5
|
+
};
|
|
6
|
+
export declare function secretstreamKeygen(): Uint8Array;
|
|
7
|
+
export declare const CHUNK_SIZE = 8192;
|
|
8
|
+
export declare type Progress = {
|
|
9
|
+
percent: number;
|
|
10
|
+
total: number;
|
|
11
|
+
current: number;
|
|
12
|
+
};
|
|
13
|
+
export declare function encryptSecretstream(key: Uint8Array, data: Uint8Array, progress?: (progress: Progress) => Promise<void>, abort?: AbortController): Promise<EncryptedFile>;
|
|
14
|
+
export declare function decryptSecretstream(key: Uint8Array, data: Uint8Array, progress?: (progress: Progress) => Promise<void>, abort?: AbortController): Promise<Uint8Array>;
|
|
@@ -0,0 +1,291 @@
|
|
|
1
|
+
import _asyncToGenerator from "@babel/runtime/helpers/asyncToGenerator";
|
|
2
|
+
import _regeneratorRuntime from "@babel/runtime/regenerator";
|
|
3
|
+
|
|
4
|
+
function _createForOfIteratorHelperLoose(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (it) return (it = it.call(o)).next.bind(it); if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; return function () { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
5
|
+
|
|
6
|
+
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
|
7
|
+
|
|
8
|
+
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
|
|
9
|
+
|
|
10
|
+
import { setup, sodium } from "../sodium.js";
|
|
11
|
+
import SparkMD5 from "spark-md5";
|
|
12
|
+
import { chunks } from "../utils.js";
|
|
13
|
+
|
|
14
|
+
function assert(c, message) {
|
|
15
|
+
if (!c) {
|
|
16
|
+
throw new Error(message);
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
export function secretstreamKeygen() {
|
|
21
|
+
return sodium.crypto_secretstream_xchacha20poly1305_keygen();
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
function encrypt(key) {
|
|
25
|
+
var destroyed = false;
|
|
26
|
+
|
|
27
|
+
var _sodium$crypto_secret = sodium.crypto_secretstream_xchacha20poly1305_init_push(key),
|
|
28
|
+
state = _sodium$crypto_secret.state,
|
|
29
|
+
header = _sodium$crypto_secret.header;
|
|
30
|
+
|
|
31
|
+
var encrypt = function encrypt(tag, plaintext) {
|
|
32
|
+
assert(destroyed === false, "state already destroyed");
|
|
33
|
+
return sodium.crypto_secretstream_xchacha20poly1305_push(state, plaintext, null, tag);
|
|
34
|
+
};
|
|
35
|
+
|
|
36
|
+
function destroy() {
|
|
37
|
+
assert(destroyed === false, "state already destroyed");
|
|
38
|
+
destroyed = true;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
return {
|
|
42
|
+
encrypt: encrypt,
|
|
43
|
+
destroy: destroy,
|
|
44
|
+
header: header
|
|
45
|
+
};
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
function decrypt(header, key) {
|
|
49
|
+
assert(header.byteLength >= sodium.crypto_secretstream_xchacha20poly1305_HEADERBYTES, "header must be at least HEADERBYTES (" + sodium.crypto_secretstream_xchacha20poly1305_HEADERBYTES + ") long");
|
|
50
|
+
assert(key.byteLength >= sodium.crypto_secretstream_xchacha20poly1305_KEYBYTES, "key must be at least KEYBYTES (" + sodium.crypto_secretstream_xchacha20poly1305_KEYBYTES + ") long");
|
|
51
|
+
var destroyed = false;
|
|
52
|
+
var state = sodium.crypto_secretstream_xchacha20poly1305_init_pull(header, key);
|
|
53
|
+
|
|
54
|
+
var decrypt = function decrypt(ciphertext) {
|
|
55
|
+
assert(destroyed === false, "state already destroyed");
|
|
56
|
+
return sodium.crypto_secretstream_xchacha20poly1305_pull(state, ciphertext);
|
|
57
|
+
};
|
|
58
|
+
|
|
59
|
+
function destroy() {
|
|
60
|
+
assert(destroyed === false, "state already destroyed");
|
|
61
|
+
destroyed = true;
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
return {
|
|
65
|
+
decrypt: decrypt,
|
|
66
|
+
destroy: destroy
|
|
67
|
+
};
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
export var CHUNK_SIZE = 8192;
|
|
71
|
+
export function encryptSecretstream(_x, _x2, _x3, _x4) {
|
|
72
|
+
return _encryptSecretstream.apply(this, arguments);
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
function _encryptSecretstream() {
|
|
76
|
+
_encryptSecretstream = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee(key, data, progress, abort) {
|
|
77
|
+
var _encrypt, crypt, destroy, header, cryptedChunk, max, final, sparkEncrypted, spark, total, lastPercent, _iterator, _step, chunk, _tag, crypted, percent;
|
|
78
|
+
|
|
79
|
+
return _regeneratorRuntime.wrap(function _callee$(_context) {
|
|
80
|
+
while (1) {
|
|
81
|
+
switch (_context.prev = _context.next) {
|
|
82
|
+
case 0:
|
|
83
|
+
_context.next = 2;
|
|
84
|
+
return setup();
|
|
85
|
+
|
|
86
|
+
case 2:
|
|
87
|
+
_encrypt = encrypt(key), crypt = _encrypt.encrypt, destroy = _encrypt.destroy, header = _encrypt.header;
|
|
88
|
+
cryptedChunk = CHUNK_SIZE + sodium.crypto_secretstream_xchacha20poly1305_ABYTES;
|
|
89
|
+
max = Math.ceil(data.byteLength / CHUNK_SIZE) * cryptedChunk + header.byteLength;
|
|
90
|
+
progress == null ? void 0 : progress({
|
|
91
|
+
percent: 0,
|
|
92
|
+
total: max,
|
|
93
|
+
current: 0
|
|
94
|
+
});
|
|
95
|
+
final = new Uint8Array(max);
|
|
96
|
+
sparkEncrypted = new SparkMD5.ArrayBuffer();
|
|
97
|
+
spark = new SparkMD5.ArrayBuffer();
|
|
98
|
+
final.set(header);
|
|
99
|
+
sparkEncrypted.append(header);
|
|
100
|
+
total = header.byteLength;
|
|
101
|
+
progress == null ? void 0 : progress({
|
|
102
|
+
percent: total / max,
|
|
103
|
+
total: max,
|
|
104
|
+
current: total
|
|
105
|
+
});
|
|
106
|
+
lastPercent = total / max;
|
|
107
|
+
_iterator = _createForOfIteratorHelperLoose(chunks(data, CHUNK_SIZE));
|
|
108
|
+
|
|
109
|
+
case 15:
|
|
110
|
+
if ((_step = _iterator()).done) {
|
|
111
|
+
_context.next = 29;
|
|
112
|
+
break;
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
chunk = _step.value;
|
|
116
|
+
|
|
117
|
+
if (!(abort != null && abort.signal.aborted)) {
|
|
118
|
+
_context.next = 19;
|
|
119
|
+
break;
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
throw new Error("Encrypt aborted");
|
|
123
|
+
|
|
124
|
+
case 19:
|
|
125
|
+
spark.append(chunk);
|
|
126
|
+
_tag = chunk.length < CHUNK_SIZE ? sodium.crypto_secretstream_xchacha20poly1305_TAG_FINAL : sodium.crypto_secretstream_xchacha20poly1305_TAG_MESSAGE;
|
|
127
|
+
crypted = crypt(_tag, chunk);
|
|
128
|
+
sparkEncrypted.append(crypted);
|
|
129
|
+
final.set(crypted, total);
|
|
130
|
+
total += crypted.byteLength;
|
|
131
|
+
percent = total / max;
|
|
132
|
+
|
|
133
|
+
if (percent > lastPercent + 0.01) {
|
|
134
|
+
progress == null ? void 0 : progress({
|
|
135
|
+
percent: percent,
|
|
136
|
+
total: max,
|
|
137
|
+
current: total
|
|
138
|
+
});
|
|
139
|
+
lastPercent = percent;
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
case 27:
|
|
143
|
+
_context.next = 15;
|
|
144
|
+
break;
|
|
145
|
+
|
|
146
|
+
case 29:
|
|
147
|
+
destroy();
|
|
148
|
+
progress == null ? void 0 : progress({
|
|
149
|
+
percent: 1,
|
|
150
|
+
total: total,
|
|
151
|
+
current: total
|
|
152
|
+
});
|
|
153
|
+
return _context.abrupt("return", {
|
|
154
|
+
data: final.slice(0, total),
|
|
155
|
+
md5Encrypted: sparkEncrypted.end(),
|
|
156
|
+
md5: spark.end()
|
|
157
|
+
});
|
|
158
|
+
|
|
159
|
+
case 32:
|
|
160
|
+
case "end":
|
|
161
|
+
return _context.stop();
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
}, _callee);
|
|
165
|
+
}));
|
|
166
|
+
return _encryptSecretstream.apply(this, arguments);
|
|
167
|
+
}
|
|
168
|
+
|
|
169
|
+
export function decryptSecretstream(_x5, _x6, _x7, _x8) {
|
|
170
|
+
return _decryptSecretstream.apply(this, arguments);
|
|
171
|
+
} // async function mainSecretstream(random: Uint8Array): Promise<void> {
|
|
172
|
+
// const key = secretstreamKeygen();
|
|
173
|
+
// console.time("secretstream_encrypt");
|
|
174
|
+
// const crypted = encryptSecretstream(key, random);
|
|
175
|
+
// console.timeEnd("secretstream_encrypt");
|
|
176
|
+
// console.time("secretstream_decrypt");
|
|
177
|
+
// const decrypted = decryptSecretstream(key, crypted);
|
|
178
|
+
// console.timeEnd("secretstream_decrypt");
|
|
179
|
+
// const first = to_hex(random).slice(0, 32);
|
|
180
|
+
// const final = to_hex(decrypted).slice(0, 32);
|
|
181
|
+
// console.log({
|
|
182
|
+
// first,
|
|
183
|
+
// final,
|
|
184
|
+
// equals: first === final
|
|
185
|
+
// });
|
|
186
|
+
// }
|
|
187
|
+
// async function mainSecretbox(random: Uint8Array): Promise<void> {
|
|
188
|
+
// const key = generateSecretBox();
|
|
189
|
+
// console.time("secretbox_encrypt");
|
|
190
|
+
// const crypted = encryptFile(random, key);
|
|
191
|
+
// console.timeEnd("secretbox_encrypt");
|
|
192
|
+
// console.time("secretbox_decrypt");
|
|
193
|
+
// const decrypted = decryptFile(crypted, key);
|
|
194
|
+
// console.timeEnd("secretbox_decrypt");
|
|
195
|
+
// const first = to_hex(random).slice(0, 32);
|
|
196
|
+
// const final = to_hex(decrypted).slice(0, 32);
|
|
197
|
+
// console.log({
|
|
198
|
+
// first,
|
|
199
|
+
// final,
|
|
200
|
+
// equals: first === final
|
|
201
|
+
// });
|
|
202
|
+
// }
|
|
203
|
+
// async function main(): Promise<void> {
|
|
204
|
+
// await ready;
|
|
205
|
+
// console.time("randombytes_buf");
|
|
206
|
+
// const random = randombytes_buf(1_000_000 * 1024);
|
|
207
|
+
// console.timeEnd("randombytes_buf");
|
|
208
|
+
// await Promise.all([mainSecretstream(random), mainSecretbox(random)]);
|
|
209
|
+
// }
|
|
210
|
+
// main();
|
|
211
|
+
|
|
212
|
+
function _decryptSecretstream() {
|
|
213
|
+
_decryptSecretstream = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee2(key, data, progress, abort) {
|
|
214
|
+
var header, _decrypt, decryptt, destroy, chunkSize, max, final, total, lastPercent, _iterator2, _step2, chunk, tmp, percent;
|
|
215
|
+
|
|
216
|
+
return _regeneratorRuntime.wrap(function _callee2$(_context2) {
|
|
217
|
+
while (1) {
|
|
218
|
+
switch (_context2.prev = _context2.next) {
|
|
219
|
+
case 0:
|
|
220
|
+
_context2.next = 2;
|
|
221
|
+
return setup();
|
|
222
|
+
|
|
223
|
+
case 2:
|
|
224
|
+
header = data.slice(0, sodium.crypto_secretstream_xchacha20poly1305_HEADERBYTES);
|
|
225
|
+
data = data.slice(sodium.crypto_secretstream_xchacha20poly1305_HEADERBYTES);
|
|
226
|
+
_decrypt = decrypt(header, key), decryptt = _decrypt.decrypt, destroy = _decrypt.destroy;
|
|
227
|
+
chunkSize = CHUNK_SIZE + sodium.crypto_secretstream_xchacha20poly1305_ABYTES;
|
|
228
|
+
max = Math.ceil(data.byteLength / chunkSize) * CHUNK_SIZE;
|
|
229
|
+
progress == null ? void 0 : progress({
|
|
230
|
+
percent: 0,
|
|
231
|
+
total: max,
|
|
232
|
+
current: 0
|
|
233
|
+
});
|
|
234
|
+
final = new Uint8Array(max);
|
|
235
|
+
total = 0;
|
|
236
|
+
lastPercent = total / max;
|
|
237
|
+
_iterator2 = _createForOfIteratorHelperLoose(chunks(data, chunkSize));
|
|
238
|
+
|
|
239
|
+
case 12:
|
|
240
|
+
if ((_step2 = _iterator2()).done) {
|
|
241
|
+
_context2.next = 23;
|
|
242
|
+
break;
|
|
243
|
+
}
|
|
244
|
+
|
|
245
|
+
chunk = _step2.value;
|
|
246
|
+
|
|
247
|
+
if (!(abort != null && abort.signal.aborted)) {
|
|
248
|
+
_context2.next = 16;
|
|
249
|
+
break;
|
|
250
|
+
}
|
|
251
|
+
|
|
252
|
+
throw new Error("Decrypt aborted");
|
|
253
|
+
|
|
254
|
+
case 16:
|
|
255
|
+
tmp = decryptt(chunk);
|
|
256
|
+
final.set(tmp.message, total);
|
|
257
|
+
total += tmp.message.byteLength;
|
|
258
|
+
percent = total / max;
|
|
259
|
+
|
|
260
|
+
if (percent > lastPercent + 0.01) {
|
|
261
|
+
progress == null ? void 0 : progress({
|
|
262
|
+
percent: percent,
|
|
263
|
+
total: max,
|
|
264
|
+
current: total
|
|
265
|
+
});
|
|
266
|
+
lastPercent = percent;
|
|
267
|
+
}
|
|
268
|
+
|
|
269
|
+
case 21:
|
|
270
|
+
_context2.next = 12;
|
|
271
|
+
break;
|
|
272
|
+
|
|
273
|
+
case 23:
|
|
274
|
+
destroy();
|
|
275
|
+
progress == null ? void 0 : progress({
|
|
276
|
+
percent: 1,
|
|
277
|
+
total: total,
|
|
278
|
+
current: total
|
|
279
|
+
});
|
|
280
|
+
return _context2.abrupt("return", final.slice(0, total));
|
|
281
|
+
|
|
282
|
+
case 26:
|
|
283
|
+
case "end":
|
|
284
|
+
return _context2.stop();
|
|
285
|
+
}
|
|
286
|
+
}
|
|
287
|
+
}, _callee2);
|
|
288
|
+
}));
|
|
289
|
+
return _decryptSecretstream.apply(this, arguments);
|
|
290
|
+
}
|
|
291
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/crypto/file.ts"],"names":["setup","sodium","SparkMD5","chunks","assert","c","message","Error","secretstreamKeygen","crypto_secretstream_xchacha20poly1305_keygen","encrypt","key","destroyed","crypto_secretstream_xchacha20poly1305_init_push","state","header","tag","plaintext","crypto_secretstream_xchacha20poly1305_push","destroy","decrypt","byteLength","crypto_secretstream_xchacha20poly1305_HEADERBYTES","crypto_secretstream_xchacha20poly1305_KEYBYTES","crypto_secretstream_xchacha20poly1305_init_pull","ciphertext","crypto_secretstream_xchacha20poly1305_pull","CHUNK_SIZE","encryptSecretstream","data","progress","abort","crypt","cryptedChunk","crypto_secretstream_xchacha20poly1305_ABYTES","max","Math","ceil","percent","total","current","final","Uint8Array","sparkEncrypted","ArrayBuffer","spark","set","append","lastPercent","chunk","signal","aborted","length","crypto_secretstream_xchacha20poly1305_TAG_FINAL","crypto_secretstream_xchacha20poly1305_TAG_MESSAGE","crypted","slice","md5Encrypted","end","md5","decryptSecretstream","decryptt","chunkSize","tmp"],"mappings":"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","sourcesContent":["import type { MessageTag } from \"libsodium-wrappers\";\nimport { setup, sodium } from \"../sodium.js\";\nimport SparkMD5 from \"spark-md5\";\nimport { chunks } from \"../utils.js\";\n\nexport type EncryptedFile = {\n  data: Uint8Array;\n  md5: string;\n  md5Encrypted: string;\n};\n\nfunction assert(c: boolean, message: string): void {\n  if (!c) {\n    throw new Error(message);\n  }\n}\n\ntype EncryptFn = (tag: number, plaintext: Uint8Array) => Uint8Array;\n\ntype DecryptFn = (ciphertext: Uint8Array) => MessageTag;\n\nexport function secretstreamKeygen(): Uint8Array {\n  return sodium.crypto_secretstream_xchacha20poly1305_keygen();\n}\n\nfunction encrypt(key: Uint8Array): {\n  destroy: () => void;\n  encrypt: EncryptFn;\n  header: Uint8Array;\n} {\n  let destroyed = false;\n  const { state, header } =\n    sodium.crypto_secretstream_xchacha20poly1305_init_push(key);\n\n  const encrypt: EncryptFn = (tag, plaintext) => {\n    assert(destroyed === false, \"state already destroyed\");\n\n    return sodium.crypto_secretstream_xchacha20poly1305_push(\n      state,\n      plaintext,\n      null,\n      tag\n    );\n  };\n\n  function destroy(): void {\n    assert(destroyed === false, \"state already destroyed\");\n    destroyed = true;\n  }\n\n  return {\n    encrypt,\n    destroy,\n    header\n  };\n}\n\nfunction decrypt(\n  header: Uint8Array,\n  key: Uint8Array\n): {\n  destroy: () => void;\n  decrypt: DecryptFn;\n} {\n  assert(\n    header.byteLength >=\n      sodium.crypto_secretstream_xchacha20poly1305_HEADERBYTES,\n    `header must be at least HEADERBYTES (${sodium.crypto_secretstream_xchacha20poly1305_HEADERBYTES}) long`\n  );\n  assert(\n    key.byteLength >= sodium.crypto_secretstream_xchacha20poly1305_KEYBYTES,\n    `key must be at least KEYBYTES (${sodium.crypto_secretstream_xchacha20poly1305_KEYBYTES}) long`\n  );\n\n  let destroyed = false;\n  const state = sodium.crypto_secretstream_xchacha20poly1305_init_pull(\n    header,\n    key\n  );\n\n  const decrypt: DecryptFn = ciphertext => {\n    assert(destroyed === false, \"state already destroyed\");\n\n    return sodium.crypto_secretstream_xchacha20poly1305_pull(state, ciphertext);\n  };\n\n  function destroy(): void {\n    assert(destroyed === false, \"state already destroyed\");\n    destroyed = true;\n  }\n\n  return {\n    decrypt,\n    destroy\n  };\n}\n\nexport const CHUNK_SIZE = 8192;\n\nexport type Progress = {\n  percent: number;\n  total: number;\n  current: number;\n};\n\nexport async function encryptSecretstream(\n  key: Uint8Array,\n  data: Uint8Array,\n  progress?: (progress: Progress) => Promise<void>,\n  abort?: AbortController\n): Promise<EncryptedFile> {\n  await setup();\n  const { encrypt: crypt, destroy, header } = encrypt(key);\n  const cryptedChunk =\n    CHUNK_SIZE + sodium.crypto_secretstream_xchacha20poly1305_ABYTES;\n  const max =\n    Math.ceil(data.byteLength / CHUNK_SIZE) * cryptedChunk + header.byteLength;\n\n  progress?.({\n    percent: 0,\n    total: max,\n    current: 0\n  });\n  const final = new Uint8Array(max);\n  const sparkEncrypted = new SparkMD5.ArrayBuffer();\n  const spark = new SparkMD5.ArrayBuffer();\n\n  final.set(header);\n  sparkEncrypted.append(header);\n  let total = header.byteLength;\n  progress?.({\n    percent: total / max,\n    total: max,\n    current: total\n  });\n  let lastPercent = total / max;\n\n  for (const chunk of chunks(data, CHUNK_SIZE)) {\n    if (abort?.signal.aborted) {\n      throw new Error(`Encrypt aborted`);\n    }\n    spark.append(chunk);\n    const tag =\n      chunk.length < CHUNK_SIZE\n        ? sodium.crypto_secretstream_xchacha20poly1305_TAG_FINAL\n        : sodium.crypto_secretstream_xchacha20poly1305_TAG_MESSAGE;\n    const crypted = crypt(tag, chunk);\n    sparkEncrypted.append(crypted);\n    final.set(crypted, total);\n    total += crypted.byteLength;\n    const percent = total / max;\n    if (percent > lastPercent + 0.01) {\n      progress?.({\n        percent,\n        total: max,\n        current: total\n      });\n      lastPercent = percent;\n    }\n  }\n\n  destroy();\n  progress?.({\n    percent: 1,\n    total,\n    current: total\n  });\n  return {\n    data: final.slice(0, total),\n    md5Encrypted: sparkEncrypted.end(),\n    md5: spark.end()\n  };\n}\n\nexport async function decryptSecretstream(\n  key: Uint8Array,\n  data: Uint8Array,\n  progress?: (progress: Progress) => Promise<void>,\n  abort?: AbortController\n): Promise<Uint8Array> {\n  await setup();\n  const header = data.slice(\n    0,\n    sodium.crypto_secretstream_xchacha20poly1305_HEADERBYTES\n  );\n  data = data.slice(sodium.crypto_secretstream_xchacha20poly1305_HEADERBYTES);\n\n  const { decrypt: decryptt, destroy } = decrypt(header, key);\n  const chunkSize =\n    CHUNK_SIZE + sodium.crypto_secretstream_xchacha20poly1305_ABYTES;\n  const max = Math.ceil(data.byteLength / chunkSize) * CHUNK_SIZE;\n\n  progress?.({\n    percent: 0,\n    total: max,\n    current: 0\n  });\n  const final = new Uint8Array(max);\n  let total = 0;\n\n  let lastPercent = total / max;\n\n  for (const chunk of chunks(data, chunkSize)) {\n    if (abort?.signal.aborted) {\n      throw new Error(`Decrypt aborted`);\n    }\n    const tmp = decryptt(chunk);\n    final.set(tmp.message, total);\n    total += tmp.message.byteLength;\n    const percent = total / max;\n    if (percent > lastPercent + 0.01) {\n      progress?.({\n        percent,\n        total: max,\n        current: total\n      });\n      lastPercent = percent;\n    }\n  }\n\n  destroy();\n  progress?.({\n    percent: 1,\n    total,\n    current: total\n  });\n  return final.slice(0, total);\n}\n\n// async function mainSecretstream(random: Uint8Array): Promise<void> {\n//   const key = secretstreamKeygen();\n//   console.time(\"secretstream_encrypt\");\n//   const crypted = encryptSecretstream(key, random);\n//   console.timeEnd(\"secretstream_encrypt\");\n//   console.time(\"secretstream_decrypt\");\n//   const decrypted = decryptSecretstream(key, crypted);\n//   console.timeEnd(\"secretstream_decrypt\");\n//   const first = to_hex(random).slice(0, 32);\n//   const final = to_hex(decrypted).slice(0, 32);\n//   console.log({\n//     first,\n//     final,\n//     equals: first === final\n//   });\n// }\n// async function mainSecretbox(random: Uint8Array): Promise<void> {\n//   const key = generateSecretBox();\n//   console.time(\"secretbox_encrypt\");\n//   const crypted = encryptFile(random, key);\n//   console.timeEnd(\"secretbox_encrypt\");\n//   console.time(\"secretbox_decrypt\");\n//   const decrypted = decryptFile(crypted, key);\n//   console.timeEnd(\"secretbox_decrypt\");\n//   const first = to_hex(random).slice(0, 32);\n//   const final = to_hex(decrypted).slice(0, 32);\n//   console.log({\n//     first,\n//     final,\n//     equals: first === final\n//   });\n// }\n\n// async function main(): Promise<void> {\n//   await ready;\n//   console.time(\"randombytes_buf\");\n//   const random = randombytes_buf(1_000_000 * 1024);\n//   console.timeEnd(\"randombytes_buf\");\n//   await Promise.all([mainSecretstream(random), mainSecretbox(random)]);\n// }\n\n// main();\n"]}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
export interface KeyPair {
|
|
2
|
+
publicKey: string;
|
|
3
|
+
privateKey: string;
|
|
4
|
+
}
|
|
5
|
+
export declare function encryptCryptoBox(data: Uint8Array, publicKeyBob: string, privateKeyAlice: string): Uint8Array;
|
|
6
|
+
export declare function generateCryptoBoxKeyPair(): KeyPair;
|
|
7
|
+
export declare function decryptCryptoBox(data: Uint8Array, publicKeyAlice: string, privateKeyBob: string): Uint8Array;
|
|
8
|
+
export declare function generateSecretBoxKey(): string;
|
|
9
|
+
export declare function encryptSecretBox(data: Uint8Array, key: string): Uint8Array;
|
|
10
|
+
export declare function decryptSecretBox(data: Uint8Array, key: string): Uint8Array;
|
|
11
|
+
export declare function encryptAnonymous(data: Uint8Array, receiverPublicKey: string): Uint8Array;
|
|
12
|
+
export declare function decryptAnonymous(data: Uint8Array, { privateKey, publicKey }: KeyPair): Uint8Array;
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import { concatenate } from "../utils.js";
|
|
2
|
+
import { sodium } from "../sodium.js";
|
|
3
|
+
export function encryptCryptoBox(data, publicKeyBob, privateKeyAlice) {
|
|
4
|
+
var nonce = sodium.randombytes_buf(sodium.crypto_box_NONCEBYTES);
|
|
5
|
+
var crypt = sodium.crypto_box_easy(data, nonce, sodium.from_hex(publicKeyBob), sodium.from_hex(privateKeyAlice));
|
|
6
|
+
return concatenate(nonce, crypt);
|
|
7
|
+
}
|
|
8
|
+
export function generateCryptoBoxKeyPair() {
|
|
9
|
+
return sodium.crypto_box_keypair("hex");
|
|
10
|
+
}
|
|
11
|
+
export function decryptCryptoBox(data, publicKeyAlice, privateKeyBob) {
|
|
12
|
+
if (data.length < sodium.crypto_box_NONCEBYTES + sodium.crypto_box_MACBYTES) {
|
|
13
|
+
throw "data too short";
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
var nonce = data.slice(0, sodium.crypto_box_NONCEBYTES);
|
|
17
|
+
var cipher = data.slice(sodium.crypto_box_NONCEBYTES);
|
|
18
|
+
return sodium.crypto_box_open_easy(cipher, nonce, sodium.from_hex(publicKeyAlice), sodium.from_hex(privateKeyBob));
|
|
19
|
+
}
|
|
20
|
+
export function generateSecretBoxKey() {
|
|
21
|
+
return sodium.randombytes_buf(sodium.crypto_secretbox_KEYBYTES, "hex");
|
|
22
|
+
}
|
|
23
|
+
export function encryptSecretBox(data, key) {
|
|
24
|
+
var nonce = sodium.randombytes_buf(sodium.crypto_secretbox_NONCEBYTES);
|
|
25
|
+
var crypt = sodium.crypto_secretbox_easy(data, nonce, sodium.from_hex(key));
|
|
26
|
+
return concatenate(nonce, crypt);
|
|
27
|
+
}
|
|
28
|
+
export function decryptSecretBox(data, key) {
|
|
29
|
+
if (data.length < sodium.crypto_secretbox_NONCEBYTES + sodium.crypto_secretbox_MACBYTES) {
|
|
30
|
+
throw "data too short";
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
var nonce = data.slice(0, sodium.crypto_secretbox_NONCEBYTES);
|
|
34
|
+
var cipher = data.slice(sodium.crypto_secretbox_NONCEBYTES);
|
|
35
|
+
return sodium.crypto_secretbox_open_easy(cipher, nonce, sodium.from_hex(key));
|
|
36
|
+
}
|
|
37
|
+
export function encryptAnonymous(data, receiverPublicKey) {
|
|
38
|
+
return sodium.crypto_box_seal(data, sodium.from_hex(receiverPublicKey));
|
|
39
|
+
}
|
|
40
|
+
export function decryptAnonymous(data, _ref) {
|
|
41
|
+
var privateKey = _ref.privateKey,
|
|
42
|
+
publicKey = _ref.publicKey;
|
|
43
|
+
return sodium.crypto_box_seal_open(data, sodium.from_hex(publicKey), sodium.from_hex(privateKey));
|
|
44
|
+
}
|
|
45
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jcnlwdG8vaW5kZXgudHMiXSwibmFtZXMiOlsiY29uY2F0ZW5hdGUiLCJzb2RpdW0iLCJlbmNyeXB0Q3J5cHRvQm94IiwiZGF0YSIsInB1YmxpY0tleUJvYiIsInByaXZhdGVLZXlBbGljZSIsIm5vbmNlIiwicmFuZG9tYnl0ZXNfYnVmIiwiY3J5cHRvX2JveF9OT05DRUJZVEVTIiwiY3J5cHQiLCJjcnlwdG9fYm94X2Vhc3kiLCJmcm9tX2hleCIsImdlbmVyYXRlQ3J5cHRvQm94S2V5UGFpciIsImNyeXB0b19ib3hfa2V5cGFpciIsImRlY3J5cHRDcnlwdG9Cb3giLCJwdWJsaWNLZXlBbGljZSIsInByaXZhdGVLZXlCb2IiLCJsZW5ndGgiLCJjcnlwdG9fYm94X01BQ0JZVEVTIiwic2xpY2UiLCJjaXBoZXIiLCJjcnlwdG9fYm94X29wZW5fZWFzeSIsImdlbmVyYXRlU2VjcmV0Qm94S2V5IiwiY3J5cHRvX3NlY3JldGJveF9LRVlCWVRFUyIsImVuY3J5cHRTZWNyZXRCb3giLCJrZXkiLCJjcnlwdG9fc2VjcmV0Ym94X05PTkNFQllURVMiLCJjcnlwdG9fc2VjcmV0Ym94X2Vhc3kiLCJkZWNyeXB0U2VjcmV0Qm94IiwiY3J5cHRvX3NlY3JldGJveF9NQUNCWVRFUyIsImNyeXB0b19zZWNyZXRib3hfb3Blbl9lYXN5IiwiZW5jcnlwdEFub255bW91cyIsInJlY2VpdmVyUHVibGljS2V5IiwiY3J5cHRvX2JveF9zZWFsIiwiZGVjcnlwdEFub255bW91cyIsInByaXZhdGVLZXkiLCJwdWJsaWNLZXkiLCJjcnlwdG9fYm94X3NlYWxfb3BlbiJdLCJtYXBwaW5ncyI6IkFBQUEsU0FBU0EsV0FBVCxRQUE0QixhQUE1QjtBQUNBLFNBQVNDLE1BQVQsUUFBdUIsY0FBdkI7QUFPQSxPQUFPLFNBQVNDLGdCQUFULENBQ0xDLElBREssRUFFTEMsWUFGSyxFQUdMQyxlQUhLLEVBSU87QUFDWixNQUFNQyxLQUFLLEdBQUdMLE1BQU0sQ0FBQ00sZUFBUCxD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LE1BREVDLFNBQ0YsUUFERUEsU0FDRjtBQUNaLFNBQU9uQyxNQUFNLENBQUNvQyxvQkFBUCxDQUNMbEMsSUFESyxFQUVMRixNQUFNLENBQUNVLFFBQVAsQ0FBZ0J5QixTQUFoQixDQUZLLEVBR0xuQyxNQUFNLENBQUNVLFFBQVAsQ0FBZ0J3QixVQUFoQixDQUhLLENBQVA7QUFLRCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNvbmNhdGVuYXRlIH0gZnJvbSBcIi4uL3V0aWxzLmpzXCI7XG5pbXBvcnQgeyBzb2RpdW0gfSBmcm9tIFwiLi4vc29kaXVtLmpzXCI7XG5cbmV4cG9ydCBpbnRlcmZhY2UgS2V5UGFpciB7XG4gIHB1YmxpY0tleTogc3RyaW5nO1xuICBwcml2YXRlS2V5OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBlbmNyeXB0Q3J5cHRvQm94KFxuICBkYXRhOiBVaW50OEFycmF5LFxuICBwdWJsaWNLZXlCb2I6IHN0cmluZyxcbiAgcHJpdmF0ZUtleUFsaWNlOiBzdHJpbmdcbik6IFVpbnQ4QXJyYXkge1xuICBjb25zdCBub25jZSA9IHNvZGl1bS5yYW5kb21ieXRlc19idWYoc29kaXVtLmNyeXB0b19ib3hfTk9OQ0VCWVRFUyk7XG4gIGNvbnN0IGNyeXB0ID0gc29kaXVtLmNyeXB0b19ib3hfZWFzeShcbiAgICBkYXRhLFxuICAgIG5vbmNlLFxuICAgIHNvZGl1bS5mcm9tX2hleChwdWJsaWNLZXlCb2IpLFxuICAgIHNvZGl1bS5mcm9tX2hleChwcml2YXRlS2V5QWxpY2UpXG4gICk7XG4gIHJldHVybiBjb25jYXRlbmF0ZShub25jZSwgY3J5cHQpO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZ2VuZXJhdGVDcnlwdG9Cb3hLZXlQYWlyKCk6IEtleVBhaXIge1xuICByZXR1cm4gc29kaXVtLmNyeXB0b19ib3hfa2V5cGFpcihcImhleFwiKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGRlY3J5cHRDcnlwdG9Cb3goXG4gIGRhdGE6IFVpbnQ4QXJyYXksXG4gIHB1YmxpY0tleUFsaWNlOiBzdHJpbmcsXG4gIHByaXZhdGVLZXlCb2I6IHN0cmluZ1xuKTogVWludDhBcnJheSB7XG4gIGlmIChkYXRhLmxlbmd0aCA8IHNvZGl1bS5jcnlwdG9fYm94X05PTkNFQllURVMgKyBzb2RpdW0uY3J5cHRvX2JveF9NQUNCWVRFUykge1xuICAgIHRocm93IFwiZGF0YSB0b28gc2hvcnRcIjtcbiAgfVxuICBjb25zdCBub25jZSA9IGRhdGEuc2xpY2UoMCwgc29kaXVtLmNyeXB0b19ib3hfTk9OQ0VCWVRFUyk7XG4gIGNvbnN0IGNpcGhlciA9IGRhdGEuc2xpY2Uoc29kaXVtLmNyeXB0b19ib3hfTk9OQ0VCWVRFUyk7XG4gIHJldHVybiBzb2RpdW0uY3J5cHRvX2JveF9vcGVuX2Vhc3koXG4gICAgY2lwaGVyLFxuICAgIG5vbmNlLFxuICAgIHNvZGl1bS5mcm9tX2hleChwdWJsaWNLZXlBbGljZSksXG4gICAgc29kaXVtLmZyb21faGV4KHByaXZhdGVLZXlCb2IpXG4gICk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBnZW5lcmF0ZVNlY3JldEJveEtleSgpOiBzdHJpbmcge1xuICByZXR1cm4gc29kaXVtLnJhbmRvbWJ5dGVzX2J1Zihzb2RpdW0uY3J5cHRvX3NlY3JldGJveF9LRVlCWVRFUywgXCJoZXhcIik7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBlbmNyeXB0U2VjcmV0Qm94KGRhdGE6IFVpbnQ4QXJyYXksIGtleTogc3RyaW5nKTogVWludDhBcnJheSB7XG4gIGNvbnN0IG5vbmNlID0gc29kaXVtLnJhbmRvbWJ5dGVzX2J1Zihzb2RpdW0uY3J5cHRvX3NlY3JldGJveF9OT05DRUJZVEVTKTtcbiAgY29uc3QgY3J5cHQgPSBzb2RpdW0uY3J5cHRvX3NlY3JldGJveF9lYXN5KGRhdGEsIG5vbmNlLCBzb2RpdW0uZnJvbV9oZXgoa2V5KSk7XG4gIHJldHVybiBjb25jYXRlbmF0ZShub25jZSwgY3J5cHQpO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZGVjcnlwdFNlY3JldEJveChkYXRhOiBVaW50OEFycmF5LCBrZXk6IHN0cmluZyk6IFVpbnQ4QXJyYXkge1xuICBpZiAoXG4gICAgZGF0YS5sZW5ndGggPFxuICAgIHNvZGl1bS5jcnlwdG9fc2VjcmV0Ym94X05PTkNFQllURVMgKyBzb2RpdW0uY3J5cHRvX3NlY3JldGJveF9NQUNCWVRFU1xuICApIHtcbiAgICB0aHJvdyBcImRhdGEgdG9vIHNob3J0XCI7XG4gIH1cbiAgY29uc3Qgbm9uY2UgPSBkYXRhLnNsaWNlKDAsIHNvZGl1bS5jcnlwdG9fc2VjcmV0Ym94X05PTkNFQllURVMpO1xuICBjb25zdCBjaXBoZXIgPSBkYXRhLnNsaWNlKHNvZGl1bS5jcnlwdG9fc2VjcmV0Ym94X05PTkNFQllURVMpO1xuICByZXR1cm4gc29kaXVtLmNyeXB0b19zZWNyZXRib3hfb3Blbl9lYXN5KGNpcGhlciwgbm9uY2UsIHNvZGl1bS5mcm9tX2hleChrZXkpKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGVuY3J5cHRBbm9ueW1vdXMoXG4gIGRhdGE6IFVpbnQ4QXJyYXksXG4gIHJlY2VpdmVyUHVibGljS2V5OiBzdHJpbmdcbik6IFVpbnQ4QXJyYXkge1xuICByZXR1cm4gc29kaXVtLmNyeXB0b19ib3hfc2VhbChkYXRhLCBzb2RpdW0uZnJvbV9oZXgocmVjZWl2ZXJQdWJsaWNLZXkpKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGRlY3J5cHRBbm9ueW1vdXMoXG4gIGRhdGE6IFVpbnQ4QXJyYXksXG4gIHsgcHJpdmF0ZUtleSwgcHVibGljS2V5IH06IEtleVBhaXJcbik6IFVpbnQ4QXJyYXkge1xuICByZXR1cm4gc29kaXVtLmNyeXB0b19ib3hfc2VhbF9vcGVuKFxuICAgIGRhdGEsXG4gICAgc29kaXVtLmZyb21faGV4KHB1YmxpY0tleSksXG4gICAgc29kaXVtLmZyb21faGV4KHByaXZhdGVLZXkpXG4gICk7XG59XG4iXX0=
|
package/dist/error.d.ts
ADDED
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
export declare type ErrorType = "ErrorUpgradePlan" | "ErrorNotFound" | "ErrorNotExist" | "ErrorAccessDenied" | "ErrorLangNotExist" | "ErrorLimit" | "ErrorBasic";
|
|
2
|
+
export interface ErrorBase {
|
|
3
|
+
message: string;
|
|
4
|
+
__typename: ErrorType;
|
|
5
|
+
}
|
|
6
|
+
export interface ErrorUpgradePlan extends ErrorBase {
|
|
7
|
+
__typename: "ErrorUpgradePlan";
|
|
8
|
+
}
|
|
9
|
+
export interface ErrorNotFound extends ErrorBase {
|
|
10
|
+
__typename: "ErrorNotFound";
|
|
11
|
+
field?: string | undefined;
|
|
12
|
+
}
|
|
13
|
+
export interface ErrorNotExist extends ErrorBase {
|
|
14
|
+
__typename: "ErrorNotExist";
|
|
15
|
+
field?: string | undefined;
|
|
16
|
+
}
|
|
17
|
+
export interface ErrorAccessDenied extends ErrorBase {
|
|
18
|
+
__typename: "ErrorAccessDenied";
|
|
19
|
+
}
|
|
20
|
+
export interface ErrorLangNotExist extends ErrorBase {
|
|
21
|
+
__typename: "ErrorLangNotExist";
|
|
22
|
+
}
|
|
23
|
+
export interface ErrorLimit extends ErrorBase {
|
|
24
|
+
__typename: "ErrorLimit";
|
|
25
|
+
field?: string | undefined;
|
|
26
|
+
}
|
|
27
|
+
export interface ErrorBasic extends ErrorBase {
|
|
28
|
+
__typename: "ErrorBasic";
|
|
29
|
+
}
|
|
30
|
+
export declare type SecrecyError = ErrorUpgradePlan | ErrorNotFound | ErrorNotExist | ErrorAccessDenied | ErrorLangNotExist | ErrorLimit | ErrorBasic;
|
package/dist/error.js
ADDED