@wener/common 1.0.4 → 2.0.1

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 (151) hide show
  1. package/lib/cn/DivisionCode.js +55 -32
  2. package/lib/cn/DivisionCode.test.js +140 -0
  3. package/lib/cn/Mod11Checksum.js +80 -37
  4. package/lib/cn/Mod31Checksum.js +89 -40
  5. package/lib/cn/ResidentIdentityCardNumber.js +16 -16
  6. package/lib/cn/ResidentIdentityCardNumber.test.js +21 -0
  7. package/lib/cn/UnifiedSocialCreditCode.js +32 -26
  8. package/lib/cn/UnifiedSocialCreditCode.test.js +16 -0
  9. package/lib/cn/formatDate.js +5 -7
  10. package/lib/cn/index.js +0 -1
  11. package/lib/cn/parseSex.js +0 -2
  12. package/lib/cn/types.d.js +0 -2
  13. package/lib/consola/createStandardConsolaReporter.js +18 -0
  14. package/lib/consola/formatLogObject.js +226 -0
  15. package/lib/consola/index.js +2 -0
  16. package/lib/data/formatSort.js +5 -6
  17. package/lib/data/formatSort.test.js +34 -0
  18. package/lib/data/index.js +0 -1
  19. package/lib/data/maybeNumber.js +11 -5
  20. package/lib/data/parseSort.js +28 -22
  21. package/lib/data/parseSort.test.js +188 -0
  22. package/lib/data/resolvePagination.js +27 -16
  23. package/lib/data/resolvePagination.test.js +232 -0
  24. package/lib/data/types.d.js +0 -2
  25. package/lib/index.js +0 -1
  26. package/lib/jsonschema/JsonSchema.js +80 -54
  27. package/lib/jsonschema/JsonSchema.test.js +137 -0
  28. package/lib/jsonschema/index.js +0 -1
  29. package/lib/jsonschema/types.d.js +5 -3
  30. package/lib/meta/defineFileType.js +103 -20
  31. package/lib/meta/defineInit.js +250 -31
  32. package/lib/meta/defineMetadata.js +140 -24
  33. package/lib/meta/defineMetadata.test.js +13 -0
  34. package/lib/meta/index.js +0 -1
  35. package/lib/password/PHC.js +87 -63
  36. package/lib/password/PHC.test.js +539 -0
  37. package/lib/password/Password.js +291 -29
  38. package/lib/password/Password.test.js +362 -0
  39. package/lib/password/createArgon2PasswordAlgorithm.js +191 -35
  40. package/lib/password/createBase64PasswordAlgorithm.js +141 -8
  41. package/lib/password/createBcryptPasswordAlgorithm.js +168 -13
  42. package/lib/password/createPBKDF2PasswordAlgorithm.js +228 -46
  43. package/lib/password/createScryptPasswordAlgorithm.js +211 -55
  44. package/lib/password/index.js +0 -1
  45. package/lib/password/server/index.js +0 -1
  46. package/lib/resource/Identifiable.js +1 -0
  47. package/lib/resource/getTitleOfResource.js +10 -0
  48. package/lib/resource/index.js +1 -0
  49. package/lib/resource/schema/AnyResourceSchema.js +89 -0
  50. package/lib/resource/schema/BaseResourceSchema.js +29 -0
  51. package/lib/resource/schema/ResourceActionType.js +118 -0
  52. package/lib/resource/schema/ResourceStatus.js +93 -0
  53. package/lib/resource/schema/ResourceType.js +24 -0
  54. package/lib/resource/schema/SchemaRegistry.js +38 -0
  55. package/lib/resource/schema/SexType.js +10 -0
  56. package/lib/resource/schema/types.js +89 -0
  57. package/lib/resource/schema/types.test.js +14 -0
  58. package/lib/schema/TypeSchema.d.js +1 -0
  59. package/lib/schema/createSchemaData.js +173 -0
  60. package/lib/schema/findJsonSchemaByPath.js +49 -0
  61. package/lib/schema/getSchemaCache.js +11 -0
  62. package/lib/schema/getSchemaOptions.js +24 -0
  63. package/lib/schema/index.js +5 -0
  64. package/lib/schema/toJsonSchema.js +441 -0
  65. package/lib/schema/toJsonSchema.test.js +27 -0
  66. package/lib/schema/validate.js +124 -0
  67. package/lib/search/AdvanceSearch.js +0 -1
  68. package/lib/search/AdvanceSearch.test.js +435 -0
  69. package/lib/search/formatAdvanceSearch.js +41 -27
  70. package/lib/search/index.js +0 -1
  71. package/lib/search/optimizeAdvanceSearch.js +79 -25
  72. package/lib/search/parseAdvanceSearch.js +5 -5
  73. package/lib/search/parser.d.js +0 -2
  74. package/lib/search/parser.js +97 -74
  75. package/lib/search/types.d.js +0 -2
  76. package/lib/tools/generateSchema.js +201 -0
  77. package/lib/tools/renderJsonSchemaToMarkdownDoc.js +143 -55
  78. package/package.json +30 -9
  79. package/src/consola/createStandardConsolaReporter.ts +31 -0
  80. package/src/consola/formatLogObject.ts +171 -0
  81. package/src/consola/index.ts +2 -0
  82. package/src/data/maybeNumber.ts +5 -1
  83. package/src/data/resolvePagination.test.ts +1 -1
  84. package/src/data/resolvePagination.ts +18 -7
  85. package/src/data/types.d.ts +12 -0
  86. package/src/jsonschema/JsonSchema.test.ts +17 -0
  87. package/src/jsonschema/JsonSchema.ts +4 -4
  88. package/src/jsonschema/types.d.ts +63 -12
  89. package/src/resource/Identifiable.ts +3 -0
  90. package/src/resource/getTitleOfResource.tsx +6 -0
  91. package/src/resource/index.ts +3 -0
  92. package/src/resource/schema/AnyResourceSchema.ts +113 -0
  93. package/src/resource/schema/BaseResourceSchema.ts +32 -0
  94. package/src/resource/schema/ResourceActionType.ts +123 -0
  95. package/src/resource/schema/ResourceStatus.ts +94 -0
  96. package/src/resource/schema/ResourceType.ts +25 -0
  97. package/src/resource/schema/SchemaRegistry.ts +42 -0
  98. package/src/resource/schema/SexType.ts +13 -0
  99. package/src/resource/schema/types.test.ts +18 -0
  100. package/src/resource/schema/types.ts +105 -0
  101. package/src/schema/TypeSchema.d.ts +32 -0
  102. package/src/schema/createSchemaData.ts +81 -0
  103. package/src/schema/findJsonSchemaByPath.ts +37 -0
  104. package/src/schema/getSchemaCache.ts +21 -0
  105. package/src/schema/getSchemaOptions.ts +24 -0
  106. package/src/schema/index.ts +6 -0
  107. package/src/schema/toJsonSchema.test.ts +37 -0
  108. package/src/schema/toJsonSchema.ts +200 -0
  109. package/src/schema/validate.ts +135 -0
  110. package/src/tools/generateSchema.ts +39 -0
  111. package/lib/cn/DivisionCode.js.map +0 -1
  112. package/lib/cn/Mod11Checksum.js.map +0 -1
  113. package/lib/cn/Mod31Checksum.js.map +0 -1
  114. package/lib/cn/ResidentIdentityCardNumber.js.map +0 -1
  115. package/lib/cn/UnifiedSocialCreditCode.js.map +0 -1
  116. package/lib/cn/formatDate.js.map +0 -1
  117. package/lib/cn/index.js.map +0 -1
  118. package/lib/cn/parseSex.js.map +0 -1
  119. package/lib/cn/types.d.js.map +0 -1
  120. package/lib/data/formatSort.js.map +0 -1
  121. package/lib/data/index.js.map +0 -1
  122. package/lib/data/maybeNumber.js.map +0 -1
  123. package/lib/data/parseSort.js.map +0 -1
  124. package/lib/data/resolvePagination.js.map +0 -1
  125. package/lib/data/types.d.js.map +0 -1
  126. package/lib/index.js.map +0 -1
  127. package/lib/jsonschema/JsonSchema.js.map +0 -1
  128. package/lib/jsonschema/index.js.map +0 -1
  129. package/lib/jsonschema/types.d.js.map +0 -1
  130. package/lib/meta/defineFileType.js.map +0 -1
  131. package/lib/meta/defineInit.js.map +0 -1
  132. package/lib/meta/defineMetadata.js.map +0 -1
  133. package/lib/meta/index.js.map +0 -1
  134. package/lib/password/PHC.js.map +0 -1
  135. package/lib/password/Password.js.map +0 -1
  136. package/lib/password/createArgon2PasswordAlgorithm.js.map +0 -1
  137. package/lib/password/createBase64PasswordAlgorithm.js.map +0 -1
  138. package/lib/password/createBcryptPasswordAlgorithm.js.map +0 -1
  139. package/lib/password/createPBKDF2PasswordAlgorithm.js.map +0 -1
  140. package/lib/password/createScryptPasswordAlgorithm.js.map +0 -1
  141. package/lib/password/index.js.map +0 -1
  142. package/lib/password/server/index.js.map +0 -1
  143. package/lib/search/AdvanceSearch.js.map +0 -1
  144. package/lib/search/formatAdvanceSearch.js.map +0 -1
  145. package/lib/search/index.js.map +0 -1
  146. package/lib/search/optimizeAdvanceSearch.js.map +0 -1
  147. package/lib/search/parseAdvanceSearch.js.map +0 -1
  148. package/lib/search/parser.d.js.map +0 -1
  149. package/lib/search/parser.js.map +0 -1
  150. package/lib/search/types.d.js.map +0 -1
  151. package/lib/tools/renderJsonSchemaToMarkdownDoc.js.map +0 -1
