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
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
| ///////////////////////////////////////////////////////////////////////////
// //
// Copyright (c) 2015 by Charta Software B.V. //
// All rights reserved //
// //
// Version: 1.7.0.83525 //
// Web site: https://pascal.chartasoftware.com/ //
// //
// This code and information are provided "as is" without warranty of //
// any kind. Dissemination of this information or reproduction of //
// this material is strictly forbidden unless prior written permission //
// is obtained from Charta Software B.V.. //
// //
///////////////////////////////////////////////////////////////////////////
unit Socket.Secure.Layer.Security;
interface
uses
Collection.List,
Encryption.Rsa.Key.Private_,
Memory.Block,
Text;
type
TCertificateChain = class(TObject)
private
FCertificates: TList<TMemoryBlock>;
protected
function ReadCertificateFile(Certificate: TText): TMemoryBlock;
public
constructor Create(); virtual;
destructor Destroy(); override;
procedure Add(Certificate: TText);
property Certificates: TList<TMemoryBlock> read FCertificates;
end;
TSecurity = class(TObject)
protected
function ReadPrivateKey(PrivateKey: TText): TRsaPrivateKey;
public
PrivateKey: TRsaPrivateKey;
CertificateChain: TCertificateChain;
constructor Create(); virtual;
destructor Destroy(); override;
procedure SetPrivateKey(Value: TText);
end;
implementation
uses
Encryption.Pem,
Memory.Block.Physical,
Object_.List,
Stream.Input;
{ TCertificateChain }
procedure TCertificateChain.Add(Certificate: TText);
begin
Certificates.Add(ReadCertificateFile(Certificate));
end;
constructor TCertificateChain.Create();
begin
inherited Create();
FCertificates := TObjectList<TMemoryBlock>.Create();
end;
destructor TCertificateChain.Destroy();
begin
Certificates.Free();
inherited Destroy();
end;
function TCertificateChain.ReadCertificateFile(Certificate: TText): TMemoryBlock;
var
InputStream: TInputStream;
CertificatePem: TPem;
begin
InputStream := Certificate.CreateInputStream();
CertificatePem := TPem.Create();
CertificatePem.Read(InputStream);
Result := TPhysicalMemoryBlock.Create();
Result.ReadFromObject(CertificatePem.Contents);
CertificatePem.Free();
InputStream.Free();
end;
{ TSecurity }
constructor TSecurity.Create();
begin
inherited Create();
CertificateChain := TCertificateChain.Create();
end;
destructor TSecurity.Destroy();
begin
CertificateChain.Free();
PrivateKey.Free();
inherited Destroy();
end;
function TSecurity.ReadPrivateKey(PrivateKey: TText): TRsaPrivateKey;
var
Stream: TInputStream;
PrivateKeyPem: TPem;
begin
Stream := PrivateKey.CreateInputStream();
PrivateKeyPem := TPem.Create();
PrivateKeyPem.Read(Stream);
Result := TRsaPrivateKey.Create();
Result.ReadFromPem(PrivateKeyPem);
PrivateKeyPem.Free();
Stream.Free();
end;
procedure TSecurity.SetPrivateKey(Value: TText);
begin
PrivateKey := ReadPrivateKey(Value);
end;
end.
|