diff options
author | David Hook <dgh@bouncycastle.org> | 2019-01-15 05:05:09 +1100 |
---|---|---|
committer | David Hook <dgh@bouncycastle.org> | 2019-01-15 05:05:09 +1100 |
commit | 56256b133d57fada6dd8997bd58c4d60ef97db3e (patch) | |
tree | 00b405aa30cb7643a0b1224eb6d40fbe710d54a6 /crypto/src/asn1/crmf | |
parent | Updated EJBCA Example (diff) | |
download | BouncyCastle.NET-ed25519-56256b133d57fada6dd8997bd58c4d60ef97db3e.tar.xz |
moved ASN.1 class back
Diffstat (limited to 'crypto/src/asn1/crmf')
-rw-r--r-- | crypto/src/asn1/crmf/Controls.cs | 55 |
1 files changed, 55 insertions, 0 deletions
diff --git a/crypto/src/asn1/crmf/Controls.cs b/crypto/src/asn1/crmf/Controls.cs new file mode 100644 index 000000000..5f132155a --- /dev/null +++ b/crypto/src/asn1/crmf/Controls.cs @@ -0,0 +1,55 @@ +using Org.BouncyCastle.Utilities; +using System; +using System.Collections.Generic; +using System.Text; + +namespace Org.BouncyCastle.Asn1.Crmf +{ + public class Controls + : Asn1Encodable + { + private readonly Asn1Sequence content; + + private Controls(Asn1Sequence seq) + { + content = seq; + } + + public static Controls GetInstance(object obj) + { + if (obj is Controls) + return (Controls)obj; + + if (obj is Asn1Sequence) + return new Controls((Asn1Sequence)obj); + + throw new ArgumentException("Invalid object: " + Platform.GetTypeName(obj), "obj"); + } + + public Controls(params AttributeTypeAndValue[] atvs) + { + content = new DerSequence(atvs); + } + + public virtual AttributeTypeAndValue[] ToAttributeTypeAndValueArray() + { + AttributeTypeAndValue[] result = new AttributeTypeAndValue[content.Count]; + for (int i = 0; i != result.Length; ++i) + { + result[i] = AttributeTypeAndValue.GetInstance(content[i]); + } + return result; + } + + /** + * <pre> + * Controls ::= SEQUENCE SIZE(1..MAX) OF AttributeTypeAndValue + * </pre> + * @return a basic ASN.1 object representation. + */ + public override Asn1Object ToAsn1Object() + { + return content; + } + } +} |