DFVA client for python.
Project description
dfva cliente para python
Este cliente permite comunicarse con DFVA para proveer servicios de firma digital para Costa Rica a institutiones.
Instalación y configuración
Instale mediante pypi:
pip install dfva-python
También se puede instalar utilizando el código fuente
git clone https://github.com/luisza/dfva_python.git
cd dfva_python
python setup.py install
Adicionalmente se crea un archivo de configuración en $HOME/.dfva_python/client.conf donde se ingresan los datos de la institución, una buena forma de crear este archivo es:
python
>>> from dfva_python.settings import Settings
>>> settings=Settings()
# a este punto ya se ha creado el archivo de configuración,
#pero puede ser de utilidad modificar las propiedades de la
# institución así
>>> settings.PRIVATE_KEY=''
>>> settings.SERVER_PUBLIC_KEY=''
>>> settings.PUBLIC_CERTIFICATE=''
>>> settings.CODE=''
>>> settings.URL_NOTIFY='N/D'
>>> settings.save()
Modo de uso
Este cliente permite:
Autenticar personas y verificar estado de autenticación
Firmar documento xml, odf, ms office y verificar estado de firma durante el tiempo que el usuario está firmando
Validar un certificado emitido con la CA nacional de Costa Rica provista por el BCCR
Validar un documento XML firmado.
Revisar si un suscriptor está conectado.
Ejemplo de uso
Nota: notificationURL debe estar registrado en dfva o ser N/D en clientes no web
Si se desea autenticar y revisar estado de la autenticación
from dfva_python.client import Client
client = Client()
auth_resp = client.authenticate('04-0212-0119')
print(auth_resp)
client.authenticate_check(auth_resp['id_transaction'])
# eliminando la peticion
client.authenticate_delete(auth_resp['id_transaction'])
Si se desea revisar si un suscriptor está conectado
client.is_suscriptor_connected('04-0777-08888')
Si se desea firmar y revisar estado de la firma.
DOCUMENT = '''IyEvYmluL2Jhc2gKCk5PRk9SQ0U9dHJ1ZQpBUFRfQ0FDSEU9IiIKCndoaWxlIGdldG9wdHMgY2h5
IG9wdGlvbgpkbwogY2FzZSAiJHtvcHRpb259IgogaW4KIHkpIE5PRk9SQ0U9ZmFsc2U7OwogYykg
QVBUX0NBQ0hFPXRydWU7OwogaCkgbXloZWxwCiAgICBleGl0IDAgOzsKIGVzYWMKZG9uZQoKaWYg
WyAkQVBUX0NBQ0hFIF07IHRoZW4gCiBlY2hvICJCSU5HTyIgCmZpCgo='''
sign_resp=client.sign( '04-0212-0119', DOCUMENT.encode(), "resumen ejemplo", _format='xml_cofirma')
# _format puede ser xml_cofirma, xml_contrafirma, odf, msoffice
print(sign_resp)
client.sign_check(sign_resp['id_transaction'])
# eliminando la peticion
client.sign_delete(auth_resp['id_transaction'])
Nota: La revisión de estado de la autenticación/firma no es necesaria en servicios web ya que estos son notificados por en la URL de institución proporcionado.
Si se desea validar un certificado
client.validate(DOCUMENT, 'certificate')
Si se desea validar un documento
client.validate(DOCUMENT, 'document', 'cofirma')
# cofirma, contrafirma, odf, msoffice, pdf
Running tests
Necesita instalar el gestor de pruebas
pip install nose
Ejecute el simulador de FVA BCCR y su cliente de celery
EN FVA BCCR ejecute
python manage.py runserver 8001
celery -A fva_bccr worker -l info
Puede ejecutar además celery beat para mayor exactitud, (‘’’celery -A fva_bccr worker -BE -l info’’’), aunque puede causar inestabilidad en las pruebas. También es importante acceder a http://localhost:8001/admin/constance/config/ y habilitar USE_UNITEST para que no espere el TASK_WAIT_TO_RESPONSE definido o poner un TASK_WAIT_TO_RESPONSE bajo como 1 segundo.
Por último ejecute las pruebas
nosetests -v --nocapture dfva_python.tests
Además se incluye un utilitario para generar las combinaciones de las pruebas con la finalidad de hacer más simple la codificación de los diferentes casos
from dfva_python.utils_test import build_test_document_python
build_test_document_python("TestAuthenticate")
Esto podría ser util para correr las pruebas cuando se conecta a BCCR
export REQUESTS_CA_BUNDLE=/etc/ssl/certs/ca-certificates.crt
export TEST_WITH_BCCR=True
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
File details
Details for the file dfva-python-0.0.5.tar.gz
.
File metadata
- Download URL: dfva-python-0.0.5.tar.gz
- Upload date:
- Size: 29.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: Python-urllib/3.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 077d8b349c531db536d7f43795395e2c2872c2293709dbb8bda91cede38ca320 |
|
MD5 | 228342def41d1a8fece74b0e5e7c49b4 |
|
BLAKE2b-256 | 3c9d50933b3e476bf12226dfd83a015301199bbdf33e38f0812b33152661b570 |