blob: 70b6a24c1f8fc6842bac9664c374531fb98d9ba0 (
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
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
|
using System;
using System.IO;
using System.Net;
using System.Net.Sockets;
using System.Threading;
using NUnit.Framework;
using Org.BouncyCastle.Crypto.Parameters;
using Org.BouncyCastle.Security;
using Org.BouncyCastle.Utilities.IO;
namespace Org.BouncyCastle.Tls.Tests
{
/// <summary>A simple test designed to conduct a TLS handshake with an external TLS client.</summary>
/// <remarks>
/// <code>
/// gnutls-cli --rawpkkeyfile ed25519.priv --rawpkfile ed25519.pub --priority NORMAL:+CTYPE-CLI-RAWPK:+CTYPE-SRV-RAWPK --insecure --debug 10 --port 5556 localhost
/// </code>
/// </remarks>
[TestFixture]
public class TlsServerRawKeysTest
{
[Test, Explicit]
public void TestConnection()
{
int port = 5556;
ProtocolVersion[] tlsVersions = ProtocolVersion.TLSv13.DownTo(ProtocolVersion.TLSv12);
TcpListener ss = new TcpListener(IPAddress.Any, port);
ss.Start();
Stream stdout = Console.OpenStandardOutput();
try
{
foreach (var tlsVersion in tlsVersions)
{
TcpClient s = ss.AcceptTcpClient();
Console.WriteLine("--------------------------------------------------------------------------------");
Console.WriteLine("Accepted " + s);
ServerTask serverTask = new ServerTask(s, stdout, tlsVersion);
Thread t = new Thread(new ThreadStart(serverTask.Run));
t.Start();
}
}
finally
{
ss.Stop();
}
}
internal class ServerTask
{
private readonly TcpClient s;
private readonly Stream stdout;
private readonly ProtocolVersion tlsVersion;
internal ServerTask(TcpClient s, Stream stdout, ProtocolVersion tlsVersion)
{
this.s = s;
this.stdout = stdout;
this.tlsVersion = tlsVersion;
}
public void Run()
{
try
{
MockRawKeysTlsServer server = new MockRawKeysTlsServer(CertificateType.RawPublicKey,
CertificateType.RawPublicKey, new short[]{ CertificateType.RawPublicKey },
new Ed25519PrivateKeyParameters(new SecureRandom()), tlsVersion);
TlsServerProtocol serverProtocol = new TlsServerProtocol(s.GetStream());
serverProtocol.Accept(server);
Stream log = new TeeOutputStream(serverProtocol.Stream, stdout);
Streams.PipeAll(serverProtocol.Stream, log);
serverProtocol.Close();
}
finally
{
try
{
s.Close();
}
catch (IOException)
{
}
}
}
}
}
}
|