初始化

master
WeiRan 2024-09-21 12:43:38 +08:00
parent fac31cb7a8
commit 19ca5b409f
60 changed files with 3015 additions and 0 deletions

38
cloud-faultmanage/.gitignore vendored 100644
View File

@ -0,0 +1,38 @@
target/
!.mvn/wrapper/maven-wrapper.jar
!**/src/main/**/target/
!**/src/test/**/target/
### IntelliJ IDEA ###
.idea/modules.xml
.idea/jarRepositories.xml
.idea/compiler.xml
.idea/libraries/
*.iws
*.iml
*.ipr
### Eclipse ###
.apt_generated
.classpath
.factorypath
.project
.settings
.springBeans
.sts4-cache
### NetBeans ###
/nbproject/private/
/nbbuild/
/dist/
/nbdist/
/.nb-gradle/
build/
!**/src/main/**/build/
!**/src/test/**/build/
### VS Code ###
.vscode/
### Mac OS ###
.DS_Store

View File

@ -0,0 +1,38 @@
target/
!.mvn/wrapper/maven-wrapper.jar
!**/src/main/**/target/
!**/src/test/**/target/
### IntelliJ IDEA ###
.idea/modules.xml
.idea/jarRepositories.xml
.idea/compiler.xml
.idea/libraries/
*.iws
*.iml
*.ipr
### Eclipse ###
.apt_generated
.classpath
.factorypath
.project
.settings
.springBeans
.sts4-cache
### NetBeans ###
/nbproject/private/
/nbbuild/
/dist/
/nbdist/
/.nb-gradle/
build/
!**/src/main/**/build/
!**/src/test/**/build/
### VS Code ###
.vscode/
### Mac OS ###
.DS_Store

View File

@ -0,0 +1,20 @@
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>com.muyu</groupId>
<artifactId>cloud-faultmanage</artifactId>
<version>3.6.3</version>
</parent>
<artifactId>cloud-faultmanage-client</artifactId>
<properties>
<maven.compiler.source>17</maven.compiler.source>
<maven.compiler.target>17</maven.compiler.target>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
</project>

View File

@ -0,0 +1,14 @@
package com.muyu;
/**
* @Authorweiran
* @Packagecom.muyu
* @ProjectDefault (Template) Project
* @name${NAME}
* @Date2024/9/17 23:27
*/
public class Main {
public static void main(String[] args) {
System.out.println("Hello world!");
}
}

View File

@ -0,0 +1,38 @@
target/
!.mvn/wrapper/maven-wrapper.jar
!**/src/main/**/target/
!**/src/test/**/target/
### IntelliJ IDEA ###
.idea/modules.xml
.idea/jarRepositories.xml
.idea/compiler.xml
.idea/libraries/
*.iws
*.iml
*.ipr
### Eclipse ###
.apt_generated
.classpath
.factorypath
.project
.settings
.springBeans
.sts4-cache
### NetBeans ###
/nbproject/private/
/nbbuild/
/dist/
/nbdist/
/.nb-gradle/
build/
!**/src/main/**/build/
!**/src/test/**/build/
### VS Code ###
.vscode/
### Mac OS ###
.DS_Store

View File

@ -0,0 +1,32 @@
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>com.muyu</groupId>
<artifactId>cloud-faultmanage</artifactId>
<version>3.6.3</version>
</parent>
<artifactId>cloud-faultmanage-common</artifactId>
<properties>
<maven.compiler.source>17</maven.compiler.source>
<maven.compiler.target>17</maven.compiler.target>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
<dependencies>
<dependency>
<groupId>com.muyu</groupId>
<artifactId>cloud-common-core</artifactId>
</dependency>
<dependency>
<groupId>io.swagger.core.v3</groupId>
<artifactId>swagger-annotations-jakarta</artifactId>
<version>2.2.8</version>
</dependency>
</dependencies>
</project>

View File

@ -0,0 +1,214 @@
package com.muyu.cloud.faultmanage.domain;
/**
* @Authorweiran
* @Packagecom.muyu.cloud.faultmanage.domain.faultrule
* @Projectcloud-server-8
* @namePureElectricCar
* @Date2024/9/20 20:22
*/
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.experimental.SuperBuilder;
@Data
@AllArgsConstructor
@NoArgsConstructor
@SuperBuilder
public class CarFaultRule {
/**
* VINVINVIN
*/
private String vin;
/**
*
*/
private long timestamp;
/**
*
*/
private double longitude;
/**
*
*/
private double latitude;
/**
*
*/
private double speed;
/**
*
*/
private long TM;
/**
*
*/
private double TV;
/**
*
*/
private double CC;
/**
*
*/
private double IR;
/**
*
*/
private String GP;
/**
*
*/
private double APTV;
/**
*
*/
private double BPTV;
/**
*
*/
private double SFC;
/**
*
*/
private double MCT;
/**
*
*/
private int MS;
/**
*
*/
private double MTO;
/**
*
*/
private double MTE;
/**
*
*/
private double MV;
/**
*
*/
private double MC;
/**
* SOCSOCSOC
*/
private double PBRSOC;
/**
*
*/
private double MACSFP;
/**
*
*/
private double CSATMDP;
/**
* BMSBMSBMS
*/
private int BMS;
/**
*
*/
private double CADC;
/**
* V3V3V3
*/
private double PBLETVV3;
/**
*
*/
private double SMV;
/**
*
*/
private double MVOAB;
/**
*
*/
private double MAXBT;
/**
*
*/
private double MINBT;
/**
*
*/
private double PBAC;
/**
*
*/
private String VS;
/**
*
*/
private String CS;
/**
*
*/
private String RS;
/**
* SOCSOCSOC
*/
private double SOC;
/**
*
*/
private String RESDWC;
/**
* EASEASEAS
*/
private String EAS;
/**
* PTCPTCPTC
*/
private String PTC;
/**
* EPSEPSEPS
*/
private String EPS;
/**
* ABSABSABS
*/
private String ABS;
/**
* MCUMCUMCU
*/
private String MCU;
/**
*
*/
private String PBHS;
/**
*
*/
private String PBCS;
/**
*
*/
private String PBIS;
/**
* DCDCDCDCDCDC
*/
private String DCDC;
/**
* CHGCHGCHG
*/
private String CHG;
/**
*
*/
private byte CHB;
/**
*
*/
private byte CUB;
}

View File

@ -0,0 +1,81 @@
package com.muyu.cloud.faultmanage.domain;
import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import com.muyu.cloud.faultmanage.domain.req.FaultCodeAddReq;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.experimental.SuperBuilder;
/**
* @Authorweiran
* @Packagecom.muyu.cloud.faultmanage.domain
* @Projectcloud-faultmanage
* @nameFaultCode
* @Date2024/9/17 14:55
*/
/**
*
*/
@Data
@AllArgsConstructor
@NoArgsConstructor
@SuperBuilder
@TableName(value = "car_faultcode",autoResultMap = true)
public class FaultCode {
/**
*Id
*/
@TableId(value = "faultcode_id",type = IdType.AUTO)
private long faultcodeId;
/**
*Id
*/
private long faultlabelId;
/**
*
*/
private String faultcodeNumber;
/**
*
*/
private String faultGroup;
/**
*
*/
private String faultBit;
/**
*
*/
private String faultValue;
/**
*
*/
private Integer isWarning;
public static FaultCode addfaultcode(FaultCodeAddReq faultCodeAddReq){
return FaultCode.builder()
.faultcodeId(0)
.faultlabelId(faultCodeAddReq.getFaultlabelId())
.faultcodeNumber(faultCodeAddReq.getFaultcodeNumber())
.faultGroup(faultCodeAddReq.getFaultGroup())
.faultBit(faultCodeAddReq.getFaultBit())
.faultValue(faultCodeAddReq.getFaultValue())
.isWarning(faultCodeAddReq.getIsWarning())
.build();
}
}

View File

@ -0,0 +1,49 @@
package com.muyu.cloud.faultmanage.domain;
import com.baomidou.mybatisplus.annotation.TableName;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.experimental.SuperBuilder;
/**
* @Authorweiran
* @Packagecom.muyu.cloud.faultmanage.domain
* @Projectcloud-faultmanage
* @nameFaultLabel
* @Date2024/9/17 15:06
*/
/**
*
*/
@Data
@AllArgsConstructor
@NoArgsConstructor
@SuperBuilder
@TableName(value = "car_fault_label",autoResultMap = true)
public class FaultLabel {
/**
*Id
*/
private long faultlabelId;
/**
*
*/
private String faultlabelName;
/**
*Id
*/
private long faulttypeId;
/**
*
*/
private Integer faultStatus;
/**
*
*/
private String faultContent;
}

View File

@ -0,0 +1,71 @@
package com.muyu.cloud.faultmanage.domain;
import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import com.fasterxml.jackson.annotation.JsonFormat;
import io.swagger.v3.oas.annotations.media.Schema;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.experimental.SuperBuilder;
import java.util.Date;
/**
* @Authorweiran
* @Packagecom.muyu.cloud.faultmanage.domain
* @Projectcloud-server-8
* @nameFaultLog
* @Date2024/9/19 0:42
*/
@Data
@AllArgsConstructor
@NoArgsConstructor
@SuperBuilder
@TableName(value = "car_fault_log",autoResultMap = true)
public class FaultLog {
/**
* Id
*/
@TableId(value = "log_id",type = IdType.AUTO)
private long logId;
/**
* Id
*/
private long faultcodeId;
/**
* Id
*/
private long carInformationId;
/**
* VIN
*/
private String carVin;
/**
*
*/
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
@Schema(description = "开始报警时间",defaultValue = "2024-8-9 10:47:57",type = "Date")
private Date startwarningTime;
/**
*
*/
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
@Schema(description = "结束报警时间",defaultValue = "2024-8-9 10:47:57",type = "Date")
private Date endwarningTime;
/**
*
*/
private String faultcodeNumber;
/**
* vin
*/
private String carInformationVIN;
}

