summary refs log tree commit diff
diff options
context:
space:
mode:
authorPeter Dettman <peter.dettman@bouncycastle.org>2024-07-01 22:18:00 +0700
committerPeter Dettman <peter.dettman@bouncycastle.org>2024-07-01 22:18:00 +0700
commit4e2bffacaddd47ffb9926dfc28f1e9725c9c929c (patch)
treee822d81703145f2a05029008f679751407caf9c5
parentMark public sequence constructor Obsolete (diff)
downloadBouncyCastle.NET-ed25519-master.tar.xz
Refactoring in Asn1.X509.SigI HEAD master
-rw-r--r--crypto/src/asn1/x509/qualified/ETSIQCObjectIdentifiers.cs22
-rw-r--r--crypto/src/asn1/x509/sigi/NameOrPseudonym.cs10
-rw-r--r--crypto/src/asn1/x509/sigi/PersonalData.cs175
-rw-r--r--crypto/src/asn1/x509/sigi/SigIObjectIdentifiers.cs19
4 files changed, 87 insertions, 139 deletions
diff --git a/crypto/src/asn1/x509/qualified/ETSIQCObjectIdentifiers.cs b/crypto/src/asn1/x509/qualified/ETSIQCObjectIdentifiers.cs
index c55bfd303..f16b8684e 100644
--- a/crypto/src/asn1/x509/qualified/ETSIQCObjectIdentifiers.cs
+++ b/crypto/src/asn1/x509/qualified/ETSIQCObjectIdentifiers.cs
@@ -1,20 +1,16 @@
-using System;
-
-using Org.BouncyCastle.Asn1;
-
 namespace Org.BouncyCastle.Asn1.X509.Qualified
 {
     // TODO[api] Make static
     public abstract class EtsiQCObjectIdentifiers
 	{
-		//
-		// base id
-		//
-		public static readonly DerObjectIdentifier IdEtsiQcs                 = new DerObjectIdentifier("0.4.0.1862.1");
+        //
+        // base id
+        //
+        public static readonly DerObjectIdentifier IdEtsiQcs = new DerObjectIdentifier("0.4.0.1862.1");
 
-		public static readonly DerObjectIdentifier IdEtsiQcsQcCompliance     = new DerObjectIdentifier(IdEtsiQcs+".1");
-		public static readonly DerObjectIdentifier IdEtsiQcsLimitValue       = new DerObjectIdentifier(IdEtsiQcs+".2");
-		public static readonly DerObjectIdentifier IdEtsiQcsRetentionPeriod  = new DerObjectIdentifier(IdEtsiQcs+".3");
-		public static readonly DerObjectIdentifier IdEtsiQcsQcSscd           = new DerObjectIdentifier(IdEtsiQcs+".4");
-	}
+        public static readonly DerObjectIdentifier IdEtsiQcsQcCompliance = IdEtsiQcs.Branch("1");
+        public static readonly DerObjectIdentifier IdEtsiQcsLimitValue = IdEtsiQcs.Branch("2");
+        public static readonly DerObjectIdentifier IdEtsiQcsRetentionPeriod = IdEtsiQcs.Branch("3");
+        public static readonly DerObjectIdentifier IdEtsiQcsQcSscd = IdEtsiQcs.Branch("4");
+    }
 }
diff --git a/crypto/src/asn1/x509/sigi/NameOrPseudonym.cs b/crypto/src/asn1/x509/sigi/NameOrPseudonym.cs
index c801002d1..7cf2f50f5 100644
--- a/crypto/src/asn1/x509/sigi/NameOrPseudonym.cs
+++ b/crypto/src/asn1/x509/sigi/NameOrPseudonym.cs
@@ -49,7 +49,13 @@ namespace Org.BouncyCastle.Asn1.X509.SigI
             throw new ArgumentException("unknown object in factory: " + Platform.GetTypeName(obj), "obj");
 		}
 
-		/**
+        public static NameOrPseudonym GetInstance(Asn1TaggedObject taggedObject, bool declaredExplicit) =>
+            Asn1Utilities.GetInstanceChoice(taggedObject, declaredExplicit, GetInstance);
+
+        public static NameOrPseudonym GetTagged(Asn1TaggedObject taggedObject, bool declaredExplicit) =>
+            Asn1Utilities.GetTaggedChoice(taggedObject, declaredExplicit, GetInstance);
+
+        /**
 		* Constructor from DERString.
 		* <p/>
 		* The sequence is of type NameOrPseudonym:
@@ -65,7 +71,7 @@ namespace Org.BouncyCastle.Asn1.X509.SigI
 		* </pre>
 		* @param pseudonym pseudonym value to use.
 		*/
