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

package org.bouncycastle.oer.its.etsi102941;

import org.bouncycastle.asn1.DEROctetString;
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.CertificateSubjectAttributes;
import org.bouncycastle.oer.its.etsi102941.basetypes.CertificateFormat;
import org.bouncycastle.asn1.ASN1OctetString;
import org.bouncycastle.oer.its.ieee1609dot2.basetypes.HashedId8;
import org.bouncycastle.asn1.ASN1Object;

public class SharedAtRequest extends ASN1Object
{
    private final HashedId8 eaId;
    private final ASN1OctetString keyTag;
    private final CertificateFormat certificateFormat;
    private final CertificateSubjectAttributes requestedSubjectAttributes;
    
    public SharedAtRequest(final HashedId8 eaId, final ASN1OctetString keyTag, final CertificateFormat certificateFormat, final CertificateSubjectAttributes requestedSubjectAttributes) {
        this.eaId = eaId;
        this.keyTag = keyTag;
        this.certificateFormat = certificateFormat;
        this.requestedSubjectAttributes = requestedSubjectAttributes;
    }
    
    private SharedAtRequest(final ASN1Sequence asn1Sequence) {
        if (asn1Sequence.size() != 4) {
            throw new IllegalArgumentException("expected sequence size of 4");
        }
        this.eaId = HashedId8.getInstance(asn1Sequence.getObjectAt(0));
        this.keyTag = ASN1OctetString.getInstance(asn1Sequence.getObjectAt(1));
        this.certificateFormat = CertificateFormat.getInstance(asn1Sequence.getObjectAt(2));
        this.requestedSubjectAttributes = CertificateSubjectAttributes.getInstance(asn1Sequence.getObjectAt(3));
    }
    
    public static SharedAtRequest getInstance(final Object o) {
        if (o instanceof SharedAtRequest) {
            return (SharedAtRequest)o;
        }
        if (o != null) {
            return new SharedAtRequest(ASN1Sequence.getInstance(o));
        }
        return null;
    }
    
    public HashedId8 getEaId() {
        return this.eaId;
    }
    
    public ASN1OctetString getKeyTag() {
        return this.keyTag;
    }
    
    public CertificateFormat getCertificateFormat() {
        return this.certificateFormat;
    }
    
    public CertificateSubjectAttributes getRequestedSubjectAttributes() {
        return this.requestedSubjectAttributes;
    }
    
    @Override
    public ASN1Primitive toASN1Primitive() {
        return new DERSequence(new ASN1Encodable[] { this.eaId, this.keyTag, this.certificateFormat, this.requestedSubjectAttributes });
    }
    
    public static Builder builder() {
        return new Builder();
    }
    
    public static class Builder
    {
        private HashedId8 eaId;
        private ASN1OctetString keyTag;
        private CertificateFormat certificateFormat;
        private CertificateSubjectAttributes requestedSubjectAttributes;
        
        public Builder setEaId(final HashedId8 eaId) {
            this.eaId = eaId;
            return this;
        }
        
        public Builder setKeyTag(final ASN1OctetString keyTag) {
            this.keyTag = keyTag;
            return this;
        }
        
        public Builder setKeyTag(final byte[] array) {
            this.keyTag = new DEROctetString(array);
            return this;
        }
        
        public Builder setCertificateFormat(final CertificateFormat certificateFormat) {
            this.certificateFormat = certificateFormat;
            return this;
        }
        
        public Builder setRequestedSubjectAttributes(final CertificateSubjectAttributes requestedSubjectAttributes) {
            this.requestedSubjectAttributes = requestedSubjectAttributes;
            return this;
        }
        
        public SharedAtRequest createSharedAtRequest() {
            return new SharedAtRequest(this.eaId, this.keyTag, this.certificateFormat, this.requestedSubjectAttributes);
        }
    }
}
