2010-11-18 20:17:14 -06:00
|
|
|
/* Authors:
|
|
|
|
* Endi Sukma Dewata <edewata@redhat.com>
|
|
|
|
*
|
|
|
|
* Copyright (C) 2010 Red Hat
|
|
|
|
* see file 'COPYING' for use and warranty information
|
|
|
|
*
|
2010-12-09 06:59:11 -06:00
|
|
|
* This program is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
2010-11-18 20:17:14 -06:00
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
2010-12-09 06:59:11 -06:00
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
2010-11-18 20:17:14 -06:00
|
|
|
*/
|
|
|
|
|
|
|
|
/* REQUIRES: ipa.js, details.js, search.js, add.js, entity.js */
|
|
|
|
|
2011-01-12 18:51:22 -06:00
|
|
|
IPA.rule_details_section = function (spec){
|
2010-11-18 20:17:14 -06:00
|
|
|
|
|
|
|
spec = spec || {};
|
|
|
|
|
2011-01-12 18:51:22 -06:00
|
|
|
var that = IPA.details_section(spec);
|
2010-11-18 20:17:14 -06:00
|
|
|
|
|
|
|
that.text = spec.text;
|
|
|
|
that.field_name = spec.field_name;
|
|
|
|
that.options = spec.options || [];
|
|
|
|
that.tables = spec.tables || [];
|
|
|
|
that.columns = spec.columns;
|
|
|
|
|
|
|
|
that.create = function(container) {
|
|
|
|
|
|
|
|
if (that.template) return;
|
|
|
|
|
|
|
|
if (that.text) container.append(that.text);
|
|
|
|
|
2011-01-12 18:51:22 -06:00
|
|
|
var param_info = IPA.get_param_info(that.entity_name, that.field_name);
|
2011-01-06 08:16:05 -06:00
|
|
|
|
|
|
|
var span = $('<span/>', {
|
|
|
|
name: that.field_name,
|
|
|
|
title: param_info.doc
|
|
|
|
}).appendTo(container);
|
2010-11-18 20:17:14 -06:00
|
|
|
|
|
|
|
if (that.options.length) {
|
|
|
|
for (var i=0; i<that.options.length; i++) {
|
|
|
|
var option = that.options[i];
|
|
|
|
|
|
|
|
$('<input/>', {
|
|
|
|
'type': 'radio',
|
|
|
|
'name': that.field_name,
|
|
|
|
'value': option.value
|
|
|
|
}).appendTo(span);
|
|
|
|
|
|
|
|
span.append(option.label);
|
|
|
|
}
|
|
|
|
|
|
|
|
span.append(' ');
|
|
|
|
|
|
|
|
$('<span/>', {
|
|
|
|
'name': 'undo',
|
|
|
|
'class': 'ui-state-highlight ui-corner-all',
|
|
|
|
'style': 'display: none;',
|
|
|
|
'html': 'undo'
|
|
|
|
}).appendTo(span);
|
|
|
|
|
|
|
|
span.append('<br/>');
|
|
|
|
}
|
|
|
|
|
2011-01-13 12:06:58 -06:00
|
|
|
for (var j=0; j<that.tables.length; j++) {
|
2011-01-12 13:47:29 -06:00
|
|
|
var table = that.tables[j];
|
2010-11-18 20:17:14 -06:00
|
|
|
|
2011-01-12 18:51:22 -06:00
|
|
|
param_info = IPA.get_param_info(that.entity_name, table.field_name);
|
2011-01-06 08:16:05 -06:00
|
|
|
|
|
|
|
var table_span = $('<span/>', {
|
|
|
|
name: table.field_name,
|
|
|
|
title: param_info ? param_info.doc : table.field_name
|
|
|
|
}).appendTo(span);
|
2010-11-18 20:17:14 -06:00
|
|
|
|
|
|
|
var field = that.get_field(table.field_name);
|
|
|
|
field.create(table_span);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2011-01-10 20:51:09 -06:00
|
|
|
that.setup = function(container) {
|
|
|
|
|
|
|
|
that.section_setup(container);
|
|
|
|
|
|
|
|
function update_tables(value) {
|
|
|
|
|
2011-01-12 13:47:29 -06:00
|
|
|
var enabled = ('' === value);
|
2011-01-10 20:51:09 -06:00
|
|
|
|
|
|
|
for (var i=0; i<that.tables.length; i++) {
|
|
|
|
var table = that.tables[i];
|
|
|
|
|
|
|
|
var field = that.get_field(table.field_name);
|
|
|
|
field.set_enabled(enabled);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
var category = that.get_field(that.field_name);
|
|
|
|
category.reset = function() {
|
|
|
|
category.widget_reset();
|
|
|
|
var values = category.save();
|
2011-01-12 13:47:29 -06:00
|
|
|
if (values.length === 0){
|
|
|
|
return;
|
|
|
|
}
|
2011-01-10 20:51:09 -06:00
|
|
|
var value = values[0];
|
|
|
|
update_tables(value);
|
|
|
|
};
|
|
|
|
|
|
|
|
var inputs = $('input[name='+that.field_name+']', container);
|
|
|
|
inputs.change(function() {
|
|
|
|
var input = $(this);
|
|
|
|
var value = input.val();
|
|
|
|
update_tables(value);
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
2010-11-18 20:17:14 -06:00
|
|
|
return that;
|
|
|
|
}
|
SUDO adjustments
The SUDO rule details facet has been updated to support the latest UI
spec. The facet consists of 5 sections: general, users, hosts, commands,
and run-as.
The general section contains the SUDO rule description and status. If
the status is changed, the sudorule-enable/disable will be invoked.
The other sections contain radio buttons for the association category
and tables for the members. When a member is added or removed, the
category will be adjusted appropriately. If the category is changed to
'all', 'allow', or 'deny', all members will be removed.
The last section is currently not working because backend support is
not yet available.
The adder dialog boxes for users, groups, and hosts has been modified
to accept external identities. The layout for the base adder dialog
was updated. The base dialog class was updated to support templates.
The SUDO dialog boxes were implemented using templates. New CSS
classes were added to ipa.css.
The HBAC rule details facet has been updated as well.
2010-12-07 01:51:51 -06:00
|
|
|
|
2011-01-12 18:51:22 -06:00
|
|
|
IPA.rule_association_table_widget = function (spec) {
|
SUDO adjustments
The SUDO rule details facet has been updated to support the latest UI
spec. The facet consists of 5 sections: general, users, hosts, commands,
and run-as.
The general section contains the SUDO rule description and status. If
the status is changed, the sudorule-enable/disable will be invoked.
The other sections contain radio buttons for the association category
and tables for the members. When a member is added or removed, the
category will be adjusted appropriately. If the category is changed to
'all', 'allow', or 'deny', all members will be removed.
The last section is currently not working because backend support is
not yet available.
The adder dialog boxes for users, groups, and hosts has been modified
to accept external identities. The layout for the base adder dialog
was updated. The base dialog class was updated to support templates.
The SUDO dialog boxes were implemented using templates. New CSS
classes were added to ipa.css.
The HBAC rule details facet has been updated as well.
2010-12-07 01:51:51 -06:00
|
|
|
|
|
|
|
spec = spec || {};
|
|
|
|
|
2011-01-12 18:51:22 -06:00
|
|
|
var that = IPA.association_table_widget(spec);
|
SUDO adjustments
The SUDO rule details facet has been updated to support the latest UI
spec. The facet consists of 5 sections: general, users, hosts, commands,
and run-as.
The general section contains the SUDO rule description and status. If
the status is changed, the sudorule-enable/disable will be invoked.
The other sections contain radio buttons for the association category
and tables for the members. When a member is added or removed, the
category will be adjusted appropriately. If the category is changed to
'all', 'allow', or 'deny', all members will be removed.
The last section is currently not working because backend support is
not yet available.
The adder dialog boxes for users, groups, and hosts has been modified
to accept external identities. The layout for the base adder dialog
was updated. The base dialog class was updated to support templates.
The SUDO dialog boxes were implemented using templates. New CSS
classes were added to ipa.css.
The HBAC rule details facet has been updated as well.
2010-12-07 01:51:51 -06:00
|
|
|
|
|
|
|
that.category = spec.category;
|
|
|
|
|
|
|
|
that.add = function(values, on_success, on_error) {
|
|
|
|
|
|
|
|
var pkey = $.bbq.getState(that.entity_name + '-pkey', true) || '';
|
|
|
|
|
2011-01-12 18:51:22 -06:00
|
|
|
var batch = IPA.batch_command({
|
SUDO adjustments
The SUDO rule details facet has been updated to support the latest UI
spec. The facet consists of 5 sections: general, users, hosts, commands,
and run-as.
The general section contains the SUDO rule description and status. If
the status is changed, the sudorule-enable/disable will be invoked.
The other sections contain radio buttons for the association category
and tables for the members. When a member is added or removed, the
category will be adjusted appropriately. If the category is changed to
'all', 'allow', or 'deny', all members will be removed.
The last section is currently not working because backend support is
not yet available.
The adder dialog boxes for users, groups, and hosts has been modified
to accept external identities. The layout for the base adder dialog
was updated. The base dialog class was updated to support templates.
The SUDO dialog boxes were implemented using templates. New CSS
classes were added to ipa.css.
The HBAC rule details facet has been updated as well.
2010-12-07 01:51:51 -06:00
|
|
|
'on_success': on_success,
|
|
|
|
'on_error': on_error
|
|
|
|
});
|
|
|
|
|
|
|
|
var command;
|
|
|
|
|
2011-01-10 20:51:09 -06:00
|
|
|
if (that.category) {
|
2011-01-12 18:51:22 -06:00
|
|
|
command = IPA.command({
|
SUDO adjustments
The SUDO rule details facet has been updated to support the latest UI
spec. The facet consists of 5 sections: general, users, hosts, commands,
and run-as.
The general section contains the SUDO rule description and status. If
the status is changed, the sudorule-enable/disable will be invoked.
The other sections contain radio buttons for the association category
and tables for the members. When a member is added or removed, the
category will be adjusted appropriately. If the category is changed to
'all', 'allow', or 'deny', all members will be removed.
The last section is currently not working because backend support is
not yet available.
The adder dialog boxes for users, groups, and hosts has been modified
to accept external identities. The layout for the base adder dialog
was updated. The base dialog class was updated to support templates.
The SUDO dialog boxes were implemented using templates. New CSS
classes were added to ipa.css.
The HBAC rule details facet has been updated as well.
2010-12-07 01:51:51 -06:00
|
|
|
'method': that.entity_name+'_mod',
|
|
|
|
'args': [pkey],
|
|
|
|
'options': {'all': true, 'rights': true},
|
|
|
|
'on_success': function() {
|
|
|
|
var record = {};
|
|
|
|
record[that.category.name] = [''];
|
2011-01-10 20:51:09 -06:00
|
|
|
that.category.load(record);
|
SUDO adjustments
The SUDO rule details facet has been updated to support the latest UI
spec. The facet consists of 5 sections: general, users, hosts, commands,
and run-as.
The general section contains the SUDO rule description and status. If
the status is changed, the sudorule-enable/disable will be invoked.
The other sections contain radio buttons for the association category
and tables for the members. When a member is added or removed, the
category will be adjusted appropriately. If the category is changed to
'all', 'allow', or 'deny', all members will be removed.
The last section is currently not working because backend support is
not yet available.
The adder dialog boxes for users, groups, and hosts has been modified
to accept external identities. The layout for the base adder dialog
was updated. The base dialog class was updated to support templates.
The SUDO dialog boxes were implemented using templates. New CSS
classes were added to ipa.css.
The HBAC rule details facet has been updated as well.
2010-12-07 01:51:51 -06:00
|
|
|
}
|
|
|
|
});
|
|
|
|
command.set_option(that.category.name, '');
|
|
|
|
batch.add_command(command);
|
|
|
|
}
|
|
|
|
|
2011-01-12 18:51:22 -06:00
|
|
|
command = IPA.command({
|
SUDO adjustments
The SUDO rule details facet has been updated to support the latest UI
spec. The facet consists of 5 sections: general, users, hosts, commands,
and run-as.
The general section contains the SUDO rule description and status. If
the status is changed, the sudorule-enable/disable will be invoked.
The other sections contain radio buttons for the association category
and tables for the members. When a member is added or removed, the
category will be adjusted appropriately. If the category is changed to
'all', 'allow', or 'deny', all members will be removed.
The last section is currently not working because backend support is
not yet available.
The adder dialog boxes for users, groups, and hosts has been modified
to accept external identities. The layout for the base adder dialog
was updated. The base dialog class was updated to support templates.
The SUDO dialog boxes were implemented using templates. New CSS
classes were added to ipa.css.
The HBAC rule details facet has been updated as well.
2010-12-07 01:51:51 -06:00
|
|
|
'method': that.entity_name+'_'+that.add_method,
|
|
|
|
'args': [pkey]
|
|
|
|
});
|
|
|
|
command.set_option(that.other_entity, values.join(','));
|
|
|
|
batch.add_command(command);
|
|
|
|
|
|
|
|
batch.execute();
|
|
|
|
};
|
|
|
|
|
|
|
|
return that;
|
|
|
|
}
|