123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157 |
- #if !BESTHTTP_DISABLE_ALTERNATE_SSL && (!UNITY_WEBGL || UNITY_EDITOR)
- #pragma warning disable
- using System;
- using BestHTTP.SecureProtocol.Org.BouncyCastle.Asn1.X509;
- using BestHTTP.SecureProtocol.Org.BouncyCastle.Utilities;
- namespace BestHTTP.SecureProtocol.Org.BouncyCastle.Asn1.Ocsp
- {
- public class ResponseData
- : Asn1Encodable
- {
- private static readonly DerInteger V1 = new DerInteger(0);
- private readonly bool versionPresent;
- private readonly DerInteger version;
- private readonly ResponderID responderID;
- private readonly DerGeneralizedTime producedAt;
- private readonly Asn1Sequence responses;
- private readonly X509Extensions responseExtensions;
- public static ResponseData GetInstance(
- Asn1TaggedObject obj,
- bool explicitly)
- {
- return GetInstance(Asn1Sequence.GetInstance(obj, explicitly));
- }
- public static ResponseData GetInstance(
- object obj)
- {
- if (obj == null || obj is ResponseData)
- {
- return (ResponseData)obj;
- }
- if (obj is Asn1Sequence)
- {
- return new ResponseData((Asn1Sequence)obj);
- }
- throw new ArgumentException("unknown object in factory: " + BestHTTP.SecureProtocol.Org.BouncyCastle.Utilities.Platform.GetTypeName(obj), "obj");
- }
- public ResponseData(
- DerInteger version,
- ResponderID responderID,
- DerGeneralizedTime producedAt,
- Asn1Sequence responses,
- X509Extensions responseExtensions)
- {
- this.version = version;
- this.responderID = responderID;
- this.producedAt = producedAt;
- this.responses = responses;
- this.responseExtensions = responseExtensions;
- }
- public ResponseData(
- ResponderID responderID,
- DerGeneralizedTime producedAt,
- Asn1Sequence responses,
- X509Extensions responseExtensions)
- : this(V1, responderID, producedAt, responses, responseExtensions)
- {
- }
- private ResponseData(
- Asn1Sequence seq)
- {
- int index = 0;
- Asn1Encodable enc = seq[0];
- if (enc is Asn1TaggedObject)
- {
- Asn1TaggedObject o = (Asn1TaggedObject)enc;
- if (o.TagNo == 0)
- {
- this.versionPresent = true;
- this.version = DerInteger.GetInstance(o, true);
- index++;
- }
- else
- {
- this.version = V1;
- }
- }
- else
- {
- this.version = V1;
- }
- this.responderID = ResponderID.GetInstance(seq[index++]);
- this.producedAt = (DerGeneralizedTime)seq[index++];
- this.responses = (Asn1Sequence)seq[index++];
- if (seq.Count > index)
- {
- this.responseExtensions = X509Extensions.GetInstance(
- (Asn1TaggedObject)seq[index], true);
- }
- }
- public DerInteger Version
- {
- get { return version; }
- }
- public ResponderID ResponderID
- {
- get { return responderID; }
- }
- public DerGeneralizedTime ProducedAt
- {
- get { return producedAt; }
- }
- public Asn1Sequence Responses
- {
- get { return responses; }
- }
- public X509Extensions ResponseExtensions
- {
- get { return responseExtensions; }
- }
- /**
- * Produce an object suitable for an Asn1OutputStream.
- * <pre>
- * ResponseData ::= Sequence {
- * version [0] EXPLICIT Version DEFAULT v1,
- * responderID ResponderID,
- * producedAt GeneralizedTime,
- * responses Sequence OF SingleResponse,
- * responseExtensions [1] EXPLICIT Extensions OPTIONAL }
- * </pre>
- */
- public override Asn1Object ToAsn1Object()
- {
- Asn1EncodableVector v = new Asn1EncodableVector();
- if (versionPresent || !version.Equals(V1))
- {
- v.Add(new DerTaggedObject(true, 0, version));
- }
- v.Add(responderID, producedAt, responses);
- v.AddOptionalTagged(true, 1, responseExtensions);
- return new DerSequence(v);
- }
- }
- }
- #pragma warning restore
- #endif
|