@ackplus/nest-auth 0.0.23
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +226 -0
- package/package.json +51 -0
- package/src/index.d.ts +11 -0
- package/src/index.js +15 -0
- package/src/index.js.map +1 -0
- package/src/lib/auth.constants.d.ts +17 -0
- package/src/lib/auth.constants.js +21 -0
- package/src/lib/auth.constants.js.map +1 -0
- package/src/lib/controllers/auth.controller.d.ts +26 -0
- package/src/lib/controllers/auth.controller.js +214 -0
- package/src/lib/controllers/auth.controller.js.map +1 -0
- package/src/lib/controllers/mfa.controller.d.ts +23 -0
- package/src/lib/controllers/mfa.controller.js +132 -0
- package/src/lib/controllers/mfa.controller.js.map +1 -0
- package/src/lib/decorators/skip-mfa.decorator.d.ts +2 -0
- package/src/lib/decorators/skip-mfa.decorator.js +8 -0
- package/src/lib/decorators/skip-mfa.decorator.js.map +1 -0
- package/src/lib/dto/index.d.ts +12 -0
- package/src/lib/dto/index.js +16 -0
- package/src/lib/dto/index.js.map +1 -0
- package/src/lib/dto/requests/forgot-password.request.dto.d.ts +5 -0
- package/src/lib/dto/requests/forgot-password.request.dto.js +30 -0
- package/src/lib/dto/requests/forgot-password.request.dto.js.map +1 -0
- package/src/lib/dto/requests/login.request.dto.d.ts +6 -0
- package/src/lib/dto/requests/login.request.dto.js +34 -0
- package/src/lib/dto/requests/login.request.dto.js.map +1 -0
- package/src/lib/dto/requests/refresh-token.request.dto.d.ts +3 -0
- package/src/lib/dto/requests/refresh-token.request.dto.js +15 -0
- package/src/lib/dto/requests/refresh-token.request.dto.js.map +1 -0
- package/src/lib/dto/requests/reset-password.request.dto.d.ts +7 -0
- package/src/lib/dto/requests/reset-password.request.dto.js +42 -0
- package/src/lib/dto/requests/reset-password.request.dto.js.map +1 -0
- package/src/lib/dto/requests/send-mfa-code.request.dto.d.ts +4 -0
- package/src/lib/dto/requests/send-mfa-code.request.dto.js +16 -0
- package/src/lib/dto/requests/send-mfa-code.request.dto.js.map +1 -0
- package/src/lib/dto/requests/signup.request.dto.d.ts +6 -0
- package/src/lib/dto/requests/signup.request.dto.js +37 -0
- package/src/lib/dto/requests/signup.request.dto.js.map +1 -0
- package/src/lib/dto/requests/social-login.request.dto.d.ts +3 -0
- package/src/lib/dto/requests/social-login.request.dto.js +16 -0
- package/src/lib/dto/requests/social-login.request.dto.js.map +1 -0
- package/src/lib/dto/requests/update-user.dto.d.ts +5 -0
- package/src/lib/dto/requests/update-user.dto.js +24 -0
- package/src/lib/dto/requests/update-user.dto.js.map +1 -0
- package/src/lib/dto/requests/verify-2fa.request.dto.d.ts +5 -0
- package/src/lib/dto/requests/verify-2fa.request.dto.js +21 -0
- package/src/lib/dto/requests/verify-2fa.request.dto.js.map +1 -0
- package/src/lib/dto/requests/verify-totp-setup.request.dto.d.ts +4 -0
- package/src/lib/dto/requests/verify-totp-setup.request.dto.js +20 -0
- package/src/lib/dto/requests/verify-totp-setup.request.dto.js.map +1 -0
- package/src/lib/dto/responses/auth.response.dto.d.ts +16 -0
- package/src/lib/dto/responses/auth.response.dto.js +55 -0
- package/src/lib/dto/responses/auth.response.dto.js.map +1 -0
- package/src/lib/dto/responses/device-info.response.dto.d.ts +6 -0
- package/src/lib/dto/responses/device-info.response.dto.js +25 -0
- package/src/lib/dto/responses/device-info.response.dto.js.map +1 -0
- package/src/lib/dto/responses/message.response.dto.d.ts +3 -0
- package/src/lib/dto/responses/message.response.dto.js +13 -0
- package/src/lib/dto/responses/message.response.dto.js.map +1 -0
- package/src/lib/entities/auth-identity.entity.d.ts +11 -0
- package/src/lib/entities/auth-identity.entity.js +47 -0
- package/src/lib/entities/auth-identity.entity.js.map +1 -0
- package/src/lib/entities/index.d.ts +10 -0
- package/src/lib/entities/index.js +26 -0
- package/src/lib/entities/index.js.map +1 -0
- package/src/lib/entities/mfa-secret.entity.d.ts +12 -0
- package/src/lib/entities/mfa-secret.entity.js +51 -0
- package/src/lib/entities/mfa-secret.entity.js.map +1 -0
- package/src/lib/entities/otp.entity.d.ts +16 -0
- package/src/lib/entities/otp.entity.js +52 -0
- package/src/lib/entities/otp.entity.js.map +1 -0
- package/src/lib/entities/permission.entity.d.ts +9 -0
- package/src/lib/entities/permission.entity.js +37 -0
- package/src/lib/entities/permission.entity.js.map +1 -0
- package/src/lib/entities/role-permission.entity.d.ts +8 -0
- package/src/lib/entities/role-permission.entity.js +30 -0
- package/src/lib/entities/role-permission.entity.js.map +1 -0
- package/src/lib/entities/role.entity.d.ts +11 -0
- package/src/lib/entities/role.entity.js +42 -0
- package/src/lib/entities/role.entity.js.map +1 -0
- package/src/lib/entities/session.entity.d.ts +16 -0
- package/src/lib/entities/session.entity.js +63 -0
- package/src/lib/entities/session.entity.js.map +1 -0
- package/src/lib/entities/tenant.entity.d.ts +10 -0
- package/src/lib/entities/tenant.entity.js +41 -0
- package/src/lib/entities/tenant.entity.js.map +1 -0
- package/src/lib/entities/user-role.entity.d.ts +13 -0
- package/src/lib/entities/user-role.entity.js +47 -0
- package/src/lib/entities/user-role.entity.js.map +1 -0
- package/src/lib/entities/user.entity.d.ts +38 -0
- package/src/lib/entities/user.entity.js +155 -0
- package/src/lib/entities/user.entity.js.map +1 -0
- package/src/lib/guards/auth.guard.d.ts +18 -0
- package/src/lib/guards/auth.guard.js +106 -0
- package/src/lib/guards/auth.guard.js.map +1 -0
- package/src/lib/interceptors/token.interceptor.d.ts +10 -0
- package/src/lib/interceptors/token.interceptor.js +41 -0
- package/src/lib/interceptors/token.interceptor.js.map +1 -0
- package/src/lib/interfaces/auth-module-options.interface.d.ts +51 -0
- package/src/lib/interfaces/auth-module-options.interface.js +3 -0
- package/src/lib/interfaces/auth-module-options.interface.js.map +1 -0
- package/src/lib/interfaces/mfa-options.interface.d.ts +25 -0
- package/src/lib/interfaces/mfa-options.interface.js +10 -0
- package/src/lib/interfaces/mfa-options.interface.js.map +1 -0
- package/src/lib/interfaces/session-options.interface.d.ts +12 -0
- package/src/lib/interfaces/session-options.interface.js +9 -0
- package/src/lib/interfaces/session-options.interface.js.map +1 -0
- package/src/lib/interfaces/token-payload.interface.d.ts +39 -0
- package/src/lib/interfaces/token-payload.interface.js +3 -0
- package/src/lib/interfaces/token-payload.interface.js.map +1 -0
- package/src/lib/migrations/1746242659133-migration.d.ts +6 -0
- package/src/lib/migrations/1746242659133-migration.js +66 -0
- package/src/lib/migrations/1746242659133-migration.js.map +1 -0
- package/src/lib/migrations/1746244352713-migration.d.ts +6 -0
- package/src/lib/migrations/1746244352713-migration.js +16 -0
- package/src/lib/migrations/1746244352713-migration.js.map +1 -0
- package/src/lib/nest-auth.module.d.ts +13 -0
- package/src/lib/nest-auth.module.js +247 -0
- package/src/lib/nest-auth.module.js.map +1 -0
- package/src/lib/providers/apple-auth.provider.d.ts +23 -0
- package/src/lib/providers/apple-auth.provider.js +61 -0
- package/src/lib/providers/apple-auth.provider.js.map +1 -0
- package/src/lib/providers/base-auth.provider.d.ts +24 -0
- package/src/lib/providers/base-auth.provider.js +54 -0
- package/src/lib/providers/base-auth.provider.js.map +1 -0
- package/src/lib/providers/email-auth.provider.d.ts +21 -0
- package/src/lib/providers/email-auth.provider.js +45 -0
- package/src/lib/providers/email-auth.provider.js.map +1 -0
- package/src/lib/providers/facebook-auth.provider.d.ts +23 -0
- package/src/lib/providers/facebook-auth.provider.js +61 -0
- package/src/lib/providers/facebook-auth.provider.js.map +1 -0
- package/src/lib/providers/google-auth.provider.d.ts +26 -0
- package/src/lib/providers/google-auth.provider.js +63 -0
- package/src/lib/providers/google-auth.provider.js.map +1 -0
- package/src/lib/providers/index.d.ts +7 -0
- package/src/lib/providers/index.js +16 -0
- package/src/lib/providers/index.js.map +1 -0
- package/src/lib/providers/jwt-auth.provider.d.ts +38 -0
- package/src/lib/providers/jwt-auth.provider.js +54 -0
- package/src/lib/providers/jwt-auth.provider.js.map +1 -0
- package/src/lib/providers/phone-auth.provider.d.ts +22 -0
- package/src/lib/providers/phone-auth.provider.js +48 -0
- package/src/lib/providers/phone-auth.provider.js.map +1 -0
- package/src/lib/request-context/request-context.d.ts +22 -0
- package/src/lib/request-context/request-context.js +108 -0
- package/src/lib/request-context/request-context.js.map +1 -0
- package/src/lib/request-context/request-context.middleware.d.ts +4 -0
- package/src/lib/request-context/request-context.middleware.js +16 -0
- package/src/lib/request-context/request-context.middleware.js.map +1 -0
- package/src/lib/services/auth-migration-service.d.ts +22 -0
- package/src/lib/services/auth-migration-service.js +125 -0
- package/src/lib/services/auth-migration-service.js.map +1 -0
- package/src/lib/services/auth-provider-registry.service.d.ts +25 -0
- package/src/lib/services/auth-provider-registry.service.js +72 -0
- package/src/lib/services/auth-provider-registry.service.js.map +1 -0
- package/src/lib/services/auth.service.d.ts +45 -0
- package/src/lib/services/auth.service.js +344 -0
- package/src/lib/services/auth.service.js.map +1 -0
- package/src/lib/services/cookie.service.d.ts +10 -0
- package/src/lib/services/cookie.service.js +43 -0
- package/src/lib/services/cookie.service.js.map +1 -0
- package/src/lib/services/jwt.service.d.ts +15 -0
- package/src/lib/services/jwt.service.js +93 -0
- package/src/lib/services/jwt.service.js.map +1 -0
- package/src/lib/services/mfa.service.d.ts +40 -0
- package/src/lib/services/mfa.service.js +254 -0
- package/src/lib/services/mfa.service.js.map +1 -0
- package/src/lib/services/session/base-session.service.d.ts +23 -0
- package/src/lib/services/session/base-session.service.js +64 -0
- package/src/lib/services/session/base-session.service.js.map +1 -0
- package/src/lib/services/session/database-session.service.d.ts +19 -0
- package/src/lib/services/session/database-session.service.js +55 -0
- package/src/lib/services/session/database-session.service.js.map +1 -0
- package/src/lib/services/session/redis-session.service.d.ts +22 -0
- package/src/lib/services/session/redis-session.service.js +120 -0
- package/src/lib/services/session/redis-session.service.js.map +1 -0
- package/src/lib/utils/database.utils.d.ts +2 -0
- package/src/lib/utils/database.utils.js +8 -0
- package/src/lib/utils/database.utils.js.map +1 -0
- package/src/lib/utils/otp.d.ts +1 -0
- package/src/lib/utils/otp.js +7 -0
- package/src/lib/utils/otp.js.map +1 -0
- package/src/typeorm.config.d.ts +2 -0
- package/src/typeorm.config.js +18 -0
- package/src/typeorm.config.js.map +1 -0
- package/tsconfig.tsbuildinfo +1 -0
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.CookieService = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const common_1 = require("@nestjs/common");
|
|
6
|
+
const auth_constants_1 = require("../auth.constants");
|
|
7
|
+
const ms_1 = tslib_1.__importDefault(require("ms"));
|
|
8
|
+
let CookieService = class CookieService {
|
|
9
|
+
constructor(options) {
|
|
10
|
+
this.options = options;
|
|
11
|
+
}
|
|
12
|
+
setAccessTokenCookie(response, token) {
|
|
13
|
+
response.cookie(auth_constants_1.ACCESS_TOKEN_COOKIE_NAME, token, {
|
|
14
|
+
httpOnly: true,
|
|
15
|
+
secure: this.options.cookieOptions.secure,
|
|
16
|
+
sameSite: this.options.cookieOptions.sameSite,
|
|
17
|
+
maxAge: (0, ms_1.default)(this.options.session.sessionExpiry),
|
|
18
|
+
});
|
|
19
|
+
}
|
|
20
|
+
setRefreshTokenCookie(response, token) {
|
|
21
|
+
response.cookie(auth_constants_1.REFRESH_TOKEN_COOKIE_NAME, token, {
|
|
22
|
+
httpOnly: true,
|
|
23
|
+
secure: this.options.cookieOptions.secure,
|
|
24
|
+
sameSite: this.options.cookieOptions.sameSite,
|
|
25
|
+
maxAge: (0, ms_1.default)(this.options.session.refreshTokenExpiry),
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
clearCookies(response) {
|
|
29
|
+
response.clearCookie(auth_constants_1.ACCESS_TOKEN_COOKIE_NAME);
|
|
30
|
+
response.clearCookie(auth_constants_1.REFRESH_TOKEN_COOKIE_NAME);
|
|
31
|
+
}
|
|
32
|
+
setTokens(response, accessToken, refreshToken) {
|
|
33
|
+
this.setAccessTokenCookie(response, accessToken);
|
|
34
|
+
this.setRefreshTokenCookie(response, refreshToken);
|
|
35
|
+
}
|
|
36
|
+
};
|
|
37
|
+
exports.CookieService = CookieService;
|
|
38
|
+
exports.CookieService = CookieService = tslib_1.__decorate([
|
|
39
|
+
(0, common_1.Injectable)(),
|
|
40
|
+
tslib_1.__param(0, (0, common_1.Inject)(auth_constants_1.AUTH_MODULE_OPTIONS)),
|
|
41
|
+
tslib_1.__metadata("design:paramtypes", [Object])
|
|
42
|
+
], CookieService);
|
|
43
|
+
//# sourceMappingURL=cookie.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cookie.service.js","sourceRoot":"","sources":["../../../../../../packages/nest-auth/src/lib/services/cookie.service.ts"],"names":[],"mappings":";;;;AAAA,2CAAoD;AAEpD,sDAA6G;AAE7G,oDAAoB;AAGb,IAAM,aAAa,GAAnB,MAAM,aAAa;IACtB,YAEY,OAA0B;QAA1B,YAAO,GAAP,OAAO,CAAmB;IAClC,CAAC;IAEL,oBAAoB,CAAC,QAAkB,EAAE,KAAa;QAClD,QAAQ,CAAC,MAAM,CAAC,yCAAwB,EAAE,KAAK,EAAE;YAC7C,QAAQ,EAAE,IAAI;YACd,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,MAAM;YACzC,QAAQ,EAAE,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,QAAQ;YAC7C,MAAM,EAAE,IAAA,YAAE,EAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,aAAa,CAAC;SACjD,CAAC,CAAC;IACP,CAAC;IAED,qBAAqB,CAAC,QAAkB,EAAE,KAAa;QACnD,QAAQ,CAAC,MAAM,CAAC,0CAAyB,EAAE,KAAK,EAAE;YAC9C,QAAQ,EAAE,IAAI;YACd,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,MAAM;YACzC,QAAQ,EAAE,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,QAAQ;YAC7C,MAAM,EAAE,IAAA,YAAE,EAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,kBAAkB,CAAC;SACtD,CAAC,CAAC;IACP,CAAC;IAED,YAAY,CAAC,QAAkB;QAC3B,QAAQ,CAAC,WAAW,CAAC,yCAAwB,CAAC,CAAC;QAC/C,QAAQ,CAAC,WAAW,CAAC,0CAAyB,CAAC,CAAC;IACpD,CAAC;IAED,SAAS,CAAC,QAAkB,EAAE,WAAmB,EAAE,YAAoB;QACnE,IAAI,CAAC,oBAAoB,CAAC,QAAQ,EAAE,WAAW,CAAC,CAAC;QACjD,IAAI,CAAC,qBAAqB,CAAC,QAAQ,EAAE,YAAY,CAAC,CAAC;IACvD,CAAC;CACJ,CAAA;AAjCY,sCAAa;wBAAb,aAAa;IADzB,IAAA,mBAAU,GAAE;IAGJ,mBAAA,IAAA,eAAM,EAAC,oCAAmB,CAAC,CAAA;;GAFvB,aAAa,CAiCzB"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { AuthModuleOptions } from '../interfaces/auth-module-options.interface';
|
|
2
|
+
import { JWTTokenPayload } from '../interfaces/token-payload.interface';
|
|
3
|
+
export declare class JwtService {
|
|
4
|
+
private options;
|
|
5
|
+
constructor(options: AuthModuleOptions);
|
|
6
|
+
generateAccessToken(payload: Partial<JWTTokenPayload>): Promise<string>;
|
|
7
|
+
generateRefreshToken(payload: Partial<JWTTokenPayload>): Promise<string>;
|
|
8
|
+
verifyToken(token: string): Promise<JWTTokenPayload>;
|
|
9
|
+
generateTokens(payload: Partial<JWTTokenPayload>): Promise<{
|
|
10
|
+
accessToken: string;
|
|
11
|
+
refreshToken: string;
|
|
12
|
+
}>;
|
|
13
|
+
updateToken(token: string, payload: Partial<JWTTokenPayload>): Promise<string>;
|
|
14
|
+
decodeToken(token: string): JWTTokenPayload | null;
|
|
15
|
+
}
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.JwtService = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const common_1 = require("@nestjs/common");
|
|
6
|
+
const jsonwebtoken_1 = tslib_1.__importDefault(require("jsonwebtoken"));
|
|
7
|
+
const auth_constants_1 = require("../auth.constants");
|
|
8
|
+
const ms_1 = tslib_1.__importDefault(require("ms"));
|
|
9
|
+
let JwtService = class JwtService {
|
|
10
|
+
constructor(options) {
|
|
11
|
+
this.options = options;
|
|
12
|
+
}
|
|
13
|
+
async generateAccessToken(payload) {
|
|
14
|
+
return new Promise((resolve, reject) => {
|
|
15
|
+
jsonwebtoken_1.default.sign({
|
|
16
|
+
...payload,
|
|
17
|
+
type: 'access',
|
|
18
|
+
exp: Math.floor(Date.now() / 1000) + (0, ms_1.default)(this.options.session.sessionExpiry),
|
|
19
|
+
iat: Math.floor(Date.now() / 1000),
|
|
20
|
+
}, this.options.jwt.secret, (err, token) => {
|
|
21
|
+
if (err)
|
|
22
|
+
reject(err);
|
|
23
|
+
else
|
|
24
|
+
resolve(token);
|
|
25
|
+
});
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
async generateRefreshToken(payload) {
|
|
29
|
+
return new Promise((resolve, reject) => {
|
|
30
|
+
jsonwebtoken_1.default.sign({
|
|
31
|
+
...payload,
|
|
32
|
+
type: 'refresh',
|
|
33
|
+
exp: Math.floor(Date.now() / 1000) + (0, ms_1.default)(this.options.session.refreshTokenExpiry),
|
|
34
|
+
iat: Math.floor(Date.now() / 1000),
|
|
35
|
+
}, this.options.jwt.secret, (err, token) => {
|
|
36
|
+
if (err)
|
|
37
|
+
reject(err);
|
|
38
|
+
else
|
|
39
|
+
resolve(token);
|
|
40
|
+
});
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
async verifyToken(token) {
|
|
44
|
+
return new Promise((resolve, reject) => {
|
|
45
|
+
jsonwebtoken_1.default.verify(token, this.options.jwt.secret, (err, decoded) => {
|
|
46
|
+
if (err)
|
|
47
|
+
reject(err);
|
|
48
|
+
else
|
|
49
|
+
resolve(decoded);
|
|
50
|
+
});
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
async generateTokens(payload) {
|
|
54
|
+
const [accessToken, refreshToken] = await Promise.all([
|
|
55
|
+
this.generateAccessToken(payload),
|
|
56
|
+
this.generateRefreshToken(payload),
|
|
57
|
+
]);
|
|
58
|
+
return {
|
|
59
|
+
accessToken,
|
|
60
|
+
refreshToken,
|
|
61
|
+
};
|
|
62
|
+
}
|
|
63
|
+
updateToken(token, payload) {
|
|
64
|
+
return new Promise((resolve, reject) => {
|
|
65
|
+
const decoded = this.decodeToken(token);
|
|
66
|
+
if (!decoded)
|
|
67
|
+
reject(new Error('Invalid token'));
|
|
68
|
+
else {
|
|
69
|
+
jsonwebtoken_1.default.sign({ ...decoded, ...payload }, this.options.jwt.secret, { expiresIn: this.options.session.sessionExpiry }, (err, token) => {
|
|
70
|
+
if (err)
|
|
71
|
+
reject(err);
|
|
72
|
+
else
|
|
73
|
+
resolve(token);
|
|
74
|
+
});
|
|
75
|
+
}
|
|
76
|
+
});
|
|
77
|
+
}
|
|
78
|
+
decodeToken(token) {
|
|
79
|
+
try {
|
|
80
|
+
return jsonwebtoken_1.default.decode(token);
|
|
81
|
+
}
|
|
82
|
+
catch (error) {
|
|
83
|
+
return null;
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
};
|
|
87
|
+
exports.JwtService = JwtService;
|
|
88
|
+
exports.JwtService = JwtService = tslib_1.__decorate([
|
|
89
|
+
(0, common_1.Injectable)(),
|
|
90
|
+
tslib_1.__param(0, (0, common_1.Inject)(auth_constants_1.AUTH_MODULE_OPTIONS)),
|
|
91
|
+
tslib_1.__metadata("design:paramtypes", [Object])
|
|
92
|
+
], JwtService);
|
|
93
|
+
//# sourceMappingURL=jwt.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jwt.service.js","sourceRoot":"","sources":["../../../../../../packages/nest-auth/src/lib/services/jwt.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { Repository } from 'typeorm';
|
|
2
|
+
import { MFASecret } from '../entities/mfa-secret.entity';
|
|
3
|
+
import { MFAMethodEnum, MFAOptions } from '../interfaces/mfa-options.interface';
|
|
4
|
+
import { AuthModuleOptions } from '../interfaces/auth-module-options.interface';
|
|
5
|
+
import { User } from '../entities/user.entity';
|
|
6
|
+
import { OTP } from '../entities/otp.entity';
|
|
7
|
+
export declare class MfaService {
|
|
8
|
+
private mfaSecretRepository;
|
|
9
|
+
private userRepository;
|
|
10
|
+
private otpRepository;
|
|
11
|
+
private readonly options;
|
|
12
|
+
mfaConfig: MFAOptions;
|
|
13
|
+
constructor(mfaSecretRepository: Repository<MFASecret>, userRepository: Repository<User>, otpRepository: Repository<OTP>, options: AuthModuleOptions);
|
|
14
|
+
checkIsMfaEnabledForApp(throwError?: boolean): boolean;
|
|
15
|
+
getEnabledMethods(userId: string): Promise<MFAMethodEnum[]>;
|
|
16
|
+
sendMfaCode(userId: string, method: MFAMethodEnum): Promise<boolean>;
|
|
17
|
+
verifyMfa(userId: string, inputOtp: string, method: MFAMethodEnum): Promise<boolean>;
|
|
18
|
+
setupTotpDevice(userId: string, deviceName?: string): Promise<{
|
|
19
|
+
secret: string;
|
|
20
|
+
qrCode: string;
|
|
21
|
+
}>;
|
|
22
|
+
verifyTotpSetup(userId: string, secret: string, inputOtp: string): Promise<boolean>;
|
|
23
|
+
getTotpDevices(userId: string): Promise<{
|
|
24
|
+
id: string;
|
|
25
|
+
deviceName: string;
|
|
26
|
+
lastUsedAt: Date;
|
|
27
|
+
verified: boolean;
|
|
28
|
+
}[]>;
|
|
29
|
+
removeDevice(deviceId: string): Promise<void>;
|
|
30
|
+
isRequiresMfa(userId: string): Promise<boolean>;
|
|
31
|
+
isMfaEnabled(userId: string): Promise<boolean>;
|
|
32
|
+
markAsVerified(userId: string, deviceId: string): Promise<void>;
|
|
33
|
+
enableMFA(userId: string): Promise<void>;
|
|
34
|
+
disableMFA(userId: string): Promise<void>;
|
|
35
|
+
removeTotpDevice(deviceId: string): Promise<void>;
|
|
36
|
+
generateRecoveryCode(userId: string): Promise<string>;
|
|
37
|
+
resetMfa(userId: string, code: string): Promise<{
|
|
38
|
+
message: string;
|
|
39
|
+
}>;
|
|
40
|
+
}
|
|
@@ -0,0 +1,254 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.MfaService = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const common_1 = require("@nestjs/common");
|
|
6
|
+
const typeorm_1 = require("@nestjs/typeorm");
|
|
7
|
+
const typeorm_2 = require("typeorm");
|
|
8
|
+
const mfa_secret_entity_1 = require("../entities/mfa-secret.entity");
|
|
9
|
+
const speakeasy = tslib_1.__importStar(require("speakeasy"));
|
|
10
|
+
const qrcode = tslib_1.__importStar(require("qrcode"));
|
|
11
|
+
const mfa_options_interface_1 = require("../interfaces/mfa-options.interface");
|
|
12
|
+
const auth_constants_1 = require("../auth.constants");
|
|
13
|
+
const user_entity_1 = require("../entities/user.entity");
|
|
14
|
+
const otp_entity_1 = require("../entities/otp.entity");
|
|
15
|
+
const otp_1 = require("../utils/otp");
|
|
16
|
+
const ms_1 = tslib_1.__importDefault(require("ms"));
|
|
17
|
+
let MfaService = class MfaService {
|
|
18
|
+
constructor(mfaSecretRepository, userRepository, otpRepository, options) {
|
|
19
|
+
this.mfaSecretRepository = mfaSecretRepository;
|
|
20
|
+
this.userRepository = userRepository;
|
|
21
|
+
this.otpRepository = otpRepository;
|
|
22
|
+
this.options = options;
|
|
23
|
+
this.mfaConfig = this.options.mfa;
|
|
24
|
+
}
|
|
25
|
+
checkIsMfaEnabledForApp(throwError = true) {
|
|
26
|
+
if (!this.mfaConfig.enabled) {
|
|
27
|
+
if (throwError) {
|
|
28
|
+
throw new common_1.ForbiddenException('MFA is not enabled for the application');
|
|
29
|
+
}
|
|
30
|
+
return false;
|
|
31
|
+
}
|
|
32
|
+
return true;
|
|
33
|
+
}
|
|
34
|
+
async getEnabledMethods(userId) {
|
|
35
|
+
this.checkIsMfaEnabledForApp(true);
|
|
36
|
+
const isEnabled = await this.isMfaEnabled(userId);
|
|
37
|
+
if (!isEnabled) {
|
|
38
|
+
return [];
|
|
39
|
+
}
|
|
40
|
+
const enableMethod = [];
|
|
41
|
+
if (this.mfaConfig.methods?.includes(mfa_options_interface_1.MFAMethodEnum.EMAIL)) {
|
|
42
|
+
enableMethod.push(mfa_options_interface_1.MFAMethodEnum.EMAIL);
|
|
43
|
+
}
|
|
44
|
+
if (this.mfaConfig.methods?.includes(mfa_options_interface_1.MFAMethodEnum.SMS)) {
|
|
45
|
+
enableMethod.push(mfa_options_interface_1.MFAMethodEnum.SMS);
|
|
46
|
+
}
|
|
47
|
+
const totpDevice = await this.mfaSecretRepository.findOne({
|
|
48
|
+
where: {
|
|
49
|
+
userId,
|
|
50
|
+
},
|
|
51
|
+
});
|
|
52
|
+
if (totpDevice) {
|
|
53
|
+
enableMethod.push(mfa_options_interface_1.MFAMethodEnum.TOTP);
|
|
54
|
+
}
|
|
55
|
+
return enableMethod;
|
|
56
|
+
}
|
|
57
|
+
async sendMfaCode(userId, method) {
|
|
58
|
+
this.checkIsMfaEnabledForApp(true);
|
|
59
|
+
const code = (0, otp_1.generateOtp)(this.mfaConfig.otpLength);
|
|
60
|
+
const expiresAt = (0, ms_1.default)(this.mfaConfig.otpExpiresIn);
|
|
61
|
+
const otp = await this.otpRepository.create({
|
|
62
|
+
userId,
|
|
63
|
+
type: otp_entity_1.OTPTypeEnum.MFA,
|
|
64
|
+
expiresAt: new Date(Date.now() + expiresAt),
|
|
65
|
+
code,
|
|
66
|
+
});
|
|
67
|
+
await this.otpRepository.save(otp);
|
|
68
|
+
if (method === mfa_options_interface_1.MFAMethodEnum.EMAIL) {
|
|
69
|
+
}
|
|
70
|
+
else if (method === mfa_options_interface_1.MFAMethodEnum.SMS) {
|
|
71
|
+
}
|
|
72
|
+
return true;
|
|
73
|
+
}
|
|
74
|
+
async verifyMfa(userId, inputOtp, method) {
|
|
75
|
+
this.checkIsMfaEnabledForApp(true);
|
|
76
|
+
if (method === mfa_options_interface_1.MFAMethodEnum.TOTP) {
|
|
77
|
+
const devices = await this.mfaSecretRepository.find({
|
|
78
|
+
where: { userId, verified: true }
|
|
79
|
+
});
|
|
80
|
+
for (const device of devices) {
|
|
81
|
+
const isValid = speakeasy.totp.verify({
|
|
82
|
+
secret: device.secret,
|
|
83
|
+
encoding: 'base32',
|
|
84
|
+
token: inputOtp,
|
|
85
|
+
window: 1
|
|
86
|
+
});
|
|
87
|
+
if (isValid) {
|
|
88
|
+
await this.mfaSecretRepository.update({ id: device.id }, { lastUsedAt: new Date() });
|
|
89
|
+
return true;
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
return false;
|
|
93
|
+
}
|
|
94
|
+
if (method === mfa_options_interface_1.MFAMethodEnum.EMAIL || method === mfa_options_interface_1.MFAMethodEnum.SMS) {
|
|
95
|
+
const otp = await this.otpRepository.findOne({
|
|
96
|
+
where: {
|
|
97
|
+
userId,
|
|
98
|
+
type: otp_entity_1.OTPTypeEnum.MFA,
|
|
99
|
+
used: false,
|
|
100
|
+
expiresAt: (0, typeorm_2.MoreThan)(new Date()),
|
|
101
|
+
code: inputOtp
|
|
102
|
+
}
|
|
103
|
+
});
|
|
104
|
+
if (!otp) {
|
|
105
|
+
return false;
|
|
106
|
+
}
|
|
107
|
+
await this.otpRepository.delete(otp.id);
|
|
108
|
+
return true;
|
|
109
|
+
}
|
|
110
|
+
return false;
|
|
111
|
+
}
|
|
112
|
+
async setupTotpDevice(userId, deviceName) {
|
|
113
|
+
this.checkIsMfaEnabledForApp(true);
|
|
114
|
+
const user = await this.userRepository.findOne({ where: { id: userId } });
|
|
115
|
+
if (!user) {
|
|
116
|
+
throw new Error('User not found');
|
|
117
|
+
}
|
|
118
|
+
const secret = speakeasy.generateSecret();
|
|
119
|
+
await this.mfaSecretRepository.save({
|
|
120
|
+
userId,
|
|
121
|
+
secret: secret.base32,
|
|
122
|
+
deviceName: deviceName || 'Authenticator',
|
|
123
|
+
verified: false
|
|
124
|
+
});
|
|
125
|
+
const qrCode = await qrcode.toDataURL(secret.otpauth_url);
|
|
126
|
+
return { secret: secret.base32, qrCode };
|
|
127
|
+
}
|
|
128
|
+
async verifyTotpSetup(userId, secret, inputOtp) {
|
|
129
|
+
this.checkIsMfaEnabledForApp(true);
|
|
130
|
+
const device = await this.mfaSecretRepository.findOne({
|
|
131
|
+
where: { userId, secret }
|
|
132
|
+
});
|
|
133
|
+
if (device) {
|
|
134
|
+
if (device.verified) {
|
|
135
|
+
return true;
|
|
136
|
+
}
|
|
137
|
+
const isValid = speakeasy.totp.verify({
|
|
138
|
+
secret: device.secret,
|
|
139
|
+
encoding: 'base32',
|
|
140
|
+
token: inputOtp,
|
|
141
|
+
window: 1
|
|
142
|
+
});
|
|
143
|
+
if (isValid) {
|
|
144
|
+
await this.mfaSecretRepository.update({ id: device.id }, { verified: true });
|
|
145
|
+
return true;
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
return false;
|
|
149
|
+
}
|
|
150
|
+
async getTotpDevices(userId) {
|
|
151
|
+
this.checkIsMfaEnabledForApp(true);
|
|
152
|
+
const devices = await this.mfaSecretRepository.find({
|
|
153
|
+
select: ['id', 'deviceName', 'lastUsedAt', 'verified'],
|
|
154
|
+
where: { userId },
|
|
155
|
+
order: { lastUsedAt: 'DESC' }
|
|
156
|
+
});
|
|
157
|
+
return devices.map(device => ({
|
|
158
|
+
id: device.id,
|
|
159
|
+
deviceName: device.deviceName,
|
|
160
|
+
lastUsedAt: device.lastUsedAt,
|
|
161
|
+
verified: device.verified,
|
|
162
|
+
}));
|
|
163
|
+
}
|
|
164
|
+
async removeDevice(deviceId) {
|
|
165
|
+
this.checkIsMfaEnabledForApp(true);
|
|
166
|
+
await this.mfaSecretRepository.delete({ id: deviceId });
|
|
167
|
+
}
|
|
168
|
+
async isRequiresMfa(userId) {
|
|
169
|
+
if (!this.mfaConfig.enabled) {
|
|
170
|
+
return false;
|
|
171
|
+
}
|
|
172
|
+
if (this.mfaConfig.required) {
|
|
173
|
+
return true;
|
|
174
|
+
}
|
|
175
|
+
const user = await this.userRepository.findOne({
|
|
176
|
+
select: ['id', 'isMfaEnabled'],
|
|
177
|
+
where: { id: userId },
|
|
178
|
+
});
|
|
179
|
+
return !!user?.isMfaEnabled;
|
|
180
|
+
}
|
|
181
|
+
async isMfaEnabled(userId) {
|
|
182
|
+
if (this.mfaConfig.enabled) {
|
|
183
|
+
const user = await this.userRepository.findOne({
|
|
184
|
+
select: ['id', 'isMfaEnabled'],
|
|
185
|
+
where: { id: userId },
|
|
186
|
+
});
|
|
187
|
+
return !!user?.isMfaEnabled;
|
|
188
|
+
}
|
|
189
|
+
return false;
|
|
190
|
+
}
|
|
191
|
+
async markAsVerified(userId, deviceId) {
|
|
192
|
+
this.checkIsMfaEnabledForApp(true);
|
|
193
|
+
await this.mfaSecretRepository.update({ id: deviceId, userId }, { verified: true });
|
|
194
|
+
}
|
|
195
|
+
async enableMFA(userId) {
|
|
196
|
+
this.checkIsMfaEnabledForApp(true);
|
|
197
|
+
if (!this.mfaConfig.allowUserToggle) {
|
|
198
|
+
throw new Error('MFA toggling is not allowed');
|
|
199
|
+
}
|
|
200
|
+
await this.userRepository.update(userId, { isMfaEnabled: true });
|
|
201
|
+
}
|
|
202
|
+
async disableMFA(userId) {
|
|
203
|
+
this.checkIsMfaEnabledForApp(true);
|
|
204
|
+
if (!this.mfaConfig.allowUserToggle) {
|
|
205
|
+
throw new Error('MFA toggling is not allowed');
|
|
206
|
+
}
|
|
207
|
+
await this.userRepository.update(userId, { isMfaEnabled: false });
|
|
208
|
+
}
|
|
209
|
+
async removeTotpDevice(deviceId) {
|
|
210
|
+
this.checkIsMfaEnabledForApp(true);
|
|
211
|
+
await this.mfaSecretRepository.delete({ id: deviceId });
|
|
212
|
+
}
|
|
213
|
+
async generateRecoveryCode(userId) {
|
|
214
|
+
this.checkIsMfaEnabledForApp(true);
|
|
215
|
+
const secret = speakeasy.generateSecret({
|
|
216
|
+
name: `NestAuth:${userId}`,
|
|
217
|
+
});
|
|
218
|
+
await this.userRepository.update(userId, { mfaRecoveryCode: secret.base32 });
|
|
219
|
+
return secret.base32;
|
|
220
|
+
}
|
|
221
|
+
async resetMfa(userId, code) {
|
|
222
|
+
this.checkIsMfaEnabledForApp(true);
|
|
223
|
+
const user = await this.userRepository.findOne({ where: { id: userId } });
|
|
224
|
+
if (!user) {
|
|
225
|
+
throw new common_1.UnauthorizedException({
|
|
226
|
+
message: 'User not found',
|
|
227
|
+
code: auth_constants_1.USER_NOT_FOUND_EXCEPTION_CODE
|
|
228
|
+
});
|
|
229
|
+
}
|
|
230
|
+
if (user.mfaRecoveryCode === code) {
|
|
231
|
+
await this.userRepository.update(userId, { mfaRecoveryCode: null });
|
|
232
|
+
await this.mfaSecretRepository.delete({ userId });
|
|
233
|
+
return {
|
|
234
|
+
message: 'Recovery code verified',
|
|
235
|
+
};
|
|
236
|
+
}
|
|
237
|
+
throw new common_1.UnauthorizedException({
|
|
238
|
+
message: 'Invalid recovery code',
|
|
239
|
+
code: auth_constants_1.INVALID_MFA_EXCEPTION_CODE
|
|
240
|
+
});
|
|
241
|
+
}
|
|
242
|
+
};
|
|
243
|
+
exports.MfaService = MfaService;
|
|
244
|
+
exports.MfaService = MfaService = tslib_1.__decorate([
|
|
245
|
+
(0, common_1.Injectable)(),
|
|
246
|
+
tslib_1.__param(0, (0, typeorm_1.InjectRepository)(mfa_secret_entity_1.MFASecret)),
|
|
247
|
+
tslib_1.__param(1, (0, typeorm_1.InjectRepository)(user_entity_1.User)),
|
|
248
|
+
tslib_1.__param(2, (0, typeorm_1.InjectRepository)(otp_entity_1.OTP)),
|
|
249
|
+
tslib_1.__param(3, (0, common_1.Inject)(auth_constants_1.AUTH_MODULE_OPTIONS)),
|
|
250
|
+
tslib_1.__metadata("design:paramtypes", [typeorm_2.Repository,
|
|
251
|
+
typeorm_2.Repository,
|
|
252
|
+
typeorm_2.Repository, Object])
|
|
253
|
+
], MfaService);
|
|
254
|
+
//# sourceMappingURL=mfa.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mfa.service.js","sourceRoot":"","sources":["../../../../../../packages/nest-auth/src/lib/services/mfa.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { AuthModuleOptions } from '../../interfaces/auth-module-options.interface';
|
|
2
|
+
import { SessionOptions } from '../../interfaces/session-options.interface';
|
|
3
|
+
import { SessionPayload } from '../../interfaces/token-payload.interface';
|
|
4
|
+
import { User } from '../../entities/user.entity';
|
|
5
|
+
export declare abstract class BaseSessionService {
|
|
6
|
+
protected readonly authModuleOptions: AuthModuleOptions;
|
|
7
|
+
protected readonly sessionOptions: SessionOptions;
|
|
8
|
+
constructor(authModuleOptions: AuthModuleOptions);
|
|
9
|
+
getSessionOptions(): SessionOptions;
|
|
10
|
+
createSessionFromUser(user: User, extraData?: {
|
|
11
|
+
isMfaVerified?: boolean;
|
|
12
|
+
}): Promise<SessionPayload>;
|
|
13
|
+
createSessionFromSession(session: SessionPayload): Promise<SessionPayload>;
|
|
14
|
+
abstract createSession(session: SessionPayload): Promise<SessionPayload>;
|
|
15
|
+
abstract getSession(sessionId: string): Promise<SessionPayload | null>;
|
|
16
|
+
abstract getUserSessions(userId: string): Promise<SessionPayload[]>;
|
|
17
|
+
abstract getCurrentSessions(userId: string): Promise<SessionPayload[]>;
|
|
18
|
+
abstract updateSession(sessionId: string, updates: Partial<SessionPayload>): Promise<SessionPayload>;
|
|
19
|
+
abstract deleteSession(sessionId: string): Promise<void>;
|
|
20
|
+
abstract deleteUserSessions(userId: string): Promise<void>;
|
|
21
|
+
abstract revokeSession(sessionId: string): Promise<void>;
|
|
22
|
+
abstract revokeUserSessions(userId: string): Promise<void>;
|
|
23
|
+
}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.BaseSessionService = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const common_1 = require("@nestjs/common");
|
|
6
|
+
const auth_constants_1 = require("../../auth.constants");
|
|
7
|
+
const common_2 = require("@nestjs/common");
|
|
8
|
+
const session_options_interface_1 = require("../../interfaces/session-options.interface");
|
|
9
|
+
const request_context_1 = require("../../request-context/request-context");
|
|
10
|
+
const ms_1 = tslib_1.__importDefault(require("ms"));
|
|
11
|
+
const lodash_1 = require("lodash");
|
|
12
|
+
let BaseSessionService = class BaseSessionService {
|
|
13
|
+
constructor(authModuleOptions) {
|
|
14
|
+
this.authModuleOptions = authModuleOptions;
|
|
15
|
+
const defaultSessionOptions = {
|
|
16
|
+
sessionExpiry: 7 * 24 * 60 * 60 * 1000,
|
|
17
|
+
refreshTokenExpiry: 15 * 60 * 1000,
|
|
18
|
+
storageType: session_options_interface_1.SessionStorageType.DATABASE,
|
|
19
|
+
};
|
|
20
|
+
this.sessionOptions = Object.assign({}, defaultSessionOptions, this.authModuleOptions.session);
|
|
21
|
+
}
|
|
22
|
+
getSessionOptions() {
|
|
23
|
+
return this.sessionOptions;
|
|
24
|
+
}
|
|
25
|
+
createSessionFromUser(user, extraData = {}) {
|
|
26
|
+
const { deviceName, ipAddress, browser } = request_context_1.RequestContext.getDeviceInfo();
|
|
27
|
+
const { isMfaVerified = false } = extraData;
|
|
28
|
+
if (!user) {
|
|
29
|
+
throw new common_1.UnauthorizedException('User not found');
|
|
30
|
+
}
|
|
31
|
+
const expiresAt = new Date(Date.now() + (0, ms_1.default)(this.authModuleOptions.session.sessionExpiry));
|
|
32
|
+
const session = {
|
|
33
|
+
userId: user.id,
|
|
34
|
+
data: {
|
|
35
|
+
user,
|
|
36
|
+
isMfaVerified: isMfaVerified,
|
|
37
|
+
roles: user.getRoles(),
|
|
38
|
+
permissions: user.getPermissions(),
|
|
39
|
+
},
|
|
40
|
+
userAgent: [browser, deviceName].join(' - '),
|
|
41
|
+
ipAddress,
|
|
42
|
+
deviceName,
|
|
43
|
+
expiresAt,
|
|
44
|
+
lastActive: new Date(),
|
|
45
|
+
createdAt: new Date(),
|
|
46
|
+
updatedAt: new Date(),
|
|
47
|
+
};
|
|
48
|
+
return this.createSession(session);
|
|
49
|
+
}
|
|
50
|
+
createSessionFromSession(session) {
|
|
51
|
+
const newSession = {
|
|
52
|
+
...(0, lodash_1.omit)(session, 'id'),
|
|
53
|
+
expiresAt: new Date(Date.now() + (0, ms_1.default)(this.authModuleOptions.session.sessionExpiry)),
|
|
54
|
+
};
|
|
55
|
+
return this.createSession(newSession);
|
|
56
|
+
}
|
|
57
|
+
};
|
|
58
|
+
exports.BaseSessionService = BaseSessionService;
|
|
59
|
+
exports.BaseSessionService = BaseSessionService = tslib_1.__decorate([
|
|
60
|
+
(0, common_1.Injectable)(),
|
|
61
|
+
tslib_1.__param(0, (0, common_2.Inject)(auth_constants_1.AUTH_MODULE_OPTIONS)),
|
|
62
|
+
tslib_1.__metadata("design:paramtypes", [Object])
|
|
63
|
+
], BaseSessionService);
|
|
64
|
+
//# sourceMappingURL=base-session.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"base-session.service.js","sourceRoot":"","sources":["../../../../../../../packages/nest-auth/src/lib/services/session/base-session.service.ts"],"names":[],"mappings":";;;;AAAA,2CAAmE;AAEnE,yDAA2D;AAC3D,2CAAwC;AACxC,0FAAgG;AAGhG,2EAAuE;AACvE,oDAAoB;AACpB,mCAA8B;AAGvB,IAAe,kBAAkB,GAAjC,MAAe,kBAAkB;IAGpC,YAEuB,iBAAoC;QAApC,sBAAiB,GAAjB,iBAAiB,CAAmB;QAEvD,MAAM,qBAAqB,GAAmB;YAC1C,aAAa,EAAE,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI;YACtC,kBAAkB,EAAE,EAAE,GAAG,EAAE,GAAG,IAAI;YAClC,WAAW,EAAE,8CAAkB,CAAC,QAAQ;SAC3C,CAAC;QACF,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,qBAAqB,EAAE,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC;IACnG,CAAC;IAED,iBAAiB;QACb,OAAO,IAAI,CAAC,cAAc,CAAC;IAC/B,CAAC;IAED,qBAAqB,CAAC,IAAU,EAAE,YAAyC,EAAE;QACzE,MAAM,EAAE,UAAU,EAAE,SAAS,EAAE,OAAO,EAAE,GAAG,gCAAc,CAAC,aAAa,EAAE,CAAC;QAC1E,MAAM,EAAE,aAAa,GAAG,KAAK,EAAE,GAAG,SAAS,CAAC;QAE5C,IAAI,CAAC,IAAI,EAAE,CAAC;YACR,MAAM,IAAI,8BAAqB,CAAC,gBAAgB,CAAC,CAAC;QACtD,CAAC;QAED,MAAM,SAAS,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,IAAA,YAAE,EAAC,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,CAAC;QAG1F,MAAM,OAAO,GAAmB;YAC5B,MAAM,EAAE,IAAI,CAAC,EAAE;YACf,IAAI,EAAE;gBACF,IAAI;gBACJ,aAAa,EAAE,aAAa;gBAC5B,KAAK,EAAE,IAAI,CAAC,QAAQ,EAAE;gBACtB,WAAW,EAAE,IAAI,CAAC,cAAc,EAAE;aACrC;YACD,SAAS,EAAE,CAAC,OAAO,EAAE,UAAU,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC;YAC5C,SAAS;YACT,UAAU;YACV,SAAS;YACT,UAAU,EAAE,IAAI,IAAI,EAAE;YACtB,SAAS,EAAE,IAAI,IAAI,EAAE;YACrB,SAAS,EAAE,IAAI,IAAI,EAAE;SACxB,CAAC;QAEF,OAAO,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;IACvC,CAAC;IAED,wBAAwB,CAAC,OAAuB;QAC5C,MAAM,UAAU,GAAmB;YAC/B,GAAG,IAAA,aAAI,EAAC,OAAO,EAAE,IAAI,CAAC;YACtB,SAAS,EAAE,IAAI,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,IAAA,YAAE,EAAC,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;SACrF,CAAC;QAEF,OAAO,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;IAC1C,CAAC;CAWJ,CAAA;AApEqB,gDAAkB;6BAAlB,kBAAkB;IADvC,IAAA,mBAAU,GAAE;IAKJ,mBAAA,IAAA,eAAM,EAAC,oCAAmB,CAAC,CAAA;;GAJd,kBAAkB,CAoEvC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { Repository } from 'typeorm';
|
|
2
|
+
import { Session } from '../../entities/session.entity';
|
|
3
|
+
import { BaseSessionService } from './base-session.service';
|
|
4
|
+
import { AuthModuleOptions } from '../../interfaces/auth-module-options.interface';
|
|
5
|
+
import { SessionPayload } from '../../interfaces/token-payload.interface';
|
|
6
|
+
export declare class DatabaseSessionService extends BaseSessionService {
|
|
7
|
+
readonly authModuleOptions: AuthModuleOptions;
|
|
8
|
+
private readonly sessionRepository;
|
|
9
|
+
constructor(authModuleOptions: AuthModuleOptions, sessionRepository: Repository<Session>);
|
|
10
|
+
createSession(session: SessionPayload): Promise<Session>;
|
|
11
|
+
getSession(sessionId: string): Promise<Session | null>;
|
|
12
|
+
getUserSessions(userId: string): Promise<Session[]>;
|
|
13
|
+
getCurrentSessions(userId: string): Promise<Session[]>;
|
|
14
|
+
updateSession(sessionId: string, updates: Partial<Session>): Promise<Session>;
|
|
15
|
+
deleteSession(sessionId: string): Promise<void>;
|
|
16
|
+
deleteUserSessions(userId: string): Promise<void>;
|
|
17
|
+
revokeSession(sessionId: string): Promise<void>;
|
|
18
|
+
revokeUserSessions(userId: string): Promise<void>;
|
|
19
|
+
}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.DatabaseSessionService = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const common_1 = require("@nestjs/common");
|
|
6
|
+
const typeorm_1 = require("@nestjs/typeorm");
|
|
7
|
+
const typeorm_2 = require("typeorm");
|
|
8
|
+
const session_entity_1 = require("../../entities/session.entity");
|
|
9
|
+
const base_session_service_1 = require("./base-session.service");
|
|
10
|
+
const auth_constants_1 = require("../../auth.constants");
|
|
11
|
+
const common_2 = require("@nestjs/common");
|
|
12
|
+
let DatabaseSessionService = class DatabaseSessionService extends base_session_service_1.BaseSessionService {
|
|
13
|
+
constructor(authModuleOptions, sessionRepository) {
|
|
14
|
+
super(authModuleOptions);
|
|
15
|
+
this.authModuleOptions = authModuleOptions;
|
|
16
|
+
this.sessionRepository = sessionRepository;
|
|
17
|
+
}
|
|
18
|
+
async createSession(session) {
|
|
19
|
+
const sessionEntity = await this.sessionRepository.save(session);
|
|
20
|
+
return sessionEntity;
|
|
21
|
+
}
|
|
22
|
+
async getSession(sessionId) {
|
|
23
|
+
return this.sessionRepository.findOne({ where: { id: sessionId } });
|
|
24
|
+
}
|
|
25
|
+
async getUserSessions(userId) {
|
|
26
|
+
return this.sessionRepository.find({ where: { userId } });
|
|
27
|
+
}
|
|
28
|
+
async getCurrentSessions(userId) {
|
|
29
|
+
return this.sessionRepository.find({ where: { userId, expiresAt: (0, typeorm_2.MoreThan)(new Date()) } });
|
|
30
|
+
}
|
|
31
|
+
async updateSession(sessionId, updates) {
|
|
32
|
+
await this.sessionRepository.update(sessionId, updates);
|
|
33
|
+
return this.getSession(sessionId);
|
|
34
|
+
}
|
|
35
|
+
async deleteSession(sessionId) {
|
|
36
|
+
await this.sessionRepository.delete(sessionId);
|
|
37
|
+
}
|
|
38
|
+
async deleteUserSessions(userId) {
|
|
39
|
+
await this.sessionRepository.delete({ userId });
|
|
40
|
+
}
|
|
41
|
+
async revokeSession(sessionId) {
|
|
42
|
+
await this.sessionRepository.delete(sessionId);
|
|
43
|
+
}
|
|
44
|
+
async revokeUserSessions(userId) {
|
|
45
|
+
await this.sessionRepository.delete({ userId });
|
|
46
|
+
}
|
|
47
|
+
};
|
|
48
|
+
exports.DatabaseSessionService = DatabaseSessionService;
|
|
49
|
+
exports.DatabaseSessionService = DatabaseSessionService = tslib_1.__decorate([
|
|
50
|
+
(0, common_1.Injectable)(),
|
|
51
|
+
tslib_1.__param(0, (0, common_2.Inject)(auth_constants_1.AUTH_MODULE_OPTIONS)),
|
|
52
|
+
tslib_1.__param(1, (0, typeorm_1.InjectRepository)(session_entity_1.Session)),
|
|
53
|
+
tslib_1.__metadata("design:paramtypes", [Object, typeorm_2.Repository])
|
|
54
|
+
], DatabaseSessionService);
|
|
55
|
+
//# sourceMappingURL=database-session.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"database-session.service.js","sourceRoot":"","sources":["../../../../../../../packages/nest-auth/src/lib/services/session/database-session.service.ts"],"names":[],"mappings":";;;;AAAA,2CAA4C;AAC5C,6CAAmD;AACnD,qCAA+C;AAC/C,kEAAwD;AACxD,iEAA4D;AAE5D,yDAA2D;AAC3D,2CAAwC;AAKjC,IAAM,sBAAsB,GAA5B,MAAM,sBAAuB,SAAQ,yCAAkB;IAC1D,YAEsB,iBAAoC,EAGrC,iBAAsC;QAEvD,KAAK,CAAC,iBAAiB,CAAC,CAAC;QALP,sBAAiB,GAAjB,iBAAiB,CAAmB;QAGrC,sBAAiB,GAAjB,iBAAiB,CAAqB;IAG3D,CAAC;IAED,KAAK,CAAC,aAAa,CAAC,OAAuB;QACvC,MAAM,aAAa,GAAG,MAAM,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACjE,OAAO,aAAa,CAAC;IACzB,CAAC;IAED,KAAK,CAAC,UAAU,CAAC,SAAiB;QAC9B,OAAO,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,EAAE,SAAS,EAAE,EAAE,CAAC,CAAC;IACxE,CAAC;IAED,KAAK,CAAC,eAAe,CAAC,MAAc;QAChC,OAAO,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,EAAE,MAAM,EAAE,EAAE,CAAC,CAAC;IAC9D,CAAC;IAED,KAAK,CAAC,kBAAkB,CAAC,MAAc;QACnC,OAAO,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,EAAE,MAAM,EAAE,SAAS,EAAE,IAAA,kBAAQ,EAAC,IAAI,IAAI,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC;IAC/F,CAAC;IAED,KAAK,CAAC,aAAa,CAAC,SAAiB,EAAE,OAAyB;QAC5D,MAAM,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC;QACxD,OAAO,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC;IACtC,CAAC;IAED,KAAK,CAAC,aAAa,CAAC,SAAiB;QACjC,MAAM,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;IACnD,CAAC;IAED,KAAK,CAAC,kBAAkB,CAAC,MAAc;QACnC,MAAM,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC;IACpD,CAAC;IAED,KAAK,CAAC,aAAa,CAAC,SAAiB;QACjC,MAAM,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;IACnD,CAAC;IAED,KAAK,CAAC,kBAAkB,CAAC,MAAc;QACnC,MAAM,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC;IACpD,CAAC;CACJ,CAAA;AAhDY,wDAAsB;iCAAtB,sBAAsB;IADlC,IAAA,mBAAU,GAAE;IAGJ,mBAAA,IAAA,eAAM,EAAC,oCAAmB,CAAC,CAAA;IAG3B,mBAAA,IAAA,0BAAgB,EAAC,wBAAO,CAAC,CAAA;qDACU,oBAAU;GANzC,sBAAsB,CAgDlC"}
|