Package com.thinkgem.jeesite.modules.sys.web

Source Code of com.thinkgem.jeesite.modules.sys.web.RoleController

/**
* Copyright &copy; 2012-2013 <a href="https://github.com/thinkgem/jeesite">JeeSite</a> All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
*/
package com.thinkgem.jeesite.modules.sys.web;

import java.util.List;
import java.util.Map;

import javax.servlet.http.HttpServletResponse;

import org.apache.shiro.authz.annotation.RequiresPermissions;
import org.apache.shiro.authz.annotation.RequiresUser;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
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.bind.annotation.ResponseBody;
import org.springframework.web.servlet.mvc.support.RedirectAttributes;

import com.google.common.collect.Lists;
import com.google.common.collect.Maps;
import com.thinkgem.jeesite.common.config.Global;
import com.thinkgem.jeesite.common.utils.StringUtils;
import com.thinkgem.jeesite.common.web.BaseController;
import com.thinkgem.jeesite.modules.sys.entity.Office;
import com.thinkgem.jeesite.modules.sys.entity.Role;
import com.thinkgem.jeesite.modules.sys.entity.User;
import com.thinkgem.jeesite.modules.sys.service.OfficeService;
import com.thinkgem.jeesite.modules.sys.service.SystemService;
import com.thinkgem.jeesite.modules.sys.utils.UserUtils;

/**
* 角色Controller
* @author ThinkGem
* @version 2013-5-15 update 2013-06-08
*/
@Controller
@RequestMapping(value = "${adminPath}/sys/role")
public class RoleController extends BaseController {

  @Autowired
  private SystemService systemService;
 
//  @Autowired
//  private CategoryService categoryService;

  @Autowired
  private OfficeService officeService;
 
  @ModelAttribute("role")
  public Role get(@RequestParam(required=false) String id) {
    if (StringUtils.isNotBlank(id)){
      return systemService.getRole(id);
    }else{
      return new Role();
    }
  }
 
  @RequiresPermissions("sys:role:view")
  @RequestMapping(value = {"list", ""})
  public String list(Role role, Model model) {
    List<Role> list = systemService.findAllRole();
    model.addAttribute("list", list);
    return "modules/sys/roleList";
  }

  @RequiresPermissions("sys:role:view")
  @RequestMapping(value = "form")
  public String form(Role role, Model model) {
    if (role.getOffice()==null){
      role.setOffice(UserUtils.getUser().getOffice());
    }
    model.addAttribute("role", role);
    model.addAttribute("menuList", systemService.findAllMenu());
//    model.addAttribute("categoryList", categoryService.findByUser(false, null));
    model.addAttribute("officeList", officeService.findAll());
    return "modules/sys/roleForm";
  }
 
  @RequiresPermissions("sys:role:edit")
  @RequestMapping(value = "save")
  public String save(Role role, Model model, String oldName, RedirectAttributes redirectAttributes) {
    if(Global.isDemoMode()){
      addMessage(redirectAttributes, "演示模式,不允许操作!");
      return "redirect:"+Global.getAdminPath()+"/sys/role/?repage";
    }
    if (!beanValidator(model, role)){
      return form(role, model);
    }
    if (!"true".equals(checkName(oldName, role.getName()))){
      addMessage(model, "保存角色'" + role.getName() + "'失败, 角色名已存在");
      return form(role, model);
    }
    systemService.saveRole(role);
    addMessage(redirectAttributes, "保存角色'" + role.getName() + "'成功");
    return "redirect:"+Global.getAdminPath()+"/sys/role/?repage";
  }
 
  @RequiresPermissions("sys:role:edit")
  @RequestMapping(value = "delete")
  public String delete(@RequestParam String id, RedirectAttributes redirectAttributes) {
    if(Global.isDemoMode()){
      addMessage(redirectAttributes, "演示模式,不允许操作!");
      return "redirect:"+Global.getAdminPath()+"/sys/role/?repage";
    }
    if (Role.isAdmin(id)){
      addMessage(redirectAttributes, "删除角色失败, 不允许内置角色或编号空");
//    }else if (UserUtils.getUser().getRoleIdList().contains(id)){
//      addMessage(redirectAttributes, "删除角色失败, 不能删除当前用户所在角色");
    }else{
      systemService.deleteRole(id);
      addMessage(redirectAttributes, "删除角色成功");
    }
    return "redirect:"+Global.getAdminPath()+"/sys/role/?repage";
  }
 
