NameOrPseudonym.cs 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181
  1. #if !BESTHTTP_DISABLE_ALTERNATE_SSL && (!UNITY_WEBGL || UNITY_EDITOR)
  2. #pragma warning disable
  3. using System;
  4. using Best.HTTP.SecureProtocol.Org.BouncyCastle.Asn1.X500;
  5. using Best.HTTP.SecureProtocol.Org.BouncyCastle.Utilities;
  6. namespace Best.HTTP.SecureProtocol.Org.BouncyCastle.Asn1.X509.SigI
  7. {
  8. /**
  9. * Structure for a name or pseudonym.
  10. *
  11. * <pre>
  12. * NameOrPseudonym ::= CHOICE {
  13. * surAndGivenName SEQUENCE {
  14. * surName DirectoryString,
  15. * givenName SEQUENCE OF DirectoryString
  16. * },
  17. * pseudonym DirectoryString
  18. * }
  19. * </pre>
  20. *
  21. * @see org.bouncycastle.asn1.x509.sigi.PersonalData
  22. *
  23. */
  24. public class NameOrPseudonym
  25. : Asn1Encodable, IAsn1Choice
  26. {
  27. private readonly DirectoryString pseudonym;
  28. private readonly DirectoryString surname;
  29. private readonly Asn1Sequence givenName;
  30. public static NameOrPseudonym GetInstance(
  31. object obj)
  32. {
  33. if (obj == null || obj is NameOrPseudonym)
  34. {
  35. return (NameOrPseudonym)obj;
  36. }
  37. if (obj is IAsn1String)
  38. {
  39. return new NameOrPseudonym(DirectoryString.GetInstance(obj));
  40. }
  41. if (obj is Asn1Sequence)
  42. {
  43. return new NameOrPseudonym((Asn1Sequence) obj);
  44. }
  45. throw new ArgumentException("unknown object in factory: " + Org.BouncyCastle.Utilities.Platform.GetTypeName(obj), "obj");
  46. }
  47. /**
  48. * Constructor from DERString.
  49. * <p/>
  50. * The sequence is of type NameOrPseudonym:
  51. * <p/>
  52. * <pre>
  53. * NameOrPseudonym ::= CHOICE {
  54. * surAndGivenName SEQUENCE {
  55. * surName DirectoryString,
  56. * givenName SEQUENCE OF DirectoryString
  57. * },
  58. * pseudonym DirectoryString
  59. * }
  60. * </pre>
  61. * @param pseudonym pseudonym value to use.
  62. */
  63. public NameOrPseudonym(
  64. DirectoryString pseudonym)
  65. {
  66. this.pseudonym = pseudonym;
  67. }
  68. /**
  69. * Constructor from Asn1Sequence.
  70. * <p/>
  71. * The sequence is of type NameOrPseudonym:
  72. * <p/>
  73. * <pre>
  74. * NameOrPseudonym ::= CHOICE {
  75. * surAndGivenName SEQUENCE {
  76. * surName DirectoryString,
  77. * givenName SEQUENCE OF DirectoryString
  78. * },
  79. * pseudonym DirectoryString
  80. * }
  81. * </pre>
  82. *
  83. * @param seq The ASN.1 sequence.
  84. */
  85. private NameOrPseudonym(
  86. Asn1Sequence seq)
  87. {
  88. if (seq.Count != 2)
  89. throw new ArgumentException("Bad sequence size: " + seq.Count);
  90. if (!(seq[0] is IAsn1String))
  91. throw new ArgumentException("Bad object encountered: " + Org.BouncyCastle.Utilities.Platform.GetTypeName(seq[0]));
  92. surname = DirectoryString.GetInstance(seq[0]);
  93. givenName = Asn1Sequence.GetInstance(seq[1]);
  94. }
  95. /**
  96. * Constructor from a given details.
  97. *
  98. * @param pseudonym The pseudonym.
  99. */
  100. public NameOrPseudonym(
  101. string pseudonym)
  102. : this(new DirectoryString(pseudonym))
  103. {
  104. }
  105. /**
  106. * Constructor from a given details.
  107. *
  108. * @param surname The surname.
  109. * @param givenName A sequence of directory strings making up the givenName
  110. */
  111. public NameOrPseudonym(
  112. DirectoryString surname,
  113. Asn1Sequence givenName)
  114. {
  115. this.surname = surname;
  116. this.givenName = givenName;
  117. }
  118. public DirectoryString Pseudonym
  119. {
  120. get { return pseudonym; }
  121. }
  122. public DirectoryString Surname
  123. {
  124. get { return surname; }
  125. }
  126. public DirectoryString[] GetGivenName()
  127. {
  128. DirectoryString[] items = new DirectoryString[givenName.Count];
  129. int count = 0;
  130. foreach (object o in givenName)
  131. {
  132. items[count++] = DirectoryString.GetInstance(o);
  133. }
  134. return items;
  135. }
  136. /**
  137. * Produce an object suitable for an Asn1OutputStream.
  138. * <p/>
  139. * Returns:
  140. * <p/>
  141. * <pre>
  142. * NameOrPseudonym ::= CHOICE {
  143. * surAndGivenName SEQUENCE {
  144. * surName DirectoryString,
  145. * givenName SEQUENCE OF DirectoryString
  146. * },
  147. * pseudonym DirectoryString
  148. * }
  149. * </pre>
  150. *
  151. * @return an Asn1Object
  152. */
  153. public override Asn1Object ToAsn1Object()
  154. {
  155. if (pseudonym != null)
  156. {
  157. return pseudonym.ToAsn1Object();
  158. }
  159. return new DerSequence(surname, givenName);
  160. }
  161. }
  162. }
  163. #pragma warning restore
  164. #endif