2024-08-22 11:40:31 +02:00
|
|
|
import { dataSource } from "../data-source";
|
|
|
|
import { refresh } from "../entity/refresh";
|
2025-01-12 11:41:02 +01:00
|
|
|
import { PWA_REFRESH_EXPIRATION, REFRESH_EXPIRATION } from "../env.defaults";
|
2025-01-29 09:42:22 +01:00
|
|
|
import DatabaseActionException from "../exceptions/databaseActionException";
|
2024-08-22 11:40:31 +02:00
|
|
|
import InternalException from "../exceptions/internalException";
|
2024-08-23 14:42:47 +02:00
|
|
|
import { StringHelper } from "../helpers/stringHelper";
|
2025-02-15 10:59:54 +01:00
|
|
|
import UserService from "../service/management/userService";
|
2024-08-23 14:42:47 +02:00
|
|
|
import { CreateRefreshCommand, DeleteRefreshCommand } from "./refreshCommand";
|
2024-08-22 11:40:31 +02:00
|
|
|
import ms from "ms";
|
|
|
|
|
|
|
|
export default abstract class RefreshCommandHandler {
|
|
|
|
/**
|
|
|
|
* @description create and save refreshToken to user
|
2025-01-05 14:29:31 +01:00
|
|
|
* @param {CreateRefreshCommand} createRefresh
|
2024-08-22 11:40:31 +02:00
|
|
|
* @returns {Promise<string>}
|
|
|
|
*/
|
|
|
|
static async create(createRefresh: CreateRefreshCommand): Promise<string> {
|
2024-08-23 14:42:47 +02:00
|
|
|
const refreshToken = StringHelper.random(32);
|
2024-08-22 11:40:31 +02:00
|
|
|
|
|
|
|
return await dataSource
|
|
|
|
.createQueryBuilder()
|
|
|
|
.insert()
|
|
|
|
.into(refresh)
|
|
|
|
.values({
|
|
|
|
token: refreshToken,
|
2025-02-08 11:05:01 +01:00
|
|
|
userId: createRefresh.userId,
|
2025-01-12 11:41:02 +01:00
|
|
|
expiry: createRefresh.isFromPwa
|
|
|
|
? new Date(Date.now() + ms(PWA_REFRESH_EXPIRATION))
|
|
|
|
: new Date(Date.now() + ms(REFRESH_EXPIRATION)),
|
2024-08-22 11:40:31 +02:00
|
|
|
})
|
|
|
|
.execute()
|
|
|
|
.then((result) => {
|
|
|
|
return refreshToken;
|
|
|
|
})
|
|
|
|
.catch((err) => {
|
2025-01-29 09:42:22 +01:00
|
|
|
throw new DatabaseActionException("CREATE", "refresh", err);
|
2024-08-22 11:40:31 +02:00
|
|
|
});
|
|
|
|
}
|
2024-08-23 14:42:47 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @description delete refresh by user and token
|
2025-01-05 14:29:31 +01:00
|
|
|
* @param {DeleteRefreshCommand} deleteRefresh
|
2024-08-25 13:36:19 +02:00
|
|
|
* @returns {Promise<any>}
|
2024-08-23 14:42:47 +02:00
|
|
|
*/
|
|
|
|
static async deleteByToken(deleteRefresh: DeleteRefreshCommand): Promise<any> {
|
|
|
|
return await dataSource
|
|
|
|
.createQueryBuilder()
|
|
|
|
.delete()
|
|
|
|
.from(refresh)
|
2025-02-08 11:05:01 +01:00
|
|
|
.where({ token: deleteRefresh.token, userId: deleteRefresh.userId })
|
2024-08-23 14:42:47 +02:00
|
|
|
.execute()
|
|
|
|
.then((res) => {})
|
|
|
|
.catch((err) => {
|
2025-01-29 09:42:22 +01:00
|
|
|
throw new DatabaseActionException("DELETE", "refresh", err);
|
2024-08-23 14:42:47 +02:00
|
|
|
});
|
|
|
|
}
|
2024-09-04 14:01:22 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @description delete expired
|
|
|
|
* @returns {Promise<any>}
|
|
|
|
*/
|
|
|
|
static async deleteExpired(): Promise<any> {
|
|
|
|
return await dataSource
|
|
|
|
.createQueryBuilder()
|
|
|
|
.delete()
|
|
|
|
.from(refresh)
|
|
|
|
.where("refresh.expiry < :expiry", { expiry: new Date() })
|
|
|
|
.execute()
|
|
|
|
.then((res) => {})
|
|
|
|
.catch((err) => {
|
2025-01-29 09:42:22 +01:00
|
|
|
throw new DatabaseActionException("DELETE", "refresh", err);
|
2024-09-04 14:01:22 +02:00
|
|
|
});
|
|
|
|
}
|
2024-08-22 11:40:31 +02:00
|
|
|
}
|