@lenne.tech/nest-server 11.11.1 → 11.13.0
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/dist/config.env.js +1 -0
- package/dist/config.env.js.map +1 -1
- package/dist/core/common/interfaces/server-options.interface.d.ts +16 -0
- package/dist/core/modules/auth/core-auth.controller.js +1 -1
- package/dist/core/modules/auth/core-auth.controller.js.map +1 -1
- package/dist/core/modules/auth/core-auth.resolver.js +1 -1
- package/dist/core/modules/auth/core-auth.resolver.js.map +1 -1
- package/dist/core/modules/better-auth/better-auth-token.service.js +1 -4
- package/dist/core/modules/better-auth/better-auth-token.service.js.map +1 -1
- package/dist/core/modules/better-auth/better-auth.config.d.ts +13 -0
- package/dist/core/modules/better-auth/better-auth.config.js +114 -17
- package/dist/core/modules/better-auth/better-auth.config.js.map +1 -1
- package/dist/core/modules/better-auth/better-auth.resolver.d.ts +7 -3
- package/dist/core/modules/better-auth/better-auth.resolver.js +16 -6
- package/dist/core/modules/better-auth/better-auth.resolver.js.map +1 -1
- package/dist/core/modules/better-auth/core-better-auth-api.middleware.d.ts +4 -2
- package/dist/core/modules/better-auth/core-better-auth-api.middleware.js +63 -18
- package/dist/core/modules/better-auth/core-better-auth-api.middleware.js.map +1 -1
- package/dist/core/modules/better-auth/core-better-auth-auth.model.d.ts +1 -0
- package/dist/core/modules/better-auth/core-better-auth-auth.model.js +7 -0
- package/dist/core/modules/better-auth/core-better-auth-auth.model.js.map +1 -1
- package/dist/core/modules/better-auth/core-better-auth-cookie.helper.d.ts +41 -0
- package/dist/core/modules/better-auth/core-better-auth-cookie.helper.js +107 -0
- package/dist/core/modules/better-auth/core-better-auth-cookie.helper.js.map +1 -0
- package/dist/core/modules/better-auth/core-better-auth-email-verification.service.d.ts +48 -0
- package/dist/core/modules/better-auth/core-better-auth-email-verification.service.js +241 -0
- package/dist/core/modules/better-auth/core-better-auth-email-verification.service.js.map +1 -0
- package/dist/core/modules/better-auth/core-better-auth-models.d.ts +2 -1
- package/dist/core/modules/better-auth/core-better-auth-models.js +8 -4
- package/dist/core/modules/better-auth/core-better-auth-models.js.map +1 -1
- package/dist/core/modules/better-auth/core-better-auth-signup-validator.service.d.ts +18 -0
- package/dist/core/modules/better-auth/core-better-auth-signup-validator.service.js +82 -0
- package/dist/core/modules/better-auth/core-better-auth-signup-validator.service.js.map +1 -0
- package/dist/core/modules/better-auth/core-better-auth-token.helper.d.ts +16 -0
- package/dist/core/modules/better-auth/core-better-auth-token.helper.js +66 -0
- package/dist/core/modules/better-auth/core-better-auth-token.helper.js.map +1 -0
- package/dist/core/modules/better-auth/core-better-auth-user.mapper.d.ts +0 -1
- package/dist/core/modules/better-auth/core-better-auth-user.mapper.js +15 -8
- package/dist/core/modules/better-auth/core-better-auth-user.mapper.js.map +1 -1
- package/dist/core/modules/better-auth/core-better-auth-web.helper.d.ts +3 -3
- package/dist/core/modules/better-auth/core-better-auth-web.helper.js +64 -44
- package/dist/core/modules/better-auth/core-better-auth-web.helper.js.map +1 -1
- package/dist/core/modules/better-auth/core-better-auth.controller.d.ts +13 -1
- package/dist/core/modules/better-auth/core-better-auth.controller.js +108 -49
- package/dist/core/modules/better-auth/core-better-auth.controller.js.map +1 -1
- package/dist/core/modules/better-auth/core-better-auth.middleware.d.ts +0 -1
- package/dist/core/modules/better-auth/core-better-auth.middleware.js +57 -39
- package/dist/core/modules/better-auth/core-better-auth.middleware.js.map +1 -1
- package/dist/core/modules/better-auth/core-better-auth.module.d.ts +6 -0
- package/dist/core/modules/better-auth/core-better-auth.module.js +129 -24
- package/dist/core/modules/better-auth/core-better-auth.module.js.map +1 -1
- package/dist/core/modules/better-auth/core-better-auth.resolver.d.ts +12 -5
- package/dist/core/modules/better-auth/core-better-auth.resolver.js +64 -17
- package/dist/core/modules/better-auth/core-better-auth.resolver.js.map +1 -1
- package/dist/core/modules/better-auth/core-better-auth.service.d.ts +4 -1
- package/dist/core/modules/better-auth/core-better-auth.service.js +143 -23
- package/dist/core/modules/better-auth/core-better-auth.service.js.map +1 -1
- package/dist/core/modules/better-auth/index.d.ts +4 -0
- package/dist/core/modules/better-auth/index.js +4 -0
- package/dist/core/modules/better-auth/index.js.map +1 -1
- package/dist/core/modules/error-code/error-codes.d.ts +45 -0
- package/dist/core/modules/error-code/error-codes.js +40 -0
- package/dist/core/modules/error-code/error-codes.js.map +1 -1
- package/dist/core/modules/user/core-user.model.d.ts +1 -0
- package/dist/core/modules/user/core-user.model.js +11 -0
- package/dist/core/modules/user/core-user.model.js.map +1 -1
- package/dist/server/modules/better-auth/better-auth.controller.d.ts +3 -1
- package/dist/server/modules/better-auth/better-auth.controller.js +12 -3
- package/dist/server/modules/better-auth/better-auth.controller.js.map +1 -1
- package/dist/server/modules/better-auth/better-auth.resolver.d.ts +7 -3
- package/dist/server/modules/better-auth/better-auth.resolver.js +16 -6
- package/dist/server/modules/better-auth/better-auth.resolver.js.map +1 -1
- package/dist/server/modules/error-code/error-codes.d.ts +5 -0
- package/dist/server/modules/user/user.model.d.ts +5 -0
- package/dist/templates/email-verification-de.ejs +78 -0
- package/dist/templates/email-verification-en.ejs +78 -0
- package/dist/test/test.helper.d.ts +4 -0
- package/dist/test/test.helper.js +54 -1
- package/dist/test/test.helper.js.map +1 -1
- package/dist/tsconfig.build.tsbuildinfo +1 -1
- package/package.json +10 -10
- package/src/config.env.ts +2 -0
- package/src/core/common/interfaces/server-options.interface.ts +240 -0
- package/src/core/modules/auth/core-auth.controller.ts +2 -2
- package/src/core/modules/auth/core-auth.resolver.ts +2 -2
- package/src/core/modules/better-auth/INTEGRATION-CHECKLIST.md +113 -0
- package/src/core/modules/better-auth/README.md +72 -7
- package/src/core/modules/better-auth/better-auth-token.service.ts +5 -8
- package/src/core/modules/better-auth/better-auth.config.ts +282 -29
- package/src/core/modules/better-auth/better-auth.resolver.ts +16 -5
- package/src/core/modules/better-auth/core-better-auth-api.middleware.ts +100 -22
- package/src/core/modules/better-auth/core-better-auth-auth.model.ts +10 -0
- package/src/core/modules/better-auth/core-better-auth-cookie.helper.ts +323 -0
- package/src/core/modules/better-auth/core-better-auth-email-verification.service.ts +433 -0
- package/src/core/modules/better-auth/core-better-auth-models.ts +6 -3
- package/src/core/modules/better-auth/core-better-auth-signup-validator.service.ts +178 -0
- package/src/core/modules/better-auth/core-better-auth-token.helper.ts +200 -0
- package/src/core/modules/better-auth/core-better-auth-user.mapper.ts +18 -14
- package/src/core/modules/better-auth/core-better-auth-web.helper.ts +119 -69
- package/src/core/modules/better-auth/core-better-auth.controller.ts +197 -84
- package/src/core/modules/better-auth/core-better-auth.middleware.ts +93 -64
- package/src/core/modules/better-auth/core-better-auth.module.ts +215 -38
- package/src/core/modules/better-auth/core-better-auth.resolver.ts +140 -20
- package/src/core/modules/better-auth/core-better-auth.service.ts +210 -32
- package/src/core/modules/better-auth/index.ts +4 -0
- package/src/core/modules/error-code/error-codes.ts +45 -0
- package/src/core/modules/user/core-user.model.ts +15 -0
- package/src/server/modules/better-auth/better-auth.controller.ts +6 -2
- package/src/server/modules/better-auth/better-auth.resolver.ts +16 -5
- package/src/templates/email-verification-de.ejs +78 -0
- package/src/templates/email-verification-en.ejs +78 -0
- package/src/test/README.md +190 -0
- package/src/test/test.helper.ts +82 -1
|
@@ -13,19 +13,24 @@ var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
|
13
13
|
};
|
|
14
14
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
15
|
exports.DefaultBetterAuthResolver = void 0;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
16
17
|
const graphql_1 = require("@nestjs/graphql");
|
|
17
18
|
const roles_decorator_1 = require("../../common/decorators/roles.decorator");
|
|
18
19
|
const role_enum_1 = require("../../common/enums/role.enum");
|
|
19
20
|
const core_better_auth_auth_model_1 = require("./core-better-auth-auth.model");
|
|
21
|
+
const core_better_auth_email_verification_service_1 = require("./core-better-auth-email-verification.service");
|
|
20
22
|
const core_better_auth_models_1 = require("./core-better-auth-models");
|
|
23
|
+
const core_better_auth_signup_validator_service_1 = require("./core-better-auth-signup-validator.service");
|
|
21
24
|
const core_better_auth_user_mapper_1 = require("./core-better-auth-user.mapper");
|
|
22
25
|
const core_better_auth_resolver_1 = require("./core-better-auth.resolver");
|
|
23
26
|
const core_better_auth_service_1 = require("./core-better-auth.service");
|
|
24
27
|
let DefaultBetterAuthResolver = class DefaultBetterAuthResolver extends core_better_auth_resolver_1.CoreBetterAuthResolver {
|
|
25
|
-
constructor(betterAuthService, userMapper) {
|
|
26
|
-
super(betterAuthService, userMapper);
|
|
28
|
+
constructor(betterAuthService, userMapper, signUpValidator, emailVerificationService) {
|
|
29
|
+
super(betterAuthService, userMapper, signUpValidator, emailVerificationService);
|
|
27
30
|
this.betterAuthService = betterAuthService;
|
|
28
31
|
this.userMapper = userMapper;
|
|
32
|
+
this.signUpValidator = signUpValidator;
|
|
33
|
+
this.emailVerificationService = emailVerificationService;
|
|
29
34
|
}
|
|
30
35
|
async betterAuthSession(ctx) {
|
|
31
36
|
return super.betterAuthSession(ctx);
|
|
@@ -42,8 +47,8 @@ let DefaultBetterAuthResolver = class DefaultBetterAuthResolver extends core_bet
|
|
|
42
47
|
async betterAuthSignIn(email, password, ctx) {
|
|
43
48
|
return super.betterAuthSignIn(email, password, ctx);
|
|
44
49
|
}
|
|
45
|
-
async betterAuthSignUp(email, password, name) {
|
|
46
|
-
return super.betterAuthSignUp(email, password, name);
|
|
50
|
+
async betterAuthSignUp(email, password, name, termsAndPrivacyAccepted) {
|
|
51
|
+
return super.betterAuthSignUp(email, password, name, termsAndPrivacyAccepted);
|
|
47
52
|
}
|
|
48
53
|
async betterAuthSignOut(ctx) {
|
|
49
54
|
return super.betterAuthSignOut(ctx);
|
|
@@ -124,8 +129,9 @@ __decorate([
|
|
|
124
129
|
__param(0, (0, graphql_1.Args)('email')),
|
|
125
130
|
__param(1, (0, graphql_1.Args)('password')),
|
|
126
131
|
__param(2, (0, graphql_1.Args)('name', { nullable: true })),
|
|
132
|
+
__param(3, (0, graphql_1.Args)('termsAndPrivacyAccepted', { nullable: true })),
|
|
127
133
|
__metadata("design:type", Function),
|
|
128
|
-
__metadata("design:paramtypes", [String, String, String]),
|
|
134
|
+
__metadata("design:paramtypes", [String, String, String, Boolean]),
|
|
129
135
|
__metadata("design:returntype", Promise)
|
|
130
136
|
], DefaultBetterAuthResolver.prototype, "betterAuthSignUp", null);
|
|
131
137
|
__decorate([
|
|
@@ -204,7 +210,11 @@ __decorate([
|
|
|
204
210
|
exports.DefaultBetterAuthResolver = DefaultBetterAuthResolver = __decorate([
|
|
205
211
|
(0, graphql_1.Resolver)(() => core_better_auth_auth_model_1.CoreBetterAuthAuthModel),
|
|
206
212
|
(0, roles_decorator_1.Roles)(role_enum_1.RoleEnum.ADMIN),
|
|
213
|
+
__param(2, (0, common_1.Optional)()),
|
|
214
|
+
__param(3, (0, common_1.Optional)()),
|
|
207
215
|
__metadata("design:paramtypes", [core_better_auth_service_1.CoreBetterAuthService,
|
|
208
|
-
core_better_auth_user_mapper_1.CoreBetterAuthUserMapper
|
|
216
|
+
core_better_auth_user_mapper_1.CoreBetterAuthUserMapper,
|
|
217
|
+
core_better_auth_signup_validator_service_1.CoreBetterAuthSignUpValidatorService,
|
|
218
|
+
core_better_auth_email_verification_service_1.CoreBetterAuthEmailVerificationService])
|
|
209
219
|
], DefaultBetterAuthResolver);
|
|
210
220
|
//# sourceMappingURL=better-auth.resolver.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"better-auth.resolver.js","sourceRoot":"","sources":["../../../../src/core/modules/better-auth/better-auth.resolver.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,6CAA2E;AAG3E,6EAAgE;AAChE,4DAAwD;AACxD,+EAAwE;AACxE,uEAMmC;AACnC,iFAA0E;AAC1E,2EAAqE;AACrE,yEAAmE;
|
|
1
|
+
{"version":3,"file":"better-auth.resolver.js","sourceRoot":"","sources":["../../../../src/core/modules/better-auth/better-auth.resolver.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { NestMiddleware } from '@nestjs/common';
|
|
2
|
-
import { NextFunction, Request
|
|
2
|
+
import { Response as ExpressResponse, NextFunction, Request } from 'express';
|
|
3
3
|
import { CoreBetterAuthChallengeService } from './core-better-auth-challenge.service';
|
|
4
4
|
import { CoreBetterAuthService } from './core-better-auth.service';
|
|
5
5
|
export declare class CoreBetterAuthApiMiddleware implements NestMiddleware {
|
|
@@ -8,7 +8,9 @@ export declare class CoreBetterAuthApiMiddleware implements NestMiddleware {
|
|
|
8
8
|
private readonly logger;
|
|
9
9
|
private readonly isProd;
|
|
10
10
|
private loggedChallengeStorageMode;
|
|
11
|
+
private cookieHelper?;
|
|
11
12
|
constructor(betterAuthService: CoreBetterAuthService, challengeService?: CoreBetterAuthChallengeService);
|
|
13
|
+
private getCookieHelper;
|
|
12
14
|
private useDbChallengeStorage;
|
|
13
|
-
use(req: Request, res:
|
|
15
|
+
use(req: Request, res: ExpressResponse, next: NextFunction): Promise<void>;
|
|
14
16
|
}
|
|
@@ -17,22 +17,12 @@ exports.CoreBetterAuthApiMiddleware = void 0;
|
|
|
17
17
|
const common_1 = require("@nestjs/common");
|
|
18
18
|
const logging_helper_1 = require("../../common/helpers/logging.helper");
|
|
19
19
|
const core_better_auth_challenge_service_1 = require("./core-better-auth-challenge.service");
|
|
20
|
+
const core_better_auth_cookie_helper_1 = require("./core-better-auth-cookie.helper");
|
|
20
21
|
const core_better_auth_web_helper_1 = require("./core-better-auth-web.helper");
|
|
21
22
|
const core_better_auth_service_1 = require("./core-better-auth.service");
|
|
22
|
-
const CONTROLLER_HANDLED_PATHS = [
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
'/sign-out',
|
|
26
|
-
'/session',
|
|
27
|
-
];
|
|
28
|
-
const PASSKEY_GENERATE_PATHS = [
|
|
29
|
-
'/passkey/generate-register-options',
|
|
30
|
-
'/passkey/generate-authenticate-options',
|
|
31
|
-
];
|
|
32
|
-
const PASSKEY_VERIFY_PATHS = [
|
|
33
|
-
'/passkey/verify-registration',
|
|
34
|
-
'/passkey/verify-authentication',
|
|
35
|
-
];
|
|
23
|
+
const CONTROLLER_HANDLED_PATHS = ['/features', '/sign-in/email', '/sign-up/email', '/sign-out', '/session'];
|
|
24
|
+
const PASSKEY_GENERATE_PATHS = ['/passkey/generate-register-options', '/passkey/generate-authenticate-options'];
|
|
25
|
+
const PASSKEY_VERIFY_PATHS = ['/passkey/verify-registration', '/passkey/verify-authentication'];
|
|
36
26
|
let CoreBetterAuthApiMiddleware = CoreBetterAuthApiMiddleware_1 = class CoreBetterAuthApiMiddleware {
|
|
37
27
|
constructor(betterAuthService, challengeService) {
|
|
38
28
|
this.betterAuthService = betterAuthService;
|
|
@@ -41,6 +31,16 @@ let CoreBetterAuthApiMiddleware = CoreBetterAuthApiMiddleware_1 = class CoreBett
|
|
|
41
31
|
this.isProd = (0, logging_helper_1.isProduction)();
|
|
42
32
|
this.loggedChallengeStorageMode = false;
|
|
43
33
|
}
|
|
34
|
+
getCookieHelper() {
|
|
35
|
+
if (!this.cookieHelper) {
|
|
36
|
+
const config = this.betterAuthService.getConfig();
|
|
37
|
+
this.cookieHelper = (0, core_better_auth_cookie_helper_1.createCookieHelper)(this.betterAuthService.getBasePath(), {
|
|
38
|
+
legacyCookieEnabled: false,
|
|
39
|
+
secret: config?.secret,
|
|
40
|
+
}, this.logger);
|
|
41
|
+
}
|
|
42
|
+
return this.cookieHelper;
|
|
43
|
+
}
|
|
44
44
|
useDbChallengeStorage() {
|
|
45
45
|
const enabled = this.challengeService?.isEnabled() ?? false;
|
|
46
46
|
if (enabled && !this.loggedChallengeStorageMode) {
|
|
@@ -73,7 +73,13 @@ let CoreBetterAuthApiMiddleware = CoreBetterAuthApiMiddleware_1 = class CoreBett
|
|
|
73
73
|
const useDbStorage = this.useDbChallengeStorage();
|
|
74
74
|
const isPasskeyGenerate = useDbStorage && PASSKEY_GENERATE_PATHS.some((p) => relativePath === p);
|
|
75
75
|
const isPasskeyVerify = useDbStorage && PASSKEY_VERIFY_PATHS.some((p) => relativePath === p);
|
|
76
|
-
|
|
76
|
+
let sessionToken = (0, core_better_auth_web_helper_1.extractSessionToken)(req, basePath);
|
|
77
|
+
if (!sessionToken) {
|
|
78
|
+
const betterAuthReq = req;
|
|
79
|
+
if (betterAuthReq.betterAuthSession?.session?.token) {
|
|
80
|
+
sessionToken = betterAuthReq.betterAuthSession.session.token;
|
|
81
|
+
}
|
|
82
|
+
}
|
|
77
83
|
const config = this.betterAuthService.getConfig();
|
|
78
84
|
const cookieName = this.challengeService?.getCookieName() || 'better-auth.better-auth-passkey';
|
|
79
85
|
let challengeIdToDelete;
|
|
@@ -156,6 +162,47 @@ let CoreBetterAuthApiMiddleware = CoreBetterAuthApiMiddleware_1 = class CoreBett
|
|
|
156
162
|
else if (challengeIdToDelete && !response.ok) {
|
|
157
163
|
this.logger.debug(`Keeping challenge mapping after failed verification (status=${response.status}) for retry`);
|
|
158
164
|
}
|
|
165
|
+
if (relativePath === '/passkey/verify-authentication' && response.ok) {
|
|
166
|
+
this.getCookieHelper().setSessionCookiesFromWebResponse(res, response);
|
|
167
|
+
try {
|
|
168
|
+
const responseClone = response.clone();
|
|
169
|
+
const responseBody = await responseClone.json();
|
|
170
|
+
if (responseBody?.session?.userId && !responseBody.user) {
|
|
171
|
+
const context = await authInstance.$context;
|
|
172
|
+
const user = await context.internalAdapter.findUserById(responseBody.session.userId);
|
|
173
|
+
if (user) {
|
|
174
|
+
const enrichedBody = {
|
|
175
|
+
...responseBody,
|
|
176
|
+
user: {
|
|
177
|
+
createdAt: user.createdAt,
|
|
178
|
+
email: user.email,
|
|
179
|
+
emailVerified: user.emailVerified,
|
|
180
|
+
id: user.id,
|
|
181
|
+
name: user.name,
|
|
182
|
+
},
|
|
183
|
+
};
|
|
184
|
+
const newHeaders = new Headers();
|
|
185
|
+
response.headers.forEach((value, key) => {
|
|
186
|
+
if (key.toLowerCase() !== 'content-encoding' && key.toLowerCase() !== 'transfer-encoding') {
|
|
187
|
+
newHeaders.set(key, value);
|
|
188
|
+
}
|
|
189
|
+
});
|
|
190
|
+
newHeaders.set('content-type', 'application/json');
|
|
191
|
+
const enrichedResponse = new Response(JSON.stringify(enrichedBody), {
|
|
192
|
+
headers: newHeaders,
|
|
193
|
+
status: response.status,
|
|
194
|
+
statusText: response.statusText,
|
|
195
|
+
});
|
|
196
|
+
this.logger.debug('Enriched passkey verify response with user data');
|
|
197
|
+
await (0, core_better_auth_web_helper_1.sendWebResponse)(res, enrichedResponse);
|
|
198
|
+
return;
|
|
199
|
+
}
|
|
200
|
+
}
|
|
201
|
+
}
|
|
202
|
+
catch (enrichError) {
|
|
203
|
+
this.logger.debug(`Could not enrich passkey response: ${enrichError instanceof Error ? enrichError.message : 'unknown'}`);
|
|
204
|
+
}
|
|
205
|
+
}
|
|
159
206
|
await (0, core_better_auth_web_helper_1.sendWebResponse)(res, response);
|
|
160
207
|
}
|
|
161
208
|
catch (error) {
|
|
@@ -166,9 +213,7 @@ let CoreBetterAuthApiMiddleware = CoreBetterAuthApiMiddleware_1 = class CoreBett
|
|
|
166
213
|
this.logger.error(`Better Auth handler error: ${error instanceof Error ? error.message : 'Unknown error'}`);
|
|
167
214
|
}
|
|
168
215
|
if (!res.headersSent) {
|
|
169
|
-
const message = this.isProd
|
|
170
|
-
? 'Authentication error'
|
|
171
|
-
: (error instanceof Error ? error.message : 'Unknown error');
|
|
216
|
+
const message = this.isProd ? 'Authentication error' : error instanceof Error ? error.message : 'Unknown error';
|
|
172
217
|
res.status(500).json({
|
|
173
218
|
error: 'Authentication handler error',
|
|
174
219
|
message,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"core-better-auth-api.middleware.js","sourceRoot":"","sources":["../../../../src/core/modules/better-auth/core-better-auth-api.middleware.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,2CAA8E;AAG9E,wEAAmE;AACnE,6FAAsF;AACtF,+EAAoH;AACpH,yEAAmE;AAenE,MAAM,wBAAwB,GAAG
|
|
1
|
+
{"version":3,"file":"core-better-auth-api.middleware.js","sourceRoot":"","sources":["../../../../src/core/modules/better-auth/core-better-auth-api.middleware.ts"],"names":[],"mappings":"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"}
|
|
@@ -17,6 +17,13 @@ const core_better_auth_models_1 = require("./core-better-auth-models");
|
|
|
17
17
|
let CoreBetterAuthAuthModel = class CoreBetterAuthAuthModel {
|
|
18
18
|
};
|
|
19
19
|
exports.CoreBetterAuthAuthModel = CoreBetterAuthAuthModel;
|
|
20
|
+
__decorate([
|
|
21
|
+
(0, graphql_1.Field)(() => Boolean, {
|
|
22
|
+
description: 'Whether email verification is required before login',
|
|
23
|
+
nullable: true,
|
|
24
|
+
}),
|
|
25
|
+
__metadata("design:type", Boolean)
|
|
26
|
+
], CoreBetterAuthAuthModel.prototype, "emailVerificationRequired", void 0);
|
|
20
27
|
__decorate([
|
|
21
28
|
(0, graphql_1.Field)(() => Boolean, { description: 'Whether authentication was successful' }),
|
|
22
29
|
__metadata("design:type", Boolean)
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"core-better-auth-auth.model.js","sourceRoot":"","sources":["../../../../src/core/modules/better-auth/core-better-auth-auth.model.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,6CAAoD;AAEpD,uFAA0E;AAC1E,4DAAwD;AACxD,uEAAoG;AAW7F,IAAM,uBAAuB,GAA7B,MAAM,uBAAuB;
|
|
1
|
+
{"version":3,"file":"core-better-auth-auth.model.js","sourceRoot":"","sources":["../../../../src/core/modules/better-auth/core-better-auth-auth.model.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,6CAAoD;AAEpD,uFAA0E;AAC1E,4DAAwD;AACxD,uEAAoG;AAW7F,IAAM,uBAAuB,GAA7B,MAAM,uBAAuB;CA+DnC,CAAA;AA/DY,0DAAuB;AASlC;IAJC,IAAA,eAAK,EAAC,GAAG,EAAE,CAAC,OAAO,EAAE;QACpB,WAAW,EAAE,qDAAqD;QAClE,QAAQ,EAAE,IAAI;KACf,CAAC;;0EACkC;AAMpC;IADC,IAAA,eAAK,EAAC,GAAG,EAAE,CAAC,OAAO,EAAE,EAAE,WAAW,EAAE,uCAAuC,EAAE,CAAC;;wDAC9D;AAUjB;IAJC,IAAA,eAAK,EAAC,GAAG,EAAE,CAAC,OAAO,EAAE;QACpB,WAAW,EAAE,0DAA0D;QACvE,QAAQ,EAAE,IAAI;KACf,CAAC;;kEAC0B;AAU5B;IAJC,IAAA,eAAK,EAAC,GAAG,EAAE,CAAC,MAAM,EAAE;QACnB,WAAW,EAAE,6DAA6D;QAC1E,QAAQ,EAAE,IAAI;KACf,CAAC;;sDACa;AASf;IAJC,IAAA,eAAK,EAAC,GAAG,EAAE,CAAC,iDAAuB,EAAE;QACpC,WAAW,EAAE,oBAAoB;QACjC,QAAQ,EAAE,IAAI;KACf,CAAC;8BACK,iDAAuB;qDAAC;AAS/B;IAJC,IAAA,eAAK,EAAC,GAAG,EAAE,CAAC,wDAA8B,EAAE;QAC3C,WAAW,EAAE,qBAAqB;QAClC,QAAQ,EAAE,IAAI;KACf,CAAC;8BACQ,wDAA8B;wDAAC;AASzC;IAJC,IAAA,eAAK,EAAC,GAAG,EAAE,CAAC,MAAM,EAAE;QACnB,WAAW,EAAE,wCAAwC;QACrD,QAAQ,EAAE,IAAI;KACf,CAAC;;sDACa;kCA9DJ,uBAAuB;IAFnC,IAAA,oBAAU,EAAC,EAAE,WAAW,EAAE,qCAAqC,EAAE,CAAC;IAClE,IAAA,iCAAU,EAAC,oBAAQ,CAAC,UAAU,CAAC;GACnB,uBAAuB,CA+DnC"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { Logger } from '@nestjs/common';
|
|
2
|
+
import { Response } from 'express';
|
|
3
|
+
export declare const AUTH_COOKIE_NAMES: {
|
|
4
|
+
readonly TOKEN: "token";
|
|
5
|
+
};
|
|
6
|
+
export interface AuthCookieOptions {
|
|
7
|
+
httpOnly: boolean;
|
|
8
|
+
maxAge?: number;
|
|
9
|
+
sameSite: 'lax' | 'none' | 'strict';
|
|
10
|
+
secure: boolean;
|
|
11
|
+
}
|
|
12
|
+
export interface BetterAuthCookieHelperConfig {
|
|
13
|
+
basePath: string;
|
|
14
|
+
legacyCookieEnabled?: boolean;
|
|
15
|
+
logger?: Logger;
|
|
16
|
+
secret?: string;
|
|
17
|
+
}
|
|
18
|
+
export interface CookieProcessingResult {
|
|
19
|
+
session?: {
|
|
20
|
+
id: string;
|
|
21
|
+
};
|
|
22
|
+
token?: string;
|
|
23
|
+
}
|
|
24
|
+
export declare class BetterAuthCookieHelper {
|
|
25
|
+
private readonly config;
|
|
26
|
+
private readonly normalizedBasePath;
|
|
27
|
+
private readonly cookieName;
|
|
28
|
+
constructor(config: BetterAuthCookieHelperConfig);
|
|
29
|
+
getDefaultCookieOptions(): AuthCookieOptions;
|
|
30
|
+
getNormalizedBasePath(): string;
|
|
31
|
+
getCookieName(): string;
|
|
32
|
+
setSessionCookies(res: Response, sessionToken: string, _sessionId?: string): void;
|
|
33
|
+
clearSessionCookies(res: Response): void;
|
|
34
|
+
extractSessionTokenFromResponse(response: globalThis.Response): null | string;
|
|
35
|
+
setSessionCookiesFromWebResponse(res: Response, webResponse: globalThis.Response): void;
|
|
36
|
+
processAuthResult<T extends CookieProcessingResult>(res: Response, result: T, cookiesEnabled: boolean): T;
|
|
37
|
+
}
|
|
38
|
+
export declare function createCookieHelper(basePath: string, options?: {
|
|
39
|
+
legacyCookieEnabled?: boolean;
|
|
40
|
+
secret?: string;
|
|
41
|
+
}, logger?: Logger): BetterAuthCookieHelper;
|
|
@@ -0,0 +1,107 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.BetterAuthCookieHelper = exports.AUTH_COOKIE_NAMES = void 0;
|
|
4
|
+
exports.createCookieHelper = createCookieHelper;
|
|
5
|
+
const core_better_auth_web_helper_1 = require("./core-better-auth-web.helper");
|
|
6
|
+
exports.AUTH_COOKIE_NAMES = {
|
|
7
|
+
TOKEN: 'token',
|
|
8
|
+
};
|
|
9
|
+
class BetterAuthCookieHelper {
|
|
10
|
+
constructor(config) {
|
|
11
|
+
this.config = config;
|
|
12
|
+
this.normalizedBasePath = config.basePath.replace(/^\//, '').replace(/\//g, '.');
|
|
13
|
+
this.cookieName = `${this.normalizedBasePath}.session_token`;
|
|
14
|
+
}
|
|
15
|
+
getDefaultCookieOptions() {
|
|
16
|
+
return {
|
|
17
|
+
httpOnly: true,
|
|
18
|
+
sameSite: 'lax',
|
|
19
|
+
secure: process.env.NODE_ENV === 'production',
|
|
20
|
+
};
|
|
21
|
+
}
|
|
22
|
+
getNormalizedBasePath() {
|
|
23
|
+
return this.normalizedBasePath;
|
|
24
|
+
}
|
|
25
|
+
getCookieName() {
|
|
26
|
+
return this.cookieName;
|
|
27
|
+
}
|
|
28
|
+
setSessionCookies(res, sessionToken, _sessionId) {
|
|
29
|
+
const cookieOptions = this.getDefaultCookieOptions();
|
|
30
|
+
let cookieValue;
|
|
31
|
+
if (this.config.secret) {
|
|
32
|
+
cookieValue = (0, core_better_auth_web_helper_1.signCookieValue)(sessionToken, this.config.secret);
|
|
33
|
+
}
|
|
34
|
+
else {
|
|
35
|
+
this.config.logger?.warn('No secret configured - setting unsigned cookie (Passkey/2FA may fail)');
|
|
36
|
+
cookieValue = sessionToken;
|
|
37
|
+
}
|
|
38
|
+
res.cookie(this.cookieName, cookieValue, cookieOptions);
|
|
39
|
+
if (this.config.legacyCookieEnabled) {
|
|
40
|
+
res.cookie(exports.AUTH_COOKIE_NAMES.TOKEN, sessionToken, cookieOptions);
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
clearSessionCookies(res) {
|
|
44
|
+
const cookieOptions = {
|
|
45
|
+
...this.getDefaultCookieOptions(),
|
|
46
|
+
maxAge: 0,
|
|
47
|
+
};
|
|
48
|
+
res.cookie(this.cookieName, '', cookieOptions);
|
|
49
|
+
if (this.config.legacyCookieEnabled) {
|
|
50
|
+
res.cookie(exports.AUTH_COOKIE_NAMES.TOKEN, '', cookieOptions);
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
extractSessionTokenFromResponse(response) {
|
|
54
|
+
try {
|
|
55
|
+
const setCookieHeaders = response.headers.getSetCookie?.() || [];
|
|
56
|
+
for (const cookieHeader of setCookieHeaders) {
|
|
57
|
+
if (cookieHeader.startsWith(`${this.cookieName}=`)) {
|
|
58
|
+
const cookieValue = cookieHeader.split(';')[0].split('=').slice(1).join('=');
|
|
59
|
+
let sessionToken;
|
|
60
|
+
try {
|
|
61
|
+
sessionToken = decodeURIComponent(cookieValue);
|
|
62
|
+
}
|
|
63
|
+
catch {
|
|
64
|
+
sessionToken = cookieValue;
|
|
65
|
+
}
|
|
66
|
+
const parts = sessionToken.split('.');
|
|
67
|
+
if (parts.length === 2) {
|
|
68
|
+
return parts[0];
|
|
69
|
+
}
|
|
70
|
+
return sessionToken;
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
return null;
|
|
74
|
+
}
|
|
75
|
+
catch (error) {
|
|
76
|
+
this.config.logger?.debug(`Failed to extract session token from response: ${error instanceof Error ? error.message : 'Unknown error'}`);
|
|
77
|
+
return null;
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
setSessionCookiesFromWebResponse(res, webResponse) {
|
|
81
|
+
const sessionToken = this.extractSessionTokenFromResponse(webResponse);
|
|
82
|
+
if (!sessionToken) {
|
|
83
|
+
return;
|
|
84
|
+
}
|
|
85
|
+
this.setSessionCookies(res, sessionToken);
|
|
86
|
+
}
|
|
87
|
+
processAuthResult(res, result, cookiesEnabled) {
|
|
88
|
+
if (!cookiesEnabled) {
|
|
89
|
+
return result;
|
|
90
|
+
}
|
|
91
|
+
if (result.token) {
|
|
92
|
+
this.setSessionCookies(res, result.token);
|
|
93
|
+
delete result.token;
|
|
94
|
+
}
|
|
95
|
+
return result;
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
exports.BetterAuthCookieHelper = BetterAuthCookieHelper;
|
|
99
|
+
function createCookieHelper(basePath, options, logger) {
|
|
100
|
+
return new BetterAuthCookieHelper({
|
|
101
|
+
basePath,
|
|
102
|
+
legacyCookieEnabled: options?.legacyCookieEnabled ?? false,
|
|
103
|
+
logger,
|
|
104
|
+
secret: options?.secret,
|
|
105
|
+
});
|
|
106
|
+
}
|
|
107
|
+
//# sourceMappingURL=core-better-auth-cookie.helper.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"core-better-auth-cookie.helper.js","sourceRoot":"","sources":["../../../../src/core/modules/better-auth/core-better-auth-cookie.helper.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import { Logger } from '@nestjs/common';
|
|
2
|
+
import { IBetterAuthEmailVerificationConfig } from '../../common/interfaces/server-options.interface';
|
|
3
|
+
import { BrevoService } from '../../common/services/brevo.service';
|
|
4
|
+
import { ConfigService } from '../../common/services/config.service';
|
|
5
|
+
import { EmailService } from '../../common/services/email.service';
|
|
6
|
+
import { TemplateService } from '../../common/services/template.service';
|
|
7
|
+
type ResolvedEmailVerificationConfig = Pick<IBetterAuthEmailVerificationConfig, 'brevoTemplateId' | 'callbackURL'> & Required<Omit<IBetterAuthEmailVerificationConfig, 'brevoTemplateId' | 'callbackURL' | 'resendCooldownSeconds'>> & {
|
|
8
|
+
resendCooldownSeconds: number;
|
|
9
|
+
};
|
|
10
|
+
export interface SendVerificationEmailOptions {
|
|
11
|
+
token: string;
|
|
12
|
+
url: string;
|
|
13
|
+
user: {
|
|
14
|
+
email: string;
|
|
15
|
+
id: string;
|
|
16
|
+
name?: null | string;
|
|
17
|
+
};
|
|
18
|
+
}
|
|
19
|
+
export declare class CoreBetterAuthEmailVerificationService {
|
|
20
|
+
protected readonly configService: ConfigService;
|
|
21
|
+
protected readonly emailService?: EmailService;
|
|
22
|
+
protected readonly templateService?: TemplateService;
|
|
23
|
+
protected readonly brevoService?: BrevoService | null;
|
|
24
|
+
protected readonly logger: Logger;
|
|
25
|
+
protected config: ResolvedEmailVerificationConfig;
|
|
26
|
+
private readonly lastSendTimes;
|
|
27
|
+
static readonly BREVO_SERVICE_TOKEN = "BETTER_AUTH_BREVO_SERVICE";
|
|
28
|
+
constructor(configService: ConfigService, emailService?: EmailService, templateService?: TemplateService, brevoService?: BrevoService | null);
|
|
29
|
+
isEnabled(): boolean;
|
|
30
|
+
getConfig(): ResolvedEmailVerificationConfig;
|
|
31
|
+
getExpiresIn(): number;
|
|
32
|
+
shouldAutoSignIn(): boolean;
|
|
33
|
+
sendVerificationEmail(options: SendVerificationEmailOptions): Promise<void>;
|
|
34
|
+
protected configure(): void;
|
|
35
|
+
protected buildFrontendVerificationUrl(token: string): string;
|
|
36
|
+
protected resolveTemplatePath(templateName: string, locale: string): Promise<{
|
|
37
|
+
isAbsolute: boolean;
|
|
38
|
+
path: string;
|
|
39
|
+
}>;
|
|
40
|
+
protected getAppName(): string;
|
|
41
|
+
protected formatProjectName(name: string): string;
|
|
42
|
+
protected getEmailSubject(appName: string): string;
|
|
43
|
+
protected formatExpiresIn(seconds: number): string;
|
|
44
|
+
protected isInCooldown(email: string): boolean;
|
|
45
|
+
protected trackSend(email: string): void;
|
|
46
|
+
protected maskEmail(email: string): string;
|
|
47
|
+
}
|
|
48
|
+
export {};
|