From e03a3e19101730173a6858a8401c70024a0e3b62 Mon Sep 17 00:00:00 2001
From: ulrich <not disclosed>
Date: Tue, 27 Dec 2016 13:16:49 +0000
Subject: [PATCH] Rolle entziehen

---
 web/ui/ui.js |  235 +++++++++++++++++++++++++++++++++++++++++++++++++++++-----
 1 files changed, 213 insertions(+), 22 deletions(-)

diff --git a/web/ui/ui.js b/web/ui/ui.js
index 7782450..af818d5 100644
--- a/web/ui/ui.js
+++ b/web/ui/ui.js
@@ -1,12 +1,21 @@
 
 function um_init() {
+  $('#user-form').hide();
   $('.user-save-btn').click(um_user_save);
   $('#nutzerliste').click(um_user_list_click);
   $('#nutzerLoeschen').click(um_del_user);
   $('#nutzerNeu').click(um_new_user);
   $('#nutzerLoeschen').prop( "disabled", true );
+  $('#nutzerRolleEntziehen').prop( "disabled", true );
+  $('#rolleErteilen').prop( "disabled", true );
+  $('#rolleErteilen').click(um_grant_role);
+  $('#nutzerRolleEntziehen').click(um_revoke_role);
+  $('#neueRolle').click(um_new_role);
+  $('#rollen').click(um_role_list_click);
+  $('#nutzerrollen').click(um_user_role_list_click);
   um_clear_user_form();
   um_apicall_get_user_list();
+  um_apicall_get_granted_roles();
 }
 
 /* ----- user functions ------ */
@@ -17,40 +26,76 @@
   if(user.pw != kww) {
     alert('Kennworte stimmen nicht ueberein.');
   } else {
-    //alert('user-save ' + user.id);
     um_apicall_create_user(self.serialisieren(user));
   }
 }
 
 function um_del_user() {
-  var users = [];
-  $('#nutzerliste :selected').each(function(i, selected){
-    users[i] = $(selected).text();
-  });
-
-  //alert('delete user ' + users[0]);
-  var antwort = confirm("Wollen Sie den Nutzer " + users[0] + " loeschen?"); 
-  if (antwort == true) {
-    var user = new User(users[0], '-', '-', '-', '-');
-    um_apicall_del_user(self.serialisieren(user));
-  }  
+  var userId = um_get_first_selected_user_id();
+  if(userId !== 'none') {
+    var antwort = confirm("Wollen Sie den Nutzer " + userId + " loeschen?"); 
+    if (antwort === true) {
+      var user = new User(userId, '-', '-', '-', '-');
+      um_apicall_del_user(self.serialisieren(user));
+    }  
+  }
 }
 
 function um_new_user() {
   alert('show form to enter new user');
 }
 
+/* ----------- role functions ------------ */
+
+function um_new_role() {
+  var roleIsNew = true;
+  var userId = um_get_first_selected_user_id();
+  if(userId === 'none') {
+    alert('Es wurde kein Benutzer ausgewaehlt.');
+  } else {
+    var answer = prompt("Name der Rolle", "");
+    if (answer === null) {
+      alert("Es wurde Cancel betaetigt.");
+    } else if(answer !== "") {
+      um_apicall_grant_role(userId, answer, roleIsNew);
+    } else {
+      alert("OK betaetigt, aber Keine Rolle angegeben.");
+    }
+  }
+}
+
+function um_grant_role() {
+  var roleIsNew = false;
+  var userId = um_get_first_selected_user_id();
+  var roleId = um_get_first_selected_role_id();
+  if(roleId !== 'none' && userId !== 'none') {
+    um_apicall_grant_role(userId, roleId, roleIsNew);
+  }
+}
+
+function um_revoke_role() {
+  var userId = um_get_first_selected_user_id();
+  var roleId = um_get_first_selected_userrole_id();
+  if(roleId !== 'none' && userId !== 'none') {
+    um_apicall_revoke_role(userId, roleId);
+  }
+}
+
 /* ----------- ui interaction ------------ */
 
 function um_user_list_click() {
   $('#nutzerLoeschen').prop( "disabled", false );
-  /*
-   var users = [];
-   $('#nutzerliste :selected').each(function(i, selected){
-     users[i] = $(selected).text();
-   });
-  */
-   //alert(users[0]);
+  $('#rollen :selected').prop("selected", false);
+  var userId = um_get_first_selected_user_id();
+  um_apicall_get_user_roles(userId);
+}
+
+function um_role_list_click() {
+  $('#rolleErteilen').prop( "disabled", false );
+}
+
+function um_user_role_list_click() {
+  $('#nutzerRolleEntziehen').prop( "disabled", false );
 }
 
 
@@ -71,15 +116,70 @@
     $("#nutzerliste").append('<option value=' + user.String + '>' + user.String + '</option>');
   }
   $('#nutzerLoeschen').prop( "disabled", true );
