com.aistor.modules.sys.service.SystemService.java Source code

Java tutorial

Introduction

Here is the source code for com.aistor.modules.sys.service.SystemService.java

Source

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

import java.util.Date;
import java.util.List;

import org.apache.commons.lang3.StringUtils;
import org.apache.shiro.SecurityUtils;
import org.hibernate.criterion.DetachedCriteria;
import org.hibernate.criterion.Order;
import org.hibernate.criterion.Restrictions;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;

import com.aistor.common.persistence.Page;
import com.aistor.common.security.Digests;
import com.aistor.common.service.BaseService;
import com.aistor.common.utils.Encodes;
import com.aistor.modules.sys.dao.MenuDao;
import com.aistor.modules.sys.dao.RoleDao;
import com.aistor.modules.sys.dao.UserDao;
import com.aistor.modules.sys.entity.Menu;
import com.aistor.modules.sys.entity.Role;
import com.aistor.modules.sys.entity.User;
import com.aistor.modules.sys.security.SystemRealm;
import com.aistor.modules.sys.utils.UserUtils;

/**
 * ??,????.
 * @author Zaric
 * @version 2013-3-15
 */
@Service
@Transactional(readOnly = true)
public class SystemService extends BaseService {

    @SuppressWarnings("unused")
    private static Logger logger = LoggerFactory.getLogger(SystemService.class);

    public static final String HASH_ALGORITHM = "SHA-1";
    public static final int HASH_INTERATIONS = 1024;
    public static final int SALT_SIZE = 8;

    @Autowired
    private UserDao userDao;
    @Autowired
    private RoleDao roleDao;
    @Autowired
    private MenuDao menuDao;
    @Autowired
    private SystemRealm systemRealm;

    //-- User Service --//

    public User getUser(Long id) {
        return userDao.findOne(id);
    }

    public Page<User> findUser(Page<User> page, User user) {
        DetachedCriteria dc = userDao.createDetachedCriteria();
        User currentUser = UserUtils.getUser();
        if (!currentUser.isAdmin()) {
            if (user.getArea() == null || user.getArea().getId() == null) {
                user.setArea(currentUser.getArea());
            }
            if (user.getOffice() == null || user.getOffice().getId() == null) {
                user.setOffice(currentUser.getOffice());
            }
        }
        dc.createAlias("area", "area");
        if (user.getArea() != null && user.getArea().getId() != null) {
            dc.add(Restrictions.or(Restrictions.eq("area.id", user.getArea().getId()),
                    Restrictions.eq("area.parent.id", user.getArea().getId()),
                    Restrictions.like("area.parentIds", "%," + user.getArea().getId() + ",%")));
        }
        dc.createAlias("office", "office");
        if (user.getOffice() != null && user.getOffice().getId() != null) {
            dc.add(Restrictions.or(Restrictions.eq("office.id", user.getOffice().getId()),
                    Restrictions.eq("office.parent.id", user.getOffice().getId()),
                    Restrictions.like("office.parentIds", "%," + user.getOffice().getId() + ",%")));
        }
        if (StringUtils.isNotEmpty(user.getLoginName())) {
            dc.add(Restrictions.like("loginName", "%" + user.getLoginName() + "%"));
        }
        if (StringUtils.isNotEmpty(user.getName())) {
            dc.add(Restrictions.like("name", "%" + user.getName() + "%"));
        }
        dc.add(Restrictions.eq("delFlag", User.DEL_FLAG_NORMAL));
        if (!StringUtils.isNotEmpty(page.getOrderBy())) {
            dc.addOrder(Order.asc("area.code")).addOrder(Order.asc("office.code"));
        }
        return userDao.find(page, dc);
    }

    public User getUserByLoginName(String loginName) {
        return userDao.findByLoginName(loginName);
    }

    @Transactional(readOnly = false)
    public void saveUser(User user) {
        userDao.clear();
        userDao.save(user);
        systemRealm.clearCachedAuthorizationInfo(user.getLoginName());
    }

    @Transactional(readOnly = false)
    public void deleteUser(Long id) {
        userDao.deleteById(id);
    }

    @Transactional(readOnly = false)
    public void updatePasswordById(Long id, String loginName, String newPassword) {
        userDao.updatePasswordById(entryptPassword(newPassword), id);
        systemRealm.clearCachedAuthorizationInfo(loginName);
    }

    @Transactional(readOnly = false)
    public void updateUserLoginInfo(Long id) {
        userDao.updateLoginInfo(SecurityUtils.getSubject().getSession().getHost(), new Date(), id);
    }

    /**
     * ????16?salt?1024 sha-1 hash
     */
    public static String entryptPassword(String plainPassword) {
        byte[] salt = Digests.generateSalt(SALT_SIZE);
        byte[] hashPassword = Digests.sha1(plainPassword.getBytes(), salt, HASH_INTERATIONS);
        return Encodes.encodeHex(salt) + Encodes.encodeHex(hashPassword);
    }

    /**
     * ??
     * @param plainPassword ?
     * @param password ?
     * @return ??true
     */
    public static boolean validatePassword(String plainPassword, String password) {
        byte[] salt = Encodes.decodeHex(password.substring(0, 16));
        byte[] hashPassword = Digests.sha1(plainPassword.getBytes(), salt, HASH_INTERATIONS);
        return password.equals(Encodes.encodeHex(salt) + Encodes.encodeHex(hashPassword));
    }

    //-- Role Service --//

    public Role getRole(Long id) {
        return roleDao.findOne(id);
    }

    public Role findRoleByName(String name) {
        return roleDao.findByName(name);
    }

    public List<Role> findAllRole() {
        User currentUser = UserUtils.getUser();
        if (!currentUser.isAdmin()) {
            return roleDao.findByUserId(currentUser.getId());
        } else {
            return roleDao.findAllList();
        }
    }

    @Transactional(readOnly = false)
    public void saveRole(Role role) {
        if (role.getId() == null) {
            role.setUser(UserUtils.getUser());
        }
        roleDao.save(role);
        systemRealm.clearAllCachedAuthorizationInfo();
    }

    @Transactional(readOnly = false)
    public void deleteRole(Long id) {
        roleDao.deleteById(id);
        systemRealm.clearAllCachedAuthorizationInfo();
    }

    //-- Menu Service --//

    public Menu getMenu(Long id) {
        return menuDao.findOne(id);
    }

    public List<Menu> findAllMenu() {
        return UserUtils.getMenuList();
    }

    @Transactional(readOnly = false)
    public void saveMenu(Menu menu) {
        menu.setParent(this.getMenu(menu.getParent().getId()));
        String oldParentIds = menu.getParentIds(); // ??parentIds?parentIds
        menu.setParentIds(menu.getParent().getParentIds() + menu.getParent().getId() + ",");
        if (menu.getId() == null) {
            menu.setUser(UserUtils.getUser());
        }
        menuDao.clear();
        menuDao.save(menu);
        // ? parentIds
        List<Menu> list = menuDao.findByParentIdsLike("%," + menu.getId() + ",%");
        for (Menu e : list) {
            e.setParentIds(e.getParentIds().replace(oldParentIds, menu.getParentIds()));
        }
        menuDao.save(list);
        systemRealm.clearAllCachedAuthorizationInfo();
    }

    @Transactional(readOnly = false)
    public void deleteMenu(Long id) {
        menuDao.deleteById(id, "%," + id + ",%");
        systemRealm.clearAllCachedAuthorizationInfo();
    }

}