View File

@ -0,0 +1,26 @@
package com.muyu.cloud.faultmanage.domain;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.experimental.SuperBuilder;
import java.util.Date;
/**
* @Authorweiran
* @Packagecom.muyu.cloud.faultmanage.domain
* @Projectcloud-server-8
* @nameFaultReport
* @Date2024/9/20 20:36
*/
@Data
@AllArgsConstructor
@NoArgsConstructor
@SuperBuilder
public class FaultReport {
private String VehicleType;
private String FaultDescription;
}

View File

@ -0,0 +1,66 @@
package com.muyu.cloud.faultmanage.domain;
import com.baomidou.mybatisplus.annotation.TableName;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.experimental.SuperBuilder;
import java.math.BigDecimal;
/**
* @Authorweiran
* @Packagecom.muyu.cloud.faultmanage.domain
* @Projectcloud-server-8
* @nameFaultRule
* @Date2024/9/19 22:11
*/
@Data
@AllArgsConstructor
@NoArgsConstructor
@SuperBuilder
@TableName(value = "car_fault_condition",autoResultMap = true)
public class FaultRule {
/**
* Id
*/
private long conditionId;
/**
* Id
*/
private long faultcodeId;
/**
*
*/
private String conditionContent;
/**
*
*/
private BigDecimal singleThreshold;
/**
*
*/
private BigDecimal minThreshold;
/**
*
*/
private BigDecimal maxThreshold;
/**
*
*/
private Integer isActive;
/**
*
*/
private BigDecimal Threshold;
}

View File

@ -0,0 +1,36 @@
package com.muyu.cloud.faultmanage.domain;
import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.experimental.SuperBuilder;
/**
* @Authorweiran
* @Packagecom.muyu.cloud.faultmanage.domain
* @Projectcloud-faultmanage
* @nameFaultType
* @Date2024/9/17 15:03
*/
/**
*
*/
@Data
@AllArgsConstructor
@NoArgsConstructor
@SuperBuilder
@TableName(value = "car_fault_type",autoResultMap = true)
public class FaultType {
/**
*Id
*/
@TableId(value = "faulttype_id",type = IdType.AUTO)
private long faulttypeId;
/**
*
*/
private String faulttypeName;
}

View File

@ -0,0 +1,26 @@
package com.muyu.cloud.faultmanage.domain;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.experimental.SuperBuilder;
/**
* @Authorweiran
* @Packagecom.muyu.cloud.faultmanage.domain
* @Projectcloud-server-8
* @nameVehicle
* @Date2024/9/20 20:44
*/
@Data
@AllArgsConstructor
@NoArgsConstructor
@SuperBuilder
public class Vehicle {
private String type; // 可以是枚举或字符串
// 其他车辆相关的字段和方法
// getter 和 setter 省略
}

View File

@ -0,0 +1,61 @@
package com.muyu.cloud.faultmanage.domain.req;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.experimental.SuperBuilder;
/**
* @Authorweiran
* @Packagecom.muyu.cloud.faultmanage.domain.req
* @Projectcloud-server-8
* @nameFaultCodeAddReq
* @Date2024/9/18 10:12
*/
@Data
@AllArgsConstructor
@NoArgsConstructor
@Builder
public class FaultCodeAddReq {
/**
* Id
*/
private long faultlabelId;
/**
*
*/
private String faultlabelName;
/**
*
*/
private String faultcodeNumber;
/**
* Id
*/
private long faulttypeId;
/**
*
*/
private Integer isWarning;
/**
*
*/
private String faultContent;
/**
*
*/
private String faultGroup;
/**
*
*/
private String faultBit;
/**
*
*/
private String faultValue;
}

View File

@ -0,0 +1,41 @@
package com.muyu.cloud.faultmanage.domain.req;
import io.swagger.v3.oas.annotations.tags.Tag;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;
/**
* @Authorweiran
* @Packagecom.muyu.cloud.faultmanage.domain.req
* @Projectcloud-faultmanage
* @nameFaultCodeListReq
* @Date2024/9/17 15:55
*/
@Tag(name = "故障码列表请求对象")
@Data
@AllArgsConstructor
@NoArgsConstructor
@Builder
public class FaultCodeListReq {
/**
*
*/
private String faultcodeNumber;
/**
*
*/
private String faultBit;
/**
* 1
*/
private Integer pageNum=1;
/**
*
*/
private Integer pageSize=10;
}

View File

@ -0,0 +1,71 @@
package com.muyu.cloud.faultmanage.domain.req;
import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableId;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;
/**
* @Authorweiran
* @Packagecom.muyu.cloud.faultmanage.domain.req
* @Projectcloud-server-8
* @nameFaultCodeAddReq
* @Date2024/9/18 10:12
*/
@Data
@AllArgsConstructor
@NoArgsConstructor
@Builder
public class FaultCodeUpdReq {
/**
*Id
*/
private long faultcodeId;
/**
* Id
*/
private long faultlabelId;
/**
*
*/
private String faultlabelName;
/**
*
*/
private String faultcodeNumber;
/**
* Id
*/
private long faulttypeId;
/**
*
*/
private Integer isWarning;
/**
*
*/
private String faultContent;
/**
*
*/
private Integer faultStatus;
/**
*
*/
private String faultGroup;
/**
*
*/
private String faultBit;
/**
*
*/
private String faultValue;
}

View File

@ -0,0 +1,57 @@
package com.muyu.cloud.faultmanage.domain.req;
import com.fasterxml.jackson.annotation.JsonFormat;
import io.swagger.v3.oas.annotations.media.Schema;
import io.swagger.v3.oas.annotations.tags.Tag;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;
import java.util.Date;
/**
* @Authorweiran
* @Packagecom.muyu.cloud.faultmanage.domain.req
* @Projectcloud-server-8
* @nameFaultLogReq
* @Date2024/9/20 9:38
*/
@Tag(name = "故障日志列表请求对象")
@Data
@AllArgsConstructor
@NoArgsConstructor
@Builder
public class FaultLogListReq {
/**
* Id
*/
private long faultcodeId;
/**
* VIN
*/
private String carVin;
/**
*
*/
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
@Schema(description = "开始报警时间",defaultValue = "2024-8-9 10:47:57",type = "Date")
private Date startwarningTime;
/**
*
*/
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
@Schema(description = "结束报警时间",defaultValue = "2024-8-9 10:47:57",type = "Date")
private Date endwarningTime;
/**
* 1
*/
private Integer pageNum=1;
/**
*
*/
private Integer pageSize=10;
}

View File

@ -0,0 +1,79 @@
package com.muyu.cloud.faultmanage.domain.resp;
import com.muyu.cloud.faultmanage.domain.vo.FaultCodeVO;
import io.swagger.v3.oas.annotations.tags.Tag;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
/**
* @Authorweiran
* @Packagecom.muyu.cloud.faultmanage.domain.resp
* @Projectcloud-faultmanage
* @nameFaultCodeListResp
* @Date2024/9/17 15:41
*/
@Data
@Builder
@AllArgsConstructor
@Tag(name="故障码信息响应对象",description = "故障码查询的响应结果")
public class FaultCodeListResp {
/**
*Id
*/
private long faultcodeId;
/**
*Id
*/
private long faultlabelId;
/**
*
*/
private String faultcodeNumber;
/**
*
*/
private String faultGroup;
/**
*
*/
private String faultBit;
/**
*
*/
private String faultValue;
/**
*
*/
private Integer isWarning;
/**
*
*/
private String faulttypeName;
/**
*
*/
private String faultlabelName;
/**
*
* @param faultCodeVO
* @return
*/
public static FaultCodeListResp faultCodeListResp(FaultCodeVO faultCodeVO){
return FaultCodeListResp.builder()
.faultcodeId(faultCodeVO.getFaultcodeId())
.faultlabelId(faultCodeVO.getFaultlabelId())
.faultcodeNumber(faultCodeVO.getFaultcodeNumber())
.faultGroup(faultCodeVO.getFaultGroup())
.faultBit(faultCodeVO.getFaultBit())
.faultValue(faultCodeVO.getFaultValue())
.isWarning(faultCodeVO.getIsWarning())
.faulttypeName(faultCodeVO.getFaulttypeName())
.faultlabelName(faultCodeVO.getFaultlabelName())
.build();
}
}

View File

@ -0,0 +1,39 @@
package com.muyu.cloud.faultmanage.domain.resp;
import io.swagger.v3.oas.annotations.tags.Tag;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.experimental.SuperBuilder;
import java.util.List;
/**
* @Authorweiran
* @Packagecom.muyu.cloud.faultmanage.domain.resp
* @Projectcloud-faultmanage
* @nameFaultCodeTotalListResp
* @Date2024/9/17 15:44
*/
@Data
@SuperBuilder
@AllArgsConstructor
@NoArgsConstructor
@Tag(name="数据总数列表",description = "数据和总数的响应")
public class FaultCodeTotalListResp {
private List<FaultCodeListResp> faultCodeListRespList;
private long total;
public static FaultCodeTotalListResp faultCodeTotalListResp(List<FaultCodeListResp> faultCodeListRespList,long total){
FaultCodeTotalListResp faultCodeTotalListResp = new FaultCodeTotalListResp();
faultCodeTotalListResp.setFaultCodeListRespList(faultCodeListRespList);
faultCodeTotalListResp.setTotal(total);
return faultCodeTotalListResp;
}
}

View File

