yang_shj
1 year ago
39 changed files with 1219 additions and 10 deletions
@ -0,0 +1,36 @@
|
||||
package com.hnac.hzims.emParam.dto; |
||||
|
||||
import com.baomidou.mybatisplus.annotation.TableName; |
||||
import com.fasterxml.jackson.annotation.JsonFormat; |
||||
import com.hnac.hzims.emParam.entity.ParamBackupsEntity; |
||||
import io.swagger.annotations.ApiModel; |
||||
import io.swagger.annotations.ApiModelProperty; |
||||
import lombok.Data; |
||||
import lombok.EqualsAndHashCode; |
||||
import org.springblade.core.tool.utils.DateUtil; |
||||
import org.springframework.format.annotation.DateTimeFormat; |
||||
|
||||
import java.io.Serializable; |
||||
import java.time.LocalDateTime; |
||||
import java.util.List; |
||||
|
||||
@Data |
||||
@ApiModel("下发参数备份DTO对象") |
||||
@EqualsAndHashCode |
||||
public class ParamBackupsDTO extends ParamBackupsEntity implements Serializable { |
||||
|
||||
|
||||
@ApiModelProperty("开始时间") |
||||
@JsonFormat(pattern = DateUtil.PATTERN_DATETIME) |
||||
@DateTimeFormat(pattern = DateUtil.PATTERN_DATETIME) |
||||
private LocalDateTime startTime; |
||||
|
||||
@ApiModelProperty("结束时间") |
||||
@JsonFormat(pattern = DateUtil.PATTERN_DATETIME) |
||||
@DateTimeFormat(pattern = DateUtil.PATTERN_DATETIME) |
||||
private LocalDateTime endTime; |
||||
|
||||
@ApiModelProperty("参数备份详情列表") |
||||
private List<ParamBackupsDetailDTO> details; |
||||
|
||||
} |
@ -0,0 +1,15 @@
|
||||
package com.hnac.hzims.emParam.dto; |
||||
|
||||
import com.hnac.hzims.emParam.entity.ParamBackupsDetailEntity; |
||||
import io.swagger.annotations.ApiModel; |
||||
import lombok.Data; |
||||
import lombok.EqualsAndHashCode; |
||||
|
||||
import java.io.Serializable; |
||||
|
||||
@Data |
||||
@ApiModel("下发参数备份详情DTO对象") |
||||
@EqualsAndHashCode |
||||
public class ParamBackupsDetailDTO extends ParamBackupsDetailEntity implements Serializable { |
||||
|
||||
} |
@ -0,0 +1,42 @@
|
||||
package com.hnac.hzims.emParam.dto; |
||||
|
||||
import io.swagger.annotations.ApiModel; |
||||
import io.swagger.annotations.ApiModelProperty; |
||||
import lombok.Data; |
||||
import lombok.EqualsAndHashCode; |
||||
|
||||
import java.io.Serializable; |
||||
|
||||
@ApiModel("下发参数") |
||||
@Data |
||||
@EqualsAndHashCode |
||||
public class ParamDTO implements Serializable { |
||||
|
||||
@ApiModelProperty("参数名称") |
||||
private String name; |
||||
|
||||
@ApiModelProperty("标识") |
||||
private String signage; |
||||
|
||||
@ApiModelProperty("关联设备") |
||||
private String facDeviceId; |
||||
|
||||
@ApiModelProperty("hz3000关联id") |
||||
private String facDeviceFuncId; |
||||
|
||||
@ApiModelProperty("参数标识") |
||||
private String parameterTag; |
||||
|
||||
@ApiModelProperty("参数名称") |
||||
private String parameterName; |
||||
|
||||
@ApiModelProperty("值") |
||||
private String value; |
||||
|
||||
@ApiModelProperty("最大值") |
||||
private String maxValue; |
||||
|
||||
@ApiModelProperty("最小值") |
||||
private String minValue; |
||||
|
||||
} |
@ -0,0 +1,37 @@
|
||||
package com.hnac.hzims.emParam.dto; |
||||
|
||||
import com.hnac.hzims.emParam.vo.ParamVO; |
||||
import io.swagger.annotations.ApiModel; |
||||
import io.swagger.annotations.ApiModelProperty; |
||||
import lombok.Data; |
||||
import lombok.EqualsAndHashCode; |
||||
|
||||
import javax.validation.constraints.NotBlank; |
||||
import java.io.Serializable; |
||||
import java.util.List; |
||||
|
||||
@ApiModel("参数下发请求体") |
||||
@Data |
||||
@EqualsAndHashCode |
||||
public class ParamDistributeDTO implements Serializable { |
||||
|
||||
@ApiModelProperty("站点编号") |
||||
@NotBlank |
||||
private String stationCode; |
||||
|
||||
@ApiModelProperty("设备编码") |
||||
@NotBlank |
||||
private String emCode; |
||||
|
||||
@ApiModelProperty("是否延迟发布") |
||||
private Boolean delay; |
||||
|
||||
@ApiModelProperty("机器码") |
||||
@NotBlank |
||||
private String machineCode; |
||||
|
||||
@ApiModelProperty("参数列表") |
||||
@NotBlank |
||||
private List<ParamDTO> paramList; |
||||
|
||||
} |
@ -0,0 +1,60 @@
|
||||
package com.hnac.hzims.emParam.entity; |
||||
|
||||
import com.baomidou.mybatisplus.annotation.TableName; |
||||
import io.swagger.annotations.ApiModel; |
||||
import io.swagger.annotations.ApiModelProperty; |
||||
import lombok.Data; |
||||
import lombok.EqualsAndHashCode; |
||||
import org.springblade.core.mp.support.QueryField; |
||||
import org.springblade.core.mp.support.SqlCondition; |
||||
import org.springblade.core.tenant.mp.TenantEntity; |
||||
|
||||
import java.io.Serializable; |
||||
|
||||
@Data |
||||
@ApiModel("下发参数备份详情表") |
||||
@TableName("HZIMS_PARAM_BACKUPS_DETAIL") |
||||
@EqualsAndHashCode |
||||
public class ParamBackupsDetailEntity extends TenantEntity implements Serializable { |
||||
|
||||
@ApiModelProperty("备份主表ID") |
||||
private Long backupsId; |
||||
|
||||
@ApiModelProperty("参数名称") |
||||
@QueryField(condition = SqlCondition.LIKE) |
||||
private String name; |
||||
|
||||
@ApiModelProperty("标识") |
||||
@QueryField(condition = SqlCondition.LIKE) |
||||
private String signage; |
||||
|
||||
@ApiModelProperty("关联设备") |
||||
private String facDeviceId; |
||||
|
||||
@ApiModelProperty("hz3000关联id") |
||||
private String facDeviceFuncId; |
||||
|
||||
@ApiModelProperty("参数标识") |
||||
@QueryField(condition = SqlCondition.LIKE) |
||||
private String parameterTag; |
||||
|
||||
@ApiModelProperty("参数名称") |
||||
@QueryField(condition = SqlCondition.LIKE) |
||||
private String parameterName; |
||||
|
||||
@ApiModelProperty("值") |
||||
private String value; |
||||
|
||||
@ApiModelProperty("最大值") |
||||
private String maxValue; |
||||
|
||||
@ApiModelProperty("最小值") |
||||
private String minValue; |
||||
|
||||
@ApiModelProperty("保留小数位") |
||||
private Integer keepFigures; |
||||
|
||||
@ApiModelProperty("描述") |
||||
private String descs; |
||||
|
||||
} |
@ -0,0 +1,41 @@
|
||||
package com.hnac.hzims.emParam.entity; |
||||
|
||||
import com.baomidou.mybatisplus.annotation.SqlCondition; |
||||
import com.baomidou.mybatisplus.annotation.TableName; |
||||
import io.swagger.annotations.ApiModel; |
||||
import io.swagger.annotations.ApiModelProperty; |
||||
import lombok.AllArgsConstructor; |
||||
import lombok.Data; |
||||
import lombok.EqualsAndHashCode; |
||||
import org.springblade.core.mp.support.QueryField; |
||||
import org.springblade.core.tenant.mp.TenantEntity; |
||||
|
||||
import java.io.Serializable; |
||||
|
||||
@Data |
||||
@ApiModel("下发参数备份表") |
||||
@TableName("hzims_param_backups") |
||||
@EqualsAndHashCode |
||||
public class ParamBackupsEntity extends TenantEntity implements Serializable { |
||||
|
||||
@ApiModelProperty("备份名称") |
||||
@QueryField(condition = SqlCondition.LIKE) |
||||
private String name; |
||||
|
||||
@ApiModelProperty("站点编号") |
||||
@QueryField(condition = SqlCondition.EQUAL) |
||||
private String stationCode; |
||||
|
||||
@ApiModelProperty("设备编号") |
||||
@QueryField(condition = SqlCondition.EQUAL) |
||||
private String emCode; |
||||
|
||||
@ApiModelProperty("是否延迟发布") |
||||
@QueryField(condition = SqlCondition.EQUAL) |
||||
private Boolean delay; |
||||
|
||||
@ApiModelProperty("机器码") |
||||
@QueryField(condition = SqlCondition.EQUAL) |
||||
private String machineCode; |
||||
|
||||
} |
@ -0,0 +1,63 @@
|
||||
package com.hnac.hzims.emParam.entity; |
||||
|
||||
import com.baomidou.mybatisplus.annotation.SqlCondition; |
||||
import com.baomidou.mybatisplus.annotation.TableName; |
||||
import io.swagger.annotations.ApiModel; |
||||
import io.swagger.annotations.ApiModelProperty; |
||||
import lombok.Data; |
||||
import lombok.EqualsAndHashCode; |
||||
import org.springblade.core.mp.support.QueryField; |
||||
import org.springblade.core.tenant.mp.TenantEntity; |
||||
|
||||
import java.io.Serializable; |
||||
|
||||
@ApiModel("HZ100C参数模板实体类") |
||||
@EqualsAndHashCode |
||||
@Data |
||||
@TableName("HZIMS_EM_PARAM_MODEL") |
||||
public class ParamModelEntity extends TenantEntity implements Serializable { |
||||
|
||||
@ApiModelProperty("编号") |
||||
@QueryField(condition = SqlCondition.LIKE) |
||||
private String code; |
||||
|
||||
@ApiModelProperty("名称") |
||||
@QueryField(condition = SqlCondition.LIKE) |
||||
private String name; |
||||
|
||||
@ApiModelProperty("单位") |
||||
private String unit; |
||||
|
||||
@ApiModelProperty("小数位") |
||||
private Integer decimalDigit; |
||||
|
||||
@ApiModelProperty("最大值") |
||||
private Double maxValue; |
||||
|
||||
@ApiModelProperty("最小值") |
||||
private Double minValue; |
||||
|
||||
@ApiModelProperty("宽度") |
||||
private Double width; |
||||
|
||||
@ApiModelProperty("类型") |
||||
@QueryField(condition = SqlCondition.EQUAL) |
||||
private Integer type; |
||||
|
||||
@ApiModelProperty("数据类型") |
||||
@QueryField(condition = SqlCondition.EQUAL) |
||||
private Integer dataType; |
||||
|
||||
@ApiModelProperty("地址") |
||||
private Integer address; |
||||
|
||||
@ApiModelProperty("起始位") |
||||
private Integer initDigital; |
||||
|
||||
@ApiModelProperty("所在显示组") |
||||
private Integer group; |
||||
|
||||
@ApiModelProperty("注释") |
||||
private String remark; |
||||
|
||||
} |
@ -0,0 +1 @@
|
||||
### HZ100C 参数下发功能 |
@ -0,0 +1,15 @@
|
||||
package com.hnac.hzims.emParam.vo; |
||||
|
||||
import com.hnac.hzims.emParam.entity.ParamBackupsDetailEntity; |
||||
import io.swagger.annotations.ApiModel; |
||||
import lombok.Data; |
||||
import lombok.EqualsAndHashCode; |
||||
|
||||
import java.io.Serializable; |
||||
|
||||
@Data |
||||
@ApiModel("下发参数备份详情VO对象") |
||||
@EqualsAndHashCode |
||||
public class ParamBackupsDetailVO extends ParamBackupsDetailEntity implements Serializable { |
||||
|
||||
} |
@ -0,0 +1,20 @@
|
||||
package com.hnac.hzims.emParam.vo; |
||||
|
||||
import com.hnac.hzims.emParam.entity.ParamBackupsEntity; |
||||
import io.swagger.annotations.ApiModel; |
||||
import io.swagger.annotations.ApiModelProperty; |
||||
import lombok.Data; |
||||
import lombok.EqualsAndHashCode; |
||||
|
||||
import java.io.Serializable; |
||||
import java.util.List; |
||||
|
||||
@Data |
||||
@ApiModel("下发参数备份VO对象") |
||||
@EqualsAndHashCode |
||||
public class ParamBackupsVO extends ParamBackupsEntity implements Serializable { |
||||
|
||||
@ApiModelProperty("下发参数备份参数列表") |
||||
private List<ParamBackupsDetailVO> detailList; |
||||
|
||||
} |
@ -0,0 +1,21 @@
|
||||
package com.hnac.hzims.emParam.vo; |
||||
|
||||
import io.swagger.annotations.ApiModel; |
||||
import io.swagger.annotations.ApiModelProperty; |
||||
import lombok.Data; |
||||
import lombok.EqualsAndHashCode; |
||||
|
||||
import java.io.Serializable; |
||||
|
||||
@Data |
||||
@ApiModel("HZ100C参数分组VO") |
||||
@EqualsAndHashCode |
||||
public class ParamGroupVO implements Serializable { |
||||
|
||||
@ApiModelProperty("参数分组ID") |
||||
private String groupId; |
||||
|
||||
@ApiModelProperty("参数分组名称") |
||||
private String groupName; |
||||
|
||||
} |
@ -0,0 +1,22 @@
|
||||
package com.hnac.hzims.emParam.vo; |
||||
|
||||
import io.swagger.annotations.ApiModel; |
||||
import io.swagger.annotations.ApiModelProperty; |
||||
import lombok.Data; |
||||
import lombok.EqualsAndHashCode; |
||||
|
||||
import java.io.Serializable; |
||||
import java.util.List; |
||||
|
||||
@Data |
||||
@ApiModel("HZ100C参数树VO") |
||||
@EqualsAndHashCode |
||||
public class ParamTreeVO implements Serializable { |
||||
|
||||
@ApiModelProperty("参数分组") |
||||
private ParamGroupVO paramGroup; |
||||
|
||||
@ApiModelProperty("参数列表") |
||||
private List<ParamVO> paramList; |
||||
|
||||
} |
@ -0,0 +1,70 @@
|
||||
package com.hnac.hzims.emParam.vo; |
||||
|
||||
import io.swagger.annotations.ApiModel; |
||||
import io.swagger.annotations.ApiModelProperty; |
||||
import lombok.Data; |
||||
import lombok.EqualsAndHashCode; |
||||
|
||||
import java.io.Serializable; |
||||
|
||||
/** |
||||
* @ClassName ParamVO |
||||
* @description: |
||||
* @author: hx |
||||
* @create: 2023-10-17 14:13 |
||||
* @Version 4.0 |
||||
**/ |
||||
@Data |
||||
@ApiModel("HZ100C参数VO") |
||||
@EqualsAndHashCode |
||||
public class ParamVO implements Serializable { |
||||
|
||||
@ApiModelProperty("参数名称") |
||||
private String name; |
||||
|
||||
@ApiModelProperty("标识") |
||||
private String signage; |
||||
|
||||
@ApiModelProperty("关联设备") |
||||
private String facDeviceId; |
||||
|
||||
@ApiModelProperty("hz3000关联id") |
||||
private String facDeviceAttrId; |
||||
|
||||
@ApiModelProperty("参数标识") |
||||
private String parameterTag; |
||||
|
||||
@ApiModelProperty("参数名称") |
||||
private String parameterName; |
||||
|
||||
@ApiModelProperty("是否只读") |
||||
private Integer isReadOnly; |
||||
|
||||
@ApiModelProperty("数据类型") |
||||
private String dbType; |
||||
|
||||
@ApiModelProperty("参数分组") |
||||
private Long modelClassifyId; |
||||
|
||||
@ApiModelProperty("参数分组名称") |
||||
private String modelClassifyName; |
||||
|
||||
@ApiModelProperty("单位") |
||||
private String units; |
||||
|
||||
@ApiModelProperty("值") |
||||
private String value; |
||||
|
||||
@ApiModelProperty("最大值") |
||||
private String maxValue; |
||||
|
||||
@ApiModelProperty("最小值") |
||||
private String minValue; |
||||
|
||||
@ApiModelProperty("保留小数位") |
||||
private Integer keepFigures; |
||||
|
||||
@ApiModelProperty("描述") |
||||
private String descs; |
||||
|
||||
} |
@ -0,0 +1,27 @@
|
||||
package com.hnac.hzims.emParam.vo; |
||||
|
||||
import io.swagger.annotations.ApiModel; |
||||
import io.swagger.annotations.ApiModelProperty; |
||||
import lombok.Data; |
||||
import lombok.EqualsAndHashCode; |
||||
|
||||
import java.io.Serializable; |
||||
|
||||
@Data |
||||
@ApiModel("实时数据VO对象") |
||||
@EqualsAndHashCode |
||||
public class RealDataVO implements Serializable { |
||||
|
||||
@ApiModelProperty("采集点ID") |
||||
private String realId; |
||||
|
||||
@ApiModelProperty("采集点实时数据") |
||||
private String value; |
||||
|
||||
@ApiModelProperty("采集点时间") |
||||
private String time; |
||||
|
||||
@ApiModelProperty("有效值") |
||||
private String q; |
||||
|
||||
} |
@ -0,0 +1,26 @@
|
||||
package com.hnac.hzims.emParam.wrapper; |
||||
|
||||
import com.hnac.hzims.emParam.entity.ParamBackupsDetailEntity; |
||||
import com.hnac.hzims.emParam.entity.ParamBackupsEntity; |
||||
import com.hnac.hzims.emParam.vo.ParamBackupsDetailVO; |
||||
import com.hnac.hzims.emParam.vo.ParamBackupsVO; |
||||
import org.springblade.core.mp.support.BaseEntityWrapper; |
||||
import org.springblade.core.tool.utils.BeanUtil; |
||||
|
||||
/** |
||||
* @ClassName ParamBackupsDetailWrapper |
||||
* @description: |
||||
* @author: hx |
||||
* @create: 2023-10-17 17:07 |
||||
* @Version 4.0 |
||||
**/ |
||||
public class ParamBackupsDetailWrapper extends BaseEntityWrapper<ParamBackupsDetailEntity, ParamBackupsDetailVO> { |
||||
public static ParamBackupsDetailWrapper build() { |
||||
return new ParamBackupsDetailWrapper(); |
||||
} |
||||
@Override |
||||
public ParamBackupsDetailVO entityVO(ParamBackupsDetailEntity entity) { |
||||
ParamBackupsDetailVO vo = BeanUtil.copy(entity, ParamBackupsDetailVO.class); |
||||
return vo; |
||||
} |
||||
} |
@ -0,0 +1,21 @@
|
||||
package com.hnac.hzims.emParam.wrapper; |
||||
|
||||
import com.hnac.hzims.emParam.entity.ParamBackupsEntity; |
||||
import com.hnac.hzims.emParam.vo.ParamBackupsVO; |
||||
import org.apache.ibatis.reflection.wrapper.BaseWrapper; |
||||
import org.springblade.core.mp.support.BaseEntityWrapper; |
||||
import org.springblade.core.tool.utils.BeanUtil; |
||||
|
||||
|
||||
public class ParamBackupsWrapper extends BaseEntityWrapper<ParamBackupsEntity,ParamBackupsVO> { |
||||
|
||||
public static ParamBackupsWrapper build() { |
||||
return new ParamBackupsWrapper(); |
||||
} |
||||
|
||||
@Override |
||||
public ParamBackupsVO entityVO(ParamBackupsEntity entity) { |
||||
ParamBackupsVO vo = BeanUtil.copy(entity,ParamBackupsVO.class); |
||||
return vo; |
||||
} |
||||
} |
@ -0,0 +1,67 @@
|
||||
package com.hnac.hzims.emParam.controller; |
||||
|
||||
import com.baomidou.mybatisplus.core.metadata.IPage; |
||||
import com.github.xiaoymin.knife4j.annotations.ApiOperationSupport; |
||||
import com.hnac.hzims.common.utils.Condition; |
||||
import com.hnac.hzims.emParam.dto.ParamBackupsDTO; |
||||
import com.hnac.hzims.emParam.entity.ParamBackupsEntity; |
||||
import com.hnac.hzims.emParam.service.IParamBackupsService; |
||||
import com.hnac.hzims.emParam.vo.ParamBackupsVO; |
||||
import com.hnac.hzims.emParam.wrapper.ParamBackupsWrapper; |
||||
import io.swagger.annotations.Api; |
||||
import io.swagger.annotations.ApiOperation; |
||||
import io.swagger.annotations.ApiParam; |
||||
import lombok.AllArgsConstructor; |
||||
import org.springblade.core.boot.ctrl.BladeController; |
||||
import org.springblade.core.mp.support.Query; |
||||
import org.springblade.core.tool.api.R; |
||||
import org.springblade.core.tool.utils.BeanUtil; |
||||
import org.springblade.core.tool.utils.Func; |
||||
import org.springframework.web.bind.annotation.*; |
||||
|
||||
@RestController |
||||
@RequestMapping("/emParam/backups") |
||||
@Api(value = "HZ100C参数下发备份管理",tags = "HZ100C参数下发备份管理") |
||||
@AllArgsConstructor |
||||
public class ParamBackupsController extends BladeController { |
||||
|
||||
private final IParamBackupsService paramBackupsService; |
||||
|
||||
@GetMapping("/listPage") |
||||
@ApiOperation("分页查询") |
||||
@ApiOperationSupport(order = 1) |
||||
public R<IPage> listPage(ParamBackupsDTO request, Query query) { |
||||
IPage page = paramBackupsService.page(Condition.getPage(query),paramBackupsService.getQueryWrapper(request)); |
||||
page.setRecords(ParamBackupsWrapper.build().listVO(page.getRecords())); |
||||
return R.data(page); |
||||
} |
||||
|
||||
@DeleteMapping("/remove/{ids}") |
||||
@ApiOperation("删除备份") |
||||
@ApiOperationSupport(order = 2) |
||||
public R remove(@PathVariable @ApiParam("主键,按,分隔") String ids) { |
||||
return R.status(paramBackupsService.removeByIds(Func.toLongList(",",ids))); |
||||
} |
||||
|
||||
@PostMapping("/save") |
||||
@ApiOperation("新增") |
||||
@ApiOperationSupport(order = 3) |
||||
public R save(@RequestBody ParamBackupsDTO request) { |
||||
return R.status(paramBackupsService.save(request)); |
||||
} |
||||
|
||||
@GetMapping("/detail/{id}") |
||||
@ApiOperation("查看详情") |
||||
@ApiOperationSupport(order = 4) |
||||
public R<ParamBackupsVO> detail(@PathVariable @ApiParam("主键") Long id) { |
||||
return R.data(paramBackupsService.detail(id)); |
||||
} |
||||
|
||||
@PutMapping("/updateById") |
||||
@ApiOperation("编辑") |
||||
@ApiOperationSupport(order = 5) |
||||
public R updateById(@RequestBody ParamBackupsDTO request) { |
||||
return R.status(paramBackupsService.updateById(request)); |
||||
} |
||||
|
||||
} |
@ -0,0 +1,39 @@
|
||||
package com.hnac.hzims.emParam.controller; |
||||
|
||||
import com.github.xiaoymin.knife4j.annotations.ApiOperationSupport; |
||||
import com.hnac.hzims.emParam.dto.ParamDistributeDTO; |
||||
import com.hnac.hzims.emParam.service.IParamService; |
||||
import com.hnac.hzims.emParam.vo.ParamTreeVO; |
||||
import com.hnac.hzinfo.sdk.core.response.Result; |
||||
import io.swagger.annotations.Api; |
||||
import io.swagger.annotations.ApiOperation; |
||||
import lombok.AllArgsConstructor; |
||||
import org.springblade.core.boot.ctrl.BladeController; |
||||
import org.springblade.core.tool.api.R; |
||||
import org.springframework.web.bind.annotation.*; |
||||
|
||||
import java.util.List; |
||||
|
||||
@RequestMapping("/param") |
||||
@AllArgsConstructor |
||||
@RestController |
||||
@Api(value = "参数下发管理",tags = "参数下发管理") |
||||
public class ParamController extends BladeController { |
||||
|
||||
private final IParamService paramService; |
||||
|
||||
@GetMapping("/recall") |
||||
@ApiOperation("召回参数") |
||||
@ApiOperationSupport(order = 1) |
||||
public R<List<ParamTreeVO>> recall(String emCode, String stationCode) { |
||||
return R.data(paramService.recall(emCode,stationCode)); |
||||
} |
||||
|
||||
@PostMapping("/distribute") |
||||
@ApiOperation("下发参数") |
||||
@ApiOperationSupport(order = 2) |
||||
public Result<Object> distribute(@RequestBody ParamDistributeDTO req) { |
||||
return paramService.distribute(req); |
||||
} |
||||
|
||||
} |
@ -0,0 +1,8 @@
|
||||
package com.hnac.hzims.emParam.mapper; |
||||
|
||||
import com.baomidou.mybatisplus.core.mapper.BaseMapper; |
||||
import com.hnac.hzims.emParam.entity.ParamBackupsDetailEntity; |
||||
import com.hnac.hzims.emParam.entity.ParamBackupsEntity; |
||||
|
||||
public interface ParamBackupsDetailMapper extends BaseMapper<ParamBackupsDetailEntity> { |
||||
} |
@ -0,0 +1,9 @@
|
||||
package com.hnac.hzims.emParam.mapper; |
||||
|
||||
import com.baomidou.mybatisplus.core.mapper.BaseMapper; |
||||
import com.hnac.hzims.emParam.entity.ParamBackupsEntity; |
||||
import org.apache.ibatis.reflection.wrapper.BaseWrapper; |
||||
|
||||
public interface ParamBackupsMapper extends BaseMapper<ParamBackupsEntity> { |
||||
|
||||
} |
@ -0,0 +1,10 @@
|
||||
package com.hnac.hzims.emParam.mapper; |
||||
|
||||
import com.baomidou.mybatisplus.core.mapper.BaseMapper; |
||||
import com.hnac.hzims.emParam.entity.ParamModelEntity; |
||||
|
||||
public interface ParamModelMapper extends BaseMapper<ParamModelEntity> { |
||||
|
||||
|
||||
|
||||
} |
@ -0,0 +1 @@
|
||||
### HZ100C 参数下发功能 |
@ -0,0 +1,8 @@
|
||||
package com.hnac.hzims.emParam.service; |
||||
|
||||
import com.hnac.hzims.emParam.entity.ParamBackupsDetailEntity; |
||||
import org.springblade.core.mp.base.BaseService; |
||||
|
||||
public interface IParamBackupsDetailService extends BaseService<ParamBackupsDetailEntity> { |
||||
|
||||
} |
@ -0,0 +1,30 @@
|
||||
package com.hnac.hzims.emParam.service; |
||||
|
||||
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; |
||||
import com.hnac.hzims.common.utils.Condition; |
||||
import com.hnac.hzims.emParam.dto.ParamBackupsDTO; |
||||
import com.hnac.hzims.emParam.entity.ParamBackupsEntity; |
||||
import com.hnac.hzims.emParam.vo.ParamBackupsVO; |
||||
import org.springblade.core.mp.base.BaseService; |
||||
import org.springblade.core.tool.utils.BeanUtil; |
||||
import org.springblade.core.tool.utils.Func; |
||||
import org.springframework.web.bind.annotation.RequestBody; |
||||
|
||||
public interface IParamBackupsService extends BaseService<ParamBackupsEntity> { |
||||
|
||||
Boolean save(ParamBackupsDTO request); |
||||
|
||||
ParamBackupsVO detail(Long id); |
||||
|
||||
Boolean updateById(ParamBackupsDTO request); |
||||
|
||||
default LambdaQueryWrapper<ParamBackupsEntity> getQueryWrapper(ParamBackupsDTO request) { |
||||
ParamBackupsEntity paramBackupsEntity = BeanUtil.copy(request, ParamBackupsEntity.class); |
||||
LambdaQueryWrapper<ParamBackupsEntity> queryWrapper = Condition.getQueryWrapper(ParamBackupsEntity.class, paramBackupsEntity); |
||||
queryWrapper.ge(Func.isNotEmpty(request.getStartTime()),ParamBackupsEntity::getCreateTime,request.getStartTime()); |
||||
queryWrapper.le(Func.isNotEmpty(request.getEndTime()),ParamBackupsEntity::getCreateTime,request.getEndTime()); |
||||
queryWrapper.orderByDesc(ParamBackupsEntity::getCreateTime); |
||||
return queryWrapper; |
||||
} |
||||
|
||||
} |
@ -0,0 +1,7 @@
|
||||
package com.hnac.hzims.emParam.service; |
||||
|
||||
import com.hnac.hzims.emParam.entity.ParamModelEntity; |
||||
import org.springblade.core.mp.base.BaseService; |
||||
|
||||
public interface IParamModelService extends BaseService<ParamModelEntity> { |
||||
} |
@ -0,0 +1,13 @@
|
||||
package com.hnac.hzims.emParam.service; |
||||
|
||||
import com.hnac.hzims.emParam.dto.ParamDistributeDTO; |
||||
import com.hnac.hzims.emParam.vo.ParamTreeVO; |
||||
import com.hnac.hzinfo.sdk.core.response.Result; |
||||
|
||||
import java.util.List; |
||||
|
||||
public interface IParamService { |
||||
List<ParamTreeVO> recall(String emCode, String stationCode); |
||||
|
||||
Result<Object> distribute(ParamDistributeDTO req); |
||||
} |
@ -0,0 +1,18 @@
|
||||
package com.hnac.hzims.emParam.service.impl; |
||||
|
||||
import com.hnac.hzims.emParam.entity.ParamBackupsDetailEntity; |
||||
import com.hnac.hzims.emParam.mapper.ParamBackupsDetailMapper; |
||||
import com.hnac.hzims.emParam.service.IParamBackupsDetailService; |
||||
import lombok.AllArgsConstructor; |
||||
import lombok.extern.slf4j.Slf4j; |
||||
import org.springblade.core.mp.base.BaseServiceImpl; |
||||
import org.springframework.stereotype.Service; |
||||
|
||||
@Service |
||||
@AllArgsConstructor |
||||
@Slf4j |
||||
public class ParamBackupsDetailServiceImpl extends BaseServiceImpl<ParamBackupsDetailMapper, ParamBackupsDetailEntity> implements IParamBackupsDetailService { |
||||
|
||||
|
||||
|
||||
} |
@ -0,0 +1,90 @@
|
||||
package com.hnac.hzims.emParam.service.impl; |
||||
|
||||
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; |
||||
import com.baomidou.mybatisplus.core.toolkit.Wrappers; |
||||
import com.hnac.hzims.emParam.dto.ParamBackupsDTO; |
||||
import com.hnac.hzims.emParam.entity.ParamBackupsDetailEntity; |
||||
import com.hnac.hzims.emParam.entity.ParamBackupsEntity; |
||||
import com.hnac.hzims.emParam.mapper.ParamBackupsDetailMapper; |
||||
import com.hnac.hzims.emParam.mapper.ParamBackupsMapper; |
||||
import com.hnac.hzims.emParam.service.IParamBackupsDetailService; |
||||
import com.hnac.hzims.emParam.service.IParamBackupsService; |
||||
import com.hnac.hzims.emParam.vo.ParamBackupsVO; |
||||
import com.hnac.hzims.emParam.wrapper.ParamBackupsDetailWrapper; |
||||
import lombok.AllArgsConstructor; |
||||
import lombok.extern.slf4j.Slf4j; |
||||
import org.springblade.core.log.exception.ServiceException; |
||||
import org.springblade.core.mp.base.BaseServiceImpl; |
||||
import org.springblade.core.tool.utils.BeanUtil; |
||||
import org.springblade.core.tool.utils.CollectionUtil; |
||||
import org.springblade.core.tool.utils.Func; |
||||
import org.springblade.core.tool.utils.ObjectUtil; |
||||
import org.springframework.stereotype.Service; |
||||
import org.springframework.transaction.annotation.Transactional; |
||||
import org.springframework.util.Assert; |
||||
|
||||
import javax.sql.rowset.serial.SerialException; |
||||
import java.util.List; |
||||
import java.util.Objects; |
||||
import java.util.stream.Collectors; |
||||
|
||||
@Service |
||||
@AllArgsConstructor |
||||
@Slf4j |
||||
public class ParamBackupsServiceImpl extends BaseServiceImpl<ParamBackupsMapper, ParamBackupsEntity> implements IParamBackupsService { |
||||
|
||||
private final IParamBackupsDetailService detailService; |
||||
|
||||
@Override |
||||
@Transactional |
||||
public Boolean save(ParamBackupsDTO request) { |
||||
Assert.isTrue(CollectionUtil.isNotEmpty(request.getDetails()),() -> { |
||||
throw new ServiceException("备份参数不能为空!"); |
||||
}); |
||||
ParamBackupsEntity paramBackupsEntity = BeanUtil.copy(request,ParamBackupsEntity.class); |
||||
if(this.save(paramBackupsEntity)) { |
||||
List<ParamBackupsDetailEntity> detailList = request.getDetails().stream() |
||||
.map(d -> BeanUtil.copy(d, ParamBackupsDetailEntity.class)).filter(Objects::nonNull) |
||||
.peek(d -> d.setBackupsId(paramBackupsEntity.getId())).collect(Collectors.toList()); |
||||
Assert.isTrue(detailService.saveBatch(detailList),() -> { |
||||
throw new ServiceException("保存备份参数列表失败!"); |
||||
}); |
||||
return true; |
||||
} |
||||
return false; |
||||
} |
||||
|
||||
@Override |
||||
public ParamBackupsVO detail(Long id) { |
||||
ParamBackupsEntity paramBackupsEntity = this.getById(id); |
||||
Assert.isTrue(Func.isNotEmpty(paramBackupsEntity),() -> { |
||||
throw new ServiceException("未查询到相关记录!"); |
||||
}); |
||||
ParamBackupsVO result = BeanUtil.copy(paramBackupsEntity,ParamBackupsVO.class); |
||||
LambdaQueryWrapper<ParamBackupsDetailEntity> detailQuery = Wrappers.<ParamBackupsDetailEntity>lambdaQuery().eq(ParamBackupsDetailEntity::getBackupsId, id); |
||||
List<ParamBackupsDetailEntity> detailList = detailService.list(detailQuery); |
||||
result.setDetailList(ParamBackupsDetailWrapper.build().listVO(detailList)); |
||||
return result; |
||||
} |
||||
|
||||
@Override |
||||
@Transactional |
||||
public Boolean updateById(ParamBackupsDTO request) { |
||||
Assert.isTrue(CollectionUtil.isNotEmpty(request.getDetails()),() -> { |
||||
throw new ServiceException("备份参数不能为空!"); |
||||
}); |
||||
ParamBackupsEntity paramBackupsEntity = BeanUtil.copy(request,ParamBackupsEntity.class); |
||||
if(this.updateById(paramBackupsEntity)) { |
||||
List<ParamBackupsDetailEntity> detailList = request.getDetails().stream() |
||||
.map(d -> BeanUtil.copy(d, ParamBackupsDetailEntity.class)).filter(Objects::nonNull) |
||||
.peek(d -> d.setBackupsId(paramBackupsEntity.getId())).collect(Collectors.toList()); |
||||
Assert.isTrue(detailService.saveOrUpdateBatch(detailList),() -> { |
||||
throw new ServiceException("保存备份参数列表失败!"); |
||||
}); |
||||
return true; |
||||
} |
||||
return false; |
||||
} |
||||
|
||||
|
||||
} |
@ -0,0 +1,17 @@
|
||||
package com.hnac.hzims.emParam.service.impl; |
||||
|
||||
import com.hnac.hzims.emParam.entity.ParamModelEntity; |
||||
import com.hnac.hzims.emParam.mapper.ParamModelMapper; |
||||
import com.hnac.hzims.emParam.service.IParamModelService; |
||||
import lombok.AllArgsConstructor; |
||||
import lombok.extern.slf4j.Slf4j; |
||||
import org.springblade.core.mp.base.BaseService; |
||||
import org.springblade.core.mp.base.BaseServiceImpl; |
||||
import org.springframework.stereotype.Service; |
||||
|
||||
@Service |
||||
@AllArgsConstructor |
||||
@Slf4j |
||||
public class ParamModelServiceImpl extends BaseServiceImpl<ParamModelMapper, ParamModelEntity> implements IParamModelService { |
||||
|
||||
} |
@ -0,0 +1,175 @@
|
||||
package com.hnac.hzims.emParam.service.impl; |
||||
|
||||
import com.alibaba.fastjson.JSON; |
||||
import com.alibaba.fastjson.JSONArray; |
||||
import com.alibaba.fastjson.JSONObject; |
||||
import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper; |
||||
import com.baomidou.mybatisplus.core.toolkit.Wrappers; |
||||
import com.google.common.collect.Lists; |
||||
import com.hnac.hzims.emParam.dto.ParamDTO; |
||||
import com.hnac.hzims.emParam.dto.ParamDistributeDTO; |
||||
import com.hnac.hzims.emParam.service.IParamService; |
||||
import com.hnac.hzims.emParam.vo.ParamGroupVO; |
||||
import com.hnac.hzims.emParam.vo.ParamTreeVO; |
||||
import com.hnac.hzims.emParam.vo.ParamVO; |
||||
import com.hnac.hzims.emParam.vo.RealDataVO; |
||||
import com.hnac.hzims.equipment.entity.EmInfoEntity; |
||||
import com.hnac.hzims.equipment.service.IEmInfoService; |
||||
import com.hnac.hzinfo.datasearch.analyse.IAnalyseDataSearchClient; |
||||
import com.hnac.hzinfo.datasearch.analyse.domain.FieldsData; |
||||
import com.hnac.hzinfo.datasearch.real.po.RealDataSearchPO; |
||||
import com.hnac.hzinfo.sdk.core.response.Result; |
||||
import com.hnac.hzinfo.sdk.v5.control.ControlClient; |
||||
import com.hnac.hzinfo.sdk.v5.control.dto.ControlBatchDTO; |
||||
import com.hnac.hzinfo.sdk.v5.control.dto.Ctrl; |
||||
import com.hnac.hzinfo.sdk.v5.device.DeviceDataClient; |
||||
import com.hnac.hzinfo.sdk.v5.device.client.DeviceClient; |
||||
import com.hnac.hzinfo.sdk.v5.device.dto.DeviceDataDTO; |
||||
import com.hnac.hzinfo.sdk.v5.device.vo.DeviceInstanceAttrVO; |
||||
import com.hnac.hzinfo.sdk.v5.device.vo.DeviceInstanceFuncVO; |
||||
import com.hnac.hzinfo.sdk.v5.redis.RedisClient; |
||||
import lombok.AllArgsConstructor; |
||||
import lombok.extern.slf4j.Slf4j; |
||||
import org.springblade.core.log.exception.ServiceException; |
||||
import org.springblade.core.log.logger.BladeLogger; |
||||
import org.springblade.core.secure.utils.AuthUtil; |
||||
import org.springblade.core.tool.api.R; |
||||
import org.springblade.core.tool.utils.*; |
||||
import org.springframework.stereotype.Service; |
||||
import org.springframework.util.Assert; |
||||
|
||||
import java.math.BigDecimal; |
||||
import java.math.RoundingMode; |
||||
import java.time.LocalDateTime; |
||||
import java.util.HashMap; |
||||
import java.util.List; |
||||
import java.util.Map; |
||||
import java.util.Optional; |
||||
import java.util.stream.Collectors; |
||||
|
||||
@Service |
||||
@AllArgsConstructor |
||||
@Slf4j |
||||
public class ParamServiceImpl implements IParamService { |
||||
|
||||
private final ControlClient controlClient; |
||||
private final DeviceClient deviceClient; |
||||
private final RedisClient redisClient; |
||||
private final BladeLogger logger; |
||||
private final IEmInfoService emInfoService; |
||||
private final DeviceDataClient deviceDataClient; |
||||
private final IAnalyseDataSearchClient analyseDataSearchClient; |
||||
|
||||
/** |
||||
* 参数召回 |
||||
* @param emCode 设备编号 |
||||
* @param stationCode 站点编号 |
||||
* @return 召回参数渲染对象 |
||||
*/ |
||||
@Override |
||||
public List<ParamTreeVO> recall(String emCode,String stationCode) { |
||||
List<ParamTreeVO> result = Lists.newArrayList(); |
||||
// 获取设备物模型中是参数的属性
|
||||
R<List<DeviceInstanceAttrVO>> paramDeviceAttrR = deviceClient.getOnlineAttr(emCode); |
||||
Assert.isTrue(paramDeviceAttrR.isSuccess() && CollectionUtil.isNotEmpty(paramDeviceAttrR.getData()),() -> { |
||||
throw new ServiceException("获取设备实例物模型属性失败!"); |
||||
}); |
||||
// 获取实时数据
|
||||
List<String> signageList = paramDeviceAttrR.getData().stream() |
||||
.filter(o->StringUtil.isNotBlank(o.getSignage()) && StringUtil.isNotBlank(o.getFacDeviceAttrId())) |
||||
.map(DeviceInstanceAttrVO::getSignage).collect(Collectors.toList()); |
||||
Result<DeviceDataDTO> realDataR = deviceDataClient.getDeviceRealDataByCode(emCode, signageList); |
||||
Assert.isTrue(realDataR.isSuccess(),() -> { |
||||
throw new ServiceException("参数召回获取实时数据失败"); |
||||
}); |
||||
Map<ParamGroupVO, List<ParamVO>> paramGroupVOListMap = paramDeviceAttrR.getData().stream() |
||||
.filter(o->StringUtil.isNotBlank(o.getFacDeviceAttrId()) && o.getIsParam() == 1) |
||||
.map(this::convert).collect(Collectors.groupingBy(p -> { |
||||
ParamGroupVO paramGroupVO = new ParamGroupVO(); |
||||
paramGroupVO.setGroupId(String.valueOf(p.getModelClassifyId())); |
||||
paramGroupVO.setGroupName(p.getModelClassifyName()); |
||||
return paramGroupVO; |
||||
})); |
||||
paramGroupVOListMap.forEach((groupVO,list) -> { |
||||
ParamTreeVO paramTreeVO = new ParamTreeVO(); |
||||
paramTreeVO.setParamGroup(groupVO); |
||||
list.stream().filter(p -> realDataR.getData().getDataMap().containsKey(p.getSignage())).forEach(p -> { |
||||
String realData = JSON.toJSONString(realDataR.getData().getDataMap().get(p.getSignage())); |
||||
if("0".equals(JSONObject.parseObject(realData).getString("q"))) { |
||||
String value = JSONObject.parseObject(realData).getString("v"); |
||||
if(StringUtil.isNotBlank(p.getDbType()) && "double".equals(p.getDbType()) |
||||
&& StringUtil.isNotBlank(value) && ObjectUtil.isNotEmpty(p.getKeepFigures())) { |
||||
value = String.valueOf(new BigDecimal(value).setScale(p.getKeepFigures(), RoundingMode.HALF_UP).doubleValue()); |
||||
} |
||||
p.setValue(value); |
||||
} |
||||
}); |
||||
paramTreeVO.setParamList(list); |
||||
result.add(paramTreeVO); |
||||
}); |
||||
return result; |
||||
} |
||||
|
||||
/** |
||||
* 参数下发 |
||||
* @param req 下发参数 |
||||
* @return 下发结果 |
||||
*/ |
||||
@Override |
||||
public Result<Object> distribute(ParamDistributeDTO req) { |
||||
Assert.isTrue(Func.isNotEmpty(AuthUtil.getUserId()),() -> { |
||||
throw new ServiceException("未获取到当前登录人,无法下发参数!"); |
||||
}); |
||||
ControlBatchDTO controlBatchDTO = new ControlBatchDTO(); |
||||
controlBatchDTO.setProjectId(req.getStationCode()); |
||||
controlBatchDTO.setDeviceCode(req.getEmCode()); |
||||
controlBatchDTO.setDelay(req.getDelay()); |
||||
controlBatchDTO.setOperator(String.valueOf(AuthUtil.getUserId())); |
||||
controlBatchDTO.setMachineCode(req.getMachineCode()); |
||||
List<Ctrl> ctrl = req.getParamList().stream().map(this::convert).collect(Collectors.toList()); |
||||
controlBatchDTO.setCtrls(ctrl); |
||||
log.info("{}",JSON.toJSONString(controlBatchDTO)); |
||||
Result<Object> result = controlClient.batchSendToDevice(controlBatchDTO); |
||||
if(!result.isSuccess()) { |
||||
logger.error("equipment:ParamServiceImpl:distribute","下发参数传参为:"+JSON.toJSONString(controlBatchDTO)+";下发结果为:"+JSON.toJSONString(result)); |
||||
return result; |
||||
} |
||||
LambdaUpdateWrapper<EmInfoEntity> updateWrapper = Wrappers.<EmInfoEntity>lambdaUpdate().set(EmInfoEntity::getLastDistributeTime, LocalDateTime.now()).eq(EmInfoEntity::getNumber, req.getEmCode()); |
||||
emInfoService.update(updateWrapper); |
||||
return result; |
||||
} |
||||
|
||||
/** |
||||
* 参数转换为下发参数传参格式 |
||||
* @param param 参数 |
||||
* @return 下发参数传参格式 |
||||
*/ |
||||
private Ctrl convert(ParamDTO param) { |
||||
Ctrl result = new Ctrl(); |
||||
result.setSignage(param.getSignage()); |
||||
Map params = new HashMap(1){{ |
||||
put(param.getSignage(),param.getValue()); |
||||
}}; |
||||
result.setParams(params); |
||||
return result; |
||||
} |
||||
|
||||
private ParamVO convert(DeviceInstanceAttrVO instanceAttrVO) { |
||||
ParamVO paramVO = BeanUtil.copy(instanceAttrVO, ParamVO.class); |
||||
paramVO.setMaxValue(String.valueOf(instanceAttrVO.getUpperLimit())); |
||||
paramVO.setMinValue(String.valueOf(instanceAttrVO.getLowerLimit())); |
||||
return paramVO; |
||||
} |
||||
|
||||
/** |
||||
* 设备实例功能对象转换为参数VO对象 |
||||
* @param funcVO 设备实例功能对象 |
||||
* @return 参数VO对象 |
||||
*/ |
||||
private ParamVO convert(DeviceInstanceFuncVO funcVO) { |
||||
ParamVO paramVO = BeanUtil.copy(funcVO, ParamVO.class); |
||||
return paramVO; |
||||
} |
||||
|
||||
|
||||
} |
@ -1 +1,50 @@
|
||||
alter table hzims_em_param add COLUMN NAME VARCHAR(100) comment '参数名称'; |
||||
alter table hzims_em_param add COLUMN NAME VARCHAR(100) comment '参数名称'; |
||||
|
||||
-- HZ100C参数下发 设备表添加参数最后下发时间字段 |
||||
alter table `hzims_em_info` add column `LAST_DISTRIBUTE_TIME` DATETIME DEFAULT NULL COMMENT '最后下发时间'; |
||||
-- HZ100C参数下发 设备表添加字段机组类别 |
||||
alter table `hzims_em_info` add column `SET_CATEGORY` VARCHAR(2) DEFAULT NULL COMMENT '机组类别'; |
||||
|
||||
CREATE TABLE `hzims_param_backups` ( |
||||
`ID` bigint(20) NOT NULL, |
||||
`NAME` varchar(255) DEFAULT NULL, |
||||
`STATION_CODE` varchar(64) DEFAULT NULL, |
||||
`EM_CODE` varchar(64) DEFAULT NULL, |
||||
`DELAY` tinyint(1) DEFAULT NULL, |
||||
`MACHINE_CODE` varchar(255) DEFAULT NULL, |
||||
`TENANT_ID` varchar(12) DEFAULT NULL COMMENT '租户ID', |
||||
`CREATE_TIME` datetime NOT NULL COMMENT '创建时间', |
||||
`UPDATE_TIME` datetime DEFAULT NULL COMMENT '更新时间', |
||||
`CREATE_USER` bigint(20) NOT NULL COMMENT '创建人', |
||||
`UPDATE_USER` bigint(20) DEFAULT NULL COMMENT '更新人', |
||||
`IS_DELETED` tinyint(4) NOT NULL DEFAULT '0' COMMENT '是否删除', |
||||
`STATUS` tinyint(4) DEFAULT NULL COMMENT '状态 ', |
||||
`CREATE_DEPT` bigint(20) DEFAULT NULL COMMENT '创建部门', |
||||
PRIMARY KEY (`ID`) USING BTREE |
||||
) ENGINE=InnoDB DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC; |
||||
|
||||
CREATE TABLE `hzims_param_backups_detail` ( |
||||
`ID` bigint(20) NOT NULL, |
||||
`BACKUPS_ID` bigint(20) DEFAULT NULL COMMENT '备份主表ID', |
||||
`NAME` varchar(255) DEFAULT NULL COMMENT '参数名称', |
||||
`SIGNAGE` varchar(128) DEFAULT NULL COMMENT '标识', |
||||
`FAC_DEVICE_ID` varchar(64) DEFAULT NULL COMMENT '关联设备', |
||||
`FAC_DEVICE_FUNC_ID` varchar(64) DEFAULT NULL COMMENT 'hz3000关联id', |
||||
`PARAMETER_TAG` varchar(128) DEFAULT NULL COMMENT '参数标识', |
||||
`PARAMETER_NAME` varchar(255) DEFAULT NULL COMMENT '参数名称', |
||||
`VALUE` varchar(16) DEFAULT NULL COMMENT '值', |
||||
`MAX_VALUE` varchar(16) DEFAULT NULL COMMENT '最大值', |
||||
`MIN_VALUE` varchar(16) DEFAULT NULL COMMENT '最小值', |
||||
`TENANT_ID` varchar(12) DEFAULT NULL COMMENT '租户ID', |
||||
`CREATE_TIME` datetime NOT NULL COMMENT '创建时间', |
||||
`UPDATE_TIME` datetime DEFAULT NULL COMMENT '更新时间', |
||||
`CREATE_USER` bigint(20) NOT NULL COMMENT '创建人', |
||||
`UPDATE_USER` bigint(20) DEFAULT NULL COMMENT '更新人', |
||||
`IS_DELETED` tinyint(4) NOT NULL DEFAULT '0' COMMENT '是否删除', |
||||
`STATUS` tinyint(4) DEFAULT NULL COMMENT '状态 ', |
||||
`CREATE_DEPT` bigint(20) DEFAULT NULL COMMENT '创建部门', |
||||
PRIMARY KEY (`ID`) |
||||
) ENGINE=InnoDB DEFAULT CHARSET=utf8; |
||||
|
||||
alter table `HZIMS_PARAM_BACKUPS_DETAIL` add COLUMN `KEEP_FIGURES` INT(11) COMMENT '小数点位数'; |
||||
alter table `HZIMS_PARAM_BACKUPS_DETAIL` add COLUMN `DESCS` VARCHAR(255) COMMENT '描述'; |
||||
|
@ -0,0 +1,134 @@
|
||||
package com.hnac.hzims.operational.maintenance.scheduled; |
||||
|
||||
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; |
||||
import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper; |
||||
import com.baomidou.mybatisplus.core.toolkit.Wrappers; |
||||
import com.hnac.hzims.equipment.feign.IEmInfoClient; |
||||
import com.hnac.hzims.operational.duty.entity.ImsDutyMainEntity; |
||||
import com.hnac.hzims.operational.maintenance.entity.OperMaintenanceLibraryEntity; |
||||
import com.hnac.hzims.operational.maintenance.entity.OperMaintenancePlanEntity; |
||||
import com.hnac.hzims.operational.maintenance.entity.OperMaintenanceTaskEntity; |
||||
import com.hnac.hzims.operational.maintenance.mapper.OperMaintenanceLibraryMapper; |
||||
import com.hnac.hzims.operational.maintenance.service.IOperMaintenancePlanService; |
||||
import com.hnac.hzims.operational.maintenance.service.IOperMaintenanceTaskService; |
||||
import com.hnac.hzinfo.inspect.plan.entity.PlanEntity; |
||||
import com.xxl.job.core.biz.model.ReturnT; |
||||
import com.xxl.job.core.handler.annotation.XxlJob; |
||||
import com.xxl.job.core.log.XxlJobLogger; |
||||
import lombok.AllArgsConstructor; |
||||
import lombok.extern.slf4j.Slf4j; |
||||
import org.apache.commons.lang.StringUtils; |
||||
import org.springblade.core.log.logger.BladeLogger; |
||||
import org.springblade.core.tool.utils.*; |
||||
import org.springblade.flow.core.feign.IFlowClient; |
||||
import org.springblade.system.user.feign.IUserClient; |
||||
import org.springframework.beans.factory.annotation.Autowired; |
||||
import org.springframework.stereotype.Component; |
||||
|
||||
import java.time.Instant; |
||||
import java.time.LocalDateTime; |
||||
import java.time.ZoneId; |
||||
import java.time.format.DateTimeFormatter; |
||||
import java.util.*; |
||||
import java.util.stream.Collectors; |
||||
|
||||
import static com.hnac.hzims.operational.maintenance.constants.ScheduledConstant.TASK_VALUE_MAINTENANCE_TASK_CREATE; |
||||
import static org.springblade.core.tool.utils.DateUtil.PATTERN_DATE; |
||||
|
||||
/** |
||||
* 日常维护任务生成 |
||||
*/ |
||||
@Component |
||||
@Slf4j |
||||
@AllArgsConstructor |
||||
public class MaintenanceTaskSchedule { |
||||
|
||||
private final BladeLogger logger; |
||||
private final IOperMaintenancePlanService planService; |
||||
private final IOperMaintenanceTaskService taskService; |
||||
private final IFlowClient flowClient; |
||||
|
||||
@XxlJob(TASK_VALUE_MAINTENANCE_TASK_CREATE) |
||||
public ReturnT<String> execute(String param) throws Exception { |
||||
Date startDate = StringUtil.isNotBlank(param) ? DateUtil.parse(param, DateUtil.PATTERN_DATE) : DateUtil.parse(DateUtil.formatDate(DateUtil.now()), DateUtil.PATTERN_DATE); |
||||
Date endDate = DateUtil.parse(DateUtil.formatDate(DateUtil.plusDays(startDate, 1)), DateUtil.PATTERN_DATE); |
||||
LambdaQueryWrapper<OperMaintenancePlanEntity> planQW = Wrappers.<OperMaintenancePlanEntity>lambdaQuery().isNull(OperMaintenancePlanEntity::getCreateTaskTime) |
||||
.gt(OperMaintenancePlanEntity::getDisposeTime, startDate).le(OperMaintenancePlanEntity::getDisposeTime, endDate); |
||||
List<OperMaintenancePlanEntity> planList = planService.list(planQW); |
||||
XxlJobLogger.log("日常维护任务生成开始!计划ID为:"+planList.stream().map(OperMaintenancePlanEntity::getId).map(String::valueOf).collect(Collectors.joining(","))); |
||||
//分页插入日常维护计划
|
||||
planList.forEach(this::generateTaskByPlan); |
||||
XxlJobLogger.log("日常维护任务生成完成!"); |
||||
return new ReturnT<>("SUCCESS"); |
||||
} |
||||
|
||||
/** |
||||
* 根据日常维护计划生成日常维护任务 |
||||
* @param plan 日常维护计划 |
||||
*/ |
||||
private void generateTaskByPlan(OperMaintenancePlanEntity plan) { |
||||
try { |
||||
OperMaintenanceTaskEntity taskEntity = BeanUtil.copy(plan,OperMaintenanceTaskEntity.class); |
||||
taskEntity.setPlanId(plan.getId()); |
||||
taskEntity.setDisposer(Optional.ofNullable(plan.getDisposer()).map(String::valueOf).orElse(null)); |
||||
LocalDateTime disposeTime = taskEntity.getDisposeTime().toInstant() |
||||
.atZone(ZoneId.systemDefault()).toLocalDateTime(); |
||||
taskEntity.setPlanEndTime(disposeTime.plusHours(taskEntity.getHours())); |
||||
|
||||
|
||||
|
||||
if(StringUtil.isNotBlank(plan.getEmCode())){ |
||||
List<String> emCodeList = Arrays.asList(plan.getEmCode().split(",")); |
||||
for(String emCode : emCodeList){ |
||||
taskEntity.setEmCode(emCode); |
||||
this.createTask(taskEntity); |
||||
} |
||||
} |
||||
else { |
||||
this.createTask(taskEntity); |
||||
} |
||||
} |
||||
catch(Exception e) { |
||||
logger.error("MaintenanceTaskSchedule:generateTaskByPlan",e.getLocalizedMessage()); |
||||
XxlJobLogger.log(plan.getId()+"计划创建任务失败"); |
||||
// 查询到日常维护计划所创建的任务
|
||||
List<OperMaintenanceTaskEntity> maintenanceTasks = taskService.list(Wrappers.<OperMaintenanceTaskEntity>lambdaQuery().eq(OperMaintenanceTaskEntity::getPlanId, plan.getId())); |
||||
for (OperMaintenanceTaskEntity maintenanceTask : maintenanceTasks) { |
||||
if(Func.isNotEmpty(maintenanceTask.getProcessInstanceId())) { |
||||
flowClient.delProcessInstanceById(maintenanceTask.getProcessInstanceId(),"错误流程"); |
||||
taskService.removeById(maintenanceTask.getId()); |
||||
} |
||||
} |
||||
} |
||||
} |
||||
|
||||
/** |
||||
* 创建日常维护任务以及生成工作流 |
||||
* @param task 日常维护任务 |
||||
*/ |
||||
private void createTask(OperMaintenanceTaskEntity task) { |
||||
task.setId(null); |
||||
task.setCreateTime(new Date()); |
||||
task.setUpdateTime(new Date()); |
||||
task.setTaskCode(UUID.randomUUID().toString()); |
||||
// if (ObjectUtil.isNotEmpty(task.getMaintenanceModel()) && finalPlanEntity.getMaintenanceModel() == 2) {
|
||||
// //查询值班信息
|
||||
// LambdaQueryWrapper<ImsDutyMainEntity> entityLambdaQueryWrapper = new LambdaQueryWrapper<>();
|
||||
// entityLambdaQueryWrapper.eq(ImsDutyMainEntity::getDutyDate, DateTimeFormatter.ofPattern(PATTERN_DATE).format(disposeTime));
|
||||
// entityLambdaQueryWrapper.eq(ImsDutyMainEntity::getClassId, finalPlanEntity.getImsDutyClassId());
|
||||
// ImsDutyMainEntity entity = mainService.getOne(entityLambdaQueryWrapper);
|
||||
// if (ObjectUtil.isNotEmpty(entity) && StringUtils.isNotEmpty(entity.getDutyPersonIds())) {
|
||||
// String userId = entity.getDutyPersonIds();
|
||||
// taskEntity.setDisposer(userId.replaceAll("\\^", ","));
|
||||
// } else {
|
||||
// log.info("计划ID为:{}未查询到排班记录", finalPlanEntity.getId());
|
||||
// LambdaUpdateWrapper<OperMaintenancePlanEntity> planQueryWrapper = Wrappers.<OperMaintenancePlanEntity>lambdaUpdate()
|
||||
// .set(OperMaintenancePlanEntity::getCreateTaskTime, new Date())
|
||||
// .eq(OperMaintenancePlanEntity::getId, finalPlanEntity.getId());
|
||||
// maintenancePlanService.update(planQueryWrapper);
|
||||
// return;
|
||||
// }
|
||||
// }
|
||||
} |
||||
|
||||
} |
Binary file not shown.
Loading…
Reference in new issue