blob: d4ff250c550c0dc61a908880d646654289084e46 (
plain) (
blame)
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
|
using Org.BouncyCastle.Asn1.Cms;
namespace Org.BouncyCastle.Asn1.Crmf
{
public class EncryptedKey
: Asn1Encodable, IAsn1Choice
{
public static EncryptedKey GetInstance(object obj)
{
if (obj is EncryptedKey encryptedKey)
return encryptedKey;
if (obj is Asn1TaggedObject taggedObject)
return new EncryptedKey(EnvelopedData.GetInstance(taggedObject, false));
return new EncryptedKey(EncryptedValue.GetInstance(obj));
}
private readonly EnvelopedData m_envelopedData;
private readonly EncryptedValue m_encryptedValue;
public EncryptedKey(EnvelopedData envelopedData)
{
m_envelopedData = envelopedData;
}
public EncryptedKey(EncryptedValue encryptedValue)
{
m_encryptedValue = encryptedValue;
}
public virtual bool IsEncryptedValue => m_encryptedValue != null;
public virtual Asn1Encodable Value
{
get
{
if (m_encryptedValue != null)
return m_encryptedValue;
return m_envelopedData;
}
}
/**
* <pre>
* EncryptedKey ::= CHOICE {
* encryptedValue EncryptedValue, -- deprecated
* envelopedData [0] EnvelopedData }
* -- The encrypted private key MUST be placed in the envelopedData
* -- encryptedContentInfo encryptedContent OCTET STRING.
* </pre>
*/
public override Asn1Object ToAsn1Object()
{
if (m_encryptedValue != null)
return m_encryptedValue.ToAsn1Object();
return new DerTaggedObject(false, 0, m_envelopedData);
}
}
}
|