@ -0,0 +1,82 @@
package com.muyu.cloud.faultmanage.domain.resp;
import com.fasterxml.jackson.annotation.JsonFormat;
import com.muyu.cloud.faultmanage.domain.FaultLog;
import io.swagger.v3.oas.annotations.media.Schema;
import io.swagger.v3.oas.annotations.tags.Tag;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import java.util.Date;
/**
* @Authorweiran
* @Packagecom.muyu.cloud.faultmanage.domain.resp
* @Projectcloud-server-8
* @nameFaultLogResp
* @Date2024/9/20 9:43
*/
@Data
@Builder
@AllArgsConstructor
@Tag(name="故障日志信息响应对象",description = "故障日志的响应结果")
public class FaultLogListResp {
/**
* Id
*/
private long logId;
/**
* Id
*/
private long faultcodeId;
/**
* Id
*/
private long carInformationId;
/**
* VIN
*/
private String carVin;
/**
*
*/
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
@Schema(description = "开始报警时间",defaultValue = "2024-8-9 10:47:57",type = "Date")
private Date startwarningTime;
/**
*
*/
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
@Schema(description = "结束报警时间",defaultValue = "2024-8-9 10:47:57",type = "Date")
private Date endwarningTime;
/**
*
*/
private String faultcodeNumber;
/**
* vin
*/
private String carInformationVIN;
/**
*
* @param faultLog
* @return
*/
public static FaultLogListResp faultLogListResp(FaultLog faultLog){
return FaultLogListResp.builder()
.logId(faultLog.getLogId())
.faultcodeId(faultLog.getFaultcodeId())
.carInformationId(faultLog.getCarInformationId())
.carVin(faultLog.getCarVin())
.startwarningTime(faultLog.getStartwarningTime())
.endwarningTime(faultLog.getEndwarningTime())
.faultcodeNumber(faultLog.getFaultcodeNumber())
.carInformationVIN(faultLog.getCarInformationVIN())
.build();
}
}

View File

@ -0,0 +1,36 @@
package com.muyu.cloud.faultmanage.domain.resp;
import io.swagger.v3.oas.annotations.tags.Tag;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.experimental.SuperBuilder;
import java.util.List;
/**
* @Authorweiran
* @Packagecom.muyu.cloud.faultmanage.domain.resp
* @Projectcloud-server-8
* @nameFaultLogTotalListResp
* @Date2024/9/20 11:18
*/
@Data
@SuperBuilder
@AllArgsConstructor
@NoArgsConstructor
@Tag(name="故障日志数据总数列表",description = "数据和总数的响应")
public class FaultLogTotalListResp {
private List<FaultLogListResp> faultLogListRespList;
private long total;
public static FaultLogTotalListResp faultLogTotalListResp(List<FaultLogListResp> faultLogListRespList,long total){
FaultLogTotalListResp faultLogTotalListResp = new FaultLogTotalListResp();
faultLogTotalListResp.setFaultLogListRespList(faultLogListRespList);
faultLogTotalListResp.setTotal(total);
return faultLogTotalListResp;
}
}

View File

@ -0,0 +1,33 @@
package com.muyu.cloud.faultmanage.domain.vo;
import com.muyu.cloud.faultmanage.domain.FaultCode;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.EqualsAndHashCode;
import lombok.NoArgsConstructor;
import lombok.experimental.SuperBuilder;
/**
* @Authorweiran
* @Packagecom.muyu.cloud.faultmanage.domain.vo
* @Projectcloud-faultmanage
* @nameFaultCodeVO
* @Date2024/9/17 15:14
*/
@EqualsAndHashCode(callSuper = true)
@Data
@AllArgsConstructor
@NoArgsConstructor
@SuperBuilder
public class FaultCodeVO extends FaultCode {
/**
*
*/
private String faulttypeName;
/**
*
*/
private String faultlabelName;
}

View File

@ -0,0 +1,38 @@
target/
!.mvn/wrapper/maven-wrapper.jar
!**/src/main/**/target/
!**/src/test/**/target/
### IntelliJ IDEA ###
.idea/modules.xml
.idea/jarRepositories.xml
.idea/compiler.xml
.idea/libraries/
*.iws
*.iml
*.ipr
### Eclipse ###
.apt_generated
.classpath
.factorypath
.project
.settings
.springBeans
.sts4-cache
### NetBeans ###
/nbproject/private/
/nbbuild/
/dist/
/nbdist/
/.nb-gradle/
build/
!**/src/main/**/build/
!**/src/test/**/build/
### VS Code ###
.vscode/
### Mac OS ###
.DS_Store

View File

@ -0,0 +1,20 @@
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>com.muyu</groupId>
<artifactId>cloud-faultmanage</artifactId>
<version>3.6.3</version>
</parent>
<artifactId>cloud-faultmanage-remote</artifactId>
<properties>
<maven.compiler.source>17</maven.compiler.source>
<maven.compiler.target>17</maven.compiler.target>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
</project>

View File

@ -0,0 +1,14 @@
package com.muyu;
/**
* @Authorweiran
* @Packagecom.muyu
* @ProjectDefault (Template) Project
* @name${NAME}
* @Date2024/9/17 23:28
*/
public class Main {
public static void main(String[] args) {
System.out.println("Hello world!");
}
}

View File

@ -0,0 +1,38 @@
target/
!.mvn/wrapper/maven-wrapper.jar
!**/src/main/**/target/
!**/src/test/**/target/
### IntelliJ IDEA ###
.idea/modules.xml
.idea/jarRepositories.xml
.idea/compiler.xml
.idea/libraries/
*.iws
*.iml
*.ipr
### Eclipse ###
.apt_generated
.classpath
.factorypath
.project
.settings
.springBeans
.sts4-cache
### NetBeans ###
/nbproject/private/
/nbbuild/
/dist/
/nbdist/
/.nb-gradle/
build/
!**/src/main/**/build/
!**/src/test/**/build/
### VS Code ###
.vscode/
### Mac OS ###
.DS_Store

View File

@ -0,0 +1,159 @@
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>com.muyu</groupId>
<artifactId>cloud-faultmanage</artifactId>
<version>3.6.3</version>
</parent>
<artifactId>cloud-faultmanage-server</artifactId>
<properties>
<maven.compiler.source>17</maven.compiler.source>
<maven.compiler.target>17</maven.compiler.target>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
<dependencies>
<dependency>
<groupId>com.muyu</groupId>
<artifactId>cloud-faultmanage-common</artifactId>
<version>3.6.3</version>
</dependency>
<!-- 图片上传 -->
<dependency>
<groupId>com.aliyun.oss</groupId>
<artifactId>aliyun-sdk-oss</artifactId>
<version>3.16.3</version>
</dependency>
<!-- 邮箱依赖 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-mail</artifactId>
</dependency>
<!-- SpringCloud Alibaba Nacos -->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
<!-- SpringCloud Alibaba Nacos Config -->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>
<!-- SpringCloud Alibaba Sentinel -->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-sentinel</artifactId>
</dependency>
<!-- SpringBoot Actuator -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
<!-- Mysql Connector -->
<dependency>
<groupId>com.mysql</groupId>
<artifactId>mysql-connector-j</artifactId>
</dependency>
<!-- MuYu Common DataSource -->
<dependency>
<groupId>com.muyu</groupId>
<artifactId>cloud-common-datasource</artifactId>
</dependency>
<!-- MuYu Common DataScope -->
<dependency>
<groupId>com.muyu</groupId>
<artifactId>cloud-common-datascope</artifactId>
</dependency>
<!-- 接口模块 -->
<dependency>
<groupId>com.muyu</groupId>
<artifactId>cloud-common-api-doc</artifactId>
</dependency>
<!-- XllJob定时任务 -->
<dependency>
<groupId>com.muyu</groupId>
<artifactId>cloud-common-xxl</artifactId>
</dependency>
<!--rqbbit公共依赖-->
<dependency>
<groupId>com.muyu</groupId>
<artifactId>cloud-common-rabbit</artifactId>
</dependency>
<!-- 文件上传 -->
<dependency>
<groupId>org.apache.httpcomponents</groupId>
<artifactId>httpmime</artifactId>
<version>4.5.14</version>
</dependency>
<!-- JSON -->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
<version>1.2.41</version>
</dependency>
</dependencies>
<build>
<finalName>cloud-faultmanage</finalName>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<executions>
<execution>
<goals>
<goal>repackage</goal>
</goals>
</execution>
</executions>
</plugin>
<!-- 加入maven deploy插件当在deploy时忽略些model-->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-deploy-plugin</artifactId>
<configuration>
<skip>true</skip>
</configuration>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.13.0</version> <!-- 使用适合你的项目的版本 -->
<configuration>
<compilerArgs>
<arg>-parameters</arg>
</compilerArgs>
</configuration>
</plugin>
</plugins>
</build>
</project>

View File

@ -0,0 +1,18 @@
package com.muyu.cloud.faultmanage;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
/**
* @Authorweiran
* @Packagecom.muyu.cloud.faultmanage
* @Projectcloud-faultmanage
* @nameMuYuFaultManageApplication
* @Date2024/9/16 21:16
*/
@SpringBootApplication
public class MuYuFaultManageApplication {
public static void main(String[] args) {
SpringApplication.run(MuYuFaultManageApplication.class, args);
}
}

View File

