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
|
using System;
using Org.BouncyCastle.Asn1.X509;
namespace Org.BouncyCastle.Asn1.Cmp
{
/**
* PBMParameter ::= SEQUENCE {
* salt OCTET STRING,
* -- note: implementations MAY wish to limit acceptable sizes
* -- of this string to values appropriate for their environment
* -- in order to reduce the risk of denial-of-service attacks
* owf AlgorithmIdentifier,
* -- AlgId for a One-Way Function (SHA-1 recommended)
* iterationCount INTEGER,
* -- number of times the OWF is applied
* -- note: implementations MAY wish to limit acceptable sizes
* -- of this integer to values appropriate for their environment
* -- in order to reduce the risk of denial-of-service attacks
* mac AlgorithmIdentifier
* -- the MAC AlgId (e.g., DES-MAC, Triple-DES-MAC [PKCS11],
* } -- or HMAC [RFC2104, RFC2202])
*/
public class PbmParameter
: Asn1Encodable
{
public static PbmParameter GetInstance(object obj)
{
if (obj is PbmParameter pbmParameter)
return pbmParameter;
if (obj != null)
return new PbmParameter(Asn1Sequence.GetInstance(obj));
return null;
}
private readonly Asn1OctetString m_salt;
private readonly AlgorithmIdentifier m_owf;
private readonly DerInteger m_iterationCount;
private readonly AlgorithmIdentifier m_mac;
private PbmParameter(Asn1Sequence seq)
{
m_salt = Asn1OctetString.GetInstance(seq[0]);
m_owf = AlgorithmIdentifier.GetInstance(seq[1]);
m_iterationCount = DerInteger.GetInstance(seq[2]);
m_mac = AlgorithmIdentifier.GetInstance(seq[3]);
}
public PbmParameter(byte[] salt, AlgorithmIdentifier owf, int iterationCount, AlgorithmIdentifier mac)
: this(new DerOctetString(salt), owf, new DerInteger(iterationCount), mac)
{
}
public PbmParameter(Asn1OctetString salt, AlgorithmIdentifier owf, DerInteger iterationCount,
AlgorithmIdentifier mac)
{
m_salt = salt;
m_owf = owf;
m_iterationCount = iterationCount;
m_mac = mac;
}
public virtual DerInteger IterationCount => m_iterationCount;
public virtual AlgorithmIdentifier Mac => m_mac;
public virtual AlgorithmIdentifier Owf => m_owf;
public virtual Asn1OctetString Salt => m_salt;
/**
* <pre>
* PbmParameter ::= SEQUENCE {
* salt OCTET STRING,
* -- note: implementations MAY wish to limit acceptable sizes
* -- of this string to values appropriate for their environment
* -- in order to reduce the risk of denial-of-service attacks
* owf AlgorithmIdentifier,
* -- AlgId for a One-Way Function (SHA-1 recommended)
* iterationCount INTEGER,
* -- number of times the OWF is applied
* -- note: implementations MAY wish to limit acceptable sizes
* -- of this integer to values appropriate for their environment
* -- in order to reduce the risk of denial-of-service attacks
* mac AlgorithmIdentifier
* -- the MAC AlgId (e.g., DES-MAC, Triple-DES-MAC [PKCS11],
* } -- or HMAC [RFC2104, RFC2202])
* </pre>
* @return a basic ASN.1 object representation.
*/
public override Asn1Object ToAsn1Object()
{
return new DerSequence(m_salt, m_owf, m_iterationCount, m_mac);
}
}
}
|