hrms-api-development/src/controllers/PortfolioController.ts

196 lines
6.2 KiB
TypeScript
Raw Normal View History

2024-06-30 20:50:39 +07:00
import {
Controller,
Post,
Put,
Delete,
Route,
Security,
Tags,
Body,
Path,
Request,
SuccessResponse,
Response,
Get,
2024-09-30 15:30:04 +07:00
Query,
2024-06-30 20:50:39 +07:00
} from "tsoa";
import { AppDataSource } from "../database/data-source";
import HttpSuccess from "../interfaces/http-success";
import HttpStatusCode from "../interfaces/http-status";
import HttpError from "../interfaces/http-error";
import { Not } from "typeorm";
import { CreatePortfolio, Portfolio } from "../entities/Portfolio";
import { RequestWithUser } from "../middlewares/user";
2024-09-03 15:18:30 +07:00
import { setLogDataDiff } from "../interfaces/utils";
2024-09-30 15:30:04 +07:00
import { Brackets } from "typeorm";
2024-06-30 20:50:39 +07:00
@Route("api/v1/development/portfolio")
@Tags("Portfolio")
@Security("bearerAuth")
@Response(
HttpStatusCode.INTERNAL_SERVER_ERROR,
"เกิดข้อผิดพลาด ไม่สามารถแสดงรายการได้ กรุณาลองใหม่ในภายหลัง",
)
@SuccessResponse(HttpStatusCode.OK, "สำเร็จ")
export class PortfolioController extends Controller {
private portfolioRepository = AppDataSource.getRepository(Portfolio);
/**
* API list
*
* @summary ORG_058 - CRUD (ADMIN) #62
*
*/
@Get()
2024-09-30 15:30:04 +07:00
async GetResult(@Request() request: RequestWithUser, @Query("keyword") keyword?: string) {
const _portfolio = await this.portfolioRepository
.createQueryBuilder("portfolio")
.select([
"portfolio.id",
"portfolio.name",
"portfolio.detail",
"portfolio.createdAt",
"portfolio.lastUpdatedAt",
"portfolio.createdFullName",
"portfolio.lastUpdateFullName",
])
.where("portfolio.createdUserId = :userId", { userId: request.user.sub })
.andWhere(
new Brackets((qb) => {
qb.where(keyword != null && keyword != "" ? "portfolio.name LIKE :keyword" : "1=1", {
keyword: `%${keyword}%`,
}).orWhere(keyword != null && keyword != "" ? "portfolio.detail LIKE :keyword" : "1=1", {
keyword: `%${keyword}%`,
});
}),
)
.getMany();
2024-06-30 20:50:39 +07:00
return new HttpSuccess(_portfolio);
}
/**
* API
*
* @summary ORG_058 - CRUD (ADMIN) #62
*
* @param {string} id Id
*/
@Get("{id}")
async GetById(@Path() id: string, @Request() request: RequestWithUser) {
const _portfolio = await this.portfolioRepository.findOne({
where: { id: id, createdUserId: request.user.sub },
select: ["id", "name", "detail"],
});
if (!_portfolio) {
throw new HttpError(HttpStatusCode.NOT_FOUND, "ไม่พบข้อมูลผลงานนี้");
}
return new HttpSuccess(_portfolio);
}
/**
* API body
*
* @summary ORG_058 - CRUD (ADMIN) #62
*
*/
@Post()
async Post(
@Body()
requestBody: CreatePortfolio,
@Request() request: RequestWithUser,
) {
const _portfolio = Object.assign(new Portfolio(), requestBody);
if (!_portfolio) {
throw new HttpError(HttpStatusCode.NOT_FOUND, "ไม่พบข้อมูลผลงานนี้");
}
const checkName = await this.portfolioRepository.findOne({
where: { name: requestBody.name, createdUserId: request.user.sub },
});
if (checkName) {
throw new HttpError(HttpStatusCode.NOT_FOUND, "ชื่อนี้มีอยู่ในระบบแล้ว");
}
2024-07-26 16:30:38 +07:00
const before = null;
2024-06-30 20:50:39 +07:00
_portfolio.createdUserId = request.user.sub;
_portfolio.createdFullName = request.user.name;
_portfolio.lastUpdateUserId = request.user.sub;
_portfolio.lastUpdateFullName = request.user.name;
_portfolio.createdAt = new Date();
_portfolio.lastUpdatedAt = new Date();
2024-08-01 14:31:32 +07:00
// addLogSequence(request, {
// action: "database",
// status: "success",
// description: "Store Portfolio.",
// });
2024-07-25 17:06:42 +07:00
await this.portfolioRepository.save(_portfolio, { data: request });
2024-07-26 16:30:38 +07:00
setLogDataDiff(request, { before, after: _portfolio });
2024-06-30 20:50:39 +07:00
return new HttpSuccess(_portfolio.id);
}
/**
* API body
*
* @summary ORG_058 - CRUD (ADMIN) #62
*
* @param {string} id Id
*/
@Put("{id}")
async Put(
@Path() id: string,
@Body()
requestBody: CreatePortfolio,
@Request() request: RequestWithUser,
) {
const _portfolio = await this.portfolioRepository.findOne({ where: { id: id } });
if (!_portfolio) {
throw new HttpError(HttpStatusCode.NOT_FOUND, "ไม่พบข้อมูลผลงานนี้");
}
const checkName = await this.portfolioRepository.findOne({
where: { id: Not(id), name: requestBody.name, createdUserId: request.user.sub },
});
if (checkName) {
throw new HttpError(HttpStatusCode.NOT_FOUND, "ชื่อนี้มีอยู่ในระบบแล้ว");
}
_portfolio.lastUpdateUserId = request.user.sub;
_portfolio.lastUpdateFullName = request.user.name;
_portfolio.lastUpdatedAt = new Date();
2024-06-30 20:50:39 +07:00
Object.assign(_portfolio, requestBody);
2024-08-01 14:31:32 +07:00
// addLogSequence(request, {
// action: "database",
// status: "success",
// description: "Store Portfolio.",
// });
2024-07-25 17:06:42 +07:00
await this.portfolioRepository.save(_portfolio, { data: request });
2024-06-30 20:50:39 +07:00
return new HttpSuccess(_portfolio.id);
}
/**
* API
*
* @summary ORG_058 - CRUD (ADMIN) #62
*
* @param {string} id Id
*/
@Delete("{id}")
async Delete(@Path() id: string, @Request() request: RequestWithUser) {
const _delPortfolio = await this.portfolioRepository.findOne({
where: { id: id, createdUserId: request.user.sub },
});
if (!_delPortfolio) {
throw new HttpError(HttpStatusCode.NOT_FOUND, "ไม่พบข้อมูลผลงานนี้");
}
2024-08-01 14:31:32 +07:00
// addLogSequence(request, {
// action: "database",
// status: "success",
// description: "Store Portfolio.",
// });
2024-07-25 17:06:42 +07:00
await this.portfolioRepository.delete(_delPortfolio.id), { data: request };
2024-06-30 20:50:39 +07:00
return new HttpSuccess();
}
}