@@ -1,14 +1,147 @@
1
- import { ArrayBuffers } from "@wener/utils";
2
- export function createBase64PasswordAlgorithm({ id = 'base64' } = {}) {
1
+ function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
2
+ try {
3
+ var info = gen[key](arg);
4
+ var value = info.value;
5
+ } catch (error) {
6
+ reject(error);
7
+ return;
8
+ }
9
+ if (info.done) {
10
+ resolve(value);
11
+ } else {
12
+ Promise.resolve(value).then(_next, _throw);
13
+ }
14
+ }
15
+ function _async_to_generator(fn) {
16
+ return function() {
17
+ var self = this, args = arguments;
18
+ return new Promise(function(resolve, reject) {
19
+ var gen = fn.apply(self, args);
20
+ function _next(value) {
21
+ asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value);
22
+ }
23
+ function _throw(err) {
24
+ asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err);
25
+ }
26
+ _next(undefined);
27
+ });
28
+ };
29
+ }
30
+ function _ts_generator(thisArg, body) {
31
+ var f, y, t, _ = {
32
+ label: 0,
33
+ sent: function() {
34
+ if (t[0] & 1) throw t[1];
35
+ return t[1];
36
+ },
37
+ trys: [],
38
+ ops: []
39
+ }, g = Object.create((typeof Iterator === "function" ? Iterator : Object).prototype);
40
+ return g.next = verb(0), g["throw"] = verb(1), g["return"] = verb(2), typeof Symbol === "function" && (g[Symbol.iterator] = function() {
41
+ return this;
42
+ }), g;
43
+ function verb(n) {
44
+ return function(v) {
45
+ return step([
46
+ n,
47
+ v
48
+ ]);
49
+ };
50
+ }
51
+ function step(op) {
52
+ if (f) throw new TypeError("Generator is already executing.");
53
+ while(g && (g = 0, op[0] && (_ = 0)), _)try {
54
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
55
+ if (y = 0, t) op = [
56
+ op[0] & 2,
57
+ t.value
58
+ ];
59
+ switch(op[0]){
60
+ case 0:
61
+ case 1:
62
+ t = op;
63
+ break;
64
+ case 4:
65
+ _.label++;
66
+ return {
67
+ value: op[1],
68
+ done: false
69
+ };
70
+ case 5:
71
+ _.label++;
72
+ y = op[1];
73
+ op = [
74
+ 0
75
+ ];
76
+ continue;
77
+ case 7:
78
+ op = _.ops.pop();
79
+ _.trys.pop();
80
+ continue;
81
+ default:
82
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) {
83
+ _ = 0;
84
+ continue;
85
+ }
86
+ if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) {
87
+ _.label = op[1];
88
+ break;
89
+ }
90
+ if (op[0] === 6 && _.label < t[1]) {
91
+ _.label = t[1];
92
+ t = op;
93
+ break;
94
+ }
95
+ if (t && _.label < t[2]) {
96
+ _.label = t[2];
97
+ _.ops.push(op);
98
+ break;
99
+ }
100
+ if (t[2]) _.ops.pop();
101
+ _.trys.pop();
102
+ continue;
103
+ }
104
+ op = body.call(thisArg, _);
105
+ } catch (e) {
106
+ op = [
107
+ 6,
108
+ e
109
+ ];
110
+ y = 0;
111
+ } finally{
112
+ f = t = 0;
113
+ }
114
+ if (op[0] & 5) throw op[1];
115
+ return {
116
+ value: op[0] ? op[1] : void 0,
117
+ done: true
118
+ };
119
+ }
120
+ }
121
+ import { ArrayBuffers } from '@wener/utils';
122
+ export function createBase64PasswordAlgorithm() {
123
+ var _ref = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {}, _ref_id = _ref.id, id = _ref_id === void 0 ? 'base64' : _ref_id;
3
124
  return {
4
125
  name: id,
5
- async hash (password) {
6
- return `$${id}$$${ArrayBuffers.toBase64(password).replace(/=/g, '')}`;
126
+ hash: function hash(password) {
127
+ return _async_to_generator(function() {
128
+ return _ts_generator(this, function(_state) {
129
+ return [
130
+ 2,
131
+ "$".concat(id, "$$").concat(ArrayBuffers.toBase64(password).replace(/=/g, ''))
132
+ ];
133
+ });
134
+ })();
7
135
  },
8
- async verify (password, hash, opts) {
9
- return Boolean(opts.hash) && ArrayBuffers.toString(opts.hash) === password;
136
+ verify: function verify(password, hash, opts) {
137
+ return _async_to_generator(function() {
138
+ return _ts_generator(this, function(_state) {
139
+ return [
140
+ 2,
141
+ Boolean(opts.hash) && ArrayBuffers.toString(opts.hash) === password
142
+ ];
143
+ });
144
+ })();
10
145
  }
11
146
  };
12
147
  }
13
-
14
- //# sourceMappingURL=createBase64PasswordAlgorithm.js.map
@@ -1,20 +1,175 @@
1
- export function createBcryptPasswordAlgorithm({ // provider = () => import('bcrypt').then((v) => v.default),
2
- provider = ()=>import("bcryptjs").then((v)=>v.default) } = {}) {
1
+ function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
2
+ try {
3
+ var info = gen[key](arg);
4
+ var value = info.value;
5
+ } catch (error) {
6
+ reject(error);
7
+ return;
8
+ }
9
+ if (info.done) {
10
+ resolve(value);
11
+ } else {
12
+ Promise.resolve(value).then(_next, _throw);
13
+ }
14
+ }
15
+ function _async_to_generator(fn) {
16
+ return function() {
17
+ var self = this, args = arguments;
18
+ return new Promise(function(resolve, reject) {
19
+ var gen = fn.apply(self, args);
20
+ function _next(value) {
21
+ asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value);
22
+ }
23
+ function _throw(err) {
24
+ asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err);
25
+ }
26
+ _next(undefined);
27
+ });
28
+ };
29
+ }
30
+ function _ts_generator(thisArg, body) {
31
+ var f, y, t, _ = {
32
+ label: 0,
33
+ sent: function() {
34
+ if (t[0] & 1) throw t[1];
35
+ return t[1];
36
+ },
37
+ trys: [],
38
+ ops: []
39
+ }, g = Object.create((typeof Iterator === "function" ? Iterator : Object).prototype);
40
+ return g.next = verb(0), g["throw"] = verb(1), g["return"] = verb(2), typeof Symbol === "function" && (g[Symbol.iterator] = function() {
41
+ return this;
42
+ }), g;
43
+ function verb(n) {
44
+ return function(v) {
45
+ return step([
46
+ n,
47
+ v
48
+ ]);
49
+ };
50
+ }
51
+ function step(op) {
52
+ if (f) throw new TypeError("Generator is already executing.");
53
+ while(g && (g = 0, op[0] && (_ = 0)), _)try {
54
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
55
+ if (y = 0, t) op = [
56
+ op[0] & 2,
57
+ t.value
58
+ ];
59
+ switch(op[0]){
60
+ case 0:
61
+ case 1:
62
+ t = op;
63
+ break;
64
+ case 4:
65
+ _.label++;
66
+ return {
67
+ value: op[1],
68
+ done: false
69
+ };
70
+ case 5:
71
+ _.label++;
72
+ y = op[1];
73
+ op = [
74
+ 0
75
+ ];
76
+ continue;
77
+ case 7:
78
+ op = _.ops.pop();
79
+ _.trys.pop();
80
+ continue;
81
+ default:
82
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) {
83
+ _ = 0;
84
+ continue;
85
+ }
86
+ if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) {
87
+ _.label = op[1];
88
+ break;
89
+ }
90
+ if (op[0] === 6 && _.label < t[1]) {
91
+ _.label = t[1];
92
+ t = op;
93
+ break;
94
+ }
95
+ if (t && _.label < t[2]) {
96
+ _.label = t[2];
97
+ _.ops.push(op);
98
+ break;
99
+ }
100
+ if (t[2]) _.ops.pop();
101
+ _.trys.pop();
102
+ continue;
103
+ }
104
+ op = body.call(thisArg, _);
105
+ } catch (e) {
106
+ op = [
107
+ 6,
108
+ e
109
+ ];
110
+ y = 0;
111
+ } finally{
112
+ f = t = 0;
113
+ }
114
+ if (op[0] & 5) throw op[1];
115
+ return {
116
+ value: op[0] ? op[1] : void 0,
117
+ done: true
118
+ };
119
+ }
120
+ }
121
+ export function createBcryptPasswordAlgorithm() {
122
+ var _ref = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {}, _ref_provider = _ref.// provider = () => import('bcrypt').then((v) => v.default),
123
+ provider, provider = _ref_provider === void 0 ? function() {
124
+ return import('bcryptjs').then(function(v) {
125
+ return v.default;
126
+ });
127
+ } : _ref_provider;
3
128
  // bcrypt or bcryptjs
4
129
  return {
5
130
  name: 'bcrypt',
6
- async hash (password, opts) {
7
- const { hash } = await provider();
8
- return hash(password, opts?.rounds ?? 10);
131
+ hash: function hash(password, opts) {
132
+ return _async_to_generator(function() {
133
+ var hash, _opts_rounds;
134
+ return _ts_generator(this, function(_state) {
135
+ switch(_state.label){
136
+ case 0:
137
+ return [
138
+ 4,
139
+ provider()
140
+ ];
141
+ case 1:
142
+ hash = _state.sent().hash;
143
+ return [
144
+ 2,
145
+ hash(password, (_opts_rounds = opts === null || opts === void 0 ? void 0 : opts.rounds) !== null && _opts_rounds !== void 0 ? _opts_rounds : 10)
146
+ ];
147
+ }
148
+ });
149
+ })();
9
150
  },
10
- async verify (password, hash) {
11
- const { compare } = await provider();
12
- if (hash.startsWith('$2y$')) {
13
- hash = hash.replace(/^\$2y\$/, '$2a$');
14
- }
15
- return compare(password, hash);
151
+ verify: function verify(password, hash) {
152
+ return _async_to_generator(function() {
153
+ var compare;
154
+ return _ts_generator(this, function(_state) {
155
+ switch(_state.label){
156
+ case 0:
157
+ return [
158
+ 4,
159
+ provider()
160
+ ];
161
+ case 1:
162
+ compare = _state.sent().compare;
163
+ if (hash.startsWith('$2y$')) {
164
+ hash = hash.replace(/^\$2y\$/, '$2a$');
165
+ }
166
+ return [
167
+ 2,
168
+ compare(password, hash)
169
+ ];
170
+ }
171
+ });
172
+ })();
16
173
  }
17
174
  };
18
175
  }
19
-
20
- //# sourceMappingURL=createBcryptPasswordAlgorithm.js.map
@@ -1,54 +1,236 @@
1
+ function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
2
+ try {
3
+ var info = gen[key](arg);
4
+ var value = info.value;
5
+ }
6
+ catch (error) {
7
+ reject(error);
8
+ return;
9
+ }
10
+ if (info.done) {
11
+ resolve(value);
12
+ }
13
+ else {
14
+ Promise.resolve(value).then(_next, _throw);
15
+ }
16
+ }
17
+ function _async_to_generator(fn) {
18
+ return function () {
19
+ var self = this, args = arguments;
20
+ return new Promise(function (resolve, reject) {
21
+ var gen = fn.apply(self, args);
22
+ function _next(value) {
23
+ asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value);
24
+ }
25
+ function _throw(err) {
26
+ asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err);
27
+ }
28
+ _next(undefined);
29
+ });
30
+ };
31
+ }
32
+ function _instanceof(left, right) {
33
+ if (right != null && typeof Symbol !== "undefined" && right[Symbol.hasInstance]) {
34
+ return !!right[Symbol.hasInstance](left);
35
+ }
36
+ else {
37
+ return left instanceof right;
38
+ }
39
+ }
40
+ function _ts_generator(thisArg, body) {
41
+ var f, y, t, _ = {
42
+ label: 0,
43
+ sent: function () {
44
+ if (t[0] & 1)
45
+ throw t[1];
46
+ return t[1];
47
+ },
48
+ trys: [],
49
+ ops: []
50
+ }, g = Object.create((typeof Iterator === "function" ? Iterator : Object).prototype);
51
+ return g.next = verb(0), g["throw"] = verb(1), g["return"] = verb(2), typeof Symbol === "function" && (g[Symbol.iterator] = function () {
52
+ return this;
53
+ }), g;
54
+ function verb(n) {
55
+ return function (v) {
56
+ return step([
57
+ n,
58
+ v
59
+ ]);
60
+ };
61
+ }
62
+ function step(op) {
63
+ if (f)
64
+ throw new TypeError("Generator is already executing.");
65
+ while (g && (g = 0, op[0] && (_ = 0)), _)
66
+ try {
67
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done)
68
+ return t;
69
+ if (y = 0, t)
70
+ op = [
71
+ op[0] & 2,
72
+ t.value
73
+ ];
74
+ switch (op[0]) {
75
+ case 0:
76
+ case 1:
77
+ t = op;
78
+ break;
79
+ case 4:
80
+ _.label++;
81
+ return {
82
+ value: op[1],
83
+ done: false
84
+ };
85
+ case 5:
86
+ _.label++;
87
+ y = op[1];
88
+ op = [
89
+ 0
90
+ ];
91
+ continue;
92
+ case 7:
93
+ op = _.ops.pop();
94
+ _.trys.pop();
95
+ continue;
96
+ default:
97
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) {
98
+ _ = 0;
99
+ continue;
100
+ }
101
+ if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) {
102
+ _.label = op[1];
103
+ break;
104
+ }
105
+ if (op[0] === 6 && _.label < t[1]) {
106
+ _.label = t[1];
107
+ t = op;
108
+ break;
109
+ }
110
+ if (t && _.label < t[2]) {
111
+ _.label = t[2];
112
+ _.ops.push(op);
113
+ break;
114
+ }
115
+ if (t[2])
116
+ _.ops.pop();
117
+ _.trys.pop();
118
+ continue;
119
+ }
120
+ op = body.call(thisArg, _);
121
+ }
122
+ catch (e) {
123
+ op = [
124
+ 6,
125
+ e
126
+ ];
127
+ y = 0;
128
+ }
129
+ finally {
130
+ f = t = 0;
131
+ }
132
+ if (op[0] & 5)
133
+ throw op[1];
134
+ return {
135
+ value: op[0] ? op[1] : void 0,
136
+ done: true
137
+ };
138
+ }
139
+ }
1
140
  import { Errors } from "@wener/utils";
