648 lines
26 KiB
HTML
648 lines
26 KiB
HTML
<html>
|
|
<head>
|
|
<link rel="stylesheet" type="text/css" href="../../lib/css/themes/jquery-ui/redmond/jquery-ui.min.css"/>
|
|
<script type="text/javascript" src="../../lib/js/jquery-1.11.1.min.js"></script>
|
|
<script type="text/javascript" src="../../socket.io/socket.io.js"></script>
|
|
<script type="text/javascript" src="../../lib/js/jquery-ui-1.10.3.full.min.js"></script>
|
|
|
|
<link rel="stylesheet" type="text/css" href="../../css/adapter.css"/>
|
|
<script type="text/javascript" src="../../js/translate.js"></script>
|
|
<script type="text/javascript" src="../../js/adapter-settings.js"></script>
|
|
<script type="text/javascript" src="words.js"></script>
|
|
|
|
<style>
|
|
.number {
|
|
width: 70px
|
|
}
|
|
</style>
|
|
|
|
<script type="text/javascript">
|
|
var supportedSockets = ['socketio'];
|
|
|
|
function showHideSettings() {
|
|
if ($('#secure').prop('checked')) {
|
|
$('#_certPublic').show();
|
|
$('#_certPrivate').show();
|
|
$('#_certChained').show();
|
|
$('.le-settings').show();
|
|
|
|
if ($('#leEnabled').prop('checked')) {
|
|
$('.le-sub-settings').show();
|
|
if ($('#leUpdate').prop('checked')) {
|
|
$('.le-sub-settings-update').show();
|
|
} else {
|
|
$('.le-sub-settings-update').hide();
|
|
}
|
|
} else {
|
|
$('.le-sub-settings').hide();
|
|
}
|
|
} else {
|
|
$('#_certPublic').hide();
|
|
$('#_certPrivate').hide();
|
|
$('#_certChained').hide();
|
|
$('#auth').prop('checked', false);
|
|
$('.le-settings').hide();
|
|
}
|
|
if ($('#auth').prop('checked')) {
|
|
$('#secure').prop('checked', true);
|
|
$('#defaultUser').val('admin');
|
|
$('.defaultUser').hide();
|
|
$('#_ttl').show();
|
|
} else {
|
|
$('.defaultUser').show();
|
|
$('#_ttl').hide();
|
|
}
|
|
if ($('#whiteListEnabled').prop('checked')) {
|
|
$('.white-list-settings').show();
|
|
} else {
|
|
$('.white-list-settings').hide();
|
|
}
|
|
}
|
|
|
|
// the function loadSettings has to exist ...
|
|
function load(settings, onChange) {
|
|
$('#tabs').tabs();
|
|
|
|
if (!settings) return;
|
|
|
|
if (!settings.lePort) settings.lePort = 80;
|
|
if (settings.whiteListEnabled === undefined) settings.whiteListEnabled = false;
|
|
|
|
getIPs(function(ips) {
|
|
for (var i = 0; i < ips.length; i++) {
|
|
$('#bind').append('<option value="' + ips[i].address + '">' + ips[i].name + '</option>');
|
|
}
|
|
$('#bind.value').val(settings.bind);
|
|
});
|
|
$('#socketio')
|
|
.append('<option value="none">' + _('none') + '</option>')
|
|
.append('<option value="">' + _('integrated') + '</option>');
|
|
|
|
var count = 0;
|
|
for (var i = 0; i < supportedSockets.length; i++) {
|
|
count++;
|
|
getAdapterInstances(supportedSockets[i], function (res) {
|
|
if (!res) return;
|
|
for (var t = 0; t < res.length; t++) {
|
|
$('#socketio').append('<option value="' + res[t]._id + '">' + res[t].common.name + ' [' + res[t]._id.replace('system.adapter.', '') + ']</option>');
|
|
}
|
|
if (!--count) {
|
|
var $socketio = $('#socketio');
|
|
$socketio.val(settings.socketio);
|
|
if (settings.socketio !== '') {
|
|
$('.socketio').hide();
|
|
}
|
|
$socketio.change(function () {
|
|
if ($(this).val() === '') {
|
|
$('.socketio').show();
|
|
} else {
|
|
$('.socketio').hide();
|
|
}
|
|
});
|
|
}
|
|
});
|
|
}
|
|
|
|
|
|
$('.value').each(function () {
|
|
var key = $(this).attr('id');
|
|
var $value = $('#' + key + '.value');
|
|
if ($value.attr('type') === 'checkbox') {
|
|
$value.prop('checked', settings[key]).change(function() {
|
|
showHideSettings();
|
|
onChange();
|
|
});
|
|
} else {
|
|
$value.val(settings[key]).change(function() {
|
|
onChange();
|
|
}).keyup(function() {
|
|
$(this).trigger('change');
|
|
});
|
|
}
|
|
});
|
|
onChange(false);
|
|
|
|
fillSelectCertificates('#certPublic', 'public', settings.certPublic);
|
|
fillSelectCertificates('#certPrivate', 'private', settings.certPrivate);
|
|
fillSelectCertificates('#certChained', 'chained', settings.certChained);
|
|
fillUsers('#defaultUser', settings.defaultUser);
|
|
|
|
showHideSettings();
|
|
|
|
$('#auth').change(function () {
|
|
if ($(this).prop('checked')) {
|
|
$('#secure').prop('checked', true);
|
|
showHideSettings();
|
|
}
|
|
|
|
updateNameSelects();
|
|
setDefaultIpUserToDefaultUser();
|
|
});
|
|
|
|
$('#defaultUser').change(function () {
|
|
setDefaultIpUserToDefaultUser();
|
|
});
|
|
|
|
applyWhiteListSettings(settings, onChange);
|
|
}
|
|
|
|
function save(callback) {
|
|
var obj = {};
|
|
$('.value').each(function () {
|
|
var $this = $(this);
|
|
if ($this.attr('type') === 'checkbox') {
|
|
obj[$this.attr('id')] = $this.prop('checked');
|
|
} else {
|
|
obj[$this.attr('id')] = $this.val();
|
|
}
|
|
});
|
|
|
|
if ($('#secure').prop('checked') && (!$('#certPrivate').val() || !$('#certPublic').val())) {
|
|
showMessage(_('Set certificates or load it first in the system settings (right top).'));
|
|
return;
|
|
}
|
|
|
|
obj['whiteListSettings'] = getWhiteListSettings();
|
|
|
|
callback(obj);
|
|
}
|
|
|
|
var ips = {};
|
|
var inputIndex = 0;
|
|
function addWhiteListTableRow(change) {
|
|
var table = document.getElementById('whiteListTable');
|
|
|
|
var row = table.insertRow(2);
|
|
|
|
var rowCount = table.rows.length;
|
|
|
|
var defaultRowIndex = rowCount - 1;
|
|
|
|
var colCount = table.rows[defaultRowIndex].cells.length;
|
|
|
|
for (var i = 0; i < colCount; i++) {
|
|
var newCell = row.insertCell(i);
|
|
var cellClass = $(table.rows[defaultRowIndex].cells[i]).attr('class');
|
|
|
|
if (cellClass.indexOf('defaultUserName') !== -1) {
|
|
newCell.innerHTML = '<select class="select-username" />';
|
|
} else {
|
|
$(newCell).addClass(cellClass);
|
|
newCell.innerHTML = table.rows[defaultRowIndex].cells[i].innerHTML;
|
|
}
|
|
|
|
if (newCell.innerHTML === 'default') {
|
|
var id = 'input_' + inputIndex++;
|
|
var ip = '192.168.0.1';
|
|
ips[id] = ip;
|
|
newCell.innerHTML = '<input name="ip" size="15" maxlength="255" id="' + id + '" value="' + ip + '"/>';
|
|
}
|
|
|
|
if (newCell.childNodes[0].type === 'checkbox') {
|
|
newCell.childNodes[0].checked = false;
|
|
}
|
|
}
|
|
|
|
$('.select-username:not(:has(option))').each(function () {
|
|
fillNameSelect($(this));
|
|
});
|
|
|
|
|
|
if (change && changedCallback) changedCallback();
|
|
|
|
defaultHandling();
|
|
return row;
|
|
}
|
|
|
|
function deleteWhiteListTableRow(index) {
|
|
try {
|
|
changedCallback && changedCallback();
|
|
var table = document.getElementById('whiteListTable');
|
|
var rowCount = table.rows.length;
|
|
if (index === rowCount - 1) return;
|
|
table.deleteRow(index);
|
|
} catch (e) {
|
|
alert(e);
|
|
}
|
|
}
|
|
|
|
function getWhiteListSettings() {
|
|
|
|
var settings = {};
|
|
|
|
try {
|
|
var table = document.getElementById('whiteListTable');
|
|
|
|
var rowCount = table.rows.length;
|
|
|
|
for (var i = 2; i < rowCount; i++) {
|
|
var row = table.rows[i];
|
|
|
|
var ip = (i === (rowCount - 1)) ? 'default' : row.cells[1].childNodes[0].value;
|
|
var userSelected = (i === (rowCount - 1)) ? $(row.cells[2]).html().toLowerCase() : $(row.cells[2].childNodes[0]).val();
|
|
|
|
settings[ip] = {
|
|
user: userSelected,
|
|
object: {},
|
|
state: {},
|
|
file: {}
|
|
};
|
|
|
|
for (var c = 2; c < row.cells.length; c++) {
|
|
var $cell = $(row.cells[c].childNodes[0]);
|
|
var permobject = $cell.attr('permobject');
|
|
|
|
var perm = $cell.attr('perm');
|
|
|
|
if (permobject && perm && settings[ip].hasOwnProperty(permobject)) {
|
|
settings[ip][permobject][perm] = $cell.prop('checked');
|
|
}
|
|
}
|
|
}
|
|
} catch (e) {
|
|
alert(e);
|
|
}
|
|
|
|
return settings;
|
|
}
|
|
|
|
function validateIp(ip) {
|
|
if (ip.indexOf('*') !== -1 && ip.lastIndexOf('.') > ip.indexOf('*')) {
|
|
return false;
|
|
}
|
|
var expression = /^(([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])\.){3}([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])$|^(([a-zA-Z]|[a-zA-Z][a-zA-Z0-9\-]*[a-zA-Z0-9])\.)*([A-Za-z]|[A-Za-z][A-Za-z0-9\-]*[A-Za-z0-9])$|^\s*((([0-9A-Fa-f]{1,4}:){7}([0-9A-Fa-f]{1,4}|:))|(([0-9A-Fa-f]{1,4}:){6}(:[0-9A-Fa-f]{1,4}|((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3})|:))|(([0-9A-Fa-f]{1,4}:){5}(((:[0-9A-Fa-f]{1,4}){1,2})|:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3})|:))|(([0-9A-Fa-f]{1,4}:){4}(((:[0-9A-Fa-f]{1,4}){1,3})|((:[0-9A-Fa-f]{1,4})?:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(([0-9A-Fa-f]{1,4}:){3}(((:[0-9A-Fa-f]{1,4}){1,4})|((:[0-9A-Fa-f]{1,4}){0,2}:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(([0-9A-Fa-f]{1,4}:){2}(((:[0-9A-Fa-f]{1,4}){1,5})|((:[0-9A-Fa-f]{1,4}){0,3}:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(([0-9A-Fa-f]{1,4}:){1}(((:[0-9A-Fa-f]{1,4}){1,6})|((:[0-9A-Fa-f]{1,4}){0,4}:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(:(((:[0-9A-Fa-f]{1,4}){1,7})|((:[0-9A-Fa-f]{1,4}){0,5}:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:)))(%.+)?\s*$/;
|
|
|
|
return expression.test(ip.replace('*', '111'));
|
|
}
|
|
|
|
function createWhiteListTable(whiteListSettings) {
|
|
var table = document.getElementById("whiteListTable");
|
|
|
|
var rowCount = table.rows.length;
|
|
|
|
for (var i = rowCount - 2; i > 1; i--) {
|
|
table.deleteRow(i);
|
|
}
|
|
|
|
if (whiteListSettings) {
|
|
Object.keys(whiteListSettings).forEach(function (key) {
|
|
rowCount = table.rows.length;
|
|
if (key !== 'default') {
|
|
addWhiteListTableRow(false);
|
|
}
|
|
});
|
|
}
|
|
}
|
|
|
|
var changedCallback = null;
|
|
var whiteListSettings = null;
|
|
function applyWhiteListSettings(settings, onChange) {
|
|
try {
|
|
whiteListSettings = settings['whiteListSettings'];
|
|
createWhiteListTable(whiteListSettings);
|
|
fillNameSelects(whiteListSettings);
|
|
changedCallback = onChange;
|
|
} catch (e) {
|
|
alert(e);
|
|
}
|
|
}
|
|
|
|
function handleIpChange() {
|
|
var ip = $(this).val();
|
|
var id = $(this).attr('id');
|
|
if (ip && !validateIp(ip)) {
|
|
showMessage(_('The provided IP is not valid'));
|
|
// alert('The provided IP ' + ip + ' is not valid');
|
|
if (ips.hasOwnProperty(id)) {
|
|
$(this).val(ips[id]);
|
|
}
|
|
} else {
|
|
ips[id] = ip;
|
|
}
|
|
|
|
changedCallback && changedCallback();
|
|
}
|
|
|
|
function wireClickEvents() {
|
|
$('.delete-btn-clmn')
|
|
.off('click')
|
|
.click(function () {
|
|
var rowIndex = $(this).parent().parent().children().index($(this).parent());
|
|
deleteWhiteListTableRow(rowIndex + 2);
|
|
});
|
|
}
|
|
|
|
function wireChangeEvents() {
|
|
var table = document.getElementById('whiteListTable');
|
|
var rowCount = table.rows.length;
|
|
|
|
for (var i = 2; i < rowCount; i++) {
|
|
var row = table.rows[i];
|
|
|
|
if (i !== rowCount - 1) {
|
|
var $input = $(row.cells[1].childNodes[0]);
|
|
$input.off('change');
|
|
$input.change(handleIpChange);
|
|
}
|
|
|
|
for (var c = 2; c < row.cells.length; c++) {
|
|
var $cell = $(row.cells[c].childNodes[0]);
|
|
$cell.off('change');
|
|
$cell.change(function () {
|
|
changedCallback && changedCallback();
|
|
});
|
|
}
|
|
}
|
|
|
|
$('.select-username')
|
|
.off('change')
|
|
.change(function () {
|
|
changedCallback && changedCallback();
|
|
});
|
|
}
|
|
|
|
function hideDefaultDeleteBtn() {
|
|
$('.delete-btn').css({
|
|
display: 'block'
|
|
});
|
|
|
|
$('.delete-btn:last').css({
|
|
display: 'none'
|
|
});
|
|
}
|
|
|
|
function addOptionIfAbsent($e, value, valueText, defaultUser) {
|
|
if (!$e.find('option[value="' + value + '"]').length) {
|
|
$e.append('<option value="' + value + '" ' + ((defaultUser === value) ? 'selected' : '') + '>' + valueText + '</option>');
|
|
}
|
|
}
|
|
|
|
function fillNameSelect($this, defaultUser) {
|
|
for (var u in users) {
|
|
var value = users[u].common.name;
|
|
var valueText = users[u].common.name[0].toUpperCase() + users[u].common.name.substring(1);
|
|
addOptionIfAbsent($this, value, valueText, defaultUser);
|
|
}
|
|
}
|
|
|
|
var users = {};
|
|
function fillNameSelects(whiteListSettings) {
|
|
|
|
if (!whiteListSettings) return;
|
|
|
|
getUsers(function (err, response) {
|
|
users = response;
|
|
$('.select-username')
|
|
.off('change')
|
|
.each(function () {
|
|
fillNameSelect($(this));
|
|
});
|
|
|
|
applyRowSettings(whiteListSettings);
|
|
|
|
defaultHandling();
|
|
});
|
|
}
|
|
|
|
function applyRowSettings(whiteListSettings) {
|
|
|
|
if (!whiteListSettings) return;
|
|
|
|
var table = document.getElementById('whiteListTable');
|
|
var rowCount = table.rows.length;
|
|
var i = 2;
|
|
Object.keys(whiteListSettings).forEach(function (key) {
|
|
var row = key === 'default' ? table.rows[rowCount - 1] : table.rows[i++];
|
|
setRowSettings(row, key, whiteListSettings[key]);
|
|
});
|
|
}
|
|
|
|
function setRowSettings(row, ip, ipSettings) {
|
|
var $ip = $(row.cells[1].childNodes[0]);
|
|
$ip.val(ip);
|
|
for (var c = 2; c < row.cells.length; c++) {
|
|
var $cell = $(row.cells[c].childNodes[c === 2 ? 1 : 0]);
|
|
|
|
if (c > 2) {
|
|
var permobject = $cell.attr('permobject');
|
|
var perm = $cell.attr('perm');
|
|
|
|
if (ipSettings.hasOwnProperty(permobject) && ipSettings[permobject].hasOwnProperty(perm)) {
|
|
$cell.prop('checked', ipSettings[permobject][perm]);
|
|
}
|
|
} else {
|
|
$(row.cells[2].childNodes[0]).val(ipSettings.user).change();
|
|
}
|
|
}
|
|
}
|
|
|
|
function setDefaultIpUserToDefaultUser() {
|
|
var auth = $('#auth').prop('checked');
|
|
var defaultUser = auth ? 'Auth' : $('#defaultUser').find('option:selected').text();
|
|
$('.defaultUserName').html(defaultUser);
|
|
}
|
|
|
|
function updateNameSelects() {
|
|
var auth = $('#auth').prop('checked');
|
|
if (auth) {
|
|
$('.select-username').each(function () {
|
|
addOptionIfAbsent($(this), 'auth', 'Auth');
|
|
});
|
|
} else {
|
|
$('.select-username option[value="auth"]').remove();
|
|
}
|
|
}
|
|
|
|
function defaultHandling() {
|
|
hideDefaultDeleteBtn();
|
|
updateNameSelects();
|
|
setDefaultIpUserToDefaultUser();
|
|
wireClickEvents();
|
|
wireChangeEvents();
|
|
}
|
|
</script>
|
|
|
|
<style>
|
|
.whiteListTableHeader {
|
|
background-color: lightgrey;
|
|
color: darkslateblue;
|
|
}
|
|
|
|
.whiteListTableUnevenBlock {
|
|
background-color: gainsboro;
|
|
}
|
|
|
|
.whiteListTableEvenBlock {
|
|
background-color: lavender;
|
|
}
|
|
</style>
|
|
</head>
|
|
<body>
|
|
<div id="adapter-container">
|
|
<table>
|
|
<tr>
|
|
<td><img src="web.png"></td>
|
|
<td><h3 class="translate">Web Server adapter settings</h3></td>
|
|
</tr>
|
|
</table>
|
|
|
|
<div id="tabs">
|
|
<ul>
|
|
<li><a href="#tabs-1" class="translate">General</a></li>
|
|
<li><a href="#tabs-2" class="translate">White List</a></li>
|
|
</ul>
|
|
<div id="tabs-1">
|
|
<table>
|
|
<tr>
|
|
<td><label class="translate" for="bind">IP:</label></td>
|
|
<td><select class="value" id="bind"></select></td>
|
|
<td></td>
|
|
</tr>
|
|
<tr>
|
|
<td><label class="translate" for="port">Port:</label></td>
|
|
<td><input class="value" id="port" size="5" maxlength="5" type="number"/></td>
|
|
<td></td>
|
|
</tr>
|
|
<tr>
|
|
<td><label class="translate" for="secure">Secure(HTTPS):</label></td>
|
|
<td><input class="value" id="secure" type="checkbox"/></td>
|
|
<td></td>
|
|
</tr>
|
|
<tr id="_certPublic">
|
|
<td><label class="translate" for="certPublic">Public certificate:</label></td>
|
|
<td><select id="certPublic" class="value"></select></td>
|
|
</tr>
|
|
<tr id="_certPrivate">
|
|
<td><label class="translate" for="certPrivate">Private certificate:</label></td>
|
|
<td><select id="certPrivate" class="value"></select></td>
|
|
</tr>
|
|
<tr id="_certChained">
|
|
<td><label class="translate" for="certChained">Chained certificate:</label></td>
|
|
<td><select id="certChained" class="value"></select></td>
|
|
</tr>
|
|
<tr>
|
|
<td><label class="translate" for="auth">Authentication:</label></td>
|
|
<td><input class="value" id="auth" type="checkbox"/></td>
|
|
<td></td>
|
|
</tr>
|
|
<tr id="_ttl">
|
|
<td><label class="translate" for="ttl">Login timeout(sec):</label></td>
|
|
<td><input class="value" id="ttl" type="number"/></td>
|
|
<td></td></tr>
|
|
<tr>
|
|
<td><label class="translate" for="cache">Cache:</label></td>
|
|
<td><input class="value" id="cache" type="checkbox"/></td>
|
|
<td></td>
|
|
</tr>
|
|
<tr>
|
|
<td><label class="translate" for="socketio">Socket.IO Instance (Optional):</label></td>
|
|
<td><select class="value" id="socketio"></select><span class="translate"
|
|
style="padding-left: 20px">socket_help</span>
|
|
</td>
|
|
</tr>
|
|
<tr class="socketio">
|
|
<td><label class="translate" for="forceWebSockets">Force Web-Sockets:</label></td>
|
|
<td><input type="checkbox" class="value" id="forceWebSockets"/></td></tr>
|
|
<tr>
|
|
<td><label class="translate" for="simpleapi">Internal 'Simple API':</label></td>
|
|
<td><input type="checkbox" class="value" id="simpleapi"/></td>
|
|
</tr>
|
|
<tr class="defaultUser">
|
|
<td><label class="translate" for="defaultUser">Run as:</label></td>
|
|
<td><select class="value" id="defaultUser"></select></td>
|
|
</tr>
|
|
<tr><td colspan="2"> </td></tr>
|
|
<tr class="le-settings"><td colspan="2"><h3 class="translate">Let's Encrypt settings</h3></tr>
|
|
<tr class="le-settings"><td><label for="leEnabled" class="translate">Use Lets Encrypt certificates:</label></td><td><input class="value" id="leEnabled" type="checkbox" /></td></tr>
|
|
<tr class="le-settings le-sub-settings"><td><label for="leUpdate" class="translate">Use this instance for automatic update:</label></td><td><input class="value" id="leUpdate" type="checkbox" /></td></tr>
|
|
<tr class="le-settings le-sub-settings le-sub-settings-update"><td><label for="lePort" class="translate">Port to check the domain:</label></td><td><input class="value number" id="lePort" type="number" size="5" maxlength="5" /></td></tr>
|
|
|
|
</table>
|
|
</div>
|
|
<div id="tabs-2">
|
|
<div>
|
|
<span><label class="translate" for="whiteListEnabled">Enabled:</label></span><input id="whiteListEnabled" class="value" type="checkbox" />
|
|
</div>
|
|
<button style="display: inline-block; width: 2em; height: 2em;" onclick="addWhiteListTableRow(true)"
|
|
class="ui-button ui-widget ui-state-default ui-corner-all ui-button-icon-only white-list-settings" role="button">
|
|
<span class="ui-button-icon-primary ui-icon ui-icon-plus"></span>
|
|
<span class="ui-button-text"></span>
|
|
</button>
|
|
|
|
<table id="whiteListTable" cellpadding="3" cellspacing="2" border="0" class="white-list-settings">
|
|
<thead>
|
|
<tr class="whiteListTableHeader">
|
|
<th rowspan="2" colspan="2" class="translate">IP</th>
|
|
<th rowspan="2" class="translate">User</th>
|
|
<th colspan="4" class="translate">object</th>
|
|
<th colspan="5" class="translate">state</th>
|
|
<th colspan="5" class="translate">file</th>
|
|
</tr>
|
|
<tr class="whiteListTableHeader">
|
|
<th class="translate">read</th>
|
|
<th class="translate">list</th>
|
|
<th class="translate">write</th>
|
|
<th class="translate">remove</th>
|
|
|
|
<th class="translate">read</th>
|
|
<th class="translate">list</th>
|
|
<th class="translate">write</th>
|
|
<th class="translate">create</th>
|
|
<th class="translate">remove</th>
|
|
|
|
<th class="translate">read</th>
|
|
<th class="translate">list</th>
|
|
<th class="translate">write</th>
|
|
<th class="translate">create</th>
|
|
<th class="translate">remove</th>
|
|
</tr>
|
|
</thead>
|
|
<tbody id="whiteListTableBody">
|
|
<tr>
|
|
<td class="whiteListTableUnevenBlock delete-btn-clmn"><a class="delete-btn" href="#"><span
|
|
class="ui-icon ui-icon-trash"></span></a></td>
|
|
|
|
<td class="whiteListTableUnevenBlock">default</td>
|
|
|
|
<td class="whiteListTableUnevenBlock defaultUserName">defaultName</td>
|
|
|
|
<td class="whiteListTableEvenBlock"><input permobject="object" perm="read" type="checkbox"
|
|
checked="true"/></td>
|
|
<td class="whiteListTableEvenBlock"><input permobject="object" perm="list" type="checkbox"
|
|
checked="true"/></td>
|
|
<td class="whiteListTableEvenBlock"><input permobject="object" perm="write" type="checkbox"
|
|
checked="true"/></td>
|
|
<td class="whiteListTableEvenBlock"><input permobject="object" perm="delete" type="checkbox"
|
|
checked="true"/></td>
|
|
|
|
<td class="whiteListTableUnevenBlock"><input permobject="state" perm="read" type="checkbox"
|
|
checked="true"/></td>
|
|
<td class="whiteListTableUnevenBlock"><input permobject="state" perm="list" type="checkbox"
|
|
checked="true"/></td>
|
|
<td class="whiteListTableUnevenBlock"><input permobject="state" perm="write" type="checkbox"
|
|
checked="true"/></td>
|
|
<td class="whiteListTableUnevenBlock"><input permobject="state" perm="create" type="checkbox"
|
|
checked="true"/></td>
|
|
<td class="whiteListTableUnevenBlock"><input permobject="state" perm="delete" type="checkbox"
|
|
checked="true"/></td>
|
|
|
|
<td class="whiteListTableEvenBlock"><input permobject="file" perm="read" type="checkbox"
|
|
checked="true"/></td>
|
|
<td class="whiteListTableEvenBlock"><input permobject="file" perm="list" type="checkbox"
|
|
checked="true"/></td>
|
|
<td class="whiteListTableEvenBlock"><input permobject="file" perm="write" type="checkbox"
|
|
checked="true"/></td>
|
|
<td class="whiteListTableEvenBlock"><input permobject="file" perm="create" type="checkbox"
|
|
checked="true"/></td>
|
|
<td class="whiteListTableEvenBlock"><input permobject="file" perm="delete" type="checkbox"
|
|
checked="true"/></td>
|
|
</tr>
|
|
</tbody>
|
|
</table >
|
|
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</body>
|
|
</html>
|