You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
48 lines
1.8 KiB
48 lines
1.8 KiB
# -*- coding: utf-8 -*-
|
|
|
|
import signxml
|
|
from pynfe.utils import etree
|
|
from pynfe.entidades.certificado import CertificadoA1
|
|
from pynfe.utils.flags import NAMESPACE_NFE, NAMESPACE_SIG
|
|
|
|
|
|
class Assinatura(object):
|
|
"""Classe abstrata responsavel por definir os metodos e logica das classes
|
|
de assinatura digital."""
|
|
|
|
certificado = None
|
|
senha = None
|
|
|
|
def __init__(self, certificado, senha):
|
|
self.certificado = certificado
|
|
self.senha = senha
|
|
|
|
def assinar(self, xml):
|
|
"""Efetua a assinatura da nota"""
|
|
pass
|
|
|
|
class AssinaturaA1(Assinatura):
|
|
"""Classe responsavel por efetuar a assinatura do certificado
|
|
digital no XML informado. Passar XML como string."""
|
|
|
|
def assinar(self, xml):
|
|
arquivo_cert = CertificadoA1(self.certificado)
|
|
#key, cert = arquivo_cert.separar_arquivo(self.senha)
|
|
cert = open("cert.pem").read()
|
|
key = open("key.pem", "rb").read()
|
|
|
|
begin = cert.find('-----BEGIN CERTIFICATE-----')
|
|
if begin < 0:
|
|
raise Exception('Formato de certificado inválido. Não encontrado tag inicial BEGIN.')
|
|
cert = cert[begin:]
|
|
|
|
# converte xml para bytes antes do parse
|
|
#root = etree.parse(xml).getroot() # caminho
|
|
root = etree.fromstring(xml) # string
|
|
signer = signxml.xmldsig(root, digest_algorithm="sha1")
|
|
signer.sign(method=signxml.methods.enveloped, key=key, cert=cert,
|
|
algorithm="rsa-sha1", c14n_algorithm='http://www.w3.org/TR/2001/REC-xml-c14n-20010315',
|
|
reference_uri='#NFe41150715380524000122651010000000271333611649')
|
|
#verified_data = signer.verify(require_x509=True, ca_pem_file="cert.pem")
|
|
result = etree.tostring(signer.data)
|
|
return result
|