/**
* Copyright (c) 2000-present Liferay, Inc. All rights reserved.
*
* This library 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 library 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.
*/
package com.liferay.portal.kernel.service;
import aQute.bnd.annotation.ProviderType;
import com.liferay.portal.kernel.exception.PortalException;
import com.liferay.portal.kernel.exception.SystemException;
import com.liferay.portal.kernel.jsonwebservice.JSONWebService;
import com.liferay.portal.kernel.model.Group;
import com.liferay.portal.kernel.model.Role;
import com.liferay.portal.kernel.security.access.control.AccessControlled;
import com.liferay.portal.kernel.transaction.Isolation;
import com.liferay.portal.kernel.transaction.Propagation;
import com.liferay.portal.kernel.transaction.Transactional;
import com.liferay.portal.kernel.util.OrderByComparator;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Locale;
import java.util.Map;
/**
* Provides the remote service interface for Role. Methods of this
* service are expected to have security checks based on the propagated JAAS
* credentials because this service can be accessed remotely.
*
* @author Brian Wing Shun Chan
* @see RoleServiceUtil
* @see com.liferay.portal.service.base.RoleServiceBaseImpl
* @see com.liferay.portal.service.impl.RoleServiceImpl
* @generated
*/
@AccessControlled
@JSONWebService
@ProviderType
@Transactional(isolation = Isolation.PORTAL, rollbackFor = {
PortalException.class, SystemException.class})
public interface RoleService extends BaseService {
/*
* NOTE FOR DEVELOPERS:
*
* Never modify or reference this interface directly. Always use {@link RoleServiceUtil} to access the role remote service. Add custom service methods to {@link com.liferay.portal.service.impl.RoleServiceImpl} and rerun ServiceBuilder to automatically copy the method declarations to this interface.
*/
/**
* Returns <code>true</code> if the user is associated with the named
* regular role.
*
* @param userId the primary key of the user
* @param companyId the primary key of the company
* @param name the name of the role
* @param inherited whether to include the user's inherited roles in the
search
* @return <code>true</code> if the user is associated with the regular
role; <code>false</code> otherwise
*/
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public boolean hasUserRole(long userId, long companyId,
java.lang.String name, boolean inherited) throws PortalException;
/**
* Returns <code>true</code> if the user has any one of the named regular
* roles.
*
* @param userId the primary key of the user
* @param companyId the primary key of the company
* @param names the names of the roles
* @param inherited whether to include the user's inherited roles in the
search
* @return <code>true</code> if the user has any one of the regular roles;
<code>false</code> otherwise
*/
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public boolean hasUserRoles(long userId, long companyId,
java.lang.String[] names, boolean inherited) throws PortalException;
/**
* Adds a role. The user is reindexed after role is added.
*
* @param className the name of the class for which the role is created
* @param classPK the primary key of the class for which the role is
created (optionally <code>0</code>)
* @param name the role's name
* @param titleMap the role's localized titles (optionally
<code>null</code>)
* @param descriptionMap the role's localized descriptions (optionally
<code>null</code>)
* @param type the role's type (optionally <code>0</code>)
* @param subtype the role's subtype (optionally <code>null</code>)
* @param serviceContext the service context to be applied (optionally
<code>null</code>). Can set the expando bridge attributes for the
role.
* @return the role
*/
public Role addRole(java.lang.String className, long classPK,
java.lang.String name, Map<Locale, java.lang.String> titleMap,
Map<Locale, java.lang.String> descriptionMap, int type,
java.lang.String subtype, ServiceContext serviceContext)
throws PortalException;
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public Role fetchRole(long roleId) throws PortalException;
/**
* Returns the role with the name in the company.
*
* <p>
* The method searches the system roles map first for default roles. If a
* role with the name is not found, then the method will query the database.
* </p>
*
* @param companyId the primary key of the company
* @param name the role's name
* @return the role with the name
*/
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public Role getRole(long companyId, java.lang.String name)
throws PortalException;
/**
* Returns the role with the primary key.
*
* @param roleId the primary key of the role
* @return the role with the primary key
*/
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public Role getRole(long roleId) throws PortalException;
/**
* Updates the role with the primary key.
*
* @param roleId the primary key of the role
* @param name the role's new name
* @param titleMap the new localized titles (optionally <code>null</code>)
to replace those existing for the role
* @param descriptionMap the new localized descriptions (optionally
<code>null</code>) to replace those existing for the role
* @param subtype the role's new subtype (optionally <code>null</code>)
* @param serviceContext the service context to be applied (optionally
<code>null</code>). Can set the expando bridge attributes for the
role.
* @return the role with the primary key
*/
public Role updateRole(long roleId, java.lang.String name,
Map<Locale, java.lang.String> titleMap,
Map<Locale, java.lang.String> descriptionMap, java.lang.String subtype,
ServiceContext serviceContext) throws PortalException;
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public int getGroupRolesAndTeamRolesCount(long companyId,
java.lang.String keywords, List<java.lang.String> excludedNames,
int[] types, long excludedTeamRoleId, long teamGroupId);
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public int searchCount(long companyId, java.lang.String keywords,
java.lang.Integer[] types,
LinkedHashMap<java.lang.String, java.lang.Object> params);
/**
* Returns the OSGi service identifier.
*
* @return the OSGi service identifier
*/
public java.lang.String getOSGiServiceIdentifier();
/**
* Returns all the roles associated with the group.
*
* @param groupId the primary key of the group
* @return the roles associated with the group
*/
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public List<Role> getGroupRoles(long groupId) throws PortalException;
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public List<Role> getGroupRolesAndTeamRoles(long companyId,
java.lang.String keywords, List<java.lang.String> excludedNames,
int[] types, long excludedTeamRoleId, long teamGroupId, int start,
int end);
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public List<Role> getRoles(int type, java.lang.String subtype)
throws PortalException;
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public List<Role> getRoles(long companyId, int[] types)
throws PortalException;
/**
* Returns all the user's roles within the user group.
*
* @param userId the primary key of the user
* @param groupId the primary key of the group
* @return the user's roles within the user group
*/
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public List<Role> getUserGroupGroupRoles(long userId, long groupId)
throws PortalException;
/**
* Returns all the user's roles within the user group.
*
* @param userId the primary key of the user
* @param groupId the primary key of the group
* @return the user's roles within the user group
*/
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public List<Role> getUserGroupRoles(long userId, long groupId)
throws PortalException;
/**
* Returns the union of all the user's roles within the groups.
*
* @param userId the primary key of the user
* @param groups the groups (optionally <code>null</code>)
* @return the union of all the user's roles within the groups
*/
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public List<Role> getUserRelatedRoles(long userId, List<Group> groups)
throws PortalException;
/**
* Returns all the roles associated with the user.
*
* @param userId the primary key of the user
* @return the roles associated with the user
*/
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public List<Role> getUserRoles(long userId) throws PortalException;
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public List<Role> search(long companyId, java.lang.String keywords,
java.lang.Integer[] types,
LinkedHashMap<java.lang.String, java.lang.Object> params, int start,
int end, OrderByComparator<Role> obc);
/**
* Adds the roles to the user. The user is reindexed after the roles are
* added.
*
* @param userId the primary key of the user
* @param roleIds the primary keys of the roles
*/
public void addUserRoles(long userId, long[] roleIds)
throws PortalException;
/**
* Deletes the role with the primary key and its associated permissions.
*
* @param roleId the primary key of the role
*/
public void deleteRole(long roleId) throws PortalException;
/**
* Removes the matching roles associated with the user. The user is
* reindexed after the roles are removed.
*
* @param userId the primary key of the user
* @param roleIds the primary keys of the roles
*/
public void unsetUserRoles(long userId, long[] roleIds)
throws PortalException;
}