001    /**
002     * Copyright 2005-2015 The Kuali Foundation
003     *
004     * Licensed under the Educational Community License, Version 2.0 (the "License");
005     * you may not use this file except in compliance with the License.
006     * You may obtain a copy of the License at
007     *
008     * http://www.opensource.org/licenses/ecl2.php
009     *
010     * Unless required by applicable law or agreed to in writing, software
011     * distributed under the License is distributed on an "AS IS" BASIS,
012     * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
013     * See the License for the specific language governing permissions and
014     * limitations under the License.
015     */
016    package org.kuali.rice.kim.api.role;
017    
018    import org.kuali.rice.core.api.criteria.QueryByCriteria;
019    import org.kuali.rice.core.api.delegation.DelegationType;
020    import org.kuali.rice.core.api.exception.RiceIllegalArgumentException;
021    import org.kuali.rice.core.api.exception.RiceIllegalStateException;
022    import org.kuali.rice.core.api.util.jaxb.MapStringStringAdapter;
023    import org.kuali.rice.kim.api.KimApiConstants;
024    import org.kuali.rice.kim.api.common.delegate.DelegateMember;
025    import org.kuali.rice.kim.api.common.delegate.DelegateType;
026    import org.kuali.rice.kim.api.permission.Permission;
027    import org.kuali.rice.kim.api.responsibility.Responsibility;
028    import org.springframework.cache.annotation.CacheEvict;
029    import org.springframework.cache.annotation.Cacheable;
030    
031    import javax.jws.WebMethod;
032    import javax.jws.WebParam;
033    import javax.jws.WebResult;
034    import javax.jws.WebService;
035    import javax.jws.soap.SOAPBinding;
036    import javax.xml.bind.annotation.XmlElement;
037    import javax.xml.bind.annotation.XmlElementWrapper;
038    import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
039    import java.util.Collection;
040    import java.util.List;
041    import java.util.Map;
042    import java.util.Set;
043    
044    /**
045     *
046     * This service provides operations for querying role and role qualification
047     * data.
048     *
049     * <p>A role is where permissions and responsibilities are granted.  Roles have
050     * a membership consisting of principals, groups or even other roles.  By
051     * being assigned as members of a role, the associated principals will be
052     * granted all permissions and responsibilities that have been granted to the
053     * role.
054     *
055     * <p>Each membership assignment on the role can have a qualification which
056     * defines extra information about that particular member of the role.  For
057     * example, one may have the role of "Dean" but that can be further qualified
058     * by the school they are the dean of, such as "Dean of Computer Science".
059     * Authorization checks that are then done in the permission service can pass
060     * qualifiers as part of the operation if they want to restrict the subset of
061     * the role against which the check is made.
062     *
063     * @author Kuali Rice Team (rice.collab@kuali.org)
064     *
065     */
066    @WebService(name = "roleService", targetNamespace = KimApiConstants.Namespaces.KIM_NAMESPACE_2_0 )
067    @SOAPBinding(style = SOAPBinding.Style.DOCUMENT, use = SOAPBinding.Use.LITERAL, parameterStyle = SOAPBinding.ParameterStyle.WRAPPED)
068    public interface RoleService {
069        /**
070         * This will create a {@link org.kuali.rice.kim.api.role.Role} exactly like the role passed in.
071         *
072         * @param role the role to create
073         * @return the newly created object.  will never be null.
074         * @throws RiceIllegalArgumentException if the role passed in is null
075         * @throws RiceIllegalStateException if the role is already existing in the system
076         */
077        @WebMethod(operationName="createRole")
078        @WebResult(name = "role")
079        @CacheEvict(value={Permission.Cache.NAME, Responsibility.Cache.NAME,  Role.Cache.NAME, RoleMembership.Cache.NAME, RoleMember.Cache.NAME, DelegateMember.Cache.NAME, RoleResponsibility.Cache.NAME, DelegateType.Cache.NAME}, allEntries = true)
080        Role createRole(@WebParam(name = "role") Role role)
081                throws RiceIllegalArgumentException, RiceIllegalStateException;
082    
083        /**
084         * This will update a {@link Role}.
085         *
086         * @param role the role to update
087         * @throws RiceIllegalArgumentException if the role is null
088         * @throws RiceIllegalStateException if the role does not exist in the system
089         */
090        @WebMethod(operationName="updateRole")
091        @WebResult(name = "role")
092        @CacheEvict(value={Permission.Cache.NAME, Responsibility.Cache.NAME, Role.Cache.NAME, RoleMembership.Cache.NAME, RoleMember.Cache.NAME, DelegateMember.Cache.NAME, RoleResponsibility.Cache.NAME, DelegateType.Cache.NAME}, allEntries = true)
093        Role updateRole(@WebParam(name = "role") Role role)
094                throws RiceIllegalArgumentException, RiceIllegalStateException;
095    
096            /**
097             * Get the KIM Role object with the given ID.
098             *
099         * @param id the id of the role.
100         * @return the role with the given id or null if role doesn't exist.
101         * @throws RiceIllegalArgumentException if roleId is null or Blank
102             */
103        @WebMethod(operationName = "getRole")
104        @WebResult(name = "role")
105        @Cacheable(value= Role.Cache.NAME, key="'id=' + #p0")
106        Role getRole(@WebParam(name = "id") String id) throws RiceIllegalArgumentException;
107    
108            /**
109             * Get the KIM Role objects for the role IDs in the given List.
110         *
111         * @param ids the ids of the roles.
112         * @return a list of roles with the given ids or null if no roles are found.
113         * @throws RiceIllegalArgumentException if ids is null or Blank
114             */
115        @WebMethod(operationName = "getRoles")
116        @XmlElementWrapper(name = "roles", required = true)
117        @XmlElement(name = "role", required = false)
118        @WebResult(name = "roles")
119        @Cacheable(value= Role.Cache.NAME, key="'ids=' + T(org.kuali.rice.core.api.cache.CacheKeyUtils).key(#p0)")
120            List<Role> getRoles( @WebParam(name="ids") List<String> ids ) throws RiceIllegalArgumentException;
121    
122            /** Get the KIM Role object with the unique combination of namespace, component,
123             * and role name.
124             *
125         * @param namespaceCode the namespace code of the role.
126         * @param name the name of the role.
127         * @return a role with the given namespace code and name or null if role does not exist.
128         * @throws RiceIllegalArgumentException if namespaceCode or name is null or blank.
129             */
130        @WebMethod(operationName = "getRoleByNamespaceCodeAndName")
131        @WebResult(name = "role")
132        @Cacheable(value=Role.Cache.NAME, key="'namespaceCode=' + #p0 + '|' + 'name=' + #p1")
133        Role getRoleByNamespaceCodeAndName(@WebParam(name = "namespaceCode") String namespaceCode,
134                @WebParam(name = "name") String name) throws RiceIllegalArgumentException;
135    
136            /**
137             * Return the Role ID for the given unique combination of namespace,
138             * component and role name.
139         *
140         * @param namespaceCode the namespace code of the role.
141         * @param name the name of the role.
142         * @return a role id for a role with the given namespace code and name or null if role does not exist.
143         * @throws RiceIllegalArgumentException if namespaceCode or name is null or blank.
144             */
145        @WebMethod(operationName = "getRoleIdByNamespaceCodeAndName")
146        @WebResult(name = "roleId")
147        @Cacheable(value=Role.Cache.NAME, key="'{getRoleIdByNamespaceCodeAndName}' + 'namespaceCode=' + #p0 + '|' + 'name=' + #p1")
148            String getRoleIdByNamespaceCodeAndName(@WebParam(name = "namespaceCode") String namespaceCode,
149                @WebParam(name = "name") String name) throws RiceIllegalArgumentException;
150    
151            /**
152             * Checks whether the role with the given role ID is active.
153             *
154             * @param id the unique id of a role.
155             * @return true if the role with the given id is active.
156         * @throws RiceIllegalArgumentException if id is null or blank.
157             */
158        @WebMethod(operationName = "isRoleActive")
159        @WebResult(name = "isRoleActive")
160        @Cacheable(value=Role.Cache.NAME, key="'{isRoleActive}' + 'id=' + #p0")
161        boolean isRoleActive( @WebParam(name="id") String id ) throws RiceIllegalArgumentException;
162    
163        /**
164         * Returns a list of role qualifiers that the given principal has without taking into consideration
165         * that the principal may be a member via an assigned group or role.  Use in situations where
166         * you are only interested in the qualifiers that are directly assigned to the principal.
167         *
168         * @param principalId the principalId to
169         * @param roleIds the namespace code of the role.
170         * @param qualification the qualifications for the roleIds.
171         * @return a map of role qualifiers for the given principalId, roleIds and qualifications or an empty map if none found.
172         * @throws RiceIllegalArgumentException if principalId is null or blank or roleIds is null.
173         */
174        @WebMethod(operationName = "getRoleQualifersForPrincipalByRoleIds")
175        @XmlElementWrapper(name = "attributes", required = true)
176        @XmlElement(name = "attribute", required = false)
177        @WebResult(name = "attributes")
178        @XmlJavaTypeAdapter(value = MapStringStringAdapter.class)
179        List<Map<String, String>> getRoleQualifersForPrincipalByRoleIds(@WebParam(name = "principalId") String principalId,
180                @WebParam(name = "roleIds") List<String> roleIds, @WebParam(name = "qualification") @XmlJavaTypeAdapter(
181                value = MapStringStringAdapter.class) Map<String, String> qualification)
182                throws RiceIllegalArgumentException;
183    
184        /**
185         * Returns a list of role qualifiers that the given principal has without taking into consideration
186         * that the principal may be a member via an assigned group or role.  Use in situations where
187         * you are only interested in the qualifiers that are directly assigned to the principal.
188         *
189         * @param principalId the principalId to
190         * @param namespaceCode the namespace code of the role.
191         * @param roleName the name of the role.
192         * @param qualification the qualifications for the roleIds.
193         * @return a map of role qualifiers for the given parameters or an empty map if none found.
194         * @throws RiceIllegalArgumentException if principalId, namespaceCode, or roleName is null or blank.
195         */
196        @WebMethod(operationName = "getRoleQualifersForPrincipalByNamespaceAndRolename")
197        @XmlElementWrapper(name = "attributes", required = true)
198        @XmlElement(name = "attribute", required = false)
199        @WebResult(name = "attributes")
200        @XmlJavaTypeAdapter(value = MapStringStringAdapter.class)
201        List<Map<String, String>> getRoleQualifersForPrincipalByNamespaceAndRolename(
202                @WebParam(name = "principalId") String principalId, @WebParam(name = "namespaceCode") String namespaceCode,
203                @WebParam(name = "roleName") String roleName, @WebParam(name = "qualification") @XmlJavaTypeAdapter(
204                value = MapStringStringAdapter.class) Map<String, String> qualification)
205                throws RiceIllegalArgumentException;
206    
207        /**
208         * Returns a list of role qualifiers that the given principal.  If the principal's membership
209         * is via a group or role, that group or role's qualifier on the given role is returned.
210         *
211         * @param principalId the principalId to
212         * @param namespaceCode the namespace code of the role.
213         * @param roleName the name of the role.
214         * @param qualification the qualifications for the roleIds.
215         * @return a map of nested role qualifiers for the given parameters or an empty map if none found.
216         * @throws RiceIllegalArgumentException if principalId, namespaceCode, or roleName is null or blank.
217         */
218        @WebMethod(operationName = "getNestedRoleQualifersForPrincipalByNamespaceAndRolename")
219        @XmlElementWrapper(name = "attributes", required = true)
220        @XmlElement(name = "attribute", required = false)
221        @WebResult(name = "attributes")
222        @XmlJavaTypeAdapter(value = MapStringStringAdapter.class)
223            List<Map<String, String>> getNestedRoleQualifersForPrincipalByNamespaceAndRolename(
224                @WebParam(name = "principalId") String principalId, @WebParam(name = "namespaceCode") String namespaceCode,
225                @WebParam(name = "roleName") String roleName, @WebParam(name = "qualification") @XmlJavaTypeAdapter(
226                value = MapStringStringAdapter.class) Map<String, String> qualification)
227                throws RiceIllegalArgumentException;
228    
229        /**
230         * Returns a list of role qualifiers that the given principal.  If the principal's membership
231         * is via a group or role, that group or role's qualifier on the given role is returned.
232         *
233         * @param principalId the principalId to
234         * @param roleIds the namespace code of the role.
235         * @param qualification the qualifications for the roleIds.
236         * @return a map of role qualifiers for the given roleIds and qualifications or an empty map if none found.
237         * @throws RiceIllegalArgumentException if principalId, namespaceCode, or roleName is null or blank.
238         */
239        @WebMethod(operationName = "getNestedRoleQualifiersForPrincipalByRoleIds")
240        @XmlElementWrapper(name = "attributes", required = true)
241        @XmlElement(name = "attribute", required = false)
242        @WebResult(name = "attributes")
243        @XmlJavaTypeAdapter(value = MapStringStringAdapter.class)
244            List<Map<String, String>> getNestedRoleQualifiersForPrincipalByRoleIds(
245                @WebParam(name = "principalId") String principalId, @WebParam(name = "roleIds") List<String> roleIds,
246                @WebParam(name = "qualification") @XmlJavaTypeAdapter(
247                        value = MapStringStringAdapter.class) Map<String, String> qualification)
248                throws RiceIllegalArgumentException;
249    
250    
251        // --------------------
252        // Role Membership Checks
253        // --------------------
254    
255        /**
256         * Get all the role members (groups and principals) associated with the given list of roles
257         * where their role membership/assignment matches the given qualification.  The list of RoleMemberships returned
258         * will only contain group and principal members.  Any nested role members will be resolved and flattened into
259         * the principals and groups that are members of that nested role (assuming qualifications match).
260         *
261         * The return object will have each membership relationship along with the delegations
262         *
263         * @param roleIds a list of role Ids.
264         * @param qualification the qualifications for the roleIds.
265         * @return a list of role members for the given roleIds and qualifications or an empty list if none found.
266         * @throws RiceIllegalArgumentException if roleIds is null.
267         */
268        @WebMethod(operationName = "getRoleMembers")
269        @XmlElementWrapper(name = "roleMemberships", required = true)
270        @XmlElement(name = "roleMembership", required = false)
271        @WebResult(name = "roleMemberships")
272        @Cacheable(value= RoleMember.Cache.NAME,
273                   key="'roleIds=' + T(org.kuali.rice.core.api.cache.CacheKeyUtils).key(#p0) + '|' + 'qualification=' + T(org.kuali.rice.core.api.cache.CacheKeyUtils).mapKey(#p1)",
274                   condition="!T(org.kuali.rice.kim.api.cache.KimCacheUtils).isDynamicRoleMembership(#p0)" )
275        List<RoleMembership> getRoleMembers(
276                    @WebParam(name="roleIds")
277                    List<String> roleIds,
278                    @WebParam(name="qualification")
279                    @XmlJavaTypeAdapter(value = MapStringStringAdapter.class)
280                    Map<String, String> qualification )
281                throws RiceIllegalArgumentException;
282    
283        /**
284             * This method gets all the members, then traverses down into members of type role and group to obtain the nested principal ids
285             *
286         * @param namespaceCode the namespace code of the role.
287         * @param roleName the name of the role
288         * @param qualification the qualifications for the roleIds.
289         * @return a list of role member principalIds for the given roleIds and qualifications, or an empty list if none found.
290         * @throws RiceIllegalArgumentException if namespaceCode, or roleName is null or blank.
291             */
292        @WebMethod(operationName = "getRoleMemberPrincipalIds")
293        @XmlElementWrapper(name = "principalIds", required = true)
294        @XmlElement(name = "principalId", required = false)
295        @WebResult(name = "principalIds")
296        @Cacheable(value= RoleMember.Cache.NAME,
297                   key="'namespaceCode=' + #p0 + '|' + 'roleName=' + #p1 + '|' + 'qualification=' + T(org.kuali.rice.core.api.cache.CacheKeyUtils).mapKey(#p2)",
298                   condition="!T(org.kuali.rice.kim.api.cache.KimCacheUtils).isDynamicMembshipRoleByNamespaceAndName(#p0, #p1)" )
299        Collection<String> getRoleMemberPrincipalIds(@WebParam(name="namespaceCode") String namespaceCode,
300                    @WebParam(name="roleName") String roleName,
301                    @WebParam(name="qualification")
302                    @XmlJavaTypeAdapter(value = MapStringStringAdapter.class)
303                    Map<String, String> qualification)
304                throws RiceIllegalArgumentException;
305    
306        /**
307         * Returns whether the given principal has any of the passed role IDs with the given qualification.
308         *
309         * @param principalId the principal Id to check.
310         * @param roleIds the list of role ids.
311         * @param qualification the qualifications for the roleIds.
312         * @return true if the principal is assigned the one of the given roleIds with the passed in qualifications.
313         * @throws RiceIllegalArgumentException if roleIds is null or principalId is null or blank.
314         */
315        @WebMethod(operationName = "principalHasRole")
316        @WebResult(name = "principalHasRole")
317        boolean principalHasRole( @WebParam(name="principalId") String principalId,
318                @WebParam(name="roleIds") List<String> roleIds,
319                @WebParam(name="qualification") @XmlJavaTypeAdapter(value = MapStringStringAdapter.class) Map<String, String> qualification )
320                throws RiceIllegalArgumentException;
321        
322        /**
323         * Returns whether the given principal has any of the passed role IDs with the given qualification.
324         *
325         * @param principalId the principal Id to check.
326         * @param roleIds the list of role ids.
327         * @param qualification the qualifications for the roleIds.
328         * @param checkDelegations whether delegations should be checked or not
329         * @return true if the principal is assigned the one of the given roleIds with the passed in qualifications.
330         * @throws RiceIllegalArgumentException if roleIds is null or principalId is null or blank.
331         * @since 2.1.1
332         */
333        @WebMethod(operationName = "principalHasRoleCheckDelegation")
334        @WebResult(name = "principalHasRoleCheckDelegation")
335        boolean principalHasRole( @WebParam(name="principalId") String principalId,
336                @WebParam(name="roleIds") List<String> roleIds,
337                @WebParam(name="qualification") @XmlJavaTypeAdapter(value = MapStringStringAdapter.class) Map<String, String> qualification, boolean checkDelegations)
338                throws RiceIllegalArgumentException;
339    
340        /**
341         * Returns the subset of the given principal ID list which has the given role and qualification.
342         * This is designed to be used by lookups of people by their roles.
343         *
344         * @param principalIds the principal Ids to check.
345         * @param roleNamespaceCode the namespaceCode of the role.
346         * @param roleName the name of the role.
347         * @param qualification the qualifications for the roleIds.
348         * @return list of principalIds that is the subset of list passed in with the given role and qualifications or an empty list.
349         * @throws RiceIllegalArgumentException if principalIds is null or the roleNamespaceCode or roleName is null or blank.
350         */
351        @WebMethod(operationName = "getPrincipalIdSubListWithRole")
352        @XmlElementWrapper(name = "principalIds", required = true)
353        @XmlElement(name = "principalId", required = false)
354        @WebResult(name = "principalIds")
355        @Cacheable(value= RoleMember.Cache.NAME,
356                   key="'getPrincipalIdSubListWithRole' + 'principalIds=' + T(org.kuali.rice.core.api.cache.CacheKeyUtils).key(#p0) + '|' + 'roleNamespaceCode=' + #p1 + '|' + 'roleName=' + #p2 + '|' + 'qualification=' + T(org.kuali.rice.core.api.cache.CacheKeyUtils).mapKey(#p3)",
357                condition="!T(org.kuali.rice.kim.api.cache.KimCacheUtils).isDynamicMembshipRoleByNamespaceAndName(#p1, #p2)" )
358                List<String> getPrincipalIdSubListWithRole( @WebParam(name="principalIds") List<String> principalIds,
359                @WebParam(name="roleNamespaceCode") String roleNamespaceCode,
360                @WebParam(name="roleName") String roleName,
361                @WebParam(name="qualification") @XmlJavaTypeAdapter(value = MapStringStringAdapter.class) Map<String, String> qualification )
362                throws RiceIllegalArgumentException;
363    
364        /**
365             *
366             * This method gets search results for role lookup
367         *
368         * @param queryByCriteria the qualifications for the roleIds.
369         * @return query results.  will never return null.
370         * @throws RiceIllegalArgumentException if queryByCriteria is null.
371             */
372        @WebMethod(operationName = "getRolesSearchResults")
373        @WebResult(name = "results")
374            RoleQueryResults findRoles(@WebParam(name = "query") QueryByCriteria queryByCriteria) throws RiceIllegalArgumentException;
375    
376    
377    
378        /**
379         * Gets all direct members of the roles that have ids within the given list
380         * of role ids.  This method does not recurse into any nested roles.
381         *
382         *  <p>The resulting List of role membership will contain membership for
383         *  all the roles with the specified ids.  The list is not guaranteed to be
384         *  in any particular order and may have membership info for the
385         *  different roles interleaved with each other.
386         *
387         * @param roleIds a list of  role Ids.
388         * @return list of RoleMembership that contains membership for the specified roleIds or empty list if none found.
389         * @throws RiceIllegalArgumentException if roleIds is null.
390         */
391        @WebMethod(operationName = "getFirstLevelRoleMembers")
392        @XmlElementWrapper(name = "roleMemberships", required = true)
393        @XmlElement(name = "roleMembership", required = false)
394        @WebResult(name = "roleMemberships")
395        @Cacheable(value=RoleMembership.Cache.NAME, key="'roleIds=' + T(org.kuali.rice.core.api.cache.CacheKeyUtils).key(#p0)")
396            List<RoleMembership> getFirstLevelRoleMembers(
397                    @WebParam(name="roleIds") List<String> roleIds) throws RiceIllegalArgumentException;
398    
399            /**
400             * Gets role member information based on the given search criteria.
401         *
402         * @param queryByCriteria the qualifications for the roleIds.
403         * @return query results.  will never return null.
404         * @throws RiceIllegalArgumentException if queryByCriteria is null.
405             */
406        @WebMethod(operationName = "findRoleMemberships")
407        @WebResult(name = "results")
408            RoleMembershipQueryResults findRoleMemberships(@WebParam(name = "query") QueryByCriteria queryByCriteria) throws RiceIllegalArgumentException;
409    
410            /**
411             * Gets a list of Roles that the given member belongs to.
412         *
413         * @param memberType the role member type.
414         * @param memberId the role member id (principalId, roleId, groupId).
415         * @return list of RoleMembership that contains membership for the specified roleIds or an empty list if none found.
416         * @throws RiceIllegalArgumentException if memberType or memberId is null or blank.
417             */
418        @WebMethod(operationName = "getMemberParentRoleIds")
419        @XmlElementWrapper(name = "roleIds", required = true)
420        @XmlElement(name = "roleId", required = false)
421        @WebResult(name = "roleIds")
422        @Cacheable(value=RoleMembership.Cache.NAME, key="'memberType=' + #p0 + '|' + 'memberId=' + #p1")
423            List<String> getMemberParentRoleIds(String memberType, String memberId) throws RiceIllegalArgumentException;
424    
425    
426        /**
427         * Gets role members based on the given search criteria.
428         *
429         * @param queryByCriteria the qualifications for the roleIds.
430         * @return query results.  will never return null.
431         * @throws RiceIllegalArgumentException if queryByCriteria is null.
432         */
433        @WebMethod(operationName = "findRoleMembers")
434        @WebResult(name = "results")
435            RoleMemberQueryResults findRoleMembers(@WebParam(name = "query") QueryByCriteria queryByCriteria) throws RiceIllegalArgumentException;
436    
437    
438        /**
439         * Gets a list of Roles Ids that are a member of the given roleId, including nested membership.
440         *
441         * @param roleId the role id.
442         * @return list of RoleIds that are members of the given role or and empty list if none found.
443         * @throws RiceIllegalArgumentException if roleId is null or blank.
444         */
445        @WebMethod(operationName = "getRoleTypeRoleMemberIds")
446        @XmlElementWrapper(name = "memberIds", required = true)
447        @XmlElement(name = "memberId", required = false)
448        @WebResult(name = "memberIds")
449        @Cacheable(value=RoleMember.Cache.NAME, key="'{getRoleTypeRoleMemberIds}' + 'roleId=' + #p0")
450        Set<String> getRoleTypeRoleMemberIds(@WebParam(name = "roleId") String roleId) throws RiceIllegalArgumentException;
451    
452    
453        /**
454         * Gets role members based on the given search criteria.
455         *
456         * @param queryByCriteria the qualifications for the roleIds.
457         * @return query results.  will never return null.
458         * @throws RiceIllegalArgumentException if queryByCriteria is null.
459         */
460        @WebMethod(operationName = "findDelegateMembers")
461        @WebResult(name = "results")
462        DelegateMemberQueryResults findDelegateMembers(@WebParam(name = "query") QueryByCriteria queryByCriteria) throws RiceIllegalArgumentException;
463    
464            /**
465             * Gets the delegate members for the given delegation.
466         *
467         * @param delegateId the delegate id.
468         * @return list of delegate members that are members of the given delegation or an empty list if none found.
469         * @throws RiceIllegalArgumentException if delegationId is null or blank.
470             */
471        @WebMethod(operationName = "getDelegationMembersByDelegationId")
472        @XmlElementWrapper(name = "delegateMembers", required = true)
473        @XmlElement(name = "delegateMember", required = false)
474        @WebResult(name = "delegateMembers")
475        @Cacheable(value=DelegateMember.Cache.NAME, key="'delegateId=' + #p0")
476        List<DelegateMember> getDelegationMembersByDelegationId(
477                @WebParam(name = "delegateId") String delegateId) throws RiceIllegalArgumentException;
478    
479    
480        /**
481         * Gets the delegate member for the given delegationId and memberId.
482         *
483         * @param delegationId the delegate id.
484         * @param memberId the member id matching the DelegateMember
485         * @return the delegate member with the given parameters or null if not found.
486         * @throws RiceIllegalArgumentException if delegationId or memberId is null or blank.
487         */
488        @WebMethod(operationName = "getDelegationMemberByDelegationAndMemberId")
489        @WebResult(name = "delegateMember")
490        @Cacheable(value=DelegateMember.Cache.NAME, key="'delegationId=' + #p0 + '|' + 'memberId=' + #p1")
491        DelegateMember getDelegationMemberByDelegationAndMemberId(
492                @WebParam(name = "delegationId") String delegationId, @WebParam(name = "memberId") String memberId) throws RiceIllegalArgumentException;
493    
494    
495        /**
496         * Gets the delegate member with the given delegation member id.
497         *
498         * @param id the member id matching the DelegateMember
499         * @return the delegate member with the given parameters or null if not found.
500         * @throws RiceIllegalArgumentException if delegationId or memberId is null or blank.
501         */
502        @WebMethod(operationName = "getDelegationMemberById")
503        @WebResult(name = "delegateMember")
504        @Cacheable(value=DelegateMember.Cache.NAME, key="'id=' + #p0")
505        DelegateMember getDelegationMemberById(@WebParam(name = "id") String id) throws RiceIllegalArgumentException;
506    
507    
508        /**
509         * Gets a list of role reponsibilities for the given role id.
510         *
511         * @param roleId the role Id.
512         * @return a list of RoleResponsibilities for the given role Id, or an empty list if none found.
513         * @throws RiceIllegalArgumentException if roleId is null or blank.
514         */
515        @WebMethod(operationName = "getRoleResponsibilities")
516        @XmlElementWrapper(name = "roleResponsibilities", required = true)
517        @XmlElement(name = "roleResponsibility", required = false)
518        @WebResult(name = "roleResponsibilities")
519        @Cacheable(value=RoleResponsibility.Cache.NAME, key="'roleId=' + #p0")
520            List<RoleResponsibility> getRoleResponsibilities(@WebParam(name="roleId") String roleId)  throws RiceIllegalArgumentException;
521    
522    
523        /**
524         * Gets a list of RoleResponsibilityActions for the given role member id.
525         *
526         * @param roleMemberId the role member Id.
527         * @return a list of RoleResponsibilityActions for the given role member Id, or an empty list if none found.
528         * @throws RiceIllegalArgumentException if roleMemberId is null or blank.
529         */
530        @WebMethod(operationName = "getRoleMemberResponsibilityActions")
531        @XmlElementWrapper(name = "roleResponsibilityActions", required = true)
532        @XmlElement(name = "roleResponsibilityAction", required = false)
533        @WebResult(name = "roleResponsibilityActions")
534        @Cacheable(value=RoleResponsibility.Cache.NAME, key="'roleMemberId=' + #p0")
535            List<RoleResponsibilityAction> getRoleMemberResponsibilityActions(
536                @WebParam(name = "roleMemberId") String roleMemberId)  throws RiceIllegalArgumentException;
537    
538    
539        /**
540         * Gets a DelegateType for the given role id and delegation type.
541         *
542         * @param roleId the role Id.
543         * @param delegateType type of delegation
544         * @return the DelegateType for the given role Id and delegationType, or null if none found.
545         * @throws RiceIllegalArgumentException if roleId or delegationType is null or blank.
546         */
547        @WebMethod(operationName = "getDelegateTypeByRoleIdAndDelegateTypeCode")
548        @WebResult(name = "delegateType")
549        @Cacheable(value=DelegateType.Cache.NAME, key="'roleId=' + #p0 + '|' + 'delegateType=' + #p1")
550        DelegateType getDelegateTypeByRoleIdAndDelegateTypeCode(@WebParam(name = "roleId") String roleId,
551                @WebParam(name = "delegateType") DelegationType delegateType)  throws RiceIllegalArgumentException;
552    
553    
554        /**
555         * Gets a DelegateType for the given delegation id.
556         *
557         * @param delegationId the id of delegation
558         * @return the DelegateType for the given delegation Id, or null if none found.
559         * @throws RiceIllegalArgumentException if delegationId is null or blank.
560         */
561        @WebMethod(operationName = "getDelegateTypeByDelegationId")
562        @WebResult(name = "delegateType")
563        @Cacheable(value=DelegateType.Cache.NAME, key="'delegationId=' + #p0")
564        DelegateType getDelegateTypeByDelegationId(@WebParam(name = "delegationId") String delegationId)  throws RiceIllegalArgumentException;
565    
566        /**
567             * Assigns the principal with the given id to the role with the specified
568             * namespace code and name with the supplied set of qualifications.
569         *
570         * @param principalId the principalId
571         * @param namespaceCode the namespaceCode of the Role
572         * @param roleName the name of the role
573         * @param qualifications the qualifications for the principalId to be assigned to the role
574         * @return newly created/assigned RoleMember.
575         * @throws RiceIllegalArgumentException if princialId, namespaceCode or roleName is null or blank.
576             */
577        @WebMethod(operationName = "assignPrincipalToRole")
578        @WebResult(name = "roleMember")
579        @CacheEvict(value={Role.Cache.NAME, Permission.Cache.NAME, Responsibility.Cache.NAME, RoleMembership.Cache.NAME, RoleMember.Cache.NAME, DelegateMember.Cache.NAME, RoleResponsibility.Cache.NAME, DelegateType.Cache.NAME }, allEntries = true)
580        RoleMember assignPrincipalToRole(@WebParam(name="principalId") String principalId,
581                    @WebParam(name="namespaceCode")
582                    String namespaceCode,
583                    @WebParam(name="roleName")
584                    String roleName,
585                    @WebParam(name="qualifications")
586                    @XmlJavaTypeAdapter(value = MapStringStringAdapter.class)
587                    Map<String, String> qualifications)
588                throws RiceIllegalArgumentException;
589    
590            /**
591             * Assigns the group with the given id to the role with the specified
592             * namespace code and name with the supplied set of qualifications.
593         *
594         * @param groupId the groupId
595         * @param namespaceCode the namespaceCode of the Role
596         * @param roleName the name of the role
597         * @param qualifications the qualifications for the principalId to be assigned to the role
598         * @return newly created/assigned RoleMember.
599         * @throws RiceIllegalArgumentException if groupId, namespaceCode or roleName is null or blank.
600             */
601        @WebMethod(operationName = "assignGroupToRole")
602        @WebResult(name = "roleMember")
603        @CacheEvict(value={Role.Cache.NAME, Permission.Cache.NAME, Responsibility.Cache.NAME, RoleMembership.Cache.NAME, RoleMember.Cache.NAME, DelegateMember.Cache.NAME, RoleResponsibility.Cache.NAME, DelegateType.Cache.NAME }, allEntries = true)
604        RoleMember assignGroupToRole(@WebParam(name="groupId") String groupId,
605                    @WebParam(name="namespaceCode") String namespaceCode,
606                    @WebParam(name="roleName") String roleName,
607                    @WebParam(name="qualifications") @XmlJavaTypeAdapter(value = MapStringStringAdapter.class) Map<String, String> qualifications)
608                throws RiceIllegalArgumentException;
609    
610            /**
611             * Assigns the role with the given id to the role with the specified
612             * namespace code and name with the supplied set of qualifications.
613         *
614         * @param roleId the roleId
615         * @param namespaceCode the namespaceCode of the Role
616         * @param roleName the name of the role
617         * @param qualifications the qualifications for the principalId to be assigned to the role
618         * @return newly created/assigned RoleMember.
619         * @throws RiceIllegalArgumentException if princiapId, namespaceCode or roleName is null or blank.
620             */
621        @WebMethod(operationName = "assignRoleToRole")
622        @WebResult(name = "roleMember")
623        @CacheEvict(value={Role.Cache.NAME, Permission.Cache.NAME, Responsibility.Cache.NAME, RoleMembership.Cache.NAME, RoleMember.Cache.NAME, DelegateMember.Cache.NAME, RoleResponsibility.Cache.NAME, DelegateType.Cache.NAME }, allEntries = true)
624        RoleMember assignRoleToRole(@WebParam(name="roleId") String roleId,
625                    @WebParam(name="namespaceCode") String namespaceCode,
626                    @WebParam(name="roleName") String roleName,
627                    @WebParam(name="qualifications") @XmlJavaTypeAdapter(value = MapStringStringAdapter.class) Map<String, String> qualifications)
628                throws RiceIllegalArgumentException;
629    
630            /**
631             * Creates a new RoleMember.  Needs to be passed a valid RoleMember object that does not currently exist.
632         *
633         * @param roleMember the new RoleMember to save.
634         * @return RoleMember as created.
635         * @throws RiceIllegalArgumentException if roleMember is null.
636         * @throws RiceIllegalStateException if roleMember already exists.
637             */
638        @WebMethod(operationName = "createRoleMember")
639        @WebResult(name = "roleMember")
640        @CacheEvict(value={Role.Cache.NAME, Permission.Cache.NAME, Responsibility.Cache.NAME, RoleMembership.Cache.NAME, RoleMember.Cache.NAME, DelegateMember.Cache.NAME, RoleResponsibility.Cache.NAME, DelegateType.Cache.NAME }, allEntries = true)
641        RoleMember createRoleMember(
642                    @WebParam(name = "roleMember")
643                    RoleMember roleMember) throws RiceIllegalArgumentException, RiceIllegalStateException;
644    
645        /**
646             * Updates the given roleMember to the values in the passed in roleMember
647         *
648         * @param roleMember the new RoleMember to save.
649         * @return RoleMember as updated.
650         * @throws RiceIllegalArgumentException if roleMember is null.
651         * @throws RiceIllegalStateException if roleMember does not yet exist.
652             */
653        @WebMethod(operationName = "updateRoleMember")
654        @WebResult(name = "roleMember")
655        @CacheEvict(value={Role.Cache.NAME, Permission.Cache.NAME, Responsibility.Cache.NAME, RoleMembership.Cache.NAME, RoleMember.Cache.NAME, DelegateMember.Cache.NAME, RoleResponsibility.Cache.NAME, DelegateType.Cache.NAME }, allEntries = true)
656        RoleMember updateRoleMember(@WebParam(name = "roleMember") RoleMember roleMember) throws RiceIllegalArgumentException, RiceIllegalStateException;
657    
658        /**
659         * Updates the given delegateMember to the values in the passed in delegateMember
660         *
661         * @param delegateMember the new DelegateMember to save.
662         * @return DelegateMember as updated.
663         * @throws RiceIllegalArgumentException if delegateMember is null.
664         * @throws RiceIllegalStateException if delegateMember does not yet exist.
665         */
666        @WebMethod(operationName = "updateDelegateMember")
667        @WebResult(name = "delegateMember")
668        @CacheEvict(value={Role.Cache.NAME, RoleMembership.Cache.NAME, RoleMember.Cache.NAME, DelegateMember.Cache.NAME, RoleResponsibility.Cache.NAME, DelegateType.Cache.NAME }, allEntries = true)
669        DelegateMember updateDelegateMember(@WebParam(name = "delegateMember") DelegateMember delegateMember) throws RiceIllegalArgumentException, RiceIllegalStateException;
670    
671        /**
672         * Creates a new DelegateMember.  Needs to be passed a valid DelegateMember object that does not currently exist.
673         *
674         * @param delegateMember the new DelegateMember to save.
675         * @return DelegateMember as created.
676         * @throws RiceIllegalArgumentException if delegateMember is null.
677         * @throws RiceIllegalStateException if delegateMember already exists.
678         */
679        @WebMethod(operationName = "createDelegateMember")
680        @WebResult(name = "delegateMember")
681        @CacheEvict(value={Role.Cache.NAME, RoleMembership.Cache.NAME, RoleMember.Cache.NAME, DelegateMember.Cache.NAME, RoleResponsibility.Cache.NAME, DelegateType.Cache.NAME }, allEntries = true)
682        DelegateMember createDelegateMember(
683                @WebParam(name = "delegateMember")
684                DelegateMember delegateMember) throws RiceIllegalArgumentException, RiceIllegalStateException;
685    
686        /**
687         * Removes existing DelegateMembers.  Needs to be passed DelegateMember objects.
688         *
689         * @param  DelegateMembers to remove.
690         * @throws RiceIllegalArgumentException if delegateMember is null.
691         */
692        @WebMethod(operationName = "removeDelegateMembers")
693        @CacheEvict(value={Role.Cache.NAME, RoleMembership.Cache.NAME, RoleMember.Cache.NAME, DelegateMember.Cache.NAME, RoleResponsibility.Cache.NAME, DelegateType.Cache.NAME }, allEntries = true)
694        void removeDelegateMembers(
695                @WebParam(name = "delegateMembers")
696                List<DelegateMember> delegateMembers) throws RiceIllegalArgumentException, RiceIllegalStateException;
697    
698        /**
699         * Creates a new RoleResponsibilityAction.  Needs to be passed a valid RoleResponsibilityAction
700         * object that does not currently exist.
701         *
702         * @param roleResponsibilityAction the new RoleResponsibilityAction to save.
703         * @return RoleResponsibilityAction as created.
704         * @throws RiceIllegalArgumentException if roleResponsibilityAction is null.
705         * @throws RiceIllegalStateException if roleResponsibilityAction already exists.
706         */
707        @WebMethod(operationName = "createRoleResponsibilityAction")
708        @CacheEvict(value={Permission.Cache.NAME, Responsibility.Cache.NAME, RoleMembership.Cache.NAME, RoleMember.Cache.NAME, DelegateMember.Cache.NAME, RoleResponsibility.Cache.NAME, DelegateType.Cache.NAME }, allEntries = true)
709        RoleResponsibilityAction createRoleResponsibilityAction(@WebParam(name = "roleResponsibilityAction") RoleResponsibilityAction roleResponsibilityAction) throws RiceIllegalArgumentException;
710    
711        /**
712         * Updates the given RoleResponsibilityAction to the values in the passed in roleResponsibilityAction
713         *
714         * @since 2.1.2
715         * @param roleResponsibilityAction the new RoleResponsibilityAction to save.
716         * @return RoleResponsibilityAction as updated.
717         * @throws RiceIllegalArgumentException if roleResponsibilityAction is null.
718         * @throws RiceIllegalStateException if roleResponsibilityAction does not exist.
719         */
720        @WebMethod(operationName = "updateRoleResponsibilityAction")
721        @CacheEvict(value={Permission.Cache.NAME, Responsibility.Cache.NAME, RoleMembership.Cache.NAME, RoleMember.Cache.NAME, DelegateMember.Cache.NAME, RoleResponsibility.Cache.NAME, DelegateType.Cache.NAME }, allEntries = true)
722        RoleResponsibilityAction updateRoleResponsibilityAction(@WebParam(name = "roleResponsibilityAction") RoleResponsibilityAction roleResponsibilityAction) throws RiceIllegalArgumentException;
723    
724        /**
725         * Deletes the given RoleResponsibilityAction
726         *
727         * @since 2.1.2
728         * @param roleResponsibilityActionId id of the RoleResponsibilityAction to delete.
729         * @throws RiceIllegalArgumentException if roleResponsibilityActionId is null.
730         * @throws RiceIllegalStateException if roleResponsibilityAction does not exist.
731         */
732        @WebMethod(operationName = "deleteRoleResponsibilityAction")
733        @CacheEvict(value={Permission.Cache.NAME, Responsibility.Cache.NAME, RoleMembership.Cache.NAME, RoleMember.Cache.NAME, DelegateMember.Cache.NAME, RoleResponsibility.Cache.NAME, DelegateType.Cache.NAME }, allEntries = true)
734        void deleteRoleResponsibilityAction(@WebParam(name = "roleResponsibilityActionId") String roleResponsibilityActionId) throws RiceIllegalArgumentException;
735    
736        /**
737         * Creates a new DelegateType.  Needs to be passed a valid DelegateType
738         * object that does not currently exist.
739         *
740         * @param delegateType the new DelegateType to save.
741         * @return DelegateType as created.
742         * @throws RiceIllegalArgumentException if delegateType is null.
743         * @throws RiceIllegalStateException if delegateType already exists.
744         */
745        @WebMethod(operationName = "createDelegateType")
746        @CacheEvict(value={Permission.Cache.NAME, Responsibility.Cache.NAME, RoleMembership.Cache.NAME, RoleMember.Cache.NAME, DelegateMember.Cache.NAME, RoleResponsibility.Cache.NAME, DelegateType.Cache.NAME }, allEntries = true)
747        DelegateType createDelegateType(@WebParam(name="delegateType") DelegateType delegateType) throws RiceIllegalArgumentException, RiceIllegalStateException;
748    
749        /**
750         * Updates the given DelegateType to the values in the passed in delegateType
751         *
752         * @param delegateType the new DelegateType to save.
753         * @return DelegateType as updated.
754         * @throws RiceIllegalArgumentException if delegateType is null.
755         * @throws RiceIllegalStateException if delegateType does not yet exist.
756         */
757        @WebMethod(operationName = "updateDelegateType")
758        @CacheEvict(value={Permission.Cache.NAME, Responsibility.Cache.NAME, RoleMembership.Cache.NAME, RoleMember.Cache.NAME, DelegateMember.Cache.NAME, RoleResponsibility.Cache.NAME, DelegateType.Cache.NAME }, allEntries = true)
759        DelegateType updateDelegateType(@WebParam(name="delegateType") DelegateType delegateType) throws RiceIllegalArgumentException, RiceIllegalStateException;
760    
761        /**
762         * Remove the principal with the given id and qualifications from the role
763         * with the specified namespace code and role name.
764         *
765         * @param principalId the principalId
766         * @param namespaceCode the namespaceCode of the Role
767         * @param roleName the name of the role
768         * @param qualifications the qualifications for the principalId to be assigned to the role
769         * @return void.
770         * @throws RiceIllegalArgumentException if principalId, namespaceCode or roleName is null or blank.
771         */
772        @WebMethod(operationName = "removePrincipalFromRole")
773        @CacheEvict(value={Role.Cache.NAME, Permission.Cache.NAME, Responsibility.Cache.NAME, RoleMembership.Cache.NAME, RoleMember.Cache.NAME, DelegateMember.Cache.NAME, RoleResponsibility.Cache.NAME, DelegateType.Cache.NAME }, allEntries = true)
774        void removePrincipalFromRole(@WebParam(name="principalId") String principalId,
775                    @WebParam(name="namespaceCode") String namespaceCode,
776                    @WebParam(name="roleName") String roleName,
777                    @WebParam(name="qualifications") @XmlJavaTypeAdapter(value = MapStringStringAdapter.class) Map<String, String> qualifications) throws RiceIllegalArgumentException;
778    
779        /**
780         * Remove the group with the given id and qualifications from the role
781         * with the specified namespace code and role name.
782         *
783         * @param groupId the groupId
784         * @param namespaceCode the namespaceCode of the Role
785         * @param roleName the name of the role
786         * @param qualifications the qualifications for the principalId to be assigned to the role
787         * @return void.
788         * @throws RiceIllegalArgumentException if groupId, namespaceCode or roleName is null or blank.
789         */
790        @WebMethod(operationName = "removeGroupFromRole")
791        @CacheEvict(value={Role.Cache.NAME, Permission.Cache.NAME, Responsibility.Cache.NAME, RoleMembership.Cache.NAME, RoleMember.Cache.NAME, DelegateMember.Cache.NAME, RoleResponsibility.Cache.NAME, DelegateType.Cache.NAME }, allEntries = true)
792        void removeGroupFromRole(@WebParam(name="groupId") String groupId,
793                    @WebParam(name="namespaceCode") String namespaceCode,
794                    @WebParam(name="roleName") String roleName,
795                    @WebParam(name="qualifications") @XmlJavaTypeAdapter(value = MapStringStringAdapter.class) Map<String, String> qualifications) throws RiceIllegalArgumentException;
796    
797        /**
798         * Remove the group with the given id and qualifications from the role
799         * with the specified namespace code and role name.
800         *
801         * @param roleId the roleId
802         * @param namespaceCode the namespaceCode of the Role
803         * @param roleName the name of the role
804         * @param qualifications the qualifications for the principalId to be assigned to the role
805         * @return void.
806         * @throws RiceIllegalArgumentException if roleId, namespaceCode or roleName is null or blank.
807         */
808        @WebMethod(operationName = "removeRoleFromRole")
809        @CacheEvict(value={Role.Cache.NAME, Permission.Cache.NAME, Responsibility.Cache.NAME, RoleMembership.Cache.NAME, RoleMember.Cache.NAME, DelegateMember.Cache.NAME, RoleResponsibility.Cache.NAME, DelegateType.Cache.NAME }, allEntries = true)
810        void removeRoleFromRole(@WebParam(name="roleId") String roleId,
811                    @WebParam(name="namespaceCode") String namespaceCode,
812                    @WebParam(name="roleName") String roleName,
813                    @WebParam(name="qualifications") @XmlJavaTypeAdapter(value = MapStringStringAdapter.class) Map<String, String> qualifications) throws RiceIllegalArgumentException;
814    
815        /**
816         * Assigns the given permission to the given role
817         *
818         * @param permissionId the permissionId
819         * @param roleId the roleId
820         * @return void.
821         * @throws RiceIllegalArgumentException if permissionId or roleId is null or blank.
822         */
823        @WebMethod(operationName = "assignPermissionToRole")
824        @CacheEvict(value={Role.Cache.NAME, Permission.Cache.NAME, Responsibility.Cache.NAME, RoleMembership.Cache.NAME, RoleMember.Cache.NAME, DelegateMember.Cache.NAME, RoleResponsibility.Cache.NAME, DelegateType.Cache.NAME }, allEntries = true)
825        void assignPermissionToRole(
826                @WebParam(name = "permissionId") String permissionId,
827                @WebParam(name = "roleId") String roleId)
828                throws RiceIllegalArgumentException;
829    
830        /**
831         * Removes the given permission to the given role
832         *
833         * @param permissionId the permissionId
834         * @param roleId the roleId
835         * @return void.
836         * @throws RiceIllegalArgumentException if permissionId or roleId is null or blank.
837         */
838        @WebMethod(operationName = "revokePermissionFromRole")
839        @CacheEvict(value={Role.Cache.NAME, Permission.Cache.NAME, Responsibility.Cache.NAME, RoleMembership.Cache.NAME, RoleMember.Cache.NAME, DelegateMember.Cache.NAME, RoleResponsibility.Cache.NAME, DelegateType.Cache.NAME }, allEntries = true)
840        void revokePermissionFromRole(
841                @WebParam(name = "permissionId") String permissionId,
842                @WebParam(name = "roleId") String roleId)
843                throws RiceIllegalArgumentException;
844    
845    
846        /**
847         * Determines if a role with a provided id is a derived role
848         *
849         * @since 2.1.1
850         * @param roleId the roleId
851         * @return true if role is a derived role
852         * @throws RiceIllegalArgumentException if roleId is null or blank.
853         */
854        @WebMethod(operationName = "isDerivedRole")
855        @WebResult(name = "isDerivedRole")
856        @Cacheable(value= Role.Cache.NAME, key="'{isDerivedRole}' + 'roleId=' + #p0")
857        boolean isDerivedRole(@WebParam(name = "roleId") String roleId) throws RiceIllegalArgumentException;
858    
859        /**
860         * Determines if a role with a provided id is a uses dynamic role memberships
861         *
862         * @since 2.1.1
863         * @param roleId the roleId
864         * @return true if role uses dynamic memberships
865         * @throws RiceIllegalArgumentException if roleId is null or blank.
866         */
867        @WebMethod(operationName = "isDynamicRoleMembership")
868        @WebResult(name = "isDynamicRoleMembership")
869        @Cacheable(value= Role.Cache.NAME, key="'{isDynamicRoleMembership}' + 'roleId=' + #p0")
870        boolean isDynamicRoleMembership(@WebParam(name = "roleId") String roleId) throws RiceIllegalArgumentException;
871    }