2024-08-22 11:40:31 +02:00
|
|
|
import { dataSource } from "../data-source";
|
|
|
|
import { refresh } from "../entity/refresh";
|
2025-01-29 09:42:22 +01:00
|
|
|
import DatabaseActionException from "../exceptions/databaseActionException";
|
2025-04-19 16:51:37 +02:00
|
|
|
import SettingHelper from "../helpers/settingsHelper";
|
2024-08-23 14:42:47 +02:00
|
|
|
import { StringHelper } from "../helpers/stringHelper";
|
|
|
|
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
|
2025-04-20 15:32:57 +02:00
|
|
|
? new Date(Date.now() + ms(SettingHelper.getSetting("session.pwa_refresh_expiration")))
|
|
|
|
: new Date(Date.now() + ms(SettingHelper.getSetting("session.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
|
|
|
}
|