@ -0,0 +1,94 @@
package com.muyu.cloud.faultmanage.controller;
import com.muyu.cloud.faultmanage.domain.req.FaultCodeAddReq;
import com.muyu.cloud.faultmanage.domain.req.FaultCodeListReq;
import com.muyu.cloud.faultmanage.domain.req.FaultCodeUpdReq;
import com.muyu.cloud.faultmanage.domain.resp.FaultCodeTotalListResp;
import com.muyu.cloud.faultmanage.service.FaultCodeService;
import com.muyu.common.core.domain.Result;
import io.swagger.v3.oas.annotations.Operation;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.*;
/**
* @Authorweiran
* @Packagecom.muyu.cloud.faultmanage.controller
* @Projectcloud-faultmanage
* @nameFaultCodeController
* @Date2024/9/17 14:51
*/
/**
*
*/
@RestController
@RequestMapping("/faultcode")
public class FaultCodeController {
@Autowired
private FaultCodeService faultCodeService;
/**
* ()
* @param faultCodeListReq
* @return
*/
@PostMapping(path = "/list")
@Operation(summary = "故障码列表(单)",description = "展示故障码信息")
public Result<FaultCodeTotalListResp> selectlist(@Validated @RequestBody FaultCodeListReq faultCodeListReq){
return Result.success(faultCodeService.selectlist(faultCodeListReq));
}
/**
* ()
* @param faultCodeListReq
* @return
*/
@PostMapping("/faultcodelist")
@Operation(summary = "故障码列表(多)",description = "展示故障码信息")
public Result<FaultCodeTotalListResp> selectfaultcodelist(@Validated @RequestBody FaultCodeListReq faultCodeListReq){
return Result.success(faultCodeService.selectfaultcodelist(faultCodeListReq));
}
/**
*
* @param faultCodeAddReq
* @return
*/
@PostMapping("/faultcodeadd")
@Operation(summary = "新增故障码",description = "新增故障码信息")
public Result insertfaultcode(@Validated @RequestBody FaultCodeAddReq faultCodeAddReq){
faultCodeService.insert(faultCodeAddReq);
return Result.success(null,"新增成功");
}
/**
*
* @param faultCodeUpdReq
* @return
*/
@PostMapping("/faultcodeupd")
@Operation(summary = "修改故障码",description = "修改故障码信息")
public Result updfaultcode(@Validated @RequestBody FaultCodeUpdReq faultCodeUpdReq){
faultCodeService.upd(faultCodeUpdReq);
return Result.success(null,"修改成功");
}
/**
*
* @param faultcodeId
* @return
*/
@PostMapping("/faultcodedel/{faultcodeId}")
@Operation(summary = "删除故障码",description = "删除故障码信息")
public Result delfaultcode(@PathVariable("faultcodeId") Integer faultcodeId){
faultCodeService.del(faultcodeId);
return Result.success(null,"删除成功");
}
}

View File

@ -0,0 +1,40 @@
package com.muyu.cloud.faultmanage.controller;
/**
* @Authorweiran
* @Packagecom.muyu.cloud.faultmanage.controller
* @Projectcloud-server-8
* @nameFaultTypeController
* @Date2024/9/18 20:58
*/
import com.muyu.cloud.faultmanage.service.FaultLabelService;
import com.muyu.cloud.faultmanage.service.FaultTypeService;
import com.muyu.common.core.domain.Result;
import io.swagger.v3.oas.annotations.Operation;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
/**
*
*/
@RestController
@RequestMapping("/faultlabel")
public class FaultLabelController {
@Autowired
private FaultLabelService faultLabelService;
/**
*
* @return
*/
@PostMapping("/list")
@Operation(summary = "故障名称查询",description = "故障名称信息")
public Result findfaulttype(){
return Result.success(faultLabelService.select());
}
}

View File

@ -0,0 +1,39 @@
package com.muyu.cloud.faultmanage.controller;
import com.muyu.cloud.faultmanage.domain.FaultLog;
import com.muyu.cloud.faultmanage.domain.req.FaultLogListReq;
import com.muyu.cloud.faultmanage.service.FaultLogService;
import com.muyu.common.core.domain.Result;
import io.swagger.v3.oas.annotations.Operation;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
/**
* @Authorweiran
* @Packagecom.muyu.cloud.faultmanage.controller
* @Projectcloud-server-8
* @nameFaultLogController
* @Date2024/9/20 9:30
*/
@RestController
@RequestMapping("/faultlog")
public class FaultLogController {
@Autowired
private FaultLogService faultLogService;
/**
*
* @param faultLogListReq
* @return
*/
@PostMapping("/list")
@Operation(summary = "故障日志列表",description = "故障日志列表展示")
public Result selectfaultlog(@Validated @RequestBody FaultLogListReq faultLogListReq){
return Result.success(faultLogService.selectfaultlog(faultLogListReq));
}
}

View File

@ -0,0 +1,42 @@
package com.muyu.cloud.faultmanage.controller;
import com.muyu.cloud.faultmanage.domain.FaultRule;
import com.muyu.cloud.faultmanage.service.FaultRuleService;
import com.muyu.common.core.domain.Result;
import io.swagger.v3.oas.annotations.Operation;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
/**
* @Authorweiran
* @Packagecom.muyu.cloud.faultmanage.controller
* @Projectcloud-server-8
* @nameFaultRuleController
* @Date2024/9/19 22:10
*/
/**
*
*/
@RestController
@RequestMapping("/faultrule")
public class FaultRuleController {
@Autowired
private FaultRuleService faultRuleService;
/**
*
* @return
*/
@PostMapping("/check-faults")
@Operation(summary = "检查故障",description = "进行故障检查")
public Result checkfaults(@Validated FaultRule faultRule){
String checkfaults = faultRuleService.checkfaults(faultRule);
return Result.success(checkfaults);
}
}

View File

@ -0,0 +1,39 @@
package com.muyu.cloud.faultmanage.controller;
/**
* @Authorweiran
* @Packagecom.muyu.cloud.faultmanage.controller
* @Projectcloud-server-8
* @nameFaultTypeController
* @Date2024/9/18 20:58
*/
import com.muyu.cloud.faultmanage.service.FaultTypeService;
import com.muyu.common.core.domain.Result;
import io.swagger.v3.oas.annotations.Operation;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
/**
*
*/
@RestController
@RequestMapping("/faulttype")
public class FaultTypeController {
@Autowired
private FaultTypeService faultTypeService;
/**
*
* @return
*/
@PostMapping("/list")
@Operation(summary = "故障码分类查询",description = "故障码分类信息")
public Result findfaulttype(){
return Result.success(faultTypeService.select());
}
}

View File

@ -0,0 +1,44 @@
package com.muyu.cloud.faultmanage.mapper;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.muyu.cloud.faultmanage.domain.FaultCode;
import com.muyu.cloud.faultmanage.domain.FaultLabel;
import com.muyu.cloud.faultmanage.domain.req.FaultCodeAddReq;
import com.muyu.cloud.faultmanage.domain.req.FaultCodeListReq;
import com.muyu.cloud.faultmanage.domain.req.FaultCodeUpdReq;
import com.muyu.cloud.faultmanage.domain.vo.FaultCodeVO;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import java.util.List;
/**
* @Authorweiran
* @Packagecom.muyu.cloud.faultmanage.mapper
* @Projectcloud-faultmanage
* @nameFaultCodeMapper
* @Date2024/9/17 14:52
*/
@Mapper
public interface FaultCodeMapper extends BaseMapper<FaultCodeVO> {
List<FaultCodeVO> selectfaultcodelist(FaultCodeListReq faultCodeListReq);
//新增故障码
FaultLabel selectfaultName(@Param("faultlabelName") String faultlabelName);
FaultCode selectfaultCode(@Param("faultcodeNumber") String faultcodeNumber);
Integer insertfaultlabel(FaultCodeAddReq faultCodeAddReq);
Integer insertfaultcode(FaultCodeAddReq faultCodeAddReq);
//修改故障码
Integer updfaultlabel(FaultCodeUpdReq faultCodeUpdReq);
Integer updfaultcode(FaultCodeUpdReq faultCodeUpdReq);
//删除故障码
FaultCode findByfaultcodeId(@Param("faultcodeId") Integer faultcodeId);
Integer delfaultcode(@Param("faultcodeId") Integer faultcodeId);
Integer delfaultlabel(@Param("faultlabelId") long faultlabelId);
}

View File

@ -0,0 +1,17 @@
package com.muyu.cloud.faultmanage.mapper;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.muyu.cloud.faultmanage.domain.FaultLabel;
import com.muyu.cloud.faultmanage.domain.FaultType;
import org.apache.ibatis.annotations.Mapper;
/**
* @Authorweiran
* @Packagecom.muyu.cloud.faultmanage.mapper
* @Projectcloud-server-8
* @nameFaultTypeMapper
* @Date2024/9/18 20:59
*/
@Mapper
public interface FaultLabelMapper extends BaseMapper<FaultLabel> {
}

View File

@ -0,0 +1,24 @@
package com.muyu.cloud.faultmanage.mapper;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.muyu.cloud.faultmanage.domain.FaultLog;
import com.muyu.cloud.faultmanage.domain.req.FaultLogListReq;
import com.muyu.cloud.faultmanage.domain.resp.FaultLogListResp;
import org.apache.ibatis.annotations.Mapper;
import java.util.List;
/**
* @Authorweiran
* @Packagecom.muyu.cloud.faultmanage.mapper
* @Projectcloud-server-8
* @nameFaultLogMapper
* @Date2024/9/20 9:33
*/
@Mapper
public interface FaultLogMapper extends BaseMapper<FaultLog> {
List<FaultLog> selectfaultLogMapper(FaultLogListReq faultLogListReq);
}

View File

@ -0,0 +1,16 @@
package com.muyu.cloud.faultmanage.mapper;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.muyu.cloud.faultmanage.domain.FaultRule;
import org.apache.ibatis.annotations.Mapper;
/**
* @Authorweiran
* @Packagecom.muyu.cloud.faultmanage.mapper
* @Projectcloud-server-8
* @nameFaultRuleMapper
* @Date2024/9/19 22:11
*/
@Mapper
public interface FaultRuleMapper extends BaseMapper<FaultRule> {
}

