added AbstractResource

This commit is contained in:
Sebastian Sdorra
2010-09-06 13:02:54 +02:00
parent 205d7718be
commit e0e033af6f
4 changed files with 333 additions and 176 deletions

View File

@@ -68,8 +68,6 @@ public class SecurityFilter implements Filter
String uri = String uri =
request.getRequestURI().substring(request.getContextPath().length()); request.getRequestURI().substring(request.getContextPath().length());
System.out.println( uri + "" + uri.startsWith( URL_AUTHENTICATION ) );
if (uri.startsWith(URL_AUTHENTICATION) if (uri.startsWith(URL_AUTHENTICATION)
|| (request.getSession(true).getAttribute("auth") != null)) || (request.getSession(true).getAttribute("auth") != null))
{ {

View File

@@ -0,0 +1,210 @@
/*
* To change this template, choose Tools | Templates
* and open the template in the editor.
*/
package sonia.scm.api.rest.resources;
//~--- JDK imports ------------------------------------------------------------
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.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;
/**
*
* @author Sebastian Sdorra
*
* @param <T>
*/
public abstract class AbstractResource<T>
{
/**
* Method description
*
*
* @param item
*/
protected abstract void addItem(T item);
/**
* Method description
*
*
* @param item
*/
protected abstract void removeItem(T item);
/**
* Method description
*
*
* @param name
* @param item
*/
protected abstract void updateItem(String name, T item);
//~--- get methods ----------------------------------------------------------
/**
* Method description
*
*
* @return
*/
protected abstract T[] getAllItems();
/**
* Method description
*
*
* @param item
*
* @return
*/
protected abstract String getId(T item);
/**
* Method description
*
*
* @param name
*
* @return
*/
protected abstract T getItem(String name);
/**
* Method description
*
*
* @return
*/
protected abstract String getPathPart();
//~--- methods --------------------------------------------------------------
/**
* Method description
*
*
*
* @param uriInfo
* @param item
*
* @return
*/
@POST
@Consumes({ MediaType.APPLICATION_XML, MediaType.APPLICATION_JSON })
public Response add(@Context UriInfo uriInfo, T item)
{
addItem(item);
return Response.created(
uriInfo.getAbsolutePath().resolve(
getPathPart().concat("/").concat(getId(item)))).build();
}
/**
* Method description
*
*
* @param name
*
* @return
*/
@DELETE
@Path("{name}")
public Response delete(@PathParam("name") String name)
{
T item = getItem(name);
if (item == null)
{
throw new WebApplicationException(Response.Status.NOT_FOUND);
}
removeItem(item);
return Response.noContent().build();
}
/**
* Method description
*
*
*
*
* @param uriInfo
* @param name
* @param item
*
* @return
*/
@PUT
@Path("{name}")
@Consumes({ MediaType.APPLICATION_XML, MediaType.APPLICATION_JSON })
public Response update(@Context UriInfo uriInfo,
@PathParam("name") String name, T item)
{
T updateItem = getItem(name);
if (updateItem == null)
{
throw new WebApplicationException(Response.Status.NOT_FOUND);
}
updateItem(name, item);
return Response.created(
uriInfo.getAbsolutePath().resolve(getId(item))).build();
}
//~--- get methods ----------------------------------------------------------
/**
* Method description
*
*
* @param name
*
* @return
*/
@GET
@Path("{name}")
public T get(@PathParam("name") String name)
{
T item = getItem(name);
if (item == null)
{
throw new WebApplicationException(Response.Status.NOT_FOUND);
}
return item;
}
/**
* Method description
*
*
* @return
*/
@GET
public T[] getAll()
{
return getAllItems();
}
}

View File

@@ -18,20 +18,9 @@ import java.util.LinkedHashMap;
import javax.inject.Singleton; import javax.inject.Singleton;
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.Path;
import javax.ws.rs.PathParam;
import javax.ws.rs.Produces; import javax.ws.rs.Produces;
import javax.ws.rs.WebApplicationException;
import javax.ws.rs.core.Context;
import javax.ws.rs.core.MediaType; import javax.ws.rs.core.MediaType;
import javax.ws.rs.core.Response;
import javax.ws.rs.core.Response.Status;
import javax.ws.rs.core.UriInfo;
/** /**
* *
@@ -40,9 +29,14 @@ import javax.ws.rs.core.UriInfo;
@Singleton @Singleton
@Path("groups") @Path("groups")
@Produces({ MediaType.APPLICATION_XML, MediaType.APPLICATION_JSON }) @Produces({ MediaType.APPLICATION_XML, MediaType.APPLICATION_JSON })
public class GroupResource public class GroupResource extends AbstractResource<Group>
{ {
/** Field description */
public static final String PATH_PART = "groups";
//~--- constructors ---------------------------------------------------------
/** /**
* Constructs ... * Constructs ...
* *
@@ -63,19 +57,24 @@ public class GroupResource
* Method description * Method description
* *
* *
* @param group * @param item
*
* @return
*/ */
@POST @Override
@Consumes({ MediaType.APPLICATION_XML, MediaType.APPLICATION_JSON }) protected void addItem(Group item)
public Response add(Group group)
{ {
groupStore.put(group.getName(), group); groupStore.put(item.getName(), item);
}
return Response.created( /**
uriInfo.getAbsolutePath().resolve( * Method description
"groups/".concat(group.getName()))).build(); *
*
* @param item
*/
@Override
protected void removeItem(Group item)
{
groupStore.remove(item.getName());
} }
/** /**
@@ -83,56 +82,46 @@ public class GroupResource
* *
* *
* @param name * @param name
* * @param item
* @return
*/ */
@DELETE @Override
@Path("{name}") protected void updateItem(String name, Group item)
public Response delete(@PathParam("name") String name)
{ {
Group group = groupStore.get(name); Group group = groupStore.get(name);
if (group == null) group.setMembers(item.getMembers());
{
throw new WebApplicationException(Status.NOT_FOUND);
}
groupStore.remove(name);
return Response.noContent().build();
}
/**
* Method description
*
*
*
* @param name
* @param group
*
* @return
*/
@PUT
@Path("{name}")
@Consumes({ MediaType.APPLICATION_XML, MediaType.APPLICATION_JSON })
public Response update(@PathParam("name") String name, Group group)
{
Group updateGroup = groupStore.get(name);
if (updateGroup == null)
{
throw new WebApplicationException(Status.NOT_FOUND);
}
updateGroup.setName(name);
updateGroup.setMembers(group.getMembers());
return Response.created(
uriInfo.getAbsolutePath().resolve(group.getName())).build();
} }
//~--- get methods ---------------------------------------------------------- //~--- get methods ----------------------------------------------------------
/**
* Method description
*
*
* @return
*/
@Override
protected Group[] getAllItems()
{
Collection<Group> groupCollection = groupStore.values();
return groupCollection.toArray(new Group[groupCollection.size()]);
}
/**
* Method description
*
*
* @param item
*
* @return
*/
@Override
protected String getId(Group item)
{
return item.getName();
}
/** /**
* Method description * Method description
* *
@@ -141,18 +130,10 @@ public class GroupResource
* *
* @return * @return
*/ */
@GET @Override
@Path("{name}") protected Group getItem(String name)
public Group get(@PathParam("name") String name)
{ {
Group group = groupStore.get(name); return groupStore.get(name);
if (group == null)
{
throw new WebApplicationException(Status.NOT_FOUND);
}
return group;
} }
/** /**
@@ -161,20 +142,14 @@ public class GroupResource
* *
* @return * @return
*/ */
@GET @Override
public Group[] getAll() protected String getPathPart()
{ {
Collection<Group> groupCollection = groupStore.values(); return PATH_PART;
return groupCollection.toArray(new Group[groupCollection.size()]);
} }
//~--- fields --------------------------------------------------------------- //~--- fields ---------------------------------------------------------------
/** Field description */ /** Field description */
private LinkedHashMap<String, Group> groupStore; private LinkedHashMap<String, Group> groupStore;
/** Field description */
@Context
private UriInfo uriInfo;
} }

View File

@@ -19,20 +19,9 @@ import java.util.LinkedHashMap;
import javax.inject.Singleton; import javax.inject.Singleton;
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.Path;
import javax.ws.rs.PathParam;
import javax.ws.rs.Produces; import javax.ws.rs.Produces;
import javax.ws.rs.WebApplicationException;
import javax.ws.rs.core.Context;
import javax.ws.rs.core.MediaType; import javax.ws.rs.core.MediaType;
import javax.ws.rs.core.Response;
import javax.ws.rs.core.Response.Status;
import javax.ws.rs.core.UriInfo;
/** /**
* *
@@ -41,9 +30,14 @@ import javax.ws.rs.core.UriInfo;
@Singleton @Singleton
@Path("repositories") @Path("repositories")
@Produces({ MediaType.APPLICATION_XML, MediaType.APPLICATION_JSON }) @Produces({ MediaType.APPLICATION_XML, MediaType.APPLICATION_JSON })
public class RepositoryResource public class RepositoryResource extends AbstractResource<Repository>
{ {
/** Field description */
public static final String PATH_PART = "repositories";
//~--- constructors ---------------------------------------------------------
/** /**
* Constructs ... * Constructs ...
* *
@@ -75,21 +69,24 @@ public class RepositoryResource
* Method description * Method description
* *
* *
* * @param item
* @param uriInfo
* @param repository
*
* @return
*/ */
@POST @Override
@Consumes({ MediaType.APPLICATION_XML, MediaType.APPLICATION_JSON }) protected void addItem(Repository item)
public Response add(@Context UriInfo uriInfo, Repository repository)
{ {
repositoryStore.put(repository.getName(), repository); repositoryStore.put(item.getName(), item);
}
return Response.created( /**
uriInfo.getAbsolutePath().resolve( * Method description
"repositories/".concat(repository.getName()))).build(); *
*
* @param item
*/
@Override
protected void removeItem(Repository item)
{
repositoryStore.remove(item.getName());
} }
/** /**
@@ -97,60 +94,48 @@ public class RepositoryResource
* *
* *
* @param name * @param name
* * @param item
* @return
*/ */
@DELETE @Override
@Path("{name}") protected void updateItem(String name, Repository item)
public Response delete(@PathParam("name") String name)
{ {
Repository repository = repositoryStore.get(name); Repository repository = repositoryStore.get(name);
if (repository == null) repository.setContact(item.getContact());
{ repository.setDescription(item.getDescription());
throw new WebApplicationException(Status.NOT_FOUND);
}
repositoryStore.remove(name);
return Response.noContent().build();
}
/**
* Method description
*
*
*
*
* @param uriInfo
* @param name
* @param repository
*
* @return
*/
@PUT
@Path("{name}")
@Consumes({ MediaType.APPLICATION_XML, MediaType.APPLICATION_JSON })
public Response update(@Context UriInfo uriInfo,
@PathParam("name") String name, Repository repository)
{
Repository updateRepository = repositoryStore.get(name);
if (updateRepository == null)
{
throw new WebApplicationException(Status.NOT_FOUND);
}
updateRepository.setName(name);
updateRepository.setDescription(repository.getDescription());
updateRepository.setContact(repository.getContact());
return Response.created(
uriInfo.getAbsolutePath().resolve(repository.getName())).build();
} }
//~--- get methods ---------------------------------------------------------- //~--- get methods ----------------------------------------------------------
/**
* Method description
*
*
* @return
*/
@Override
protected Repository[] getAllItems()
{
Collection<Repository> repositoryCollection = repositoryStore.values();
return repositoryCollection.toArray(
new Repository[repositoryCollection.size()]);
}
/**
* Method description
*
*
* @param item
*
* @return
*/
@Override
protected String getId(Repository item)
{
return item.getName();
}
/** /**
* Method description * Method description
* *
@@ -159,18 +144,10 @@ public class RepositoryResource
* *
* @return * @return
*/ */
@GET @Override
@Path("{name}") protected Repository getItem(String name)
public Repository get(@PathParam("name") String name)
{ {
Repository repository = repositoryStore.get(name); return repositoryStore.get(name);
if (repository == null)
{
throw new WebApplicationException(Status.NOT_FOUND);
}
return repository;
} }
/** /**
@@ -179,13 +156,10 @@ public class RepositoryResource
* *
* @return * @return
*/ */
@GET @Override
public Repository[] getAll() protected String getPathPart()
{ {
Collection<Repository> repositoryCollection = repositoryStore.values(); return PATH_PART;
return repositoryCollection.toArray(
new Repository[repositoryCollection.size()]);
} }
//~--- fields --------------------------------------------------------------- //~--- fields ---------------------------------------------------------------