All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.liferay.portal.kernel.service.RoleService Maven / Gradle / Ivy

There is a newer version: 7.4.3.112-ga112
Show newest version
/**
 * 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
 * @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 com.liferay.portal.service.impl.RoleServiceImpl and rerun ServiceBuilder to automatically copy the method declarations to this interface.
	 */

	/**
	 * 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 0)
	 * @param name the role's name
	 * @param titleMap the role's localized titles (optionally
	 null)
	 * @param descriptionMap the role's localized descriptions (optionally
	 null)
	 * @param type the role's type (optionally 0)
	 * @param subtype the role's subtype (optionally null)
	 * @param serviceContext the service context to be applied (optionally
	 null). Can set the expando bridge attributes for the
	 role.
	 * @return the role
	 */
	public Role addRole(
			String className, long classPK, String name,
			Map titleMap, Map descriptionMap,
			int type, String subtype, ServiceContext serviceContext)
		throws PortalException;

	/**
	 * 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;

	@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
	public Role fetchRole(long roleId) throws PortalException;

	/**
	 * 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 getGroupRoles(long groupId) throws PortalException;

	@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
	public List getGroupRolesAndTeamRoles(
		long companyId, String keywords, List excludedNames,
		int[] types, long excludedTeamRoleId, long teamGroupId, int start,
		int end);

	@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
	public int getGroupRolesAndTeamRolesCount(
		long companyId, String keywords, List excludedNames,
		int[] types, long excludedTeamRoleId, long teamGroupId);

	/**
	 * Returns the OSGi service identifier.
	 *
	 * @return the OSGi service identifier
	 */
	public String getOSGiServiceIdentifier();

	/**
	 * 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;

	/**
	 * Returns the role with the name in the company.
	 *
	 * 

* 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. *

* * @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, String name) throws PortalException; @Transactional(propagation = Propagation.SUPPORTS, readOnly = true) public List getRoles(int type, String subtype) throws PortalException; @Transactional(propagation = Propagation.SUPPORTS, readOnly = true) public List 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 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 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 null) * @return the union of all the user's roles within the groups */ @Transactional(propagation = Propagation.SUPPORTS, readOnly = true) public List getUserRelatedRoles(long userId, List 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 getUserRoles(long userId) throws PortalException; /** * Returns true 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 true if the user is associated with the regular role; false otherwise */ @Transactional(propagation = Propagation.SUPPORTS, readOnly = true) public boolean hasUserRole( long userId, long companyId, String name, boolean inherited) throws PortalException; /** * Returns true 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 true if the user has any one of the regular roles; false otherwise */ @Transactional(propagation = Propagation.SUPPORTS, readOnly = true) public boolean hasUserRoles( long userId, long companyId, String[] names, boolean inherited) throws PortalException; @Transactional(propagation = Propagation.SUPPORTS, readOnly = true) public List search( long companyId, String keywords, Integer[] types, LinkedHashMap params, int start, int end, OrderByComparator obc); @Transactional(propagation = Propagation.SUPPORTS, readOnly = true) public int searchCount( long companyId, String keywords, Integer[] types, LinkedHashMap params); /** * 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; /** * 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 null) to replace those existing for the role * @param descriptionMap the new localized descriptions (optionally null) to replace those existing for the role * @param subtype the role's new subtype (optionally null) * @param serviceContext the service context to be applied (optionally null). Can set the expando bridge attributes for the role. * @return the role with the primary key */ public Role updateRole( long roleId, String name, Map titleMap, Map descriptionMap, String subtype, ServiceContext serviceContext) throws PortalException; }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy