/* * JBoss, Home of Professional Open Source. * Copyright 2013, Red Hat, Inc., and individual contributors * as indicated by the @author tags. See the copyright.txt file in the * distribution for a full listing of individual contributors. * * This is free software; you can redistribute it and/or modify it * under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation; either version 2.1 of * the License, or (at your option) any later version. * * This software 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 * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this software; if not, write to the Free * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA * 02110-1301 USA, or see the FSF site: http://www.fsf.org. */ package org.jboss.as.test.integration.mgmt.access; import java.io.IOException; import org.jboss.as.controller.PathAddress; import org.jboss.as.controller.PathElement; import org.jboss.as.controller.access.CombinationPolicy; import org.jboss.as.controller.access.rbac.StandardRole; import org.jboss.as.controller.client.ModelControllerClient; import org.jboss.as.controller.descriptions.ModelDescriptionConstants; import org.jboss.as.controller.operations.common.Util; import org.jboss.as.test.integration.management.rbac.Outcome; import org.jboss.as.test.integration.management.rbac.RbacUtil; import org.jboss.dmr.ModelNode; import org.junit.After; import org.junit.Before; import org.junit.Test; import org.junit.runner.RunWith; import org.wildfly.core.testrunner.WildflyTestRunner; /** * Test {@link org.jboss.as.controller.access.CombinationPolicy#REJECTING}. * * @author Brian Stansberry (c) 2013 Red Hat Inc. */ @RunWith(WildflyTestRunner.class) public class RejectingCombinationPolicyTestCase extends AbstractRbacTestCase { private static final PathAddress AC_ADDRESS = PathAddress.pathAddress(PathElement.pathElement(ModelDescriptionConstants.CORE_SERVICE, ModelDescriptionConstants.MANAGEMENT), PathElement.pathElement(ModelDescriptionConstants.ACCESS, ModelDescriptionConstants.AUTHORIZATION)); @Before public void setup() throws IOException { ModelNode op = Util.getWriteAttributeOperation(AC_ADDRESS, ModelDescriptionConstants.PERMISSION_COMBINATION_POLICY, new ModelNode(CombinationPolicy.REJECTING.toString())); RbacUtil.executeOperation(getManagementClient().getControllerClient(), op, Outcome.SUCCESS); } @After public void tearDown() throws IOException { ModelNode op = Util.createEmptyOperation(ModelDescriptionConstants.UNDEFINE_ATTRIBUTE_OPERATION, AC_ADDRESS); op.get(ModelDescriptionConstants.NAME).set(ModelDescriptionConstants.PERMISSION_COMBINATION_POLICY); RbacUtil.executeOperation(getManagementClient().getControllerClient(), op, Outcome.SUCCESS); } @Test public void testStandardRbac() throws IOException { ModelControllerClient client = getManagementClient().getControllerClient(); try { addMonitorUser(StandardRole.MONITOR, client); addMonitorUser(StandardRole.MAINTAINER, client); ModelNode op = Util.createEmptyOperation(ModelDescriptionConstants.READ_RESOURCE_OPERATION, PathAddress.EMPTY_ADDRESS); RbacUtil.executeOperation(getClientForUser(RbacUtil.MONITOR_USER), op, Outcome.FAILED); } finally { try { removeMonitorUser(StandardRole.MAINTAINER, client); } finally { removeMonitorUser(StandardRole.MONITOR, client); } } } @Test public void testRunAsRoles() throws IOException { ModelNode op = Util.createEmptyOperation(ModelDescriptionConstants.READ_RESOURCE_OPERATION, PathAddress.EMPTY_ADDRESS); ModelNode roles = op.get(ModelDescriptionConstants.OPERATION_HEADERS).get(ModelDescriptionConstants.ROLES); roles.add(RbacUtil.MONITOR_USER); roles.add(RbacUtil.SUPERUSER_ROLE); RbacUtil.executeOperation(getManagementClient().getControllerClient(), op, Outcome.FAILED); } private void addMonitorUser(StandardRole role, ModelControllerClient client) throws IOException { RbacUtil.addRoleMapping(role.getFormalName(), client); RbacUtil.addRoleUser(role.getFormalName(), RbacUtil.MONITOR_USER, client); } private void removeMonitorUser(StandardRole role, ModelControllerClient client) throws IOException { try { RbacUtil.removeRoleUser(role.getFormalName(), RbacUtil.MONITOR_USER, client); } finally { RbacUtil.removeRoleMapping(role.getFormalName(), client); } } }