schema change and base operations

This commit is contained in:
Julian Krauser 2025-07-19 11:02:07 +02:00
parent 799a719012
commit 4d37571cb6
27 changed files with 660 additions and 52 deletions

View file

@ -10,7 +10,7 @@ export default abstract class DamageReportService {
.leftJoinAndSelect("damageReport.equipment", "equipment")
.leftJoinAndSelect("damageReport.vehicle", "vehicle")
.leftJoinAndSelect("damageReport.wearable", "wearable")
.leftJoinAndSelect("damageReport.maintenance", "maintenance");
.leftJoinAndSelect("damageReport.repair", "repair");
/**
* @description get all damageReports By done

View file

@ -1,3 +1,4 @@
import { Not, IsNull } from "typeorm";
import { dataSource } from "../../data-source";
import { maintenance } from "../../entity/unit/maintenance";
import DatabaseActionException from "../../exceptions/databaseActionException";
@ -9,8 +10,7 @@ export default abstract class MaintenanceService {
.createQueryBuilder("maintenance")
.leftJoinAndSelect("maintenance.equipment", "equipment")
.leftJoinAndSelect("maintenance.vehicle", "vehicle")
.leftJoinAndSelect("maintenance.wearable", "wearable")
.leftJoinAndSelect("maintenance.reports", "reports");
.leftJoinAndSelect("maintenance.wearable", "wearable");
/**
* @description get all maintenances
@ -28,7 +28,7 @@ export default abstract class MaintenanceService {
noLimit?: boolean;
}
): Promise<[Array<maintenance>, number]> {
let query = this.query().where({ done });
let query = this.query().where({ finishedAt: done ? Not(IsNull()) : IsNull() });
if (!noLimit) {
query = query.offset(offset).limit(count);
}

View file

@ -0,0 +1,96 @@
import { IsNull, Not } from "typeorm";
import { dataSource } from "../../data-source";
import { repair } from "../../entity/unit/repair";
import DatabaseActionException from "../../exceptions/databaseActionException";
export default abstract class RepairService {
private static query = () =>
dataSource
.getRepository(repair)
.createQueryBuilder("repair")
.leftJoinAndSelect("repair.equipment", "equipment")
.leftJoinAndSelect("repair.vehicle", "vehicle")
.leftJoinAndSelect("repair.wearable", "wearable")
.leftJoinAndSelect("repair.reports", "reports");
/**
* @description get all repairs
* @returns {Promise<[Array<repair>, number]>}
*/
static async getAll(
done = false,
{
offset = 0,
count = 25,
noLimit = false,
}: {
offset?: number;
count?: number;
noLimit?: boolean;
}
): Promise<[Array<repair>, number]> {
let query = this.query().where({ finishedAt: done ? Not(IsNull()) : IsNull() });
if (!noLimit) {
query = query.offset(offset).limit(count);
}
return await query
.orderBy("repair.createdAt", "ASC")
.getManyAndCount()
.then((res) => {
return res;
})
.catch((err) => {
throw new DatabaseActionException("SELECT", "repair", err);
});
}
/**
* @description get all repairs By related
* @returns {Promise<[Array<repair>, number]>}
*/
static async getAllForRelated(
where: { equipmentId: string } | { vehicleId: string } | { wearableId: string },
{
offset = 0,
count = 25,
noLimit = false,
}: {
offset?: number;
count?: number;
noLimit?: boolean;
}
): Promise<[Array<repair>, number]> {
let query = this.query().where(where);
if (!noLimit) {
query = query.offset(offset).limit(count);
}
return await query
.orderBy("repair.createdAt", "ASC")
.getManyAndCount()
.then((res) => {
return res;
})
.catch((err) => {
throw new DatabaseActionException("SELECT", "repair", err);
});
}
/**
* @description get repair by id
* @returns {Promise<repair>}
*/
static async getById(id: string): Promise<repair> {
return await this.query()
.where({ id })
.getOneOrFail()
.then((res) => {
return res;
})
.catch((err) => {
throw new DatabaseActionException("SELECT", "repair", err);
});
}
}