View File

@ -0,0 +1,16 @@
package com.muyu.cloud.faultmanage.mapper;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.muyu.cloud.faultmanage.domain.FaultType;
import org.apache.ibatis.annotations.Mapper;
/**
* @Authorweiran
* @Packagecom.muyu.cloud.faultmanage.mapper
* @Projectcloud-server-8
* @nameFaultTypeMapper
* @Date2024/9/18 20:59
*/
@Mapper
public interface FaultTypeMapper extends BaseMapper<FaultType> {
}

View File

@ -0,0 +1,57 @@
package com.muyu.cloud.faultmanage.service;
import com.baomidou.mybatisplus.extension.service.IService;
import com.muyu.cloud.faultmanage.domain.req.FaultCodeAddReq;
import com.muyu.cloud.faultmanage.domain.req.FaultCodeListReq;
import com.muyu.cloud.faultmanage.domain.req.FaultCodeUpdReq;
import com.muyu.cloud.faultmanage.domain.resp.FaultCodeTotalListResp;
import com.muyu.cloud.faultmanage.domain.vo.FaultCodeVO;
/**
* @Authorweiran
* @Packagecom.muyu.cloud.faultmanage.service
* @Projectcloud-faultmanage
* @nameFaultCodeService
* @Date2024/9/17 14:53
*/
public interface FaultCodeService extends IService<FaultCodeVO> {
/**
*
* @param faultCodeListReq
* @return
*/
FaultCodeTotalListResp selectlist(FaultCodeListReq faultCodeListReq);
/**
* ()
* @param faultCodeListReq
* @return
*/
FaultCodeTotalListResp selectfaultcodelist(FaultCodeListReq faultCodeListReq);
/**
*
* @param faultCodeAddReq
* @return
*/
void insert(FaultCodeAddReq faultCodeAddReq);
/**
*
* @param faultCodeUpdReq
* @return
*/
void upd(FaultCodeUpdReq faultCodeUpdReq);
/**
*
* @param faultcodeId
* @return
*/
void del(Integer faultcodeId);
}

View File

@ -0,0 +1,22 @@
package com.muyu.cloud.faultmanage.service;
/**
* @Authorweiran
* @Packagecom.muyu.cloud.faultmanage.service
* @Projectcloud-server-8
* @nameFaultDetectionStrategy
* @Date2024/9/20 19:40
*/
import com.muyu.cloud.faultmanage.domain.CarFaultRule;
import com.muyu.cloud.faultmanage.domain.FaultReport;
import com.muyu.cloud.faultmanage.domain.Vehicle;
/**
*
*/
public interface FaultDetectionStrategy {
FaultReport detectFaults(CarFaultRule carFaultRule);
}

View File

@ -0,0 +1,23 @@
package com.muyu.cloud.faultmanage.service;
import com.baomidou.mybatisplus.extension.service.IService;
import com.muyu.cloud.faultmanage.domain.FaultLabel;
import com.muyu.cloud.faultmanage.domain.FaultType;
import java.util.List;
/**
* @Authorweiran
* @Packagecom.muyu.cloud.faultmanage.service
* @Projectcloud-server-8
* @nameFaultTypeService
* @Date2024/9/18 20:59
*/
public interface FaultLabelService extends IService<FaultLabel> {
/**
*
* @return
*/
List<FaultLabel> select();
}

View File

@ -0,0 +1,26 @@
package com.muyu.cloud.faultmanage.service;
import com.baomidou.mybatisplus.extension.service.IService;
import com.muyu.cloud.faultmanage.domain.FaultLog;
import com.muyu.cloud.faultmanage.domain.req.FaultLogListReq;
import com.muyu.cloud.faultmanage.domain.resp.FaultLogListResp;
import com.muyu.cloud.faultmanage.domain.resp.FaultLogTotalListResp;
import java.util.List;
/**
* @Authorweiran
* @Packagecom.muyu.cloud.faultmanage.service
* @Projectcloud-server-8
* @nameFaultLogService
* @Date2024/9/20 9:34
*/
public interface FaultLogService extends IService<FaultLog> {
/**
*
* @param faultLogListReq
* @return
*/
FaultLogTotalListResp selectfaultlog(FaultLogListReq faultLogListReq);
}

View File

@ -0,0 +1,21 @@
package com.muyu.cloud.faultmanage.service;
import com.baomidou.mybatisplus.extension.service.IService;
import com.muyu.cloud.faultmanage.domain.FaultRule;
/**
* @Authorweiran
* @Packagecom.muyu.cloud.faultmanage.service.impl
* @Projectcloud-server-8
* @nameFaultRuleService
* @Date2024/9/19 22:10
*/
public interface FaultRuleService extends IService<FaultRule> {
/**
*
* @return
*/
String checkfaults(FaultRule faultRule);
}

View File

@ -0,0 +1,22 @@
package com.muyu.cloud.faultmanage.service;
import com.baomidou.mybatisplus.extension.service.IService;
import com.muyu.cloud.faultmanage.domain.FaultType;
import java.util.List;
/**
* @Authorweiran
* @Packagecom.muyu.cloud.faultmanage.service
* @Projectcloud-server-8
* @nameFaultTypeService
* @Date2024/9/18 20:59
*/
public interface FaultTypeService extends IService<FaultType> {
/**
*
* @return
*/
List<FaultType> select();
}

View File

@ -0,0 +1,125 @@
package com.muyu.cloud.faultmanage.service.impl;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.github.pagehelper.PageHelper;
import com.github.pagehelper.PageInfo;
import com.muyu.cloud.faultmanage.domain.FaultCode;
import com.muyu.cloud.faultmanage.domain.FaultLabel;
import com.muyu.cloud.faultmanage.domain.req.FaultCodeAddReq;
import com.muyu.cloud.faultmanage.domain.req.FaultCodeListReq;
import com.muyu.cloud.faultmanage.domain.req.FaultCodeUpdReq;
import com.muyu.cloud.faultmanage.domain.resp.FaultCodeListResp;
import com.muyu.cloud.faultmanage.domain.resp.FaultCodeTotalListResp;
import com.muyu.cloud.faultmanage.domain.vo.FaultCodeVO;
import com.muyu.cloud.faultmanage.mapper.FaultCodeMapper;
import com.muyu.cloud.faultmanage.service.FaultCodeService;
import com.muyu.common.core.utils.StringUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import java.util.List;
/**
* @Authorweiran
* @Packagecom.muyu.cloud.faultmanage.service.impl
* @Projectcloud-faultmanage
* @nameFaultCodeServiceImpl
* @Date2024/9/17 14:53
*/
@Service
public class FaultCodeServiceImpl extends ServiceImpl<FaultCodeMapper, FaultCodeVO> implements FaultCodeService {
@Autowired
private FaultCodeMapper faultCodeMapper;
/**
*
* @param faultCodeListReq
* @return
*/
@Override
public FaultCodeTotalListResp selectlist(FaultCodeListReq faultCodeListReq) {
Integer pageNum = faultCodeListReq.getPageNum();
Integer pageSize = faultCodeListReq.getPageSize();
LambdaQueryWrapper<FaultCodeVO> queryWrapper = new LambdaQueryWrapper<>();
queryWrapper.eq(StringUtils.isNotEmpty(faultCodeListReq.getFaultcodeNumber()),
FaultCodeVO::getFaultcodeNumber,faultCodeListReq.getFaultcodeNumber());
queryWrapper.eq(StringUtils.isNotEmpty(faultCodeListReq.getFaultBit()),
FaultCodeVO::getFaultBit,faultCodeListReq.getFaultBit());
long count = this.count(queryWrapper);
queryWrapper.last("LIMIT "+ ((pageNum-1)*pageSize)+", "+pageSize);
List<FaultCodeVO> faultCodeVOList = this.list(queryWrapper);
List<FaultCodeListResp> faultCodeListRespList = faultCodeVOList.stream()
.map(FaultCodeListResp::faultCodeListResp)
.toList();
return FaultCodeTotalListResp.faultCodeTotalListResp(faultCodeListRespList,count);
}
/**
* ()
* @param faultCodeListReq
* @return
*/
@Override
public FaultCodeTotalListResp selectfaultcodelist(FaultCodeListReq faultCodeListReq) {
LambdaQueryWrapper<FaultCodeVO> queryWrapper = new LambdaQueryWrapper<>();
long count = this.count(queryWrapper);
int offset = (faultCodeListReq.getPageNum() - 1) * faultCodeListReq.getPageSize();
faultCodeListReq.setPageNum(offset);
List<FaultCodeVO> selectfaultcodelist = faultCodeMapper.selectfaultcodelist(faultCodeListReq);
List<FaultCodeListResp> faultCodeListRespList = selectfaultcodelist.stream()
.map(FaultCodeListResp::faultCodeListResp)
.toList();
return FaultCodeTotalListResp.faultCodeTotalListResp(faultCodeListRespList,count);
}
/**
*
* @param faultCodeAddReq
* @return
*/
@Override
public void insert(FaultCodeAddReq faultCodeAddReq) {
//判断故障名称或故障码是否存在,若都不存在先添加故障名称表,在添加故障码表
//1.判断故障名称是否存在
String faultlabelName = faultCodeAddReq.getFaultlabelName();
FaultLabel faultLabel = faultCodeMapper.selectfaultName(faultlabelName);
//2.判断故障码是否存在
String faultcodeNumber = faultCodeAddReq.getFaultcodeNumber();
FaultCode faultCode = faultCodeMapper.selectfaultCode(faultcodeNumber);
if (faultLabel==null && faultCode==null){
faultCodeMapper.insertfaultlabel(faultCodeAddReq);
faultCodeMapper.insertfaultcode(faultCodeAddReq);
}
}
/**
*
* @param faultCodeUpdReq
* @return
*/
@Override
public void upd(FaultCodeUpdReq faultCodeUpdReq) {
//修改故障名称表信息和故障码表信息
// faultCodeMapper.updfaultlabel(faultCodeUpdReq);
faultCodeMapper.updfaultcode(faultCodeUpdReq);
}
/**
*
* @param faultcodeId
* @return
*/
@Override
public void del(Integer faultcodeId) {
//查找故障码信息对应的故障名称
FaultCode faultCode = faultCodeMapper.findByfaultcodeId(faultcodeId);
//删除故障码表信息
faultCodeMapper.delfaultcode(faultcodeId);
//删除对应的故障名称表信息
faultCodeMapper.delfaultlabel(faultCode.getFaultlabelId());
}
}

