/*
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You 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.apache.catalina.mbeans;

import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;

import javax.management.MalformedObjectNameException;
import javax.management.ObjectName;

import org.apache.catalina.Group;
import org.apache.catalina.Role;
import org.apache.catalina.User;
import org.apache.catalina.UserDatabase;
import org.apache.tomcat.util.modeler.BaseModelMBean;
import org.apache.tomcat.util.modeler.ManagedBean;
import org.apache.tomcat.util.modeler.Registry;
import org.apache.tomcat.util.res.StringManager;

A ModelMBean implementation for the org.apache.catalina.users.MemoryUserDatabase component.

Author:Craig R. McClanahan
/** * <p>A <strong>ModelMBean</strong> implementation for the * <code>org.apache.catalina.users.MemoryUserDatabase</code> component.</p> * * @author Craig R. McClanahan */
public class MemoryUserDatabaseMBean extends BaseModelMBean { private static final StringManager sm = StringManager.getManager(MemoryUserDatabaseMBean.class); // ----------------------------------------------------- Instance Variables
The configuration information registry for our managed beans.
/** * The configuration information registry for our managed beans. */
protected final Registry registry = MBeanUtils.createRegistry();
The ManagedBean information describing this MBean.
/** * The <code>ManagedBean</code> information describing this MBean. */
protected final ManagedBean managed = registry.findManagedBean("MemoryUserDatabase");
The ManagedBean information describing Group MBeans.
/** * The <code>ManagedBean</code> information describing Group MBeans. */
protected final ManagedBean managedGroup = registry.findManagedBean("Group");
The ManagedBean information describing Group MBeans.
/** * The <code>ManagedBean</code> information describing Group MBeans. */
protected final ManagedBean managedRole = registry.findManagedBean("Role");
The ManagedBean information describing User MBeans.
/** * The <code>ManagedBean</code> information describing User MBeans. */
protected final ManagedBean managedUser = registry.findManagedBean("User"); // ------------------------------------------------------------- Attributes
Returns:the MBean Names of all groups defined in this database.
/** * @return the MBean Names of all groups defined in this database. */
public String[] getGroups() { UserDatabase database = (UserDatabase) this.resource; List<String> results = new ArrayList<>(); Iterator<Group> groups = database.getGroups(); while (groups.hasNext()) { Group group = groups.next(); results.add(findGroup(group.getGroupname())); } return results.toArray(new String[0]); }
Returns:the MBean Names of all roles defined in this database.
/** * @return the MBean Names of all roles defined in this database. */
public String[] getRoles() { UserDatabase database = (UserDatabase) this.resource; List<String> results = new ArrayList<>(); Iterator<Role> roles = database.getRoles(); while (roles.hasNext()) { Role role = roles.next(); results.add(findRole(role.getRolename())); } return results.toArray(new String[0]); }
Returns:the MBean Names of all users defined in this database.
/** * @return the MBean Names of all users defined in this database. */
public String[] getUsers() { UserDatabase database = (UserDatabase) this.resource; List<String> results = new ArrayList<>(); Iterator<User> users = database.getUsers(); while (users.hasNext()) { User user = users.next(); results.add(findUser(user.getUsername())); } return results.toArray(new String[0]); } // ------------------------------------------------------------- Operations
Create a new Group and return the corresponding MBean Name.
Params:
  • groupname – Group name of the new group
  • description – Description of the new group
Returns:the new group object name
/** * Create a new Group and return the corresponding MBean Name. * * @param groupname Group name of the new group * @param description Description of the new group * @return the new group object name */
public String createGroup(String groupname, String description) { UserDatabase database = (UserDatabase) this.resource; Group group = database.createGroup(groupname, description); try { MBeanUtils.createMBean(group); } catch (Exception e) { IllegalArgumentException iae = new IllegalArgumentException(sm.getString("userMBean.createMBeanError.group", groupname)); iae.initCause(e); throw iae; } return findGroup(groupname); }
Create a new Role and return the corresponding MBean Name.
Params:
  • rolename – Group name of the new group
  • description – Description of the new group
Returns:the new role object name
/** * Create a new Role and return the corresponding MBean Name. * * @param rolename Group name of the new group * @param description Description of the new group * @return the new role object name */
public String createRole(String rolename, String description) { UserDatabase database = (UserDatabase) this.resource; Role role = database.createRole(rolename, description); try { MBeanUtils.createMBean(role); } catch (Exception e) { IllegalArgumentException iae = new IllegalArgumentException(sm.getString("userMBean.createMBeanError.role", rolename)); iae.initCause(e); throw iae; } return findRole(rolename); }
Create a new User and return the corresponding MBean Name.
Params:
  • username – User name of the new user
  • password – Password for the new user
  • fullName – Full name for the new user
Returns:the new user object name
/** * Create a new User and return the corresponding MBean Name. * * @param username User name of the new user * @param password Password for the new user * @param fullName Full name for the new user * @return the new user object name */
public String createUser(String username, String password, String fullName) { UserDatabase database = (UserDatabase) this.resource; User user = database.createUser(username, password, fullName); try { MBeanUtils.createMBean(user); } catch (Exception e) { IllegalArgumentException iae = new IllegalArgumentException(sm.getString("userMBean.createMBeanError.user", username)); iae.initCause(e); throw iae; } return findUser(username); }
Return the MBean Name for the specified group name (if any); otherwise return null.
Params:
  • groupname – Group name to look up
Returns:the group object name
/** * Return the MBean Name for the specified group name (if any); * otherwise return <code>null</code>. * * @param groupname Group name to look up * @return the group object name */
public String findGroup(String groupname) { UserDatabase database = (UserDatabase) this.resource; Group group = database.findGroup(groupname); if (group == null) { return null; } try { ObjectName oname = MBeanUtils.createObjectName(managedGroup.getDomain(), group); return oname.toString(); } catch (MalformedObjectNameException e) { IllegalArgumentException iae = new IllegalArgumentException(sm.getString("userMBean.createError.group", groupname)); iae.initCause(e); throw iae; } }
Return the MBean Name for the specified role name (if any); otherwise return null.
Params:
  • rolename – Role name to look up
Returns:the role object name
/** * Return the MBean Name for the specified role name (if any); * otherwise return <code>null</code>. * * @param rolename Role name to look up * @return the role object name */
public String findRole(String rolename) { UserDatabase database = (UserDatabase) this.resource; Role role = database.findRole(rolename); if (role == null) { return null; } try { ObjectName oname = MBeanUtils.createObjectName(managedRole.getDomain(), role); return oname.toString(); } catch (MalformedObjectNameException e) { IllegalArgumentException iae = new IllegalArgumentException(sm.getString("userMBean.createError.role", rolename)); iae.initCause(e); throw iae; } }
Return the MBean Name for the specified user name (if any); otherwise return null.
Params:
  • username – User name to look up
Returns:the user object name
/** * Return the MBean Name for the specified user name (if any); * otherwise return <code>null</code>. * * @param username User name to look up * @return the user object name */
public String findUser(String username) { UserDatabase database = (UserDatabase) this.resource; User user = database.findUser(username); if (user == null) { return null; } try { ObjectName oname = MBeanUtils.createObjectName(managedUser.getDomain(), user); return oname.toString(); } catch (MalformedObjectNameException e) { IllegalArgumentException iae = new IllegalArgumentException(sm.getString("userMBean.createError.user", username)); iae.initCause(e); throw iae; } }
Remove an existing group and destroy the corresponding MBean.
Params:
  • groupname – Group name to remove
/** * Remove an existing group and destroy the corresponding MBean. * * @param groupname Group name to remove */
public void removeGroup(String groupname) { UserDatabase database = (UserDatabase) this.resource; Group group = database.findGroup(groupname); if (group == null) { return; } try { MBeanUtils.destroyMBean(group); database.removeGroup(group); } catch (Exception e) { IllegalArgumentException iae = new IllegalArgumentException(sm.getString("userMBean.destroyError.group", groupname)); iae.initCause(e); throw iae; } }
Remove an existing role and destroy the corresponding MBean.
Params:
  • rolename – Role name to remove
/** * Remove an existing role and destroy the corresponding MBean. * * @param rolename Role name to remove */
public void removeRole(String rolename) { UserDatabase database = (UserDatabase) this.resource; Role role = database.findRole(rolename); if (role == null) { return; } try { MBeanUtils.destroyMBean(role); database.removeRole(role); } catch (Exception e) { IllegalArgumentException iae = new IllegalArgumentException(sm.getString("userMBean.destroyError.role", rolename)); iae.initCause(e); throw iae; } }
Remove an existing user and destroy the corresponding MBean.
Params:
  • username – User name to remove
/** * Remove an existing user and destroy the corresponding MBean. * * @param username User name to remove */
public void removeUser(String username) { UserDatabase database = (UserDatabase) this.resource; User user = database.findUser(username); if (user == null) { return; } try { MBeanUtils.destroyMBean(user); database.removeUser(user); } catch (Exception e) { IllegalArgumentException iae = new IllegalArgumentException(sm.getString("userMBean.destroyError.user", username)); iae.initCause(e); throw iae; } } }