package com.moral.api.service.impl; import com.alibaba.fastjson.JSON; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.moral.api.entity.Organization; import com.moral.api.entity.ServicesScope; import com.moral.api.entity.ServicesScopeDevice; import com.moral.api.mapper.OrganizationMapper; import com.moral.api.mapper.ServicesScopeDeviceMapper; import com.moral.api.mapper.ServicesScopeMapper; import com.moral.api.pojo.form.ServiceScope.AddBoundaryBindDevice; import com.moral.api.service.ServicesScopeService; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.moral.api.util.LogUtils; import com.moral.constant.Constants; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; import org.springframework.util.ObjectUtils; import org.springframework.web.context.request.RequestContextHolder; import org.springframework.web.context.request.ServletRequestAttributes; import javax.servlet.http.HttpServletRequest; import java.text.SimpleDateFormat; import java.util.*; import java.util.stream.Collectors; /** *

* 服务实现类 *

* * @author moral * @since 2022-01-12 */ @Service public class ServicesScopeServiceImpl extends ServiceImpl implements ServicesScopeService { @Autowired private ServicesScopeMapper servicesScopeMapper; @Autowired private OrganizationMapper organizationMapper; @Autowired private ServicesScopeDeviceMapper servicesScopeDeviceMapper; @Override public Map getDataByCondition(Map map) { Map resultMap = new HashMap<>(); int current = Integer.parseInt(map.get("current").toString()); int size = Integer.parseInt(map.get("size").toString()); Page page = new Page<>(current, size); QueryWrapper servicesScopeWrapper = new QueryWrapper<>(); servicesScopeWrapper.eq("is_delete",Constants.NOT_DELETE); if (!ObjectUtils.isEmpty(map.get("orgId"))){ servicesScopeWrapper.eq("organization_id",Integer.parseInt(map.get("orgId").toString())); } if (!ObjectUtils.isEmpty(map.get("name"))){ if (map.get("name") != ""){ servicesScopeWrapper.like("name",map.get("name").toString()); } } Page resultPage = servicesScopeMapper.selectPage(page, servicesScopeWrapper); List servicesScopes = resultPage.getRecords(); SimpleDateFormat SDF = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); List> servicesScopesList = new ArrayList<>(); for (ServicesScope servicesScope:servicesScopes) { Map servicesScopeMap = JSON.parseObject(JSON.toJSONString(servicesScope),Map.class); if (ObjectUtils.isEmpty(servicesScopeMap.get("centerLongitude"))){ servicesScopeMap.put("centerLongitude",null); } if (ObjectUtils.isEmpty(servicesScopeMap.get("centerLatitude"))){ servicesScopeMap.put("centerLatitude",null); } if (ObjectUtils.isEmpty(servicesScopeMap.get("boundary"))){ servicesScopeMap.put("boundary",null); } String createTime = SDF.format(servicesScope.getCreateTime()); String updateTime = SDF.format(servicesScope.getUpdateTime()); servicesScopeMap.put("createTime",createTime); servicesScopeMap.put("updateTime",updateTime); int organization_id = servicesScope.getOrganizationId(); Organization organization = organizationMapper.selectById(organization_id); servicesScopeMap.put("organization_name",organization.getName()); servicesScopesList.add(servicesScopeMap); } resultMap.put("servicesScopes",servicesScopesList); int totalNumber = servicesScopeMapper.selectCount(servicesScopeWrapper); resultMap.put("totalNumber",totalNumber); resultMap.put("current",current); int totalPageNumber = totalNumber/size; if(totalNumber%size != 0){ totalPageNumber += 1; } resultMap.put("totalPageNumber",totalPageNumber); return resultMap; } @Transactional @Override public void insert(ServicesScope servicesScope) { int count = servicesScopeMapper.insert(servicesScope); if (count > 0) { //操作日志记录 HttpServletRequest request = ((ServletRequestAttributes) Objects.requireNonNull(RequestContextHolder.getRequestAttributes())).getRequest(); StringBuilder content = new StringBuilder(); content.append("添加了服务范围:").append("id:").append(servicesScope.getId() + ";").append("name:").append(servicesScope.getName() + ";").append(":").append("organization_id:").append(servicesScope.getOrganizationId() + ";"); LogUtils.saveOperationForManage(request, content.toString(), Constants.INSERT_OPERATE_TYPE); } } @Override @Transactional public void update(ServicesScope servicesScope) { ServicesScope oldServicesScope = servicesScopeMapper.selectById(servicesScope.getId()); servicesScopeMapper.updateById(servicesScope); ServicesScope newServicesScope = servicesScopeMapper.selectById(servicesScope.getId()); //操作日志记录 HttpServletRequest request = ((ServletRequestAttributes) Objects.requireNonNull(RequestContextHolder.getRequestAttributes())).getRequest(); StringBuilder content = new StringBuilder(); content.append("修改了服务范围:").append("id:").append(servicesScope.getId() + ";"); if (!com.baomidou.mybatisplus.core.toolkit.ObjectUtils.isEmpty(servicesScope.getOrganizationId())) { content.append("organization_id:").append(oldServicesScope.getOrganizationId()).append("->").append(newServicesScope.getOrganizationId()).append(";"); } if (!com.baomidou.mybatisplus.core.toolkit.ObjectUtils.isEmpty(servicesScope.getName())) { content.append("name:").append(oldServicesScope.getName()).append("->").append(newServicesScope.getName()).append(";"); } if (!com.baomidou.mybatisplus.core.toolkit.ObjectUtils.isEmpty(servicesScope.getCenterLongitude())) { content.append("center_longitude:").append(oldServicesScope.getCenterLongitude()).append("->").append(newServicesScope.getCenterLongitude()).append(";"); } if (!com.baomidou.mybatisplus.core.toolkit.ObjectUtils.isEmpty(servicesScope.getCenterLatitude())) { content.append("center_latitude:").append(oldServicesScope.getCenterLatitude()).append("->").append(newServicesScope.getCenterLatitude()).append(";"); } if (!com.baomidou.mybatisplus.core.toolkit.ObjectUtils.isEmpty(servicesScope.getBoundary())) { content.append("boundary:").append("数据过长").append(";"); } LogUtils.saveOperationForManage(request, content.toString(), Constants.UPDATE_OPERATE_TYPE); } @Override @Transactional public void delete(int id) { ServicesScope servicesScope = new ServicesScope(); servicesScope.setId(id); servicesScope.setIsDelete(Constants.DELETE); servicesScopeMapper.updateById(servicesScope); //操作日志记录 HttpServletRequest request = ((ServletRequestAttributes) Objects.requireNonNull(RequestContextHolder.getRequestAttributes())).getRequest(); StringBuilder content = new StringBuilder(); content.append("删除了服务范围:").append("id:").append(id).append(";"); LogUtils.saveOperationForManage(request, content.toString(), Constants.DELETE_OPERATE_TYPE); } @Override @Transactional public void addBoundaryBindDevice(AddBoundaryBindDevice addBoundaryBindDevice) { String devices = addBoundaryBindDevice.getDevices(); if (!ObjectUtils.isEmpty(devices) && !devices.equals("")){ String[] deviceIds = devices.split(","); List deviceIds_String = Arrays.asList(deviceIds); List deviceIdList = new ArrayList<>(); for (String deviceId_String:deviceIds_String) { deviceIdList.add(Integer.parseInt(deviceId_String)); } QueryWrapper servicesScopeDeviceQueryWrapper = new QueryWrapper<>(); servicesScopeDeviceQueryWrapper.eq("is_delete",Constants.NOT_DELETE); servicesScopeDeviceQueryWrapper.eq("services_scope_id",addBoundaryBindDevice.getServicesScope().getId()); List servicesScopeDevices = servicesScopeDeviceMapper.selectList(servicesScopeDeviceQueryWrapper); List oldDeviceIds = servicesScopeDevices.stream().map(p -> p.getDeviceId()).collect(Collectors.toList()); List insertList = new ArrayList<>(); for (Integer deviceId:deviceIdList) { if (!oldDeviceIds.contains(deviceId)){ insertList.add(deviceId); } } if (insertList.size()>0){ servicesScopeDeviceMapper.insertBatch(addBoundaryBindDevice.getServicesScope().getId(),insertList); } servicesScopeDeviceQueryWrapper.notIn("device_id",deviceIdList); ServicesScopeDevice servicesScopeDevice = new ServicesScopeDevice(); servicesScopeDevice.setIsDelete(Constants.DELETE); servicesScopeDeviceMapper.update(servicesScopeDevice,servicesScopeDeviceQueryWrapper); } ServicesScope oldServicesScope = servicesScopeMapper.selectById(addBoundaryBindDevice.getServicesScope().getId()); servicesScopeMapper.updateById(addBoundaryBindDevice.getServicesScope()); ServicesScope newServicesScope = servicesScopeMapper.selectById(addBoundaryBindDevice.getServicesScope().getId()); //操作日志记录 HttpServletRequest request = ((ServletRequestAttributes) Objects.requireNonNull(RequestContextHolder.getRequestAttributes())).getRequest(); StringBuilder content = new StringBuilder(); content.append("修改了服务范围:").append("id:").append(addBoundaryBindDevice.getServicesScope().getId() + ";"); if (!com.baomidou.mybatisplus.core.toolkit.ObjectUtils.isEmpty(addBoundaryBindDevice.getServicesScope().getOrganizationId())) { content.append("organization_id:").append(oldServicesScope.getOrganizationId()).append("->").append(newServicesScope.getOrganizationId()).append(";"); } if (!com.baomidou.mybatisplus.core.toolkit.ObjectUtils.isEmpty(addBoundaryBindDevice.getServicesScope().getName())) { content.append("name:").append(oldServicesScope.getName()).append("->").append(newServicesScope.getName()).append(";"); } if (!com.baomidou.mybatisplus.core.toolkit.ObjectUtils.isEmpty(addBoundaryBindDevice.getServicesScope().getCenterLongitude())) { content.append("center_longitude:").append(oldServicesScope.getCenterLongitude()).append("->").append(newServicesScope.getCenterLongitude()).append(";"); } if (!com.baomidou.mybatisplus.core.toolkit.ObjectUtils.isEmpty(addBoundaryBindDevice.getServicesScope().getCenterLatitude())) { content.append("center_latitude:").append(oldServicesScope.getCenterLatitude()).append("->").append(newServicesScope.getCenterLatitude()).append(";"); } if (!com.baomidou.mybatisplus.core.toolkit.ObjectUtils.isEmpty(addBoundaryBindDevice.getServicesScope().getBoundary())) { content.append("boundary:").append("数据过长").append(";"); } LogUtils.saveOperationForManage(request, content.toString(), Constants.UPDATE_OPERATE_TYPE); } }