View File

@ -0,0 +1,39 @@
package com.muyu.cloud.faultmanage.service.impl;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.muyu.cloud.faultmanage.domain.FaultLabel;
import com.muyu.cloud.faultmanage.domain.FaultType;
import com.muyu.cloud.faultmanage.mapper.FaultLabelMapper;
import com.muyu.cloud.faultmanage.mapper.FaultTypeMapper;
import com.muyu.cloud.faultmanage.service.FaultLabelService;
import com.muyu.cloud.faultmanage.service.FaultTypeService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import java.util.List;
/**
* @Authorweiran
* @Packagecom.muyu.cloud.faultmanage.service.impl
* @Projectcloud-server-8
* @nameFaultTypeServiceImpl
* @Date2024/9/18 21:00
*/
@Service
public class FaultLabelServiceImpl extends ServiceImpl<FaultLabelMapper, FaultLabel> implements FaultLabelService {
@Autowired
private FaultLabelMapper faultLabelMapper;
/**
*
* @return
*/
@Override
public List<FaultLabel> select() {
LambdaQueryWrapper<FaultLabel> queryWrapper = new LambdaQueryWrapper<>();
List<FaultLabel> list = this.list(queryWrapper);
return list;
}
}

View File

@ -0,0 +1,45 @@
package com.muyu.cloud.faultmanage.service.impl;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.muyu.cloud.faultmanage.domain.FaultLog;
import com.muyu.cloud.faultmanage.domain.req.FaultLogListReq;
import com.muyu.cloud.faultmanage.domain.resp.FaultLogListResp;
import com.muyu.cloud.faultmanage.domain.resp.FaultLogTotalListResp;
import com.muyu.cloud.faultmanage.mapper.FaultLogMapper;
import com.muyu.cloud.faultmanage.service.FaultLogService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import java.util.List;
/**
* @Authorweiran
* @Packagecom.muyu.cloud.faultmanage.service.impl
* @Projectcloud-server-8
* @nameFaultLogServiceImpl
* @Date2024/9/20 9:34
*/
@Service
public class FaultLogServiceImpl extends ServiceImpl<FaultLogMapper, FaultLog> implements FaultLogService {
@Autowired
private FaultLogMapper faultLogMapper;
/**
*
* @param faultLogListReq
* @return
*/
@Override
public FaultLogTotalListResp selectfaultlog(FaultLogListReq faultLogListReq) {
LambdaQueryWrapper<FaultLog> queryWrapper = new LambdaQueryWrapper<>();
long count = this.count(queryWrapper);
int offset = (faultLogListReq.getPageNum() - 1) * faultLogListReq.getPageSize();
faultLogListReq.setPageNum(offset);
List<FaultLog> faultLogListResps = faultLogMapper.selectfaultLogMapper(faultLogListReq);
List<FaultLogListResp> faultLogListRespList = faultLogListResps.stream()
.map(FaultLogListResp::faultLogListResp)
.toList();
return FaultLogTotalListResp.faultLogTotalListResp(faultLogListRespList,count);
}
}

View File

@ -0,0 +1,63 @@
package com.muyu.cloud.faultmanage.service.impl;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.muyu.cloud.faultmanage.domain.FaultRule;
import com.muyu.cloud.faultmanage.mapper.FaultRuleMapper;
import com.muyu.cloud.faultmanage.service.FaultRuleService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import java.math.BigDecimal;
import java.util.List;
/**
* @Authorweiran
* @Packagecom.muyu.cloud.faultmanage.service.impl
* @Projectcloud-server-8
* @nameFaultRuleServiceImpl
* @Date2024/9/19 22:10
*/
@Service
public class FaultRuleServiceImpl extends ServiceImpl<FaultRuleMapper, FaultRule> implements FaultRuleService {
@Autowired
private FaultRuleMapper faultRuleMapper;
/**
*
* @return
*/
@Override
public String checkfaults(FaultRule faultRule) {
//获取触发条件
LambdaQueryWrapper<FaultRule> queryWrapper = new LambdaQueryWrapper<>();
if (Long.valueOf(faultRule.getFaultcodeId())!=null && faultRule.getFaultcodeId()!=0){
queryWrapper.eq(FaultRule::getFaultcodeId, faultRule.getFaultcodeId());
}
List<FaultRule> faultRuleList = this.list(queryWrapper);
for (FaultRule rule : faultRuleList) {
//单个值比较
if (faultRule.getSingleThreshold()!=null && faultRule.getMaxThreshold()==null && faultRule.getMinThreshold()==null){
//大于阈值
if (faultRule.getConditionContent().contains(">") || faultRule.getConditionContent().contains("大于")){
if (faultRule.getThreshold().compareTo(rule.getSingleThreshold())>0){
return "数据超过阈值,出现异常";
}
}
//小于阈值
if (faultRule.getConditionContent().contains("<") || faultRule.getConditionContent().contains("小于")){
if (faultRule.getThreshold().compareTo(rule.getSingleThreshold())<0){
return "数据过低,出现异常";
}
}
}else { //区间值比较
if (faultRule.getThreshold().compareTo(rule.getMinThreshold())<0 || faultRule.getThreshold().compareTo(rule.getMaxThreshold())>0){
return "数据不在可控范围内,出现异常";
}
}
}
return "判断出现异常";
}
}

View File

@ -0,0 +1,36 @@
package com.muyu.cloud.faultmanage.service.impl;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.muyu.cloud.faultmanage.domain.FaultType;
import com.muyu.cloud.faultmanage.mapper.FaultTypeMapper;
import com.muyu.cloud.faultmanage.service.FaultTypeService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import java.util.List;
/**
* @Authorweiran
* @Packagecom.muyu.cloud.faultmanage.service.impl
* @Projectcloud-server-8
* @nameFaultTypeServiceImpl
* @Date2024/9/18 21:00
*/
@Service
public class FaultTypeServiceImpl extends ServiceImpl<FaultTypeMapper, FaultType> implements FaultTypeService {
@Autowired
private FaultTypeMapper faultTypeMapper;
/**
*
* @return
*/
@Override
public List<FaultType> select() {
LambdaQueryWrapper<FaultType> queryWrapper = new LambdaQueryWrapper<>();
List<FaultType> list = this.list(queryWrapper);
return list;
}
}

View File

@ -0,0 +1,19 @@
package com.muyu.cloud.faultmanage.service.impl.faultDetectionStrategy;
import org.springframework.stereotype.Service;
/**
* @Authorweiran
* @Packagecom.muyu.cloud.faultmanage.service.impl.faultDetectionStrategy
* @Projectcloud-server-8
* @nameFuelVehicleCarFaultDetectionStrategy
* @Date2024/9/20 20:00
*/
/**
*
*/
@Service(value = "FuelVehicleCar")
public class FuelVehicleCarFaultDetectionStrategy {
}

View File

