ReaderRestView.java 2.78 KB
package fi.codecrew.moya.rest;

import javax.ejb.EJB;
import javax.enterprise.context.RequestScoped;
import javax.ws.rs.Consumes;
import javax.ws.rs.GET;
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.Response.ResponseBuilder;
import javax.ws.rs.core.Response.Status;

import fi.codecrew.moya.beans.ReaderBeanLocal;
import fi.codecrew.moya.beans.UserBeanLocal;
import fi.codecrew.moya.model.EventUser;
import fi.codecrew.moya.model.ReaderEvent;
import fi.codecrew.moya.rest.pojo.EventUserRestPojo;
import fi.codecrew.moya.rest.pojo.ReaderEventRestPojo;
import fi.codecrew.moya.rest.pojo.ReaderEventRestRoot;
import fi.codecrew.moya.rest.pojo.ReaderRestPojo;
import fi.codecrew.moya.rest.pojo.ReaderRestRoot;
import fi.codecrew.moya.rest.pojo.UserPermissionRestPojo;

@RequestScoped
@Path("/reader")
@Consumes({ MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
@Produces({ MediaType.APPLICATION_JSON })
public class ReaderRestView {

	@EJB
	private ReaderBeanLocal readerbean;

	@EJB
	private UserBeanLocal userbean;

	@GET
	@Path("/List")
	public ReaderRestRoot getReaderList()
	{
		return new ReaderRestRoot(ReaderRestPojo.parse(readerbean.getReaders()));
	}

	@GET
	@Path("/LastEventusers")
	public ReaderEventRestRoot getLastEventusers()
	{
		return new ReaderEventRestRoot(ReaderEventRestPojo.parse(readerbean.getLastReaderEvents()));
	}

	//	@GET
	//	@Path("/RfidEvent/{reader}/{tagId}")
	//	public void createRfidEvent(@PathParam("reader") String reader, @PathParam("tagId") String tagId) {
	//
	//	}

	@GET
	@Path("/EventRole/{reader}/{tagId}/{roleid}")
	public Response eventRole(@PathParam("reader") String reader, @PathParam("tagId") String tag, @PathParam("roleid") Integer roleId) {
		ReaderEvent ret = readerbean.checkTag(reader, tag);
		ResponseBuilder builder = null;
		if (roleId == null || roleId.equals(0))
		{
			builder = Response.status(Status.BAD_REQUEST);
			builder.entity("role ID is required!");
			builder.type(MediaType.TEXT_PLAIN);

		}
		if (builder == null)
		{
			if (ret == null || ret.getPrintedCard() == null) {
				builder = Response.status(Status.NOT_ACCEPTABLE);
				builder.entity("No card found for uid.");
				builder.type(MediaType.TEXT_PLAIN);
			} else {
				EventUser user = ret.getPrintedCard().getUser();
				boolean found = userbean.isUserInRole(user, roleId);
				if (found) {
					builder = Response.status(Status.OK);
				} else {
					builder = Response.status(Status.FORBIDDEN);
				}
				builder.entity(new UserPermissionRestPojo(new EventUserRestPojo(user), found));

			}
		}

		return builder.build();
	}

	@GET
	@Path("/EventCard/{reader}/{cardid}")
	public void eventCard(@PathParam("reader") String reader, @PathParam("cardid") String cardId) {

	}

}