zhibing.pu
2024-08-09 bed6becab65745585281ba2e499fa39de561c29f
ruoyi-service/ruoyi-chargingPile/src/main/java/com/ruoyi/chargingPile/service/impl/SiteServiceImpl.java
@@ -5,16 +5,23 @@
import com.ruoyi.chargingPile.api.dto.GetSiteListDTO;
import com.ruoyi.chargingPile.api.model.Site;
import com.ruoyi.chargingPile.api.model.TChargingGun;
import com.ruoyi.chargingPile.api.model.TChargingPile;
import com.ruoyi.chargingPile.api.query.GetSiteList;
import com.ruoyi.chargingPile.api.query.SiteQuery;
import com.ruoyi.chargingPile.api.vo.SiteVO;
import com.ruoyi.chargingPile.api.vo.TAccountingStrategyVO;
import com.ruoyi.chargingPile.domain.SiteMenu;
import com.ruoyi.chargingPile.mapper.SiteMapper;
import com.ruoyi.chargingPile.service.IPartnerService;
import com.ruoyi.chargingPile.service.ISiteService;
import com.ruoyi.chargingPile.service.TChargingGunService;
import com.ruoyi.chargingPile.service.TChargingPileService;
import com.ruoyi.common.core.utils.StringUtils;
import com.ruoyi.common.core.web.domain.AjaxResult;
import com.ruoyi.common.core.web.page.PageInfo;
import com.ruoyi.common.security.utils.SecurityUtils;
import com.ruoyi.system.api.domain.SysUser;
import com.ruoyi.system.api.feignClient.SysUserClient;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Propagation;
import org.springframework.transaction.annotation.Transactional;
@@ -32,6 +39,15 @@
   @Resource
   private TChargingGunService chargingGunService;
   
   @Resource
   private TChargingPileService chargingPileService;
   @Resource
   private SysUserClient sysUserClient;
   @Resource
   private IPartnerService partnerService;
   
   
   /**
@@ -41,10 +57,30 @@
    */
   @Override
   public PageInfo<GetSiteListDTO> getSiteList(GetSiteList siteList) {
      List<Integer> ids = null;
      //校验合作商权限
      SysUser sysUser = sysUserClient.getSysUser(SecurityUtils.getUserId()).getData();
      Integer roleType = sysUser.getRoleType();
      Integer objectId = sysUser.getObjectId();
      //合作商
      if(roleType == 2){
         ids = partnerService.authSite(objectId, SiteMenu.SITE_LIST);
      }
      PageInfo<GetSiteListDTO> pageInfo = new PageInfo<>(siteList.getPageCurr(), siteList.getPageSize());
      List<GetSiteListDTO> list = this.baseMapper.getSiteList(pageInfo, siteList);
      List<GetSiteListDTO> list = this.baseMapper.getSiteList(pageInfo, siteList, ids);
      for (GetSiteListDTO getSiteListDTO : list) {
         Integer siteId = getSiteListDTO.getId();
         getSiteListDTO.setAuthAccountingStrategy(roleType == 1 ? true : partnerService.authMenu(objectId, siteId, SiteMenu.SITE_ACCOUNTING_STRATEGY));
         //平台账号才有此权限
         getSiteListDTO.setAuthPartner(roleType == 1 ? true : false);
         getSiteListDTO.setAuthUpdate(roleType == 1 ? true : partnerService.authMenu(objectId, siteId, SiteMenu.SITE_UPDATE));
         getSiteListDTO.setAuthDelete(roleType == 1 ? true : partnerService.authMenu(objectId, siteId, SiteMenu.SITE_DELETE));
      }
      return pageInfo.setRecords(list);
   }
   
   /**
    * 添加站点信息
@@ -148,7 +184,10 @@
   public AjaxResult delSite(Integer id) {
      //查询是否有关联数据
      //充电桩
      // todo 待完善
      long count1 = chargingPileService.count(new LambdaQueryWrapper<TChargingPile>().eq(TChargingPile::getSiteId, id).eq(TChargingPile::getDelFlag, 0));
      if(count1 > 0){
         return AjaxResult.error("该站点有关联充电桩,删除失败!");
      }
      Site site = this.getById(id);
      site.setDelFlag(true);
      this.updateById(site);
@@ -170,7 +209,7 @@
    * @param accountingStrategyId 计费策略id
    */
   @Override
   @Transactional(propagation = Propagation.REQUIRES_NEW)
   @Transactional(rollbackFor = Exception.class)
   public void setAccountingStrategy(Integer id, Integer accountingStrategyId) {
      Site site = this.getById(id);
      site.setAccountingStrategyId(accountingStrategyId);