All files / src/utils auditErrors.ts

0% Statements 0/71
100% Branches 1/1
100% Functions 1/1
0% Lines 0/71

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94                                                                                                                                                                                           
import { logger } from '@rasla/logify';
 
/**
 * Error personalizado base para errores relacionados con auditorías
 */
export class AuditError extends Error {
	public errorCode: string;
 
	constructor(message: string, errorCode: string) {
		super(message);
		this.name = this.constructor.name;
		this.errorCode = errorCode;
	}
}
 
/**
 * Logs audit-related errors
 * @param {string} functionName - Name of the function where the error occurred
 * @param {unknown} error - The error object
 */
export function logAuditError(functionName: string, error: unknown): void {
	console.error(`Error en auditService.${functionName}:`, error);
}
 
export class AuditTemplateNotFoundError extends AuditError {
	constructor() {
		super(
			'No se encontró la plantilla de auditoría solicitada',
			'AUDIT_TEMPLATE_NOT_FOUND'
		);
	}
}
 
export class AuditResultNotFoundError extends AuditError {
	constructor(id: string) {
		super(
			`No se encontró el resultado de auditoría con ID: '${id}'`,
			'AUDIT_RESULT_NOT_FOUND'
		);
	}
}
 
export class InvalidAuditDataError extends AuditError {
	constructor(detail: string) {
		super(`Datos de auditoría inválidos: ${detail}`, 'INVALID_AUDIT_DATA');
	}
}
 
export class FirebaseOperationError extends AuditError {
	constructor(operation: string) {
		super(
			`Error en la operación de Firebase: ${operation}`,
			'FIREBASE_OPERATION_ERROR'
		);
	}
}
 
// Función para crear respuestas de error estandarizadas
export function createAuditErrorResponse(error: any, defaultMessage: string) {
	// Error específico de auditoría
	if (error instanceof AuditError) {
		if (
			error instanceof AuditTemplateNotFoundError ||
			error instanceof AuditResultNotFoundError
		) {
			return {
				status: 404,
				message: error.message,
				errorCode: error.errorCode,
			};
		} else if (error instanceof InvalidAuditDataError) {
			return {
				status: 400,
				message: error.message,
				errorCode: error.errorCode,
			};
		} else if (error instanceof FirebaseOperationError) {
			return {
				status: 500,
				message: error.message,
				errorCode: error.errorCode,
			};
		}
	}
 
	// Error genérico
	console.error('Error en el servicio de auditoría:', error);
	return {
		status: 500,
		message: defaultMessage,
		errorCode: 'INTERNAL_SERVER_ERROR',
	};
}