コード例 #1
0
 public void roleEdit(User user) {
   if (user.getIds() != null) {
     for (String id : user.getIds().split(",")) {
       Tuser u = userDao.get(Tuser.class, id);
       this.saveUserRole(user, u);
     }
   }
 }
コード例 #2
0
 public void add(Auth auth) {
   Tauth t = new Tauth();
   BeanUtils.copyProperties(auth, t);
   t.setCid(UUID.randomUUID().toString());
   if (auth.getPid() != null && !auth.getPid().equals(auth.getCid())) {
     t.setTauth(authDao.get(Tauth.class, auth.getPid()));
   }
   authDao.save(t);
 }
コード例 #3
0
 public void update(User user) {
   Tuser u = userDao.get(Tuser.class, user.getCid());
   BeanUtils.copyProperties(user, u, new String[] {"cid", "cpwd"});
   if (user.getCpwd() != null && !user.getCpwd().trim().equals("")) {
     u.setCpwd(Encrypt.e(user.getCpwd()));
   }
   u.setCmodifydatetime(new Date());
   this.saveUserRole(user, u);
 }
コード例 #4
0
 public void edit(Auth auth) {
   Tauth t = authDao.get(Tauth.class, auth.getCid()); // authority to be edit
   BeanUtils.copyProperties(auth, t);
   if (auth.getPid() != null && !auth.getPid().equals(auth.getCid())) {
     Tauth pAuth = authDao.get(Tauth.class, auth.getPid()); // parent authority
     if (pAuth != null) {
       if (isDown(t, pAuth)) {
         Set<Tauth> tauths = t.getTauths(); // all child auth of current auth
         if (tauths != null && tauths.size() > 0) {
           for (Tauth tauth : tauths) {
             if (tauth != null) {
               tauth.setTauth(null);
             }
           }
         }
       }
       t.setTauth(pAuth);
     }
   }
 }
コード例 #5
0
 public void delete(String ids) {
   if (ids != null) {
     for (String id : ids.split(",")) {
       Tuser u = userDao.get(Tuser.class, id.trim());
       if (u != null) {
         userroleDao.executeHql("delete Tusertrole t where t.tuser = ?", new Object[] {u});
         userDao.delete(u);
       }
     }
   }
 }
コード例 #6
0
 /**
  * keep relationship between user and role
  *
  * @param user
  * @param u
  */
 private void saveUserRole(User user, Tuser u) {
   userroleDao.executeHql("delete Tusertrole t where t.tuser = ?", new Object[] {u});
   if (user.getRoleIds() != null) {
     for (String id : user.getRoleIds().split(",")) {
       Tusertrole tusertrole = new Tusertrole();
       tusertrole.setCid(UUID.randomUUID().toString());
       tusertrole.setTrole(roleDao.get(Trole.class, id.trim()));
       tusertrole.setTuser(u);
       userroleDao.save(tusertrole);
     }
   }
 }
コード例 #7
0
 private void del(String cid) {
   Tauth t = authDao.get(Tauth.class, cid);
   if (t != null) {
     roleauthDao.executeHql("delete Troletauth t where t.tauth = ?", new Object[] {t});
     Set<Tauth> auths = t.getTauths();
     if (auths != null && !auths.isEmpty()) {
       // there exists child auth under current auth
       for (Tauth tauth : auths) {
         del(tauth.getCid());
       }
     }
     authDao.delete(t);
   }
 }
コード例 #8
0
  public User login(User user) {
    Tuser t =
        userDao.get(
            "from Tuser t where t.cname = ? and t.cpwd = ?",
            new Object[] {user.getCname(), Encrypt.e(user.getCpwd())});
    if (t != null) {
      BeanUtils.copyProperties(t, user, new String[] {"cpwd"});

      Map<String, String> authIdsMap = new HashMap<String, String>();
      String authIds = "";
      String authNames = "";
      Map<String, String> authUrlsMap = new HashMap<String, String>();
      String authUrls = "";
      String roleIds = "";
      String roleNames = "";
      boolean b1 = false;
      Set<Tusertrole> tusertroles = t.getTusertroles();
      if (tusertroles != null && tusertroles.size() > 0) {
        for (Tusertrole tusertrole : tusertroles) {
          Trole trole = tusertrole.getTrole();
          if (b1) {
            roleIds += ",";
            roleNames += ",";
          }
          roleIds += trole.getCid();
          roleNames += trole.getCname();
          b1 = true;

          Set<Troletauth> troletauths = trole.getTroletauths();
          if (troletauths != null && troletauths.size() > 0) {
            for (Troletauth troletauth : troletauths) {
              Tauth tauth = troletauth.getTauth();
              authIdsMap.put(tauth.getCid(), tauth.getCname());
              authUrlsMap.put(tauth.getCid(), tauth.getCurl());
            }
          }
        }
      }
      boolean b2 = false;
      for (String id : authIdsMap.keySet()) {
        if (b2) {
          authIds += ",";
          authNames += ",";
        }
        authIds += id;
        authNames += authIdsMap.get(id);
        b2 = true;
      }
      user.setAuthIds(authIds);
      user.setAuthNames(authNames);
      user.setRoleIds(roleIds);
      user.setRoleNames(roleNames);
      boolean b3 = false;
      for (String id : authUrlsMap.keySet()) {
        if (b3) {
          authUrls += ",";
        }
        authUrls += authUrlsMap.get(id);
        b3 = true;
      }
      user.setAuthUrls(authUrls);

      return user;
    }
    return null;
  }
コード例 #9
0
 public void editUserInfo(User user) {
   if (user.getCpwd() != null && !user.getCpwd().trim().equals("")) {
     Tuser t = userDao.get(Tuser.class, user.getCid());
     t.setCpwd(Encrypt.e(user.getCpwd()));
   }
 }