Skip to content

Commit c63be9b

Browse files
committed
Tests: proxy protocol v2 TLVs tests for stream module.
1 parent 2306d03 commit c63be9b

File tree

1 file changed

+154
-0
lines changed

1 file changed

+154
-0
lines changed

stream_proxy_protocol2_tlv.t

Lines changed: 154 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,154 @@
1+
#!/usr/bin/perl
2+
3+
# (C) Roman Arutyunyan
4+
# (C) Eugene Grebenschikov
5+
# (C) Nginx, Inc.
6+
7+
# Tests for variables for proxy protocol v2 TLVs.
8+
9+
###############################################################################
10+
11+
use warnings;
12+
use strict;
13+
14+
use Test::More;
15+
16+
BEGIN { use FindBin; chdir($FindBin::Bin); }
17+
18+
use lib 'lib';
19+
use Test::Nginx;
20+
use Test::Nginx::Stream qw/ stream /;
21+
22+
###############################################################################
23+
24+
select STDERR; $| = 1;
25+
select STDOUT; $| = 1;
26+
27+
my $t = Test::Nginx->new()->has(qw/stream stream_return map/)
28+
->write_file_expand('nginx.conf', <<'EOF');
29+
30+
%%TEST_GLOBALS%%
31+
32+
daemon off;
33+
34+
events {
35+
}
36+
37+
stream {
38+
%%TEST_GLOBALS_STREAM%%
39+
40+
map $proxy_protocol_tlv_ssl $binary_present {
41+
"~\\x00" "true";
42+
}
43+
44+
server {
45+
listen 127.0.0.1:8080 proxy_protocol;
46+
return "
47+
alpn:$proxy_protocol_tlv_alpn
48+
authority:$proxy_protocol_tlv_authority
49+
crc32c:$proxy_protocol_tlv_0x3
50+
unique-id:$proxy_protocol_tlv_unique_id
51+
netns:$proxy_protocol_tlv_netns
52+
ssl-verify:$proxy_protocol_tlv_ssl_verify
53+
ssl-version:$proxy_protocol_tlv_ssl_version
54+
ssl-cn:$proxy_protocol_tlv_ssl_cn
55+
ssl-cipher:$proxy_protocol_tlv_ssl_cipher
56+
ssl-sig-alg:$proxy_protocol_tlv_ssl_sig_alg
57+
ssl-key-alg:$proxy_protocol_tlv_ssl_key_alg
58+
custom:$proxy_protocol_tlv_0x000ae
59+
x:$proxy_protocol_tlv_0x000e
60+
ssl-binary:$binary_present";
61+
}
62+
}
63+
64+
EOF
65+
66+
$t->try_run('no proxy_protocol tlv')->plan(14);
67+
68+
###############################################################################
69+
70+
my $tlv = pp2_create_tlv(0x1, "ALPN1");
71+
$tlv .= pp2_create_tlv(0x2, "localhost");
72+
$tlv .= pp2_create_tlv(0x3, "4321");
73+
$tlv .= pp2_create_tlv(0x5, "UNIQQ");
74+
$tlv .= pp2_create_tlv(0x30, "NETNS");
75+
$tlv .= pp2_create_tlv(0xae, "12345");
76+
my $p = pp2_create($tlv);
77+
78+
my $r = pp_get(8080, $p);
79+
like($r, qr/alpn:ALPN1\x0d?$/m, 'ALPN');
80+
like($r, qr/authority:localhost\x0d?$/m, 'AUTHORITY');
81+
like($r, qr/crc32c:4321\x0d?$/m, 'CRC32C');
82+
like($r, qr/unique-id:UNIQQ\x0d?$/m, 'UNIQUE_ID');
83+
like($r, qr/netns:NETNS\x0d?$/m, 'NETNS');
84+
like($r, qr/custom:12345\x0d?$/m, 'custom');
85+
like($r, qr/x:\x0d?$/m, 'non-existent');
86+
87+
# big proxy protocol header with TLVs
88+
89+
TODO: {
90+
local $TODO = 'not yet' unless $t->has_version('1.23.3');
91+
92+
my $sub = pp2_create_tlv(0x21, "TLSv1.2");
93+
$sub .= pp2_create_tlv(0x22, "example.com");
94+
$sub .= pp2_create_tlv(0x23, "AES256-SHA");
95+
$sub .= pp2_create_tlv(0x24, "SHA1");
96+
$sub .= pp2_create_tlv(0x25, "RSA512");
97+
my $ssl = pp2_create_ssl(0x01, 255, $sub);
98+
$tlv .= pp2_create_tlv(0x20, $ssl);
99+
$p = pp2_create($tlv);
100+
101+
$r = pp_get(8080, $p);
102+
like($r, qr/ssl-verify:255\x0d?$/m, 'SSL_VERIFY');
103+
like($r, qr/ssl-version:TLSv1.2\x0d?$/m, 'SSL_VERSION');
104+
like($r, qr/ssl-cn:example.com\x0d?$/m, 'SSL_CN');
105+
like($r, qr/ssl-cipher:AES256-SHA\x0d?$/m, 'SSL_CIPHER');
106+
like($r, qr/ssl-sig-alg:SHA1\x0d?$/m, 'SSL_SIG_ALG');
107+
like($r, qr/ssl-key-alg:RSA512\x0d?$/m, 'SSL_KEY_ALG');
108+
like($r, qr/ssl-binary:true/, 'SSL_BINARY');
109+
110+
}
111+
112+
###############################################################################
113+
114+
sub pp_get {
115+
my ($port, $proxy) = @_;
116+
stream(PeerPort => port($port))->io($proxy);
117+
}
118+
119+
sub pp2_create {
120+
my ($tlv) = @_;
121+
122+
my $pp2_sig = pack("N3", 0x0D0A0D0A, 0x000D0A51, 0x5549540A);
123+
my $ver_cmd = pack('C', 0x21);
124+
my $family = pack('C', 0x11);
125+
my $packet = $pp2_sig . $ver_cmd . $family;
126+
127+
my $ip1 = pack('N', 0xc0000201); # 192.0.2.1
128+
my $ip2 = pack('N', 0xc0000202); # 192.0.2.2
129+
my $port1 = pack('n', 123);
130+
my $port2 = pack('n', 5678);
131+
my $addrs = $ip1 . $ip2 . $port1 . $port2;
132+
133+
my $len = length($addrs) + length($tlv);
134+
135+
$packet .= pack('n', $len) . $addrs . $tlv;
136+
137+
return $packet;
138+
}
139+
140+
sub pp2_create_tlv {
141+
my ($type, $content) = @_;
142+
143+
my $len = length($content);
144+
145+
return pack("CnA*", $type, $len, $content);
146+
}
147+
148+
sub pp2_create_ssl {
149+
my ($client, $verify, $content) = @_;
150+
151+
return pack("CNA*", $client, $verify, $content);
152+
}
153+
154+
###############################################################################

0 commit comments

Comments
 (0)