@spinajs/rbac-http-user 2.0.373 → 2.0.374
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/lib/cjs/2fa/Default2FaToken.d.ts +20 -0
- package/lib/cjs/2fa/Default2FaToken.d.ts.map +1 -0
- package/lib/cjs/2fa/Default2FaToken.js +122 -0
- package/lib/cjs/2fa/Default2FaToken.js.map +1 -0
- package/lib/cjs/actions/2fa.d.ts +11 -0
- package/lib/cjs/actions/2fa.d.ts.map +1 -0
- package/lib/cjs/actions/2fa.js +34 -0
- package/lib/cjs/actions/2fa.js.map +1 -0
- package/lib/cjs/config/rbac-http.d.ts +13 -0
- package/lib/cjs/config/rbac-http.d.ts.map +1 -1
- package/lib/cjs/config/rbac-http.js +14 -1
- package/lib/cjs/config/rbac-http.js.map +1 -1
- package/lib/cjs/controllers/LoginController.d.ts +1 -0
- package/lib/cjs/controllers/LoginController.d.ts.map +1 -1
- package/lib/cjs/controllers/LoginController.js +39 -108
- package/lib/cjs/controllers/LoginController.js.map +1 -1
- package/lib/cjs/controllers/TwoFactorAuthController.d.ts +9 -0
- package/lib/cjs/controllers/TwoFactorAuthController.d.ts.map +1 -1
- package/lib/cjs/controllers/TwoFactorAuthController.js +81 -56
- package/lib/cjs/controllers/TwoFactorAuthController.js.map +1 -1
- package/lib/cjs/policies/2FaPolicy.d.ts +2 -2
- package/lib/cjs/policies/2FaPolicy.d.ts.map +1 -1
- package/lib/cjs/policies/2FaPolicy.js +8 -1
- package/lib/cjs/policies/2FaPolicy.js.map +1 -1
- package/lib/mjs/2fa/Default2FaToken.d.ts +20 -0
- package/lib/mjs/2fa/Default2FaToken.d.ts.map +1 -0
- package/lib/mjs/2fa/Default2FaToken.js +96 -0
- package/lib/mjs/2fa/Default2FaToken.js.map +1 -0
- package/lib/mjs/actions/2fa.d.ts +11 -0
- package/lib/mjs/actions/2fa.d.ts.map +1 -0
- package/lib/mjs/actions/2fa.js +30 -0
- package/lib/mjs/actions/2fa.js.map +1 -0
- package/lib/mjs/config/rbac-http.d.ts +13 -0
- package/lib/mjs/config/rbac-http.d.ts.map +1 -1
- package/lib/mjs/config/rbac-http.js +14 -1
- package/lib/mjs/config/rbac-http.js.map +1 -1
- package/lib/mjs/controllers/LoginController.d.ts +1 -0
- package/lib/mjs/controllers/LoginController.d.ts.map +1 -1
- package/lib/mjs/controllers/LoginController.js +39 -108
- package/lib/mjs/controllers/LoginController.js.map +1 -1
- package/lib/mjs/controllers/TwoFactorAuthController.d.ts +9 -1
- package/lib/mjs/controllers/TwoFactorAuthController.d.ts.map +1 -1
- package/lib/mjs/controllers/TwoFactorAuthController.js +78 -57
- package/lib/mjs/controllers/TwoFactorAuthController.js.map +1 -1
- package/lib/mjs/policies/2FaPolicy.d.ts +2 -2
- package/lib/mjs/policies/2FaPolicy.d.ts.map +1 -1
- package/lib/mjs/policies/2FaPolicy.js +8 -1
- package/lib/mjs/policies/2FaPolicy.js.map +1 -1
- package/lib/tsconfig.cjs.tsbuildinfo +1 -1
- package/lib/tsconfig.mjs.tsbuildinfo +1 -1
- package/package.json +12 -11
- package/lib/cjs/2fa/SpeakEasy2FaToken.d.ts +0 -1
- package/lib/cjs/2fa/SpeakEasy2FaToken.d.ts.map +0 -1
- package/lib/cjs/2fa/SpeakEasy2FaToken.js +0 -48
- package/lib/cjs/2fa/SpeakEasy2FaToken.js.map +0 -1
- package/lib/mjs/2fa/SpeakEasy2FaToken.d.ts +0 -2
- package/lib/mjs/2fa/SpeakEasy2FaToken.d.ts.map +0 -1
- package/lib/mjs/2fa/SpeakEasy2FaToken.js +0 -49
- package/lib/mjs/2fa/SpeakEasy2FaToken.js.map +0 -1
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@spinajs/rbac-http-user",
|
|
3
|
-
"version": "2.0.
|
|
3
|
+
"version": "2.0.374",
|
|
4
4
|
"description": "HTTP API for basic user tasks ( login, logout, managing user account etc )",
|
|
5
5
|
|
|
6
6
|
"main": "lib/cjs/index.js",
|
|
@@ -50,20 +50,21 @@
|
|
|
50
50
|
},
|
|
51
51
|
"homepage": "https://github.com/spinajs/main#readme",
|
|
52
52
|
"dependencies": {
|
|
53
|
-
"@spinajs/configuration": "^2.0.
|
|
54
|
-
"@spinajs/di": "^2.0.
|
|
55
|
-
"@spinajs/exceptions": "^2.0.
|
|
56
|
-
"@spinajs/http": "^2.0.
|
|
57
|
-
"@spinajs/log": "^2.0.
|
|
58
|
-
"@spinajs/orm": "^2.0.
|
|
59
|
-
"@spinajs/orm-http": "^2.0.
|
|
60
|
-
"@spinajs/rbac": "^2.0.
|
|
61
|
-
"@spinajs/rbac-http": "^2.0.
|
|
53
|
+
"@spinajs/configuration": "^2.0.374",
|
|
54
|
+
"@spinajs/di": "^2.0.374",
|
|
55
|
+
"@spinajs/exceptions": "^2.0.374",
|
|
56
|
+
"@spinajs/http": "^2.0.374",
|
|
57
|
+
"@spinajs/log": "^2.0.374",
|
|
58
|
+
"@spinajs/orm": "^2.0.374",
|
|
59
|
+
"@spinajs/orm-http": "^2.0.374",
|
|
60
|
+
"@spinajs/rbac": "^2.0.374",
|
|
61
|
+
"@spinajs/rbac-http": "^2.0.374",
|
|
62
|
+
"otpauth": "9.4.0",
|
|
62
63
|
"luxon": "^3.6.1",
|
|
63
64
|
"uuid": "^9.0.0"
|
|
64
65
|
},
|
|
65
66
|
"devDependencies": {
|
|
66
|
-
"@spinajs/orm-sqlite": "^2.0.
|
|
67
|
+
"@spinajs/orm-sqlite": "^2.0.374"
|
|
67
68
|
},
|
|
68
69
|
"gitHead": "002dc553b0ffffd72193d0121ac425a4083bc9ee"
|
|
69
70
|
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
//# sourceMappingURL=SpeakEasy2FaToken.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"SpeakEasy2FaToken.d.ts","sourceRoot":"","sources":["../../../src/2fa/SpeakEasy2FaToken.ts"],"names":[],"mappings":""}
|
|
@@ -1,48 +0,0 @@
|
|
|
1
|
-
// import { Injectable } from '@spinajs/di';
|
|
2
|
-
// import * as speakeasy from 'speakeasy';
|
|
3
|
-
// import { User } from '@spinajs/rbac';
|
|
4
|
-
// import { Config } from '@spinajs/configuration';
|
|
5
|
-
// import { Log, Logger } from '@spinajs/log';
|
|
6
|
-
// @Injectable(TwoFactorAuthProvider)
|
|
7
|
-
// export class SpeakEasy2FaToken extends TwoFactorAuthProvider {
|
|
8
|
-
// @Config('rbac.speakeasy')
|
|
9
|
-
// protected Config: any;
|
|
10
|
-
// @Logger('SPEAKEASY_2FA_TOKEN')
|
|
11
|
-
// protected Log: Log;
|
|
12
|
-
// constructor() {
|
|
13
|
-
// super();
|
|
14
|
-
// }
|
|
15
|
-
// public execute(_: User): Promise<void> {
|
|
16
|
-
// // empty, speakasy works offline eg. google authenticator
|
|
17
|
-
// // we dont send any email or sms
|
|
18
|
-
// return Promise.resolve();
|
|
19
|
-
// }
|
|
20
|
-
// public async verifyToken(token: string, user: User): Promise<boolean> {
|
|
21
|
-
// const meta = user.Metadata.find((x) => x.Key === '2fa_speakeasy_token');
|
|
22
|
-
// if (!meta || meta.Value === '') {
|
|
23
|
-
// this.Log.trace(`Cannot verify 2fa token, no 2fa token for user ${user.Id}`);
|
|
24
|
-
// return false;
|
|
25
|
-
// }
|
|
26
|
-
// const verified = speakeasy.totp.verify({
|
|
27
|
-
// secret: meta.Value,
|
|
28
|
-
// encoding: 'base32',
|
|
29
|
-
// token,
|
|
30
|
-
// window: 5,
|
|
31
|
-
// });
|
|
32
|
-
// return verified;
|
|
33
|
-
// }
|
|
34
|
-
// public async initialize(user: User): Promise<any> {
|
|
35
|
-
// const secret = speakeasy.generateSecret(this.Config);
|
|
36
|
-
// await (user.Metadata['2fa_speakeasy_token'] = secret.base32);
|
|
37
|
-
// return secret.base32;
|
|
38
|
-
// }
|
|
39
|
-
// public async isEnabled(user: User): Promise<boolean> {
|
|
40
|
-
// const val = await user.Metadata['2fa_enabled'];
|
|
41
|
-
// return val as boolean;
|
|
42
|
-
// }
|
|
43
|
-
// public async isInitialized(user: User): Promise<boolean> {
|
|
44
|
-
// const val = await user.Metadata['2fa_speakeasy_token'];
|
|
45
|
-
// return val !== '';
|
|
46
|
-
// }
|
|
47
|
-
// }
|
|
48
|
-
//# sourceMappingURL=SpeakEasy2FaToken.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"SpeakEasy2FaToken.js","sourceRoot":"","sources":["../../../src/2fa/SpeakEasy2FaToken.ts"],"names":[],"mappings":"AAAA,4CAA4C;AAC5C,0CAA0C;AAC1C,wCAAwC;AACxC,mDAAmD;AACnD,8CAA8C;AAE9C,qCAAqC;AACrC,iEAAiE;AACjE,8BAA8B;AAC9B,2BAA2B;AAE3B,mCAAmC;AACnC,wBAAwB;AAExB,oBAAoB;AACpB,eAAe;AACf,MAAM;AAEN,6CAA6C;AAC7C,gEAAgE;AAChE,uCAAuC;AACvC,gCAAgC;AAChC,MAAM;AAEN,4EAA4E;AAC5E,+EAA+E;AAE/E,wCAAwC;AACxC,qFAAqF;AAErF,sBAAsB;AACtB,QAAQ;AAER,+CAA+C;AAC/C,4BAA4B;AAC5B,4BAA4B;AAC5B,eAAe;AACf,mBAAmB;AACnB,UAAU;AAEV,uBAAuB;AACvB,MAAM;AAEN,wDAAwD;AACxD,4DAA4D;AAC5D,oEAAoE;AACpE,4BAA4B;AAC5B,MAAM;AAEN,2DAA2D;AAC3D,sDAAsD;AACtD,6BAA6B;AAC7B,MAAM;AAEN,+DAA+D;AAC/D,8DAA8D;AAC9D,yBAAyB;AACzB,MAAM;AACN,IAAI"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"SpeakEasy2FaToken.d.ts","sourceRoot":"","sources":["../../../src/2fa/SpeakEasy2FaToken.ts"],"names":[],"mappings":""}
|
|
@@ -1,49 +0,0 @@
|
|
|
1
|
-
// import { Injectable } from '@spinajs/di';
|
|
2
|
-
// import * as speakeasy from 'speakeasy';
|
|
3
|
-
// import { User } from '@spinajs/rbac';
|
|
4
|
-
// import { Config } from '@spinajs/configuration';
|
|
5
|
-
// import { Log, Logger } from '@spinajs/log';
|
|
6
|
-
export {};
|
|
7
|
-
// @Injectable(TwoFactorAuthProvider)
|
|
8
|
-
// export class SpeakEasy2FaToken extends TwoFactorAuthProvider {
|
|
9
|
-
// @Config('rbac.speakeasy')
|
|
10
|
-
// protected Config: any;
|
|
11
|
-
// @Logger('SPEAKEASY_2FA_TOKEN')
|
|
12
|
-
// protected Log: Log;
|
|
13
|
-
// constructor() {
|
|
14
|
-
// super();
|
|
15
|
-
// }
|
|
16
|
-
// public execute(_: User): Promise<void> {
|
|
17
|
-
// // empty, speakasy works offline eg. google authenticator
|
|
18
|
-
// // we dont send any email or sms
|
|
19
|
-
// return Promise.resolve();
|
|
20
|
-
// }
|
|
21
|
-
// public async verifyToken(token: string, user: User): Promise<boolean> {
|
|
22
|
-
// const meta = user.Metadata.find((x) => x.Key === '2fa_speakeasy_token');
|
|
23
|
-
// if (!meta || meta.Value === '') {
|
|
24
|
-
// this.Log.trace(`Cannot verify 2fa token, no 2fa token for user ${user.Id}`);
|
|
25
|
-
// return false;
|
|
26
|
-
// }
|
|
27
|
-
// const verified = speakeasy.totp.verify({
|
|
28
|
-
// secret: meta.Value,
|
|
29
|
-
// encoding: 'base32',
|
|
30
|
-
// token,
|
|
31
|
-
// window: 5,
|
|
32
|
-
// });
|
|
33
|
-
// return verified;
|
|
34
|
-
// }
|
|
35
|
-
// public async initialize(user: User): Promise<any> {
|
|
36
|
-
// const secret = speakeasy.generateSecret(this.Config);
|
|
37
|
-
// await (user.Metadata['2fa_speakeasy_token'] = secret.base32);
|
|
38
|
-
// return secret.base32;
|
|
39
|
-
// }
|
|
40
|
-
// public async isEnabled(user: User): Promise<boolean> {
|
|
41
|
-
// const val = await user.Metadata['2fa_enabled'];
|
|
42
|
-
// return val as boolean;
|
|
43
|
-
// }
|
|
44
|
-
// public async isInitialized(user: User): Promise<boolean> {
|
|
45
|
-
// const val = await user.Metadata['2fa_speakeasy_token'];
|
|
46
|
-
// return val !== '';
|
|
47
|
-
// }
|
|
48
|
-
// }
|
|
49
|
-
//# sourceMappingURL=SpeakEasy2FaToken.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"SpeakEasy2FaToken.js","sourceRoot":"","sources":["../../../src/2fa/SpeakEasy2FaToken.ts"],"names":[],"mappings":"AAAA,4CAA4C;AAC5C,0CAA0C;AAC1C,wCAAwC;AACxC,mDAAmD;AACnD,8CAA8C;;AAE9C,qCAAqC;AACrC,iEAAiE;AACjE,8BAA8B;AAC9B,2BAA2B;AAE3B,mCAAmC;AACnC,wBAAwB;AAExB,oBAAoB;AACpB,eAAe;AACf,MAAM;AAEN,6CAA6C;AAC7C,gEAAgE;AAChE,uCAAuC;AACvC,gCAAgC;AAChC,MAAM;AAEN,4EAA4E;AAC5E,+EAA+E;AAE/E,wCAAwC;AACxC,qFAAqF;AAErF,sBAAsB;AACtB,QAAQ;AAER,+CAA+C;AAC/C,4BAA4B;AAC5B,4BAA4B;AAC5B,eAAe;AACf,mBAAmB;AACnB,UAAU;AAEV,uBAAuB;AACvB,MAAM;AAEN,wDAAwD;AACxD,4DAA4D;AAC5D,oEAAoE;AACpE,4BAA4B;AAC5B,MAAM;AAEN,2DAA2D;AAC3D,sDAAsD;AACtD,6BAA6B;AAC7B,MAAM;AAEN,+DAA+D;AAC/D,8DAA8D;AAC9D,yBAAyB;AACzB,MAAM;AACN,IAAI"}
|