Club Delphi  
    Paypal   FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Proyecto SIF/Veri*Factu/Ley Antifraude > Envío de registros y sus respuestas
Registrarse FAQ Miembros Calendario Guía de estilo Buscar Temas de Hoy Marcar Foros Como Leídos

Tema Cerrado
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 20-04-2025
Avatar de seccion_31
seccion_31 seccion_31 is offline
Miembro
 
Registrado: ene 2017
Posts: 472
Poder: 10
seccion_31 Va por buen camino
Cita:
Empezado por delphiGar Ver Mensaje
Hay que diferenciar con el tema del IRPF, lo que se cobra por la factura y el importe real de la misma:

Una factura normal SIN IRPF coincide el Importe Real con el que se va a cobrar:

Base Imponible + cuota iva = Importe Real, es el que se declara en verifactu

En el caso de una factura normal CON IRPF no coinicden los importes de cobro y el importe real:

Base Imponible + cuota iva - IRPF ( porcentaje aplicado IRPF * Base Imponible ) = Total a cobrar

Base Imponible + cuota iva = Importe real y a declarar en Verifactu.


Nota: El que no pagemos el IRPF o no lo cobremos de una factura es por que, o bien lo ingresamos en hacienda o nos lo deducimos, en ese orden.
gracias a ambos por las respuestas !

En cuanto probemos un poco mas la 4.2 la semana que viene, la publicare, y creo qua estas alturas ya no añadiremos mas funcionalidades mas.

Slds !
  #2  
Antiguo 20-04-2025
jguso jguso is offline
Miembro
 
Registrado: sep 2024
Posts: 42
Poder: 0
jguso Va por buen camino
ayuda

existe alguna forma de validar que el certificado con el que enviamos las facturas es correcto, es decir, está en vigor y todo eso
  #3  
Antiguo 20-04-2025
jguso jguso is offline
Miembro
 
Registrado: sep 2024
Posts: 42
Poder: 0
jguso Va por buen camino
ayuda

Otra cosa, hay alguna manera de validar los NIFs extranjeros y comunitarios antes de dar de alta algún cliente en el sistema de gestión, hacerlo a traves de esta librería. ?
  #4  
Antiguo 24-04-2025
Avatar de seccion_31
seccion_31 seccion_31 is offline
Miembro
 
Registrado: ene 2017
Posts: 472
Poder: 10
seccion_31 Va por buen camino
en la demo tienes un ejemplo para validar el nif con la aeat.

en la version 4.3 ademas se añade la validacion del vies para paises de la ue.

Saludos !
  #5  
Antiguo 24-04-2025
Avatar de seccion_31
seccion_31 seccion_31 is offline
Miembro
 
Registrado: ene 2017
Posts: 472
Poder: 10
seccion_31 Va por buen camino
Cita:
Empezado por jguso Ver Mensaje
existe alguna forma de validar que el certificado con el que enviamos las facturas es correcto, es decir, está en vigor y todo eso
en teoria que recuerde, los certificados que se obtienen de almacen, solo se muestran los vigentes.

el usado desde un archivo pfx o p12, ese no se valida antes de usarlo.

saludos
  #6  
Antiguo 24-04-2025
Avatar de seccion_31
seccion_31 seccion_31 is offline
Miembro
 
Registrado: ene 2017
Posts: 472
Poder: 10
seccion_31 Va por buen camino
El lunes se publicara la version 4.3, que incorpora bastantes cosas nuevas, y espero cerrar ya el ciclo de novedades, e ir arreglando posibles fallos.

saludos !
  #7  
Antiguo 24-04-2025
Avatar de seccion_31
seccion_31 seccion_31 is offline
Miembro
 
Registrado: ene 2017
Posts: 472
Poder: 10
seccion_31 Va por buen camino
esto no es parte del componente, pero por si no lo sabiais, respuesta de la AEAT:

(sobre integridad, inalterabilidad de los datos en sistemas verifactu)

Cita:
Buenos días:

En un sistema informático de facturación (SIF) que actúa en la modalidad VERI*FACTU, como el que cita, la integridad, inalterabilidad, conservación, accesibilidad y legibilidad se dan por garantizadas en cuanto se remite correctamente el registro de facturación (RF) a la AEAT. Por lo tanto, después ya "no importaría" que esos RF pudieran ser manipulados por otras aplicaciones y no habría obligación de hacer nada más (incluso podrían dejar de conservarse en el SIF, si así se desea). De hecho, los SIF VERI*FACTU no tienen obligación de detectar este tipo de anomalías.
Saludos !

: )
  #8  
Antiguo 24-04-2025
Avatar de bmfranky
bmfranky bmfranky is offline
Miembro
 
Registrado: may 2024
Ubicación: Gandia, Valencia
Posts: 863
Poder: 3
bmfranky Va por buen camino
Cita:
Empezado por seccion_31 Ver Mensaje
esto no es parte del componente, pero por si no lo sabiais, respuesta de la AEAT:

(sobre integridad, inalterabilidad de los datos en sistemas verifactu)



Saludos !