-  //var user1 = users.List[1];
-  //var username = user1.String;
-  //alert(username);
 }
 
 function um_clear_user_form() {
   $('#anmeldename').val('');
   $('#kennwort').val('');
   $('#kennwortw').val('');
+}
+
+function um_get_first_selected_user_id() {
+  var userId = 'none';
+  var userIds = [];
+  $('#nutzerliste :selected').each(function(i, selected){
+    userIds[i] = $(selected).text();
+  });
+  if(userIds.length > 0) {
+    userId = userIds[0];
+  }
+  return userId;
+}
+
+function um_get_first_selected_role_id() {
+  var roleId = 'none';
+  var roleIds = [];
+  $('#rollen :selected').each(function(i, selected){
+    roleIds[i] = $(selected).text();
+  });
+  if(roleIds.length > 0) {
+    roleId = roleIds[0];
+  }
+  return roleId;
+}
+
+function um_get_first_selected_userrole_id() {
+  var roleId = 'none';
+  var roleIds = [];
+  $('#nutzerrollen :selected').each(function(i, selected){
+    roleIds[i] = $(selected).text();
+  });
+  if(roleIds.length > 0) {
+    roleId = roleIds[0];
+  }
+  return roleId;
+}
+
+// {"List":[{"List":[{"String":"ROLE_NAME"},{"String":"testrolle1"}]}]}
+function um_show_user_role_list(resp) {
+  $("#nutzerrollen").empty();
+  var rollen = resp.List[0];
+  for(var i = 1; i < rollen.List.length; i++) {
+    var rolle = rollen.List[i];
+    $("#nutzerrollen").append('<option value=' + rolle.String + '>' + rolle.String + '</option>');
+  }
+  $('#nutzerRolleEntziehen').prop( "disabled", true );
+}
+
+function um_show_role_list(resp) {
+  $("#rollen").empty();
+  var rollen = resp.List[0];
+  for(var i = 1; i < rollen.List.length; i++) {
+    var rolle = rollen.List[i];
+    $("#rollen").append('<option value=' + rolle.String + '>' + rolle.String + '</option>');
+  }
+  //$('#neueRolle').prop( "disabled", true );
+  $('#rolleErteilen').prop( "disabled", true );
 }
 
 /* ---- api calls ----- */
@@ -149,6 +249,97 @@
   });      
 }
 
+// public UserRole grantRole(String userId, String roleName) 
+function um_apicall_grant_role(userId, roleName, isNewRole) {
+  var m = 'grantRole';
+  var u = '../svc/' + m;
+  $.ajax({
+    url: u,
+    data: {
+      p1: userId,
+      p2: roleName
+    },
+    type: "POST",
+    dataType : "html",
+    success: function( resp ) {
+      um_apicall_get_user_roles(userId);
+      if(isNewRole) {
+        um_apicall_get_granted_roles();
+      }
+    },
+    error: function( xhr, status, errorThrown ) {
+      $('#fehler').html("Error: " + errorThrown + " Status: " + status);
+    },
+    complete: function( xhr, status ) {
+      //alert( "The request is complete!" );
+    }
+  });
+}
+
+function um_apicall_revoke_role(userId, roleName) {
+  var m = 'revokeRole';
+  var u = '../svc/' + m;
+  $.ajax({
+    url: u,
+    data: {
+      p1: userId,
+      p2: roleName
+    },
+    type: "POST",
+    dataType : "html",
+    success: function( resp ) {
+      um_apicall_get_user_roles(userId);
+    },
+    error: function( xhr, status, errorThrown ) {
+      $('#fehler').html("Error: " + errorThrown + " Status: " + status);
+    },
+    complete: function( xhr, status ) {
+      //alert( "The request is complete!" );
+    }
+  });
+}
+
+//public List getUserRoleNames(String userId)
+function um_apicall_get_user_roles(userId) {
+  var m = 'getUserRoleNames';
+  var u = '../svc/' + m + '?p=' + userId;
+  $.ajax({
+    url: u,
+    type: "GET",
+    dataType : "json",
+    success: function( resp ) {
+      // Antwort in Liste anzeigen
+      um_show_user_role_list(resp);
+    },
+    error: function( xhr, status, errorThrown ) {
+      $('#fehler').html("Error: " + errorThrown + " Status: " + status);
+    },
+    complete: function( xhr, status ) {
+      //alert( "The request is complete!" );
+    }
+  });      
+}
+
+function um_apicall_get_granted_roles() {
+  var m = 'getRoleNamesGranted';
+  var u = '../svc/' + m;
+  $.ajax({
+    url: u,
+    type: "GET",
+    dataType : "json",
+    success: function( resp ) {
+      // Antwort in Liste anzeigen
+      um_show_role_list(resp);
+    },
+    error: function( xhr, status, errorThrown ) {
+      $('#fehler').html("Error: " + errorThrown + " Status: " + status);
+    },
+    complete: function( xhr, status ) {
+      //alert( "The request is complete!" );
+    }
+  });      
+}
+
 /* ----- Hilfsfunktionen ----- */
 
 function serialisieren(obj) {

--
Gitblit v1.9.3