package org.apache.kerberos.kerb.spec.ap;
import org.apache.haox.asn1.type.Asn1FieldInfo;
import org.apache.haox.asn1.type.Asn1Integer;
import org.apache.kerberos.kerb.spec.KerberosString;
import org.apache.kerberos.kerb.spec.KerberosTime;
import org.apache.kerberos.kerb.spec.KrbAppSequenceType;
import org.apache.kerberos.kerb.spec.common.AuthorizationData;
import org.apache.kerberos.kerb.spec.common.CheckSum;
import org.apache.kerberos.kerb.spec.common.EncryptionKey;
import org.apache.kerberos.kerb.spec.common.PrincipalName;
/**
Authenticator ::= [APPLICATION 2] SEQUENCE {
authenticator-vno [0] INTEGER (5),
crealm [1] Realm,
cname [2] PrincipalName,
cksum [3] Checksum OPTIONAL,
cusec [4] Microseconds,
ctime [5] KerberosTime,
subkey [6] EncryptionKey OPTIONAL,
seq-number [7] UInt32 OPTIONAL,
authorization-data [8] AuthorizationData OPTIONAL
}
*/
public class Authenticator extends KrbAppSequenceType {
public static int TAG = 2;
private static int AUTHENTICATOR_VNO = 0;
private static int CREALM = 1;
private static int CNAME = 2;
private static int CKSUM = 3;
private static int CUSEC = 4;
private static int CTIME = 5;
private static int SUBKEY = 6;
private static int SEQ_NUMBER = 7;
private static int AUTHORIZATION_DATA = 8;
static Asn1FieldInfo[] fieldInfos = new Asn1FieldInfo[] {
new Asn1FieldInfo(AUTHENTICATOR_VNO, 0, Asn1Integer.class),
new Asn1FieldInfo(CREALM, 1, KerberosString.class),
new Asn1FieldInfo(CNAME, 2, PrincipalName.class),
new Asn1FieldInfo(CKSUM, 3, CheckSum.class),
new Asn1FieldInfo(CUSEC, 4, Asn1Integer.class),
new Asn1FieldInfo(CTIME, 5, KerberosTime.class),
new Asn1FieldInfo(SUBKEY, 6, EncryptionKey.class),
new Asn1FieldInfo(SEQ_NUMBER, 7, Asn1Integer.class),
new Asn1FieldInfo(AUTHORIZATION_DATA, 8, AuthorizationData.class)
};
public Authenticator() {
super(TAG, fieldInfos);
}
public int getAuthenticatorVno() {
return getFieldAsInt(AUTHENTICATOR_VNO);
}
public void setAuthenticatorVno(int authenticatorVno) {
setFieldAsInt(AUTHENTICATOR_VNO, authenticatorVno);
}
public String getCrealm() {
return getFieldAsString(CREALM);
}
public void setCrealm(String crealm) {
setFieldAsString(CREALM, crealm);
}
public PrincipalName getCname() {
return getFieldAs(CNAME, PrincipalName.class);
}
public void setCname(PrincipalName cname) {
setFieldAs(CNAME, cname);
}
public CheckSum getCksum() {
return getFieldAs(CKSUM, CheckSum.class);
}
public void setCksum(CheckSum cksum) {
setFieldAs(CKSUM, cksum);
}
public int getCusec() {
return getFieldAsInt(CUSEC);
}
public void setCusec(int cusec) {
setFieldAsInt(CUSEC, cusec);
}
public KerberosTime getCtime() {
return getFieldAsTime(CTIME);
}
public void setCtime(KerberosTime ctime) {
setFieldAs(CTIME, ctime);
}
public EncryptionKey getSubKey() {
return getFieldAs(SUBKEY, EncryptionKey.class);
}
public void setSubKey(EncryptionKey subKey) {
setFieldAs(SUBKEY, subKey);
}
public int getSeqNumber() {
return getFieldAsInt(SEQ_NUMBER);
}
public void setSeqNumber(Integer seqNumber) {
setFieldAsInt(SEQ_NUMBER, seqNumber);
}
public AuthorizationData getAuthorizationData() {
return getFieldAs(AUTHORIZATION_DATA, AuthorizationData.class);
}
public void setAuthorizationData(AuthorizationData authorizationData) {
setFieldAs(AUTHORIZATION_DATA, authorizationData);
}
}