
brooklyn.rest.api.LocationApi Maven / Gradle / Ivy
The newest version!
package brooklyn.rest.api;
import java.util.List;
import java.util.Map;
import javax.validation.Valid;
import javax.ws.rs.Consumes;
import javax.ws.rs.DELETE;
import javax.ws.rs.DefaultValue;
import javax.ws.rs.GET;
import javax.ws.rs.POST;
import javax.ws.rs.Path;
import javax.ws.rs.PathParam;
import javax.ws.rs.Produces;
import javax.ws.rs.QueryParam;
import javax.ws.rs.core.MediaType;
import javax.ws.rs.core.Response;
import brooklyn.rest.apidoc.Apidoc;
import brooklyn.rest.domain.LocationSpec;
import brooklyn.rest.domain.LocationSummary;
import com.wordnik.swagger.core.ApiOperation;
import com.wordnik.swagger.core.ApiParam;
@Path("/v1/locations")
@Apidoc("Locations")
@Produces(MediaType.APPLICATION_JSON)
@Consumes(MediaType.APPLICATION_JSON)
public interface LocationApi {
@GET
@ApiOperation(value = "Fetch the list of locations",
responseClass = "brooklyn.rest.domain.LocationSummary",
multiValueResponse = true)
public List list() ;
// this is here to support the web GUI's circles
@GET
@Path("/usage/LocatedLocations")
@ApiOperation(value = "Return a summary of all usage", notes="interim API, expected to change")
public Map> getLocatedLocations() ;
@GET
@Path("/{locationId}")
@ApiOperation(value = "Fetch details about a location",
responseClass = "brooklyn.rest.domain.LocationSummary",
multiValueResponse = true)
public LocationSummary get(
@ApiParam(value = "Location id to fetch", required = true)
@PathParam("locationId") String locationId,
@ApiParam(value = "Whether full (inherited) config should be compiled", required = false)
@DefaultValue("false")
@QueryParam("full") String fullConfig) ;
// breaks BrooklynApi -- as method needs an annotation
// /** @deprecated since 0.7.0; REST call now handled by above (optional query parameter added) */
// @Deprecated
// public LocationSummary get(String locationId);
@POST
@ApiOperation(value = "Create a new location", responseClass = "String")
public Response create(
@ApiParam(name = "locationSpec", value = "Location specification object", required = true)
@Valid LocationSpec locationSpec) ;
@DELETE
@Path("/{locationId}")
@ApiOperation(value = "Delete a location object by id")
public void delete(
@ApiParam(value = "Location id to delete", required = true)
@PathParam("locationId") String locationId) ;
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy