Search in sources :

Example 1 with PUBLIC

use of io.gravitee.rest.api.model.Visibility.PUBLIC in project gravitee-management-rest-api by gravitee-io.

the class ApiRatingResource method getApiRating.

@GET
@ApiOperation(value = "List ratings for an API")
@Produces(MediaType.APPLICATION_JSON)
public Page<RatingEntity> getApiRating(@Min(1) @QueryParam("pageNumber") int pageNumber, @QueryParam("pageSize") int pageSize) {
    final ApiEntity apiEntity = apiService.findById(api);
    if (PUBLIC.equals(apiEntity.getVisibility()) || hasPermission(RolePermission.API_RATING, api, RolePermissionAction.READ)) {
        final Page<RatingEntity> ratingEntityPage = ratingService.findByApi(api, new PageableBuilder().pageNumber(pageNumber).pageSize(pageSize).build());
        final List<RatingEntity> filteredRatings = ratingEntityPage.getContent().stream().map(ratingEntity -> filterPermission(api, ratingEntity)).collect(toList());
        return new Page<>(filteredRatings, ratingEntityPage.getPageNumber(), (int) ratingEntityPage.getPageElements(), ratingEntityPage.getTotalElements());
    } else {
        throw new UnauthorizedAccessException();
    }
}
Also used : PUBLIC(io.gravitee.rest.api.model.Visibility.PUBLIC) RolePermissionAction(io.gravitee.rest.api.model.permissions.RolePermissionAction) ApiEntity(io.gravitee.rest.api.model.api.ApiEntity) Page(io.gravitee.common.data.domain.Page) RatingService(io.gravitee.rest.api.service.RatingService) ApiParam(io.swagger.annotations.ApiParam) Min(javax.validation.constraints.Min) NotNull(javax.validation.constraints.NotNull) Permission(io.gravitee.rest.api.management.rest.security.Permission) UnauthorizedAccessException(io.gravitee.rest.api.service.exceptions.UnauthorizedAccessException) Inject(javax.inject.Inject) Valid(javax.validation.Valid) ApiOperation(io.swagger.annotations.ApiOperation) Collectors.toList(java.util.stream.Collectors.toList) List(java.util.List) MediaType(io.gravitee.common.http.MediaType) javax.ws.rs(javax.ws.rs) PageableBuilder(io.gravitee.repository.management.api.search.builder.PageableBuilder) io.gravitee.rest.api.model(io.gravitee.rest.api.model) Api(io.swagger.annotations.Api) Permissions(io.gravitee.rest.api.management.rest.security.Permissions) RolePermission(io.gravitee.rest.api.model.permissions.RolePermission) UnauthorizedAccessException(io.gravitee.rest.api.service.exceptions.UnauthorizedAccessException) ApiEntity(io.gravitee.rest.api.model.api.ApiEntity) Page(io.gravitee.common.data.domain.Page) PageableBuilder(io.gravitee.repository.management.api.search.builder.PageableBuilder) ApiOperation(io.swagger.annotations.ApiOperation)

Example 2 with PUBLIC

use of io.gravitee.rest.api.model.Visibility.PUBLIC in project gravitee-management-rest-api by gravitee-io.

the class ApisResource method getApis.

