@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.
Files changed (154) hide show
  1. package/dist/BaseClient.d.ts +274 -0
  2. package/dist/BaseClient.js +2227 -0
  3. package/dist/PopupTools.d.ts +17 -0
  4. package/dist/PopupTools.js +213 -0
  5. package/dist/ZeusThunder.d.ts +2 -0
  6. package/dist/ZeusThunder.js +113 -0
  7. package/dist/cache.d.ts +7 -0
  8. package/dist/cache.js +5 -0
  9. package/dist/client/admin/index.d.ts +11 -0
  10. package/dist/client/admin/index.js +198 -0
  11. package/dist/client/convert/file.d.ts +5 -0
  12. package/dist/client/convert/file.js +39 -0
  13. package/dist/client/convert/folder.d.ts +8 -0
  14. package/dist/client/convert/folder.js +264 -0
  15. package/dist/client/convert/mail.d.ts +3 -0
  16. package/dist/client/convert/mail.js +46 -0
  17. package/dist/client/convert/vFile.d.ts +5 -0
  18. package/dist/client/convert/vFile.js +164 -0
  19. package/dist/client/helpers.d.ts +23 -0
  20. package/dist/client/helpers.js +114 -0
  21. package/dist/client/index.d.ts +172 -0
  22. package/dist/client/index.js +6169 -0
  23. package/dist/client/storage.d.ts +7 -0
  24. package/dist/client/storage.js +12 -0
  25. package/dist/client/types/File.d.ts +21 -0
  26. package/dist/client/types/File.js +3 -0
  27. package/dist/client/types/FilesOnUsersOnApplications.d.ts +9 -0
  28. package/dist/client/types/FilesOnUsersOnApplications.js +3 -0
  29. package/dist/client/types/Folder.d.ts +68 -0
  30. package/dist/client/types/Folder.js +7 -0
  31. package/dist/client/types/Inputs.d.ts +21 -0
  32. package/dist/client/types/Inputs.js +3 -0
  33. package/dist/client/types/UserAppNotifications.d.ts +6 -0
  34. package/dist/client/types/UserAppNotifications.js +3 -0
  35. package/dist/client/types/UserAppSettings.d.ts +7 -0
  36. package/dist/client/types/UserAppSettings.js +3 -0
  37. package/dist/client/types/VFile.d.ts +62 -0
  38. package/dist/client/types/VFile.js +4 -0
  39. package/dist/client/types/index.d.ts +154 -0
  40. package/dist/client/types/index.js +10 -0
  41. package/dist/client/types/queries.d.ts +535 -0
  42. package/dist/client/types/queries.js +192 -0
  43. package/dist/crypto/file.d.ts +14 -0
  44. package/dist/crypto/file.js +291 -0
  45. package/dist/crypto/index.d.ts +12 -0
  46. package/dist/crypto/index.js +45 -0
  47. package/dist/error.d.ts +30 -0
  48. package/dist/error.js +3 -0
  49. package/dist/index.d.ts +13 -3857
  50. package/dist/index.js +42 -255
  51. package/dist/minify/index.d.ts +2 -0
  52. package/dist/minify/index.js +28 -0
  53. package/dist/minify/lz4.d.ts +5 -0
  54. package/dist/minify/lz4.js +633 -0
  55. package/dist/sodium.d.ts +3 -0
  56. package/dist/sodium.js +28 -0
  57. package/dist/utils/store-buddy.d.ts +14 -0
  58. package/dist/utils/store-buddy.js +69 -0
  59. package/dist/utils/time.d.ts +10 -0
  60. package/dist/utils/time.js +22 -0
  61. package/dist/utils.d.ts +4 -0
  62. package/dist/utils.js +188 -0
  63. package/dist/worker/__mock__/sodium.worker.d.ts +19 -0
  64. package/dist/worker/__mock__/sodium.worker.js +46 -0
  65. package/dist/worker/md5.d.ts +1 -0
  66. package/dist/worker/md5.js +43 -0
  67. package/dist/worker/sodium.d.ts +3 -0
  68. package/dist/worker/sodium.js +155 -0
  69. package/dist/worker/workerCodes.d.ts +2 -0
  70. package/dist/worker/workerCodes.js +3 -0
  71. package/dist/zeus/const.d.ts +2 -0
  72. package/dist/zeus/const.js +2267 -0
  73. package/dist/zeus/index.d.ts +4043 -0
  74. package/dist/zeus/index.js +549 -0
  75. package/package.json +23 -14
  76. package/__tests__/client/client.test.ts +0 -81
  77. package/__tests__/client/folder.test.ts +0 -302
  78. package/__tests__/client/mail.test.ts +0 -476
  79. package/__tests__/client/timing.test.ts +0 -35
  80. package/__tests__/client/utils.ts +0 -41
  81. package/__tests__/client/vFile.test.ts +0 -207
  82. package/__tests__/index.test.ts +0 -171
  83. package/commitlint.config.cjs +0 -3
  84. package/dist/index.js.map +0 -1
  85. package/dist/index.mjs +0 -255
  86. package/dist/index.mjs.map +0 -1
  87. package/docs/assets/css/main.css +0 -2660
  88. package/docs/assets/images/icons.png +0 -0
  89. package/docs/assets/images/icons@2x.png +0 -0
  90. package/docs/assets/images/widgets.png +0 -0
  91. package/docs/assets/images/widgets@2x.png +0 -0
  92. package/docs/assets/js/main.js +0 -248
  93. package/docs/assets/js/search.js +0 -1
  94. package/docs/classes/baseclient.baseclient-1.html +0 -1165
  95. package/docs/classes/client.secrecyclient.html +0 -2527
  96. package/docs/enums/index.sodium.base64_variants.html +0 -205
  97. package/docs/index.html +0 -198
  98. package/docs/interfaces/client_types.draftmail.html +0 -335
  99. package/docs/interfaces/client_types.filecontentbase.html +0 -231
  100. package/docs/interfaces/client_types.filecontentcloud.html +0 -244
  101. package/docs/interfaces/client_types.filecontentreceivedmail.html +0 -244
  102. package/docs/interfaces/client_types.filecontentsentmail.html +0 -230
  103. package/docs/interfaces/client_types.receivedmail.html +0 -363
  104. package/docs/interfaces/client_types.sentmail.html +0 -335
  105. package/docs/interfaces/crypto.keypair.html +0 -202
  106. package/docs/interfaces/index.sodium.cryptobox.html +0 -185
  107. package/docs/interfaces/index.sodium.cryptokx.html +0 -185
  108. package/docs/interfaces/index.sodium.keypair.html +0 -199
  109. package/docs/interfaces/index.sodium.messagetag.html +0 -185
  110. package/docs/interfaces/index.sodium.secretbox.html +0 -185
  111. package/docs/interfaces/index.sodium.stateaddress.html +0 -171
  112. package/docs/interfaces/index.sodium.stringcryptobox.html +0 -185
  113. package/docs/interfaces/index.sodium.stringcryptokx.html +0 -185
  114. package/docs/interfaces/index.sodium.stringkeypair.html +0 -199
  115. package/docs/interfaces/index.sodium.stringmessagetag.html +0 -185
  116. package/docs/interfaces/index.sodium.stringsecretbox.html +0 -185
  117. package/docs/interfaces/utils_store_buddy.storebuddy.html +0 -333
  118. package/docs/modules/baseclient.html +0 -929
  119. package/docs/modules/cache.html +0 -185
  120. package/docs/modules/client.html +0 -207
  121. package/docs/modules/client_convert_file.html +0 -216
  122. package/docs/modules/client_convert_folder.html +0 -303
  123. package/docs/modules/client_convert_vfile.html +0 -216
  124. package/docs/modules/client_helpers.html +0 -311
  125. package/docs/modules/client_storage.html +0 -167
  126. package/docs/modules/client_types.html +0 -1227
  127. package/docs/modules/client_types_file.html +0 -233
  128. package/docs/modules/client_types_filesonusersonapplications.html +0 -168
  129. package/docs/modules/client_types_folder.html +0 -383
  130. package/docs/modules/client_types_inputs.html +0 -263
  131. package/docs/modules/client_types_mail.html +0 -181
  132. package/docs/modules/client_types_queries.html +0 -199
  133. package/docs/modules/client_types_userappsettings.html +0 -163
  134. package/docs/modules/client_types_vfile.html +0 -364
  135. package/docs/modules/crypto.html +0 -366
  136. package/docs/modules/crypto_file.html +0 -344
  137. package/docs/modules/index.html +0 -779
  138. package/docs/modules/index.sodium.html +0 -6039
  139. package/docs/modules/minify.html +0 -183
  140. package/docs/modules/minify_lz4.html +0 -279
  141. package/docs/modules/popuptools.html +0 -259
  142. package/docs/modules/sodium.html +0 -167
  143. package/docs/modules/utils.html +0 -219
  144. package/docs/modules/utils_store_buddy.html +0 -208
  145. package/docs/modules/utils_time.html +0 -330
  146. package/docs/modules/worker_md5.html +0 -156
  147. package/docs/modules/worker_sodium.html +0 -231
  148. package/docs/modules/worker_workercodes.html +0 -157
  149. package/docs/modules.html +0 -235
  150. package/index.html +0 -21
  151. package/jest.config.ts +0 -27
  152. package/jest.setup.ts +0 -6
  153. package/release.config.cjs +0 -15
  154. 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":";;;;;;AAAA,OAAO,IAAMA,YAAY,GAAG;AAC1BC,EAAAA,EAAE,EAAE,IADsB;AAE1BC,EAAAA,IAAI,EAAE,IAFoB;AAG1BC,EAAAA,UAAU,EAAE,IAHc;AAI1BC,EAAAA,SAAS,EAAE,IAJe;AAK1BC,EAAAA,GAAG,EAAE,IALqB;AAM1BC,EAAAA,YAAY,EAAE,IANY;AAO1BC,EAAAA,IAAI,EAAE;AACJC,IAAAA,GAAG,EAAE,IADD;AAEJC,IAAAA,OAAO,EAAE;AACPC,MAAAA,OAAO,EAAE;AACPC,QAAAA,GAAG,EAAE;AADE;AADF;AAFL;AAPoB,CAArB;AAiBP,OAAO,IAAMC,aAAa,GAAG;AAC3BX,EAAAA,EAAE,EAAE,IADuB;AAE3BY,EAAAA,QAAQ,EAAE,IAFiB;AAG3BC,EAAAA,SAAS,EAAE;AACTP,IAAAA,IAAI,EAAE;AACJN,MAAAA,EAAE,EAAE,IADA;AAEJc,MAAAA,SAAS,EAAE,IAFP;AAGJC,MAAAA,QAAQ,EAAE,IAHN;AAIJC,MAAAA,KAAK,EAAE,IAJH;AAKJC,MAAAA,SAAS,EAAE;AALP;AADG,GAHgB;AAY3BC,EAAAA,QAAQ,EAAE;AACRC,IAAAA,MAAM,EAAE,IADA;AAERC,IAAAA,MAAM,EAAE,IAFA;AAGRZ,IAAAA,OAAO,EAAE;AACPF,MAAAA,IAAI,EAAE;AACJN,QAAAA,EAAE,EAAE,IADA;AAEJc,QAAAA,SAAS,EAAE,IAFP;AAGJC,QAAAA,QAAQ,EAAE,IAHN;AAIJC,QAAAA,KAAK,EAAE,IAJH;AAKJC,QAAAA,SAAS,EAAE;AALP;AADC;AAHD,GAZiB;AAyB3BT,EAAAA,OAAO,EAAE;AACPA,IAAAA,OAAO,EAAE;AACPF,MAAAA,IAAI,EAAE;AACJN,QAAAA,EAAE,EAAE;AADA;AADC,KADF;AAMPqB,IAAAA,OAAO,EAAE,IANF;AAOPF,IAAAA,MAAM,EAAE,IAPD;AAQPC,IAAAA,MAAM,EAAE;AARD,GAzBkB;AAmC3BE,EAAAA,UAAU,EAAE,IAnCe;AAoC3BnB,EAAAA,SAAS,EAAE,IApCgB;AAqC3BoB,EAAAA,SAAS,EAAE,IArCgB;AAsC3BC,EAAAA,SAAS,EAAE,IAtCgB;AAuC3BC,EAAAA,OAAO,oBACF1B,YADE,CAvCoB;AA0C3B2B,EAAAA,OAAO,oBACF3B,YADE;AA1CoB,CAAtB;AA+CP,OAAO,IAAM4B,cAAc,GAAG;AAC5B3B,EAAAA,EAAE,EAAE,IADwB;AAE5BsB,EAAAA,UAAU,EAAE,IAFgB;AAG5BnB,EAAAA,SAAS,EAAE,IAHiB;AAI5BoB,EAAAA,SAAS,EAAE,IAJiB;AAK5BC,EAAAA,SAAS,EAAE,IALiB;AAM5BI,EAAAA,IAAI,EAAE,IANsB;AAO5Bf,EAAAA,SAAS,EAAE;AACTP,IAAAA,IAAI,EAAE;AACJN,MAAAA,EAAE,EAAE,IADA;AAEJc,MAAAA,SAAS,EAAE,IAFP;AAGJC,MAAAA,QAAQ,EAAE,IAHN;AAIJC,MAAAA,KAAK,EAAE,IAJH;AAKJC,MAAAA,SAAS,EAAE;AALP;AADG,GAPiB;AAgB5BC,EAAAA,QAAQ,EAAE;AACRC,IAAAA,MAAM,EAAE,IADA;AAERC,IAAAA,MAAM,EAAE,IAFA;AAGRZ,IAAAA,OAAO,EAAE;AACPF,MAAAA,IAAI,EAAE;AACJN,QAAAA,EAAE,EAAE,IADA;AAEJc,QAAAA,SAAS,EAAE,IAFP;AAGJC,QAAAA,QAAQ,EAAE,IAHN;AAIJC,QAAAA,KAAK,EAAE,IAJH;AAKJC,QAAAA,SAAS,EAAE;AALP;AADC;AAHD,GAhBkB;AA6B5BT,EAAAA,OAAO,EAAE;AACPA,IAAAA,OAAO,EAAE;AACPF,MAAAA,IAAI,EAAE;AACJN,QAAAA,EAAE,EAAE;AADA;AADC,KADF;AAMPqB,IAAAA,OAAO,EAAE,IANF;AAOPF,IAAAA,MAAM,EAAE,IAPD;AAQPC,IAAAA,MAAM,EAAE;AARD,GA7BmB;AAuC5BS,EAAAA,UAAU,EAAE;AACV7B,IAAAA,EAAE,EAAE,IADM;AAEV4B,IAAAA,IAAI,EAAE,IAFI;AAGVP,IAAAA,OAAO,EAAE,IAHC;AAIVS,IAAAA,MAAM,EAAE;AAJE;AAvCgB,CAAvB;AA+CP,OAAO,IAAMC,kBAAkB,mCAC1BJ,cAD0B;AAE7BK,EAAAA,MAAM,oBACDrB,aADC,CAFuB;AAK7BsB,EAAAA,YAAY,EAAEN,cALe;AAM7BO,EAAAA,UAAU,EAAEP;AANiB,EAAxB;AASP,OAAO,IAAMQ,uBAAuB,mCAC/BxB,aAD+B;AAElCyB,EAAAA,MAAM,oBACDT,cADC;AAF4B,EAA7B;AAOP,OAAO,IAAMU,YAAY,GAAG;AAC1BrC,EAAAA,EAAE,EAAE,IADsB;AAE1BsC,EAAAA,IAAI,EAAE,IAFoB;AAG1BC,EAAAA,IAAI,EAAE,IAHoB;AAI1BC,EAAAA,OAAO,EAAE,IAJiB;AAK1BC,EAAAA,QAAQ,EAAE,IALgB;AAM1BtC,EAAAA,SAAS,EAAE,IANe;AAO1BoB,EAAAA,SAAS,EAAE,IAPe;AAQ1BmB,EAAAA,UAAU,EAAE;AACV1C,IAAAA,EAAE,EAAE,IADM;AAEVc,IAAAA,SAAS,EAAE,IAFD;AAGVC,IAAAA,QAAQ,EAAE,IAHA;AAIVC,IAAAA,KAAK,EAAE,IAJG;AAKVC,IAAAA,SAAS,EAAE;AALD,GARc;AAe1B0B,EAAAA,SAAS,EAAE;AACT3C,IAAAA,EAAE,EAAE,IADK;AAETc,IAAAA,SAAS,EAAE,IAFF;AAGTC,IAAAA,QAAQ,EAAE,IAHD;AAITC,IAAAA,KAAK,EAAE,IAJE;AAKTC,IAAAA,SAAS,EAAE;AALF,GAfe;AAsB1B2B,EAAAA,MAAM,EAAE;AACN5C,IAAAA,EAAE,EAAE,IADE;AAENc,IAAAA,SAAS,EAAE,IAFL;AAGNC,IAAAA,QAAQ,EAAE,IAHJ;AAINC,IAAAA,KAAK,EAAE,IAJD;AAKNC,IAAAA,SAAS,EAAE;AALL,GAtBkB;AA6B1B4B,EAAAA,aAAa,EAAE;AACbC,IAAAA,mBAAmB,EAAE;AACnB9B,MAAAA,KAAK,EAAE;AADY,KADR;AAIb0B,IAAAA,UAAU,EAAE;AACV1C,MAAAA,EAAE,EAAE,IADM;AAEVc,MAAAA,SAAS,EAAE,IAFD;AAGVC,MAAAA,QAAQ,EAAE,IAHA;AAIVC,MAAAA,KAAK,EAAE,IAJG;AAKVC,MAAAA,SAAS,EAAE;AALD,KAJC;AAWbjB,IAAAA,EAAE,EAAE,IAXS;AAYb+C,IAAAA,IAAI,EAAE,IAZO;AAabC,IAAAA,OAAO,EAAE,IAbI;AAcbC,IAAAA,OAAO,EAAE;AACPjD,MAAAA,EAAE,EAAE;AADG;AAdI,GA7BW;AA+C1BkD,EAAAA,kBAAkB,EAAE;AAClBJ,IAAAA,mBAAmB,EAAE;AACnB9B,MAAAA,KAAK,EAAE;AADY,KADH;AAIlB0B,IAAAA,UAAU,EAAE;AACV1C,MAAAA,EAAE,EAAE,IADM;AAEVc,MAAAA,SAAS,EAAE,IAFD;AAGVC,MAAAA,QAAQ,EAAE,IAHA;AAIVC,MAAAA,KAAK,EAAE,IAJG;AAKVC,MAAAA,SAAS,EAAE;AALD,KAJM;AAWlBjB,IAAAA,EAAE,EAAE,IAXc;AAYlB+C,IAAAA,IAAI,EAAE,IAZY;AAalBC,IAAAA,OAAO,EAAE,IAbS;AAclBC,IAAAA,OAAO,EAAE;AACPjD,MAAAA,EAAE,EAAE;AADG;AAdS,GA/CM;AAiE1BmD,EAAAA,KAAK,EAAE;AACLC,IAAAA,OAAO,EAAE,IADJ;AAELxC,IAAAA,QAAQ,EAAE,IAFL;AAGLyC,IAAAA,IAAI,EAAE;AACJrD,MAAAA,EAAE,EAAE;AADA;AAHD;AAjEmB,CAArB","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=
@@ -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
@@ -0,0 +1,3 @@
1
+ export {};
2
+ export {};
3
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbXX0=