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; }