org.keycloak.admin.client.resource.RoleResource Maven / Gradle / Ivy
/*
* Copyright 2016 Red Hat, Inc. and/or its affiliates
* and other contributors as indicated by the @author tags.
*
* Licensed 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.keycloak.admin.client.resource;
import org.keycloak.representations.idm.GroupRepresentation;
import org.keycloak.representations.idm.ManagementPermissionReference;
import org.keycloak.representations.idm.ManagementPermissionRepresentation;
import org.keycloak.representations.idm.RoleRepresentation;
import org.keycloak.representations.idm.UserRepresentation;
import jakarta.ws.rs.Consumes;
import jakarta.ws.rs.DELETE;
import jakarta.ws.rs.GET;
import jakarta.ws.rs.POST;
import jakarta.ws.rs.PUT;
import jakarta.ws.rs.Path;
import jakarta.ws.rs.PathParam;
import jakarta.ws.rs.Produces;
import jakarta.ws.rs.QueryParam;
import jakarta.ws.rs.core.MediaType;
import java.util.List;
import java.util.Set;
/**
* @author [email protected]
*/
public interface RoleResource {
/**
* Enables or disables the fine grain permissions feature.
* Returns the updated status of the server in the
* {@link ManagementPermissionReference}.
*
* @param status status request to apply
* @return permission reference indicating the updated status
*/
@PUT
@Path("/management/permissions")
@Consumes(MediaType.APPLICATION_JSON)
@Produces(MediaType.APPLICATION_JSON)
ManagementPermissionReference setPermissions(ManagementPermissionRepresentation status);
/**
* Returns indicator if the fine grain permissions are enabled or not.
*
* @return current representation of the permissions feature
*/
@GET
@Path("/management/permissions")
@Produces(MediaType.APPLICATION_JSON)
ManagementPermissionReference getPermissions();
@GET
@Produces(MediaType.APPLICATION_JSON)
RoleRepresentation toRepresentation();
@PUT
@Consumes(MediaType.APPLICATION_JSON)
void update(RoleRepresentation roleRepresentation);
@DELETE
void remove();
@GET
@Path("composites")
@Produces(MediaType.APPLICATION_JSON)
Set getRoleComposites();
@GET
@Path("composites/realm")
@Produces(MediaType.APPLICATION_JSON)
Set getRealmRoleComposites();
@GET
@Path("composites/clients/{clientUuid}")
@Produces(MediaType.APPLICATION_JSON)
Set getClientRoleComposites(@PathParam("clientUuid") String clientUuid);
@POST
@Path("composites")
@Consumes(MediaType.APPLICATION_JSON)
void addComposites(List rolesToAdd);
@DELETE
@Path("composites")
@Consumes(MediaType.APPLICATION_JSON)
void deleteComposites(List rolesToRemove);
/**
* Get role members.
*
* Returns users that have the given role, sorted by username ascending.
*
*
* Note: This method just returns the first 100 users. In order to retrieve all users, use paging (see
* {@link #getUserMembers(Integer, Integer)}).
*
*
* @return a list of users with the given role
*/
@GET
@Path("users")
@Produces(MediaType.APPLICATION_JSON)
List getUserMembers();
/**
* Get role members.
* Returns users that have the given role, sorted by username ascending, paginated according to the query
* parameters.
*
* @param firstResult Pagination offset
* @param maxResults Pagination size
* @return a list of users with the given role
*/
@GET
@Path("users")
@Produces(MediaType.APPLICATION_JSON)
List getUserMembers(@QueryParam("first") Integer firstResult,
@QueryParam("max") Integer maxResults);
/**
* Get role members.
* Returns users that have the given role, sorted by username ascending, paginated according to the query
* parameters.
*
* @param briefRepresentation If the user should be returned in brief or full representation. Parameter available since Keycloak server 26. Will be ignored on older Keycloak versions with the default value false.
* @param firstResult Pagination offset
* @param maxResults Pagination size
* @return a list of users with the given role
*/
@GET
@Path("users")
@Produces(MediaType.APPLICATION_JSON)
List getUserMembers(@QueryParam("briefRepresentation") Boolean briefRepresentation,
@QueryParam("first") Integer firstResult,
@QueryParam("max") Integer maxResults);
/**
* Get role groups.
* Returns groups that have the given role.
*
* @return a list of groups with the given role
*/
@GET
@Path("groups")
@Produces(MediaType.APPLICATION_JSON)
Set getRoleGroupMembers();
/**
* Get role groups.
* Returns groups that have the given role, paginated according to the query parameters.
*
* @param firstResult Pagination offset
* @param maxResults Pagination size
* @return a list of groups with the given role
*/
@GET
@Path("groups")
@Produces(MediaType.APPLICATION_JSON)
Set getRoleGroupMembers(@QueryParam("first") Integer firstResult,
@QueryParam("max") Integer maxResults);
/**
* Get role members.
* Returns users that have the given role.
*
* @return a set of users with the given role
*
* @deprecated please use {@link #getUserMembers()}
*/
@GET
@Path("users")
@Produces(MediaType.APPLICATION_JSON)
@Deprecated
Set getRoleUserMembers();
/**
* Get role members.
* Returns users that have the given role, paginated according to the query parameters.
*
* @param firstResult Pagination offset
* @param maxResults Pagination size
* @return a set of users with the given role
*
* @deprecated please use {@link #getUserMembers(Integer, Integer)}
*/
@GET
@Path("users")
@Produces(MediaType.APPLICATION_JSON)
@Deprecated
Set getRoleUserMembers(@QueryParam("first") Integer firstResult,
@QueryParam("max") Integer maxResults);
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy