Uecko_ERP/modules/customers/src/api/infrastructure/express/controllers/update-customer.controller.ts

25 lines
944 B
TypeScript
Raw Normal View History

2025-09-01 14:07:59 +00:00
import { ExpressController, authGuard, forbidQueryFieldGuard, tenantGuard } from "@erp/core/api";
import { UpdateCustomerRequestDTO } from "../../../../common/dto";
import { UpdateCustomerUseCase } from "../../../application";
export class UpdateCustomerController extends ExpressController {
public constructor(private readonly useCase: UpdateCustomerUseCase) {
super();
// 🔐 Reutiliza guards de auth/tenant y prohíbe 'companyId' en query
this.useGuards(authGuard(), tenantGuard(), forbidQueryFieldGuard("companyId"));
}
protected async executeImpl() {
const companyId = this.getTenantId()!; // garantizado por tenantGuard
2025-09-02 08:57:41 +00:00
const { customer_id } = this.req.params;
2025-09-01 14:07:59 +00:00
const dto = this.req.body as UpdateCustomerRequestDTO;
2025-09-02 08:57:41 +00:00
const result = await this.useCase.execute({ customer_id, companyId, dto });
2025-09-01 14:07:59 +00:00
return result.match(
2025-09-02 11:06:25 +00:00
(data) => this.ok(data),
2025-09-01 14:07:59 +00:00
(err) => this.handleError(err)
);
}
}