: )
Pus, mira , de un plumazo desaparece la la mitad de cosas a implementar...
__________________
Uno se alegra de ser útil. (Isaac Asimov)
  #9  
Antiguo 24-04-2025
Avatar de seccion_31
seccion_31 seccion_31 is offline
Miembro
 
Registrado: ene 2017
Posts: 472
Poder: 10
seccion_31 Va por buen camino
version 4.3

(ya enviada para su publicacion en el ftp del foro)

Leed atentamente ayuda.txt y cualquier duda, la posteais:

Cita:
version 4.3
----------------------------------------------------------------------------------------------------------------------------
valida el VIES, ademas del NIF. Para validar el VIES no es necesario un certificado.
Al añadir factura se comprueba que haya desgloses (de exenta o iva) en altas. Debe de haber al menos un desglose, aunque sea a cero.

version 4.2
----------------------------------------------------------------------------------------------------------------------------
corregidos encadenamientos, con facturas reenviadas y nuevas
corregidos tiempo 2 de minutos con facturas reeenviadas para marcar incidencia automaticamente al igualar o superar ese tiempo de reenvio.

version 4.1
----------------------------------------------------------------------------------------------------------------------------
se suprime soloRegistroAceptadas: boolean y pasan a guardarse todos los registros de facturacion, aceptados o no aceptados o incluso de envios fallidos.

a cambio se facilita el nombre del xml ya que si el sistema genera otro registro de facturacion existente por numserie, añadira _1 , _2 etc... al nombre del archivo para conservar todos los registros en la carpeta de ese numserie.

En el resultado (fallido o no) se envia el nombre (solo el nombre del archivo) dentro de la ruta programada en pathXML_RegistroFacturacion en TVeriFactu
en la variable: filenameXMLRegistro del resultado. Esto nos facilita archivar y encontrar el xml generado para una factura concreta.

En el evento del resultado (fallido o no) podremos acceder al nombre del archivo COMPLETO del xml con su ruta a traves del STATUS de cada factura remitida.Tambien recibiremos el XML via parametro.

AHORA:
cuando el envio no puede ser realizado, por fallos tecnicos de la AEAT o internet, etc... se devuelve "un resultado informativo" de la sesion fallida, donde se podran recoger las huellas y el error ocurrido:

resultado.errorDes

envioOk sera false
AceptadasOK :=0;
AceptadasError :=0;
ConErrores :=0;

cada factura del array de resultado contendra al menos los siguiente datos para indicar el error de transmision

facturas[n].ErrorCodigo:=-1;
facturas[n].error:=true;
facturas[n].aceptadoConErrores:=false;

ademas de las huellas y otros datos.

En resultado:

envioOK sera true cuando se haya podido enviar, por tanto los datos que regresen seran de la AEAT

envioOk sera false:

Cuando el envio NO puede ser realizado se guardan los registros de facturacion, exactamente de la misma forma que si hubieran sido aceptados, pero con algunos cambios como hemos visto arriba.

Todos los eventos tienen lugar con normalidad.

El evento que genera las huelllas a medida de calculo, no sabe si la transmision sera posible, por tanto genera las huellas sin mas
El evento que genera los registros de facturacion, ya conoce si el evento es (fallido o no) y se envia envioOK ademas del indice de la factura, el registro de facturacion (XML) y otros parametros.

El evento resultado ya conoce si ha sido fallido. el Componente TVerifactu devuelve false y resultado.envioOK devuelve false.
Las diferencias a cuanto a que encontraremos en el resultado devuelto dependen de si ha sido fallido o no.



version 4.0
----------------------------------------------------------------------------------------------------------------------------
Volvemos a las 10 sesiones

Vista la nueva informacion sobre encadenamientos hay que cambiar la forma en que se envian.

Explicaremos como se hacia, y despues como se hara desde la 4.0

Version 3 y anteriores:
Cuando se envia un registro SIEMPRE se calculaba una nueva huella:

Si la factura es nueva, no hay problema, huella nueva
Si se vuelve a enviar por error de datos de facturacion, un nif equivocado o algo asi, no hay problema, huella nueva
Si se vuelve a enviar por un error tecnico, fallo de internet, del equipo, (sin respuesta de la AEAT) etc... y el registro en principio es valido. HAY PROBLEMA, no deberiamos calcular una nueva huella deberiamos enviar la factura con la huella y encadenamiento originales. Y marcar como incidencia. Respetando el encadenamiento de la ultima factura añadida, para las siguientes. (eso ya pertences a la logica del programa).

La version 4 soluciona este problema
Se añaden tres campos en el registro de factura:

numeroSerieAnt[60]
huellaAnterior[64]
huellaFechaAnt[20]

estos tres campos junto a estos ya existentes:

huella[64]
huellaFechaHora[20]

Seran los que nos permitiran reenviar una factura fallida por fallo tecnico.

El Envio de una factura nueva, o factura modificada, huella nueva, por tanto no hay que indicar nada en estos valores

En el Re-Envio de una factura por fallo tecnico, hay que indicar esos valores, ya que tenemos un registro valido.

Por tanto siempre debemos guardar estos datos.

¿Como guardarlos?

Tras el envio y ocurra lo que ocurra, estan disponibles en el registro de factura:

