com.freedomotic.plugins.devices.restapiv3.utils.AbstractResource Maven / Gradle / Ivy
The newest version!
/**
*
* Copyright (c) 2009-2014 Freedomotic team http://freedomotic.com
*
* This file is part of Freedomotic
*
* This Program is free software; you can redistribute it and/or modify it under
* the terms of the GNU General Public License as published by the Free Software
* Foundation; either version 2, or (at your option) any later version.
*
* This Program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
* FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
* details.
*
* You should have received a copy of the GNU General Public License along with
* Freedomotic; see the file COPYING. If not, see
* .
*/
package com.freedomotic.plugins.devices.restapiv3.utils;
import com.freedomotic.plugins.devices.restapiv3.filters.ForbiddenException;
import com.freedomotic.plugins.devices.restapiv3.filters.ItemNotFoundException;
import com.wordnik.swagger.annotations.ApiOperation;
import com.wordnik.swagger.annotations.ApiParam;
import com.wordnik.swagger.annotations.ApiResponse;
import com.wordnik.swagger.annotations.ApiResponses;
import java.net.URI;
import java.net.URISyntaxException;
import java.util.logging.Level;
import javax.ws.rs.Consumes;
import javax.ws.rs.DELETE;
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.MediaType;
import javax.ws.rs.core.Response;
import javax.ws.rs.core.UriBuilder;
/**
*
* @author matteo
* @param
*/
public abstract class AbstractResource extends AbstractReadOnlyResource implements ResourceInterface {
/**
*
* @param UUID
* @param s
* @return
*/
@Override
@PUT
@Path("/{id}")
@Consumes(MediaType.APPLICATION_JSON)
@Produces(MediaType.APPLICATION_JSON)
@ApiResponses(value = {
@ApiResponse(code = 304, message = "Item not modified")
})
@ApiOperation(value = "Update an item", position = 40)
public Response update(
@ApiParam(value = "ID of item to update", required = true)
@PathParam("id") String UUID,
T s) {
if (api.getAuth().isPermitted(authContext + ":update:" + UUID)) {
try {
LOG.info("Acquiring modified element");
T z = doUpdate(UUID,s);
if (z != null) {
LOG.info("Everything was correctly computed");
return Response.ok().build();
} else {
LOG.info("There was a error, so nothing's changed");
return Response.notModified().build();
}
} catch (Exception e) {
LOG.log(Level.SEVERE, "Cannot update an item", e);
return Response.notModified().build();
}
}
throw new ForbiddenException("User " + api.getAuth().getSubject().getPrincipal() + " cannot modify " + authContext + " " + UUID);
}
/**
*
* @param s
* @return
* @throws URISyntaxException
*/
@POST
@Consumes(MediaType.APPLICATION_JSON)
@Produces(MediaType.APPLICATION_JSON)
@ApiOperation(value = "Create a new item", position = 30)
@ApiResponses(value = {
@ApiResponse(code = 201, message = "New item created")
})
@Override
public Response create(T s) throws URISyntaxException {
if (api.getAuth().isPermitted(authContext + ":create")) {
try {
return Response.created(doCreate(s)).build();
} catch (URISyntaxException e) {
LOG.log(Level.SEVERE, null, e);
return Response.serverError().build();
}
}
throw new ForbiddenException("User " + api.getAuth().getSubject().getPrincipal() + " cannot create any " + authContext);
}
/**
*
* @param UUID
* @return
*/
@Override
@DELETE
@Path("/{id}")
@ApiOperation(value = "Delete an item", position = 50)
@ApiResponses(value = {
@ApiResponse(code = 404, message = "Item not found")
})
public Response delete(
@ApiParam(value = "ID of item to delete", required = true)
@PathParam("id") String UUID) {
if (api.getAuth().isPermitted(authContext + ":create") && api.getAuth().isPermitted(authContext + ":read:" + UUID)) {
if (doDelete(UUID)) {
return Response.ok().build();
} else {
throw new ItemNotFoundException("Cannot find item: " + UUID);
}
}
throw new ForbiddenException("User " + api.getAuth().getSubject().getPrincipal() + " cannot copy " + authContext + " with UUID " + UUID);
}
@Override
@POST
@Path("/{id}/copy")
@ApiOperation(value = "Copy an item", position = 35)
@ApiResponses(value = {
@ApiResponse(code = 404, message = "Source item not found")
})
public Response copy(
@ApiParam(value = "ID of item to copy", required = true)
@PathParam("id") String UUID) {
URI ref = doCopy(UUID);
if (ref != null) {
return Response.created(ref).build();
} else {
throw new ItemNotFoundException("Cannot find item: " + UUID);
}
}
protected URI createUri(String resId) {
return UriBuilder.fromResource(this.getClass()).path(resId).build();
}
/**
*
* @param UUID
* @return
*/
abstract protected URI doCopy(String UUID);
/**
*
* @param o
* @return
* @throws URISyntaxException
*/
abstract protected URI doCreate(T o) throws URISyntaxException;
/**
*
* @param UUID
* @return
*/
abstract protected boolean doDelete(String UUID);
/**
*
* @param o
* @return
*/
abstract protected T doUpdate(String UUID, T o);
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy