/// <summary> /// Reads data into this RR from the DNS wire format data in <paramref name="reader"/> /// </summary> /// <param name="reader">Reader in which wire format data for this RR is already buffered.</param> protected override void DeserializeRecordData(ref DnsBufferReader reader) { ushort certType = reader.ReadUShort(); if (certType > (ushort)CertificateType.IACPKIK) { throw new DnsProtocolException(DnsProtocolError.InvalidCertRecord); } m_certType = (CertificateType)certType; m_keyTag = reader.ReadUShort(); m_algorithm = reader.ReadByte(); m_certData = reader.ReadBytes(this.RecordDataLength - 5); // 5 == # of bytes we've already read (certType, keytag etc) this.EnsureDnsCert(); }
/// <summary> /// Reads data into this RR from the DNS wire format data in <paramref name="reader"/> /// </summary> /// <param name="reader">Reader in which wire format data for this RR is already buffered.</param> protected override void DeserializeRecordData(ref DnsBufferReader reader) { ushort certType = reader.ReadUShort(); if (certType > (ushort) CertificateType.IACPKIK) { throw new DnsProtocolException(DnsProtocolError.InvalidCertRecord); } m_certType = (CertificateType) certType; m_keyTag = reader.ReadUShort(); m_algorithm = reader.ReadByte(); m_certData = reader.ReadBytes(this.RecordDataLength - 5); // 5 == # of bytes we've already read (certType, keytag etc) this.EnsureDnsCert(); }