… | |
… | |
4 | |
4 | |
5 | use strict qw(vars subs); |
5 | use strict qw(vars subs); |
6 | |
6 | |
7 | use AnyEvent::Socket; |
7 | use AnyEvent::Socket; |
8 | use AnyEvent::Handle; |
8 | use AnyEvent::Handle; |
|
|
9 | use AnyEvent::TLS; |
9 | |
10 | |
10 | { |
11 | my $ctx = new AnyEvent::TLS cert_file => $0; |
11 | my $ctx = AnyEvent::Handle::TLS_CTX; |
|
|
12 | |
|
|
13 | Net::SSLeay::CTX_use_certificate_chain_file ($ctx->ctx, $0) |
|
|
14 | or die "unable to set certificate chain file"; |
|
|
15 | Net::SSLeay::CTX_use_PrivateKey_file ($ctx->ctx, $0, Net::SSLeay::FILETYPE_PEM ()) |
|
|
16 | or die "unable to set private key file"; |
|
|
17 | } |
|
|
18 | |
12 | |
19 | for my $mode (1..5) { |
13 | for my $mode (1..5) { |
20 | my $server_done = AnyEvent->condvar; |
14 | my $server_done = AnyEvent->condvar; |
21 | my $client_done = AnyEvent->condvar; |
15 | my $client_done = AnyEvent->condvar; |
22 | |
16 | |
… | |
… | |
29 | |
23 | |
30 | ok (1, "server_connect $mode"); |
24 | ok (1, "server_connect $mode"); |
31 | |
25 | |
32 | my $hd; $hd = new AnyEvent::Handle |
26 | my $hd; $hd = new AnyEvent::Handle |
33 | tls => "accept", |
27 | tls => "accept", |
|
|
28 | tls_ctx => $ctx, |
34 | fh => $fh, |
29 | fh => $fh, |
35 | timeout => 8, |
30 | timeout => 8, |
36 | on_error => sub { |
31 | on_error => sub { |
37 | ok (0, "server_error <$!>"); |
32 | ok (0, "server_error <$!>"); |
38 | $server_done->send; undef $hd; |
33 | $server_done->send; undef $hd; |
… | |
… | |
90 | |
85 | |
91 | ok (1, "client_connect $mode"); |
86 | ok (1, "client_connect $mode"); |
92 | |
87 | |
93 | my $hd; $hd = new AnyEvent::Handle |
88 | my $hd; $hd = new AnyEvent::Handle |
94 | tls => "connect", |
89 | tls => "connect", |
|
|
90 | tls_ctx => $ctx, |
95 | fh => $fh, |
91 | fh => $fh, |
96 | timeout => 8, |
92 | timeout => 8, |
97 | on_error => sub { |
93 | on_error => sub { |
98 | ok (0, "client_error <$!>"); |
94 | ok (0, "client_error <$!>"); |
99 | $client_done->send; undef $hd; |
95 | $client_done->send; undef $hd; |
… | |
… | |
162 | $server_done->recv; |
158 | $server_done->recv; |
163 | $client_done->recv; |
159 | $client_done->recv; |
164 | } |
160 | } |
165 | |
161 | |
166 | __END__ |
162 | __END__ |
|
|
163 | -----BEGIN RSA PRIVATE KEY----- |
|
|
164 | MIIBOwIBAAJBAL3Qbshr1ENmAzHxIRIvUaIG8+PCjc7xdXLBm+asBPMu0APQVQXJ |
|
|
165 | RTL3DueRUB51hAgSPgzSnj+ryZVzdcDER+UCAwEAAQJAGRftDWHz9dUOpxORo63N |
|
|
166 | xPXWWE3oIWuac0lVKvGi1eMoI4UCW/Y7qM4rXsUXqasUo3mxV24+QqJHDQid1qi6 |
|
|
167 | AQIhAN5BtiqfjFjb97uUbdE6aiqE+nSG0eXlkeHKNpBNtiUxAiEA2qHNZ5fcQTqT |
|
|
168 | 4qlnYhbI+g6bTwuR7QnzzGTlHUGxsPUCIQDLfvTw37Zb4cNYb1WBPW/ZUHoU2SAz |
|
|
169 | 01cXmdMNmumL8QIhAJMGTENl9FBJPDopAcUM3YqLWBYICdIF51WEZC8QhpYhAiBe |
|
|
170 | KcoNT51hv3pKK8oZtPJGsKFjmGVVnZeNNzyQmt/YWw== |
|
|
171 | -----END RSA PRIVATE KEY----- |
167 | -----BEGIN CERTIFICATE----- |
172 | -----BEGIN CERTIFICATE----- |
168 | MIIDJjCCAtCgAwIBAgIJAJ3NPnD6z5+2MA0GCSqGSIb3DQEBBQUAMIGWMQswCQYD |
173 | MIIDJjCCAtCgAwIBAgIJAJ3NPnD6z5+2MA0GCSqGSIb3DQEBBQUAMIGWMQswCQYD |
169 | VQQGEwJYTjETMBEGA1UECBMKU29tZS1TdGF0ZTESMBAGA1UEBxMJU29tZS1DaXR5 |
174 | VQQGEwJYTjETMBEGA1UECBMKU29tZS1TdGF0ZTESMBAGA1UEBxMJU29tZS1DaXR5 |
170 | MRUwEwYDVQQKEwxTb21lLUNvbXBhbnkxEjAQBgNVBAsTCVNvbWUtVW5pdDEQMA4G |
175 | MRUwEwYDVQQKEwxTb21lLUNvbXBhbnkxEjAQBgNVBAsTCVNvbWUtVW5pdDEQMA4G |
171 | A1UEAxMHU29tZS1DTjEhMB8GCSqGSIb3DQEJARYSc29tZUBlbWFpbC5pbnZhbGlk |
176 | A1UEAxMHU29tZS1DTjEhMB8GCSqGSIb3DQEJARYSc29tZUBlbWFpbC5pbnZhbGlk |
… | |
… | |
181 | b21wYW55MRIwEAYDVQQLEwlTb21lLVVuaXQxEDAOBgNVBAMTB1NvbWUtQ04xITAf |
186 | b21wYW55MRIwEAYDVQQLEwlTb21lLVVuaXQxEDAOBgNVBAMTB1NvbWUtQ04xITAf |
182 | BgkqhkiG9w0BCQEWEnNvbWVAZW1haWwuaW52YWxpZIIJAJ3NPnD6z5+2MAwGA1Ud |
187 | BgkqhkiG9w0BCQEWEnNvbWVAZW1haWwuaW52YWxpZIIJAJ3NPnD6z5+2MAwGA1Ud |
183 | EwQFMAMBAf8wDQYJKoZIhvcNAQEFBQADQQA48HjY23liyBMmh3cNo9TC+/bu/G3E |
188 | EwQFMAMBAf8wDQYJKoZIhvcNAQEFBQADQQA48HjY23liyBMmh3cNo9TC+/bu/G3E |
184 | oT5npm3+Lh6VA/4kKMyMu2mP31BToTZfl7vUcBJCQBhPFYOiPd/HnwzW |
189 | oT5npm3+Lh6VA/4kKMyMu2mP31BToTZfl7vUcBJCQBhPFYOiPd/HnwzW |
185 | -----END CERTIFICATE----- |
190 | -----END CERTIFICATE----- |
186 | -----BEGIN RSA PRIVATE KEY----- |
|
|
187 | MIIBOwIBAAJBAL3Qbshr1ENmAzHxIRIvUaIG8+PCjc7xdXLBm+asBPMu0APQVQXJ |
|
|
188 | RTL3DueRUB51hAgSPgzSnj+ryZVzdcDER+UCAwEAAQJAGRftDWHz9dUOpxORo63N |
|
|
189 | xPXWWE3oIWuac0lVKvGi1eMoI4UCW/Y7qM4rXsUXqasUo3mxV24+QqJHDQid1qi6 |
|
|
190 | AQIhAN5BtiqfjFjb97uUbdE6aiqE+nSG0eXlkeHKNpBNtiUxAiEA2qHNZ5fcQTqT |
|
|
191 | 4qlnYhbI+g6bTwuR7QnzzGTlHUGxsPUCIQDLfvTw37Zb4cNYb1WBPW/ZUHoU2SAz |
|
|
192 | 01cXmdMNmumL8QIhAJMGTENl9FBJPDopAcUM3YqLWBYICdIF51WEZC8QhpYhAiBe |
|
|
193 | KcoNT51hv3pKK8oZtPJGsKFjmGVVnZeNNzyQmt/YWw== |
|
|
194 | -----END RSA PRIVATE KEY----- |
|
|
195 | |
191 | |
196 | |
192 | |
197 | |
193 | |