Search in sources :

Example 1 with RSAKeyValueType

use of com.axelor.apps.account.ebics.schema.xmldsig.RSAKeyValueType in project axelor-open-suite by axelor.

the class EbicsXmlFactory method createRSAKeyValueType.

/**
 * Creates a new <code>RSAKeyValueType</code> XML object
 *
 * @param exponent the public exponent of the public key
 * @param modulus the modulus of the public key
 * @return the <code>RSAKeyValueType</code> XML object
 */
public static RSAKeyValueType createRSAKeyValueType(byte[] exponent, byte[] modulus) {
    RSAKeyValueType newRSAKeyValueType = RSAKeyValueType.Factory.newInstance();
    newRSAKeyValueType.setExponent(exponent);
    newRSAKeyValueType.setModulus(modulus);
    return newRSAKeyValueType;
}
Also used : RSAKeyValueType(com.axelor.apps.account.ebics.schema.xmldsig.RSAKeyValueType)

Example 2 with RSAKeyValueType

use of com.axelor.apps.account.ebics.schema.xmldsig.RSAKeyValueType in project axelor-open-suite by axelor.

the class HIARequestOrderDataElement method build.

@Override
public void build() {
    HIARequestOrderDataType request;
    AuthenticationPubKeyInfoType authenticationPubKeyInfo;
    EncryptionPubKeyInfoType encryptionPubKeyInfo;
    PubKeyValueType encryptionPubKeyValue;
    X509DataType encryptionX509Data = null;
    RSAKeyValueType encryptionRsaKeyValue;
    PubKeyValueType authPubKeyValue;
    X509DataType authX509Data = null;
    RSAKeyValueType authRsaKeyValue;
    EbicsCertificate certificate = session.getUser().getE002Certificate();
    encryptionX509Data = EbicsXmlFactory.createX509DataType(session.getUser().getDn(), certificate.getCertificate());
    // Include Certificate issuer and serial ?
    // encryptionX509Data = EbicsXmlFactory.createX509DataType(session.getUser().getDn(),
    // certificate.getCertificate(), certificate.getIssuer(),   new
    // BigInteger(certificate.getSerial(), 16));
    encryptionRsaKeyValue = EbicsXmlFactory.createRSAKeyValueType(new BigInteger(certificate.getPublicKeyExponent(), 16).toByteArray(), new BigInteger(certificate.getPublicKeyModulus(), 16).toByteArray());
    encryptionPubKeyValue = EbicsXmlFactory.createH003PubKeyValueType(encryptionRsaKeyValue, Calendar.getInstance());
    encryptionPubKeyInfo = EbicsXmlFactory.createEncryptionPubKeyInfoType("E002", encryptionPubKeyValue, encryptionX509Data);
    certificate = session.getUser().getX002Certificate();
    authX509Data = EbicsXmlFactory.createX509DataType(session.getUser().getDn(), certificate.getCertificate());
    // Include Certificate issuer and serial ?
    // authX509Data = EbicsXmlFactory.createX509DataType(session.getUser().getDn(),
    // certificate.getCertificate(), certificate.getIssuer(),   new
    // BigInteger(certificate.getSerial(), 16));
    authRsaKeyValue = EbicsXmlFactory.createRSAKeyValueType(new BigInteger(certificate.getPublicKeyExponent(), 16).toByteArray(), new BigInteger(certificate.getPublicKeyModulus(), 16).toByteArray());
    authPubKeyValue = EbicsXmlFactory.createH003PubKeyValueType(authRsaKeyValue, Calendar.getInstance());
    authenticationPubKeyInfo = EbicsXmlFactory.createAuthenticationPubKeyInfoType("X002", authPubKeyValue, authX509Data);
    request = EbicsXmlFactory.createHIARequestOrderDataType(authenticationPubKeyInfo, encryptionPubKeyInfo, session.getUser().getEbicsPartner().getPartnerId(), session.getUser().getUserId());
    document = EbicsXmlFactory.createHIARequestOrderDataDocument(request);
}
Also used : X509DataType(com.axelor.apps.account.ebics.schema.xmldsig.X509DataType) EbicsCertificate(com.axelor.apps.bankpayment.db.EbicsCertificate) AuthenticationPubKeyInfoType(com.axelor.apps.account.ebics.schema.h003.AuthenticationPubKeyInfoType) PubKeyValueType(com.axelor.apps.account.ebics.schema.h003.PubKeyValueType) BigInteger(java.math.BigInteger) HIARequestOrderDataType(com.axelor.apps.account.ebics.schema.h003.HIARequestOrderDataType) RSAKeyValueType(com.axelor.apps.account.ebics.schema.xmldsig.RSAKeyValueType) EncryptionPubKeyInfoType(com.axelor.apps.account.ebics.schema.h003.EncryptionPubKeyInfoType)

Example 3 with RSAKeyValueType

use of com.axelor.apps.account.ebics.schema.xmldsig.RSAKeyValueType in project axelor-open-suite by axelor.

the class SignaturePubKeyOrderDataElement method build.

@Override
public void build() throws AxelorException {
    SignaturePubKeyInfoType signaturePubKeyInfo;
    X509DataType x509Data;
    RSAKeyValueType rsaKeyValue;
    PubKeyValueType pubKeyValue;
    SignaturePubKeyOrderDataType signaturePubKeyOrderData;
    EbicsCertificate certificate = session.getUser().getA005Certificate();
    System.out.println("Certificate : " + new String(certificate.getCertificate()));
    System.out.println("Certificate size : " + certificate.getCertificate().length);
    EbicsCertificate ebicsEertificate = session.getUser().getA005Certificate();
    // Include certificate issuer and serial (certificate information)
    // x509Data = EbicsXmlFactory.createX509DataType(ebicsEertificate.getSubject(), certEncoded,
    // ebicsEertificate.getIssuer(),  new BigInteger(ebicsEertificate.getSerial(), 16));
    x509Data = EbicsXmlFactory.createX509DataType(ebicsEertificate.getSubject(), ebicsEertificate.getCertificate());
    rsaKeyValue = EbicsXmlFactory.createRSAKeyValueType(new BigInteger(ebicsEertificate.getPublicKeyExponent(), 16).toByteArray(), new BigInteger(ebicsEertificate.getPublicKeyModulus(), 16).toByteArray());
    pubKeyValue = EbicsXmlFactory.createPubKeyValueType(rsaKeyValue, Calendar.getInstance());
    signaturePubKeyInfo = EbicsXmlFactory.createSignaturePubKeyInfoType(x509Data, pubKeyValue, "A005");
    signaturePubKeyOrderData = EbicsXmlFactory.createSignaturePubKeyOrderData(signaturePubKeyInfo, session.getUser().getEbicsPartner().getPartnerId(), session.getUser().getUserId());
    document = EbicsXmlFactory.createSignaturePubKeyOrderDataDocument(signaturePubKeyOrderData);
}
Also used : X509DataType(com.axelor.apps.account.ebics.schema.xmldsig.X509DataType) EbicsCertificate(com.axelor.apps.bankpayment.db.EbicsCertificate) PubKeyValueType(com.axelor.apps.account.ebics.schema.s001.PubKeyValueType) SignaturePubKeyOrderDataType(com.axelor.apps.account.ebics.schema.s001.SignaturePubKeyOrderDataType) BigInteger(java.math.BigInteger) RSAKeyValueType(com.axelor.apps.account.ebics.schema.xmldsig.RSAKeyValueType) SignaturePubKeyInfoType(com.axelor.apps.account.ebics.schema.s001.SignaturePubKeyInfoType)

Aggregations

RSAKeyValueType (com.axelor.apps.account.ebics.schema.xmldsig.RSAKeyValueType)3 X509DataType (com.axelor.apps.account.ebics.schema.xmldsig.X509DataType)2 EbicsCertificate (com.axelor.apps.bankpayment.db.EbicsCertificate)2 BigInteger (java.math.BigInteger)2 AuthenticationPubKeyInfoType (com.axelor.apps.account.ebics.schema.h003.AuthenticationPubKeyInfoType)1 EncryptionPubKeyInfoType (com.axelor.apps.account.ebics.schema.h003.EncryptionPubKeyInfoType)1 HIARequestOrderDataType (com.axelor.apps.account.ebics.schema.h003.HIARequestOrderDataType)1 PubKeyValueType (com.axelor.apps.account.ebics.schema.h003.PubKeyValueType)1 PubKeyValueType (com.axelor.apps.account.ebics.schema.s001.PubKeyValueType)1 SignaturePubKeyInfoType (com.axelor.apps.account.ebics.schema.s001.SignaturePubKeyInfoType)1 SignaturePubKeyOrderDataType (com.axelor.apps.account.ebics.schema.s001.SignaturePubKeyOrderDataType)1