diff options
author | Joseph Ditton <jditton.atomic@gmail.com> | 2021-12-01 20:18:26 -0700 |
---|---|---|
committer | Joseph Ditton <jditton.atomic@gmail.com> | 2021-12-01 20:18:26 -0700 |
commit | 84b45cd6b11347e66437cd92dc20372d0abd6eb9 (patch) | |
tree | 6e42b5861278485c67159dc57c225983e3fd69f8 /server/controllers/sessions.controller.ts | |
parent | d803aaaf1be441f55fe674c3b0c6793e77a9203f (diff) | |
download | locchat-84b45cd6b11347e66437cd92dc20372d0abd6eb9.tar.gz locchat-84b45cd6b11347e66437cd92dc20372d0abd6eb9.zip |
adds roles
Diffstat (limited to 'server/controllers/sessions.controller.ts')
-rw-r--r-- | server/controllers/sessions.controller.ts | 9 |
1 files changed, 8 insertions, 1 deletions
diff --git a/server/controllers/sessions.controller.ts b/server/controllers/sessions.controller.ts index 9ae647b..e1d1155 100644 --- a/server/controllers/sessions.controller.ts +++ b/server/controllers/sessions.controller.ts @@ -5,6 +5,9 @@ import { SignInDto } from 'server/dto/sign_in.dto'; import { JwtService } from 'server/providers/services/jwt.service'; import { RefreshTokensService } from 'server/providers/services/refresh_tokens.service'; import { RefreshToken } from 'server/entities/refresh_token.entity'; +import { Skip } from 'server/decorators/skip.decorator'; +import { AuthGuard } from 'server/providers/guards/auth.guard'; +import { RolesService } from 'server/providers/services/roles.service'; // this is kind of a misnomer because we are doing token based auth // instead of session based auth @@ -13,10 +16,12 @@ export class SessionsController { constructor( private usersService: UsersService, private jwtService: JwtService, + private rolesService: RolesService, private refreshTokenService: RefreshTokensService, ) {} @Post('/sessions') + @Skip(AuthGuard) async create(@Body() body: SignInDto, @Res({ passthrough: true }) res: Response) { const { verified, user } = await this.usersService.verify(body.email, body.password); @@ -32,8 +37,10 @@ export class SessionsController { // generate new refresh token } + const userRoles = await this.rolesService.findByIds(user.userRoles.map((ur) => ur.roleId)); + // JWT gets sent with response - const token = this.jwtService.issueToken({ userId: user.id }); + const token = this.jwtService.issueToken({ userId: user.id, roles: userRoles.map((r) => r.key) }); const refreshJwtToken = this.jwtService.issueRefreshToken({ id: refreshToken.id, userId: user.id }); |