2
141
  import { PHC } from "./PHC.js";
3
- export function createPBKDF2PasswordAlgorithm({ id, digest, iterations = 100000, saltlen = 16, keylen = digest === "SHA-256" ? 32 : 64 }) {
142
+ export function createPBKDF2PasswordAlgorithm(param) {
143
+ var id = param.id, digest = param.digest, _param_iterations = param.iterations, iterations = _param_iterations === void 0 ? 100000 : _param_iterations, _param_saltlen = param.saltlen, saltlen = _param_saltlen === void 0 ? 16 : _param_saltlen, _param_keylen = param.keylen, keylen = _param_keylen === void 0 ? digest === "SHA-256" ? 32 : 64 : _param_keylen;
4
144
  return {
5
145
  name: id,
6
- async hash(password, opts) {
7
- let salt;
8
- if (opts?.salt) {
9
- salt = opts.salt;
10
- }
11
- else {
12
- salt = new Uint8Array(saltlen);
13
- crypto.getRandomValues(salt);
14
- }
15
- const rounds = opts?.rounds ?? iterations;
16
- let key = await crypto.subtle.importKey("raw", new TextEncoder().encode(password), "PBKDF2", false, [
17
- "deriveBits"
18
- ]);
19
- let hash = await crypto.subtle.deriveBits({
20
- name: "PBKDF2",
21
- iterations: rounds,
22
- salt,
23
- hash: digest
24
- }, key, keylen * 8);
25
- return PHC.serialize({
26
- id: opts?.id ?? id,
27
- params: {
28
- rounds
29
- },
30
- salt,
31
- hash: new Uint8Array(hash)
32
- });
146
+ hash: function hash(password, opts) {
147
+ return _async_to_generator(function () {
148
+ var salt, _opts_rounds, rounds, key, hash, _opts_id;
149
+ return _ts_generator(this, function (_state) {
150
+ switch (_state.label) {
151
+ case 0:
152
+ if (opts === null || opts === void 0 ? void 0 : opts.salt) {
153
+ salt = opts.salt;
154
+ }
155
+ else {
156
+ salt = new Uint8Array(saltlen);
157
+ crypto.getRandomValues(salt);
158
+ }
159
+ rounds = (_opts_rounds = opts === null || opts === void 0 ? void 0 : opts.rounds) !== null && _opts_rounds !== void 0 ? _opts_rounds : iterations;
160
+ return [
161
+ 4,
162
+ crypto.subtle.importKey("raw", new TextEncoder().encode(password), "PBKDF2", false, [
163
+ "deriveBits"
164
+ ])
165
+ ];
166
+ case 1:
167
+ key = _state.sent();
168
+ return [
169
+ 4,
170
+ crypto.subtle.deriveBits({
171
+ name: "PBKDF2",
172
+ iterations: rounds,
173
+ salt: salt,
174
+ hash: digest
175
+ }, key, keylen * 8)
176
+ ];
177
+ case 2:
178
+ hash = _state.sent();
179
+ return [
180
+ 2,
181
+ PHC.serialize({
182
+ id: (_opts_id = opts === null || opts === void 0 ? void 0 : opts.id) !== null && _opts_id !== void 0 ? _opts_id : id,
183
+ params: {
184
+ rounds: rounds
185
+ },
186
+ salt: salt,
187
+ hash: new Uint8Array(hash)
188
+ })
189
+ ];
190
+ }
191
+ });
192
+ })();
33
193
  },
34
- async verify(password, _, opts) {
35
- const rounds = opts?.params?.rounds ?? iterations;
36
- const salt = opts.salt;
37
- const storedHash = opts.hash;
38
- Errors.BadRequest.check(typeof rounds === "number", "Invalid rounds");
39
- Errors.BadRequest.check(salt instanceof Uint8Array, "Invalid salt");
40
- Errors.BadRequest.check(storedHash instanceof Uint8Array, "Invalid hash");
41
- let key = await crypto.subtle.importKey("raw", new TextEncoder().encode(password), "PBKDF2", false, [
42
- "deriveBits"
43
- ]);
44
- let hash = await crypto.subtle.deriveBits({
45
- name: "PBKDF2",
46
- iterations: rounds,
47
- salt,
48
- hash: digest
49
- }, key, storedHash.length * 8);
50
- return new Uint8Array(hash).every((v, i) => v === storedHash[i]);
194
+ verify: function verify(password, _, opts) {
195
+ return _async_to_generator(function () {
196
+ var _opts_params, _opts_params_rounds, rounds, salt, storedHash, key, hash;
197
+ return _ts_generator(this, function (_state) {
198
+ switch (_state.label) {
199
+ case 0:
200
+ rounds = (_opts_params_rounds = opts === null || opts === void 0 ? void 0 : (_opts_params = opts.params) === null || _opts_params === void 0 ? void 0 : _opts_params.rounds) !== null && _opts_params_rounds !== void 0 ? _opts_params_rounds : iterations;
201
+ salt = opts.salt;
202
+ storedHash = opts.hash;
203
+ Errors.BadRequest.check(typeof rounds === "number", "Invalid rounds");
204
+ Errors.BadRequest.check(_instanceof(salt, Uint8Array), "Invalid salt");
205
+ Errors.BadRequest.check(_instanceof(storedHash, Uint8Array), "Invalid hash");
206
+ return [
207
+ 4,
208
+ crypto.subtle.importKey("raw", new TextEncoder().encode(password), "PBKDF2", false, [
209
+ "deriveBits"
210
+ ])
211
+ ];
212
+ case 1:
213
+ key = _state.sent();
214
+ return [
215
+ 4,
216
+ crypto.subtle.deriveBits({
217
+ name: "PBKDF2",
218
+ iterations: rounds,
219
+ salt: salt,
220
+ hash: digest
221
+ }, key, storedHash.length * 8)
222
+ ];
223
+ case 2:
224
+ hash = _state.sent();
225
+ return [
226
+ 2,
227
+ new Uint8Array(hash).every(function (v, i) {
228
+ return v === storedHash[i];
229
+ })
230
+ ];
231
+ }
232
+ });
233
+ })();
51
234
  }
52
235
  };
53
236
  }
54
- //# sourceMappingURL=createPBKDF2PasswordAlgorithm.js.map