//
-// Pkcs9Attribute.cs - System.Security.Cryptography.Pkcs.Pkcs9Attribute
+// System.Security.Cryptography.Pkcs.Pkcs9AttributeObject class
//
// Author:
-// Sebastien Pouliot (spouliot@motus.com)
+// Sebastien Pouliot <sebastien@ximian.com>
//
// (C) 2003 Motus Technologies Inc. (http://www.motus.com)
-//
-
+// Copyright (C) 2004-2005 Novell Inc. (http://www.novell.com)
//
// Permission is hereby granted, free of charge, to any person obtaining
// a copy of this software and associated documentation files (the
// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
//
-#if NET_2_0
+#if SECURITY_DEP
-using System;
using System.Collections;
namespace System.Security.Cryptography.Pkcs {
- public class Pkcs9Attribute : CryptographicAttribute {
+ public class Pkcs9AttributeObject : AsnEncodedData {
// constructors
- public Pkcs9Attribute (Oid oid) : base (oid) {}
+ public Pkcs9AttributeObject ()
+ : base ()
+ {
+ }
+
+ public Pkcs9AttributeObject (AsnEncodedData asnEncodedData)
+ : base (asnEncodedData)
+ {
+ }
+
+ public Pkcs9AttributeObject (Oid oid, byte[] encodedData)
+ {
+ if (oid == null)
+ throw new ArgumentNullException ("oid");
+ base.Oid = oid;
+ RawData = encodedData;
+ }
+
+ public Pkcs9AttributeObject (string oid, byte[] encodedData)
+ : base (oid, encodedData)
+ {
+ }
+
+ // this (sadly) removes the "set" accessor
+ public new Oid Oid {
+ get { return base.Oid; }
+ internal set { base.Oid = value; }
+ }
- public Pkcs9Attribute (Oid oid, ArrayList values) : base (oid, values) {}
+ public override void CopyFrom (AsnEncodedData asnEncodedData)
+ {
+ if (asnEncodedData == null)
+ throw new ArgumentNullException ("asnEncodedData");
- public Pkcs9Attribute (Oid oid, object value) : base (oid, value) {}
+ throw new ArgumentException ("Cannot convert the PKCS#9 attribute.");
+ }
}
}
-#endif
\ No newline at end of file
+#endif