/* * The MIT License * * Copyright 2014 Miroslav Cupak (mirocupak@gmail.com). * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal * in the Software without restriction, including without limitation the rights * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell * copies of the Software, and to permit persons to whom the Software is * furnished to do so, subject to the following conditions: * * The above copyright notice and this permission notice shall be included in * all copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN * THE SOFTWARE. */ package com.dnastack.bob.rest.resource; import com.dnastack.bob.rest.comparator.NameComparator; import com.dnastack.bob.rest.comparator.OrganizationDtoComparator; import com.dnastack.bob.service.api.OrganizationService; import com.dnastack.bob.service.dto.OrganizationDto; import com.dnastack.bob.service.parser.util.ParseUtils; import java.net.HttpURLConnection; import java.net.URI; import java.util.Collection; import java.util.Set; import java.util.TreeSet; import javax.enterprise.context.RequestScoped; import javax.inject.Inject; import javax.inject.Named; import javax.ws.rs.Consumes; import javax.ws.rs.DELETE; import javax.ws.rs.GET; import javax.ws.rs.POST; import javax.ws.rs.PUT; import javax.ws.rs.Path; import javax.ws.rs.PathParam; import javax.ws.rs.Produces; import javax.ws.rs.QueryParam; import javax.ws.rs.WebApplicationException; import javax.ws.rs.core.Context; import javax.ws.rs.core.MediaType; import javax.ws.rs.core.Response; import javax.ws.rs.core.UriInfo; /** * Organization rest resource. * * @author Miroslav Cupak (mirocupak@gmail.com) * @version 1.0 */ @Path("/organizations") @Consumes({MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML}) @Produces({MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML}) @RequestScoped @Named public class OrganizationResource { @Inject private OrganizationService organizationService; @Inject @NameComparator private OrganizationDtoComparator organizationComparator; @Inject private ParseUtils parseUtils; /** * Shows organization details. * * @param organizationId id of the organization * * @return organization */ @GET @Path("/{organizationId}") public OrganizationDto showOrganization(@PathParam("organizationId") String organizationId) { OrganizationDto b = organizationService.find(organizationId); if (b == null) { throw new WebApplicationException(HttpURLConnection.HTTP_NOT_FOUND); } return b; } /** * Shows all the organizations or a specific organization as determined by a param. * * @param organizationIds organization ID * * @return set of organizations */ @GET public Collection<OrganizationDto> show(@QueryParam("organization") String organizationIds) { Set<OrganizationDto> bs = new TreeSet<>(organizationComparator); if (organizationIds == null) { bs.addAll(organizationService.findAll()); } else { bs.addAll(organizationService.find(parseUtils.parseMultipleParameterValues(organizationIds))); } return bs; } @POST public Response create(@Context UriInfo uriInfo, OrganizationDto organization) { OrganizationDto o = organizationService.create(organization); return Response.created(URI.create(uriInfo.getAbsolutePath() + "/" + o.getId())).build(); } @PUT @Path("/{organizationId}") public Response update(@Context UriInfo uriInfo, @PathParam("organizationId") String organizationId, OrganizationDto organization) { OrganizationDto o = organizationService.update(organizationId, organization); return Response.ok(o).build(); } @DELETE @Path("/{organizationId}") public Response delete(@Context UriInfo uriInfo, @PathParam("organizationId") String organizationId) { organizationService.delete(organizationId); return Response.ok().build(); } }