  @RequiresPermissions("sys:role:edit")
  @RequestMapping(value = "assign")
  public String assign(Role role, Model model) {
    List<User> users = role.getUserList();
    model.addAttribute("users", users);
    return "modules/sys/roleAssign";
  }
 
  @RequiresPermissions("sys:role:view")
  @RequestMapping(value = "usertorole")
  public String selectUserToRole(Role role, Model model) {
    model.addAttribute("role", role);
    model.addAttribute("selectIds", role.getUserIds());
    model.addAttribute("officeList", officeService.findAll());
    return "modules/sys/selectUserToRole";
  }
 
  @RequiresPermissions("sys:role:view")
  @ResponseBody
  @RequestMapping(value = "users")
  public List<Map<String, Object>> users(String officeId, HttpServletResponse response) {
    response.setContentType("application/json; charset=UTF-8");
    List<Map<String, Object>> mapList = Lists.newArrayList();
    Office office = officeService.get(officeId);
    List<User> userList = office.getUserList();
    for (User user : userList) {
      Map<String, Object> map = Maps.newHashMap();
      map.put("id", user.getId());
      map.put("pId", 0);
      map.put("name", user.getName());
      mapList.add(map);     
    }
    return mapList;
  }
 
  @RequiresPermissions("sys:role:edit")
  @RequestMapping(value = "outrole")
  public String outrole(String userId, String roleId, RedirectAttributes redirectAttributes) {
    if(Global.isDemoMode()){
      addMessage(redirectAttributes, "演示模式,不允许操作!");
      return "redirect:"+Global.getAdminPath()+"/sys/role/assign?id="+roleId;
    }
    Role role = systemService.getRole(roleId);
    User user = systemService.getUser(userId);
    if (user.equals(UserUtils.getUser())) {
      addMessage(redirectAttributes, "无法从角色【" + role.getName() + "】中移除用户【" + user.getName() + "】自己!");
    }else {
      Boolean flag = systemService.outUserInRole(role, userId);
      if (!flag) {
        addMessage(redirectAttributes, "用户【" + user.getName() + "】从角色【" + role.getName() + "】中移除失败!");
      }else {
        addMessage(redirectAttributes, "用户【" + user.getName() + "】从角色【" + role.getName() + "】中移除成功!");
      }     
    }
    return "redirect:"+Global.getAdminPath()+"/sys/role/assign?id="+role.getId();
  }
 
  @RequiresPermissions("sys:role:edit")
  @RequestMapping(value = "assignrole")
  public String assignRole(Role role, String[] idsArr, RedirectAttributes redirectAttributes) {
    if(Global.isDemoMode()){
      addMessage(redirectAttributes, "演示模式,不允许操作!");
      return "redirect:"+Global.getAdminPath()+"/sys/role/assign?id="+role.getId();
    }
    StringBuilder msg = new StringBuilder();
    int newNum = 0;
    for (int i = 0; i < idsArr.length; i++) {
      User user = systemService.assignUserToRole(role, idsArr[i]);
      if (null != user) {
        msg.append("<br/>新增用户【" + user.getName() + "】到角色【" + role.getName() + "】!");
        newNum++;
      }
    }
    addMessage(redirectAttributes, "已成功分配 "+newNum+" 个用户"+msg);
    return "redirect:"+Global.getAdminPath()+"/sys/role/assign?id="+role.getId();
  }

  @RequiresUser
  @ResponseBody
  @RequestMapping(value = "checkName")
  public String checkName(String oldName, String name) {
    if (name!=null && name.equals(oldName)) {
      return "true";
    } else if (name!=null && systemService.findRoleByName(name) == null) {
      return "true";
    }
    return "false";
  }

}
TOP

Related Classes of com.thinkgem.jeesite.modules.sys.web.RoleController

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.