com.glaf.base.modules.sys.service.mybatis.GroupServiceImpl.java Source code

Java tutorial

Introduction

Here is the source code for com.glaf.base.modules.sys.service.mybatis.GroupServiceImpl.java

Source

/*
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you under the Apache License, Version 2.0 (the
 * "License"); you may not use this file except in compliance
 * with the License.  You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package com.glaf.base.modules.sys.service.mybatis;

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

import org.apache.commons.lang3.StringUtils;
import org.apache.ibatis.session.RowBounds;
import org.mybatis.spring.SqlSessionTemplate;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;

import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONObject;
import com.glaf.base.modules.sys.SysConstants;
import com.glaf.base.modules.sys.mapper.GroupLeaderMapper;
import com.glaf.base.modules.sys.mapper.GroupMapper;
import com.glaf.base.modules.sys.mapper.GroupUserMapper;
import com.glaf.base.modules.sys.model.Group;
import com.glaf.base.modules.sys.model.GroupLeader;
import com.glaf.base.modules.sys.model.GroupUser;
import com.glaf.base.modules.sys.query.GroupQuery;
import com.glaf.base.modules.sys.service.GroupService;
import com.glaf.base.modules.sys.util.GroupJsonFactory;
import com.glaf.core.cache.CacheFactory;
import com.glaf.core.config.SystemConfig;
import com.glaf.core.dao.EntityDAO;
import com.glaf.core.id.IdGenerator;
import com.glaf.core.util.PageResult;
import com.glaf.core.util.UUID32;

@Service("groupService")
@Transactional(readOnly = true)
public class GroupServiceImpl implements GroupService {
    protected EntityDAO entityDAO;

    protected GroupMapper groupMapper;

    protected GroupUserMapper groupUserMapper;

    protected GroupLeaderMapper groupLeaderMapper;

    protected IdGenerator idGenerator;

    protected final Logger logger = LoggerFactory.getLogger(getClass());

    protected SqlSessionTemplate sqlSessionTemplate;

    public GroupServiceImpl() {

    }

    public int count(GroupQuery query) {
        query.ensureInitialized();
        return groupMapper.getGroupCount(query);
    }

    @Transactional
    public void deleteById(String id) {
        if (id != null) {
            groupMapper.deleteGroupById(id);
        }
    }

    @Transactional
    public void deleteByIds(List<String> rowIds) {
        if (rowIds != null && !rowIds.isEmpty()) {
            GroupQuery query = new GroupQuery();
            query.rowIds(rowIds);
            groupMapper.deleteGroups(query);
        }
    }

    public Group getGroup(String id) {
        if (id == null) {
            return null;
        }
        String cacheKey = "sys_group_" + id;

        if (SystemConfig.getBoolean("use_query_cache") && CacheFactory.getString(cacheKey) != null) {
            String text = CacheFactory.getString(cacheKey);
            JSONObject json = JSON.parseObject(text);
            return GroupJsonFactory.jsonToObject(json);
        }
        Group group = groupMapper.getGroupById(id);
        if (group != null && SystemConfig.getBoolean("use_query_cache")) {
            JSONObject json = group.toJsonObject();
            CacheFactory.put(cacheKey, json.toJSONString());
        }
        return group;
    }

    public int getGroupCountByQueryCriteria(GroupQuery query) {
        return groupMapper.getGroupCount(query);
    }

    public PageResult getGroupList(String type, String createBy, int pageNo, int pageSize) {
        // 
        PageResult pager = new PageResult();
        GroupQuery query = new GroupQuery();
        query.setType(type);
        query.setCreateBy(createBy);

        int count = this.count(query);
        if (count == 0) {// 
            pager.setPageSize(pageSize);
            return pager;
        }
        query.setOrderBy(" E.SORT desc");

        int start = pageSize * (pageNo - 1);
        List<Group> list = this.getGroupsByQueryCriteria(start, pageSize, query);
        pager.setResults(list);
        pager.setPageSize(pageSize);
        pager.setCurrentPageNo(pageNo);
        pager.setTotalRecordCount(count);

        return pager;
    }

    public List<Group> getGroupsByQueryCriteria(int start, int pageSize, GroupQuery query) {
        RowBounds rowBounds = new RowBounds(start, pageSize);
        List<Group> rows = sqlSessionTemplate.selectList("getGroups", query, rowBounds);
        return rows;
    }

    /**
     * ??
     * 
     * @param userId
     * @return
     */
    public List<Group> getGroupsByUserId(String userId) {
        return groupMapper.getGroupsByUserId(userId);
    }

    /**
     * ???
     * 
     * @param userId
     * @param type
     * @return
     */
    public List<Group> getGroupsByUserIdAndType(String userId, String type) {
        GroupQuery query = new GroupQuery();
        query.setUserId(userId);
        query.setType(type);
        return groupMapper.getGroupsByUserIdAndType(query);
    }

    public List<String> getUserIdsByGroupId(String groupId) {
        return groupUserMapper.getUserIdsByGroupId(groupId);
    }

    public List<String> getLeaderUserIdsByGroupId(String groupId) {
        return groupLeaderMapper.getUserIdsByGroupId(groupId);
    }

    /**
     * ?????
     * 
     * @param groupName
     * @param groupType
     * @return
     */
    public List<String> getUserIdsByGroupNameAndType(String groupName, String groupType) {
        GroupQuery query = new GroupQuery();
        query.name(groupName);
        query.type(groupType);
        List<Group> list = groupMapper.getGroups(query);
        if (list != null && list.isEmpty()) {
            Group group = list.get(0);
            return this.getUserIdsByGroupId(group.getGroupId());
        }
        return null;
    }

    public List<Group> list(GroupQuery query) {
        List<Group> list = groupMapper.getGroups(query);
        return list;
    }

    @Transactional
    public void save(Group group) {
        if (StringUtils.isEmpty(group.getGroupId())) {
            group.setGroupId(UUID32.getUUID());
            group.setSort(1);
            group.setCreateDate(new Date());
            groupMapper.insertGroup(group);
        } else {
            if (groupMapper.getGroupById(group.getGroupId()) == null) {
                group.setCreateDate(new Date());
                groupMapper.insertGroup(group);
            } else {
                group.setUpdateDate(new Date());
                groupMapper.updateGroup(group);
                String cacheKey = "sys_group_" + group.getGroupId();
                CacheFactory.remove(cacheKey);
            }
        }
    }

    /**
     * ?
     * 
     * @param groupId
     * @param userIds
     */
    @Transactional
    public void saveGroupUsers(String groupId, Set<String> userIds) {
        groupUserMapper.deleteGroupUsersByGroupId(groupId);
        if (userIds != null && !userIds.isEmpty()) {
            for (String userId : userIds) {
                GroupUser gu = new GroupUser();
                gu.setGroupId(groupId);
                gu.setUserId(userId);
                groupUserMapper.insertGroupUser(gu);
            }
        }
    }

    /**
     * ?
     * 
     * @param groupId
     * @param userIds
     */
    @Transactional
    public void saveGroupLeaders(String groupId, Set<String> userIds) {
        groupLeaderMapper.deleteGroupLeadersByGroupId(groupId);
        if (userIds != null && !userIds.isEmpty()) {
            for (String userId : userIds) {
                GroupLeader g = new GroupLeader();
                g.setGroupId(groupId);
                g.setUserId(userId);
                groupLeaderMapper.insertGroupLeader(g);
            }
        }
    }

    @javax.annotation.Resource
    public void setEntityDAO(EntityDAO entityDAO) {
        this.entityDAO = entityDAO;
    }

    @javax.annotation.Resource
    public void setGroupLeaderMapper(GroupLeaderMapper groupLeaderMapper) {
        this.groupLeaderMapper = groupLeaderMapper;
    }

    @javax.annotation.Resource
    public void setGroupMapper(GroupMapper groupMapper) {
        this.groupMapper = groupMapper;
    }

    @javax.annotation.Resource
    public void setGroupUserMapper(GroupUserMapper groupUserMapper) {
        this.groupUserMapper = groupUserMapper;
    }

    @javax.annotation.Resource
    public void setIdGenerator(IdGenerator idGenerator) {
        this.idGenerator = idGenerator;
    }

    @javax.annotation.Resource
    public void setSqlSessionTemplate(SqlSessionTemplate sqlSessionTemplate) {
        this.sqlSessionTemplate = sqlSessionTemplate;
    }

    /**
     * ?
     * 
     * @param bean
     *            Group
     * @param operate
     *            int ?
     */
    @Transactional
    public void sort(Group bean, int operate) {
        if (bean == null)
            return;
        if (operate == SysConstants.SORT_PREVIOUS) {// ?
            sortByPrevious(bean);
        } else if (operate == SysConstants.SORT_FORWARD) {// ?
            sortByForward(bean);
        }
    }

    /**
     * ???
     * 
     * @param bean
     */
    private void sortByForward(Group bean) {
        GroupQuery query = new GroupQuery();
        query.setSortLessThan(bean.getSort());
        query.setOrderBy(" E.SORT desc ");
        List<Group> list = this.list(query);
        if (list != null && list.size() > 0) {// 
            Group temp = (Group) list.get(0);
            int sort = bean.getSort();
            bean.setSort(temp.getSort() - 1);
            this.update(bean);// bean

            temp.setSort(sort + 1);
            this.update(temp);// temp
        }
    }

    /**
     * ???
     * 
     * @param bean
     */
    private void sortByPrevious(Group bean) {
        GroupQuery query = new GroupQuery();
        query.setSortGreaterThan(bean.getSort());
        query.setOrderBy(" E.SORT asc ");
        // ?
        List<Group> list = this.list(query);
        if (list != null && list.size() > 0) {// 
            Group temp = (Group) list.get(0);
            int sort = bean.getSort();
            bean.setSort(temp.getSort() + sort);
            this.update(bean);// bean

            temp.setSort(sort - 1);
            this.update(temp);// temp
        }
    }

    @Transactional
    public void update(Group group) {
        group.setUpdateDate(new Date());
        groupMapper.updateGroup(group);
        String cacheKey = "sys_group_" + group.getGroupId();
        CacheFactory.remove(cacheKey);
    }

}