![]() |
![]() |
| Paypal | FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
|||||||
| Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
![]() |
|
|
Herramientas | Buscar en Tema | Desplegado |
|
#41
|
|||
|
|||
|
Cita:
Con los fallos de encadenamiento también actúan igual, te los permiten porque saben que pueden haber huecos debido a rechazos, pero si fuera una casuística recurrente en tu SIF, entiendo que te llamarían a capítulo |
|
#42
|
|||
|
|||
|
Mi locura particular. Archivos bath.
Voy a volver sobre este tema de las subsanaciones por si algún alma caritativa me lo deja claro, porque la verdad aún no me entero.
Supongamos que envío un XML con un conjunto de 20 facturas y supongamos que la número 10 me devuelve incorrecto, en mi caso concreto, por el tema del NIF. El resto de posibles errores ya los tengo blindados para que el usuario no los pueda cometer antes de enviar la factura. Ahora leyendo lo del webservice para la comprobación del NIF veré a ver qué hago. Se supone que no se puede modificar la factura para cambiar el NIF o el nombre del cliente (por ejemplo uno con apellidos compuestos que tienen guiones supongamos ALBERTO MARTIN-GARCIA FERNANDEZ). Así que hacienda la factura 10 no la tiene, mi SIF ya tiene generado un registro de envío de la 10 encadenado con la 9 y también uno para la 11 encadenado con la 10 que me devolvió correcto, a pesar de que la 10 no la cogió. Si ahora decido volver a enviar la 10 eligiendo como decís eso de (otro no censado), ¿tengo que volver a encadenar ese envío de la subsanación de la 10 con la huella de la 20 que fue la última que se envió? y luego cuando envíe la 21, la tengo que encadenar con el envío de la subsanación de la 10 que sería el último enviado? y si me doy cuenta del error mañana la fecha y hora que hay que poner es la del registro del envío de la subsanación, imagino. No la fecha de la factura. ¿no? Y por último otro problema que tengo es el siguiente, si genero un XML con 200 facturas, el proceso de creación del XML con los encadenamientos, etc me tarda más de los 240 segundos y por tanto cuando lo mando, los primeros registros del conjunto me los acepta con errores por que dice que ha pasado más tiempo del debido. De momento no pienso hacer nada con eso, pero ¿es legal? Gracias de antemano y perdón por el rollo. |
|
#43
|
|||
|
|||
|
Cita:
Dicho de otra forma: imagina que no tienes conexión a internet durante un día, pero tu ese día necesitas hacer facturas. Y no solo facturas, sino rectificativas, subsanaciones, etc. Las que quieras (el envío ya lo harás cuando vuelva internet). Pues bien, para que eso sea posible, tu tienes que encadenarlo todo "cronológicamente", a medida que vaya surgiendo lo que tengas que hacer. Olvídate de seguir una numeración correlativa, no tiene que ver con eso. Tu puedes enviar el RF de la factura 1000 después de haber enviado un RF de la Rectificativa 200-R o de un tícket (simplificada) 351-T. Es difícil que se tarde más de 240 segundos en generar y enviar el XML con 200 facturas, pero si se diera el caso, debes enviar el XML indicando Incidencia = S en la Cabecera. Esto puedes comprobarlo ANTES de generar la cabecera: compruebas si en el bloque que vas a enviar hay alguna factura que se haya emitido hace más de 240 segundos y, si es así, marcas el envío como Incidencia. He leído por aquí que algunos marcan todos los envíos como Incidencia aunque no la haya (Hacienda lo acepta), pero no soy partidario de que sea lo correcto. A mí me respondieron desde VeriFactu que por lo pronto este error y otros similares no los van a tener en cuenta, salvo que sea algo muy recurrente en tu software. Ahí supongo que te dirían algo si lo consideran sospechoso. |
|
#44
|
|||
|
|||
|
Cita:
|
|
#45
|
||||
|
||||
|
Hola, lo que no has de esperarte tanto para generar el registro a enviar, si realmete te tarda tanto en generar y enviar, no apures, envia cada menos, envez de esperar los 240" envia a los 210 y mientras generas cumples con los 60" o lo que te inmpongan , no has de esperar 240" para enviar.
La cronologia es , envias el primer envio del dia, antes de cumplir 240" del primer registro, poner a 0 el contador e inicializar la cuenta de 60" o lo que te pidan par impedir un n uevo envio, en el momento de generrse un registro que encolas pones a 0 el contador de envios, cuando llegue a 210", seguro que has superado los x segundos que te indican en la respuesta, cierras el xml a enviar y envias, poniendo a 0 el contador de de registros de los 210" si se genera alguno, entre tanto recuperas el tiempo de espera, lo asignas y activas el contador, vas encolando si se generan registros de alta, abono, alta de subsanacion etc... y lo mismo , al llegar a 210" del primer registro encadenado, seguro qe has superado los segundos de espera, envias y vuelves a empezar, es lioso de explicar pero sencillo de implementar. 2 contadores uno de espera minima en principio 60" que se inicializa con el tiempo de la respuesta y tiende a 0 cada segundo y otro de espera maxima que empieza en 0 al encolar el primer registro, ya sea del dia , desde inicio del SIF o desde el anterior envio, y se incrementa hasta llegar a 210" por ejemplo y una subrutina que se encarga cada segundo de decrementar el de 60" si mayor a 0 y de incrementar el de 210 si menor a 210, cuando llegues a 210" envias lo que hay encolado en la tabla que almacenas los registros a enviar y vuelves a empezar.
__________________
Uno se alegra de ser útil. (Isaac Asimov) |
|
#46
|
|||
|
|||
|
Cita:
Nosotros lo tenemos de otra manera... es un servicio de windows que salta por defecto cada 60 segundos (controlado con el propio timer del servicio). La mayoría de las veces no habrá nada para enviar y estará saltando cada 60 segundos pero cuando sí encuentre algo entonces para el timer, envía, obtiene la respuesta, coge el valor de "TiempoEsperaEnvio" (que en las pruebas que hago siempre me devuelve 60), y vuelve a poner en marcha el timer asignándole como intervalo el valor de "TiempoEsperaEnvio". De esta manera enviará o intentará enviar cada 60 segundos. Pero si un día la respuesta del envío dice que tenemos que esperar por ejemplo 200 segundos automáticamente el timer pasará a saltar cada 200 segundos. No sé si alguien más lo tiene así o si le veis alguna traba! Saludos |
|
#47
|
|||
|
|||
|
Cita:
|
|
#48
|
||||
|
||||
|
Cita:
Nidecoña. De forma normal no puede pasar más de 60s desde que se genera la factura hasta que se envía.
__________________
Be water my friend. |
|
#49
|
|||
|
|||
|
Efectivamente, se tiene que enviar el RF al 'instante' de crearlo. Además si el cliente de turno le da por leer el QR puede decirte, aquí me dice que no esta en el portal, xD.
|
|
#50
|
|||
|
|||
|
Cita:
|
|
#51
|
|||
|
|||
|
Cita:
Hola, lo veo arriesgarl por no decir MAL, a ver, te pongo un escenario: Envías a las 12:30:05 por que tu timer ha llegado a los 60segundos y había 1 ó 2 registros.inmed8atemente están generando un registro que se graba a las 12:30:07 que no entra en ese lote, pero es que tampoco podría entrar en wl siguiente por que no ha llegado a los 60 segundos de antigüedad, con lo cual cuando lo vayas a enviar tiene 118segundos, con lo cual ese envío tiene que estar finalizado en 2 segundos máximo, es arriesgado. O sea, todo lo que generes después de el último envio no lo puedes enviar hasta que cumpla cada uno de ellos 60 segundos, lo siento, pero lo tienes mal. Repasalo Por ejemplo: Reduce el timer a 10 segundos y mira cada registro pendiemte si ya ha cumplido los 60 segundos y metelos en el lote de envío. |
|
#52
|
|||
|
|||
|
Yo lo tengo como Jarogo08, con una pequeña variación:
- Tras recoger la respuesta del envío realizado y comprobar el tiempo de espera, es entonces donde hago una pausa con ese valor, y tras ello vuelvo a comprobar si ya hay más registros de facturacion pendientes de enviar. |
|
#53
|
||||
|
||||
|
Cita:
de tiempo entre generar y enviar, teniendo en cuenta que si solo enviamos de 1 en 1 registro "Deberíamos" esperar los t" , segundos que nos indican en la respuesta del envío antes del siguiente, aunque que a efectos prácticos, realmente tienes razón y no sera 60, segundos porque mientras generas el ticket algunos segundos tardas... , incluso un cajero avanzado no tarda 1" en finalizar y cobrar un ticket (Digo ticket porque es lo mas rápido de gestionar que se me ocurre, un ticket de supermercado.), aunque un supermercado de mas de 1 caja , imagino que tendrán la generación de tickets de caja centralizada, y el servidor sera el encargado de encolar los registros y enviarlos y demás y no la caja...
__________________
Uno se alegra de ser útil. (Isaac Asimov) |
|
#54
|
||||
|
||||
|
Cita:
Cita:
"pero es que tampoco podría entrar en wl siguiente por que no ha llegado a los 60 segundos de antigüedad" Un registro NO DEBE enviarse con más de 240 sg. de antigüedad, de otra forma hay que marcarlo con INCIDENCIA, pero lo que es incorrecto es que no se pueda enviar con menos de 60 sg. de antigüedad. Tú puedes geberar un Registro de Facturación y enviarlo 2 sg. después, no hay problema, siempre y cuando el último envío haya sido hace 60 sg. Es decir, el escenario que dice [Jarogo08], que tenemos nosotros y que es correcto sería por ejemplo este: Código:
12:00:00 Se prepara envío (como es vacio, no se envía NADA); 60 sg. de espera 12:01:00 Se prepara envío (como es vacio, no se envía NADA); 60 sg. de espera 12:01:10 Generamos factura 1 12:01:45 Generamos factura 2 12:02:00 Se prepara envío (2 facturas); 60 sg. de espera 12:03:00 Se prepara envío (como es vacio, no se envía NADA); 60 sg. de espera 12:03:10 Generamos factura 3 12:03:20 Generamos factura 4 12:03:30 Generamos factura 5 12:03:40 Generamos factura 6 12:03:50 Generamos factura 7 12:04:00 Se prepara envío (5 facturas); AEAT contesta con 120 sg. de espera 12:06:00 Se prepara envío (como es vacio, no se envía NADA); 120 sg. de espera 12:08:00 Se prepara envío (como es vacio, no se envía NADA); 120 sg. de espera 12:09:50 Generamos factura 8 12:10:00 Se prepara envío (1 factura); AEAT contesta con 60 sg. de espera 12:11:00 Se prepara envío (como es vacio, no se envía NADA); 60 sg. de espera ...
__________________
Germán Estévez => Web/Blog Guía de estilo, Guía alternativa Utiliza TAG's en tus mensajes. Contactar con el Clubdelphi ![]() P.D: Más tiempo dedicado a la pregunta=Mejores respuestas. Última edición por Neftali [Germán.Estévez] fecha: 08-05-2025 a las 11:29:59. |
|
#55
|
|||
|
|||
|
Cita:
Nosotros lo hacemos de forma muy similar, el servicio tiene una tarea que salta siempre cada 60 segundos. en ese momento comprueba el valor t que contestó el último envío y la fecha del último envío. Si ya ha pasado el tiempo o si hay mas de 1000 registros, envía. sino vuelve a esperar 60 segundos y vuelve a comprobar. Los 60 segundos de espera de nuestra tarea podría ser otro valor, por ejemplo 30... también habíamos probado con 1 segundo pero en ese caso consumía muchos recursos y no hace falta. mientras se despierte una vez cada minuto creo que ya está bien Última edición por rci fecha: 08-05-2025 a las 10:16:05. |
|
#56
|
||||
|
||||
|
Creo que os estáis liando con el tema de tiempos.
Lo que tiene que esperar 60 segundos son los envíos, no un registro de facturación para ser enviado. Un Registro de Facturación puede enviarse 1 sg. después de haberse generado (siempre que en los últimos 60 sg. no hayas hecho un envío).
__________________
Germán Estévez => Web/Blog Guía de estilo, Guía alternativa Utiliza TAG's en tus mensajes. Contactar con el Clubdelphi ![]() P.D: Más tiempo dedicado a la pregunta=Mejores respuestas. |
|
#57
|
|||
|
|||
|
Cita:
|
|
#58
|
||||
|
||||
|
Cita:
*El primer envío es el de puesta en marcha del servicio.
__________________
Uno se alegra de ser útil. (Isaac Asimov) |
|
#59
|
|||
|
|||
|
Cita:
Si no hay registros pendientes de envío ya no se envía nada y AEAT no contesta no? |
|
#60
|
|||
|
|||
|
Cita:
Exactamente + 2 Última edición por Jarogo08 fecha: 08-05-2025 a las 10:51:03. |
![]() |
|
|
Temas Similares
|
||||
| Tema | Autor | Foro | Respuestas | Último mensaje |
| Entorno pruebas AEAT | _Io | Envío de registros y sus respuestas | 8 | 02-04-2025 14:56:55 |
| Error 2004 - FechaHoraGenRegistro Exento De Subsanacion | bmfranky | Errores (relacionados con al AEAT) | 3 | 05-12-2024 13:36:39 |
| Error 3002 en subsanacion | ermendalenda | Errores (relacionados con al AEAT) | 5 | 14-11-2024 10:59:55 |
| Tabla de Facturas vs Detalles de Facturas | magnu9 | Conexión con bases de datos | 9 | 27-07-2007 17:27:37 |
| Campos calculados, facturas y detalles de facturas. | Letty | Conexión con bases de datos | 7 | 07-11-2003 11:19:44 |
|