# HG changeset patch # User Raimund Renkert # Date 1424351714 -3600 # Node ID 9ed02cacd020705ae9e9e41bab2a2cc28e83282d # Parent 9bbe9dea64befac619640d1b66c772a217c84382 Added location services. diff -r 9bbe9dea64be -r 9ed02cacd020 src/main/java/de/intevation/lada/rest/stamm/LocationService.java --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/main/java/de/intevation/lada/rest/stamm/LocationService.java Thu Feb 19 14:15:14 2015 +0100 @@ -0,0 +1,159 @@ +/* Copyright (C) 2013 by Bundesamt fuer Strahlenschutz + * Software engineering by Intevation GmbH + * + * This file is Free Software under the GNU GPL (v>=3) + * and comes with ABSOLUTELY NO WARRANTY! Check out + * the documentation coming with IMIS-Labordaten-Application for details. + */ +package de.intevation.lada.rest.stamm; + +import javax.enterprise.context.RequestScoped; +import javax.inject.Inject; +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.core.Context; +import javax.ws.rs.core.HttpHeaders; +import javax.ws.rs.core.MediaType; +import javax.ws.rs.core.UriInfo; + +import org.apache.log4j.Logger; + +import de.intevation.lada.model.stamm.SOrt; +import de.intevation.lada.util.annotation.AuthenticationConfig; +import de.intevation.lada.util.annotation.AuthorizationConfig; +import de.intevation.lada.util.annotation.RepositoryConfig; +import de.intevation.lada.util.auth.Authentication; +import de.intevation.lada.util.auth.AuthenticationType; +import de.intevation.lada.util.auth.Authorization; +import de.intevation.lada.util.auth.AuthorizationType; +import de.intevation.lada.util.data.Repository; +import de.intevation.lada.util.data.RepositoryType; +import de.intevation.lada.util.rest.Response; + +@Path("location") +@RequestScoped +public class LocationService { + + /* The logger used in this class.*/ + @Inject + private Logger logger; + + /* The data repository granting read/write access.*/ + @Inject + @RepositoryConfig(type=RepositoryType.RW) + private Repository defaultRepo; + + /* The authentication module.*/ + @Inject + @AuthenticationConfig(type=AuthenticationType.NONE) + private Authentication authentication; + + /* The authorization module.*/ + @Inject + @AuthorizationConfig(type=AuthorizationType.NONE) + private Authorization authorization; + + /** + * Get all objects. + * + * @return Response object containing all objects. + */ + @GET + @Path("/") + @Produces(MediaType.APPLICATION_JSON) + public Response get( + @Context HttpHeaders headers, + @Context UriInfo info + ) { + if (!authentication.isAuthenticated(headers)) { + logger.debug("User is not authenticated!"); + return new Response(false, 699, null); + } + return defaultRepo.getAll(SOrt.class, "stamm"); + } + + /** + * Get an object by id. + * + * @return Response object containing a single object. + */ + @GET + @Path("/{id}") + @Produces(MediaType.APPLICATION_JSON) + public Response getById( + @Context HttpHeaders headers, + @PathParam("id") String id + ) { + if (!authentication.isAuthenticated(headers)) { + logger.debug("User is not authenticated!"); + return new Response(false, 699, null); + } + return defaultRepo.getById( + SOrt.class, + Integer.valueOf(id), + "stamm"); + } + + @POST + @Path("/") + @Produces(MediaType.APPLICATION_JSON) + public Response create( + @Context HttpHeaders headers, + SOrt ort + ) { + if (!authentication.isAuthenticated(headers)) { + return new Response(false, 699, null); + } + /* Persist the new object*/ + return defaultRepo.create(ort, "stamm"); + } + + /** + * Update an existing object. + * + * @return Response object containing the updated object. + */ + @PUT + @Path("/") + @Produces(MediaType.APPLICATION_JSON) + public Response update(@Context HttpHeaders headers, SOrt ort) { + if (!authentication.isAuthenticated(headers)) { + logger.debug("User is not authenticated!"); + return new Response(false, 699, null); + } + Response response = defaultRepo.update(ort, "stamm"); + Response updated = defaultRepo.getById( + SOrt.class, + ((SOrt)response.getData()).getId(), "stamm"); + return updated; + } + + /** + * Delete an existing object by id. + * + * @return Response object. + */ + @DELETE + @Path("/{id}") + @Produces(MediaType.APPLICATION_JSON) + public Response delete( + @Context HttpHeaders headers, + @PathParam("id") String id + ) { + if (!authentication.isAuthenticated(headers)) { + logger.debug("User is not authenticated!"); + return new Response(false, 699, null); + } + /* Get the object by id*/ + Response object = + defaultRepo.getById(SOrt.class, Integer.valueOf(id), "stamm"); + SOrt ortObj = (SOrt)object.getData(); + /* Delete the object*/ + return defaultRepo.delete(ortObj, "stamm"); + } +}