summaryrefslogtreecommitdiff
path: root/server/controllers/refresh_tokens.controller.ts
diff options
context:
space:
mode:
Diffstat (limited to 'server/controllers/refresh_tokens.controller.ts')
-rw-r--r--server/controllers/refresh_tokens.controller.ts32
1 files changed, 32 insertions, 0 deletions
diff --git a/server/controllers/refresh_tokens.controller.ts b/server/controllers/refresh_tokens.controller.ts
new file mode 100644
index 0000000..2a24abe
--- /dev/null
+++ b/server/controllers/refresh_tokens.controller.ts
@@ -0,0 +1,32 @@
+import { Body, Controller, Get, HttpException, Req } from '@nestjs/common';
+import { Request } from 'express';
+import { UsersService } from 'server/providers/services/users.service';
+import { SignInDto } from 'server/dto/sign_in.dto';
+import { RefreshTokenBody } from 'server/dto/refresh_token_body.dto';
+import { JwtService } from 'server/providers/services/jwt.service';
+
+// this is kind of a misnomer because we are doing token based auth
+// instead of session based auth
+@Controller()
+export class RefreshTokensController {
+ constructor(private usersService: UsersService, private jwtService: JwtService) {}
+
+ @Get('/refresh_token')
+ async get(@Body() body: SignInDto, @Req() req: Request) {
+ const refreshToken: string = req.cookies['_refresh_token'];
+ if (!refreshToken) {
+ throw new HttpException('No refresh token present', 401);
+ }
+
+ const tokenBody = this.jwtService.parseRefreshToken(refreshToken) as RefreshTokenBody;
+
+ const user = await this.usersService.find(tokenBody.userId, ['refreshTokens']);
+ const userRefreshToken = user.refreshTokens.find((t) => t.id === tokenBody.id);
+ if (!userRefreshToken) {
+ throw new HttpException('User refresh token not found', 401);
+ }
+
+ const token = this.jwtService.issueToken({ userId: user.id });
+ return { token };
+ }
+}