// 
// Decompiled by Procyon v0.6.0
// 

package org.bouncycastle.oer.its.etsi102941;

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

public class InnerAtRequest extends ASN1Object
{
    private final PublicKeys publicKeys;
    private final ASN1OctetString hmacKey;
    private final SharedAtRequest sharedAtRequest;
    private final EcSignature ecSignature;
    
    public InnerAtRequest(final PublicKeys publicKeys, final ASN1OctetString hmacKey, final SharedAtRequest sharedAtRequest, final EcSignature ecSignature) {
        this.publicKeys = publicKeys;
        this.hmacKey = hmacKey;
        this.sharedAtRequest = sharedAtRequest;
        this.ecSignature = ecSignature;
    }
    
    private InnerAtRequest(final ASN1Sequence asn1Sequence) {
        if (asn1Sequence.size() != 4) {
            throw new IllegalArgumentException("expected sequence size of 4");
        }
        this.publicKeys = PublicKeys.getInstance(asn1Sequence.getObjectAt(0));
        this.hmacKey = ASN1OctetString.getInstance(asn1Sequence.getObjectAt(1));
        this.sharedAtRequest = SharedAtRequest.getInstance(asn1Sequence.getObjectAt(2));
        this.ecSignature = EcSignature.getInstance(asn1Sequence.getObjectAt(3));
    }
    
    public static InnerAtRequest getInstance(final Object o) {
        if (o instanceof InnerAtRequest) {
            return (InnerAtRequest)o;
        }
        if (o != null) {
            return new InnerAtRequest(ASN1Sequence.getInstance(o));
        }
        return null;
    }
    
    public PublicKeys getPublicKeys() {
        return this.publicKeys;
    }
    
    public ASN1OctetString getHmacKey() {
        return this.hmacKey;
    }
    
    public SharedAtRequest getSharedAtRequest() {
        return this.sharedAtRequest;
    }
    
    public EcSignature getEcSignature() {
        return this.ecSignature;
    }
    
    @Override
    public ASN1Primitive toASN1Primitive() {
        return new DERSequence(new ASN1Encodable[] { this.publicKeys, this.hmacKey, this.sharedAtRequest, this.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(final PublicKeys publicKeys) {
            this.publicKeys = publicKeys;
            return this;
        }
        
        public Builder setHmacKey(final ASN1OctetString hmacKey) {
            this.hmacKey = hmacKey;
            return this;
        }
        
        public Builder setHmacKey(final byte[] array) {
            this.hmacKey = new DEROctetString(Arrays.clone(array));
            return this;
        }
        
        public Builder setSharedAtRequest(final SharedAtRequest sharedAtRequest) {
            this.sharedAtRequest = sharedAtRequest;
            return this;
        }
        
        public Builder setEcSignature(final EcSignature ecSignature) {
            this.ecSignature = ecSignature;
            return this;
        }
        
        public InnerAtRequest createInnerAtRequest() {
            return new InnerAtRequest(this.publicKeys, this.hmacKey, this.sharedAtRequest, this.ecSignature);
        }
    }
}
