//
-// Pkcs9Attribute.cs - System.Security.Cryptography.Pkcs.Pkcs9Attribute
+// System.Security.Cryptography.Pkcs.Pkcs9AttributeObject class
//
// Author:
// Sebastien Pouliot <sebastien@ximian.com>
//
// (C) 2003 Motus Technologies Inc. (http://www.motus.com)
-// Copyright (C) 2004 Novell Inc. (http://www.novell.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 : AsnEncodedData {
+ public class Pkcs9AttributeObject : AsnEncodedData {
// constructors
- public Pkcs9Attribute ()
+ public Pkcs9AttributeObject ()
: base ()
{
}
- public Pkcs9Attribute (AsnEncodedData asnEncodedData)
+ public Pkcs9AttributeObject (AsnEncodedData asnEncodedData)
: base (asnEncodedData)
{
}
- public Pkcs9Attribute (Oid oid, byte[] encodedData)
- : base (oid, encodedData)
+ public Pkcs9AttributeObject (Oid oid, byte[] encodedData)
{
+ if (oid == null)
+ throw new ArgumentNullException ("oid");
+ base.Oid = oid;
+ RawData = encodedData;
}
- public Pkcs9Attribute (string oid, byte[] 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 override void CopyFrom (AsnEncodedData asnEncodedData)
+ {
+ if (asnEncodedData == null)
+ throw new ArgumentNullException ("asnEncodedData");
+
+ throw new ArgumentException ("Cannot convert the PKCS#9 attribute.");
}
}
}