package doumeemes.service.system.impl; 
 | 
  
 | 
import com.github.yulichang.wrapper.MPJLambdaWrapper; 
 | 
import doumeemes.core.model.PageData; 
 | 
import doumeemes.core.model.PageWrap; 
 | 
import doumeemes.core.utils.Utils; 
 | 
import doumeemes.dao.business.model.Company; 
 | 
import doumeemes.dao.business.model.CompanyUser; 
 | 
import doumeemes.dao.ext.dto.ActivityLoginDTO; 
 | 
import doumeemes.dao.ext.vo.ActivityLoginVO; 
 | 
import doumeemes.dao.ext.vo.StagingLoginVO; 
 | 
import doumeemes.dao.system.SystemLoginLogMapper; 
 | 
import doumeemes.dao.system.dto.QuerySystemLoginLogDTO; 
 | 
import doumeemes.dao.system.join.SystemLoginLogJoinMapper; 
 | 
import doumeemes.dao.system.model.SystemLoginLog; 
 | 
import doumeemes.dao.system.model.SystemTraceLog; 
 | 
import doumeemes.service.system.SystemLoginLogService; 
 | 
import com.baomidou.mybatisplus.core.conditions.Wrapper; 
 | 
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; 
 | 
import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper; 
 | 
import com.baomidou.mybatisplus.core.metadata.IPage; 
 | 
import com.baomidou.mybatisplus.extension.plugins.pagination.Page; 
 | 
import org.apache.commons.lang3.StringUtils; 
 | 
import org.springframework.beans.factory.annotation.Autowired; 
 | 
import org.springframework.stereotype.Service; 
 | 
import org.springframework.util.CollectionUtils; 
 | 
  
 | 
import java.util.List; 
 | 
  
 | 
/** 
 | 
 * 登录日志Service实现 
 | 
 * @author Eva.Caesar Liu 
 | 
 * @date 2022/04/18 18:12 
 | 
 */ 
 | 
@Service 
 | 
public class SystemLoginLogServiceImpl implements SystemLoginLogService { 
 | 
  
 | 
    @Autowired 
 | 
    private SystemLoginLogMapper systemLoginLogMapper; 
 | 
    @Autowired 
 | 
    private SystemLoginLogJoinMapper systemLoginLogJoinMapper; 
 | 
  
 | 
    @Override 
 | 
    public Integer create(SystemLoginLog systemLoginLog) { 
 | 
        systemLoginLogMapper.insert(systemLoginLog); 
 | 
        return systemLoginLog.getId(); 
 | 
    } 
 | 
  
 | 
    @Override 
 | 
    public void deleteById(Integer id) { 
 | 
        systemLoginLogMapper.deleteById(id); 
 | 
    } 
 | 
  
 | 
    @Override 
 | 
    public void delete(SystemLoginLog systemLoginLog) { 
 | 
        UpdateWrapper<SystemLoginLog> deleteWrapper = new UpdateWrapper<>(systemLoginLog); 
 | 
        systemLoginLogMapper.delete(deleteWrapper); 
 | 
    } 
 | 
  
 | 
    @Override 
 | 
    public void deleteByIdInBatch(List<Integer> ids) { 
 | 
        if (CollectionUtils.isEmpty(ids)) return; 
 | 
        systemLoginLogMapper.deleteBatchIds(ids); 
 | 
    } 
 | 
  
 | 
    @Override 
 | 
    public void updateById(SystemLoginLog systemLoginLog) { 
 | 
        systemLoginLogMapper.updateById(systemLoginLog); 
 | 
    } 
 | 
  
 | 
    @Override 
 | 
    public void updateByIdInBatch(List<SystemLoginLog> systemLoginLogs) { 
 | 
        if (CollectionUtils.isEmpty(systemLoginLogs)) return; 
 | 
        for (SystemLoginLog systemLoginLog: systemLoginLogs) { 
 | 
            this.updateById(systemLoginLog); 
 | 
        } 
 | 
    } 
 | 
  
 | 
    @Override 
 | 
    public SystemLoginLog findById(Integer id) { 
 | 
        return systemLoginLogMapper.selectById(id); 
 | 
    } 
 | 
  
