Class: Rex::Proto::Kerberos::Model::PreAuthDataEntry
- Defined in:
- lib/rex/proto/kerberos/model/pre_auth_data_entry.rb
Overview
This class provides a representation for Kerberos pre authenticated data entry.
Constant Summary
Constants included from Rex::Proto::Kerberos::Model
AP_REP, AP_REQ, AS_REP, AS_REQ, AUTHENTICATOR, ENC_KRB_CRED_PART, KRB_CRED, KRB_ERROR, TGS_REP, TGS_REQ, TICKET, VERSION
Instance Attribute Summary collapse
-
#type ⇒ Integer
The padata type.
-
#value ⇒ String
The padata value, encoded.
Instance Method Summary collapse
-
#decode(input) ⇒ self
Decodes a Rex::Proto::Kerberos::Model::PreAuthDataEntry.
-
#decoded_value ⇒ Object
Gets the value of this PreAuthDataEntry as its instantiated object, based on the type.
-
#encode ⇒ String
Encodes a Rex::Proto::Kerberos::Model::PreAuthDataEntry into an ASN.1 String.
Methods inherited from Element
attr_accessor, attributes, #attributes, decode, #initialize
Constructor Details
This class inherits a constructor from Rex::Proto::Kerberos::Model::Element
Instance Attribute Details
#type ⇒ Integer
Returns The padata type.
13 14 15 |
# File 'lib/rex/proto/kerberos/model/pre_auth_data_entry.rb', line 13 def type @type end |
#value ⇒ String
Returns The padata value, encoded.
16 17 18 |
# File 'lib/rex/proto/kerberos/model/pre_auth_data_entry.rb', line 16 def value @value end |
Instance Method Details
#decode(input) ⇒ self
Decodes a Rex::Proto::Kerberos::Model::PreAuthDataEntry
23 24 25 26 27 28 29 30 31 32 33 34 35 36 |
# File 'lib/rex/proto/kerberos/model/pre_auth_data_entry.rb', line 23 def decode(input) case input when String decode_string(input) when OpenSSL::ASN1::ASN1Data decode_asn1(input) when OpenSSL::ASN1::Sequence decode_asn1(input) else raise ::Rex::Proto::Kerberos::Model::Error::KerberosDecodingError, 'Failed to decode PreAuthDataEntry, invalid input' end self end |
#decoded_value ⇒ Object
Gets the value of this PreAuthDataEntry as its instantiated object, based on the type
53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 |
# File 'lib/rex/proto/kerberos/model/pre_auth_data_entry.rb', line 53 def decoded_value case self.type when Rex::Proto::Kerberos::Model::PreAuthType::PA_TGS_REQ decoded = OpenSSL::ASN1.decode(self.value) ApReq.decode(decoded) when Rex::Proto::Kerberos::Model::PreAuthType::PA_ENC_TIMESTAMP decoded = OpenSSL::ASN1.decode(self.value) PreAuthEncTimeStamp.decode(decoded) when Rex::Proto::Kerberos::Model::PreAuthType::PA_PW_SALT # This is not DER_encoded - just pass the string directly PreAuthPwSalt.decode(self.value) when Rex::Proto::Kerberos::Model::PreAuthType::PA_ETYPE_INFO # Not yet supported when Rex::Proto::Kerberos::Model::PreAuthType::PA_PK_AS_REQ PreAuthPkAsReq.decode(self.value) when Rex::Proto::Kerberos::Model::PreAuthType::PA_PK_AS_REP PreAuthPkAsRep.decode(self.value) when Rex::Proto::Kerberos::Model::PreAuthType::PA_ETYPE_INFO2 decoded = OpenSSL::ASN1.decode(self.value) PreAuthEtypeInfo2.decode(decoded) when Rex::Proto::Kerberos::Model::PreAuthType::PA_PAC_REQUEST decoded = OpenSSL::ASN1.decode(self.value) PreAuthPacRequest.decode(decoded) when Rex::Proto::Kerberos::Model::PreAuthType::PA_FOR_USER decoded = OpenSSL::ASN1.decode(self.value) PreAuthForUser.decode(decoded) else # Unknown type - just ignore for now end end |
#encode ⇒ String
Encodes a Rex::Proto::Kerberos::Model::PreAuthDataEntry into an ASN.1 String
41 42 43 44 45 46 47 |
# File 'lib/rex/proto/kerberos/model/pre_auth_data_entry.rb', line 41 def encode type_asn1 = OpenSSL::ASN1::ASN1Data.new([encode_type], 1, :CONTEXT_SPECIFIC) value_asn1 = OpenSSL::ASN1::ASN1Data.new([encode_value], 2, :CONTEXT_SPECIFIC) seq = OpenSSL::ASN1::Sequence.new([type_asn1, value_asn1]) seq.to_der end |