-		public NameOrPseudonym(
+        public NameOrPseudonym(
 			DirectoryString pseudonym)
 		{
 			this.pseudonym = pseudonym;
diff --git a/crypto/src/asn1/x509/sigi/PersonalData.cs b/crypto/src/asn1/x509/sigi/PersonalData.cs
index e8c75bf93..70a22ada0 100644
--- a/crypto/src/asn1/x509/sigi/PersonalData.cs
+++ b/crypto/src/asn1/x509/sigi/PersonalData.cs
@@ -2,11 +2,10 @@ using System;
 
 using Org.BouncyCastle.Asn1.X500;
 using Org.BouncyCastle.Math;
-using Org.BouncyCastle.Utilities;
 
 namespace Org.BouncyCastle.Asn1.X509.SigI
 {
-	/**
+    /**
 	* Contains personal data for the otherName field in the subjectAltNames
 	* extension.
 	* <p/>
@@ -24,31 +23,30 @@ namespace Org.BouncyCastle.Asn1.X509.SigI
 	* @see org.bouncycastle.asn1.x509.sigi.NameOrPseudonym
 	* @see org.bouncycastle.asn1.x509.sigi.SigIObjectIdentifiers
 	*/
-	public class PersonalData
+    public class PersonalData
 		: Asn1Encodable
 	{
-		private readonly NameOrPseudonym	nameOrPseudonym;
-		private readonly BigInteger			nameDistinguisher;
-		private readonly Asn1GeneralizedTime dateOfBirth;
-		private readonly DirectoryString	placeOfBirth;
-		private readonly string				gender;
-		private readonly DirectoryString	postalAddress;
-
-		public static PersonalData GetInstance(
-			object obj)
-		{
-			if (obj == null || obj is PersonalData)
-			{
-				return (PersonalData) obj;
-			}
+        public static PersonalData GetInstance(object obj)
+        {
+            if (obj == null)
+                return null;
+            if (obj is PersonalData personalData)
+                return personalData;
+            return new PersonalData(Asn1Sequence.GetInstance(obj));
+        }
 
-			if (obj is Asn1Sequence)
-			{
-				return new PersonalData((Asn1Sequence) obj);
-			}
+        public static PersonalData GetInstance(Asn1TaggedObject taggedObject, bool declaredExplicit) =>
+            new PersonalData(Asn1Sequence.GetInstance(taggedObject, declaredExplicit));
 
-            throw new ArgumentException("unknown object in factory: " + Platform.GetTypeName(obj), "obj");
-		}
+        public static PersonalData GetTagged(Asn1TaggedObject taggedObject, bool declaredExplicit) =>
+            new PersonalData(Asn1Sequence.GetTagged(taggedObject, declaredExplicit));
+
+        private readonly NameOrPseudonym m_nameOrPseudonym;
+        private readonly DerInteger m_nameDistinguisher;
+        private readonly Asn1GeneralizedTime m_dateOfBirth;
+        private readonly DirectoryString m_placeOfBirth;
+        private readonly DerPrintableString m_gender;
+        private readonly DirectoryString m_postalAddress;
 
 		/**
 		* Constructor from Asn1Sequence.
@@ -70,42 +68,22 @@ namespace Org.BouncyCastle.Asn1.X509.SigI
 		*/
 		private PersonalData(Asn1Sequence seq)
 		{
-			if (seq.Count < 1)
-				throw new ArgumentException("Bad sequence size: " + seq.Count);
-
-			var e = seq.GetEnumerator();
-			e.MoveNext();
-
-			nameOrPseudonym = NameOrPseudonym.GetInstance(e.Current);
-
-			while (e.MoveNext())
-			{
-				Asn1TaggedObject o = Asn1TaggedObject.GetInstance(e.Current);
-				int tag = o.TagNo;
-				switch (tag)
-				{
-				case 0:
-					nameDistinguisher = DerInteger.GetInstance(o, false).Value;
-					break;
-				case 1:
-					dateOfBirth = Asn1GeneralizedTime.GetInstance(o, false);
-					break;
-				case 2:
-					placeOfBirth = DirectoryString.GetInstance(o, true);
-					break;
-				case 3:
-					gender = DerPrintableString.GetInstance(o, false).GetString();
-					break;
-				case 4:
-					postalAddress = DirectoryString.GetInstance(o, true);
-					break;
-				default:
-					throw new ArgumentException("Bad tag number: " + o.TagNo);
-				}
-			}
+			int count = seq.Count, pos = 0;
+			if (count < 1 || count > 6)
+				throw new ArgumentException("Bad sequence size: " + count, nameof(seq));
+
+			m_nameOrPseudonym = NameOrPseudonym.GetInstance(seq[pos++]);
+			m_nameDistinguisher = Asn1Utilities.ReadOptionalContextTagged(seq, ref pos, 0, false, DerInteger.GetTagged);
+            m_dateOfBirth = Asn1Utilities.ReadOptionalContextTagged(seq, ref pos, 1, false, Asn1GeneralizedTime.GetTagged);
+            m_placeOfBirth = Asn1Utilities.ReadOptionalContextTagged(seq, ref pos, 2, true, DirectoryString.GetTagged); //CHOICE
+            m_gender = Asn1Utilities.ReadOptionalContextTagged(seq, ref pos, 3, false, DerPrintableString.GetTagged);
+            m_postalAddress = Asn1Utilities.ReadOptionalContextTagged(seq, ref pos, 4, true, DirectoryString.GetTagged); //CHOICE
+
+            if (pos != count)
+                throw new ArgumentException("Unexpected elements in sequence", nameof(seq));
 		}
 
-		/**
+        /**
 		* Constructor from a given details.
 		*
 		* @param nameOrPseudonym  Name or pseudonym.
@@ -115,53 +93,31 @@ namespace Org.BouncyCastle.Asn1.X509.SigI
 		* @param gender           Gender.
 		* @param postalAddress    Postal Address.
 		*/
-		public PersonalData(
-			NameOrPseudonym		nameOrPseudonym,
-			BigInteger			nameDistinguisher,
-            Asn1GeneralizedTime dateOfBirth,
-			DirectoryString		placeOfBirth,
-			string				gender,
-			DirectoryString		postalAddress)
-		{
-			this.nameOrPseudonym = nameOrPseudonym;
-			this.dateOfBirth = dateOfBirth;
-			this.gender = gender;
-			this.nameDistinguisher = nameDistinguisher;
-			this.postalAddress = postalAddress;
-			this.placeOfBirth = placeOfBirth;
-		}
+        public PersonalData(NameOrPseudonym nameOrPseudonym, BigInteger nameDistinguisher,
+			Asn1GeneralizedTime dateOfBirth, DirectoryString placeOfBirth, string gender,
+			DirectoryString postalAddress)
+        {
+            m_nameOrPseudonym = nameOrPseudonym ?? throw new ArgumentNullException(nameof(nameOrPseudonym));
+            m_nameDistinguisher = nameDistinguisher == null ? null : new DerInteger(nameDistinguisher);
+            m_dateOfBirth = dateOfBirth;
+            m_placeOfBirth = placeOfBirth;
+            m_gender = gender == null ? null : new DerPrintableString(gender, true);
+            m_postalAddress = postalAddress;
+        }
 
-		public NameOrPseudonym NameOrPseudonym
-		{
-			get { return nameOrPseudonym; }
-		}
+        public NameOrPseudonym NameOrPseudonym => m_nameOrPseudonym;
 
-		public BigInteger NameDistinguisher
-		{
-			get { return nameDistinguisher; }
-		}
+		public BigInteger NameDistinguisher => m_nameDistinguisher?.Value;
 
-		public Asn1GeneralizedTime DateOfBirth
-		{
-			get { return dateOfBirth; }
-		}
+		public Asn1GeneralizedTime DateOfBirth => m_dateOfBirth;
 
-		public DirectoryString PlaceOfBirth
-		{
-			get { return placeOfBirth; }
-		}
+		public DirectoryString PlaceOfBirth => m_placeOfBirth;
 
-		public string Gender
-		{
-			get { return gender; }
-		}
+		public string Gender => m_gender?.GetString();
 
-		public DirectoryString PostalAddress
-		{
-			get { return postalAddress; }
-		}
+		public DirectoryString PostalAddress => m_postalAddress;
 
-		/**
+        /**
 		* Produce an object suitable for an Asn1OutputStream.
 		* <p/>
 		* Returns:
@@ -181,23 +137,14 @@ namespace Org.BouncyCastle.Asn1.X509.SigI
 		*/
         public override Asn1Object ToAsn1Object()
         {
-            Asn1EncodableVector v = new Asn1EncodableVector(nameOrPseudonym);
-
-            if (null != nameDistinguisher)
-            {
-                v.Add(new DerTaggedObject(false, 0, new DerInteger(nameDistinguisher)));
-            }
-
-            v.AddOptionalTagged(false, 1, dateOfBirth);
-            v.AddOptionalTagged(true, 2, placeOfBirth);
-
-            if (null != gender)
-            {
-                v.Add(new DerTaggedObject(false, 3, new DerPrintableString(gender, true)));
-            }
-
-            v.AddOptionalTagged(true, 4, postalAddress);
+            Asn1EncodableVector v = new Asn1EncodableVector(6);
+            v.Add(m_nameOrPseudonym);
+            v.AddOptionalTagged(false, 0, m_nameDistinguisher);
+            v.AddOptionalTagged(false, 1, m_dateOfBirth);
+            v.AddOptionalTagged(true, 2, m_placeOfBirth); // CHOICE
+            v.AddOptionalTagged(false, 3, m_gender);
+            v.AddOptionalTagged(true, 4, m_postalAddress); // CHOICE
             return new DerSequence(v);
         }
-	}
+    }
 }
diff --git a/crypto/src/asn1/x509/sigi/SigIObjectIdentifiers.cs b/crypto/src/asn1/x509/sigi/SigIObjectIdentifiers.cs
index 682311adc..3ec50ae37 100644
--- a/crypto/src/asn1/x509/sigi/SigIObjectIdentifiers.cs
+++ b/crypto/src/asn1/x509/sigi/SigIObjectIdentifiers.cs
@@ -1,12 +1,11 @@
-using System;
-
 namespace Org.BouncyCastle.Asn1.X509.SigI
 {
-	/**
+    /**
 	 * Object Identifiers of SigI specifciation (German Signature Law
 	 * Interoperability specification).
 	 */
-	public sealed class SigIObjectIdentifiers
+    // TODO[api] Make static
+    public sealed class SigIObjectIdentifiers
 	{
 		private SigIObjectIdentifiers()
 		{
@@ -18,32 +17,32 @@ namespace Org.BouncyCastle.Asn1.X509.SigI
 		* Key purpose IDs for German SigI (Signature Interoperability
 		* Specification)
 		*/
-		public readonly static DerObjectIdentifier IdSigIKP = new DerObjectIdentifier(IdSigI + ".2");
+		public readonly static DerObjectIdentifier IdSigIKP = IdSigI.Branch("2");
 
 		/**
 		* Certificate policy IDs for German SigI (Signature Interoperability
 		* Specification)
 		*/
-		public readonly static DerObjectIdentifier IdSigICP = new DerObjectIdentifier(IdSigI + ".1");
+		public readonly static DerObjectIdentifier IdSigICP = IdSigI.Branch("1");
 
 		/**
 		* Other Name IDs for German SigI (Signature Interoperability Specification)
 		*/
-		public readonly static DerObjectIdentifier IdSigION = new DerObjectIdentifier(IdSigI + ".4");
+		public readonly static DerObjectIdentifier IdSigION = IdSigI.Branch("4");
 
 		/**
 		* To be used for for the generation of directory service certificates.
 		*/
-		public static readonly DerObjectIdentifier IdSigIKPDirectoryService = new DerObjectIdentifier(IdSigIKP + ".1");
+		public static readonly DerObjectIdentifier IdSigIKPDirectoryService = IdSigIKP.Branch("1");
 
 		/**
 		* ID for PersonalData
 		*/
-		public static readonly DerObjectIdentifier IdSigIONPersonalData = new DerObjectIdentifier(IdSigION + ".1");
+		public static readonly DerObjectIdentifier IdSigIONPersonalData = IdSigION.Branch("1");
 
 		/**
 		* Certificate is conform to german signature law.
 		*/
-		public static readonly DerObjectIdentifier IdSigICPSigConform = new DerObjectIdentifier(IdSigICP + ".1");
+		public static readonly DerObjectIdentifier IdSigICPSigConform = IdSigICP.Branch("1");
 	}
 }