summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAdam Young <ayoung@redhat.com>2010-10-28 17:20:12 -0400
committerEndi Sukma Dewata <edewata@redhat.com>2010-10-29 17:12:55 -0400
commit6df16f3a1007bb60414bda87c970a89b21713888 (patch)
treebe48c9a16c58d719261c6e924a24f61b9de7f88c
parent3c795f3251bd0354d56e2b50042ee04cee7cd21f (diff)
downloadfreeipa-6df16f3a1007bb60414bda87c970a89b21713888.tar.gz
freeipa-6df16f3a1007bb60414bda87c970a89b21713888.tar.xz
freeipa-6df16f3a1007bb60414bda87c970a89b21713888.zip
delete associations
Uses code very similar to the search code for deleting associations Had to modify how we were configuring for bulk so that the logic for delete matched the logic for enroll Fixed unit test and removed the 'new' from the associator call
-rw-r--r--install/static/associate.js247
-rw-r--r--install/static/group.js6
-rw-r--r--install/static/host.js4
-rw-r--r--install/static/serverconfig.js4
-rw-r--r--install/static/test/association_tests.js10
-rw-r--r--install/static/user.js8
6 files changed, 213 insertions, 66 deletions
diff --git a/install/static/associate.js b/install/static/associate.js
index 7daa0cffb..2050e468e 100644
--- a/install/static/associate.js
+++ b/install/static/associate.js
@@ -25,14 +25,14 @@
/**
*This associator is built for the case where each association requires a separate rpc
*/
-function SerialAssociator(form, manyObjPkeys, on_success)
+function serial_associate(form, manyObjPkeys, on_success)
{
var associator = this;
this.form = form;
this.manyObjPkeys = manyObjPkeys;
this.on_success = on_success;
- this.associateNext = function(){
+ this.associate_next = function(){
var form = this.form;
//TODO assert pre-conditions
var manyObjPkey = manyObjPkeys.shift();
@@ -46,7 +46,7 @@ function SerialAssociator(form, manyObjPkeys, on_success)
if (data.error){
alert('error adding member: '+data.error.message);
}else{
- associator.associateNext();
+ associator.associate_next();
}
},
function(xhr, text_status, error_thrown) {
@@ -57,53 +57,117 @@ function SerialAssociator(form, manyObjPkeys, on_success)
associator.on_success();
}
}
+ this.associate_next();
}
+
+function serial_delete(delete_method, one_entity, one_entity_pkey, many_entity,
+ many_entity_pkeys, on_success){
+ var that = {};
+ that.one_entity = one_entity;
+ that.on_success = on_success;
+ that.many_entity_pkeys = many_entity_pkeys;
+ that.delete_next = function(){
+ var many_entity_pkey = this.many_entity_pkeys.shift();
+ if (many_entity_pkey){
+ var options = {};
+ options[one_entity] = one_entity_pkey;
+ var args = [many_entity_pkey];
+ ipa_cmd( delete_method,args, options ,
+ function(data, text_status, xhr) {
+ if (data.error){
+ alert("error deleting member: "
+ +data.error.message);
+ }else{
+ that.delete_next();
+ }
+ },
+ function(xhr, text_status, error_thrown) {
+ alert("associateFailure");
+ },
+ many_entity );
+ }else{
+ this.on_success();
+ }
+ }
+
+ that.delete_next();
+}
+
+function bulk_delete(delete_method, one_entity, one_entity_pkey, many_entity,
+ many_entity_pkeys, on_success){
+ if (many_entity_pkeys.length){
+ var options = {};
+ options[one_entity] = one_entity_pkey;
+ var option = many_entity_pkeys.shift();
+ while(many_entity_pkeys.length > 0) {
+ option += ',' + many_entity_pkeys.shift();
+ }
+
+ var options = {
+ 'all':true
+ };
+ options[many_entity] = option;
+ var args = [one_entity_pkey];
+ ipa_cmd( delete_method,args, options ,
+ function(data, text_status, xhr) {
+ if (data.error){
+ alert("error deleting member: "
+ +data.error.message);
+ }else{
+ on_success();
+ }
+ },
+ function(xhr, text_status, error_thrown) {
+ alert("associateFailure");
+ },
+ one_entity );
+ }else{
+ on_success();
+ }
+}
+
+
/**
*This associator is for the common case where all the asociations can be sent
in a single rpc
*/
-function BulkAssociator(form, manyObjPkeys, on_success)
+function bulk_associate(form, manyObjPkeys, on_success)
{
var associator = this;
this.form = form;
this.manyObjPkeys = manyObjPkeys;
this.on_success = on_success;
- this.associateNext = function() {
- var form = this.form;
- var option = manyObjPkeys.shift();
- while(manyObjPkeys.length > 0) {
- option += ',' + manyObjPkeys.shift();
- }
-
- var options = {
- 'all':true
- };
- options[form.manyObj] = option;
-
- var args = [form.pkey];
-
- ipa_cmd( form.method,args, options ,
- function(data, text_status, xhr) {
- if (data.error){
- alert('error adding member: '+data.error.message);
- }else{
- associator.on_success();
- }
- },
- function(xhr, text_status, error_thrown) {
- alert('associateFailure');
- },
- form.oneObj );
+ var form = this.form;
+ var option = manyObjPkeys.shift();
+ while(manyObjPkeys.length > 0) {
+ option += ',' + manyObjPkeys.shift();
}
+ var options = {
+ 'all':true
+ };
+ options[form.manyObj] = option;
+ var args = [form.pkey];
+ ipa_cmd( form.method,args, options ,
+ function(data, text_status, xhr) {
+ if (data.error){
+ alert('error adding member: '+data.error.message);
+ }else{
+ associator.on_success();
+ }
+ },
+ function(xhr, text_status, error_thrown) {
+ alert('associateFailure');
+ },
+ form.oneObj );
}
/**
* Create a form for a one to many association.
*
*/
-function AssociationForm(oneObj, pkey, manyObj, on_success, associatorConstructor, method)
+function AssociationForm(oneObj, pkey, manyObj, on_success, associator, method)
{
var form = this;
@@ -121,10 +185,9 @@ function AssociationForm(oneObj, pkey, manyObj, on_success, associatorConstructo
else
this.method = 'add_member';
- if (associatorConstructor)
- this.associatorConstructor = associatorConstructor;
- else
- this.associatorConstructor = BulkAssociator;
+ this.associator = associator;
+
+
this.setup = function() {
var label = IPA.metadata[form.manyObj].label;
@@ -203,9 +266,7 @@ function AssociationForm(oneObj, pkey, manyObj, on_success, associatorConstructo
$('#enrollments', form.dialog).children().each(function (i, selected) {
manyObjPkeys.push(selected.value);
});
- var associator =
- new this.associatorConstructor(form, manyObjPkeys, on_success);
- associator.associateNext();
+ this.associator(form, manyObjPkeys, on_success);
};
}
@@ -271,7 +332,15 @@ function ipa_association_facet(spec) {
];
var config = that.get_config(that.other_entity);
- that.associator = config ? config.associator : null;
+
+ if ( config && config.associator === 'serial' ){
+ that.associator = serial_associate;
+ that.deleter = serial_delete;
+ }else{
+ that.associator = bulk_associate;
+ that.deleter = bulk_delete;
+ }
+
that.method = config ? config.method : null;
that.setup_views(container);
@@ -284,15 +353,21 @@ function ipa_association_facet(spec) {
container.find('.search-filter').css('display', 'none');
container.find('.search-buttons').html('');
- $('<input/>', {
- type: 'button',
- value: 'enroll',
- click: function() {
- that.show_enrollment_dialog();
- }
- }).appendTo(container.find('.search-buttons'));
+ var ctrls = container.find('.search-buttons');
+
+ ipa_make_button( 'ui-icon-plus',IPA.messages.button.enroll).
+ click(function() {
+ that.show_enrollment_dialog(container);
+ }).appendTo(ctrls);
+
+ ipa_make_button('ui-icon-trash',IPA.messages.button.delete).
+ click(function(){
+ that.delete_on_click(container);
+ }).appendTo(ctrls);
+
- var header = $('<tr></tr>').appendTo(container.find('.search-table thead:last'));
+
+ var header = container.find('.search-table thead:last').find("tr");;
for (var i =0 ; i != that.columns.length ;i++){
$('<th></th>',{
html: that.columns[i].title
@@ -301,21 +376,91 @@ function ipa_association_facet(spec) {
that.refresh(container);
};
+ that.delete_on_click = function(container) {
+ var delete_list = [];
+ var delete_dialog = $('<div></div>', {
+ title: IPA.messages.button.delete,
+ 'class': 'search-dialog-delete'
+ });
+
+ function delete_on_click() {
+ that.deleter('remove_member', that.entity_name,
+ that.pkey, that.other_entity, delete_list,
+ function(){ that.refresh(container)});
+ delete_dialog.dialog('close');
+ }
+ function delete_on_win() {
+ delete_dialog.dialog('close');
+ }
+ function cancel_on_click() {
+ delete_dialog.dialog('close');
+ }
+ var confirm_list = $('<ul/>');
+ var delete_list = [];
+ container.find('.search-selector').each(function () {
+ if (this.checked){
+ delete_list.push(this.title);
+ confirm_list.append($('<li/>',{text: this.title}));
+ }
+ });
+ if (delete_list.length == 0){
+ return;
+ }
+ delete_dialog.append(confirm_list);
+ delete_dialog.append(
+ $('<p/>',
+ {text:IPA.messages.search.delete_confirm}));
+
+
+ delete_dialog.dialog({
+ modal: true,
+ buttons: {
+ 'Delete': delete_on_click,
+ 'Cancel': cancel_on_click
+ }
+ });
+ }
+
that.refresh = function(container) {
function refresh_on_success(data, text_status, xhr) {
var tbody = container.find('.search-table tbody');
tbody.empty();
var associationList = data.result.result[that.columns[0].column];
+ //TODO, this is masking an error where the wrong
+ //direction association is presented upon page reload.
+ //if the associationList is unset, it is because
+ //form.associationColumns[0] doesn't exist in the results
+ if (!associationList) return;
+
+
for (var j = 0; j < associationList.length; j++){
+ var association = associationList[j];
var row = $('<tr/>').appendTo(tbody);
+ search_generate_checkbox_td(row, association);
+
+
for (var k = 0; k < that.columns.length ;k++){
var column = that.columns[k].column;
$('<td></td>',{
- html: data.result.result[column][j]
+ html:data.result.result[column][j],
}).appendTo(row);
}
}
+
+ tbody.find('.search-a-pkey').click(function () {
+ var jobj = $(this);
+ var state = {};
+ state[that.other_entity + '-facet'] = 'details';
+ state[that.other_entity + '-pkey'] = $(this).text();
+ //Before this will work, we need to set the tab one level up
+ //for example:
+ //state['identity'] = 0;
+ //but we have no way of getting the index.
+
+ $.bbq.pushState(state);
+ return (false);
+ });
}
function refresh_on_error(xhr, text_status, error_thrown) {
@@ -328,14 +473,16 @@ function ipa_association_facet(spec) {
ipa_cmd('show', [that.pkey], {}, refresh_on_success, refresh_on_error, that.entity_name);
};
- that.show_enrollment_dialog = function() {
+ that.show_enrollment_dialog = function(container) {
+
+
var enrollment_dialog = new AssociationForm(
that.entity_name,
that.pkey,
that.other_entity,
function() {
- that.refresh();
+ that.refresh(container);
enrollment_dialog.close();
},
that.associator,
diff --git a/install/static/group.js b/install/static/group.js
index 1a66c9289..1d1e9b5ce 100644
--- a/install/static/group.js
+++ b/install/static/group.js
@@ -44,9 +44,9 @@ ipa_entity_set_details_definition('group',[
]);
ipa_entity_set_association_definition('group', {
- 'netgroup': { associator: SerialAssociator },
- 'rolegroup': { associator: SerialAssociator },
- 'taskgroup': { associator: SerialAssociator }
+ 'netgroup': { associator: 'serial' },
+ 'rolegroup': { associator: 'serial' },
+ 'taskgroup': { associator: 'serial' }
});
function f_posix(dlg, mode)
diff --git a/install/static/host.js b/install/static/host.js
index c4d110a86..8407e269d 100644
--- a/install/static/host.js
+++ b/install/static/host.js
@@ -48,8 +48,8 @@ ipa_entity_set_details_definition('host', [
]);
ipa_entity_set_association_definition('host', {
- 'hostgroup': { associator: SerialAssociator },
- 'rolegroup': { associator: SerialAssociator }
+ 'hostgroup': { associator: 'serial' },
+ 'rolegroup': { associator: 'serial' }
});
function host_enrollment_status_load(container, dt, result) {
diff --git a/install/static/serverconfig.js b/install/static/serverconfig.js
index cb61265ee..327616aa4 100644
--- a/install/static/serverconfig.js
+++ b/install/static/serverconfig.js
@@ -70,7 +70,7 @@ ipa_entity_set_association_definition('taskgroup', {
});
ipa_entity_set_association_definition('rolegroup', {
- 'rolegroup': { associator: BulkAssociator }
+ 'rolegroup': { }
});
@@ -98,7 +98,7 @@ ipa_entity_set_details_definition('rolegroup', [
]);
ipa_entity_set_association_definition('rolegroup', {
- 'taskgroup': { associator: SerialAssociator }
+ 'taskgroup': { associator: 'serial' }
});
/* Configuration */
diff --git a/install/static/test/association_tests.js b/install/static/test/association_tests.js
index 61cc3a04a..05e43ce4a 100644
--- a/install/static/test/association_tests.js
+++ b/install/static/test/association_tests.js
@@ -18,7 +18,7 @@
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
-test("Testing SerialAssociator().", function() {
+test("Testing serial_associate().", function() {
expect(10);
@@ -62,8 +62,8 @@ test("Testing SerialAssociator().", function() {
ok(true, "on_success() is invoked.");
};
- var associator = new SerialAssociator(form, manyObjPkeys, on_success);
- associator.associateNext();
+ var associator = serial_associate(form, manyObjPkeys, on_success);
+ //associator.associateNext();
ipa_cmd = orig_ipa_cmd;
});
@@ -117,8 +117,8 @@ test("Testing BulkAssociator().", function() {
ok(true, "on_success() is invoked.");
};
- var associator = new BulkAssociator(form, manyObjPkeys, on_success);
- associator.associateNext();
+ var associator = bulk_associate(form, manyObjPkeys, on_success);
+ //associator.associateNext();
ipa_cmd = orig_ipa_cmd;
});
diff --git a/install/static/user.js b/install/static/user.js
index 3ac828fe1..5645967d2 100644
--- a/install/static/user.js
+++ b/install/static/user.js
@@ -75,10 +75,10 @@ ipa_entity_set_details_definition('user', [
]);
ipa_entity_set_association_definition('user', {
- 'group': { associator: SerialAssociator },
- 'netgroup': { associator: SerialAssociator },
- 'rolegroup': { associator: SerialAssociator },
- 'taskgroup': { associator: SerialAssociator }
+ 'group': { associator: 'serial' },
+ 'netgroup': { associator: 'serial' },
+ 'rolegroup': { associator: 'serial' },
+ 'taskgroup': { associator: 'serial' }
});
/* Account status Toggle button */