[Lada-commits] [PATCH 6 of 8] Added location services
Wald Commits
scm-commit at wald.intevation.org
Thu Feb 19 14:20:56 CET 2015
# HG changeset patch
# User Raimund Renkert <raimund.renkert at intevation.de>
# 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;
+
+ at Path("location")
+ at 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");
+ }
+}
More information about the Lada-commits
mailing list