123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114 |
- #if !BESTHTTP_DISABLE_ALTERNATE_SSL && (!UNITY_WEBGL || UNITY_EDITOR)
- using System;
- using System.Text;
- using Org.BouncyCastle.Utilities;
- namespace Org.BouncyCastle.Asn1
- {
-
- public class DerVisibleString
- : DerStringBase
- {
- private readonly string str;
-
- public static DerVisibleString GetInstance(
- object obj)
- {
- if (obj == null || obj is DerVisibleString)
- {
- return (DerVisibleString)obj;
- }
- if (obj is Asn1OctetString)
- {
- return new DerVisibleString(((Asn1OctetString)obj).GetOctets());
- }
- if (obj is Asn1TaggedObject)
- {
- return GetInstance(((Asn1TaggedObject)obj).GetObject());
- }
- throw new ArgumentException("illegal object in GetInstance: " + Org.BouncyCastle.Utilities.Platform.GetTypeName(obj));
- }
-
- public static DerVisibleString GetInstance(
- Asn1TaggedObject obj,
- bool explicitly)
- {
- return GetInstance(obj.GetObject());
- }
-
- public DerVisibleString(
- byte[] str)
- : this(Strings.FromAsciiByteArray(str))
- {
- }
-
- public DerVisibleString(
- string str)
- {
- if (str == null)
- throw new ArgumentNullException("str");
- this.str = str;
- }
- public override string GetString()
- {
- return str;
- }
- public byte[] GetOctets()
- {
- return Strings.ToAsciiByteArray(str);
- }
- internal override void Encode(
- DerOutputStream derOut)
- {
- derOut.WriteEncoded(Asn1Tags.VisibleString, GetOctets());
- }
- protected override bool Asn1Equals(
- Asn1Object asn1Object)
- {
- DerVisibleString other = asn1Object as DerVisibleString;
- if (other == null)
- return false;
- return this.str.Equals(other.str);
- }
- protected override int Asn1GetHashCode()
- {
- return this.str.GetHashCode();
- }
- }
- }
- #endif
|