@ -0,0 +1,198 @@
package com.muyu.cloud.faultmanage.service.impl.faultDetectionStrategy;
import com.muyu.cloud.faultmanage.domain.CarFaultRule;
import com.muyu.cloud.faultmanage.domain.FaultReport;
import com.muyu.cloud.faultmanage.service.FaultDetectionStrategy;
import org.springframework.stereotype.Service;
/**
* @Authorweiran
* @Packagecom.muyu.cloud.faultmanage.service.impl.faultDetectionStrategy
* @Projectcloud-server-8
* @nameCarFaultDetectionStrategy
* @Date2024/9/20 19:44
*/
/**
*
*/
@Service(value = "PureElectricCar")
public class PureElectricCarFaultDetectionStrategy implements FaultDetectionStrategy {
@Override
public FaultReport detectFaults(CarFaultRule carFaultRule) {
//检测车速是否处于正常范围
if (carFaultRule.getSpeed()>200 || carFaultRule.getSpeed()<0){
return new FaultReport("纯电车","车速不在正常范围内,请注意");
}
//检测总里程数是否超过正常数
if (carFaultRule.getTM()>5000000){
return new FaultReport("纯电车","总里程数已超标,请注意");
}
//检测总电压是否正常
if (carFaultRule.getTV()>650){
return new FaultReport("纯电车","总电压过高,请注意");
}
//检测电流是否超标
if (carFaultRule.getCC()>50){
return new FaultReport("纯电车","电流过高,请注意");
}
//检测绝缘电阻
if (carFaultRule.getIR()>100000){
return new FaultReport("纯电车","绝缘电阻过高,请注意");
}
// //检测加速踏板行程值
// if (carFaultRule.getAPTV()){
//
// }
// //检测制动踏板行程值
// if (carFaultRule.getBPTV()){
//
// }
// //检测燃料消耗率
// if (carFaultRule.getSFC()){
//
// }
// //检测电机控制器温度
// if (carFaultRule.getMCT()){
//
// }
// //检测电机转速
// if (carFaultRule.getMS()){
//
// }
// //检测电机转矩
// if (carFaultRule.getMTO()){
//
// }
// //检测电机温度
// if (carFaultRule.getMTE()){
//
// }
// //检测电机电压
// if (carFaultRule.getMV()){
//
// }
// //检测电机电流
// if (carFaultRule.getMC()){
//
// }
// //检测动力电池剩余电量SOC
// if (carFaultRule.getPBRSOC()){
//
// }
// //检测当前状态允许的最大反馈功率
// if (carFaultRule.getMACSFP()){
//
// }
// //检测当前状态允许最大放电功率
// if (carFaultRule.getCSATMDP()) {
//
// }
// //检测BMS自检计数器
// if (carFaultRule.getBMS()) {
//
// }
// //检测动力电池充放电电流
// if (carFaultRule.getCADC()) {
//
// }
// //检测动力电池负载端总电压V3
// if (carFaultRule.getPBLETVV3()) {
//
// }
// //检测单次最大电压
// if (carFaultRule.getSMV()) {
//
// }
// //检测单体电池最低电压
// if (carFaultRule.getMVOAB()) {
//
// }
// //检测单体电池最高温度
// if (carFaultRule.getMAXBT()) {
//
// }
// //检测单体电池最低温度
// if (carFaultRule.getMINBT()) {
//
// }
// //检测动力电池可用容量
// if (carFaultRule.getPBAC()) {
//
// }
// //检测车辆状态
// if (carFaultRule.getVS()) {
//
// }
// //检测充电状态
// if (carFaultRule.getCS()) {
//
// }
// //检测运行状态
// if (carFaultRule.getRS()) {
//
// }
// //检测SOC
// if (carFaultRule.getSOC()) {
//
// }
// //检测可充电储能装置工作状态
// if (carFaultRule.getRESDWC()) {
//
// }
// //检测驱动电机状态
// if (carFaultRule.getEAS()) {
//
// }
// //检测定位是否有效
// if (carFaultRule.getPTC()) {
//
// }
// //检测EAS
// if (carFaultRule.getEPS()) {
//
// }
// //检测PTC
// if (carFaultRule.getABS()) {
//
// }
// //检测EPS
// if (carFaultRule.getMCU()) {
//
// }
// //检测ABS
// if (carFaultRule.getPBHS()) {
//
// }
// //检测MCU
// if (carFaultRule.getPBCS()) {
//
// }
// //检测动力电池加热状态
// if (carFaultRule.getPBIS()) {
//
// }
// //检测动力电池当前状态
// if (carFaultRule.getDCDC()) {
//
// }
// //检测动力电池保温状态
// if (carFaultRule.getCHG()) {
//
// }
// //检测DCDC
// if (carFaultRule.getCHB()) {
//
// }
// //检测CHG
// if (carFaultRule.getCUB()) {
//
// }
return null;
}
}

View File

@ -0,0 +1,2 @@
Spring Boot Version: ${spring-boot.version}
Spring Application Name: ${spring.application.name}

View File

@ -0,0 +1,74 @@
<?xml version="1.0" encoding="UTF-8"?>
<configuration scan="true" scanPeriod="60 seconds" debug="false">
<!-- 日志存放路径 -->
<property name="log.path" value="logs/cloud-faultmanage"/>
<!-- 日志输出格式 -->
<property name="log.pattern" value="%d{HH:mm:ss.SSS} [%thread] %-5level %logger{20} - [%method,%line] - %msg%n"/>
<!-- 控制台输出 -->
<appender name="console" class="ch.qos.logback.core.ConsoleAppender">
<encoder>
<pattern>${log.pattern}</pattern>
</encoder>
</appender>
<!-- 系统日志输出 -->
<appender name="file_info" class="ch.qos.logback.core.rolling.RollingFileAppender">
<file>${log.path}/info.log</file>
<!-- 循环政策:基于时间创建日志文件 -->
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<!-- 日志文件名格式 -->
<fileNamePattern>${log.path}/info.%d{yyyy-MM-dd}.log</fileNamePattern>
<!-- 日志最大的历史 60天 -->
<maxHistory>60</maxHistory>
</rollingPolicy>
<encoder>
<pattern>${log.pattern}</pattern>
</encoder>
<filter class="ch.qos.logback.classic.filter.LevelFilter">
<!-- 过滤的级别 -->
<level>INFO</level>
<!-- 匹配时的操作:接收(记录) -->
<onMatch>ACCEPT</onMatch>
<!-- 不匹配时的操作:拒绝(不记录) -->
<onMismatch>DENY</onMismatch>
</filter>
</appender>
<appender name="file_error" class="ch.qos.logback.core.rolling.RollingFileAppender">
<file>${log.path}/error.log</file>
<!-- 循环政策:基于时间创建日志文件 -->
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<!-- 日志文件名格式 -->
<fileNamePattern>${log.path}/error.%d{yyyy-MM-dd}.log</fileNamePattern>
<!-- 日志最大的历史 60天 -->
<maxHistory>60</maxHistory>
</rollingPolicy>
<encoder>
<pattern>${log.pattern}</pattern>
</encoder>
<filter class="ch.qos.logback.classic.filter.LevelFilter">
<!-- 过滤的级别 -->
<level>ERROR</level>
<!-- 匹配时的操作:接收(记录) -->
<onMatch>ACCEPT</onMatch>
<!-- 不匹配时的操作:拒绝(不记录) -->
<onMismatch>DENY</onMismatch>
</filter>
</appender>
<!-- 系统模块日志级别控制 -->
<logger name="com.muyu" level="info"/>
<!-- Spring日志级别控制 -->
<logger name="org.springframework" level="warn"/>
<root level="info">
<appender-ref ref="console"/>
</root>
<!--系统操作日志-->
<root level="info">
<appender-ref ref="file_info"/>
<appender-ref ref="file_error"/>
</root>
</configuration>

View File

@ -0,0 +1,81 @@
<?xml version="1.0" encoding="UTF-8"?>
<configuration scan="true" scanPeriod="60 seconds" debug="false">
<!-- 日志存放路径 -->
<property name="log.path" value="logs/cloud-faultmanage"/>
<!-- 日志输出格式 -->
<property name="log.pattern" value="%d{HH:mm:ss.SSS} [%thread] %-5level %logger{20} - [%method,%line] - %msg%n"/>
<property name="log.sky.pattern" value="%d{HH:mm:ss.SSS} %yellow([%tid]) [%thread] %-5level %logger{20} - [%method,%line] - %msg%n"/>
<!-- 控制台输出 -->
<appender name="console" class="ch.qos.logback.core.ConsoleAppender">
<encoder>
<pattern>${log.sky.pattern}</pattern>
</encoder>
</appender>
<!-- 系统日志输出 -->
<appender name="file_info" class="ch.qos.logback.core.rolling.RollingFileAppender">
<file>${log.path}/info.log</file>
<!-- 循环政策:基于时间创建日志文件 -->
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<!-- 日志文件名格式 -->
<fileNamePattern>${log.path}/info.%d{yyyy-MM-dd}.log</fileNamePattern>
<!-- 日志最大的历史 60天 -->
<maxHistory>60</maxHistory>
</rollingPolicy>
<filter class="ch.qos.logback.classic.filter.LevelFilter">
<!-- 过滤的级别 -->
<level>INFO</level>
<!-- 匹配时的操作:接收(记录) -->
<onMatch>ACCEPT</onMatch>
<!-- 不匹配时的操作:拒绝(不记录) -->
<onMismatch>DENY</onMismatch>
</filter>
</appender>
<appender name="file_error" class="ch.qos.logback.core.rolling.RollingFileAppender">
<file>${log.path}/error.log</file>
<!-- 循环政策:基于时间创建日志文件 -->
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<!-- 日志文件名格式 -->
<fileNamePattern>${log.path}/error.%d{yyyy-MM-dd}.log</fileNamePattern>
<!-- 日志最大的历史 60天 -->
<maxHistory>60</maxHistory>
</rollingPolicy>
<filter class="ch.qos.logback.classic.filter.LevelFilter">
<!-- 过滤的级别 -->
<level>ERROR</level>
<!-- 匹配时的操作:接收(记录) -->
<onMatch>ACCEPT</onMatch>
<!-- 不匹配时的操作:拒绝(不记录) -->
<onMismatch>DENY</onMismatch>
</filter>
</appender>
<!-- 使用gRpc将日志发送到skywalking服务端 -->
<appender name="GRPC_LOG" class="org.apache.skywalking.apm.toolkit.log.logback.v1.x.log.GRPCLogClientAppender">
<encoder class="ch.qos.logback.core.encoder.LayoutWrappingEncoder">
<layout class="org.apache.skywalking.apm.toolkit.log.logback.v1.x.TraceIdPatternLogbackLayout">
<Pattern>${log.sky.pattern}</Pattern>
</layout>
</encoder>
</appender>
<!-- 系统模块日志级别控制 -->
<logger name="com.muyu" level="info"/>
<!-- Spring日志级别控制 -->
<logger name="org.springframework" level="warn"/>
<root level="info">
<appender-ref ref="GRPC_LOG"/>
<appender-ref ref="console"/>
</root>
<!--系统操作日志-->
<root level="info">
<appender-ref ref="file_info"/>
<appender-ref ref="file_error"/>
</root>
</configuration>

View File

