123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255 |
- package com.fdkankan.manage.service.impl;
- import java.util.*;
- import cn.dev33.satoken.stp.StpUtil;
- import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
- import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
- import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
- import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
- import com.fdkankan.common.util.Base64Converter;
- import com.fdkankan.common.util.SecurityUtil;
- import com.fdkankan.manage.common.CacheUtil;
- import com.fdkankan.manage.common.OssPath;
- import com.fdkankan.manage.common.ResultCode;
- import com.fdkankan.manage.entity.SysUser;
- import com.fdkankan.manage.entity.UserIncrement;
- import com.fdkankan.manage.exception.BusinessException;
- import com.fdkankan.manage.common.PageInfo;
- import com.fdkankan.manage.entity.User;
- import com.fdkankan.manage.httpClient.service.LaserService;
- import com.fdkankan.manage.mapper.IUserMapper;
- import com.fdkankan.manage.service.*;
- import com.fdkankan.manage.util.Dateutils;
- import com.fdkankan.manage.vo.request.SceneParam;
- import com.fdkankan.manage.vo.request.UserIncrementParam;
- import com.fdkankan.manage.vo.request.UserParam;
- import com.fdkankan.manage.vo.response.UserVo;
- import org.apache.commons.lang3.StringUtils;
- import org.springframework.beans.BeanUtils;
- import org.springframework.beans.factory.annotation.Autowired;
- import org.springframework.stereotype.Service;
- import java.util.stream.Collectors;
- /**
- * <p>
- * 用户信息表 服务实现类
- * </p>
- *
- * @author
- * @since 2022-06-16
- */
- @Service
- public class UserServiceImpl extends ServiceImpl<IUserMapper, User> implements IUserService {
- @Autowired
- private IUserIncrementService userIncrementService;
- @Autowired
- private ICameraDetailService cameraDetailService;
- @Autowired
- private ISceneService sceneService;
- @Autowired
- private ISceneProService sceneProService;
- @Autowired
- private IScenePlusService scenePlusService;
- @Autowired
- private LaserService laserService;
- @Autowired
- private ISysUserService sysUserService;
- @Override
- public PageInfo pageList(UserParam param) {
- LambdaQueryWrapper<User> wrapper = new LambdaQueryWrapper<>();
- if(StringUtils.isNotBlank(param.getUserName())){
- wrapper.like(User::getUserName,param.getUserName());
- }
- if(StringUtils.isNotBlank(param.getEmail())){
- wrapper.like(User::getEmail,param.getEmail());
- }
- wrapper.orderByDesc(User::getCreateTime);
- Page<User> page = this.page(new Page<>(param.getPageNum(), param.getPageSize()), wrapper);
- List<User> records = page.getRecords();
- List<UserVo> userVo = getUserVo(records);
- Page<UserVo> pageVo = new Page<>(page.getCurrent(),page.getSize());
- pageVo.setTotal(page.getTotal());
- pageVo.setRecords(userVo);
- return PageInfo.PageInfo(pageVo);
- }
- @Override
- public void addDownNum(UserIncrementParam param) {
- User user = this.getById(param.getUserId());
- if(user == null){
- throw new BusinessException(ResultCode.USER_NOT_EXIST);
- }
- Integer totalNum = user.getDownloadNumTotal() == null ? 0 : user.getDownloadNumTotal() + param.getCount();
- user.setDownloadNumTotal(totalNum);
- this.updateById(user);
- }
- @Override
- public List<UserVo> userDetail(Integer userId) {
- User user = this.getById(userId);
- if(user!=null){
- return getUserVo(Arrays.asList(user));
- }
- return new ArrayList<>();
- }
- private List<UserVo> getUserVo(List<User> userList){
- List<UserVo> voList = new ArrayList<>();
- if(userList.size() >0){
- List<Long> userIdList = userList.parallelStream().map(User::getId).collect(Collectors.toList());
- Set<Long> sysUserIds = userList.stream().map(User::getSysUserId).collect(Collectors.toSet());
- HashMap<Long, SysUser> sysMap = sysUserService.getByIds(sysUserIds);
- HashMap<Long,Long> incrementCountMap = userIncrementService.getValidCountGroupByUserId(userIdList);
- HashMap<Long,Long> cameraCountMap = cameraDetailService.getCountGroupByUserId(userIdList);
- HashMap<Long,Long> sceneCountMap = sceneService.getCountGroupByUserId(userIdList);
- HashMap<Long,Long> sceneProCountMap = sceneProService.getCountGroupByUserId(userIdList,0);
- HashMap<Long,Long> scenePlusCountMap = scenePlusService.getCountGroupByUserId(userIdList,0);
- // HashMap<Long,Long> sceneProCountObjMap = sceneProService.getCountGroupByUserId(userIdList,1);
- // HashMap<Long,Long> scenePlusCountObjMap = scenePlusService.getCountGroupByUserId(userIdList,1);
- for (User user :userList) {
- long incrementCount = incrementCountMap.get(user.getId()) == null ? 0 : incrementCountMap.get(user.getId());
- long cameraCount = cameraCountMap.get(user.getId()) == null ? 0 : cameraCountMap.get(user.getId());
- long sceneCount = sceneCountMap.get(user.getId()) == null ? 0 : sceneCountMap.get(user.getId());
- long sceneProCount = sceneProCountMap.get(user.getId()) == null ? 0 : sceneProCountMap.get(user.getId());
- long scenePlusCount = scenePlusCountMap.get(user.getId()) == null ? 0 : scenePlusCountMap.get(user.getId());
- // long sceneProObjCount = sceneProCountObjMap.get(user.getId()) == null ? 0 : sceneProCountObjMap.get(user.getId());
- // long scenePlusObjCount = scenePlusCountObjMap.get(user.getId()) == null ? 0 : scenePlusCountObjMap.get(user.getId());
- Long ssNum = 0L;
- if(!CacheUtil.uploadType.equals("local")){
- SceneParam param = new SceneParam();
- param.setUserName(user.getUserName());
- PageInfo pageInfo = laserService.pageList(param);
- ssNum = pageInfo.getTotal();
- }
- UserVo vo = new UserVo();
- BeanUtils.copyProperties(user,vo);
- vo.setVip(incrementCount > 0 ? 1: 0);
- vo.setIncrementCount(incrementCount);
- vo.setSurDownNum(user.getDownloadNumTotal() - user.getDownloadNum());
- vo.setCameraCount(cameraCount);
- vo.setSceneNum(sceneCount + sceneProCount + scenePlusCount + ssNum);
- if(user.getSysUserId() != null){
- SysUser sysUser = sysMap.get(user.getSysUserId());
- if(sysUser != null){
- vo.setSysUserName(sysUser.getNickName());
- }
- }
- voList.add(vo);
- }
- }
- return voList;
- }
- @Override
- public HashMap<Long, User> getByIds(List<Long> userIds) {
- LambdaQueryWrapper<User> wrapper = new LambdaQueryWrapper<>();
- wrapper.in(User::getId,userIds);
- List<User> list = this.list(wrapper);
- HashMap<Long,User> map = new HashMap<>();
- list.forEach(entity -> map.put(entity.getId(),entity));
- return map;
- }
- @Override
- public List<User> getByUserName(String userName) {
- LambdaQueryWrapper<User> wrapper = new LambdaQueryWrapper<>();
- wrapper.eq(User::getUserName,userName);
- return this.list(wrapper);
- }
- @Override
- public Boolean checkUserName(String userName) {
- List<User> userList = this.getByUserName(userName);
- if(userList == null || userList.size() <=0){
- return false;
- }
- return true;
- }
- @Override
- public void addUcenterUser(UserParam param) {
- if(StringUtils.isBlank(param.getUserName()) || StringUtils.isBlank(param.getNickName()) || StringUtils.isBlank(param.getPassword())){
- throw new BusinessException(ResultCode.MISSING_REQUIRED_PARAMETERS);
- }
- Boolean ubo = this.checkUserName(param.getUserName());
- if(ubo){
- throw new BusinessException(ResultCode.USER_EXIST);
- }
- try {
- String passwordMd5 = SecurityUtil.MD5(Base64Converter.decode(Base64Converter.subText(param.getPassword())));
- User user = new User();
- user.setHead(OssPath.default_head);
- user.setPassword(passwordMd5);
- user.setStatus(1);
- user.setIsNotice(1);
- user.setRegisterTime(new Date());
- user.setUserName(param.getUserName());
- user.setNickName(param.getNickName());
- user.setCountry("86");
- user.setDownloadNumTotal(1000);
- user.setDownloadNum(0);
- user.setCreateTime(Dateutils.getDate(new Date()));
- user.setRecStatus("A");
- user.setUpdateTime(Dateutils.getDate(new Date()));
- user.setSysUserId(Long.valueOf((String) StpUtil.getLoginId()));
- this.save(user);
- UserIncrement userIncrement = new UserIncrement();
- userIncrement.setKeyWord(UUID.randomUUID().toString().replace("-", ""));
- userIncrement.setIsExpired(0);
- userIncrement.setIncrementStartTime(Dateutils.getDate(new Date()));
- userIncrement.setUserId(user.getId());
- userIncrement.setIncrementTypeId(1);
- userIncrement.setIncrementEndTime("2199-01-01 00:00:00");
- userIncrementService.save(userIncrement);
- }catch (Exception e){
- log.error("ReUcenterUserPassword:error",e);
- throw new BusinessException(ResultCode.PASSWORD_ERROR_G);
- }
- }
- @Override
- public void delUcenterUser(UserParam userParam) {
- if(userParam.getId() == null){
- throw new BusinessException(ResultCode.MISSING_REQUIRED_PARAMETERS);
- }
- this.removeById(userParam.getId());
- }
- @Override
- public void ReUcenterUserPassword(UserParam userParam) {
- if(userParam.getId() == null || StringUtils.isBlank(userParam.getNewPassword())){
- throw new BusinessException(ResultCode.MISSING_REQUIRED_PARAMETERS);
- }
- try {
- String passwordMd5 = SecurityUtil.MD5(Base64Converter.decode(Base64Converter.subText(userParam.getNewPassword())));
- LambdaUpdateWrapper<User> wrapper = new LambdaUpdateWrapper<>();
- wrapper.eq(User::getId,userParam.getId());
- wrapper.set(User::getPassword,passwordMd5);
- this.update(wrapper);
- }catch (Exception e){
- log.error("ReUcenterUserPassword:error",e);
- throw new BusinessException(ResultCode.PASSWORD_ERROR_G);
- }
- }
- @Override
- public void updateUcenterUser(UserParam userParam) {
- if(userParam.getId() == null || StringUtils.isBlank(userParam.getNickName())){
- throw new BusinessException(ResultCode.MISSING_REQUIRED_PARAMETERS);
- }
- LambdaUpdateWrapper<User> wrapper = new LambdaUpdateWrapper<>();
- wrapper.eq(User::getId,userParam.getId());
- wrapper.set(User::getNickName,userParam.getNickName());
- this.update(wrapper);
- }
- }
|