Estamos intentando usar un certificado instalado en el almacén de windows para realizar la remisión a VeriFactu.
Para esto usamos el evento HTTPWebNode.OnNeedClientCertificate(const Sender: TObject; const ARequest: TURLRequest; const ACertificateList: TCertificateList var AnIndex: Integer);
En este evento nos llega una lista de certificados válidos para el server de la AEAT y escogemos uno de ellos.
Ahora bien, queremos que el proceso sea automático y en caso de que el certificado use una Passowrd nos salta la pantalla de Windows pidiendo la contraseña del certificado. Queríamos evitar esto.
Se nos ocurren dos opciones:
1) Poder asignar por código la Password directamente al certificado escogido en el OnNeedCertificate pero solo podemos asignar el parámetro de salida AnIndex.
2) Sabemos que existe una forma de asignar las password de la siguiente forma:
Cita:
// Asignar el cetificado
HTTPWebNode.ClientCertificate.Stream := Certificate;
ó
HTTPWebNode.ClientCertificate.FileName := xxx
// y a continuación la password:
HTTPWebNode.ClientCertificate.Password := CertPassword;
|
Pero esto implica tener el certificado en un Stream o un fichero y eso es lo que queremos evitar, queremos que sea uno de los válidos que nos entrega la AEAT en el OnNeedClientCertificate.
Quizás hay alguna forma de exportar desde el Almacén de certificados de Windows hacia un Stream y así asignarlo directamente al HTTPWebNode.ClientCertificate.Stream y después la Password.
¿Alguien de aquí escoge el certificado desde el almacén o todos lo cargais desde un fichero?