package com.jsh.erp.service.tenant;
|
|
import com.alibaba.fastjson.JSONObject;
|
import com.jsh.erp.constants.BusinessConstants;
|
import com.jsh.erp.datasource.entities.Tenant;
|
import com.jsh.erp.datasource.entities.TenantEx;
|
import com.jsh.erp.datasource.entities.TenantExample;
|
import com.jsh.erp.datasource.entities.UserEx;
|
import com.jsh.erp.datasource.mappers.TenantMapper;
|
import com.jsh.erp.datasource.mappers.TenantMapperEx;
|
import com.jsh.erp.datasource.mappers.UserBusinessMapperEx;
|
import com.jsh.erp.datasource.mappers.UserMapperEx;
|
import com.jsh.erp.exception.JshException;
|
import com.jsh.erp.service.log.LogService;
|
import com.jsh.erp.service.user.UserService;
|
import com.jsh.erp.utils.StringUtil;
|
import com.jsh.erp.utils.Tools;
|
import org.slf4j.Logger;
|
import org.slf4j.LoggerFactory;
|
import org.springframework.beans.factory.annotation.Value;
|
import org.springframework.stereotype.Service;
|
import org.springframework.transaction.annotation.Transactional;
|
import org.springframework.web.context.request.RequestContextHolder;
|
import org.springframework.web.context.request.ServletRequestAttributes;
|
|
import javax.annotation.Resource;
|
import javax.servlet.http.HttpServletRequest;
|
import java.util.ArrayList;
|
import java.util.List;
|
|
@Service
|
public class TenantService {
|
private Logger logger = LoggerFactory.getLogger(TenantService.class);
|
|
@Resource
|
private TenantMapper tenantMapper;
|
|
@Resource
|
private TenantMapperEx tenantMapperEx;
|
|
@Resource
|
private UserMapperEx userMapperEx;
|
|
@Resource
|
private UserBusinessMapperEx userBusinessMapperEx;
|
|
@Resource
|
private UserService userService;
|
|
@Resource
|
private LogService logService;
|
|
@Value("${manage.roleId}")
|
private Integer manageRoleId;
|
|
public Tenant getTenant(long id)throws Exception {
|
Tenant result=null;
|
try{
|
result=tenantMapper.selectByPrimaryKey(id);
|
}catch(Exception e){
|
JshException.readFail(logger, e);
|
}
|
return result;
|
}
|
|
public List<Tenant> getTenant()throws Exception {
|
TenantExample example = new TenantExample();
|
example.createCriteria().andDeleteFlagNotEqualTo(BusinessConstants.DELETE_FLAG_DELETED);
|
List<Tenant> list=null;
|
try{
|
list=tenantMapper.selectByExample(example);
|
}catch(Exception e){
|
JshException.readFail(logger, e);
|
}
|
return list;
|
}
|
|
public List<TenantEx> select(String loginName, String type, String enabled, String remark, int offset, int rows)throws Exception {
|
List<TenantEx> list= new ArrayList<>();
|
try{
|
if(BusinessConstants.DEFAULT_MANAGER.equals(userService.getCurrentUser().getLoginName())) {
|
list = tenantMapperEx.selectByConditionTenant(loginName, type, enabled, remark, offset, rows);
|
if (null != list) {
|
for (TenantEx tenantEx : list) {
|
tenantEx.setCreateTimeStr(Tools.getCenternTime(tenantEx.getCreateTime()));
|
tenantEx.setExpireTimeStr(Tools.getCenternTime(tenantEx.getExpireTime()));
|
}
|
}
|
}
|
}catch(Exception e){
|
JshException.readFail(logger, e);
|
}
|
return list;
|
}
|
|
public Long countTenant(String loginName, String type, String enabled, String remark)throws Exception {
|
Long result=null;
|
try{
|
if(BusinessConstants.DEFAULT_MANAGER.equals(userService.getCurrentUser().getLoginName())) {
|
result = tenantMapperEx.countsByTenant(loginName, type, enabled, remark);
|
}
|
}catch(Exception e){
|
JshException.readFail(logger, e);
|
}
|
return result;
|
}
|
|
@Transactional(value = "transactionManager", rollbackFor = Exception.class)
|
public int insertTenant(JSONObject obj, HttpServletRequest request)throws Exception {
|
UserEx ue = JSONObject.parseObject(obj.toJSONString(), UserEx.class);
|
int result = 0;
|
try{
|
ue.setUsername(ue.getLoginName());
|
userService.checkLoginName(ue); //检查登录名
|
userService.registerUser(ue,manageRoleId,request);
|
result = 1;
|
} catch(Exception e){
|
JshException.writeFail(logger, e);
|
}
|
return result;
|
}
|
|
@Transactional(value = "transactionManager", rollbackFor = Exception.class)
|
public int updateTenant(JSONObject obj, HttpServletRequest request)throws Exception {
|
Tenant tenant = JSONObject.parseObject(obj.toJSONString(), Tenant.class);
|
int result=0;
|
try{
|
if(BusinessConstants.DEFAULT_MANAGER.equals(userService.getCurrentUser().getLoginName())) {
|
//如果租户下的用户限制数量为1,则将该租户之外的用户全部禁用
|
if (1 == tenant.getUserNumLimit()) {
|
userMapperEx.disableUserByLimit(tenant.getTenantId());
|
}
|
result = tenantMapper.updateByPrimaryKeySelective(tenant);
|
//更新租户对应的角色
|
if(obj.get("roleId")!=null) {
|
String ubValue = "[" + obj.getString("roleId") + "]";
|
userBusinessMapperEx.updateValueByTypeAndKeyId("UserRole", tenant.getTenantId().toString(), ubValue);
|
}
|
}
|
}catch(Exception e){
|
JshException.writeFail(logger, e);
|
}
|
return result;
|
}
|
|
@Transactional(value = "transactionManager", rollbackFor = Exception.class)
|
public int deleteTenant(Long id, HttpServletRequest request)throws Exception {
|
int result=0;
|
try{
|
if(BusinessConstants.DEFAULT_MANAGER.equals(userService.getCurrentUser().getLoginName())) {
|
result = tenantMapper.deleteByPrimaryKey(id);
|
}
|
}catch(Exception e){
|
JshException.writeFail(logger, e);
|
}
|
return result;
|
}
|
|
@Transactional(value = "transactionManager", rollbackFor = Exception.class)
|
public int batchDeleteTenant(String ids, HttpServletRequest request)throws Exception {
|
List<Long> idList = StringUtil.strToLongList(ids);
|
TenantExample example = new TenantExample();
|
example.createCriteria().andIdIn(idList);
|
int result=0;
|
try{
|
if(BusinessConstants.DEFAULT_MANAGER.equals(userService.getCurrentUser().getLoginName())) {
|
result = tenantMapper.deleteByExample(example);
|
}
|
}catch(Exception e){
|
JshException.writeFail(logger, e);
|
}
|
return result;
|
}
|
|
public int checkIsNameExist(Long id, String name)throws Exception {
|
TenantExample example = new TenantExample();
|
example.createCriteria().andIdNotEqualTo(id).andLoginNameEqualTo(name).andDeleteFlagNotEqualTo(BusinessConstants.DELETE_FLAG_DELETED);
|
List<Tenant> list=null;
|
try{
|
list= tenantMapper.selectByExample(example);
|
}catch(Exception e){
|
JshException.readFail(logger, e);
|
}
|
return list==null?0:list.size();
|
}
|
|
public Tenant getTenantByTenantId(long tenantId) {
|
Tenant tenant = new Tenant();
|
TenantExample example = new TenantExample();
|
example.createCriteria().andTenantIdEqualTo(tenantId).andDeleteFlagNotEqualTo(BusinessConstants.DELETE_FLAG_DELETED);
|
List<Tenant> list = tenantMapper.selectByExample(example);
|
if(list.size()>0) {
|
tenant = list.get(0);
|
}
|
return tenant;
|
}
|
|
public int batchSetStatus(Boolean status, String ids)throws Exception {
|
int result=0;
|
try{
|
if(BusinessConstants.DEFAULT_MANAGER.equals(userService.getCurrentUser().getLoginName())) {
|
String statusStr = "";
|
if (status) {
|
statusStr = "批量启用";
|
} else {
|
statusStr = "批量禁用";
|
}
|
logService.insertLog("用户",
|
new StringBuffer(BusinessConstants.LOG_OPERATION_TYPE_EDIT).append(ids).append("-").append(statusStr).toString(),
|
((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest());
|
List<Long> idList = StringUtil.strToLongList(ids);
|
Tenant tenant = new Tenant();
|
tenant.setEnabled(status);
|
TenantExample example = new TenantExample();
|
example.createCriteria().andIdIn(idList);
|
result = tenantMapper.updateByExampleSelective(tenant, example);
|
}
|
}catch(Exception e){
|
JshException.writeFail(logger, e);
|
}
|
return result;
|
}
|
}
|