/* * Copyright 2016 Red Hat, Inc. and/or its affiliates. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package org.uberfire.ext.security.management.client.widgets.management.editor.user; import java.util.Iterator; import java.util.Set; import javax.enterprise.context.Dependent; import javax.enterprise.event.Event; import javax.inject.Inject; import org.jboss.errai.security.shared.api.Role; import org.jboss.errai.security.shared.api.identity.User; import org.uberfire.ext.security.management.api.Capability; import org.uberfire.ext.security.management.client.ClientUserSystemManager; import org.uberfire.ext.security.management.client.resources.i18n.UsersManagementWidgetsConstants; import org.uberfire.ext.security.management.client.widgets.management.editor.AssignedEntitiesExplorer; import org.uberfire.ext.security.management.client.widgets.management.events.OnRemoveUserRoleEvent; import org.uberfire.ext.security.management.client.widgets.management.list.RolesList; import org.uberfire.ext.security.management.client.widgets.popup.ConfirmBox; /** * <p>Presenter class for user's assigned roles explorer widget.</p> * <p>It's considered an Editor due to it allows removing assigned user's roles.</p> * @since 0.8.0 */ @Dependent public class UserAssignedRolesExplorer extends UserAssignedEntitiesExplorer<Role> implements org.uberfire.ext.security.management.client.editor.user.UserAssignedRolesExplorer { Event<OnRemoveUserRoleEvent> removeUserRoleEvent; @Inject public UserAssignedRolesExplorer(final ClientUserSystemManager userSystemManager, final ConfirmBox confirmBox, final RolesList rolesList, final AssignedEntitiesExplorer view, final Event<OnRemoveUserRoleEvent> removeUserRoleEvent) { super(userSystemManager, confirmBox, rolesList, view); this.removeUserRoleEvent = removeUserRoleEvent; } @Override protected String getEmptyText() { return UsersManagementWidgetsConstants.INSTANCE.userHasNoRoles(); } @Override protected String getEntityType() { return UsersManagementWidgetsConstants.INSTANCE.rolesAssigned(); } @Override protected String getTitle() { return null; } @Override protected String getEntityId(final Role entity) { return entity.getName(); } @Override protected String getEntityName(final Role entity) { return entity.getName(); } @Override protected String getEnsureRemoveText() { return UsersManagementWidgetsConstants.INSTANCE.ensureRemoveRoleFromUser(); } @Override protected boolean canAssignEntities() { final boolean canAssignRoles = userSystemManager.isUserCapabilityEnabled(Capability.CAN_ASSIGN_ROLES); return isEditMode && canAssignRoles; } @Override protected void open(final User user) { final Set<Role> uRoles = user.getRoles(); for (final Role _role : uRoles) { this.entities.add(_role); } super.open(user); } @Override protected void doShow() { entitiesList.show(this.entities, getCallback()); } @Override protected void removeEntity(String name) { // Remove the role from the local cache. Iterator<Role> roles = this.entities.iterator(); while (roles.hasNext()) { final Role g = roles.next(); if (g.getName().equals(name)) { roles.remove(); } } // Reload view. doShow(); // Fire the event for any others components listening. removeUserRoleEvent.fire(new OnRemoveUserRoleEvent(UserAssignedRolesExplorer.this, name)); } }