From a88ba6b7606a73086cadb02c6115c3c01ce03f3e Mon Sep 17 00:00:00 2001 From: Pu Zhibing <393733352@qq.com> Date: 星期一, 24 三月 2025 20:00:51 +0800 Subject: [PATCH] 开发管理后台车辆管理模块部分接口和订单模块部分接口 --- ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/controller/CarController.java | 151 ++++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 151 insertions(+), 0 deletions(-) diff --git a/ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/controller/CarController.java b/ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/controller/CarController.java index cc99532..cad06fe 100644 --- a/ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/controller/CarController.java +++ b/ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/controller/CarController.java @@ -1,7 +1,33 @@ package com.ruoyi.system.controller; +import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; +import com.ruoyi.common.core.domain.R; +import com.ruoyi.common.core.web.page.PageInfo; +import com.ruoyi.dataInterchange.api.feignClient.PlaybackMsgClient; +import com.ruoyi.dataInterchange.api.feignClient.RealVideoMsgClient; +import com.ruoyi.dataInterchange.api.feignClient.UPExgMsgRealLocationClient; +import com.ruoyi.dataInterchange.api.vo.OrderTravelVo; +import com.ruoyi.dataInterchange.api.vo.UPPlaybackMsgStartupAckVo; +import com.ruoyi.dataInterchange.api.vo.UPRealvideoMsgStartupAckVo; +import com.ruoyi.system.api.model.Car; +import com.ruoyi.system.api.model.Driver; +import com.ruoyi.system.api.model.Enterprise; +import com.ruoyi.system.query.*; +import com.ruoyi.system.service.ICarService; +import com.ruoyi.system.service.IDriverService; +import com.ruoyi.system.service.IEnterpriseService; +import io.swagger.annotations.ApiImplicitParam; +import io.swagger.annotations.ApiImplicitParams; +import io.swagger.annotations.ApiOperation; +import org.springframework.web.bind.annotation.GetMapping; +import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; + +import javax.annotation.Resource; +import java.time.LocalDateTime; +import java.time.ZoneOffset; +import java.util.List; /** * @author zhibing.pu @@ -10,4 +36,129 @@ @RestController @RequestMapping("/car") public class CarController { + + @Resource + private ICarService carService; + + @Resource + private IDriverService driverService; + + @Resource + private IEnterpriseService enterpriseService; + + @Resource + private RealVideoMsgClient realVideoMsgClient; + + @Resource + private PlaybackMsgClient playbackMsgClient; + + @Resource + private UPExgMsgRealLocationClient upExgMsgRealLocationClient; + + + @GetMapping("/getCarList") + @ApiOperation(value = "获取车辆列表", tags = {"车辆管理"}) + public R<PageInfo<CarListResp>> getCarList(CarListReq carListReq) { + PageInfo<CarListResp> carList = carService.getCarList(carListReq); + return R.ok(carList); + } + + + @GetMapping("/getCarInfo/{id}") + @ApiOperation(value = "获取车辆详情", tags = {"车辆管理"}) + @ApiImplicitParams({ + @ApiImplicitParam(value = "车辆id", name = "id", required = true) + }) + public R<Car> getCarInfo(@PathVariable("id") Integer id){ + Car car = carService.getById(id); + if(null == car){ + return R.fail("失败"); + } + Driver driver = driverService.getOne(new LambdaQueryWrapper<Driver>().eq(Driver::getVehicleNumber, car.getVehicleNumber()).eq(Driver::getStatus, 1)); + Enterprise enterprise = enterpriseService.getById(car.getEnterpriseId()); + car.setEnterpriseName(enterprise.getName()); + car.setDriverName(driver.getName()); + return R.ok(car); + } + + + + @GetMapping("/getRealVideo/{id}") + @ApiOperation(value = "获取实时音视频", tags = {"车辆管理"}) + @ApiImplicitParams({ + @ApiImplicitParam(value = "车辆id", name = "id", required = true) + }) + public R<RealVideoResp> getRealVideo(@PathVariable("id") Integer id){ + Car car = carService.getById(id); + if(null == car){ + return R.fail("失败"); + } + Enterprise enterprise = enterpriseService.getById(car.getEnterpriseId()); + R<UPRealvideoMsgStartupAckVo> msgStartupAckVoR = realVideoMsgClient.startupRealVideo(Integer.valueOf(enterprise.getCode()), car.getVehicleNumber()); + if(200 == msgStartupAckVoR.getCode()){ + UPRealvideoMsgStartupAckVo data = msgStartupAckVoR.getData(); + RealVideoResp resp = new RealVideoResp(); + resp.setServerIp(data.getServerIP()); + resp.setServerPort(data.getServerPort()); + return R.ok(resp); + } + return R.fail(msgStartupAckVoR.getMsg()); + } + + + @GetMapping("/getPlaybackVideo") + @ApiOperation(value = "获取音视频回放", tags = {"车辆管理"}) + public R<RealVideoResp> getPlaybackVideo(PlaybackVideoReq req){ + Car car = carService.getById(req.getId()); + if(null == car){ + return R.fail("失败"); + } + Enterprise enterprise = enterpriseService.getById(car.getEnterpriseId()); + R<UPPlaybackMsgStartupAckVo> startupAckVoR = playbackMsgClient.playbackMsgStartup(Integer.valueOf(enterprise.getCode()), car.getVehicleNumber(), + req.getStartTime(), req.getEndTime()); + if(200 == startupAckVoR.getCode()){ + UPPlaybackMsgStartupAckVo data = startupAckVoR.getData(); + RealVideoResp resp = new RealVideoResp(); + resp.setServerIp(data.getServerIP()); + resp.setServerPort(data.getServerPort()); + return R.ok(resp); + } + return R.fail(startupAckVoR.getMsg()); + } + + + + + @GetMapping("/playbackMsgControl") + @ApiOperation(value = "音视频回放远程控制", tags = {"车辆管理"}) + public R playbackMsgControl(PlaybackMsgControlReq req){ + Car car = carService.getById(req.getId()); + if(null == car){ + return R.fail("失败"); + } + Enterprise enterprise = enterpriseService.getById(car.getEnterpriseId()); + return playbackMsgClient.playbackMsgControl(Integer.valueOf(enterprise.getCode()), car.getVehicleNumber(), + req.getControlType(), req.getFastTime()); + } + + + + + @GetMapping("/getCarTravel") + @ApiOperation(value = "获取车辆行程轨迹", tags = {"车辆管理"}) + public R<List<OrderTravelVo>> getCarTravel(CarTravelReq req){ + Car car = carService.getOne(new LambdaQueryWrapper<Car>().eq(Car::getVehicleNumber, req.getVehicleNumber())); + Long startTime; + Long endTime; + if(null != req.getStartTime() && null != req.getEndTime()){ + startTime = req.getStartTime(); + endTime = req.getEndTime(); + }else{ + LocalDateTime now = LocalDateTime.now(); + startTime = now.minusMinutes(1).toEpochSecond(ZoneOffset.ofHours(8)); + endTime = now.toEpochSecond(ZoneOffset.ofHours(8)); + } + R<List<OrderTravelVo>> orderTravel = upExgMsgRealLocationClient.getOrderTravel(car.getVehicleNumber(), startTime, endTime); + return orderTravel; + } } -- Gitblit v1.7.1