![]() |
![]() |
![]() |
![]() |
![]() |
FTP | ![]() |
![]() |
CCD | ![]() |
![]() |
Buscar | ![]() |
![]() |
Trucos | ![]() |
![]() |
Trabajo | ![]() |
![]() |
Foros | ![]() |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
![]() |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
|||
|
|||
¿Qué (posibles) errores comprobáis antes de guardar la factura?
Buenas!
Pues eso. Imagino que hacéis comprobaciones antes de permitir guardar/emitir la factura, para evitar algunos de los problemas más comunes cuando ésta se envíe. Nosotros comprobamos/validamos el NIF del Emisor (si no es una fac. simplificada) y el del Destinatario, el certificado digital (que no esté caducado, etc.), si se trata de un cliente extranjero, que esté definido el País, etc. Hay muchísimas validaciones que se podrían hacer, pero no sé si currármelas todas con un un "super validador" o centrarme solo en los problemas más comunes y ya si luego da error, que el usuario subsane o rectifique según proceda. ¿Alguna validación previa más que consideráis importante? |
#2
|
|||
|
|||
Cita:
https://www.agenciatributaria.es/sta...Veri-Factu.pdf Si alguna validación no se supera, se informa al usuario y no se permite salvar la venta. |
#3
|
|||
|
|||
Cita:
Yo hasta ahora me he centrado en todo lo demás. Como aún queda tiempo, quizás vaya añadiendo más validaciones previas poco a poco. |
#4
|
||||
|
||||
Yo personalmente, como no tengo pensado emitir facturas sin que haya conexion, uso el sistema de validacion que han implementado para los no verifactu, que es el mismo que se usa para el verifactu, si pasa la verificacion, ya guardo , envio e imprimo la factura con total seguridad de que es correcta, si no lo es , como aun estoy en fase de *diseño de la misma, pues puedo correjir lo que haga falta, e incluso salir sin guardar nada descartando cualquier cambio, en la base de datos, puesto que la factura no se ha finalizado....
Aunque si , esa super funcion de comprobacion , de @rci para el modo offline, serida suprema.... *Se aceptan donaciones de codigo.... ![]() ![]()
__________________
Uno se alegra de ser útil. (Isaac Asimov) |
#5
|
||||
|
||||
Es buena idea validar de forma "TOTAL" la factura antes de guardarla pero se me ocurre que eso puede traer algún problema que otro:
1- Entiendo que la factura debe de tener su número para poder validarla, si por lo que sea hay algún error y no dejáis guardarla/enviarla entiendo que el proceso se atasca. En ambientes de red, si otro está facturando por otro sitio entiendo que debería de dejarle enviar la factura siendo correcta y esta llevará un número posterior. Si al final la factura atascada no se puede llevar a término por el motivo que sea tendremos un problema y no sé si también aunque al final se envíe si se hace con una fecha+hora posterior a una factura posterior. 2- Igualmente si hay "bulla" y una factura se "atasca" se puede atascar igualmente la cosa con otros clientes que haya esperando. 3- Si por el motivo que sea no hay internet se debe de poder emitir la factura aunque se envíe posteriormente con incidencia (es mi opinión). Saludos.
__________________
Be water my friend. |
#6
|
||||
|
||||
Cita:
Dentro de ese proceso se busca el numero que le toca en una tabla de contadores y se actualiza esa tabla para que la siguiente factura no coja el mismo número. Dentro de esa misma transacción también se crea el registro de facturación, con el número asignado y también dentro de esa transacción se hacen las validaciones. Si alguna validación falla, se lanza un error y el proceso de salvar se cancela y se deshace toda la transacción (RollBack). Por lo tanto no se guarda la venta, no se guarda registro de facturación pero tampoco se guarda la información del contador, el numero de factura que toca. De esta forma, si "al segundo siguiente" otro ordenador quiere salvar una factura, hará el mismo proceso y cogerá el mismo número que el SIF quería utilizar para la factura que ha fallado en la validación, el que toca en ese momento. Si ese segundo ordenador no tiene errores podrá salvar la factura. El primer ordenador, que no ha podido salvar por un error en la validación, cuando corrija el problema y vuelva a salvar la factura, cogerá otro numero (el que toque) y si no hay errores pues salvará la factura y el registro de facturación con los nuevos datos. Cita:
Cita:
Seguro que se puede mejorar y también seguramente encontraremos algunos problemas pero de momento está funcionando. Cita:
Esta idea tiene de bueno que las validaciones realmente las hace la AEAT y seguramente son las mismas que se harán al enviar. A parte que cuando AEAT hace cambios en las validaciones, de esta forma no tienes que cambiar nada y con la función que hemos hecho (que también puede tener errores en nuestro código), en cada cambio de la AEAT, tenemos que mantener la función que valida. Esperemos que no cambien mucho. Saludos Última edición por rci fecha: Hace 18 Horas a las 18:14:17. |
#7
|
|||
|
|||
Cita:
en mi caso actualmente no comprobamos nada, tu generas la facturas y el RF, y si luego al enviarse da error pues a corregirla. Igual le tengo que dar una vuelta a esto ![]() |
#8
|
|||
|
|||
Si, las dos cosas. El CIF se valida con el algoritmo (que no requiere internet) i también con el web Service de la AEAT, pero si es posible se hace antes de salvar la factura, por ejemplo cuando se indica el cliente o cuando se modifica el CIF o la razón social, así de esta forma, si en el momento de salvar la factura el CIF ya está "marcado internamente" como validado, ya no se tiene que validar de nuevo.
|
#9
|
|||
|
|||
Cita:
Solo afectará a la cola de clientes que estén esperando, pero vamos, si hay cola es probablemente un comercio, donde no hay NIF del cliente ni otras cosas que puedan fallar, así que no será el caso. Yo lo que haré es comprobar solo algunas de las validaciones, las que más sujetas estén a fallo por parte del usuario. Hay otras que tal como está diseñada la aplicación es imposible que se den nunca. Por cierto, le he dado a ChatGPT el documento de validaciones y le he pedido que me cree un algoritmo en PHP que haga todas las validaciones del documento. Aún no me he puesto a revisarlo, pero creo que lo ha hecho bastante bien ![]() No todas estas validaciones pueden hacerse ANTES de guardar la factura, y no todas requieren validación, pero algo se podrá aprovechar: Código PHP:
|
#10
|
||||
|
||||
Pues la funcion que postee, funciona perfectamente, hasta me ha salido un error oculto que tenia en la llamada a la funcion que me bajaba la hora del roa, al caer eñl servicio me ha diagnosticado que insertaba decimales, todo antes de enviar nada realmente a la AEAT, al no ser un envio aunque falles, no reza en ningun sitio...
__________________
Uno se alegra de ser útil. (Isaac Asimov) |
![]() |
|
|
![]() |
||||
Tema | Autor | Foro | Respuestas | Último mensaje |
Tipo de Registro para Errores en el receptor de factura | ermendalenda | Envío de registros y sus respuestas | 38 | 20-11-2024 20:24:50 |
Guardar y Leer fotos directamente a una base de datos sin antes guardar como archivo | rmeckbell | Desarrollo en Delphi para Android | 6 | 26-06-2017 18:24:20 |
Guardar antes de que mi aplicacion se cierre | Gelmin | Varios | 4 | 24-09-2008 09:20:23 |
Calcular un valor antes de guardar en una tabla | FGarcia | Varios | 11 | 21-11-2007 05:22:07 |
![]() |
|