Ejemplo: (sin el evento para recoger huellas) (ha sido escrito sin compilar, de memoria y es una aproximacion propia)

iniciamos sesion, cargamos datos , etc...

veriFactu.clearFactura( factura );
........
........
........ cargamos datos de la factura, cuotas, cif, totales, etc...
........
........ y añadimos:

// si hubo un fallo tecnico en la factura (ver mas abajo) tras el envio llevara marcado esto:
if dbFactura.feldbyName('fallotecnico').text='S' then
begin
factura.huella :=dbFactura.fieldbyName('huella').text; // cargamos la huella y anterior original
factura.huellafecha:=dbFactura.fieldbyName('Huellafecha').text; // debe contener espacio suficiente para la fecha y hora (string(20))

factura.numeroSerieAnt:=dbFactura.fieldbyname('antnumero').text;
factura.huellaFechaAnt:=dbFactura.fieldbyname('antfecha').text;
factura.huellaAnterior:=dbFactura.fieldbyname('anthuella').text;
end;

ok:=Verifactu.envio( resultado ); // enviamos

Verifactu.factura(1, factura); // seleccionamos la 1ª factura (puede ser un envio de 1)

dbFactura.edit; // la guardamos en la bd. (el registro de la bd. ya esta posicionada en ese registro)

dbFactura.fieldbyName('huella').text :=factura.huella; // 64 digitos
dbFactura.fieldbyName('Huellafecha').text:=factura.huellaFechaHora; // este campo deberia ser de 20 digitos. (contendra fecha y hora)

dbFactura.fieldbyname('antnumero').text :=factura.numeroSerieAnt;
dbFactura.fieldbyname('antfecha').text :=factura.huellaFechaAnt; // fecha
dbFactura.fieldbyname('anthuella').text :=factura.huellaAnterior; // 64 digitos

if not resultado.envioOk then // el envio ha sido fallido por causas tecnicas ( ha salido por el try... except )
begin
dbFactura.fieldbyname('fallotecnico').text:='S'; // lo indicamos en la factura

dbIncidencias.insert; // lo anotamos en el libro de incidencias (opcional)
dbIncidencias.fieldbyName('fecha').asdatetime:=time;
dbIncidencias.fieldbyName('hora').text :=timetostr(time);
dbIncidencias.fieldbyName('factura').text :=factura.numSerieFactura;
dbIncidencias.fieldbyName('texto').text :=resultado.error;
dbIncidencias.post;
end
else
dbFactura.fieldbyname('fallotecnico').text:='N'; // limpiamos esto si paso bien

dbFactura.post;

Y ahora procesariamos mas cosas....

Con esto ya tendriamos las huellas disponibles, y mas informacion si añadimos un bucle etc... podemos intervenir todas las facturas enviadas


Mas tarde podriamos volver a enviar la factura, y al haber sido marcada como fallotecnico se cargaran las huellas originales y no se generaran nuevas.


Nuevo: evento para recoger huellas

Sin esperar al resultado del envio:

El evento: onRegHue proporciona las huellas a medida que se va calculando el objeto SOAP antes de enviar, factura por factura.
Nos enviara la siguiente informacion:


TRegistroHueEvent = procedure( Sender: TObject; resultadoHuella:THuellaCallBack ) of object;

THuellaCallback=record
nifEmisor :string[9];
numserie :string[60];
FechaFactura :TDatetime;
TipoFactura :string[2]; ( F1 F2 etc... ó "B" si anulacion )
alta_baja :string[1]; (A o B)

Cuotatotal :currency;
ImporteTotal :currency;

Huella :string[64];
huellaFechaHora :string[20]; // guardaremos en un campo timestamp o de 20 digitos fecha y hora

numeroSerieAnt :string[60];
huellaAnterior :string[64];
huellaFechaAnt :string[20];

huellaSinCodificar:TMyString; // solo en altas o bajas ( no en reenvios con huella anterior)

indice :integer;
incidencia :boolean;
end;

Permitiendonos guardar esta informacion antes de su envio. (eso si, tenemos que llamar a la funcion enviar)



----------- enviamos la factura -------------------

Y procesamos resultado.

Y podria volver con algun fallo de nif, etc... pero al reenviar ya lo hariamos con huella nueva.
Tema Cerrado


Herramientas Buscar en Tema
Buscar en Tema:

Búsqueda Avanzada
Desplegado

Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro

Temas Similares
Tema Autor Foro Respuestas Último mensaje
Verifactu o por requerimiento (no-verifactu) ¿decisión del usuario? Maska10 Temas legales 2 07-12-2024 12:34:47
Demo de una applicación para una estación de enfermera con RAD Studio AgustinOrtu La Taberna 1 21-07-2015 17:41:35
Demo Delphi, EMail Caral Internet 1 19-12-2006 00:37:56
Demo de delphi 2005 mazinger Varios 2 18-12-2004 09:23:09
El Rave que viene con Delphi es una Demo? apicito Impresión 0 04-06-2003 11:33:36


La franja horaria es GMT +2. Ahora son las 16:39:09.


Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi
Copyright 1996-2007 Club Delphi