123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129 |
- #if !BESTHTTP_DISABLE_ALTERNATE_SSL && (!UNITY_WEBGL || UNITY_EDITOR)
- #pragma warning disable
- using System;
- using BestHTTP.SecureProtocol.Org.BouncyCastle.Utilities;
- namespace BestHTTP.SecureProtocol.Org.BouncyCastle.Asn1.X509
- {
- /**
- * Target information extension for attributes certificates according to RFC
- * 3281.
- *
- * <pre>
- * SEQUENCE OF Targets
- * </pre>
- *
- */
- public class TargetInformation
- : Asn1Encodable
- {
- private readonly Asn1Sequence targets;
- /**
- * Creates an instance of a TargetInformation from the given object.
- * <p>
- * <code>obj</code> can be a TargetInformation or a {@link Asn1Sequence}</p>
- *
- * @param obj The object.
- * @return A TargetInformation instance.
- * @throws ArgumentException if the given object cannot be interpreted as TargetInformation.
- */
- public static TargetInformation GetInstance(
- object obj)
- {
- if (obj is TargetInformation)
- {
- return (TargetInformation) obj;
- }
- if (obj is Asn1Sequence)
- {
- return new TargetInformation((Asn1Sequence) obj);
- }
- throw new ArgumentException("unknown object in factory: " + BestHTTP.SecureProtocol.Org.BouncyCastle.Utilities.Platform.GetTypeName(obj), "obj");
- }
- /**
- * Constructor from a Asn1Sequence.
- *
- * @param seq The Asn1Sequence.
- * @throws ArgumentException if the sequence does not contain
- * correctly encoded Targets elements.
- */
- private TargetInformation(
- Asn1Sequence targets)
- {
- this.targets = targets;
- }
- /**
- * Returns the targets in this target information extension.
- * <p>
- * The ArrayList is cloned before it is returned.</p>
- *
- * @return Returns the targets.
- */
- public virtual Targets[] GetTargetsObjects()
- {
- Targets[] result = new Targets[targets.Count];
- for (int i = 0; i < targets.Count; ++i)
- {
- result[i] = Targets.GetInstance(targets[i]);
- }
- return result;
- }
- /**
- * Constructs a target information from a single targets element.
- * According to RFC 3281 only one targets element must be produced.
- *
- * @param targets A Targets instance.
- */
- public TargetInformation(
- Targets targets)
- {
- this.targets = new DerSequence(targets);
- }
- /**
- * According to RFC 3281 only one targets element must be produced. If
- * multiple targets are given they must be merged in
- * into one targets element.
- *
- * @param targets An array with {@link Targets}.
- */
- public TargetInformation(
- Target[] targets)
- : this(new Targets(targets))
- {
- }
- /**
- * Produce an object suitable for an Asn1OutputStream.
- *
- * Returns:
- *
- * <pre>
- * SEQUENCE OF Targets
- * </pre>
- *
- * <p>
- * According to RFC 3281 only one targets element must be produced. If
- * multiple targets are given in the constructor they are merged into one
- * targets element. If this was produced from a
- * {@link BestHTTP.SecureProtocol.Org.BouncyCastle.Asn1.Asn1Sequence} the encoding is kept.</p>
- *
- * @return an Asn1Object
- */
- public override Asn1Object ToAsn1Object()
- {
- return targets;
- }
- }
- }
- #pragma warning restore
- #endif
|