/** * Waffle (https://github.com/Waffle/waffle) * * Copyright (c) 2010-2016 Application Security, Inc. * * All rights reserved. This program and the accompanying materials are made available under the terms of the Eclipse * Public License v1.0 which accompanies this distribution, and is available at * https://www.eclipse.org/legal/epl-v10.html. * * Contributors: Application Security, Inc. */ package waffle.shiro; import java.util.Collection; import java.util.HashMap; import java.util.HashSet; import java.util.Map; import java.util.Set; import org.apache.shiro.authz.AuthorizationInfo; import org.apache.shiro.authz.SimpleAuthorizationInfo; /** * A {@link org.apache.shiro.realm.Realm} that authenticates with Active Directory using WAFFLE and assigns roles to * users based on a mapping from their groups. To define permissions based on these roles, set a * {@link org.apache.shiro.authz.permission.RolePermissionResolver}. */ public class GroupMappingWaffleRealm extends AbstractWaffleRealm { /** The group roles map. */ private final Map<String, String> groupRolesMap = new HashMap<>(); /** * Sets the translation from group names to role names. If not set, the map is empty, resulting in no users getting * roles. * * @param value * the group roles map to set */ public void setGroupRolesMap(final Map<String, String> value) { this.groupRolesMap.clear(); if (value != null) { this.groupRolesMap.putAll(value); } } /** * This method is called by to translate group names to role names. This implementation uses the groupRolesMap to * map group names to role names. * * @param groupNames * the group names that apply to the current user * @return a collection of roles that are implied by the given role names * @see #setGroupRolesMap */ protected Collection<String> getRoleNamesForGroups(final Collection<String> groupNames) { final Set<String> roleNames = new HashSet<>(); for (final String groupName : groupNames) { final String roleName = this.groupRolesMap.get(groupName); if (roleName != null) { roleNames.add(roleName); } } return roleNames; } /** * Builds an {@link AuthorizationInfo} object based on the user's groups. The groups are translated to roles names * by using the configured groupRolesMap. * * @param principal * the principal of Subject that is being authorized * @return the AuthorizationInfo for the given Subject principal * * @see #setGroupRolesMap * @see #getRoleNamesForGroups */ @Override protected AuthorizationInfo buildAuthorizationInfo(final WaffleFqnPrincipal principal) { final SimpleAuthorizationInfo authorizationInfo = new SimpleAuthorizationInfo(); authorizationInfo.addRoles(this.getRoleNamesForGroups(principal.getGroupFqns())); return authorizationInfo; } }