 | 
    @Override 
 | 
    public SystemLoginLog findOne(SystemLoginLog systemLoginLog) { 
 | 
        Wrapper<SystemLoginLog> wrapper = new QueryWrapper<>(systemLoginLog); 
 | 
        return systemLoginLogMapper.selectOne(wrapper); 
 | 
    } 
 | 
  
 | 
    @Override 
 | 
    public List<SystemLoginLog> findList(SystemLoginLog systemLoginLog) { 
 | 
        Wrapper<SystemLoginLog> wrapper = new QueryWrapper<>(systemLoginLog); 
 | 
        return systemLoginLogMapper.selectList(wrapper); 
 | 
    } 
 | 
  
 | 
    @Override 
 | 
    public PageData<SystemLoginLog> findPage(PageWrap<QuerySystemLoginLogDTO> pageWrap) { 
 | 
        IPage<SystemLoginLog> page = new Page<>(pageWrap.getPage(), pageWrap.getCapacity()); 
 | 
  
 | 
        MPJLambdaWrapper<SystemLoginLog> mpjLambdaWrapper = new MPJLambdaWrapper<>(); 
 | 
        mpjLambdaWrapper.selectAll(SystemLoginLog.class); 
 | 
        mpjLambdaWrapper.leftJoin(Company.class,Company::getId,SystemLoginLog::getCompanyId); 
 | 
        mpjLambdaWrapper.leftJoin(CompanyUser.class,CompanyUser::getId,SystemLoginLog::getCompanyUserId); 
 | 
        mpjLambdaWrapper.selectAs(Company::getName, SystemLoginLog::getCompanyName); 
 | 
        mpjLambdaWrapper.selectAs(CompanyUser::getName, SystemLoginLog::getCompanyUserName); 
 | 
        // 登录用户名 
 | 
        if (StringUtils.isNotBlank(pageWrap.getModel().getLoginUsername())) { 
 | 
            mpjLambdaWrapper.like(SystemLoginLog::getLoginUsername, pageWrap.getModel().getLoginUsername()); 
 | 
        } 
 | 
        // 登录IP 
 | 
        if (StringUtils.isNotBlank(pageWrap.getModel().getIp())) { 
 | 
            mpjLambdaWrapper.eq(SystemLoginLog::getIp, pageWrap.getModel().getIp()); 
 | 
        } 
 | 
        if ( pageWrap.getModel().getOrgin() !=null) { 
 | 
            mpjLambdaWrapper.eq(SystemLoginLog::getOrgin, pageWrap.getModel().getOrgin()); 
 | 
        } 
 | 
        // 服务器IP 
 | 
        if (StringUtils.isNotBlank(pageWrap.getModel().getServerIp())) { 
 | 
            mpjLambdaWrapper.eq(SystemLoginLog::getServerIp, pageWrap.getModel().getServerIp()); 
 | 
        } 
 | 
        // 登录状态 
 | 
        if (pageWrap.getModel().getSuccess() != null) { 
 | 
            mpjLambdaWrapper.eq(SystemLoginLog::getSuccess, pageWrap.getModel().getSuccess()); 
 | 
        } 
 | 
        // 登录开始时间 
 | 
        if (pageWrap.getModel().getStartTime() != null) { 
 | 
            mpjLambdaWrapper.ge(SystemLoginLog::getLoginTime, pageWrap.getModel().getStartTime()); 
 | 
        } 
 | 
        // 登录结束时间 
 | 
        if (pageWrap.getModel().getStartTime() != null) { 
 | 
            mpjLambdaWrapper.lt(SystemLoginLog::getLoginTime, pageWrap.getModel().getEndTime()); 
 | 
        } 
 | 
  
 | 
        mpjLambdaWrapper.orderByDesc(SystemLoginLog::getLoginTime); 
 | 
        return PageData.from(systemLoginLogJoinMapper.selectJoinPage(page, SystemLoginLog.class,mpjLambdaWrapper)); 
 | 
    } 
 | 
  
 | 
    @Override 
 | 
    public long count(SystemLoginLog systemLoginLog) { 
 | 
        Wrapper<SystemLoginLog> wrapper = new QueryWrapper<>(systemLoginLog); 
 | 
        return systemLoginLogMapper.selectCount(wrapper); 
 | 
    } 
 | 
  
