]> git.argeo.org Git - lgpl/argeo-commons.git/blobdiff - security/plugins/org.argeo.security.ui.admin/src/main/java/org/argeo/security/ui/admin/commands/AddRole.java
Remove old interfaces
[lgpl/argeo-commons.git] / security / plugins / org.argeo.security.ui.admin / src / main / java / org / argeo / security / ui / admin / commands / AddRole.java
index e8825bce302c8e71b9f501cda3035a20b80ebbc6..d550484fcf0c0d5cdd578faebdebd2f894b5735f 100644 (file)
@@ -1,17 +1,20 @@
 package org.argeo.security.ui.admin.commands;
 
 import org.argeo.ArgeoException;
-import org.argeo.security.ArgeoSecurityService;
+import org.argeo.security.UserAdminService;
+import org.argeo.security.ui.admin.editors.ArgeoUserEditor;
 import org.argeo.security.ui.admin.views.RolesView;
 import org.eclipse.core.commands.AbstractHandler;
 import org.eclipse.core.commands.ExecutionEvent;
 import org.eclipse.core.commands.ExecutionException;
+import org.eclipse.ui.IEditorReference;
+import org.eclipse.ui.IWorkbenchPage;
 import org.eclipse.ui.handlers.HandlerUtil;
 
 /** Add a new role. */
 public class AddRole extends AbstractHandler {
-       public final static String COMMAND_ID = "org.argeo.security.ui.addRole";
-       private ArgeoSecurityService securityService;
+       public final static String COMMAND_ID = "org.argeo.security.ui.admin.addRole";
+       private UserAdminService userAdminService;
        private String rolePrefix = "ROLE_";
 
        public Object execute(ExecutionEvent event) throws ExecutionException {
@@ -26,15 +29,26 @@ public class AddRole extends AbstractHandler {
                role = role.trim().toUpperCase();
                if (!role.startsWith(rolePrefix))
                        role = rolePrefix + role;
-               if (securityService.listEditableRoles().contains(role))
+               if (userAdminService.listEditableRoles().contains(role))
                        throw new ArgeoException("Role " + role + " already exists");
-               securityService.newRole(role);
+               userAdminService.newRole(role);
                rolesView.refresh();
+
+               // refresh editors
+               IEditorReference[] refs = HandlerUtil.getActiveWorkbenchWindow(event)
+                               .getActivePage()
+                               .findEditors(null, ArgeoUserEditor.ID, IWorkbenchPage.MATCH_ID);
+               for (IEditorReference ref : refs) {
+                       ArgeoUserEditor userEditor = (ArgeoUserEditor) ref.getEditor(false);
+                       if (userEditor != null) {
+                               userEditor.refresh();
+                       }
+               }
                return null;
        }
 
-       public void setSecurityService(ArgeoSecurityService securityService) {
-               this.securityService = securityService;
+       public void setUserAdminService(UserAdminService userAdminService) {
+               this.userAdminService = userAdminService;
        }
 
 }