@ambushsoftworks/nestjs-auth-graphql 0.4.0 → 0.6.7
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 +528 -1313
- package/dist/auth.module.d.ts +53 -2
- package/dist/auth.module.d.ts.map +1 -1
- package/dist/auth.module.js +115 -16
- package/dist/auth.module.js.map +1 -1
- package/dist/constants.d.ts +13 -0
- package/dist/constants.d.ts.map +1 -1
- package/dist/constants.js +14 -1
- package/dist/constants.js.map +1 -1
- package/dist/decorators/current-tenant.decorator.d.ts +2 -0
- package/dist/decorators/current-tenant.decorator.d.ts.map +1 -0
- package/dist/decorators/current-tenant.decorator.js +10 -0
- package/dist/decorators/current-tenant.decorator.js.map +1 -0
- package/dist/decorators/public-endpoint.decorator.d.ts +2 -0
- package/dist/decorators/public-endpoint.decorator.d.ts.map +1 -0
- package/dist/decorators/public-endpoint.decorator.js +9 -0
- package/dist/decorators/public-endpoint.decorator.js.map +1 -0
- package/dist/decorators/public.decorator.d.ts +3 -0
- package/dist/decorators/public.decorator.d.ts.map +1 -0
- package/dist/decorators/public.decorator.js +8 -0
- package/dist/decorators/public.decorator.js.map +1 -0
- package/dist/decorators/require-permissions.decorator.d.ts +2 -0
- package/dist/decorators/require-permissions.decorator.d.ts.map +1 -0
- package/dist/decorators/require-permissions.decorator.js +8 -0
- package/dist/decorators/require-permissions.decorator.js.map +1 -0
- package/dist/decorators/resource-scope.decorator.d.ts +2 -0
- package/dist/decorators/resource-scope.decorator.d.ts.map +1 -0
- package/dist/decorators/resource-scope.decorator.js +8 -0
- package/dist/decorators/resource-scope.decorator.js.map +1 -0
- package/dist/decorators/skip-tenant.decorator.d.ts +2 -0
- package/dist/decorators/skip-tenant.decorator.d.ts.map +1 -0
- package/dist/decorators/skip-tenant.decorator.js +8 -0
- package/dist/decorators/skip-tenant.decorator.js.map +1 -0
- package/dist/guards/create-auth-guard.d.ts +11 -0
- package/dist/guards/create-auth-guard.d.ts.map +1 -0
- package/dist/guards/create-auth-guard.js +49 -0
- package/dist/guards/create-auth-guard.js.map +1 -0
- package/dist/guards/csrf.guard.d.ts +16 -0
- package/dist/guards/csrf.guard.d.ts.map +1 -0
- package/dist/guards/csrf.guard.js +90 -0
- package/dist/guards/csrf.guard.js.map +1 -0
- package/dist/guards/permission.guard.d.ts +12 -0
- package/dist/guards/permission.guard.d.ts.map +1 -0
- package/dist/guards/permission.guard.js +90 -0
- package/dist/guards/permission.guard.js.map +1 -0
- package/dist/guards/tenant.guard.d.ts +13 -0
- package/dist/guards/tenant.guard.d.ts.map +1 -0
- package/dist/guards/tenant.guard.js +85 -0
- package/dist/guards/tenant.guard.js.map +1 -0
- package/dist/index.d.ts +32 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +32 -0
- package/dist/index.js.map +1 -1
- package/dist/interfaces/api-key-repository.interface.d.ts +11 -0
- package/dist/interfaces/api-key-repository.interface.d.ts.map +1 -0
- package/dist/interfaces/api-key-repository.interface.js +3 -0
- package/dist/interfaces/api-key-repository.interface.js.map +1 -0
- package/dist/interfaces/auth-lifecycle-hooks.interface.d.ts +2 -0
- package/dist/interfaces/auth-lifecycle-hooks.interface.d.ts.map +1 -1
- package/dist/interfaces/auth-user.interface.d.ts +28 -10
- package/dist/interfaces/auth-user.interface.d.ts.map +1 -1
- package/dist/interfaces/auth-user.interface.js.map +1 -1
- package/dist/interfaces/email-branding-config.interface.d.ts +10 -0
- package/dist/interfaces/email-branding-config.interface.d.ts.map +1 -0
- package/dist/interfaces/email-branding-config.interface.js +3 -0
- package/dist/interfaces/email-branding-config.interface.js.map +1 -0
- package/dist/interfaces/email-sender.interface.d.ts +13 -0
- package/dist/interfaces/email-sender.interface.d.ts.map +1 -0
- package/dist/interfaces/email-sender.interface.js +3 -0
- package/dist/interfaces/email-sender.interface.js.map +1 -0
- package/dist/interfaces/email-template-renderer.interface.d.ts +39 -0
- package/dist/interfaces/email-template-renderer.interface.d.ts.map +1 -0
- package/dist/interfaces/email-template-renderer.interface.js +3 -0
- package/dist/interfaces/email-template-renderer.interface.js.map +1 -0
- package/dist/interfaces/index.d.ts +3 -0
- package/dist/interfaces/index.d.ts.map +1 -1
- package/dist/interfaces/index.js +3 -0
- package/dist/interfaces/index.js.map +1 -1
- package/dist/interfaces/jwt-payload-factory.interface.d.ts +8 -0
- package/dist/interfaces/jwt-payload-factory.interface.d.ts.map +1 -0
- package/dist/interfaces/jwt-payload-factory.interface.js +3 -0
- package/dist/interfaces/jwt-payload-factory.interface.js.map +1 -0
- package/dist/interfaces/resource-permission-repository.interface.d.ts +4 -0
- package/dist/interfaces/resource-permission-repository.interface.d.ts.map +1 -0
- package/dist/interfaces/resource-permission-repository.interface.js +3 -0
- package/dist/interfaces/resource-permission-repository.interface.js.map +1 -0
- package/dist/interfaces/tenant-extractor.interface.d.ts +4 -0
- package/dist/interfaces/tenant-extractor.interface.d.ts.map +1 -0
- package/dist/interfaces/tenant-extractor.interface.js +3 -0
- package/dist/interfaces/tenant-extractor.interface.js.map +1 -0
- package/dist/interfaces/tenant-repository.interface.d.ts +9 -0
- package/dist/interfaces/tenant-repository.interface.d.ts.map +1 -0
- package/dist/interfaces/tenant-repository.interface.js +3 -0
- package/dist/interfaces/tenant-repository.interface.js.map +1 -0
- package/dist/interfaces/user-repository.interface.d.ts +26 -18
- package/dist/interfaces/user-repository.interface.d.ts.map +1 -1
- package/dist/repositories/noop-brute-force.repository.d.ts +1 -1
- package/dist/repositories/noop-brute-force.repository.d.ts.map +1 -1
- package/dist/repositories/noop-brute-force.repository.js +6 -6
- package/dist/repositories/noop-brute-force.repository.js.map +1 -1
- package/dist/repositories/noop-tenant-extractor.d.ts +8 -0
- package/dist/repositories/noop-tenant-extractor.d.ts.map +1 -0
- package/dist/repositories/noop-tenant-extractor.js +35 -0
- package/dist/repositories/noop-tenant-extractor.js.map +1 -0
- package/dist/repositories/noop-tenant.repository.d.ts +8 -0
- package/dist/repositories/noop-tenant.repository.d.ts.map +1 -0
- package/dist/repositories/noop-tenant.repository.js +39 -0
- package/dist/repositories/noop-tenant.repository.js.map +1 -0
- package/dist/resolvers/base-auth.resolver.d.ts +18 -5
- package/dist/resolvers/base-auth.resolver.d.ts.map +1 -1
- package/dist/resolvers/base-auth.resolver.js +59 -25
- package/dist/resolvers/base-auth.resolver.js.map +1 -1
- package/dist/resolvers/oauth.controller.d.ts +1 -1
- package/dist/resolvers/oauth.controller.d.ts.map +1 -1
- package/dist/resolvers/oauth.controller.js +3 -2
- package/dist/resolvers/oauth.controller.js.map +1 -1
- package/dist/services/auth.service.d.ts +23 -3
- package/dist/services/auth.service.d.ts.map +1 -1
- package/dist/services/auth.service.js +173 -91
- package/dist/services/auth.service.js.map +1 -1
- package/dist/services/biometric-auth.service.d.ts +0 -1
- package/dist/services/biometric-auth.service.d.ts.map +1 -1
- package/dist/services/biometric-auth.service.js +0 -6
- package/dist/services/biometric-auth.service.js.map +1 -1
- package/dist/services/brute-force-protection.service.d.ts +2 -0
- package/dist/services/brute-force-protection.service.d.ts.map +1 -1
- package/dist/services/brute-force-protection.service.js +8 -0
- package/dist/services/brute-force-protection.service.js.map +1 -1
- package/dist/services/configurable-email.service.d.ts +23 -0
- package/dist/services/configurable-email.service.d.ts.map +1 -0
- package/dist/services/configurable-email.service.js +114 -0
- package/dist/services/configurable-email.service.js.map +1 -0
- package/dist/services/default-email-template-renderer.d.ts +57 -0
- package/dist/services/default-email-template-renderer.d.ts.map +1 -0
- package/dist/services/default-email-template-renderer.js +422 -0
- package/dist/services/default-email-template-renderer.js.map +1 -0
- package/dist/services/default-jwt-payload-factory.d.ts +9 -0
- package/dist/services/default-jwt-payload-factory.d.ts.map +1 -0
- package/dist/services/default-jwt-payload-factory.js +26 -0
- package/dist/services/default-jwt-payload-factory.js.map +1 -0
- package/dist/services/header-tenant-extractor.d.ts +7 -0
- package/dist/services/header-tenant-extractor.d.ts.map +1 -0
- package/dist/services/header-tenant-extractor.js +38 -0
- package/dist/services/header-tenant-extractor.js.map +1 -0
- package/dist/services/noop-email-sender.d.ts +15 -0
- package/dist/services/noop-email-sender.d.ts.map +1 -0
- package/dist/services/noop-email-sender.js +24 -0
- package/dist/services/noop-email-sender.js.map +1 -0
- package/dist/services/noop-email.service.d.ts +1 -0
- package/dist/services/noop-email.service.d.ts.map +1 -1
- package/dist/services/noop-email.service.js +7 -2
- package/dist/services/noop-email.service.js.map +1 -1
- package/dist/services/noop-sms.service.d.ts +1 -0
- package/dist/services/noop-sms.service.d.ts.map +1 -1
- package/dist/services/noop-sms.service.js +6 -1
- package/dist/services/noop-sms.service.js.map +1 -1
- package/dist/services/oauth-linking-token.service.d.ts.map +1 -1
- package/dist/services/oauth-linking-token.service.js +3 -8
- package/dist/services/oauth-linking-token.service.js.map +1 -1
- package/dist/services/refresh-token.service.d.ts +1 -0
- package/dist/services/refresh-token.service.d.ts.map +1 -1
- package/dist/services/refresh-token.service.js +15 -3
- package/dist/services/refresh-token.service.js.map +1 -1
- package/dist/services/resend-email-sender.d.ts +17 -0
- package/dist/services/resend-email-sender.d.ts.map +1 -0
- package/dist/services/resend-email-sender.js +45 -0
- package/dist/services/resend-email-sender.js.map +1 -0
- package/dist/services/sendgrid-email-sender.d.ts +16 -0
- package/dist/services/sendgrid-email-sender.d.ts.map +1 -0
- package/dist/services/sendgrid-email-sender.js +75 -0
- package/dist/services/sendgrid-email-sender.js.map +1 -0
- package/dist/services/sendgrid-email.service.d.ts.map +1 -1
- package/dist/services/sendgrid-email.service.js.map +1 -1
- package/dist/services/verification.service.d.ts +7 -0
- package/dist/services/verification.service.d.ts.map +1 -1
- package/dist/services/verification.service.js +104 -116
- package/dist/services/verification.service.js.map +1 -1
- package/dist/strategies/api-key.strategy.d.ts +11 -0
- package/dist/strategies/api-key.strategy.d.ts.map +1 -0
- package/dist/strategies/api-key.strategy.js +63 -0
- package/dist/strategies/api-key.strategy.js.map +1 -0
- package/dist/strategies/jwt.strategy.d.ts +6 -2
- package/dist/strategies/jwt.strategy.d.ts.map +1 -1
- package/dist/strategies/jwt.strategy.js +30 -4
- package/dist/strategies/jwt.strategy.js.map +1 -1
- package/dist/test-utils/mock-repositories.js +1 -1
- package/dist/test-utils/mock-repositories.js.map +1 -1
- package/dist/utils/cookie-options.d.ts +18 -0
- package/dist/utils/cookie-options.d.ts.map +1 -0
- package/dist/utils/cookie-options.js +65 -0
- package/dist/utils/cookie-options.js.map +1 -0
- package/dist/utils/escape-html.d.ts +2 -0
- package/dist/utils/escape-html.d.ts.map +1 -0
- package/dist/utils/escape-html.js +12 -0
- package/dist/utils/escape-html.js.map +1 -0
- package/dist/utils/execution-context.d.ts +3 -0
- package/dist/utils/execution-context.d.ts.map +1 -0
- package/dist/utils/execution-context.js +12 -0
- package/dist/utils/execution-context.js.map +1 -0
- package/dist/utils/request-helpers.d.ts +2 -0
- package/dist/utils/request-helpers.d.ts.map +1 -0
- package/dist/utils/request-helpers.js +9 -0
- package/dist/utils/request-helpers.js.map +1 -0
- package/package.json +13 -6
- package/dist/resolvers/auth.resolver.d.ts +0 -73
- package/dist/resolvers/auth.resolver.d.ts.map +0 -1
- package/dist/resolvers/auth.resolver.js +0 -472
- package/dist/resolvers/auth.resolver.js.map +0 -1
- package/dist/utils/passport-inspector.d.ts +0 -11
- package/dist/utils/passport-inspector.d.ts.map +0 -1
- package/dist/utils/passport-inspector.js +0 -48
- package/dist/utils/passport-inspector.js.map +0 -1
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { CanActivate, ExecutionContext } from '@nestjs/common';
|
|
2
|
+
import { Reflector } from '@nestjs/core';
|
|
3
|
+
import type { AuthModuleOptions } from '../auth.module';
|
|
4
|
+
export declare class CsrfGuard implements CanActivate {
|
|
5
|
+
private readonly reflector;
|
|
6
|
+
private readonly logger;
|
|
7
|
+
private readonly headerName;
|
|
8
|
+
private readonly requireInProduction;
|
|
9
|
+
private readonly exemptOperations;
|
|
10
|
+
private readonly cookieAuthEnabled;
|
|
11
|
+
private readonly nodeEnv;
|
|
12
|
+
constructor(reflector: Reflector, options?: AuthModuleOptions);
|
|
13
|
+
canActivate(context: ExecutionContext): boolean;
|
|
14
|
+
private getOperationName;
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=csrf.guard.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"csrf.guard.d.ts","sourceRoot":"","sources":["../../src/guards/csrf.guard.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,WAAW,EACX,gBAAgB,EAKjB,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAKzC,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AA+BxD,qBACa,SAAU,YAAW,WAAW;IASzC,OAAO,CAAC,QAAQ,CAAC,SAAS;IAR5B,OAAO,CAAC,QAAQ,CAAC,MAAM,CAA8B;IACrD,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAS;IACpC,OAAO,CAAC,QAAQ,CAAC,mBAAmB,CAAU;IAC9C,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAc;IAC/C,OAAO,CAAC,QAAQ,CAAC,iBAAiB,CAAU;IAC5C,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAS;gBAGd,SAAS,EAAE,SAAS,EAGrC,OAAO,CAAC,EAAE,iBAAiB;IAS7B,WAAW,CAAC,OAAO,EAAE,gBAAgB,GAAG,OAAO;IAmD/C,OAAO,CAAC,gBAAgB;CAyBzB"}
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
+
};
|
|
14
|
+
var CsrfGuard_1;
|
|
15
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
16
|
+
exports.CsrfGuard = void 0;
|
|
17
|
+
const common_1 = require("@nestjs/common");
|
|
18
|
+
const core_1 = require("@nestjs/core");
|
|
19
|
+
const graphql_1 = require("@nestjs/graphql");
|
|
20
|
+
const public_decorator_1 = require("../decorators/public.decorator");
|
|
21
|
+
const constants_1 = require("../constants");
|
|
22
|
+
const execution_context_1 = require("../utils/execution-context");
|
|
23
|
+
let CsrfGuard = CsrfGuard_1 = class CsrfGuard {
|
|
24
|
+
constructor(reflector, options) {
|
|
25
|
+
this.reflector = reflector;
|
|
26
|
+
this.logger = new common_1.Logger(CsrfGuard_1.name);
|
|
27
|
+
this.cookieAuthEnabled = options?.features?.cookieAuth === true;
|
|
28
|
+
this.headerName = (options?.csrf?.headerName || 'X-Requested-With').toLowerCase();
|
|
29
|
+
this.requireInProduction = options?.csrf?.requireInProduction !== false;
|
|
30
|
+
this.exemptOperations = new Set(options?.csrf?.exemptOperations || []);
|
|
31
|
+
this.nodeEnv = options?.nodeEnv || process.env.NODE_ENV || 'production';
|
|
32
|
+
}
|
|
33
|
+
canActivate(context) {
|
|
34
|
+
if (!this.cookieAuthEnabled) {
|
|
35
|
+
return true;
|
|
36
|
+
}
|
|
37
|
+
const isPublic = this.reflector.getAllAndOverride(public_decorator_1.IS_PUBLIC_KEY, [
|
|
38
|
+
context.getHandler(),
|
|
39
|
+
context.getClass(),
|
|
40
|
+
]);
|
|
41
|
+
if (isPublic) {
|
|
42
|
+
return true;
|
|
43
|
+
}
|
|
44
|
+
const request = (0, execution_context_1.getRequestFromContext)(context);
|
|
45
|
+
const authHeader = request.headers?.authorization ?? request.headers?.Authorization;
|
|
46
|
+
if (authHeader) {
|
|
47
|
+
return true;
|
|
48
|
+
}
|
|
49
|
+
if (!this.requireInProduction && this.nodeEnv !== 'production') {
|
|
50
|
+
return true;
|
|
51
|
+
}
|
|
52
|
+
const operationName = this.getOperationName(request, context);
|
|
53
|
+
if (operationName && this.exemptOperations.has(operationName)) {
|
|
54
|
+
return true;
|
|
55
|
+
}
|
|
56
|
+
const csrfHeader = request.headers?.[this.headerName];
|
|
57
|
+
if (!csrfHeader) {
|
|
58
|
+
this.logger.warn(`CSRF validation failed: missing ${this.headerName} header` +
|
|
59
|
+
(operationName ? ` for operation: ${operationName}` : ''));
|
|
60
|
+
throw new common_1.ForbiddenException('CSRF validation failed');
|
|
61
|
+
}
|
|
62
|
+
return true;
|
|
63
|
+
}
|
|
64
|
+
getOperationName(request, context) {
|
|
65
|
+
if (request.body?.operationName) {
|
|
66
|
+
return request.body.operationName;
|
|
67
|
+
}
|
|
68
|
+
const contextType = context.getType();
|
|
69
|
+
if (contextType === 'graphql') {
|
|
70
|
+
try {
|
|
71
|
+
const gqlContext = graphql_1.GqlExecutionContext.create(context);
|
|
72
|
+
const info = gqlContext.getInfo?.();
|
|
73
|
+
if (info?.operation?.name?.value) {
|
|
74
|
+
return info.operation.name.value;
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
catch {
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
return undefined;
|
|
81
|
+
}
|
|
82
|
+
};
|
|
83
|
+
exports.CsrfGuard = CsrfGuard;
|
|
84
|
+
exports.CsrfGuard = CsrfGuard = CsrfGuard_1 = __decorate([
|
|
85
|
+
(0, common_1.Injectable)(),
|
|
86
|
+
__param(1, (0, common_1.Optional)()),
|
|
87
|
+
__param(1, (0, common_1.Inject)(constants_1.AUTH_MODULE_OPTIONS)),
|
|
88
|
+
__metadata("design:paramtypes", [core_1.Reflector, Object])
|
|
89
|
+
], CsrfGuard);
|
|
90
|
+
//# sourceMappingURL=csrf.guard.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"csrf.guard.js","sourceRoot":"","sources":["../../src/guards/csrf.guard.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { CanActivate, ExecutionContext } from '@nestjs/common';
|
|
2
|
+
import { Reflector } from '@nestjs/core';
|
|
3
|
+
import { IResourcePermissionRepository } from '../interfaces/resource-permission-repository.interface';
|
|
4
|
+
export declare class PermissionGuard implements CanActivate {
|
|
5
|
+
private readonly reflector;
|
|
6
|
+
private readonly resourcePermissionRepository?;
|
|
7
|
+
private readonly logger;
|
|
8
|
+
constructor(reflector: Reflector, resourcePermissionRepository?: IResourcePermissionRepository | undefined);
|
|
9
|
+
canActivate(context: ExecutionContext): Promise<boolean>;
|
|
10
|
+
private getResourceId;
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=permission.guard.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"permission.guard.d.ts","sourceRoot":"","sources":["../../src/guards/permission.guard.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,WAAW,EACX,gBAAgB,EAMjB,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAQzC,OAAO,EAAE,6BAA6B,EAAE,MAAM,wDAAwD,CAAC;AAqBvG,qBACa,eAAgB,YAAW,WAAW;IAI/C,OAAO,CAAC,QAAQ,CAAC,SAAS;IAG1B,OAAO,CAAC,QAAQ,CAAC,4BAA4B,CAAC;IANhD,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAoC;gBAGxC,SAAS,EAAE,SAAS,EAGpB,4BAA4B,CAAC,EAAE,6BAA6B,YAAA;IAGzE,WAAW,CAAC,OAAO,EAAE,gBAAgB,GAAG,OAAO,CAAC,OAAO,CAAC;IAwF9D,OAAO,CAAC,aAAa;CAWtB"}
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
+
};
|
|
14
|
+
var PermissionGuard_1;
|
|
15
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
16
|
+
exports.PermissionGuard = void 0;
|
|
17
|
+
const common_1 = require("@nestjs/common");
|
|
18
|
+
const core_1 = require("@nestjs/core");
|
|
19
|
+
const graphql_1 = require("@nestjs/graphql");
|
|
20
|
+
const constants_1 = require("../constants");
|
|
21
|
+
const execution_context_1 = require("../utils/execution-context");
|
|
22
|
+
let PermissionGuard = PermissionGuard_1 = class PermissionGuard {
|
|
23
|
+
constructor(reflector, resourcePermissionRepository) {
|
|
24
|
+
this.reflector = reflector;
|
|
25
|
+
this.resourcePermissionRepository = resourcePermissionRepository;
|
|
26
|
+
this.logger = new common_1.Logger(PermissionGuard_1.name);
|
|
27
|
+
}
|
|
28
|
+
async canActivate(context) {
|
|
29
|
+
const requiredPermissions = this.reflector.getAllAndOverride(constants_1.PERMISSIONS_KEY, [context.getHandler(), context.getClass()]);
|
|
30
|
+
if (!requiredPermissions || requiredPermissions.length === 0) {
|
|
31
|
+
return true;
|
|
32
|
+
}
|
|
33
|
+
const request = (0, execution_context_1.getRequestFromContext)(context);
|
|
34
|
+
const tenantContext = request._tenantContext;
|
|
35
|
+
if (!tenantContext) {
|
|
36
|
+
throw new common_1.ForbiddenException('Tenant context required for permission check — ensure TenantGuard runs before PermissionGuard');
|
|
37
|
+
}
|
|
38
|
+
const userPermissions = tenantContext.permissions;
|
|
39
|
+
const missingPermissions = requiredPermissions.filter((perm) => !userPermissions.includes(perm));
|
|
40
|
+
if (missingPermissions.length === 0) {
|
|
41
|
+
return true;
|
|
42
|
+
}
|
|
43
|
+
const resourceScope = this.reflector.getAllAndOverride(constants_1.RESOURCE_SCOPE_KEY, [context.getHandler(), context.getClass()]);
|
|
44
|
+
if (!resourceScope || !this.resourcePermissionRepository) {
|
|
45
|
+
throw new common_1.ForbiddenException('Insufficient permissions');
|
|
46
|
+
}
|
|
47
|
+
const resourceId = this.getResourceId(context, resourceScope.argName);
|
|
48
|
+
if (!resourceId) {
|
|
49
|
+
throw new common_1.ForbiddenException('Insufficient permissions');
|
|
50
|
+
}
|
|
51
|
+
try {
|
|
52
|
+
const userId = request.user?.id;
|
|
53
|
+
if (!userId) {
|
|
54
|
+
throw new common_1.ForbiddenException('Insufficient permissions');
|
|
55
|
+
}
|
|
56
|
+
for (const permission of missingPermissions) {
|
|
57
|
+
const hasPermission = await this.resourcePermissionRepository.hasPermission(userId, tenantContext.tenantId, permission, resourceScope.resourceType, resourceId);
|
|
58
|
+
if (!hasPermission) {
|
|
59
|
+
throw new common_1.ForbiddenException('Insufficient permissions');
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
return true;
|
|
63
|
+
}
|
|
64
|
+
catch (error) {
|
|
65
|
+
if (error instanceof common_1.ForbiddenException) {
|
|
66
|
+
throw error;
|
|
67
|
+
}
|
|
68
|
+
this.logger.error(`Failed resource permission check: ${error instanceof Error ? error.message : String(error)}`, error instanceof Error ? error.stack : undefined);
|
|
69
|
+
throw new common_1.ServiceUnavailableException('Unable to verify permissions');
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
getResourceId(context, argName) {
|
|
73
|
+
const contextType = context.getType();
|
|
74
|
+
if (contextType === 'graphql') {
|
|
75
|
+
const gqlContext = graphql_1.GqlExecutionContext.create(context);
|
|
76
|
+
const args = gqlContext.getArgs();
|
|
77
|
+
return args[argName];
|
|
78
|
+
}
|
|
79
|
+
const request = context.switchToHttp().getRequest();
|
|
80
|
+
return request.params?.[argName] ?? request.query?.[argName];
|
|
81
|
+
}
|
|
82
|
+
};
|
|
83
|
+
exports.PermissionGuard = PermissionGuard;
|
|
84
|
+
exports.PermissionGuard = PermissionGuard = PermissionGuard_1 = __decorate([
|
|
85
|
+
(0, common_1.Injectable)(),
|
|
86
|
+
__param(1, (0, common_1.Optional)()),
|
|
87
|
+
__param(1, (0, common_1.Inject)(constants_1.RESOURCE_PERMISSION_REPOSITORY)),
|
|
88
|
+
__metadata("design:paramtypes", [core_1.Reflector, Object])
|
|
89
|
+
], PermissionGuard);
|
|
90
|
+
//# sourceMappingURL=permission.guard.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"permission.guard.js","sourceRoot":"","sources":["../../src/guards/permission.guard.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { CanActivate, ExecutionContext } from '@nestjs/common';
|
|
2
|
+
import { Reflector } from '@nestjs/core';
|
|
3
|
+
import { ITenantExtractor } from '../interfaces/tenant-extractor.interface';
|
|
4
|
+
import { ITenantRepository } from '../interfaces/tenant-repository.interface';
|
|
5
|
+
export declare class TenantGuard implements CanActivate {
|
|
6
|
+
private readonly reflector;
|
|
7
|
+
private readonly tenantExtractor?;
|
|
8
|
+
private readonly tenantRepository?;
|
|
9
|
+
private readonly logger;
|
|
10
|
+
constructor(reflector: Reflector, tenantExtractor?: ITenantExtractor | undefined, tenantRepository?: ITenantRepository | undefined);
|
|
11
|
+
canActivate(context: ExecutionContext): Promise<boolean>;
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=tenant.guard.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tenant.guard.d.ts","sourceRoot":"","sources":["../../src/guards/tenant.guard.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,WAAW,EACX,gBAAgB,EAQjB,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAIzC,OAAO,EAAE,gBAAgB,EAAE,MAAM,0CAA0C,CAAC;AAC5E,OAAO,EAAE,iBAAiB,EAAE,MAAM,2CAA2C,CAAC;AAc9E,qBACa,WAAY,YAAW,WAAW;IAI3C,OAAO,CAAC,QAAQ,CAAC,SAAS;IACY,OAAO,CAAC,QAAQ,CAAC,eAAe,CAAC;IAChC,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAC;IAL3E,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAgC;gBAGpC,SAAS,EAAE,SAAS,EACkB,eAAe,CAAC,EAAE,gBAAgB,YAAA,EACjC,gBAAgB,CAAC,EAAE,iBAAiB,YAAA;IAGxF,WAAW,CAAC,OAAO,EAAE,gBAAgB,GAAG,OAAO,CAAC,OAAO,CAAC;CAiE/D"}
|
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
+
};
|
|
14
|
+
var TenantGuard_1;
|
|
15
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
16
|
+
exports.TenantGuard = void 0;
|
|
17
|
+
const common_1 = require("@nestjs/common");
|
|
18
|
+
const core_1 = require("@nestjs/core");
|
|
19
|
+
const public_decorator_1 = require("../decorators/public.decorator");
|
|
20
|
+
const constants_1 = require("../constants");
|
|
21
|
+
const execution_context_1 = require("../utils/execution-context");
|
|
22
|
+
let TenantGuard = TenantGuard_1 = class TenantGuard {
|
|
23
|
+
constructor(reflector, tenantExtractor, tenantRepository) {
|
|
24
|
+
this.reflector = reflector;
|
|
25
|
+
this.tenantExtractor = tenantExtractor;
|
|
26
|
+
this.tenantRepository = tenantRepository;
|
|
27
|
+
this.logger = new common_1.Logger(TenantGuard_1.name);
|
|
28
|
+
}
|
|
29
|
+
async canActivate(context) {
|
|
30
|
+
const isPublic = this.reflector.getAllAndOverride(public_decorator_1.IS_PUBLIC_KEY, [
|
|
31
|
+
context.getHandler(),
|
|
32
|
+
context.getClass(),
|
|
33
|
+
]);
|
|
34
|
+
if (isPublic)
|
|
35
|
+
return true;
|
|
36
|
+
const skipTenant = this.reflector.getAllAndOverride(constants_1.SKIP_TENANT_KEY, [
|
|
37
|
+
context.getHandler(),
|
|
38
|
+
context.getClass(),
|
|
39
|
+
]);
|
|
40
|
+
if (skipTenant)
|
|
41
|
+
return true;
|
|
42
|
+
if (!this.tenantRepository)
|
|
43
|
+
return true;
|
|
44
|
+
const request = (0, execution_context_1.getRequestFromContext)(context);
|
|
45
|
+
if (!this.tenantExtractor) {
|
|
46
|
+
throw new common_1.BadRequestException('Tenant ID required');
|
|
47
|
+
}
|
|
48
|
+
const tenantId = this.tenantExtractor.extractTenantId(request);
|
|
49
|
+
if (!tenantId) {
|
|
50
|
+
throw new common_1.BadRequestException('Tenant ID required');
|
|
51
|
+
}
|
|
52
|
+
const user = request.user;
|
|
53
|
+
if (!user) {
|
|
54
|
+
throw new common_1.UnauthorizedException('Authentication required');
|
|
55
|
+
}
|
|
56
|
+
try {
|
|
57
|
+
const tenantContext = await this.tenantRepository.resolveTenant(user.id, tenantId);
|
|
58
|
+
if (!tenantContext) {
|
|
59
|
+
throw new common_1.ForbiddenException('Access denied to this tenant');
|
|
60
|
+
}
|
|
61
|
+
request._tenantContext = tenantContext;
|
|
62
|
+
return true;
|
|
63
|
+
}
|
|
64
|
+
catch (error) {
|
|
65
|
+
if (error instanceof common_1.ForbiddenException ||
|
|
66
|
+
error instanceof common_1.BadRequestException ||
|
|
67
|
+
error instanceof common_1.UnauthorizedException ||
|
|
68
|
+
error instanceof common_1.ServiceUnavailableException) {
|
|
69
|
+
throw error;
|
|
70
|
+
}
|
|
71
|
+
this.logger.error(`Failed to resolve tenant context: ${error instanceof Error ? error.message : String(error)}`, error instanceof Error ? error.stack : undefined);
|
|
72
|
+
throw new common_1.ServiceUnavailableException('Unable to resolve tenant context');
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
};
|
|
76
|
+
exports.TenantGuard = TenantGuard;
|
|
77
|
+
exports.TenantGuard = TenantGuard = TenantGuard_1 = __decorate([
|
|
78
|
+
(0, common_1.Injectable)(),
|
|
79
|
+
__param(1, (0, common_1.Optional)()),
|
|
80
|
+
__param(1, (0, common_1.Inject)(constants_1.TENANT_EXTRACTOR)),
|
|
81
|
+
__param(2, (0, common_1.Optional)()),
|
|
82
|
+
__param(2, (0, common_1.Inject)(constants_1.TENANT_REPOSITORY)),
|
|
83
|
+
__metadata("design:paramtypes", [core_1.Reflector, Object, Object])
|
|
84
|
+
], TenantGuard);
|
|
85
|
+
//# sourceMappingURL=tenant.guard.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tenant.guard.js","sourceRoot":"","sources":["../../src/guards/tenant.guard.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,2CAWwB;AACxB,uCAAyC;AACzC,qEAA+D;AAC/D,4CAAoF;AACpF,kEAAmE;AAiB5D,IAAM,WAAW,mBAAjB,MAAM,WAAW;IAGtB,YACmB,SAAoB,EACC,eAAmD,EAClD,gBAAqD;QAF3E,cAAS,GAAT,SAAS,CAAW;QACkB,oBAAe,GAAf,eAAe,CAAmB;QACjC,qBAAgB,GAAhB,gBAAgB,CAAoB;QAL7E,WAAM,GAAG,IAAI,eAAM,CAAC,aAAW,CAAC,IAAI,CAAC,CAAC;IAMpD,CAAC;IAEJ,KAAK,CAAC,WAAW,CAAC,OAAyB;QAEzC,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,iBAAiB,CAAU,gCAAa,EAAE;YACxE,OAAO,CAAC,UAAU,EAAE;YACpB,OAAO,CAAC,QAAQ,EAAE;SACnB,CAAC,CAAC;QACH,IAAI,QAAQ;YAAE,OAAO,IAAI,CAAC;QAG1B,MAAM,UAAU,GAAG,IAAI,CAAC,SAAS,CAAC,iBAAiB,CAAU,2BAAe,EAAE;YAC5E,OAAO,CAAC,UAAU,EAAE;YACpB,OAAO,CAAC,QAAQ,EAAE;SACnB,CAAC,CAAC;QACH,IAAI,UAAU;YAAE,OAAO,IAAI,CAAC;QAG5B,IAAI,CAAC,IAAI,CAAC,gBAAgB;YAAE,OAAO,IAAI,CAAC;QAExC,MAAM,OAAO,GAAG,IAAA,yCAAqB,EAAC,OAAO,CAAC,CAAC;QAG/C,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC;YAC1B,MAAM,IAAI,4BAAmB,CAAC,oBAAoB,CAAC,CAAC;QACtD,CAAC;QAED,MAAM,QAAQ,GAAG,IAAI,CAAC,eAAe,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC;QAC/D,IAAI,CAAC,QAAQ,EAAE,CAAC;YACd,MAAM,IAAI,4BAAmB,CAAC,oBAAoB,CAAC,CAAC;QACtD,CAAC;QAGD,MAAM,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;QAC1B,IAAI,CAAC,IAAI,EAAE,CAAC;YACV,MAAM,IAAI,8BAAqB,CAAC,yBAAyB,CAAC,CAAC;QAC7D,CAAC;QAGD,IAAI,CAAC;YACH,MAAM,aAAa,GAAG,MAAM,IAAI,CAAC,gBAAgB,CAAC,aAAa,CAAC,IAAI,CAAC,EAAE,EAAE,QAAQ,CAAC,CAAC;YAEnF,IAAI,CAAC,aAAa,EAAE,CAAC;gBACnB,MAAM,IAAI,2BAAkB,CAAC,8BAA8B,CAAC,CAAC;YAC/D,CAAC;YAED,OAAO,CAAC,cAAc,GAAG,aAAa,CAAC;YACvC,OAAO,IAAI,CAAC;QACd,CAAC;QAAC,OAAO,KAAc,EAAE,CAAC;YAExB,IACE,KAAK,YAAY,2BAAkB;gBACnC,KAAK,YAAY,4BAAmB;gBACpC,KAAK,YAAY,8BAAqB;gBACtC,KAAK,YAAY,oCAA2B,EAC5C,CAAC;gBACD,MAAM,KAAK,CAAC;YACd,CAAC;YAGD,IAAI,CAAC,MAAM,CAAC,KAAK,CACf,qCAAqC,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,EAC7F,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,SAAS,CACjD,CAAC;YACF,MAAM,IAAI,oCAA2B,CAAC,kCAAkC,CAAC,CAAC;QAC5E,CAAC;IACH,CAAC;CACF,CAAA;AA1EY,kCAAW;sBAAX,WAAW;IADvB,IAAA,mBAAU,GAAE;IAMR,WAAA,IAAA,iBAAQ,GAAE,CAAA;IAAE,WAAA,IAAA,eAAM,EAAC,4BAAgB,CAAC,CAAA;IACpC,WAAA,IAAA,iBAAQ,GAAE,CAAA;IAAE,WAAA,IAAA,eAAM,EAAC,6BAAiB,CAAC,CAAA;qCAFV,gBAAS;GAJ5B,WAAW,CA0EvB"}
|
package/dist/index.d.ts
CHANGED
|
@@ -15,6 +15,14 @@ export * from './interfaces/password-policy-config.interface';
|
|
|
15
15
|
export * from './interfaces/rate-limiter.interface';
|
|
16
16
|
export * from './interfaces/password-reset-strategy.interface';
|
|
17
17
|
export * from './interfaces/magic-link-repository.interface';
|
|
18
|
+
export * from './interfaces/tenant-repository.interface';
|
|
19
|
+
export * from './interfaces/tenant-extractor.interface';
|
|
20
|
+
export * from './interfaces/resource-permission-repository.interface';
|
|
21
|
+
export * from './interfaces/jwt-payload-factory.interface';
|
|
22
|
+
export * from './interfaces/api-key-repository.interface';
|
|
23
|
+
export * from './interfaces/email-template-renderer.interface';
|
|
24
|
+
export * from './interfaces/email-sender.interface';
|
|
25
|
+
export * from './interfaces/email-branding-config.interface';
|
|
18
26
|
export * from './services/auth.service';
|
|
19
27
|
export * from './services/refresh-token.service';
|
|
20
28
|
export * from './services/verification.service';
|
|
@@ -26,21 +34,31 @@ export * from './services/biometric-verification.service';
|
|
|
26
34
|
export * from './services/oauth-linking-token.service';
|
|
27
35
|
export * from './services/password-validation.service';
|
|
28
36
|
export * from './services/in-memory-rate-limiter.service';
|
|
37
|
+
export * from './services/default-jwt-payload-factory';
|
|
38
|
+
export * from './services/header-tenant-extractor';
|
|
39
|
+
export * from './services/default-email-template-renderer';
|
|
40
|
+
export * from './services/configurable-email.service';
|
|
29
41
|
export * from './services/sendgrid-email.service';
|
|
30
42
|
export * from './services/twilio-sms.service';
|
|
31
43
|
export * from './services/noop-email.service';
|
|
32
44
|
export * from './services/noop-sms.service';
|
|
33
45
|
export * from './services/console-logger.service';
|
|
46
|
+
export * from './services/sendgrid-email-sender';
|
|
47
|
+
export * from './services/resend-email-sender';
|
|
48
|
+
export * from './services/noop-email-sender';
|
|
34
49
|
export * from './repositories/noop-verification.repository';
|
|
35
50
|
export * from './repositories/noop-brute-force.repository';
|
|
36
51
|
export * from './repositories/noop-biometric.repository';
|
|
37
52
|
export * from './repositories/noop-rate-limiter';
|
|
38
53
|
export * from './repositories/noop-magic-link.repository';
|
|
54
|
+
export * from './repositories/noop-tenant.repository';
|
|
55
|
+
export * from './repositories/noop-tenant-extractor';
|
|
39
56
|
export * from './strategies/jwt.strategy';
|
|
40
57
|
export * from './strategies/google.strategy';
|
|
41
58
|
export * from './strategies/facebook.strategy';
|
|
42
59
|
export * from './strategies/noop-google.strategy';
|
|
43
60
|
export * from './strategies/noop-facebook.strategy';
|
|
61
|
+
export * from './strategies/api-key.strategy';
|
|
44
62
|
export * from './strategies/verification-code.strategy';
|
|
45
63
|
export * from './strategies/magic-link.strategy';
|
|
46
64
|
export * from './resolvers/base-auth.resolver';
|
|
@@ -75,7 +93,17 @@ export * from './dto/request-password-reset.input';
|
|
|
75
93
|
export * from './dto/reset-password.input';
|
|
76
94
|
export * from './dto/password-reset-response.dto';
|
|
77
95
|
export * from './decorators/current-user.decorator';
|
|
96
|
+
export * from './decorators/public.decorator';
|
|
97
|
+
export * from './decorators/public-endpoint.decorator';
|
|
98
|
+
export * from './decorators/skip-tenant.decorator';
|
|
99
|
+
export * from './decorators/require-permissions.decorator';
|
|
100
|
+
export * from './decorators/current-tenant.decorator';
|
|
101
|
+
export * from './decorators/resource-scope.decorator';
|
|
78
102
|
export * from './guards/jwt-auth.guard';
|
|
103
|
+
export * from './guards/tenant.guard';
|
|
104
|
+
export * from './guards/permission.guard';
|
|
105
|
+
export * from './guards/create-auth-guard';
|
|
106
|
+
export * from './guards/csrf.guard';
|
|
79
107
|
export { AuthUser } from './entities/auth-user.entity';
|
|
80
108
|
export * from './exceptions/account-locked.exception';
|
|
81
109
|
export * from './exceptions/verification.exceptions';
|
|
@@ -84,4 +112,8 @@ export * from './exceptions/password-reset.exceptions';
|
|
|
84
112
|
export * from './enums/verification-type.enum';
|
|
85
113
|
export * from './types/oauth.types';
|
|
86
114
|
export * from './utils/provider-helpers';
|
|
115
|
+
export * from './utils/cookie-options';
|
|
116
|
+
export * from './utils/escape-html';
|
|
117
|
+
export * from './utils/execution-context';
|
|
118
|
+
export * from './utils/request-helpers';
|
|
87
119
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAYA,cAAc,eAAe,CAAC;AAC9B,cAAc,aAAa,CAAC;AAK5B,cAAc,kCAAkC,CAAC;AACjD,cAAc,wCAAwC,CAAC;AACvD,cAAc,sCAAsC,CAAC;AACrD,cAAc,oCAAoC,CAAC;AACnD,cAAc,6CAA6C,CAAC;AAC5D,cAAc,wCAAwC,CAAC;AACvD,cAAc,iDAAiD,CAAC;AAChE,cAAc,oCAAoC,CAAC;AACnD,cAAc,gDAAgD,CAAC;AAC/D,cAAc,+CAA+C,CAAC;AAC9D,cAAc,6CAA6C,CAAC;AAC5D,cAAc,+CAA+C,CAAC;AAC9D,cAAc,qCAAqC,CAAC;AACpD,cAAc,gDAAgD,CAAC;AAC/D,cAAc,8CAA8C,CAAC;AAK7D,cAAc,yBAAyB,CAAC;AACxC,cAAc,kCAAkC,CAAC;AACjD,cAAc,iCAAiC,CAAC;AAChD,cAAc,+BAA+B,CAAC;AAC9C,cAAc,gCAAgC,CAAC;AAC/C,cAAc,2CAA2C,CAAC;AAE1D,cAAc,mCAAmC,CAAC;AAElD,cAAc,2CAA2C,CAAC;AAC1D,cAAc,wCAAwC,CAAC;AACvD,cAAc,wCAAwC,CAAC;AACvD,cAAc,2CAA2C,CAAC;
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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"}
|
package/dist/index.js
CHANGED
|
@@ -32,6 +32,14 @@ __exportStar(require("./interfaces/password-policy-config.interface"), exports);
|
|
|
32
32
|
__exportStar(require("./interfaces/rate-limiter.interface"), exports);
|
|
33
33
|
__exportStar(require("./interfaces/password-reset-strategy.interface"), exports);
|
|
34
34
|
__exportStar(require("./interfaces/magic-link-repository.interface"), exports);
|
|
35
|
+
__exportStar(require("./interfaces/tenant-repository.interface"), exports);
|
|
36
|
+
__exportStar(require("./interfaces/tenant-extractor.interface"), exports);
|
|
37
|
+
__exportStar(require("./interfaces/resource-permission-repository.interface"), exports);
|
|
38
|
+
__exportStar(require("./interfaces/jwt-payload-factory.interface"), exports);
|
|
39
|
+
__exportStar(require("./interfaces/api-key-repository.interface"), exports);
|
|
40
|
+
__exportStar(require("./interfaces/email-template-renderer.interface"), exports);
|
|
41
|
+
__exportStar(require("./interfaces/email-sender.interface"), exports);
|
|
42
|
+
__exportStar(require("./interfaces/email-branding-config.interface"), exports);
|
|
35
43
|
__exportStar(require("./services/auth.service"), exports);
|
|
36
44
|
__exportStar(require("./services/refresh-token.service"), exports);
|
|
37
45
|
__exportStar(require("./services/verification.service"), exports);
|
|
@@ -43,21 +51,31 @@ __exportStar(require("./services/biometric-verification.service"), exports);
|
|
|
43
51
|
__exportStar(require("./services/oauth-linking-token.service"), exports);
|
|
44
52
|
__exportStar(require("./services/password-validation.service"), exports);
|
|
45
53
|
__exportStar(require("./services/in-memory-rate-limiter.service"), exports);
|
|
54
|
+
__exportStar(require("./services/default-jwt-payload-factory"), exports);
|
|
55
|
+
__exportStar(require("./services/header-tenant-extractor"), exports);
|
|
56
|
+
__exportStar(require("./services/default-email-template-renderer"), exports);
|
|
57
|
+
__exportStar(require("./services/configurable-email.service"), exports);
|
|
46
58
|
__exportStar(require("./services/sendgrid-email.service"), exports);
|
|
47
59
|
__exportStar(require("./services/twilio-sms.service"), exports);
|
|
48
60
|
__exportStar(require("./services/noop-email.service"), exports);
|
|
49
61
|
__exportStar(require("./services/noop-sms.service"), exports);
|
|
50
62
|
__exportStar(require("./services/console-logger.service"), exports);
|
|
63
|
+
__exportStar(require("./services/sendgrid-email-sender"), exports);
|
|
64
|
+
__exportStar(require("./services/resend-email-sender"), exports);
|
|
65
|
+
__exportStar(require("./services/noop-email-sender"), exports);
|
|
51
66
|
__exportStar(require("./repositories/noop-verification.repository"), exports);
|
|
52
67
|
__exportStar(require("./repositories/noop-brute-force.repository"), exports);
|
|
53
68
|
__exportStar(require("./repositories/noop-biometric.repository"), exports);
|
|
54
69
|
__exportStar(require("./repositories/noop-rate-limiter"), exports);
|
|
55
70
|
__exportStar(require("./repositories/noop-magic-link.repository"), exports);
|
|
71
|
+
__exportStar(require("./repositories/noop-tenant.repository"), exports);
|
|
72
|
+
__exportStar(require("./repositories/noop-tenant-extractor"), exports);
|
|
56
73
|
__exportStar(require("./strategies/jwt.strategy"), exports);
|
|
57
74
|
__exportStar(require("./strategies/google.strategy"), exports);
|
|
58
75
|
__exportStar(require("./strategies/facebook.strategy"), exports);
|
|
59
76
|
__exportStar(require("./strategies/noop-google.strategy"), exports);
|
|
60
77
|
__exportStar(require("./strategies/noop-facebook.strategy"), exports);
|
|
78
|
+
__exportStar(require("./strategies/api-key.strategy"), exports);
|
|
61
79
|
__exportStar(require("./strategies/verification-code.strategy"), exports);
|
|
62
80
|
__exportStar(require("./strategies/magic-link.strategy"), exports);
|
|
63
81
|
__exportStar(require("./resolvers/base-auth.resolver"), exports);
|
|
@@ -91,7 +109,17 @@ __exportStar(require("./dto/request-password-reset.input"), exports);
|
|
|
91
109
|
__exportStar(require("./dto/reset-password.input"), exports);
|
|
92
110
|
__exportStar(require("./dto/password-reset-response.dto"), exports);
|
|
93
111
|
__exportStar(require("./decorators/current-user.decorator"), exports);
|
|
112
|
+
__exportStar(require("./decorators/public.decorator"), exports);
|
|
113
|
+
__exportStar(require("./decorators/public-endpoint.decorator"), exports);
|
|
114
|
+
__exportStar(require("./decorators/skip-tenant.decorator"), exports);
|
|
115
|
+
__exportStar(require("./decorators/require-permissions.decorator"), exports);
|
|
116
|
+
__exportStar(require("./decorators/current-tenant.decorator"), exports);
|
|
117
|
+
__exportStar(require("./decorators/resource-scope.decorator"), exports);
|
|
94
118
|
__exportStar(require("./guards/jwt-auth.guard"), exports);
|
|
119
|
+
__exportStar(require("./guards/tenant.guard"), exports);
|
|
120
|
+
__exportStar(require("./guards/permission.guard"), exports);
|
|
121
|
+
__exportStar(require("./guards/create-auth-guard"), exports);
|
|
122
|
+
__exportStar(require("./guards/csrf.guard"), exports);
|
|
95
123
|
var auth_user_entity_1 = require("./entities/auth-user.entity");
|
|
96
124
|
Object.defineProperty(exports, "AuthUser", { enumerable: true, get: function () { return auth_user_entity_1.AuthUser; } });
|
|
97
125
|
__exportStar(require("./exceptions/account-locked.exception"), exports);
|
|
@@ -101,4 +129,8 @@ __exportStar(require("./exceptions/password-reset.exceptions"), exports);
|
|
|
101
129
|
__exportStar(require("./enums/verification-type.enum"), exports);
|
|
102
130
|
__exportStar(require("./types/oauth.types"), exports);
|
|
103
131
|
__exportStar(require("./utils/provider-helpers"), exports);
|
|
132
|
+
__exportStar(require("./utils/cookie-options"), exports);
|
|
133
|
+
__exportStar(require("./utils/escape-html"), exports);
|
|
134
|
+
__exportStar(require("./utils/execution-context"), exports);
|
|
135
|
+
__exportStar(require("./utils/request-helpers"), exports);
|
|
104
136
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAYA,gDAA8B;AAC9B,8CAA4B;AAK5B,mEAAiD;AACjD,yEAAuD;AACvD,uEAAqD;AACrD,qEAAmD;AACnD,8EAA4D;AAC5D,yEAAuD;AACvD,kFAAgE;AAChE,qEAAmD;AACnD,iFAA+D;AAC/D,gFAA8D;AAC9D,8EAA4D;AAC5D,gFAA8D;AAC9D,sEAAoD;AACpD,iFAA+D;AAC/D,+EAA6D;AAK7D,0DAAwC;AACxC,mEAAiD;AACjD,kEAAgD;AAChD,gEAA8C;AAC9C,iEAA+C;AAC/C,4EAA0D;AAE1D,oEAAkD;AAElD,4EAA0D;AAC1D,yEAAuD;AACvD,yEAAuD;AACvD,4EAA0D;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAYA,gDAA8B;AAC9B,8CAA4B;AAK5B,mEAAiD;AACjD,yEAAuD;AACvD,uEAAqD;AACrD,qEAAmD;AACnD,8EAA4D;AAC5D,yEAAuD;AACvD,kFAAgE;AAChE,qEAAmD;AACnD,iFAA+D;AAC/D,gFAA8D;AAC9D,8EAA4D;AAC5D,gFAA8D;AAC9D,sEAAoD;AACpD,iFAA+D;AAC/D,+EAA6D;AAC7D,2EAAyD;AACzD,0EAAwD;AACxD,wFAAsE;AACtE,6EAA2D;AAC3D,4EAA0D;AAC1D,iFAA+D;AAC/D,sEAAoD;AACpD,+EAA6D;AAK7D,0DAAwC;AACxC,mEAAiD;AACjD,kEAAgD;AAChD,gEAA8C;AAC9C,iEAA+C;AAC/C,4EAA0D;AAE1D,oEAAkD;AAElD,4EAA0D;AAC1D,yEAAuD;AACvD,yEAAuD;AACvD,4EAA0D;AAC1D,yEAAuD;AACvD,qEAAmD;AACnD,6EAA2D;AAC3D,wEAAsD;AAKtD,oEAAkD;AAClD,gEAA8C;AAC9C,gEAA8C;AAC9C,8DAA4C;AAC5C,oEAAkD;AAClD,mEAAiD;AACjD,iEAA+C;AAC/C,+DAA6C;AAK7C,8EAA4D;AAC5D,6EAA2D;AAC3D,2EAAyD;AACzD,mEAAiD;AACjD,4EAA0D;AAC1D,wEAAsD;AACtD,uEAAqD;AAKrD,4DAA0C;AAC1C,+DAA6C;AAC7C,iEAA+C;AAC/C,oEAAkD;AAClD,sEAAoD;AACpD,gEAA8C;AAC9C,0EAAwD;AACxD,mEAAiD;AAKjD,iEAA+C;AAG/C,+DAA6C;AAM7C,oDAAkC;AAClC,qDAAmC;AACnC,4DAA0C;AAC1C,qDAAmC;AACnC,4DAA0C;AAC1C,2DAAyC;AACzC,kEAAgD;AAChD,sEAAoD;AACpD,2DAAyC;AACzC,wEAAsD;AACtD,sEAAoD;AACpD,kEAAgD;AAChD,uEAAqD;AACrD,oEAAkD;AAClD,2EAAyD;AACzD,gEAA8C;AAC9C,8DAA4C;AAC5C,6DAA2C;AAC3C,+DAA6C;AAC7C,+DAA6C;AAC7C,yEAAuD;AACvD,iEAA+C;AAC/C,gEAA8C;AAC9C,6EAA2D;AAC3D,8DAA4C;AAC5C,qEAAmD;AACnD,6DAA2C;AAC3C,oEAAkD;AAKlD,sEAAoD;AACpD,gEAA8C;AAC9C,yEAAuD;AACvD,qEAAmD;AACnD,6EAA2D;AAC3D,wEAAsD;AACtD,wEAAsD;AAKtD,0DAAwC;AACxC,wDAAsC;AACtC,4DAA0C;AAC1C,6DAA2C;AAC3C,sDAAoC;AAKpC,gEAAuD;AAA9C,4GAAA,QAAQ,OAAA;AAKjB,wEAAsD;AACtD,uEAAqD;AACrD,gEAA8C;AAC9C,yEAAuD;AAKvD,iEAA+C;AAK/C,sDAAoC;AAKpC,2DAAyC;AACzC,yDAAuC;AACvC,sDAAoC;AACpC,4DAA0C;AAC1C,0DAAwC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export interface IApiKeyAccount {
|
|
2
|
+
id: string;
|
|
3
|
+
email: string;
|
|
4
|
+
isActive: boolean;
|
|
5
|
+
isServiceAccount: boolean;
|
|
6
|
+
metadata: Record<string, unknown>;
|
|
7
|
+
}
|
|
8
|
+
export interface IApiKeyRepository {
|
|
9
|
+
findByKeyHash(keyHash: string): Promise<IApiKeyAccount | null>;
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=api-key-repository.interface.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"api-key-repository.interface.d.ts","sourceRoot":"","sources":["../../src/interfaces/api-key-repository.interface.ts"],"names":[],"mappings":"AAkDA,MAAM,WAAW,cAAc;IAE7B,EAAE,EAAE,MAAM,CAAC;IAGX,KAAK,EAAE,MAAM,CAAC;IAGd,QAAQ,EAAE,OAAO,CAAC;IAGlB,gBAAgB,EAAE,OAAO,CAAC;IAG1B,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACnC;AAQD,MAAM,WAAW,iBAAiB;IAOhC,aAAa,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,cAAc,GAAG,IAAI,CAAC,CAAC;CAChE"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"api-key-repository.interface.js","sourceRoot":"","sources":["../../src/interfaces/api-key-repository.interface.ts"],"names":[],"mappings":""}
|
|
@@ -6,6 +6,8 @@ export interface IAuthLifecycleHooks<T extends import('./auth-user.interface').I
|
|
|
6
6
|
onPhoneVerified?(user: T): Promise<void>;
|
|
7
7
|
onOAuthAccountLinked?(user: T, provider: string): Promise<void>;
|
|
8
8
|
onPasswordReset?(user: T): Promise<void>;
|
|
9
|
+
onPasswordChanged?(user: T): Promise<void>;
|
|
10
|
+
onAuthFailure?(email: string, ipAddress: string | undefined, reason: string): void;
|
|
9
11
|
onAccountDelete?(user: T): Promise<void>;
|
|
10
12
|
}
|
|
11
13
|
//# sourceMappingURL=auth-lifecycle-hooks.interface.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"auth-lifecycle-hooks.interface.d.ts","sourceRoot":"","sources":["../../src/interfaces/auth-lifecycle-hooks.interface.ts"],"names":[],"mappings":"AAMA,MAAM,WAAW,mBAAmB,CAAC,CAAC,SAAS,OAAO,uBAAuB,EAAE,SAAS,GAAG,OAAO,uBAAuB,EAAE,SAAS;IAOlI,QAAQ,CAAC,CAAC,IAAI,EAAE,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAMlC,OAAO,CAAC,CAAC,IAAI,EAAE,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAMjC,QAAQ,CAAC,CAAC,IAAI,EAAE,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAMlC,eAAe,CAAC,CAAC,IAAI,EAAE,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAMzC,eAAe,CAAC,CAAC,IAAI,EAAE,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAMzC,oBAAoB,CAAC,CAAC,IAAI,EAAE,CAAC,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAMhE,eAAe,CAAC,CAAC,IAAI,EAAE,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAMzC,eAAe,CAAC,CAAC,IAAI,EAAE,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;CAC1C"}
|
|
1
|
+
{"version":3,"file":"auth-lifecycle-hooks.interface.d.ts","sourceRoot":"","sources":["../../src/interfaces/auth-lifecycle-hooks.interface.ts"],"names":[],"mappings":"AAMA,MAAM,WAAW,mBAAmB,CAAC,CAAC,SAAS,OAAO,uBAAuB,EAAE,SAAS,GAAG,OAAO,uBAAuB,EAAE,SAAS;IAOlI,QAAQ,CAAC,CAAC,IAAI,EAAE,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAMlC,OAAO,CAAC,CAAC,IAAI,EAAE,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAMjC,QAAQ,CAAC,CAAC,IAAI,EAAE,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAMlC,eAAe,CAAC,CAAC,IAAI,EAAE,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAMzC,eAAe,CAAC,CAAC,IAAI,EAAE,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAMzC,oBAAoB,CAAC,CAAC,IAAI,EAAE,CAAC,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAMhE,eAAe,CAAC,CAAC,IAAI,EAAE,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAMzC,iBAAiB,CAAC,CAAC,IAAI,EAAE,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAa3C,aAAa,CAAC,CAAC,KAAK,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,SAAS,EAAE,MAAM,EAAE,MAAM,GAAG,IAAI,CAAC;IAMnF,eAAe,CAAC,CAAC,IAAI,EAAE,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;CAC1C"}
|
|
@@ -9,25 +9,43 @@ export declare enum UserStatus {
|
|
|
9
9
|
SUSPENDED = "SUSPENDED",
|
|
10
10
|
DELETED = "DELETED"
|
|
11
11
|
}
|
|
12
|
-
export interface
|
|
12
|
+
export interface IAuthUserCore {
|
|
13
13
|
id: string;
|
|
14
14
|
email: string;
|
|
15
15
|
passwordHash: string | null;
|
|
16
16
|
emailVerified: boolean;
|
|
17
|
-
|
|
18
|
-
|
|
17
|
+
provider?: string;
|
|
18
|
+
createdAt: Date;
|
|
19
|
+
updatedAt: Date;
|
|
20
|
+
deletedAt?: Date | null;
|
|
21
|
+
}
|
|
22
|
+
export interface IAuthUserOAuth {
|
|
23
|
+
providerId?: string | null;
|
|
24
|
+
googleId?: string | null;
|
|
25
|
+
facebookId?: string | null;
|
|
26
|
+
appleId?: string | null;
|
|
27
|
+
}
|
|
28
|
+
export interface IAuthUserPhone {
|
|
19
29
|
phoneNumber?: string | null;
|
|
20
30
|
phoneVerified?: boolean;
|
|
21
31
|
phoneVerifiedAt?: Date | null;
|
|
22
32
|
phoneVerificationSentAt?: Date | null;
|
|
33
|
+
}
|
|
34
|
+
export interface IAuthUserSecurity {
|
|
35
|
+
failedLoginAttempts?: number;
|
|
36
|
+
lockedUntil?: Date | null;
|
|
37
|
+
lastLoginAt?: Date | null;
|
|
38
|
+
status: string;
|
|
39
|
+
}
|
|
40
|
+
export interface IAuthUserVerification {
|
|
41
|
+
emailVerifiedAt?: Date | null;
|
|
42
|
+
emailVerificationSentAt?: Date | null;
|
|
23
43
|
passwordResetSentAt?: Date | null;
|
|
44
|
+
}
|
|
45
|
+
export interface IAuthUserProfile {
|
|
24
46
|
name?: string | null;
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
lastLoginAt?: Date | null;
|
|
29
|
-
createdAt: Date;
|
|
30
|
-
updatedAt: Date;
|
|
31
|
-
deletedAt?: Date | null;
|
|
47
|
+
}
|
|
48
|
+
export interface IAuthUser extends IAuthUserCore, IAuthUserSecurity, IAuthUserVerification, IAuthUserProfile, Partial<IAuthUserOAuth>, Partial<IAuthUserPhone> {
|
|
49
|
+
provider: AuthProvider | string;
|
|
32
50
|
}
|
|
33
51
|
//# sourceMappingURL=auth-user.interface.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"auth-user.interface.d.ts","sourceRoot":"","sources":["../../src/interfaces/auth-user.interface.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"auth-user.interface.d.ts","sourceRoot":"","sources":["../../src/interfaces/auth-user.interface.ts"],"names":[],"mappings":"AAOA,oBAAY,YAAY;IACtB,KAAK,UAAU;IACf,MAAM,WAAW;IACjB,QAAQ,aAAa;IACrB,KAAK,UAAU;CAChB;AAUD,oBAAY,UAAU;IACpB,MAAM,WAAW;IACjB,SAAS,cAAc;IACvB,OAAO,YAAY;CACpB;AAaD,MAAM,WAAW,aAAa;IAE5B,EAAE,EAAE,MAAM,CAAC;IAGX,KAAK,EAAE,MAAM,CAAC;IAGd,YAAY,EAAE,MAAM,GAAG,IAAI,CAAC;IAG5B,aAAa,EAAE,OAAO,CAAC;IAQvB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAGlB,SAAS,EAAE,IAAI,CAAC;IAGhB,SAAS,EAAE,IAAI,CAAC;IAGhB,SAAS,CAAC,EAAE,IAAI,GAAG,IAAI,CAAC;CACzB;AAQD,MAAM,WAAW,cAAc;IAE7B,UAAU,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAG3B,QAAQ,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAGzB,UAAU,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAG3B,OAAO,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;CACzB;AAOD,MAAM,WAAW,cAAc;IAE7B,WAAW,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAG5B,aAAa,CAAC,EAAE,OAAO,CAAC;IAGxB,eAAe,CAAC,EAAE,IAAI,GAAG,IAAI,CAAC;IAG9B,uBAAuB,CAAC,EAAE,IAAI,GAAG,IAAI,CAAC;CACvC;AAOD,MAAM,WAAW,iBAAiB;IAEhC,mBAAmB,CAAC,EAAE,MAAM,CAAC;IAG7B,WAAW,CAAC,EAAE,IAAI,GAAG,IAAI,CAAC;IAG1B,WAAW,CAAC,EAAE,IAAI,GAAG,IAAI,CAAC;IAQ1B,MAAM,EAAE,MAAM,CAAC;CAChB;AAOD,MAAM,WAAW,qBAAqB;IAEpC,eAAe,CAAC,EAAE,IAAI,GAAG,IAAI,CAAC;IAG9B,uBAAuB,CAAC,EAAE,IAAI,GAAG,IAAI,CAAC;IAGtC,mBAAmB,CAAC,EAAE,IAAI,GAAG,IAAI,CAAC;CACnC;AAKD,MAAM,WAAW,gBAAgB;IAE/B,IAAI,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;CACtB;AAgCD,MAAM,WAAW,SACf,SAAQ,aAAa,EACnB,iBAAiB,EACjB,qBAAqB,EACrB,gBAAgB,EAChB,OAAO,CAAC,cAAc,CAAC,EACvB,OAAO,CAAC,cAAc,CAAC;IAKzB,QAAQ,EAAE,YAAY,GAAG,MAAM,CAAC;CACjC"}
|