ff-admin-server/src/service/club/member/membershipService.ts

69 lines
2.3 KiB
TypeScript
Raw Normal View History

2025-01-05 14:14:00 +01:00
import { dataSource } from "../../../data-source";
import { membership } from "../../../entity/club/member/membership";
import InternalException from "../../../exceptions/internalException";
2025-01-21 14:49:14 +01:00
import { membershipView } from "../../../views/membershipsView";
2024-09-16 15:55:41 +02:00
2024-09-16 16:00:05 +02:00
export default abstract class MembershipService {
2024-09-16 15:55:41 +02:00
/**
* @description get all by member id
2025-01-29 08:53:49 +01:00
* @param {string} memberId
2024-09-16 15:55:41 +02:00
* @returns {Promise<Array<membership>>}
*/
2025-01-29 08:53:49 +01:00
static async getAll(memberId: string): Promise<Array<membership>> {
2024-09-16 15:55:41 +02:00
return await dataSource
.getRepository(membership)
.createQueryBuilder("membership")
2024-09-17 16:44:39 +02:00
.leftJoinAndSelect("membership.status", "membershipStatus")
2024-09-16 15:55:41 +02:00
.where("membership.memberId = :memberId", { memberId: memberId })
2025-01-02 17:08:53 +01:00
.orderBy("membership.start", "DESC")
2024-09-16 15:55:41 +02:00
.getMany()
.then((res) => {
return res;
})
.catch((err) => {
throw new InternalException("member memberships not found", err);
});
}
/**
* @description get by memberId and recordId
2025-01-29 08:53:49 +01:00
* @param {string} memberId
2024-09-16 15:55:41 +02:00
* @param {number} recordId
* @returns {Promise<Array<member>>}
*/
2025-01-29 08:53:49 +01:00
static async getById(memberId: string, recordId: number): Promise<membership> {
2024-09-16 15:55:41 +02:00
return await dataSource
.getRepository(membership)
.createQueryBuilder("membership")
2024-09-17 16:44:39 +02:00
.leftJoinAndSelect("membership.status", "membershipStatus")
2024-09-16 15:55:41 +02:00
.where("membership.memberId = :memberId", { memberId: memberId })
.andWhere("membership.id = :recordId", { recordId: recordId })
.getOneOrFail()
.then((res) => {
return res;
})
.catch((err) => {
throw new InternalException("member membership not found by id", err);
});
}
2025-01-21 14:49:14 +01:00
/**
* @description get membership statistics by memberId
2025-01-29 08:53:49 +01:00
* @param {string} memberId
2025-01-22 08:59:38 +01:00
* @returns {Promise<Array<membershipView>>}
2025-01-21 14:49:14 +01:00
*/
2025-01-29 08:53:49 +01:00
static async getStatisticsById(memberId: string): Promise<Array<membershipView>> {
2025-01-21 14:49:14 +01:00
return await dataSource
.getRepository(membershipView)
.createQueryBuilder("membershipView")
.where("membershipView.memberId = :memberId", { memberId: memberId })
2025-01-22 08:59:38 +01:00
.getMany()
2025-01-21 14:49:14 +01:00
.then((res) => {
return res;
})
.catch((err) => {
throw new InternalException("membershipView not found by id", err);
});
}
2024-09-16 15:55:41 +02:00
}