blob: e0f57333bab5738d864e13b25701d7ebeb016f04 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
|
//
// System.Security.Cryptography AsymmetricAlgorithm Class implementation
//
// Authors:
// Thomas Neidhart (tome@sbox.tugraz.at)
//
using System;
namespace System.Security.Cryptography {
/// <summary>
/// Abstract base class for all cryptographic asymmetric algorithms.
/// Available algorithms include:
/// RSA, DSA
/// </summary>
public abstract class AsymmetricAlgorithm {
protected int KeySizeValue; // The size of the secret key used by the symmetric algorithm in bits.
protected KeySizes[] LegalKeySizesValue; // Specifies the key sizes that are supported by the symmetric algorithm.
/// <summary>
/// Called from constructor of derived class.
/// </summary>
protected AsymmetricAlgorithm () {
throw new CryptographicException();
}
/// <summary>
/// Gets the key exchange algorithm
/// </summary>
public abstract string KeyExchangeAlgorithm {get;}
/// <summary>
/// Gets or sets the actual key size
/// </summary>
public virtual int KeySize {
get {
return this.KeySizeValue;
}
set {
if (!IsLegalKeySize(this.LegalKeySizesValue, value))
throw new CryptographicException("key size not supported by algorithm");
this.KeySizeValue = value;
}
}
/// <summary>
/// Gets all legal key sizes
/// </summary>
public virtual KeySizes[] LegalKeySizes {
get {
return this.LegalKeySizesValue;
}
}
/// <summary>
/// Gets the signature algorithm
/// </summary>
public abstract string SignatureAlgorithm {get;}
/// <summary>
/// Reconstructs the AsymmetricAlgorithm Object from an XML-string
/// </summary>
public abstract void FromXmlString(string xmlString);
/// <summary>
/// Returns an XML string representation the current AsymmetricAlgorithm object
/// </summary>
public abstract string ToXmlString(bool includePrivateParameters);
private bool IsLegalKeySize(KeySizes[] LegalKeys, int Size) {
foreach (KeySizes LegalKeySize in LegalKeys) {
for (int i=LegalKeySize.MinSize; i<=LegalKeySize.MaxSize; i+=LegalKeySize.SkipSize) {
if (i == Size)
return true;
}
}
return false;
}
/// <summary>
/// Checks wether the given keyLength is valid for the current algorithm
/// </summary>
/// <param name="bitLength">the given keyLength</param>
public bool ValidKeySize(int bitLength) {
return IsLegalKeySize(LegalKeySizesValue, bitLength);
}
/// <summary>
/// Creates the default implementation of the default asymmetric algorithm (RSA).
/// </summary>
public static AsymmetricAlgorithm Create () {
return RSA.Create();;
}
/// <summary>
/// Creates a specific implementation of the given asymmetric algorithm.
/// </summary>
/// <param name="algName">the given algorithm</param>
[MonoTODO]
public static AsymmetricAlgorithm Create (string algName) {
// TODO: use reflection to create a new instance of the given algorithm
return null;
}
}
}
|