UNPKG

@briswell/bw-domain

Version:

Domain Library for Node.js

62 lines (61 loc) 2.44 kB
"use strict"; var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { return new (P || (P = Promise))(function (resolve, reject) { function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } step((generator = generator.apply(thisArg, _arguments || [])).next()); }); }; Object.defineProperty(exports, "__esModule", { value: true }); const moment = require("moment"); const uuid = require("uuid"); const refreshToken_1 = require("../model/refreshToken"); const user_1 = require("../model/user"); class RefreshTokenRepository { constructor(db) { this.refreshTokenModel = refreshToken_1.default(db); this.userModel = user_1.default(db); this.refreshTokenModel.belongsTo(this.userModel); } /** * トークン確実 * @param params token = refresh token, maxAge = トークン失効になる期間 */ checkToken(params) { return __awaiter(this, void 0, void 0, function* () { const token = yield this.refreshTokenModel.find({ where: { refreshToken: params.token }, include: [{ model: this.userModel, where: { disableFlag: 0 } }] }); if (token === null) { return undefined; } else { const updatedAt = moment(token.updatedAt); const expiredAt = updatedAt.add(params.maxAge, 'minutes'); if (expiredAt < moment()) { return undefined; } else { // 新しいトークンに変更する const newToken = uuid(); token.set('refreshToken', newToken); yield token.save(); return { id: token.userId, refreshToken: newToken }; } } }); } } exports.default = RefreshTokenRepository;