/* * Copyright 2015-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.hawkular.inventory.rest.deprecated; import static javax.ws.rs.core.MediaType.APPLICATION_JSON; import static javax.ws.rs.core.Response.Status.FORBIDDEN; import javax.inject.Inject; import javax.ws.rs.Consumes; import javax.ws.rs.DELETE; import javax.ws.rs.DefaultValue; import javax.ws.rs.GET; import javax.ws.rs.PUT; import javax.ws.rs.Path; import javax.ws.rs.Produces; import javax.ws.rs.QueryParam; import javax.ws.rs.core.Context; import javax.ws.rs.core.Response; import javax.ws.rs.core.UriInfo; import org.hawkular.inventory.api.model.Tenant; import org.hawkular.inventory.paths.CanonicalPath; import org.hawkular.inventory.rest.RestBase; import org.hawkular.inventory.rest.json.ApiError; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; import io.swagger.annotations.ApiParam; import io.swagger.annotations.ApiResponse; import io.swagger.annotations.ApiResponses; /** * @author Lukas Krejci * @since 0.0.1 */ @Path("/deprecated/tenant") @Produces(APPLICATION_JSON) @Consumes(APPLICATION_JSON) @Api(value = "/tenant", description = "Work with the tenant of the current persona", tags = {"Deprecated"}) public class RestTenants extends RestBase { @Inject private RestRelationships restRelationships; @GET @Path("/") @ApiOperation("Retrieves the tenant of the currently logged in persona") @ApiResponses({ @ApiResponse(code = 200, message = "OK"), @ApiResponse(code = 401, message = "Unauthorized access"), @ApiResponse(code = 404, message = "Tenant doesn't exist", response = ApiError.class), @ApiResponse(code = 500, message = "Server error", response = ApiError.class) }) public Response getTenant() { String tenantId = getTenantId(); return Response.ok(inventory.tenants().get(tenantId).entity()).build(); } @GET @Path("/relationships") @ApiOperation("Retrieves tenant's relationships") @ApiResponses({ @ApiResponse(code = 200, message = "OK"), @ApiResponse(code = 401, message = "Unauthorized access"), @ApiResponse(code = 404, message = "Tenant doesn't exist", response = ApiError.class), @ApiResponse(code = 500, message = "Server error", response = ApiError.class) }) public Response getTenantRelationships(@DefaultValue("both") @QueryParam("direction") String direction, @DefaultValue("") @QueryParam("property") String propertyName, @DefaultValue("") @QueryParam("propertyValue") String propertyValue, @DefaultValue("") @QueryParam("named") String named, @DefaultValue("") @QueryParam("sourceType") String sourceType, @DefaultValue("") @QueryParam("targetType") String targetType, @DefaultValue("false") @QueryParam("jsonld") String jsonLd, @Context UriInfo uriInfo) { // this needs to be handled here and delegated to the right place, because RestEasy puts higher priority in // it's method matcher if there is a class annotated with a prefix of the request URL return restRelationships.get("tenant", direction, propertyName, propertyValue, named, sourceType, targetType, jsonLd, uriInfo); } @PUT @Path("/") @ApiOperation("Updates properties of the current tenant") @ApiResponses({ @ApiResponse(code = 204, message = "OK"), @ApiResponse(code = 400, message = "Invalid input data", response = ApiError.class), @ApiResponse(code = 401, message = "Unauthorized access"), @ApiResponse(code = 404, message = "Tenant doesn't exist", response = ApiError.class), @ApiResponse(code = 500, message = "Server error", response = ApiError.class) }) public Response updateTenant(@ApiParam(required = true) Tenant.Update update) { String tenantId = getTenantId(); if (!security.canUpdate(CanonicalPath.of().tenant(tenantId).get())) { return Response.status(FORBIDDEN).build(); } inventory.tenants().update(tenantId, update); return Response.noContent().build(); } @DELETE @Path("/") @ApiOperation("Deletes the tenant and all its data. Be careful!") @ApiResponses({ @ApiResponse(code = 204, message = "OK"), @ApiResponse(code = 401, message = "Unauthorized access"), @ApiResponse(code = 404, message = "Tenant doesn't exist", response = ApiError.class), @ApiResponse(code = 500, message = "Server error", response = ApiError.class) }) public Response deleteTenant() { String tenantId = getTenantId(); if (!security.canDelete(CanonicalPath.of().tenant(tenantId).get())) { return Response.status(FORBIDDEN).build(); } inventory.tenants().delete(tenantId); return Response.noContent().build(); } }