|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import cn.hutool.core.img.ImgUtil; | 
|---|
|  |  |  | import cn.hutool.core.io.FileUtil; | 
|---|
|  |  |  | import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | 
|---|
|  |  |  | import com.baomidou.mybatisplus.core.toolkit.Wrappers; | 
|---|
|  |  |  | import com.ruoyi.chargingPile.api.dto.GetSiteListDTO; | 
|---|
|  |  |  | import com.ruoyi.chargingPile.api.dto.TChargingGunDTO; | 
|---|
|  |  |  | 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.model.TFaultMessage; | 
|---|
|  |  |  | import com.ruoyi.chargingPile.api.query.TChargingGunQuery; | 
|---|
|  |  |  | import com.ruoyi.chargingPile.api.vo.GetChargingGunByCode; | 
|---|
|  |  |  | import com.ruoyi.chargingPile.api.vo.GunStatusStatisticsVO; | 
|---|
|  |  |  | import com.ruoyi.chargingPile.api.vo.SiteNameVO; | 
|---|
|  |  |  | import com.ruoyi.chargingPile.api.vo.TChargingGunVO; | 
|---|
|  |  |  | import com.ruoyi.chargingPile.config.FileUploadConfig; | 
|---|
|  |  |  | import com.ruoyi.chargingPile.service.ISiteService; | 
|---|
|  |  |  | import com.ruoyi.chargingPile.service.TChargingGunService; | 
|---|
|  |  |  | import com.ruoyi.chargingPile.service.TChargingPileService; | 
|---|
|  |  |  | 
|---|
|  |  |  | import com.ruoyi.common.log.annotation.Log; | 
|---|
|  |  |  | import com.ruoyi.common.log.enums.BusinessType; | 
|---|
|  |  |  | import com.ruoyi.common.log.enums.OperatorType; | 
|---|
|  |  |  | import com.ruoyi.common.security.utils.SecurityUtils; | 
|---|
|  |  |  | import com.ruoyi.integration.api.feignClient.IntegrationClient; | 
|---|
|  |  |  | import com.ruoyi.integration.api.model.EndCharge; | 
|---|
|  |  |  | import com.ruoyi.order.api.feignClient.ChargingOrderClient; | 
|---|
|  |  |  | import io.swagger.annotations.Api; | 
|---|
|  |  |  | import io.swagger.annotations.ApiOperation; | 
|---|
|  |  |  | import org.springframework.beans.factory.annotation.Autowired; | 
|---|
|  |  |  | 
|---|
|  |  |  | import javax.servlet.ServletOutputStream; | 
|---|
|  |  |  | import javax.servlet.http.HttpServletResponse; | 
|---|
|  |  |  | import java.awt.image.BufferedImage; | 
|---|
|  |  |  | import java.io.BufferedReader; | 
|---|
|  |  |  | import java.io.FileInputStream; | 
|---|
|  |  |  | import java.io.FileReader; | 
|---|
|  |  |  | import java.io.PrintWriter; | 
|---|
|  |  |  | import java.io.*; | 
|---|
|  |  |  | import java.net.URLEncoder; | 
|---|
|  |  |  | import java.util.ArrayList; | 
|---|
|  |  |  | import java.util.Arrays; | 
|---|
|  |  |  | import java.util.List; | 
|---|
|  |  |  | import java.util.Map; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * <p> | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private TChargingGunService chargingGunService; | 
|---|
|  |  |  | @Resource | 
|---|
|  |  |  | private ChargingOrderClient chargingOrderClient; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Resource | 
|---|
|  |  |  | private TChargingPileService chargingPileService; | 
|---|
|  |  |  | @Resource | 
|---|
|  |  |  | private ISiteService siteService; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private FileUploadConfig fileUploadConfig; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 查询充电枪列表 | 
|---|
|  |  |  | 
|---|
|  |  |  | @Log(title = "【充电桩信息】结束充电", businessType = BusinessType.OTHER,operatorType = OperatorType.MANAGE) | 
|---|
|  |  |  | @ApiOperation(tags = {"后台-充电枪"},value = "结束充电") | 
|---|
|  |  |  | @PutMapping(value = "/stopCharging") | 
|---|
|  |  |  | public AjaxResult<String> stopCharging(@RequestParam("id") Integer id) { | 
|---|
|  |  |  | // TODO 硬件 结束充电 | 
|---|
|  |  |  | //        EndCharge endCharge = new EndCharge(); | 
|---|
|  |  |  | //        integrationClient.endCharge(endCharge); | 
|---|
|  |  |  | public AjaxResult<String> stopCharging(@RequestParam("id") String id) { | 
|---|
|  |  |  | // 根据充电枪id 查询最新的一笔订单 | 
|---|
|  |  |  | String data = chargingOrderClient.queryOrderByGunId(id).getData(); | 
|---|
|  |  |  | // 硬件 结束充电 | 
|---|
|  |  |  | chargingOrderClient.stopCharging(data); | 
|---|
|  |  |  | return AjaxResult.success(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | public void downloadQRCode(@PathVariable Integer id, HttpServletResponse response){ | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | TChargingGun chargingGun = chargingGunService.getById(id); | 
|---|
|  |  |  | String fileName = URLEncoder.encode(chargingGun.getCode(), "UTF-8") + ".jpg"; | 
|---|
|  |  |  | TChargingPile chargingPile = chargingPileService.getById(chargingGun.getChargingPileId()); | 
|---|
|  |  |  | String code = chargingPile.getCode() + chargingGun.getCode(); | 
|---|
|  |  |  | String fileName = URLEncoder.encode(code, "UTF-8") + ".jpg"; | 
|---|
|  |  |  | response.setContentType("application/force-download"); | 
|---|
|  |  |  | response.addHeader("Content-Disposition", "attachment;fileName=" + fileName); | 
|---|
|  |  |  | String url = "https://www.baidu.com?id=" + id; | 
|---|
|  |  |  | String filePath = "D:/Program Files/nginx-1.20.2/html"; | 
|---|
|  |  |  | String url = "https://mxcd.zhinenganguan.com?No=" + code; | 
|---|
|  |  |  | String filePath = fileUploadConfig.getLocation() + fileName; | 
|---|
|  |  |  | QRCodeUtils.encode(url, filePath); | 
|---|
|  |  |  | FileInputStream inputStream = new FileInputStream(filePath); | 
|---|
|  |  |  | ServletOutputStream out = response.getOutputStream(); | 
|---|
|  |  |  | 
|---|
|  |  |  | out.flush(); | 
|---|
|  |  |  | out.close(); | 
|---|
|  |  |  | inputStream.close(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //清除服务器上的文件 | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | // 使用Runtime执行命令 | 
|---|
|  |  |  | Process process = Runtime.getRuntime().exec("sudo rm -rf " + filePath); | 
|---|
|  |  |  | // 读取命令的输出 | 
|---|
|  |  |  | BufferedReader reader = new BufferedReader(new InputStreamReader(process.getInputStream())); | 
|---|
|  |  |  | String line; | 
|---|
|  |  |  | while ((line = reader.readLine()) != null) { | 
|---|
|  |  |  | System.out.println(line); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 等待命令执行完成 | 
|---|
|  |  |  | process.waitFor(); | 
|---|
|  |  |  | // 关闭流 | 
|---|
|  |  |  | reader.close(); | 
|---|
|  |  |  | } catch (IOException | InterruptedException e) { | 
|---|
|  |  |  | e.printStackTrace(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | }catch (Exception e){ | 
|---|
|  |  |  | e.printStackTrace(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 设备状态统计 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @ApiOperation(tags = {"后台-工作台"},value = "设备状态统计") | 
|---|
|  |  |  | @PutMapping(value = "/gunStatusStatistics") | 
|---|
|  |  |  | public R<GunStatusStatisticsVO> gunStatusStatistics() { | 
|---|
|  |  |  | List<Integer> siteIds = new ArrayList<>(); | 
|---|
|  |  |  | Long userId = SecurityUtils.getUserId(); | 
|---|
|  |  |  | //获取当前登录的siteIds | 
|---|
|  |  |  | PageInfo<GetSiteListDTO> siteList1 = siteService.getSiteList1(userId); | 
|---|
|  |  |  | for (GetSiteListDTO datum : siteList1.getRecords()) { | 
|---|
|  |  |  | siteIds.add(datum.getId()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return R.ok(chargingGunService.gunStatusStatistics(siteIds)); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 根据id获取充电枪完整名称 | 
|---|
|  |  |  | 
|---|
|  |  |  | * @param code | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @PostMapping("/getChargingGunByCode/{code}") | 
|---|
|  |  |  | public R<TChargingGun> getChargingGunByCode(@PathVariable("code") String code){ | 
|---|
|  |  |  | @PostMapping("/getChargingGunByCode") | 
|---|
|  |  |  | public R<TChargingGun> getChargingGunByCode(@RequestBody GetChargingGunByCode code){ | 
|---|
|  |  |  | TChargingPile chargingPile = chargingPileService.getOne(new LambdaQueryWrapper<TChargingPile>() | 
|---|
|  |  |  | .eq(TChargingPile::getCode, code.getCharging_pile_code()).eq(TChargingPile::getDelFlag, 0)); | 
|---|
|  |  |  | return R.ok(chargingGunService.getOne(Wrappers.lambdaQuery(TChargingGun.class) | 
|---|
|  |  |  | .eq(TChargingGun::getCode, code) | 
|---|
|  |  |  | .last("LIMIT 1"))); | 
|---|
|  |  |  | .eq(TChargingGun::getChargingPileId, chargingPile.getId()) | 
|---|
|  |  |  | .eq(TChargingGun::getCode, code.getCharging_gun_code()) | 
|---|
|  |  |  | .eq(TChargingGun::getDelFlag, 0) | 
|---|
|  |  |  | .last("LIMIT 1"))); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 根据枪编号获取充电枪 | 
|---|