@GET
@Path("_paged")
@Produces(MediaType.APPLICATION_JSON)
@ApiOperation(value = "List APIs with pagination", notes = "List all the APIs accessible to the current user with pagination.", nickname = "getApisPaged")
@ApiResponses({ @ApiResponse(code = 200, message = "Page of APIs for current user", response = PagedResult.class), @ApiResponse(code = 500, message = "Internal server error") })
public PagedResult<ApiListItem> getApis(@BeanParam final ApisParam apisParam, @Valid @BeanParam Pageable pageable) {
    final ApiQuery apiQuery = new ApiQuery();
    if (apisParam.getGroup() != null) {
        apiQuery.setGroups(singletonList(apisParam.getGroup()));
    }
    apiQuery.setContextPath(apisParam.getContextPath());
    apiQuery.setLabel(apisParam.getLabel());
    apiQuery.setVersion(apisParam.getVersion());
    apiQuery.setName(apisParam.getName());
    apiQuery.setTag(apisParam.getTag());
    apiQuery.setState(apisParam.getState());
    if (apisParam.getCategory() != null) {
        apiQuery.setCategory(categoryService.findById(apisParam.getCategory()).getId());
    }
    Sortable sortable = null;
    if (apisParam.getOrder() != null) {
        sortable = new SortableImpl(apisParam.getOrder().getField(), apisParam.getOrder().isOrder());
    }
    io.gravitee.rest.api.model.common.Pageable commonPageable = null;
    if (pageable != null) {
        commonPageable = pageable.toPageable();
    }
    final Page<ApiEntity> apis;
    if (isAdmin()) {
        apis = apiService.search(apiQuery, sortable, commonPageable);
    } else {
        if (apisParam.isPortal() || apisParam.isTop()) {
            apiQuery.setLifecycleStates(singletonList(PUBLISHED));
        }
        if (isAuthenticated()) {
            apis = apiService.findByUser(getAuthenticatedUser(), apiQuery, sortable, commonPageable, apisParam.isPortal());
        } else {
            apiQuery.setVisibility(PUBLIC);
            apis = apiService.search(apiQuery, sortable, commonPageable);
        }
    }
    final boolean isRatingServiceEnabled = ratingService.isEnabled();
    if (apisParam.isTop()) {
        final List<String> visibleApis = apis.getContent().stream().map(ApiEntity::getId).collect(toList());
        return new PagedResult<>(topApiService.findAll().stream().filter(topApi -> visibleApis.contains(topApi.getApi())).map(topApiEntity -> apiService.findById(topApiEntity.getApi())).map(apiEntity -> this.convert(apiEntity, isRatingServiceEnabled)).collect(toList()), apis.getPageNumber(), (int) apis.getPageElements(), (int) apis.getTotalElements());
    }
    return new PagedResult<>(apis.getContent().stream().map(apiEntity -> this.convert(apiEntity, isRatingServiceEnabled)).collect(toList()), apis.getPageNumber(), (int) apis.getPageElements(), (int) apis.getTotalElements());
}
Also used : PUBLIC(io.gravitee.rest.api.model.Visibility.PUBLIC) io.gravitee.rest.api.service(io.gravitee.rest.api.service) PagedResult(io.gravitee.rest.api.management.rest.model.PagedResult) java.util(java.util) PUBLISHED(io.gravitee.rest.api.model.api.ApiLifecycleState.PUBLISHED) ApiHook(io.gravitee.rest.api.service.notification.ApiHook) Page(io.gravitee.common.data.domain.Page) Sortable(io.gravitee.rest.api.model.common.Sortable) VirtualHost(io.gravitee.definition.model.VirtualHost) Hook(io.gravitee.rest.api.service.notification.Hook) GraviteeContext(io.gravitee.rest.api.service.common.GraviteeContext) VerifyApiParam(io.gravitee.rest.api.management.rest.resource.param.VerifyApiParam) Collections.singletonList(java.util.Collections.singletonList) Inject(javax.inject.Inject) Valid(javax.validation.Valid) ImportSwaggerDescriptorEntity(io.gravitee.rest.api.model.ImportSwaggerDescriptorEntity) WorkflowState(io.gravitee.rest.api.model.WorkflowState) TechnicalManagementException(io.gravitee.rest.api.service.exceptions.TechnicalManagementException) RatingSummaryEntity(io.gravitee.rest.api.model.RatingSummaryEntity) SortableImpl(io.gravitee.rest.api.model.common.SortableImpl) io.swagger.annotations(io.swagger.annotations) UriBuilder(javax.ws.rs.core.UriBuilder) URI(java.net.URI) Lifecycle(io.gravitee.common.component.Lifecycle) OrderParam(io.gravitee.rest.api.management.rest.resource.param.OrderParam) RolePermissionAction(io.gravitee.rest.api.model.permissions.RolePermissionAction) Context(javax.ws.rs.core.Context) ApisParam(io.gravitee.rest.api.management.rest.resource.param.ApisParam) Pageable(io.gravitee.rest.api.management.rest.model.Pageable) NotNull(javax.validation.constraints.NotNull) io.gravitee.rest.api.model.api(io.gravitee.rest.api.model.api) Permission(io.gravitee.rest.api.management.rest.security.Permission) Collectors.toList(java.util.stream.Collectors.toList) MediaType(io.gravitee.common.http.MediaType) FlowService(io.gravitee.rest.api.service.configuration.flow.FlowService) DefinitionVersion(io.gravitee.definition.model.DefinitionVersion) javax.ws.rs(javax.ws.rs) Response(javax.ws.rs.core.Response) ResourceContext(javax.ws.rs.container.ResourceContext) ApiAlreadyExistsException(io.gravitee.rest.api.service.exceptions.ApiAlreadyExistsException) Permissions(io.gravitee.rest.api.management.rest.security.Permissions) RolePermission(io.gravitee.rest.api.model.permissions.RolePermission) StringUtils(org.springframework.util.StringUtils) SortableImpl(io.gravitee.rest.api.model.common.SortableImpl) Sortable(io.gravitee.rest.api.model.common.Sortable) io.gravitee.rest.api.model.api(io.gravitee.rest.api.model.api) PagedResult(io.gravitee.rest.api.management.rest.model.PagedResult)

Aggregations

Page (io.gravitee.common.data.domain.Page)2 MediaType (io.gravitee.common.http.MediaType)2 Permission (io.gravitee.rest.api.management.rest.security.Permission)2 Permissions (io.gravitee.rest.api.management.rest.security.Permissions)2 PUBLIC (io.gravitee.rest.api.model.Visibility.PUBLIC)2 RolePermission (io.gravitee.rest.api.model.permissions.RolePermission)2 RolePermissionAction (io.gravitee.rest.api.model.permissions.RolePermissionAction)2 Collectors.toList (java.util.stream.Collectors.toList)2 Inject (javax.inject.Inject)2 Valid (javax.validation.Valid)2 NotNull (javax.validation.constraints.NotNull)2 javax.ws.rs (javax.ws.rs)2 Lifecycle (io.gravitee.common.component.Lifecycle)1 DefinitionVersion (io.gravitee.definition.model.DefinitionVersion)1 VirtualHost (io.gravitee.definition.model.VirtualHost)1 PageableBuilder (io.gravitee.repository.management.api.search.builder.PageableBuilder)1 Pageable (io.gravitee.rest.api.management.rest.model.Pageable)1 PagedResult (io.gravitee.rest.api.management.rest.model.PagedResult)1 ApisParam (io.gravitee.rest.api.management.rest.resource.param.ApisParam)1 OrderParam (io.gravitee.rest.api.management.rest.resource.param.OrderParam)1