All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.bouncycastle.oer.its.etsi102941.InnerAtRequest Maven / Gradle / Ivy

Go to download

The Bouncy Castle Java APIs for ASN.1 extension and utility APIs used to support bcpkix and bctls with the BC FIPS provider. The APIs may also be used with other providers although if being used in a FIPS context it is the responsibility of the user to ensure that any other providers used are FIPS certified and used appropriately.

There is a newer version: 2.0.3
Show newest version
package org.bouncycastle.oer.its.etsi102941;

import org.bouncycastle.asn1.ASN1Encodable;
import org.bouncycastle.asn1.ASN1Object;
import org.bouncycastle.asn1.ASN1OctetString;
import org.bouncycastle.asn1.ASN1Primitive;
import org.bouncycastle.asn1.ASN1Sequence;
import org.bouncycastle.asn1.DEROctetString;
import org.bouncycastle.asn1.DERSequence;
import org.bouncycastle.oer.its.etsi102941.basetypes.EcSignature;
import org.bouncycastle.oer.its.etsi102941.basetypes.PublicKeys;
import org.bouncycastle.util.Arrays;

/**
 * InnerAtRequest ::= SEQUENCE {
 * publicKeys                    PublicKeys,
 * hmacKey                       OCTET STRING (SIZE(32)),
 * sharedAtRequest               SharedAtRequest,
 * ecSignature                   EcSignature,
 * ...
 * }
 */
public class InnerAtRequest
    extends ASN1Object
{

    private final PublicKeys publicKeys;
    private final ASN1OctetString hmacKey;
    private final SharedAtRequest sharedAtRequest;
    private final EcSignature ecSignature;

    public InnerAtRequest(
        PublicKeys publicKeys,
        ASN1OctetString hmacKey,
        SharedAtRequest sharedAtRequest,
        EcSignature ecSignature)
    {
        this.publicKeys = publicKeys;
        this.hmacKey = hmacKey;
        this.sharedAtRequest = sharedAtRequest;
        this.ecSignature = ecSignature;
    }

    private InnerAtRequest(ASN1Sequence seq)
    {
        if (seq.size() != 4)
        {
            throw new IllegalArgumentException("expected sequence size of 4");
        }

        publicKeys = PublicKeys.getInstance(seq.getObjectAt(0));
        hmacKey = ASN1OctetString.getInstance(seq.getObjectAt(1));
        sharedAtRequest = SharedAtRequest.getInstance(seq.getObjectAt(2));
        ecSignature = EcSignature.getInstance(seq.getObjectAt(3));

    }

    public static InnerAtRequest getInstance(Object o)
    {
        if (o instanceof InnerAtRequest)
        {
            return (InnerAtRequest)o;
        }

        if (o != null)
        {
            return new InnerAtRequest(ASN1Sequence.getInstance(o));
        }

        return null;
    }

    public PublicKeys getPublicKeys()
    {
        return publicKeys;
    }

    public ASN1OctetString getHmacKey()
    {
        return hmacKey;
    }

    public SharedAtRequest getSharedAtRequest()
    {
        return sharedAtRequest;
    }

    public EcSignature getEcSignature()
    {
        return ecSignature;
    }

    public ASN1Primitive toASN1Primitive()
    {
        return new DERSequence(new ASN1Encodable[]{publicKeys, hmacKey, sharedAtRequest, ecSignature});
    }

    public static Builder builder()
    {
        return new Builder();
    }

    public static class Builder
    {
        private PublicKeys publicKeys;
        private ASN1OctetString hmacKey;
        private SharedAtRequest sharedAtRequest;
        private EcSignature ecSignature;

        public Builder setPublicKeys(PublicKeys publicKeys)
        {
            this.publicKeys = publicKeys;
            return this;
        }

        public Builder setHmacKey(ASN1OctetString hmacKey)
        {
            this.hmacKey = hmacKey;
            return this;
        }

        public Builder setHmacKey(byte[] hmacKey)
        {
            this.hmacKey = new DEROctetString(Arrays.clone(hmacKey));
            return this;
        }

        public Builder setSharedAtRequest(SharedAtRequest sharedAtRequest)
        {
            this.sharedAtRequest = sharedAtRequest;
            return this;
        }

        public Builder setEcSignature(EcSignature ecSignature)
        {
            this.ecSignature = ecSignature;
            return this;
        }

        public InnerAtRequest createInnerAtRequest()
        {
            return new InnerAtRequest(publicKeys, hmacKey, sharedAtRequest, ecSignature);
        }
    }

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy