You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
202 lines
5.0 KiB
202 lines
5.0 KiB
8 years ago
|
//
|
||
|
// X509Extensions.cs: Handles X.509 extensions.
|
||
|
//
|
||
|
// Author:
|
||
|
// Sebastien Pouliot <sebastien@ximian.com>
|
||
|
//
|
||
|
// (C) 2003 Motus Technologies Inc. (http://www.motus.com)
|
||
|
// (C) 2004 Novell (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
|
||
|
// "Software"), to deal in the Software without restriction, including
|
||
|
// without limitation the rights to use, copy, modify, merge, publish,
|
||
|
// distribute, sublicense, and/or sell copies of the Software, and to
|
||
|
// permit persons to whom the Software is furnished to do so, subject to
|
||
|
// the following conditions:
|
||
|
//
|
||
|
// The above copyright notice and this permission notice shall be
|
||
|
// included in all copies or substantial portions of the Software.
|
||
|
//
|
||
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||
|
// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||
|
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
||
|
// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
||
|
// LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
||
|
// OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
||
|
// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||
|
//
|
||
|
|
||
|
using System;
|
||
|
using System.Collections;
|
||
|
|
||
|
using Mono.Security;
|
||
|
|
||
|
namespace Mono.Security.X509 {
|
||
|
/*
|
||
|
* Extensions ::= SEQUENCE SIZE (1..MAX) OF Extension
|
||
|
*
|
||
|
* Note: 1..MAX -> There shouldn't be 0 Extensions in the ASN1 structure
|
||
|
*/
|
||
|
#if INSIDE_CORLIB
|
||
|
internal
|
||
|
#else
|
||
|
public
|
||
|
#endif
|
||
|
sealed class X509ExtensionCollection : CollectionBase, IEnumerable {
|
||
|
|
||
|
private bool readOnly;
|
||
|
|
||
|
public X509ExtensionCollection () : base ()
|
||
|
{
|
||
|
}
|
||
|
|
||
|
public X509ExtensionCollection (ASN1 asn1) : this ()
|
||
|
{
|
||
|
readOnly = true;
|
||
|
if (asn1 == null)
|
||
|
return;
|
||
|
if (asn1.Tag != 0x30)
|
||
|
throw new Exception ("Invalid extensions format");
|
||
|
for (int i=0; i < asn1.Count; i++) {
|
||
|
X509Extension extension = new X509Extension (asn1 [i]);
|
||
|
InnerList.Add (extension);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public int Add (X509Extension extension)
|
||
|
{
|
||
|
if (extension == null)
|
||
|
throw new ArgumentNullException ("extension");
|
||
|
if (readOnly)
|
||
|
throw new NotSupportedException ("Extensions are read only");
|
||
|
|
||
|
return InnerList.Add (extension);
|
||
|
}
|
||
|
|
||
|
public void AddRange (X509Extension[] extension)
|
||
|
{
|
||
|
if (extension == null)
|
||
|
throw new ArgumentNullException ("extension");
|
||
|
if (readOnly)
|
||
|
throw new NotSupportedException ("Extensions are read only");
|
||
|
|
||
|
for (int i = 0; i < extension.Length; i++)
|
||
|
InnerList.Add (extension [i]);
|
||
|
}
|
||
|
|
||
|
public void AddRange (X509ExtensionCollection collection)
|
||
|
{
|
||
|
if (collection == null)
|
||
|
throw new ArgumentNullException ("collection");
|
||
|
if (readOnly)
|
||
|
throw new NotSupportedException ("Extensions are read only");
|
||
|
|
||
|
for (int i = 0; i < collection.InnerList.Count; i++)
|
||
|
InnerList.Add (collection [i]);
|
||
|
}
|
||
|
|
||
|
public bool Contains (X509Extension extension)
|
||
|
{
|
||
|
return (IndexOf (extension) != -1);
|
||
|
}
|
||
|
|
||
|
public bool Contains (string oid)
|
||
|
{
|
||
|
return (IndexOf (oid) != -1);
|
||
|
}
|
||
|
|
||
|
public void CopyTo (X509Extension[] extensions, int index)
|
||
|
{
|
||
|
if (extensions == null)
|
||
|
throw new ArgumentNullException ("extensions");
|
||
|
|
||
|
InnerList.CopyTo (extensions, index);
|
||
|
}
|
||
|
|
||
|
public int IndexOf (X509Extension extension)
|
||
|
{
|
||
|
if (extension == null)
|
||
|
throw new ArgumentNullException ("extension");
|
||
|
|
||
|
for (int i=0; i < InnerList.Count; i++) {
|
||
|
X509Extension ex = (X509Extension) InnerList [i];
|
||
|
if (ex.Equals (extension))
|
||
|
return i;
|
||
|
}
|
||
|
return -1;
|
||
|
}
|
||
|
|
||
|
public int IndexOf (string oid)
|
||
|
{
|
||
|
if (oid == null)
|
||
|
throw new ArgumentNullException ("oid");
|
||
|
|
||
|
for (int i=0; i < InnerList.Count; i++) {
|
||
|
X509Extension ex = (X509Extension) InnerList [i];
|
||
|
if (ex.Oid == oid)
|
||
|
return i;
|
||
|
}
|
||
|
return -1;
|
||
|
}
|
||
|
|
||
|
public void Insert (int index, X509Extension extension)
|
||
|
{
|
||
|
if (extension == null)
|
||
|
throw new ArgumentNullException ("extension");
|
||
|
|
||
|
InnerList.Insert (index, extension);
|
||
|
}
|
||
|
|
||
|
public void Remove (X509Extension extension)
|
||
|
{
|
||
|
if (extension == null)
|
||
|
throw new ArgumentNullException ("extension");
|
||
|
|
||
|
InnerList.Remove (extension);
|
||
|
}
|
||
|
|
||
|
public void Remove (string oid)
|
||
|
{
|
||
|
if (oid == null)
|
||
|
throw new ArgumentNullException ("oid");
|
||
|
|
||
|
int index = IndexOf (oid);
|
||
|
if (index != -1)
|
||
|
InnerList.RemoveAt (index);
|
||
|
}
|
||
|
|
||
|
IEnumerator IEnumerable.GetEnumerator ()
|
||
|
{
|
||
|
return InnerList.GetEnumerator ();
|
||
|
}
|
||
|
|
||
|
public X509Extension this [int index] {
|
||
|
get { return (X509Extension) InnerList [index]; }
|
||
|
}
|
||
|
|
||
|
public X509Extension this [string oid] {
|
||
|
get {
|
||
|
int index = IndexOf (oid);
|
||
|
if (index == -1)
|
||
|
return null;
|
||
|
return (X509Extension) InnerList [index];
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public byte[] GetBytes ()
|
||
|
{
|
||
|
if (InnerList.Count < 1)
|
||
|
return null;
|
||
|
ASN1 sequence = new ASN1 (0x30);
|
||
|
for (int i=0; i < InnerList.Count; i++) {
|
||
|
X509Extension x = (X509Extension) InnerList [i];
|
||
|
sequence.Add (x.ASN1);
|
||
|
}
|
||
|
return sequence.GetBytes ();
|
||
|
}
|
||
|
}
|
||
|
}
|