@loopstack/auth 0.7.1 → 0.7.2

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/CHANGELOG.md CHANGED
@@ -1,5 +1,11 @@
1
1
  # @loopstack/auth
2
2
 
3
+ ## 0.7.2
4
+
5
+ ### Patch Changes
6
+
7
+ - set cookie domain and cors origin for auth api and websocket
8
+
3
9
  ## 0.7.1
4
10
 
5
11
  ### Patch Changes
@@ -1,9 +1,10 @@
1
- import { AuthService, OAuthService } from '../services';
1
+ import { AuthService, OAuthService, TokenService } from '../services';
2
2
  import { AuthResponseDto, LinkProviderDto, LoginDto, RegisterDto, UserResponseDto } from '@loopstack/shared';
3
3
  export declare class AuthController {
4
4
  private readonly authService;
5
+ private readonly tokenService;
5
6
  private readonly oauthService;
6
- constructor(authService: AuthService, oauthService: OAuthService);
7
+ constructor(authService: AuthService, tokenService: TokenService, oauthService: OAuthService);
7
8
  login(req: any, res: any, loginDto: LoginDto): Promise<{
8
9
  message: string;
9
10
  }>;
@@ -20,25 +20,17 @@ const shared_1 = require("@loopstack/shared");
20
20
  const swagger_1 = require("@nestjs/swagger");
21
21
  let AuthController = class AuthController {
22
22
  authService;
23
+ tokenService;
23
24
  oauthService;
24
- constructor(authService, oauthService) {
25
+ constructor(authService, tokenService, oauthService) {
25
26
  this.authService = authService;
27
+ this.tokenService = tokenService;
26
28
  this.oauthService = oauthService;
27
29
  }
28
30
  async login(req, res, loginDto) {
29
31
  const tokens = await this.authService.login(req.user);
30
- res.cookie('accessToken', tokens.accessToken, {
31
- httpOnly: true,
32
- secure: process.env.NODE_ENV === 'production',
33
- sameSite: 'strict',
34
- maxAge: tokens.expiresIn * 1000,
35
- });
36
- res.cookie('refreshToken', tokens.refreshToken, {
37
- httpOnly: true,
38
- secure: process.env.NODE_ENV === 'production',
39
- sameSite: 'strict',
40
- maxAge: 7 * 24 * 60 * 60 * 1000,
41
- });
32
+ res.cookie('accessToken', tokens.accessToken, this.tokenService.createAccessTokenCookieOptions());
33
+ res.cookie('refreshToken', tokens.refreshToken, this.tokenService.createRefreshTokenCookieOptions());
42
34
  return { message: 'Login successful' };
43
35
  }
44
36
  async register(registerDto) {
@@ -47,18 +39,8 @@ let AuthController = class AuthController {
47
39
  async refresh(req, res) {
48
40
  const refreshToken = req.cookies?.refreshToken;
49
41
  const tokens = await this.authService.refresh(refreshToken);
50
- res.cookie('accessToken', tokens.accessToken, {
51
- httpOnly: true,
52
- secure: process.env.NODE_ENV === 'production',
53
- sameSite: 'strict',
54
- maxAge: tokens.expiresIn * 1000,
55
- });
56
- res.cookie('refreshToken', tokens.refreshToken, {
57
- httpOnly: true,
58
- secure: process.env.NODE_ENV === 'production',
59
- sameSite: 'strict',
60
- maxAge: 7 * 24 * 60 * 60 * 1000,
61
- });
42
+ res.cookie('accessToken', tokens.accessToken, this.tokenService.createAccessTokenCookieOptions());
43
+ res.cookie('refreshToken', tokens.refreshToken, this.tokenService.createRefreshTokenCookieOptions());
62
44
  return { message: 'Token refreshed successfully' };
63
45
  }
64
46
  async logout(res) {
@@ -82,18 +64,8 @@ let AuthController = class AuthController {
82
64
  }
83
65
  async devLogin(req, res) {
84
66
  const tokens = await this.authService.login(req.user);
85
- res.cookie('accessToken', tokens.accessToken, {
86
- httpOnly: true,
87
- secure: process.env.NODE_ENV === 'production',
88
- sameSite: 'strict',
89
- maxAge: tokens.expiresIn * 1000,
90
- });
91
- res.cookie('refreshToken', tokens.refreshToken, {
92
- httpOnly: true,
93
- secure: process.env.NODE_ENV === 'production',
94
- sameSite: 'strict',
95
- maxAge: 7 * 24 * 60 * 60 * 1000,
96
- });
67
+ res.cookie('accessToken', tokens.accessToken, this.tokenService.createAccessTokenCookieOptions());
68
+ res.cookie('refreshToken', tokens.refreshToken, this.tokenService.createRefreshTokenCookieOptions());
97
69
  return { message: 'Login successful' };
98
70
  }
99
71
  };
@@ -190,6 +162,7 @@ exports.AuthController = AuthController = __decorate([
190
162
  (0, swagger_1.ApiTags)('api/v1/auth'),
191
163
  (0, common_1.Controller)('api/v1/auth'),
192
164
  __metadata("design:paramtypes", [services_1.AuthService,
165
+ services_1.TokenService,
193
166
  services_1.OAuthService])
194
167
  ], AuthController);
195
168
  //# sourceMappingURL=auth.controller.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"auth.controller.js","sourceRoot":"","sources":["../../src/controllers/auth.controller.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"auth.controller.js","sourceRoot":"","sources":["../../src/controllers/auth.controller.ts"],"names":[],"mappings":"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"}
@@ -12,6 +12,7 @@ export interface AuthConfig {
12
12
  expiresIn: string;
13
13
  refreshSecret?: string;
14
14
  refreshExpiresIn?: string;
15
+ cookieDomain?: string;
15
16
  };
16
17
  oauth?: {
17
18
  google?: OAuthProviderConfig;
@@ -4,6 +4,22 @@ export declare class TokenService {
4
4
  private config;
5
5
  private jwtService;
6
6
  constructor(config: AuthConfig, jwtService: JwtService);
7
+ private getExpiresIn;
8
+ private getRefreshExpiresIn;
9
+ createAccessTokenCookieOptions(): {
10
+ domain: string | undefined;
11
+ httpOnly: boolean;
12
+ secure: boolean;
13
+ sameSite: string;
14
+ maxAge: number;
15
+ };
16
+ createRefreshTokenCookieOptions(): {
17
+ domain: string | undefined;
18
+ httpOnly: boolean;
19
+ secure: boolean;
20
+ sameSite: string;
21
+ maxAge: number;
22
+ };
7
23
  generateTokens(user: any): Promise<{
8
24
  accessToken: string;
9
25
  refreshToken: string;
@@ -23,6 +23,30 @@ let TokenService = class TokenService {
23
23
  this.config = config;
24
24
  this.jwtService = jwtService;
25
25
  }
26
+ getExpiresIn() {
27
+ return this.getExpiresInSeconds(this.config.jwt?.expiresIn || '1h');
28
+ }
29
+ getRefreshExpiresIn() {
30
+ return this.getExpiresInSeconds(this.config.jwt?.refreshExpiresIn || '7h');
31
+ }
32
+ createAccessTokenCookieOptions() {
33
+ return {
34
+ domain: this.config.jwt?.cookieDomain ?? undefined,
35
+ httpOnly: true,
36
+ secure: process.env.NODE_ENV === 'production',
37
+ sameSite: 'lax',
38
+ maxAge: this.getExpiresIn() * 1000,
39
+ };
40
+ }
41
+ createRefreshTokenCookieOptions() {
42
+ return {
43
+ domain: this.config.jwt?.cookieDomain ?? undefined,
44
+ httpOnly: true,
45
+ secure: process.env.NODE_ENV === 'production',
46
+ sameSite: 'lax',
47
+ maxAge: this.getRefreshExpiresIn() * 1000,
48
+ };
49
+ }
26
50
  async generateTokens(user) {
27
51
  const payload = {
28
52
  sub: user.id || null,
@@ -39,7 +63,7 @@ let TokenService = class TokenService {
39
63
  return {
40
64
  accessToken,
41
65
  refreshToken,
42
- expiresIn: this.getExpiresInSeconds(this.config.jwt?.expiresIn || '1h'),
66
+ expiresIn: this.getExpiresIn(),
43
67
  };
44
68
  }
45
69
  getExpiresInSeconds(expiresIn) {
@@ -1 +1 @@
1
- {"version":3,"file":"token.service.js","sourceRoot":"","sources":["../../src/services/token.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAAoD;AACpD,qCAAyC;AAEzC,4CAA2C;AAIpC,IAAM,YAAY,GAAlB,MAAM,YAAY;IAEQ;IACrB;IAFV,YAC+B,MAAkB,EACvC,UAAsB;QADD,WAAM,GAAN,MAAM,CAAY;QACvC,eAAU,GAAV,UAAU,CAAY;IAC7B,CAAC;IAEJ,KAAK,CAAC,cAAc,CAAC,IAAS;QAC5B,MAAM,OAAO,GAAwB;YACnC,GAAG,EAAE,IAAI,CAAC,EAAE,IAAI,IAAI;YACpB,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,OAAO,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE;SAClF,CAAC;QAEF,MAAM,CAAC,WAAW,EAAE,YAAY,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC;YACpD,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,OAAO,CAAC;YAClC,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,OAAO,EAAE;gBACjC,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE,aAAa,IAAI,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE,MAAM;gBACjE,SAAS,EAAE,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE,gBAAgB,IAAI,IAAI;aACrD,CAAC;SACH,CAAC,CAAC;QAEH,OAAO;YACL,WAAW;YACX,YAAY;YACZ,SAAS,EAAE,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE,SAAS,IAAI,IAAI,CAAC;SACxE,CAAC;IACJ,CAAC;IAEO,mBAAmB,CAAC,SAAiB;QAC3C,MAAM,IAAI,GAAG,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;QACjC,MAAM,KAAK,GAAG,QAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QAE/C,QAAQ,IAAI,EAAE,CAAC;YACb,KAAK,GAAG,CAAC,CAAC,OAAO,KAAK,GAAG,IAAI,CAAC;YAC9B,KAAK,GAAG,CAAC,CAAC,OAAO,KAAK,GAAG,KAAK,CAAC;YAC/B,KAAK,GAAG,CAAC,CAAC,OAAO,KAAK,GAAG,EAAE,CAAC;YAC5B,KAAK,GAAG,CAAC,CAAC,OAAO,KAAK,CAAC;YACvB,OAAO,CAAC,CAAC,OAAO,IAAI,CAAC;QACvB,CAAC;IACH,CAAC;CACF,CAAA;AAxCY,oCAAY;uBAAZ,YAAY;IADxB,IAAA,mBAAU,GAAE;IAGR,WAAA,IAAA,eAAM,EAAC,uBAAW,CAAC,CAAA;6CACA,gBAAU;GAHrB,YAAY,CAwCxB"}
1
+ {"version":3,"file":"token.service.js","sourceRoot":"","sources":["../../src/services/token.service.ts"],"names":[],"mappings":"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"}