Update: nueva version Horux Despachos
This commit is contained in:
62
apps/api/src/controllers/bancos.controller.ts
Normal file
62
apps/api/src/controllers/bancos.controller.ts
Normal file
@@ -0,0 +1,62 @@
|
||||
import type { Request, Response, NextFunction } from 'express';
|
||||
import { z } from 'zod';
|
||||
import * as bancosService from '../services/bancos.service.js';
|
||||
import { AppError } from '../middlewares/error.middleware.js';
|
||||
|
||||
const createSchema = z.object({
|
||||
banco: z.string().min(1, 'banco requerido').max(100),
|
||||
terminacionCuenta: z.string().min(1).max(4, 'terminacionCuenta max 4 digitos'),
|
||||
});
|
||||
|
||||
const updateSchema = z.object({
|
||||
banco: z.string().min(1).max(100).optional(),
|
||||
terminacionCuenta: z.string().min(1).max(4).optional(),
|
||||
});
|
||||
|
||||
export async function getBancos(req: Request, res: Response, next: NextFunction) {
|
||||
try {
|
||||
const contribuyenteId = (req.query.contribuyenteId as string) || null;
|
||||
const bancos = await bancosService.getBancos(req.tenantPool!, contribuyenteId);
|
||||
res.json(bancos);
|
||||
} catch (error) { next(error); }
|
||||
}
|
||||
|
||||
export async function createBanco(req: Request, res: Response, next: NextFunction) {
|
||||
try {
|
||||
if (req.user!.role !== 'owner') return res.status(403).json({ message: 'No autorizado' });
|
||||
const data = createSchema.parse(req.body);
|
||||
const contribuyenteId = req.body.contribuyenteId as string | undefined;
|
||||
const result = await bancosService.createBanco(req.tenantPool!, { ...data, contribuyenteId });
|
||||
res.status(201).json(result);
|
||||
} catch (error) {
|
||||
if (error instanceof z.ZodError) return next(new AppError(400, error.errors[0].message));
|
||||
next(error);
|
||||
}
|
||||
}
|
||||
|
||||
export async function updateBanco(req: Request, res: Response, next: NextFunction) {
|
||||
try {
|
||||
if (req.user!.role !== 'owner') return res.status(403).json({ message: 'No autorizado' });
|
||||
const id = parseInt(String(req.params.id));
|
||||
const data = updateSchema.parse(req.body);
|
||||
const result = await bancosService.updateBanco(req.tenantPool!, id, data);
|
||||
res.json(result);
|
||||
} catch (error) {
|
||||
if (error instanceof z.ZodError) return next(new AppError(400, error.errors[0].message));
|
||||
next(error);
|
||||
}
|
||||
}
|
||||
|
||||
export async function deleteBanco(req: Request, res: Response, next: NextFunction) {
|
||||
try {
|
||||
if (req.user!.role !== 'owner') return res.status(403).json({ message: 'No autorizado' });
|
||||
const id = parseInt(String(req.params.id));
|
||||
await bancosService.deleteBanco(req.tenantPool!, id);
|
||||
res.json({ message: 'Banco eliminado' });
|
||||
} catch (error: any) {
|
||||
if (error.message?.includes('conciliaciones')) {
|
||||
return res.status(400).json({ message: error.message });
|
||||
}
|
||||
next(error);
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user