/**
  * 根据密码和新密码 进行密码修改
  *
  * @param loginPwd 原来的密码
  * @param newLoginPwd 新密码
  * @return 成功或者失败
  * @throws Exception 抛出异常
  */
 @Override
 @Transactional(readOnly = false, rollbackFor = Throwable.class)
 public int updPassword(String loginPwd, String newLoginPwd, HttpServletRequest request)
     throws Exception {
   LoginToken loginToken =
       (LoginToken) SessionUtils.getObjectAttribute(request, SessionNameConstants.LOGIN_TOKEN);
   if (loginToken.getSysLogin().getLoginPwd().equals(MD5Utils.toMD5(loginPwd))) {
     SysLogin login = loginToken.getSysLogin();
     // 用MD5算法加密
     login.setLoginPwd(MD5Utils.toMD5(newLoginPwd));
     baseDao.update(login);
     // 保存系统日志
     String operDesc = "【修改密码】用户名:" + login.getLoginName();
     sysLogService.save(SysLog.OPERATE_TYPE_UPDATE, operDesc);
     return ResultConstants.UPDATE_SUCCEED;
   } else return ResultConstants.UPDATE_FAILED;
 }
  /**
   * 加载登录用户的相关信息到登录令牌
   *
   * @param frameSysLogin
   * @return
   */
  public LoginToken getAdminLoginToken(SysLogin sysLogin) throws Exception {
    LoginToken loginToken = new LoginToken();
    loginToken.setSysLogin(sysLogin);
    // 获得该登录者单位信息
    if (sysLogin.getSysCorp() != null) {
      Hibernate.initialize(sysLogin.getSysCorp());
      loginToken.setSysCorp(sysLogin.getSysCorp());
    }
    List<SysRole> roles = new ArrayList<SysRole>();
    if (sysLogin.getSysLoginRoles() != null && sysLogin.getSysLoginRoles().size() > 0) {

      List<SysLoginRole> sysLoginRoles = sysLogin.getSysLoginRoles();
      for (SysLoginRole sysLoginRole : sysLoginRoles) {
        roles.add(sysLoginRole.getSysRole());
      }

    } else {
      SysRole role = new SysRole();
      role.setRoleName("超级管理员");
      roles.add(role);
    }
    loginToken.setSysRoles(roles);
    // 设置登录信息

    Map<Long, SysPermission> menuPermissions = new HashMap<Long, SysPermission>();
    List<SysPermission> menus = null;
    // 如果是超级管理员用户,则显示所有菜单
    if (sysLogin.getUserType().longValue() == SysLogin.USER_TYPE_SUPER_ADMIN) {
      // 获得本系统下所有的菜单项和权限项
      menus = sysPermissionService.findMenuBySystemId(sysLogin.getSystemId());
      for (SysPermission menu : menus) menuPermissions.put(menu.getPermissionId(), menu);

    }
    // 如果不是超级管理员,则根据分配的角色进行权限查询
    else if (sysLogin.getSysLoginRoles() != null) {
      for (SysLoginRole sysLoginRole : sysLogin.getSysLoginRoles()) {
        SysRole sysRole = sysLoginRole.getSysRole();

        for (SysRolePermission rolePermission : sysRole.getSysRolePermissions())
          menuPermissions.put(
              rolePermission.getSysPermission().getPermissionId(),
              rolePermission.getSysPermission());
      }
    }
    loginToken.setMenuPermissions(menuPermissions);

    // 取得数据库中所有一级菜单列表
    List<SysPermission> allLevel1MenuList = sysPermissionService.findLevel1Menu(1);

    List<SysPermission> level1MenuList = new ArrayList<SysPermission>();
    Map<Long, List<SysPermission>> level2MenuMap = new HashMap<Long, List<SysPermission>>();

    if (allLevel1MenuList != null && allLevel1MenuList.size() > 0) {
      for (SysPermission level1Menu : allLevel1MenuList) {
        Long level1MenuId = level1Menu.getPermissionId();

        List<SysPermission> allLevel2Menus =
            sysPermissionService.findMenuByparentIdAndType(
                level1MenuId, SysPermission.PERMISSION_TYPE_1);
        List<SysPermission> level2Menus = new ArrayList<SysPermission>();
        if (allLevel2Menus != null && allLevel2Menus.size() > 0) {
          for (SysPermission level2menu : allLevel2Menus) {
            Long level2MenuId = level2menu.getPermissionId();
            if (menuPermissions.containsKey(level2MenuId)) {
              level2Menus.add(level2menu);
            }
          }
          if (level2Menus.size() > 0) {
            level1MenuList.add(level1Menu);
            level2MenuMap.put(level1MenuId, level2Menus);
          }
        }
      }
    }
    loginToken.setLevel1MenuList(level1MenuList);
    loginToken.setLevel2MenuMap(level2MenuMap);
    return loginToken;
  }