You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
freshtomato-arm/release/src-rt-6.x.4708/router/www/admin-log.asp

246 lines
9.8 KiB
Plaintext

<!DOCTYPE html>
<!--
Tomato GUI
Copyright (C) 2006-2010 Jonathan Zarate
http://www.polarcloud.com/tomato/
For use with Tomato Firmware only.
No part of this file may be used without permission.
-->
<html lang="en-GB">
<head>
<meta http-equiv="content-type" content="text/html;charset=utf-8">
<meta name="robots" content="noindex,nofollow">
<title>[<% ident(); %>] Admin: Logging</title>
<link rel="stylesheet" type="text/css" href="tomato.css?rel=<% version(); %>">
<% css(); %>
<script src="tomato.js?rel=<% version(); %>"></script>
<script>
// <% nvram("log_remote,log_remoteip,log_remoteport,log_file,log_file_custom,log_file_path,log_limit,log_in,log_out,log_mark,log_events,log_wm,log_wmtype,log_wmip,log_wmdmax,log_wmsmax,log_file_size,log_file_keep,log_dropdups,log_min_level,webmon_bkp,webmon_dir,webmon_shrink"); %>
function verifyFields(focused, quiet) {
var a, b, c;
a = E('_f_log_file').checked;
b = E('_f_log_remote').checked;
c = E('_f_log_file_custom').checked;
a = !(a || b);
E('_log_in').disabled = a;
E('_log_out').disabled = a;
E('_log_limit').disabled = a;
E('_log_mark').disabled = a;
E('_f_log_acre').disabled = a;
E('_f_log_crond').disabled = a;
E('_f_log_dhcpc').disabled = a;
E('_f_log_ntp').disabled = a;
E('_f_log_sched').disabled = a;
E('_f_log_dropdups').disabled = a;
elem.display(PR('_log_remoteip'), b);
E('_log_remoteip').disabled = !b;
E('_log_remoteport').disabled = !b;
E('_f_log_file_custom').disabled = !E('_f_log_file').checked;
E('_log_file_path').disabled = !c || !E('_f_log_file').checked;
if (!a) {
if (!v_range('_log_limit', quiet, 0, 2400))
return 0;
if (!v_range('_log_mark', quiet, 0, 99999))
return 0;
if (b) {
c = E('_log_remoteip');
if (!v_ip(c, 1) && !v_domain(c, 1)) {
if (!quiet)
ferror.show(c);
return 0;
}
if (!v_port('_log_remoteport', quiet))
return 0;
}
}
if (E('_f_log_file').checked) {
E('_log_file_size').disabled = 0;
if (!v_range('_log_file_size', quiet, 0, 99999))
return 0;
if (parseInt(E('_log_file_size').value) > 0) {
E('_log_file_keep').disabled = 0;
if (!v_range('_log_file_keep', quiet, 0, 99))
return 0;
}
else
E('_log_file_keep').disabled = 1;
}
else {
E('_log_file_size').disabled = 1;
E('_log_file_keep').disabled = 1;
}
a = E('_f_log_wm').checked;
b = E('_log_wmtype').value != 0;
c = E('_f_webmon_bkp').checked;
E('_log_wmtype').disabled = !a;
E('_f_log_wmip').disabled = !a;
E('_log_wmdmax').disabled = !a;
E('_log_wmsmax').disabled = !a;
E('_f_webmon_bkp').disabled = !a;
E('_f_webmon_shrink').disabled = !a || !c;
E('_webmon_dir').disabled = !a || !c;
elem.display(PR('_f_log_wmip'), b);
if (a) {
if (b) {
if (!_v_iptaddr('_f_log_wmip', quiet, 15, 1, 1))
return 0;
}
if (!v_range('_log_wmdmax', quiet, 0, 9999))
return 0;
if (!v_range('_log_wmsmax', quiet, 0, 9999))
return 0;
}
return 1;
}
function save() {
var a, fom;
if (!verifyFields(null, 0))
return;
fom = E('t_fom');
fom.log_dropdups.value = E('_f_log_dropdups').checked ? 1 : 0;
fom.log_remote.value = E('_f_log_remote').checked ? 1 : 0;
fom.log_file.value = E('_f_log_file').checked ? 1 : 0;
fom.log_file_custom.value = E('_f_log_file_custom').checked ? 1 : 0;
a = [];
if (E('_f_log_acre').checked)
a.push('acre');
if (E('_f_log_crond').checked)
a.push('crond');
if (E('_f_log_dhcpc').checked)
a.push('dhcpc');
if (E('_f_log_ntp').checked)
a.push('ntp');
if (E('_f_log_sched').checked)
a.push('sched');
fom.log_events.value = a.join(',');
fom.log_min_level.value = E('_f_log_min_level').value;
fom.log_wm.value = E('_f_log_wm').checked ? 1 : 0;
fom.log_wmip.value = fom.f_log_wmip.value.split(/\s*,\s*/).join(',');
fom.webmon_bkp.value = E('_f_webmon_bkp').checked ? 1 : 0;
fom.webmon_shrink.value = E('_f_webmon_shrink').checked ? 1 : 0;
form.submit(fom, 1);
}
</script>
</head>
<body>
<form id="t_fom" method="post" action="tomato.cgi">
<table id="container">
<tr><td colspan="2" id="header">
<div class="title"><a href="/">FreshTomato</a></div>
<div class="version">Version <% version(); %> on <% nv("t_model_name"); %></div>
</td></tr>
<tr id="body"><td id="navi"><script>navi()</script></td>
<td id="content">
<div id="ident"><% ident(); %> | <script>wikiLink();</script></div>
<!-- / / / -->
<input type="hidden" name="_nextpage" value="admin-log.asp">
<input type="hidden" name="_service" value="logging-restart">
<input type="hidden" name="log_remote">
<input type="hidden" name="log_dropdups">
<input type="hidden" name="log_file">
<input type="hidden" name="log_file_custom">
<input type="hidden" name="log_events">
<input type="hidden" name="log_min_level">
<input type="hidden" name="log_wm">
<input type="hidden" name="log_wmip">
<input type="hidden" name="webmon_bkp">
<input type="hidden" name="webmon_shrink">
<!-- / / / -->
<div class="section-title">Syslog</div>
<div class="section">
<script>
/* REMOVE-BEGIN
// adjust (>=1.22)
nvram.log_mark *= 1;
if (nvram.log_mark >= 120) nvram.log_mark = 120;
else if (nvram.log_mark >= 60) nvram.log_mark = 60;
else if (nvram.log_mark > 0) nvram.log_mark = 30;
else nvram.log_mark = 0;
REMOVE-END */
createFieldTable('', [
{ title: 'Log Internally', name: 'f_log_file', type: 'checkbox', value: nvram.log_file == 1 },
{ title: 'Max size before rotate', name: 'log_file_size', type: 'text', maxlen: 5, size: 6, value: nvram.log_file_size || 50, suffix: ' <small>KB<\/small>' },
{ title: 'Number of rotated logs to keep', name: 'log_file_keep', type: 'text', maxlen: 2, size: 3, value: nvram.log_file_keep || 1 },
{ title: 'Custom Log File Path', multi: [
{ name: 'f_log_file_custom', type: 'checkbox', value: nvram.log_file_custom == 1, suffix: ' ' },
{ name: 'log_file_path', type: 'text', maxlen: 50, size: 30, value: nvram.log_file_path, suffix: ' <small>/path/filename, target folder must be writable<\/small>' } ] },
{ title: 'Drop dups', name: 'f_log_dropdups', type: 'checkbox', value: nvram.log_dropdups == 1 },
{ title: 'Log To Remote System', name: 'f_log_remote', type: 'checkbox', value: nvram.log_remote == 1 },
{ title: 'Host or IP Address / Port', indent: 2, multi: [
{ name: 'log_remoteip', type: 'text', maxlen: 32, size: 35, value: nvram.log_remoteip, suffix: ':' },
{ name: 'log_remoteport', type: 'text', maxlen: 5, size: 7, value: nvram.log_remoteport } ]},
{ title: 'Generate Marker', name: 'log_mark', type: 'select', options: [[0,'Disabled'],[30,'Every 30 Minutes'],[60,'Every 1 Hour'],[120,'Every 2 Hours'],[360,'Every 6 Hours'],[720,'Every 12 Hours'],[1440,'Every 1 Day'],[10080,'Every 7 Days']], value: nvram.log_mark },
{ title: 'Events Logged', text: '<small>some of the changes will take effect after a restart<\/small>' },
{ title: 'Access Restriction', indent: 2, name: 'f_log_acre', type: 'checkbox', value: (nvram.log_events.indexOf('acre') != -1) },
{ title: 'Cron', indent: 2, name: 'f_log_crond', type: 'checkbox', value: (nvram.log_events.indexOf('crond') != -1) },
{ title: 'DHCP Client', indent: 2, name: 'f_log_dhcpc', type: 'checkbox', value: (nvram.log_events.indexOf('dhcpc') != -1) },
{ title: 'NTP', indent: 2, name: 'f_log_ntp', type: 'checkbox', value: (nvram.log_events.indexOf('ntp') != -1) },
{ title: 'Scheduler', indent: 2, name: 'f_log_sched', type: 'checkbox', value: (nvram.log_events.indexOf('sched') != -1) },
{ title: 'Minimum log level', name: 'f_log_min_level', type: 'select', options: [[1,'Emergency'],[2,'Alert'],[3,'Critical'],[4,'Error'],[5,'Warning'],[6,'Notice'],[7,'Info'],[8,'Debug']], value: nvram.log_min_level },
{ title: 'Connection Logging' },
{ title: 'Inbound', indent: 2, name: 'log_in', type: 'select', options: [[0,'Disabled (recommended)'],[1,'If Blocked By Firewall'],[2,'If Allowed By Firewall'],[3,'Both']], value: nvram.log_in },
{ title: 'Outbound', indent: 2, name: 'log_out', type: 'select', options: [[0,'Disabled (recommended)'],[1,'If Blocked By Firewall'],[2,'If Allowed By Firewall'],[3,'Both']], value: nvram.log_out },
{ title: 'Limit', indent: 2, name: 'log_limit', type: 'text', maxlen: 4, size: 5, value: nvram.log_limit, suffix: ' <small>messages per minute; 0 for unlimited<\/small>' }
]);
</script>
</div>
<!-- / / / -->
<div class="section-title">Web Monitor</div>
<div class="section">
<script>
createFieldTable('', [
{ title: 'Monitor Web Usage', name: 'f_log_wm', type: 'checkbox', value: nvram.log_wm == 1 },
{ title: 'Monitor', name: 'log_wmtype', type: 'select', options: [[0,'All Computers / Devices'],[1,'The Following...'],[2,'All Except...']], value: nvram.log_wmtype },
{ title: 'IP Address(es)', indent: 2, name: 'f_log_wmip', type: 'text', maxlen: 512, size: 64, value: nvram.log_wmip,
suffix: '<br><small>ex: "1.1.1.1", "1.1.1.0/24" or "1.1.1.1 - 2.2.2.2"<\/small>' },
{ title: 'Number of Entries to remember' },
{ title: 'Domains', indent: 2, name: 'log_wmdmax', type: 'text', maxlen: 4, size: 6, value: nvram.log_wmdmax, suffix: ' <small>0 to disable<\/small>' },
{ title: 'Searches', indent: 2, name: 'log_wmsmax', type: 'text', maxlen: 4, size: 6, value: nvram.log_wmsmax, suffix: ' <small>0 to disable<\/small>' },
{ title: 'Daily Backup', name: 'f_webmon_bkp', type: 'checkbox', value: nvram.webmon_bkp == 1, suffix: ' <small>(every day at midnight)<\/small>' },
{ title: 'Clear Data After Backup', indent: 2, name: 'f_webmon_shrink', type: 'checkbox', value: nvram.webmon_shrink == 1 },
{ title: 'Backup Directory', indent: 2, name: 'webmon_dir', type: 'text', maxlen: 128, size: 30, value: nvram.webmon_dir, suffix: ' <small>make sure the directory exists and is writable<\/small>' }
]);
</script>
</div>
<!-- / / / -->
<div id="footer">
<span id="footer-msg"></span>
<input type="button" value="Save" id="save-button" onclick="save()">
<input type="button" value="Cancel" id="cancel-button" onclick="reloadPage();">
</div>
</td></tr>
</table>
</form>
<script>verifyFields(null, 1);</script>
</body>
</html>