@ -0,0 +1,81 @@
<?xml version="1.0" encoding="UTF-8"?>
<configuration scan="true" scanPeriod="60 seconds" debug="false">
<!-- 日志存放路径 -->
<property name="log.path" value="logs/cloud-faultmanage"/>
<!-- 日志输出格式 -->
<property name="log.pattern" value="%d{HH:mm:ss.SSS} [%thread] %-5level %logger{20} - [%method,%line] - %msg%n"/>
<property name="log.sky.pattern" value="%d{HH:mm:ss.SSS} %yellow([%tid]) [%thread] %-5level %logger{20} - [%method,%line] - %msg%n"/>
<!-- 控制台输出 -->
<appender name="console" class="ch.qos.logback.core.ConsoleAppender">
<encoder>
<pattern>${log.sky.pattern}</pattern>
</encoder>
</appender>
<!-- 系统日志输出 -->
<appender name="file_info" class="ch.qos.logback.core.rolling.RollingFileAppender">
<file>${log.path}/info.log</file>
<!-- 循环政策:基于时间创建日志文件 -->
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<!-- 日志文件名格式 -->
<fileNamePattern>${log.path}/info.%d{yyyy-MM-dd}.log</fileNamePattern>
<!-- 日志最大的历史 60天 -->
<maxHistory>60</maxHistory>
</rollingPolicy>
<filter class="ch.qos.logback.classic.filter.LevelFilter">
<!-- 过滤的级别 -->
<level>INFO</level>
<!-- 匹配时的操作:接收(记录) -->
<onMatch>ACCEPT</onMatch>
<!-- 不匹配时的操作:拒绝(不记录) -->
<onMismatch>DENY</onMismatch>
</filter>
</appender>
<appender name="file_error" class="ch.qos.logback.core.rolling.RollingFileAppender">
<file>${log.path}/error.log</file>
<!-- 循环政策:基于时间创建日志文件 -->
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<!-- 日志文件名格式 -->
<fileNamePattern>${log.path}/error.%d{yyyy-MM-dd}.log</fileNamePattern>
<!-- 日志最大的历史 60天 -->
<maxHistory>60</maxHistory>
</rollingPolicy>
<filter class="ch.qos.logback.classic.filter.LevelFilter">
<!-- 过滤的级别 -->
<level>ERROR</level>
<!-- 匹配时的操作:接收(记录) -->
<onMatch>ACCEPT</onMatch>
<!-- 不匹配时的操作:拒绝(不记录) -->
<onMismatch>DENY</onMismatch>
</filter>
</appender>
<!-- 使用gRpc将日志发送到skywalking服务端 -->
<appender name="GRPC_LOG" class="org.apache.skywalking.apm.toolkit.log.logback.v1.x.log.GRPCLogClientAppender">
<encoder class="ch.qos.logback.core.encoder.LayoutWrappingEncoder">
<layout class="org.apache.skywalking.apm.toolkit.log.logback.v1.x.TraceIdPatternLogbackLayout">
<Pattern>${log.sky.pattern}</Pattern>
</layout>
</encoder>
</appender>
<!-- 系统模块日志级别控制 -->
<logger name="com.muyu" level="info"/>
<!-- Spring日志级别控制 -->
<logger name="org.springframework" level="warn"/>
<root level="info">
<appender-ref ref="GRPC_LOG"/>
<appender-ref ref="console"/>
</root>
<!--系统操作日志-->
<root level="info">
<appender-ref ref="file_info"/>
<appender-ref ref="file_error"/>
</root>
</configuration>

View File

@ -0,0 +1,102 @@
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.muyu.cloud.faultmanage.mapper.FaultCodeMapper">
<resultMap id="FaultCodeVoResult" type="com.muyu.cloud.faultmanage.domain.vo.FaultCodeVO">
<id property="faultcodeId" column="faultcode_id"></id>
<result property="faultlabelId" column="faultlabel_id"></result>
<result property="faultcodeNumber" column="faultcode_number"></result>
<result property="faultGroup" column="fault_group"></result>
<result property="faultBit" column="fault_bit"></result>
<result property="faultValue" column="fault_value"></result>
<result property="isWarning" column="is_warning"></result>
<result property="faulttypeName" column="faulttype_name"></result>
<result property="faultlabelName" column="faultlabel_name"></result>
</resultMap>
<sql id="selectfaultcodelist" >
SELECT
car_faultcode.faultcode_id,
car_fault_label.faulttype_id,
car_fault_label.faultlabel_id,
car_faultcode.faultcode_number,
car_fault_type.faulttype_name,
car_faultcode.fault_group,
car_faultcode.fault_bit,
car_faultcode.fault_value,
car_fault_label.faultlabel_name,
car_faultcode.is_warning
FROM
car_faultcode
LEFT JOIN car_fault_label ON car_faultcode.faultlabel_id = car_fault_label.faultlabel_id
LEFT JOIN car_fault_type ON car_fault_label.faulttype_id = car_fault_type.faulttype_id
</sql>
<!--故障码列表展示-->
<select id="selectfaultcodelist" resultMap="FaultCodeVoResult">
<include refid="selectfaultcodelist"></include>
<where>
<if test="faultcodeNumber!=null and faultcodeNumber!=''">
and car_faultcode.faultcode_number=#{faultcodeNumber}
</if>
<if test="faultBit!=null and faultBit!=''">
and car_faultcode.fault_bit=#{faultBit}
</if>
</where>
limit #{pageNum},#{pageSize}
</select>
<!--新增故障码-->
<select id="selectfaultName" resultType="com.muyu.cloud.faultmanage.domain.FaultLabel">
select * from car_fault_label where faultlabel_name=#{faultlabelName}
</select>
<select id="selectfaultCode" resultType="com.muyu.cloud.faultmanage.domain.FaultCode">
select * from car_faultcode where faultcode_number=#{faultcodeNumber}
</select>
<insert id="insertfaultlabel" keyProperty="faultlabelId" useGeneratedKeys="true">
INSERT INTO `eight`.`car_fault_label`
(`faultlabel_id`, `faultlabel_name`, `faulttype_id`, `fault_status`, `fault_content`) VALUES
(0, #{faultlabelName}, #{faulttypeId}, 0, #{faultContent});
</insert>
<insert id="insertfaultcode">
INSERT INTO `eight`.`car_faultcode`
(`faultcode_id`, `faultlabel_id`, `faultcode_number`, `fault_group`, `fault_bit`, `fault_value`, `is_warning`) VALUES
(0, #{faultlabelId}, #{faultcodeNumber}, #{faultGroup}, #{faultBit}, #{faultValue}, #{isWarning});
</insert>
<!--修改故障码-->
<update id="updfaultlabel">
UPDATE `eight`.`car_fault_label`
SET `faultlabel_name` = #{faultlabelName},
`faulttype_id` = #{faulttypeId},
`fault_status` = #{faultStatus},
`fault_content` = #{faultContent}
WHERE `faultlabel_id`= #{faultlabelId};
</update>
<update id="updfaultcode">
UPDATE `eight`.`car_faultcode`
SET `faultlabel_id` = #{faultlabelId},
`faultcode_number` = #{faultcodeNumber},
`fault_group` = #{faultGroup},
`fault_bit` = #{faultBit},
`fault_value` = #{faultValue},
`is_warning` = #{isWarning}
WHERE `faultcode_id` = #{faultcodeId};
</update>
<!--删除故障码-->
<select id="findByfaultcodeId" resultType="com.muyu.cloud.faultmanage.domain.FaultCode">
select * from car_faultcode where faultcode_id=#{faultcodeId}
</select>
<delete id="delfaultcode">
delete from car_faultcode where faultcode_id=#{faultcodeId}
</delete>
<delete id="delfaultlabel">
delete from car_fault_label where faultlabel_id=#{faultlabelId}
</delete>
</mapper>

View File

@ -0,0 +1,45 @@
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.muyu.cloud.faultmanage.mapper.FaultLogMapper">
<resultMap id="FaultCodeLogResult" type="com.muyu.cloud.faultmanage.domain.FaultLog">
<id property="logId" column="log_id"></id>
<result property="faultcodeId" column="faultcode_id"></result>
<result property="carInformationId" column="car_information_id"></result>
<result property="carVin" column="car_vin"></result>
<result property="startwarningTime" column="startwarning_time"></result>
<result property="endwarningTime" column="endwarning_time"></result>
<result property="carInformationVIN" column="car_information_VIN"></result>
<result property="faultcodeNumber" column="faultcode_number"></result>
</resultMap>
<sql id="selectfaultloglist">
SELECT
car_fault_log.*,
car_faultcode.faultcode_number,
car_information.car_information_VIN
FROM
car_fault_log
LEFT JOIN car_faultcode ON car_fault_log.faultcode_id = car_faultcode.faultcode_id
LEFT JOIN car_information ON car_fault_log.car_information_id = car_information.car_information_id
</sql>
<!--日志列表-->
<select id="selectfaultLogMapper" resultType="com.muyu.cloud.faultmanage.domain.FaultLog">
<include refid="selectfaultloglist"></include>
<where>
<if test="carVin!=null and carVin!=''">
and car_fault_log.car_vin=#{carVin}
</if>
<if test="startwarningTime!=null and startwarningTime!=''">
and car_fault_log.startwarning_time=#{startwarningTime}
</if>
<if test="endwarningTime!=null and endwarningTime!=''">
and car_fault_log.endwarning_time=#{endwarningTime}
</if>
</where>
limit #{pageNum},#{pageSize}
</select>
</mapper>

View File

@ -0,0 +1,27 @@
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>com.muyu</groupId>
<artifactId>cloud-server</artifactId>
<version>3.6.3</version>
</parent>
<artifactId>cloud-faultmanage</artifactId>
<packaging>pom</packaging>
<modules>
<module>cloud-faultmanage-server</module>
<module>cloud-faultmanage-client</module>
<module>cloud-faultmanage-remote</module>
<module>cloud-faultmanage-common</module>
</modules>
<properties>
<maven.compiler.source>17</maven.compiler.source>
<maven.compiler.target>17</maven.compiler.target>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
</project>

View File

@ -275,6 +275,7 @@
<module>cloud-visual</module>
<module>cloud-modules</module>
<module>cloud-common</module>
<module>cloud-faultmanage</module>
</modules>
<packaging>pom</packaging>