package com.techiekernel.easylocate.ws;
import java.util.List;
import javax.servlet.http.HttpServletResponse;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.ResponseBody;
import com.techiekernel.easylocate.pojo.Role;
import com.techiekernel.easylocate.service.RoleService;
@Controller
@RequestMapping("/api/role")
public class RoleWebService {
@Autowired
RoleService roleService;
@RequestMapping(value = "/{roleId}", method = RequestMethod.GET, headers = "Accept=application/json", produces = { "application/json" })
@ResponseBody
public Role getRole(@PathVariable int roleId, HttpServletResponse response) {
response.setHeader("Access-Control-Allow-Origin", "*");
return roleService.getRole(roleId);
}
@RequestMapping(method = RequestMethod.GET, headers = "Accept=application/json", produces = { "application/json" })
@ResponseBody
public List<Role> getRoles(HttpServletResponse response) {
response.setHeader("Access-Control-Allow-Origin", "*");
return roleService.getRoles();
}
@RequestMapping(method = RequestMethod.POST, headers = "Accept=application/json", produces = { "application/json" }, consumes = { "application/json" })
@ResponseBody
public boolean createRole(@RequestBody Role role,
HttpServletResponse response) {
response.setHeader("Access-Control-Allow-Origin", "*");
return roleService.saveOrUpdateRole(role);
}
@RequestMapping(value = "/{roleId}", method = RequestMethod.PUT, headers = "Accept=application/json", produces = { "application/json" }, consumes = { "application/json" })
@ResponseBody
public boolean editFoobar(@RequestBody Role role, @PathVariable int roleId,
HttpServletResponse response) {
response.setHeader("Access-Control-Allow-Origin", "*");
if (role.getRoleId() != null)
return roleService.saveOrUpdateRole(role);
else
return false;
}
@RequestMapping(value = "/{roleId}", method = RequestMethod.DELETE, headers = "Accept=application/json", produces = { "application/json" })
@ResponseBody
public boolean deleteRole(@PathVariable int roleId,
HttpServletResponse response) {
response.setHeader("Access-Control-Allow-Origin", "*");
return roleService.deleteRole(roleId);
}
}