1 <!DOCTYPE HTML PUBLIC '-//W3C//DTD HTML
4.0//EN'
>
4 Copyright (C) 2006-2009 Jonathan Zarate
5 http://www.polarcloud.com/tomato/
7 For use with Tomato Firmware only.
8 No part of this file may be used without permission.
12 <meta http-equiv='content-type' content='text/html;charset=utf-
8'
>
13 <meta name='robots' content='noindex,nofollow'
>
14 <title>[<%
ident(); %>] Advanced: Conntrack / Netfilter
</title>
15 <link rel='stylesheet' type='text/css' href='tomato.css'
>
16 <link rel='stylesheet' type='text/css' href='color.css'
>
17 <script type='text/javascript' src='tomato.js'
></script>
21 <script type='text/javascript' src='debug.js'
></script>
23 <script type='text/javascript'
>
25 // <% nvram("ct_tcp_timeout,ct_udp_timeout,ct_timeout,ct_max,ct_hashsize,nf_l7in,nf_ttl,nf_sip,nf_rtsp,nf_pptp,nf_h323,nf_ftp"); %>
28 var timer
= new TomatoTimer(check
);
34 if ((checker
) || (!running
)) return;
36 checker
= new XmlHttp();
37 checker
.onCompleted = function(text
, xml
) {
38 var conntrack
, total
, i
;
47 for (i
= 1; i
< 13; ++i
) {
48 E('count' + i
).innerHTML
= ' <small>('+ ((conntrack
[i
] || 0) * 1) + ' in this state)</small>';
50 E('count0').innerHTML
= '(' + ((conntrack
[0] || 0) * 1) + ' connections currently tracked)';
54 checker
.onError = function(x
) {
59 checker
.post('update.cgi', 'exec=ctcount&arg0=0');
65 E('spin').style
.visibility
= running
? 'visible' : 'hidden';
72 function expireTimer()
76 if (!expireText
) expireText
= e
.value
;
78 if (--expireTime
== 0) {
83 setTimeout(expireTimer
, 1000);
84 e
.value
= 'Expire Scheduled... ' + expireTime
;
88 function expireClicked()
91 E('expire').disabled
= true;
92 (new XmlHttp()).post('expct.cgi', '');
97 function verifyFields(focused
, quiet
)
101 for (i
= 1; i
< 9; ++i
) {
102 if (!v_range('_f_tcp_' + i
, quiet
, 1, 432000)) return 0;
104 for (i
= 0; i
< 2; ++i
) {
105 if (!v_range('_f_udp_' + i
, quiet
, 1, 432000)) return 0;
107 for (i
= 0; i
< 2; ++i
) {
108 if (!v_range('_f_ct_' + i
, quiet
, 1, 432000)) return 0;
110 return v_range('_ct_max', quiet
, 128, 10240);
115 var i
, tcp
, udp
, ct
, fom
;
117 if (!verifyFields(null, false)) return;
121 for (i
= 1; i
< 9; ++i
) {
122 tcp
.push(E('_f_tcp_' + i
).value
);
127 for (i
= 0; i
< 2; ++i
) {
128 udp
.push(E('_f_udp_' + i
).value
);
132 for (i
= 0; i
< 2; ++i
) {
133 ct
.push(E('_f_ct_' + i
).value
);
137 fom
.ct_tcp_timeout
.value
= tcp
.join(' ');
138 fom
.ct_udp_timeout
.value
= udp
.join(' ');
139 fom
.ct_timeout
.value
= ct
.join(' ');
140 fom
.nf_l7in
.value
= E('_f_l7in').checked
? 1 : 0;
141 fom
.nf_rtsp
.value
= E('_f_rtsp').checked
? 1 : 0;
142 fom
.nf_pptp
.value
= E('_f_pptp').checked
? 1 : 0;
143 fom
.nf_h323
.value
= E('_f_h323').checked
? 1 : 0;
144 fom
.nf_ftp
.value
= E('_f_ftp').checked
? 1 : 0;
151 <form id='_fom' method='post' action='tomato.cgi'
>
152 <table id='container' cellspacing=
0>
153 <tr><td colspan=
2 id='header'
>
154 <div class='title'
>Tomato
</div>
155 <div class='version'
>Version <%
version(); %></div>
157 <tr id='body'
><td id='navi'
><script type='text/javascript'
>navi()</script></td>
159 <div id='ident'
><%
ident(); %></div>
163 <input type='hidden' name='_nextpage' value='advanced-ctnf.asp'
>
164 <input type='hidden' name='_service' value='ctnf-restart'
>
166 <input type='hidden' name='ct_tcp_timeout' value=''
>
167 <input type='hidden' name='ct_udp_timeout' value=''
>
168 <input type='hidden' name='ct_timeout' value=''
>
169 <input type='hidden' name='nf_l7in' value=''
>
170 <input type='hidden' name='nf_rtsp'
>
171 <input type='hidden' name='nf_pptp'
>
172 <input type='hidden' name='nf_h323'
>
173 <input type='hidden' name='nf_ftp'
>
175 <div class='section-title'
>Connections
</div>
176 <div class='section'
>
177 <script type='text/javascript'
>
178 createFieldTable('', [
179 { title
: 'Maximum Connections', name
: 'ct_max', type
: 'text', maxlen
: 5, size
: 7,
180 suffix
: ' <a href="javascript:clicked()" id="count0">[ count current... ]</a> <img src="spin.gif" style="vertical-align:bottom;padding-left:10px;visibility:hidden" id="spin" onclick="clicked()">',
181 value
: fixInt(nvram
.ct_max
|| 4096, 128, 10240, 4096) }
185 <input type='button' value='Drop Idle' onclick='expireClicked()' id='expire'
>
190 <div class='section-title'
>TCP Timeout
</div>
191 <div class='section'
>
192 <script type='text/javascript'
>
193 if ((v
= nvram
.ct_tcp_timeout
.match(/^(\d+)\s+(\d+)\s+(\d+)\s+(\d+)\s+(\d+)\s+(\d+)\s+(\d+)\s+(\d+)\s+(\d+)\s+(\d+)$/)) == null) {
194 v
= [0,0,1200,120,60,120,120,10,60,30,0];
196 titles
= ['-', 'None', 'Established', 'SYN Sent', 'SYN Received', 'FIN Wait', 'Time Wait', 'Close', 'Close Wait', 'Last ACK', 'Listen'];
197 f
= [{ title
: ' ', text
: '<small>(seconds)</small>' }];
198 for (i
= 1; i
< 11; ++i
) {
199 f
.push({ title
: titles
[i
], name
: ('f_tcp_' + (i
- 1)),
200 type
: 'text', maxlen
: 6, size
: 8, value
: v
[i
],
201 hidden
: (i
== 1 || i
== 10) ? 1 : 0,
202 suffix
: '<span id="count' + i
+ '"></span>' });
204 createFieldTable('', f
);
208 <div class='section-title'
>UDP Timeout
</div>
209 <div class='section'
>
210 <script type='text/javascript'
>
211 if ((v
= nvram
.ct_udp_timeout
.match(/^(\d+)\s+(\d+)$/)) == null) {
214 createFieldTable('', [
215 { title
: ' ', text
: '<small>(seconds)</small>' },
216 { title
: 'Unreplied', name
: 'f_udp_0', type
: 'text', maxlen
: 6, size
: 8, value
: v
[1], suffix
: '<span id="count11"></span>' },
217 { title
: 'Assured', name
: 'f_udp_1', type
: 'text', maxlen
: 6, size
: 8, value
: v
[2], suffix
: '<span id="count12"></span>' }
222 <div class='section-title'
>Other Timeouts
</div>
223 <div class='section'
>
224 <script type='text/javascript'
>
225 if ((v
= nvram
.ct_timeout
.match(/^(\d+)\s+(\d+)$/)) == null) {
228 createFieldTable('', [
229 { title
: ' ', text
: '<small>(seconds)</small>' },
230 { title
: 'Generic', name
: 'f_ct_0', type
: 'text', maxlen
: 6, size
: 8, value
: v
[1] },
231 { title
: 'ICMP', name
: 'f_ct_1', type
: 'text', maxlen
: 6, size
: 8, value
: v
[2] }
236 <div class='section-title'
>Tracking / NAT Helpers
</div>
237 <div class='section'
>
238 <script type='text/javascript'
>
239 createFieldTable('', [
240 { title
: 'FTP', name
: 'f_ftp', type
: 'checkbox', value
: nvram
.nf_ftp
!= '0' },
241 { title
: 'GRE / PPTP', name
: 'f_pptp', type
: 'checkbox', value
: nvram
.nf_pptp
!= '0' },
242 { title
: 'H.323', name
: 'f_h323', type
: 'checkbox', value
: nvram
.nf_h323
!= '0' },
243 { title
: 'RTSP', name
: 'f_rtsp', type
: 'checkbox', value
: nvram
.nf_rtsp
!= '0' }
248 <div class='section-title'
>Miscellaneous
</div>
249 <div class='section'
>
250 <script type='text/javascript'
>
252 for (i
= -5; i
<= 5; ++i
) {
253 v
.push([i
, i
? ((i
> 0) ? '+' : '') + i
: 'None']);
255 createFieldTable('', [
256 { title
: 'TTL Adjust', name
: 'nf_ttl', type
: 'select', options
: v
, value
: nvram
.nf_ttl
},
257 { title
: 'Inbound Layer 7', name
: 'f_l7in', type
: 'checkbox', value
: nvram
.nf_l7in
!= '0' }
265 <tr><td id='footer' colspan=
2>
266 <span id='footer-msg'
></span>
267 <input type='button' value='Save' id='save-button' onclick='save()'
>
268 <input type='button' value='Cancel' id='cancel-button' onclick='reloadPage();'
>
272 <script type='text/javascript'
>verifyFields(null, 1);</script>