package com.jspxcms.core.web.back;
import static com.jspxcms.core.support.Constants.CREATE;
import static com.jspxcms.core.support.Constants.DELETE_SUCCESS;
import static com.jspxcms.core.support.Constants.EDIT;
import static com.jspxcms.core.support.Constants.MESSAGE;
import static com.jspxcms.core.support.Constants.OPRT;
import static com.jspxcms.core.support.Constants.SAVE_SUCCESS;
import java.util.List;
import java.util.Map;
import javax.servlet.http.HttpServletRequest;
import org.apache.shiro.authz.annotation.RequiresPermissions;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.domain.Pageable;
import org.springframework.data.domain.Sort.Direction;
import org.springframework.data.web.PageableDefaults;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.ModelAttribute;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.servlet.mvc.support.RedirectAttributes;
import com.jspxcms.common.util.RowSide;
import com.jspxcms.common.web.Servlets;
import com.jspxcms.core.domain.Role;
import com.jspxcms.core.service.RoleService;
import com.jspxcms.core.support.Constants;
import com.jspxcms.core.support.Context;
/**
* RoleController
*
* @author liufang
*
*/
@Controller
@RequestMapping("/core/role")
public class RoleController {
private static final Logger logger = LoggerFactory
.getLogger(RoleController.class);
@RequiresPermissions("core:role:list")
@RequestMapping("list.do")
public String list(
@PageableDefaults(sort = { "seq", "id" }, sortDir = Direction.ASC) Pageable pageable,
HttpServletRequest request, org.springframework.ui.Model modelMap) {
Map<String, String[]> params = Servlets.getParameterValuesMap(request,
Constants.SEARCH_PREFIX);
List<Role> list = service.findList(params, pageable.getSort());
modelMap.addAttribute("list", list);
return "core/role/role_list";
}
@RequiresPermissions("core:role:create")
@RequestMapping("create.do")
public String create(Integer id, org.springframework.ui.Model modelMap) {
if (id != null) {
Role bean = service.get(id);
modelMap.addAttribute("bean", bean);
}
modelMap.addAttribute(OPRT, CREATE);
return "core/role/role_form";
}
@RequiresPermissions("core:role:edit")
@RequestMapping("edit.do")
public String edit(Integer id, Integer position, @PageableDefaults(sort = {
"seq", "id" }, sortDir = Direction.ASC) Pageable pageable,
HttpServletRequest request, org.springframework.ui.Model modelMap) {
Integer siteId = Context.getCurrentSiteId(request);
Role bean = service.get(id);
Map<String, String[]> params = Servlets.getParameterValuesMap(request,
Constants.SEARCH_PREFIX);
RowSide<Role> side = service.findSide(params, bean, position,
pageable.getSort());
modelMap.addAttribute("allPerm", bean.getAllPerm(siteId));
modelMap.addAttribute("allInfo", bean.getAllInfo(siteId));
modelMap.addAttribute("allNode", bean.getAllNode(siteId));
modelMap.addAttribute("perms", bean.getPerms(siteId));
modelMap.addAttribute("infoRights", bean.getInfoRights(siteId));
modelMap.addAttribute("nodeRights", bean.getNodeRights(siteId));
modelMap.addAttribute("infoRightType", bean.getInfoRightType(siteId));
modelMap.addAttribute("bean", bean);
modelMap.addAttribute("side", side);
modelMap.addAttribute("position", position);
modelMap.addAttribute(OPRT, EDIT);
return "core/role/role_form";
}
@RequiresPermissions("core:role:save")
@RequestMapping("save.do")
public String save(Role bean, Boolean allPerm, String perms,
Boolean allInfo, Integer[] infoRightIds, Boolean allNode,
Integer[] nodeRightIds, Integer infoRightType, String redirect,
HttpServletRequest request, RedirectAttributes ra) {
Integer siteId = Context.getCurrentSiteId(request);
service.save(bean, allPerm, perms, allInfo, infoRightIds, allNode,
nodeRightIds, infoRightType, siteId);
logger.info("save Role, name={}.", bean.getName());
ra.addFlashAttribute(MESSAGE, SAVE_SUCCESS);
if (Constants.REDIRECT_LIST.equals(redirect)) {
return "redirect:list.do";
} else if (Constants.REDIRECT_CREATE.equals(redirect)) {
return "redirect:create.do";
} else {
ra.addAttribute("id", bean.getId());
return "redirect:edit.do";
}
}
@RequiresPermissions("core:role:update")
@RequestMapping("update.do")
public String update(@ModelAttribute("bean") Role bean, Boolean allPerm,
String perms, Boolean allInfo, Integer[] infoRightIds,
Boolean allNode, Integer[] nodeRightIds, Integer infoRightType,
Integer position, String redirect, RedirectAttributes ra) {
service.update(bean, allPerm, perms, allInfo, infoRightIds, allNode,
nodeRightIds, infoRightType);
logger.info("update Role, name={}.", bean.getName());
ra.addFlashAttribute(MESSAGE, SAVE_SUCCESS);
if (Constants.REDIRECT_LIST.equals(redirect)) {
return "redirect:list.do";
} else {
ra.addAttribute("id", bean.getId());
ra.addAttribute("position", position);
return "redirect:edit.do";
}
}
@RequiresPermissions("core:role:delete")
@RequestMapping("delete.do")
public String delete(Integer[] ids, RedirectAttributes ra) {
Role[] beans = service.delete(ids);
for (Role bean : beans) {
logger.info("delete Role, name={}.", bean.getName());
}
ra.addFlashAttribute(MESSAGE, DELETE_SUCCESS);
return "redirect:list.do";
}
@ModelAttribute("bean")
public Role preloadBean(@RequestParam(required = false) Integer oid) {
return oid != null ? service.get(oid) : null;
}
@Autowired
private RoleService service;
}