Compare commits
No commits in common. "4eabd13d41e58dc4be4820afe7a9ace830fa41e3" and "3b17c079827f22da819ef7dc59d870dce110bfca" have entirely different histories.
4eabd13d41
...
3b17c07982
10
pom.xml
10
pom.xml
|
@ -165,16 +165,6 @@
|
|||
<artifactId>oshi-core-java11</artifactId>
|
||||
<version>6.4.12</version>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>org.mapstruct</groupId>
|
||||
<artifactId>mapstruct</artifactId>
|
||||
<version>1.5.0.Final</version>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>org.mapstruct</groupId>
|
||||
<artifactId>mapstruct-processor</artifactId>
|
||||
<version>1.5.5.Final</version>
|
||||
</dependency>
|
||||
</dependencies>
|
||||
|
||||
<build>
|
||||
|
|
|
@ -1,59 +0,0 @@
|
|||
package com.cmhi.cf.controller;
|
||||
|
||||
import com.cmhi.cf.restapi.annotation.EncryptionProtocol;
|
||||
import com.cmhi.cf.restapi.annotation.OperationLogAnnotation;
|
||||
import com.cmhi.cf.restapi.pojo.base.BaseRespStatus;
|
||||
import com.cmhi.cf.restapi.pojo.vo.GetHwInfoResp;
|
||||
import com.cmhi.cf.restapi.pojo.vo.GetOsInfoResp;
|
||||
import com.cmhi.cf.restapi.pojo.vo.GetProcessorInfoResp;
|
||||
import com.cmhi.cf.restapi.pojo.vo.ProtocolResp;
|
||||
import com.cmhi.cf.service.SystemInfoService;
|
||||
import io.swagger.v3.oas.annotations.tags.Tag;
|
||||
import jakarta.annotation.Resource;
|
||||
import lombok.extern.slf4j.Slf4j;
|
||||
import org.springframework.stereotype.Controller;
|
||||
import org.springframework.web.bind.annotation.GetMapping;
|
||||
import org.springframework.web.bind.annotation.RequestMapping;
|
||||
import org.springframework.web.bind.annotation.ResponseBody;
|
||||
|
||||
import java.sql.Timestamp;
|
||||
|
||||
@Controller
|
||||
@Slf4j
|
||||
@Tag(name = "系统信息接口")
|
||||
@RequestMapping(value = "/api/systemInfo")
|
||||
public class SystemInfoApi {
|
||||
@Resource
|
||||
private SystemInfoService systemInfoService;
|
||||
|
||||
@GetMapping("/osInfo")
|
||||
@ResponseBody
|
||||
@EncryptionProtocol
|
||||
@OperationLogAnnotation(OperationModule = "系统信息模块", OperationType = "读取", OperationDesc = "获取当前操作系统信息")
|
||||
public ProtocolResp<? extends BaseRespStatus> getOsInfo() {
|
||||
return ProtocolResp.result(GetOsInfoResp.builder()
|
||||
.os(systemInfoService.getOsName())
|
||||
.bootTime(new Timestamp(systemInfoService.getOsBootTimeStamp()))
|
||||
.build());
|
||||
}
|
||||
|
||||
@GetMapping("/processorInfo")
|
||||
@ResponseBody
|
||||
@EncryptionProtocol
|
||||
@OperationLogAnnotation(OperationModule = "系统信息模块", OperationType = "读取", OperationDesc = "获取当前处理器信息")
|
||||
public ProtocolResp<? extends BaseRespStatus> getProcessorInfo() {
|
||||
return ProtocolResp.result(GetProcessorInfoResp.builder()
|
||||
.cpuInfo(systemInfoService.getProcessInfo())
|
||||
.build());
|
||||
}
|
||||
|
||||
@GetMapping("/hwInfo")
|
||||
@ResponseBody
|
||||
@EncryptionProtocol
|
||||
@OperationLogAnnotation(OperationModule = "系统信息模块", OperationType = "读取", OperationDesc = "获取系统硬件信息")
|
||||
public ProtocolResp<? extends BaseRespStatus> getHwInfo() {
|
||||
return ProtocolResp.result(GetHwInfoResp.builder()
|
||||
.hwInfo(systemInfoService.getHardwareInfo())
|
||||
.build());
|
||||
}
|
||||
}
|
|
@ -1,60 +0,0 @@
|
|||
package com.cmhi.cf.restapi.imapstruct;
|
||||
|
||||
import com.cmhi.cf.restapi.pojo.po.HwFirmware;
|
||||
import com.cmhi.cf.restapi.pojo.po.HwInfo;
|
||||
import com.cmhi.cf.restapi.pojo.po.HwMotherBoard;
|
||||
import com.cmhi.cf.restapi.pojo.po.ProcessorInfo;
|
||||
import org.mapstruct.Mapper;
|
||||
import org.mapstruct.Mapping;
|
||||
import org.mapstruct.Mappings;
|
||||
import org.mapstruct.factory.Mappers;
|
||||
import oshi.hardware.Baseboard;
|
||||
import oshi.hardware.CentralProcessor;
|
||||
import oshi.hardware.ComputerSystem;
|
||||
import oshi.hardware.Firmware;
|
||||
|
||||
@Mapper
|
||||
public interface IStructConvert {
|
||||
IStructConvert INSTANCE = Mappers.getMapper(IStructConvert.class);
|
||||
|
||||
@Mappings({
|
||||
@Mapping(expression = "java(f.getName())", target = "name"),
|
||||
@Mapping(expression = "java(f.getVersion())", target = "version"),
|
||||
@Mapping(expression = "java(f.getDescription())", target = "description"),
|
||||
@Mapping(expression = "java(f.getManufacturer())", target = "manufacturer"),
|
||||
@Mapping(expression = "java(f.getReleaseDate())", target = "releaseDate")
|
||||
})
|
||||
HwFirmware toHwFirmware(Firmware f);
|
||||
|
||||
@Mappings({
|
||||
@Mapping(expression = "java(b.getVersion().trim())", target = "version"),
|
||||
@Mapping(expression = "java(b.getManufacturer())", target = "manufacturer"),
|
||||
@Mapping(expression = "java(b.getModel())", target = "model"),
|
||||
@Mapping(expression = "java(b.getSerialNumber())", target = "serialNumber")
|
||||
})
|
||||
HwMotherBoard toHwMotherBoard(Baseboard b);
|
||||
|
||||
@Mappings({
|
||||
@Mapping(expression = "java(c.getModel())", target = "model"),
|
||||
@Mapping(expression = "java(c.getManufacturer())", target = "manufacturer"),
|
||||
@Mapping(expression = "java(c.getHardwareUUID())", target = "uuid"),
|
||||
@Mapping(expression = "java(c.getSerialNumber())", target = "serialNumber"),
|
||||
@Mapping(expression = "java(toHwFirmware(c.getFirmware()))", target = "firmware"),
|
||||
@Mapping(expression = "java(toHwMotherBoard(c.getBaseboard()))", target = "mb")
|
||||
})
|
||||
HwInfo toHwInfo(ComputerSystem c);
|
||||
|
||||
@Mappings({
|
||||
@Mapping(expression = "java(p.getProcessorIdentifier().getVendor())", target = "cpuVendor"),
|
||||
@Mapping(expression = "java(p.getProcessorIdentifier().getName())", target = "cpuName"),
|
||||
@Mapping(expression = "java(p.getProcessorIdentifier().getProcessorID())", target = "processorId"),
|
||||
@Mapping(expression = "java(p.getProcessorIdentifier().getIdentifier())", target = "cpuIdentifier"),
|
||||
@Mapping(expression = "java(p.getProcessorIdentifier().getMicroarchitecture())", target = "microArchitecture"),
|
||||
@Mapping(expression = "java(p.getProcessorIdentifier().isCpu64bit())", target = "cpu64bit"),
|
||||
@Mapping(expression = "java(p.getMaxFreq())", target = "cpuVendorFreq"),
|
||||
@Mapping(expression = "java(p.getPhysicalPackageCount())", target = "physicalCpus"),
|
||||
@Mapping(expression = "java(p.getPhysicalProcessorCount())", target = "physicalCores"),
|
||||
@Mapping(expression = "java(p.getLogicalProcessorCount())", target = "logicalCpu")
|
||||
})
|
||||
ProcessorInfo toProcessorInfo(CentralProcessor p, CentralProcessor.ProcessorIdentifier i);
|
||||
}
|
|
@ -1,14 +0,0 @@
|
|||
package com.cmhi.cf.restapi.pojo.po;
|
||||
|
||||
import com.fasterxml.jackson.annotation.JsonPropertyOrder;
|
||||
import lombok.Data;
|
||||
|
||||
@Data
|
||||
@JsonPropertyOrder({"name", "version", "manufacturer", "releaseDate", "description"})
|
||||
public class HwFirmware {
|
||||
private String name;
|
||||
private String version;
|
||||
private String description;
|
||||
private String manufacturer;
|
||||
private String releaseDate;
|
||||
}
|
|
@ -1,15 +0,0 @@
|
|||
package com.cmhi.cf.restapi.pojo.po;
|
||||
|
||||
import com.fasterxml.jackson.annotation.JsonPropertyOrder;
|
||||
import lombok.Data;
|
||||
|
||||
@Data
|
||||
@JsonPropertyOrder({"model", "manufacturer", "uuid", "serialNumber", "firmware", "mb"})
|
||||
public class HwInfo {
|
||||
private String model;
|
||||
private String manufacturer;
|
||||
private String uuid;
|
||||
private String serialNumber;
|
||||
private HwFirmware firmware;
|
||||
private HwMotherBoard mb;
|
||||
}
|
|
@ -1,13 +0,0 @@
|
|||
package com.cmhi.cf.restapi.pojo.po;
|
||||
|
||||
import com.fasterxml.jackson.annotation.JsonPropertyOrder;
|
||||
import lombok.Data;
|
||||
|
||||
@Data
|
||||
@JsonPropertyOrder({"version", "manufacturer", "model", "serialNumber"})
|
||||
public class HwMotherBoard {
|
||||
private String version;
|
||||
private String manufacturer;
|
||||
private String model;
|
||||
private String serialNumber;
|
||||
}
|
|
@ -1,20 +0,0 @@
|
|||
package com.cmhi.cf.restapi.pojo.po;
|
||||
|
||||
import com.fasterxml.jackson.annotation.JsonPropertyOrder;
|
||||
import lombok.Data;
|
||||
|
||||
@Data
|
||||
@JsonPropertyOrder({"cpuVendor", "cpuName", "processorId", "cpuIdentifier", "microArchitecture", "cpu64bit", "cpuVendorFreq",
|
||||
"physicalCpus", "physicalCores", "logicalCpu"})
|
||||
public class ProcessorInfo {
|
||||
private String cpuVendor;
|
||||
private String cpuName;
|
||||
private String processorId;
|
||||
private String cpuIdentifier;
|
||||
private String microArchitecture;
|
||||
private Boolean cpu64bit;
|
||||
private Long cpuVendorFreq;
|
||||
private Integer physicalCpus;
|
||||
private Integer physicalCores;
|
||||
private Integer logicalCpu;
|
||||
}
|
|
@ -1,22 +0,0 @@
|
|||
package com.cmhi.cf.restapi.pojo.vo;
|
||||
|
||||
import com.cmhi.cf.restapi.pojo.base.BaseRespStatus;
|
||||
import com.cmhi.cf.restapi.pojo.po.HwInfo;
|
||||
import com.fasterxml.jackson.annotation.JsonPropertyOrder;
|
||||
import io.swagger.v3.oas.annotations.media.Schema;
|
||||
import lombok.AllArgsConstructor;
|
||||
import lombok.Builder;
|
||||
import lombok.Data;
|
||||
import lombok.EqualsAndHashCode;
|
||||
import lombok.NoArgsConstructor;
|
||||
|
||||
@Schema(name = "系统硬件信息")
|
||||
@EqualsAndHashCode(callSuper = true)
|
||||
@Data
|
||||
@Builder
|
||||
@JsonPropertyOrder({"hwInfo", "status", "message"})
|
||||
@AllArgsConstructor
|
||||
@NoArgsConstructor
|
||||
public class GetHwInfoResp extends BaseRespStatus {
|
||||
private HwInfo hwInfo;
|
||||
}
|
|
@ -1,24 +0,0 @@
|
|||
package com.cmhi.cf.restapi.pojo.vo;
|
||||
|
||||
import com.cmhi.cf.restapi.pojo.base.BaseRespStatus;
|
||||
import com.fasterxml.jackson.annotation.JsonPropertyOrder;
|
||||
import io.swagger.v3.oas.annotations.media.Schema;
|
||||
import lombok.AllArgsConstructor;
|
||||
import lombok.Builder;
|
||||
import lombok.Data;
|
||||
import lombok.EqualsAndHashCode;
|
||||
import lombok.NoArgsConstructor;
|
||||
|
||||
import java.sql.Timestamp;
|
||||
|
||||
@Schema(name = "操作系统信息")
|
||||
@EqualsAndHashCode(callSuper = true)
|
||||
@Data
|
||||
@Builder
|
||||
@JsonPropertyOrder({"os", "bootTime", "status", "message"})
|
||||
@AllArgsConstructor
|
||||
@NoArgsConstructor
|
||||
public class GetOsInfoResp extends BaseRespStatus {
|
||||
private String os;
|
||||
private Timestamp bootTime;
|
||||
}
|
|
@ -1,22 +0,0 @@
|
|||
package com.cmhi.cf.restapi.pojo.vo;
|
||||
|
||||
import com.cmhi.cf.restapi.pojo.base.BaseRespStatus;
|
||||
import com.cmhi.cf.restapi.pojo.po.ProcessorInfo;
|
||||
import com.fasterxml.jackson.annotation.JsonPropertyOrder;
|
||||
import io.swagger.v3.oas.annotations.media.Schema;
|
||||
import lombok.AllArgsConstructor;
|
||||
import lombok.Builder;
|
||||
import lombok.Data;
|
||||
import lombok.EqualsAndHashCode;
|
||||
import lombok.NoArgsConstructor;
|
||||
|
||||
@Schema(name = "操作系统信息")
|
||||
@EqualsAndHashCode(callSuper = true)
|
||||
@Data
|
||||
@Builder
|
||||
@JsonPropertyOrder({"cpuInfo", "status", "message"})
|
||||
@AllArgsConstructor
|
||||
@NoArgsConstructor
|
||||
public class GetProcessorInfoResp extends BaseRespStatus {
|
||||
private ProcessorInfo cpuInfo;
|
||||
}
|
|
@ -1,13 +0,0 @@
|
|||
package com.cmhi.cf.service;
|
||||
|
||||
import com.cmhi.cf.restapi.pojo.po.HwInfo;
|
||||
import com.cmhi.cf.restapi.pojo.po.ProcessorInfo;
|
||||
|
||||
public interface SystemInfoService {
|
||||
String getOsName();
|
||||
long getOsBootTimeStamp();
|
||||
|
||||
ProcessorInfo getProcessInfo();
|
||||
|
||||
HwInfo getHardwareInfo();
|
||||
}
|
|
@ -1,37 +0,0 @@
|
|||
package com.cmhi.cf.service.impl;
|
||||
|
||||
import com.cmhi.cf.restapi.imapstruct.IStructConvert;
|
||||
import com.cmhi.cf.restapi.pojo.po.HwInfo;
|
||||
import com.cmhi.cf.restapi.pojo.po.ProcessorInfo;
|
||||
import com.cmhi.cf.service.SystemInfoService;
|
||||
import org.springframework.stereotype.Service;
|
||||
import oshi.SystemInfo;
|
||||
import oshi.hardware.CentralProcessor;
|
||||
import oshi.hardware.ComputerSystem;
|
||||
|
||||
@Service
|
||||
public class SystemInfoServiceImpl implements SystemInfoService {
|
||||
private final SystemInfo si = new SystemInfo();
|
||||
|
||||
@Override
|
||||
public String getOsName() {
|
||||
return String.valueOf(si.getOperatingSystem());
|
||||
}
|
||||
|
||||
@Override
|
||||
public long getOsBootTimeStamp() {
|
||||
return si.getOperatingSystem().getSystemBootTime() * 1000L;
|
||||
}
|
||||
|
||||
@Override
|
||||
public ProcessorInfo getProcessInfo() {
|
||||
CentralProcessor proc = si.getHardware().getProcessor();
|
||||
return IStructConvert.INSTANCE.toProcessorInfo(proc, proc.getProcessorIdentifier());
|
||||
}
|
||||
|
||||
@Override
|
||||
public HwInfo getHardwareInfo() {
|
||||
ComputerSystem cs = si.getHardware().getComputerSystem();
|
||||
return IStructConvert.INSTANCE.toHwInfo(cs);
|
||||
}
|
||||
}
|
|
@ -48,9 +48,6 @@ INSERT IGNORE INTO rbac_resource_data VALUES (406, 'e441dbb4-b844-461c-a5f8-07ee
|
|||
INSERT IGNORE INTO rbac_resource_data VALUES (407, 'c803571e-ba0d-4f3d-bcc8-76488b1af22a', '/api/dict/user/addDictContent', '新增用户字典详细信息', 'PUT', 0);
|
||||
INSERT IGNORE INTO rbac_resource_data VALUES (408, '99106f7a-6c4e-4438-ad40-65ed9417d0b4', '/api/dict/user/upgradeDictContent', '更新用户字典详细信息', 'POST', 0);
|
||||
INSERT IGNORE INTO rbac_resource_data VALUES (409, 'a4c04e8f-d495-46ca-b67e-79cc9a91d623', '/api/dict/user/deleteDictContent', '删除用户字典详细信息', 'DELETE', 0);
|
||||
INSERT IGNORE INTO rbac_resource_data VALUES (500, '3e7b6439-8d66-4409-84db-16fcbb115215', '/api/systemInfo/osInfo', '获取操作系统信息', 'GET', 0);
|
||||
INSERT IGNORE INTO rbac_resource_data VALUES (501, 'a958211f-083e-4a2d-b21d-5442090486d2', '/api/systemInfo/processorInfo', '获取系统处理器信息', 'GET', 0);
|
||||
INSERT IGNORE INTO rbac_resource_data VALUES (502, 'f5dcb609-692d-4f81-b3fa-0f4dc3c891fb', '/api/systemInfo/hwInfo', '获取系统硬件信息', 'GET', 0);
|
||||
|
||||
-- ----------------------------
|
||||
-- Records of role_resource
|
||||
|
@ -80,9 +77,7 @@ INSERT IGNORE INTO rbac_role_resource VALUES (1, 406, 1);
|
|||
INSERT IGNORE INTO rbac_role_resource VALUES (1, 407, 1);
|
||||
INSERT IGNORE INTO rbac_role_resource VALUES (1, 408, 1);
|
||||
INSERT IGNORE INTO rbac_role_resource VALUES (1, 409, 1);
|
||||
INSERT IGNORE INTO rbac_role_resource VALUES (1, 500, 1);
|
||||
INSERT IGNORE INTO rbac_role_resource VALUES (1, 501, 1);
|
||||
INSERT IGNORE INTO rbac_role_resource VALUES (1, 502, 1);
|
||||
|
||||
# INSERT IGNORE INTO role_resource (role_id, resource_id, authorize) VALUES (2, 1, 1);
|
||||
# INSERT IGNORE INTO role_resource (role_id, resource_id, authorize) VALUES (2, 2, 1);
|
||||
# INSERT IGNORE INTO role_resource (role_id, resource_id, authorize) VALUES (2, 3, 1);
|
||||
|
|
Loading…
Reference in New Issue