 | 
  
 | 
    @Override 
 | 
    public StagingLoginVO getStagingLoginVO(){ 
 | 
        StagingLoginVO stagingLoginVO = new StagingLoginVO(); 
 | 
        //今日活跃用户:统计当天登录用户数,一个系统用户在不同的企业登录,算两个用户;一个用户在一个企业内多次登录,算一个用户 
 | 
        stagingLoginVO.setDayActiveUserNum( 
 | 
            systemLoginLogMapper.selectList(new QueryWrapper<SystemLoginLog>() 
 | 
                    .select(" COMPANY_USER_ID ") 
 | 
                    .isNotNull(" COMPANY_ID ") 
 | 
                    .isNotNull(" COMPANY_USER_ID ") 
 | 
                    .apply(" LOGIN_TIME like concat(CURDATE(),'%') ") 
 | 
                    .groupBy(" COMPANY_ID , COMPANY_USER_ID ") 
 | 
            ).size() 
 | 
        ); 
 | 
        //今日活跃企业:统计当天登录的企业数,一个企业的不同用户登录,算一个企业数; 
 | 
        stagingLoginVO.setDayActiveCompanyNum( 
 | 
                systemLoginLogMapper.selectList(new QueryWrapper<SystemLoginLog>() 
 | 
                        .select(" COMPANY_ID ") 
 | 
                        .isNotNull(" COMPANY_ID ") 
 | 
                        .isNotNull(" COMPANY_USER_ID ") 
 | 
                        .apply(" LOGIN_TIME like concat(CURDATE(),'%') ") 
 | 
                        .groupBy(" COMPANY_ID ") 
 | 
                ).size() 
 | 
        ); 
 | 
        //统计本月(自然月)登录的企业数,逻辑同上; 
 | 
        stagingLoginVO.setMonthActiveCompanyNum( 
 | 
                systemLoginLogMapper.selectList(new QueryWrapper<SystemLoginLog>() 
 | 
                        .select(" COMPANY_ID ") 
 | 
                        .isNotNull(" COMPANY_ID ") 
 | 
                        .isNotNull(" COMPANY_USER_ID ") 
 | 
                        .apply(" LOGIN_TIME like concat(date_format(NOW(), '%Y-%m'),'%') ") 
 | 
                        .groupBy(" COMPANY_ID ") 
 | 
                ).size() 
 | 
        ); 
 | 
        //本月登录2次及以上企业数:统计本月(自然月)登录2次及以上的企业数,逻辑同上; 
 | 
        stagingLoginVO.setMonthTwoCompanyNum( 
 | 
                systemLoginLogMapper.selectList(new QueryWrapper<SystemLoginLog>() 
 | 
                        .select(" COMPANY_ID ") 
 | 
                        .isNotNull(" COMPANY_ID ") 
 | 
                        .isNotNull(" COMPANY_USER_ID ") 
 | 
                        .apply(" LOGIN_TIME like concat(date_format(NOW(), '%Y-%m'),'%') ") 
 | 
                        .groupBy(" COMPANY_ID ") 
 | 
                        .having(" count(1) > 1 ") 
 | 
                ).size() 
 | 
        ); 
 | 
        //本月登录2次及以上企业数(羚羊):统计本月(自然月)登录2次及以上(登录来源于羚羊平台)的企业数,逻辑同上; 
 | 
        stagingLoginVO.setMonthTwoCompanyLYNum( 
 | 
                systemLoginLogMapper.selectList(new QueryWrapper<SystemLoginLog>() 
 | 
                        .select(" COMPANY_ID ") 
 | 
                        .isNotNull(" COMPANY_ID ") 
 | 
                        .isNotNull(" COMPANY_USER_ID ") 
 | 
                        .apply(" LOGIN_TIME like concat(date_format(NOW(), '%Y-%m'),'%') ") 
 | 
                        .eq("ORGIN",2) 
 | 
                        .groupBy(" COMPANY_ID ") 
 | 
                        .having(" count(1) > 1 ") 
 | 
                ).size() 
 | 
        ); 
 | 
        return stagingLoginVO; 
 | 
    } 
 | 
  
 | 
  
 | 
  
 | 
} 
 |