Merge branch 'master' of http://47.109.37.87:3000/by2025/SmartParks
This commit is contained in:
8
pom.xml
8
pom.xml
@@ -74,8 +74,8 @@
|
||||
<properties>
|
||||
<!-- 环境标识,需要与配置文件的名称相对应 -->
|
||||
<profiles.active>dev</profiles.active>
|
||||
<nacos.server>127.0.0.1:8848</nacos.server>
|
||||
<logstash.address>127.0.0.1:4560</logstash.address>
|
||||
<nacos.server>10.20.1.65:8848</nacos.server>
|
||||
<logstash.address>10.20.1.65:4560</logstash.address>
|
||||
<nacos.discovery.group>DEFAULT_GROUP</nacos.discovery.group>
|
||||
<nacos.config.group>DEFAULT_GROUP</nacos.config.group>
|
||||
<nacos.username>nacos</nacos.username>
|
||||
@@ -91,8 +91,8 @@
|
||||
<properties>
|
||||
<!-- 环境标识,需要与配置文件的名称相对应 -->
|
||||
<profiles.active>dev</profiles.active>
|
||||
<nacos.server>10.20.1.60:8848</nacos.server>
|
||||
<logstash.address>10.20.1.60:4560</logstash.address>
|
||||
<nacos.server>127.0.0.1:8848</nacos.server>
|
||||
<logstash.address>127.0.0.1:4560</logstash.address>
|
||||
<nacos.discovery.group>DEFAULT_GROUP</nacos.discovery.group>
|
||||
<nacos.config.group>DEFAULT_GROUP</nacos.config.group>
|
||||
<nacos.username>nacos</nacos.username>
|
||||
|
@@ -0,0 +1,23 @@
|
||||
package org.dromara.property.api;
|
||||
|
||||
import org.dromara.property.api.domain.vo.RemoteAttendanceUserGroupVo;
|
||||
|
||||
import java.util.Date;
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* 排班远程服务调用
|
||||
*
|
||||
* @author lxj
|
||||
*/
|
||||
public interface RemoteAttendanceService {
|
||||
|
||||
/**
|
||||
* 查询指定天数的排班信息
|
||||
*
|
||||
* @param date 查询时间
|
||||
* @return 返回排班人员信息
|
||||
*/
|
||||
public List<RemoteAttendanceUserGroupVo> queryAttendPersonInfo(Date date);
|
||||
|
||||
}
|
@@ -0,0 +1,5 @@
|
||||
package org.dromara.property.api;
|
||||
|
||||
public interface RemoteVisitoreGetCodeInfoService {
|
||||
String getCodeInfo(String code);
|
||||
}
|
@@ -0,0 +1,53 @@
|
||||
package org.dromara.property.api.domain.vo;
|
||||
|
||||
import lombok.Data;
|
||||
|
||||
import java.io.Serializable;
|
||||
import java.time.LocalDate;
|
||||
|
||||
/**
|
||||
* 排班人员信息
|
||||
*
|
||||
* @author lxj
|
||||
* @since 2025-08-17
|
||||
*/
|
||||
@Data
|
||||
public class RemoteAttendanceUserGroupVo implements Serializable {
|
||||
|
||||
/**
|
||||
* 排班ID
|
||||
*/
|
||||
private Long scheduleId;
|
||||
|
||||
/**
|
||||
* 员工ID
|
||||
*/
|
||||
private Long employeeId;
|
||||
|
||||
/**
|
||||
* 员工姓名
|
||||
*/
|
||||
private String employeeName;
|
||||
|
||||
/**
|
||||
* 部门ID
|
||||
*/
|
||||
private Long deptId;
|
||||
|
||||
/**
|
||||
* 部门名称
|
||||
*/
|
||||
private String deptName;
|
||||
|
||||
/**
|
||||
* 开始日期
|
||||
*/
|
||||
private LocalDate startDate;
|
||||
|
||||
/**
|
||||
* 结束日期(仅date_type=3时有效)
|
||||
*/
|
||||
private LocalDate endDate;
|
||||
|
||||
|
||||
}
|
@@ -34,4 +34,10 @@ public interface RemoteDeptService {
|
||||
*/
|
||||
List<RemoteDeptVo> selectDeptsByList();
|
||||
|
||||
/**
|
||||
* 根据部门id查询部门信息
|
||||
* @param deptId 部门id
|
||||
* @return 返回部门信息
|
||||
*/
|
||||
RemoteDeptVo selectDeptVoById(Long deptId);
|
||||
}
|
||||
|
@@ -0,0 +1,19 @@
|
||||
package org.dromara.sis.api;
|
||||
|
||||
import org.dromara.sis.api.domain.RemoteVisitor;
|
||||
|
||||
/**
|
||||
* @author lsm
|
||||
* @apiNote RemoteVisitorService
|
||||
* @since 2025/8/18
|
||||
*/
|
||||
public interface RemoteVisitorService {
|
||||
|
||||
/**
|
||||
* 访客信息写入E8平台
|
||||
*
|
||||
* @param visitor 访客信息
|
||||
* @return 访客ID
|
||||
*/
|
||||
Long syncE8PlatVisitor(RemoteVisitor visitor);
|
||||
}
|
@@ -0,0 +1,48 @@
|
||||
package org.dromara.sis.api.domain;
|
||||
|
||||
import lombok.Data;
|
||||
|
||||
import java.io.Serial;
|
||||
import java.io.Serializable;
|
||||
|
||||
/**
|
||||
* @author lsm
|
||||
* @apiNote RemoteVisitor
|
||||
* @since 2025/8/18
|
||||
*/
|
||||
@Data
|
||||
public class RemoteVisitor implements Serializable {
|
||||
|
||||
@Serial
|
||||
private static final long serialVersionUID = 1L;
|
||||
|
||||
/**
|
||||
* 访客名称
|
||||
*/
|
||||
private String visitorName;
|
||||
|
||||
/**
|
||||
* 手机号码
|
||||
*/
|
||||
private String mobilePhone;
|
||||
|
||||
/**
|
||||
* 被访人手机号
|
||||
*/
|
||||
private String intervieweeMobile;
|
||||
|
||||
/**
|
||||
* 授权开始时间
|
||||
*/
|
||||
private String visitorStartTime;
|
||||
|
||||
/**
|
||||
* 授权结束时间
|
||||
*/
|
||||
private String vistorEndTime;
|
||||
|
||||
/**
|
||||
* 访客人脸照
|
||||
*/
|
||||
private String visitorFaceImg;
|
||||
}
|
@@ -1,28 +1,28 @@
|
||||
package org.dromara.property.controller;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
import lombok.RequiredArgsConstructor;
|
||||
import jakarta.servlet.http.HttpServletResponse;
|
||||
import jakarta.validation.constraints.*;
|
||||
import cn.dev33.satoken.annotation.SaCheckPermission;
|
||||
import org.dromara.property.domain.bo.AttendanceArrangementBo;
|
||||
import org.dromara.property.domain.vo.AttendanceArrangementVo;
|
||||
import org.springframework.web.bind.annotation.*;
|
||||
import org.springframework.validation.annotation.Validated;
|
||||
import org.dromara.common.idempotent.annotation.RepeatSubmit;
|
||||
import org.dromara.common.log.annotation.Log;
|
||||
import org.dromara.common.web.core.BaseController;
|
||||
import org.dromara.common.mybatis.core.page.PageQuery;
|
||||
import jakarta.servlet.http.HttpServletResponse;
|
||||
import jakarta.validation.constraints.NotEmpty;
|
||||
import jakarta.validation.constraints.NotNull;
|
||||
import lombok.RequiredArgsConstructor;
|
||||
import org.dromara.common.core.domain.R;
|
||||
import org.dromara.common.core.validate.AddGroup;
|
||||
import org.dromara.common.core.validate.EditGroup;
|
||||
import org.dromara.common.log.enums.BusinessType;
|
||||
import org.dromara.common.excel.utils.ExcelUtil;
|
||||
import org.dromara.property.domain.vo.AttendanceUserGroupVo;
|
||||
import org.dromara.property.domain.bo.AttendanceUserGroupBo;
|
||||
import org.dromara.property.service.IAttendanceUserGroupService;
|
||||
import org.dromara.common.idempotent.annotation.RepeatSubmit;
|
||||
import org.dromara.common.log.annotation.Log;
|
||||
import org.dromara.common.log.enums.BusinessType;
|
||||
import org.dromara.common.mybatis.core.page.PageQuery;
|
||||
import org.dromara.common.mybatis.core.page.TableDataInfo;
|
||||
import org.dromara.common.web.core.BaseController;
|
||||
import org.dromara.property.domain.bo.AttendanceUserGroupBo;
|
||||
import org.dromara.property.domain.vo.AttendanceUserGroupVo;
|
||||
import org.dromara.property.service.IAttendanceUserGroupService;
|
||||
import org.springframework.validation.annotation.Validated;
|
||||
import org.springframework.web.bind.annotation.*;
|
||||
|
||||
import java.util.Date;
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* 排班明细
|
||||
@@ -114,4 +114,16 @@ public class AttendanceUserGroupController extends BaseController {
|
||||
public TableDataInfo<AttendanceUserGroupVo> queryScheduleView(AttendanceUserGroupBo bo, PageQuery pageQuery) {
|
||||
return attendanceUserGroupService.queryScheduleView(bo, pageQuery);
|
||||
}
|
||||
|
||||
/**
|
||||
* 查询今天的排班人员信息
|
||||
*
|
||||
* @return 返回排班人员信息
|
||||
*/
|
||||
@GetMapping("/query/currentDay")
|
||||
public R<List<AttendanceUserGroupVo>> queryCurrentSchedu() {
|
||||
return R.ok(attendanceUserGroupService.queryAttendPersonInfo(new Date()));
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
@@ -0,0 +1,106 @@
|
||||
package org.dromara.property.controller;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
import lombok.RequiredArgsConstructor;
|
||||
import jakarta.servlet.http.HttpServletResponse;
|
||||
import jakarta.validation.constraints.*;
|
||||
import cn.dev33.satoken.annotation.SaCheckPermission;
|
||||
import org.springframework.web.bind.annotation.*;
|
||||
import org.springframework.validation.annotation.Validated;
|
||||
import org.dromara.common.idempotent.annotation.RepeatSubmit;
|
||||
import org.dromara.common.log.annotation.Log;
|
||||
import org.dromara.common.web.core.BaseController;
|
||||
import org.dromara.common.mybatis.core.page.PageQuery;
|
||||
import org.dromara.common.core.domain.R;
|
||||
import org.dromara.common.core.validate.AddGroup;
|
||||
import org.dromara.common.core.validate.EditGroup;
|
||||
import org.dromara.common.log.enums.BusinessType;
|
||||
import org.dromara.common.excel.utils.ExcelUtil;
|
||||
import org.dromara.property.domain.vo.FaqManagementVo;
|
||||
import org.dromara.property.domain.bo.FaqManagementBo;
|
||||
import org.dromara.property.service.IFaqManagementService;
|
||||
import org.dromara.common.mybatis.core.page.TableDataInfo;
|
||||
|
||||
/**
|
||||
* 常见问题管理
|
||||
* 前端访问路由地址为:/property/faqManagement
|
||||
*
|
||||
* @author LionLi
|
||||
* @date 2025-08-18
|
||||
*/
|
||||
@Validated
|
||||
@RequiredArgsConstructor
|
||||
@RestController
|
||||
@RequestMapping("/faqManagement")
|
||||
public class FaqManagementController extends BaseController {
|
||||
|
||||
private final IFaqManagementService faqManagementService;
|
||||
|
||||
/**
|
||||
* 查询常见问题管理列表
|
||||
*/
|
||||
@SaCheckPermission("property:faqManagement:list")
|
||||
@GetMapping("/list")
|
||||
public TableDataInfo<FaqManagementVo> list(FaqManagementBo bo, PageQuery pageQuery) {
|
||||
return faqManagementService.queryPageList(bo, pageQuery);
|
||||
}
|
||||
|
||||
/**
|
||||
* 导出常见问题管理列表
|
||||
*/
|
||||
@SaCheckPermission("property:faqManagement:export")
|
||||
@Log(title = "常见问题管理", businessType = BusinessType.EXPORT)
|
||||
@PostMapping("/export")
|
||||
public void export(FaqManagementBo bo, HttpServletResponse response) {
|
||||
List<FaqManagementVo> list = faqManagementService.queryList(bo);
|
||||
ExcelUtil.exportExcel(list, "常见问题管理", FaqManagementVo.class, response);
|
||||
}
|
||||
|
||||
/**
|
||||
* 获取常见问题管理详细信息
|
||||
*
|
||||
* @param id 主键
|
||||
*/
|
||||
@SaCheckPermission("property:faqManagement:query")
|
||||
@GetMapping("/{id}")
|
||||
public R<FaqManagementVo> getInfo(@NotNull(message = "主键不能为空")
|
||||
@PathVariable("id") Long id) {
|
||||
return R.ok(faqManagementService.queryById(id));
|
||||
}
|
||||
|
||||
/**
|
||||
* 新增常见问题管理
|
||||
*/
|
||||
@SaCheckPermission("property:faqManagement:add")
|
||||
@Log(title = "常见问题管理", businessType = BusinessType.INSERT)
|
||||
@RepeatSubmit()
|
||||
@PostMapping()
|
||||
public R<Void> add(@Validated(AddGroup.class) @RequestBody FaqManagementBo bo) {
|
||||
return toAjax(faqManagementService.insertByBo(bo));
|
||||
}
|
||||
|
||||
/**
|
||||
* 修改常见问题管理
|
||||
*/
|
||||
@SaCheckPermission("property:faqManagement:edit")
|
||||
@Log(title = "常见问题管理", businessType = BusinessType.UPDATE)
|
||||
@RepeatSubmit()
|
||||
@PutMapping()
|
||||
public R<Void> edit(@Validated(EditGroup.class) @RequestBody FaqManagementBo bo) {
|
||||
return toAjax(faqManagementService.updateByBo(bo));
|
||||
}
|
||||
|
||||
/**
|
||||
* 删除常见问题管理
|
||||
*
|
||||
* @param ids 主键串
|
||||
*/
|
||||
@SaCheckPermission("property:faqManagement:remove")
|
||||
@Log(title = "常见问题管理", businessType = BusinessType.DELETE)
|
||||
@DeleteMapping("/{ids}")
|
||||
public R<Void> remove(@NotEmpty(message = "主键不能为空")
|
||||
@PathVariable("ids") Long[] ids) {
|
||||
return toAjax(faqManagementService.deleteWithValidByIds(List.of(ids), true));
|
||||
}
|
||||
}
|
@@ -51,7 +51,7 @@ public class QuestionnaireController extends BaseController {
|
||||
*
|
||||
* @param id 主键
|
||||
*/
|
||||
@SaCheckPermission("property:questionnaire:query")
|
||||
// @SaCheckPermission("property:questionnaire:query")
|
||||
@GetMapping("/{id}")
|
||||
public R<QuestionnaireVo> getInfo(@NotNull(message = "主键不能为空")
|
||||
@PathVariable("id") Long id) {
|
||||
|
@@ -0,0 +1,61 @@
|
||||
package org.dromara.property.domain;
|
||||
|
||||
import org.dromara.common.tenant.core.TenantEntity;
|
||||
import com.baomidou.mybatisplus.annotation.*;
|
||||
import lombok.Data;
|
||||
import lombok.EqualsAndHashCode;
|
||||
|
||||
import java.io.Serial;
|
||||
|
||||
/**
|
||||
* 常见问题管理对象 faq_management
|
||||
*
|
||||
* @author LionLi
|
||||
* @date 2025-08-18
|
||||
*/
|
||||
@Data
|
||||
@EqualsAndHashCode(callSuper = true)
|
||||
@TableName("faq_management")
|
||||
public class FaqManagement extends TenantEntity {
|
||||
|
||||
@Serial
|
||||
private static final long serialVersionUID = 1L;
|
||||
|
||||
/**
|
||||
* id
|
||||
*/
|
||||
@TableId(value = "id")
|
||||
private Long id;
|
||||
|
||||
/**
|
||||
* 标题
|
||||
*/
|
||||
private String head;
|
||||
|
||||
/**
|
||||
* 分类
|
||||
*/
|
||||
private String type;
|
||||
|
||||
/**
|
||||
* 浏览量
|
||||
*/
|
||||
private Long pageView;
|
||||
|
||||
/**
|
||||
* 内容
|
||||
*/
|
||||
private String contents;
|
||||
|
||||
/**
|
||||
* 状态(1草稿 2已发布)
|
||||
*/
|
||||
private String status;
|
||||
|
||||
/**
|
||||
* 搜索值
|
||||
*/
|
||||
private String searchValue;
|
||||
|
||||
|
||||
}
|
@@ -5,7 +5,6 @@ import com.baomidou.mybatisplus.annotation.*;
|
||||
import lombok.Data;
|
||||
import lombok.EqualsAndHashCode;
|
||||
import java.util.Date;
|
||||
import com.fasterxml.jackson.annotation.JsonFormat;
|
||||
|
||||
import java.io.Serial;
|
||||
|
||||
@@ -59,5 +58,4 @@ public class Questionnaire extends TenantEntity {
|
||||
*/
|
||||
private String status;
|
||||
|
||||
|
||||
}
|
||||
|
@@ -118,5 +118,8 @@ public class TbVisitorManagement extends TenantEntity {
|
||||
*/
|
||||
private String searchValue;
|
||||
|
||||
|
||||
/**
|
||||
* e8平台id
|
||||
*/
|
||||
private Long eEightId;
|
||||
}
|
||||
|
@@ -0,0 +1,64 @@
|
||||
package org.dromara.property.domain.bo;
|
||||
|
||||
import org.dromara.property.domain.FaqManagement;
|
||||
import org.dromara.common.mybatis.core.domain.BaseEntity;
|
||||
import org.dromara.common.core.validate.AddGroup;
|
||||
import org.dromara.common.core.validate.EditGroup;
|
||||
import io.github.linpeilie.annotations.AutoMapper;
|
||||
import lombok.Data;
|
||||
import lombok.EqualsAndHashCode;
|
||||
import jakarta.validation.constraints.*;
|
||||
|
||||
/**
|
||||
* 常见问题管理业务对象 faq_management
|
||||
*
|
||||
* @author LionLi
|
||||
* @date 2025-08-18
|
||||
*/
|
||||
@Data
|
||||
@EqualsAndHashCode(callSuper = true)
|
||||
@AutoMapper(target = FaqManagement.class, reverseConvertGenerate = false)
|
||||
public class FaqManagementBo extends BaseEntity {
|
||||
|
||||
/**
|
||||
* id
|
||||
*/
|
||||
@NotNull(message = "id不能为空", groups = { EditGroup.class })
|
||||
private Long id;
|
||||
|
||||
/**
|
||||
* 标题
|
||||
*/
|
||||
@NotBlank(message = "标题不能为空", groups = { AddGroup.class, EditGroup.class })
|
||||
private String head;
|
||||
|
||||
/**
|
||||
* 分类
|
||||
*/
|
||||
@NotBlank(message = "分类不能为空", groups = { AddGroup.class, EditGroup.class })
|
||||
private String type;
|
||||
|
||||
/**
|
||||
* 浏览量
|
||||
*/
|
||||
private Long pageView;
|
||||
|
||||
/**
|
||||
* 内容
|
||||
*/
|
||||
@NotBlank(message = "内容不能为空", groups = { AddGroup.class, EditGroup.class })
|
||||
private String contents;
|
||||
|
||||
/**
|
||||
* 状态(1草稿 2已发布)
|
||||
*/
|
||||
@NotBlank(message = "状态(1草稿 2已发布)不能为空", groups = { AddGroup.class, EditGroup.class })
|
||||
private String status;
|
||||
|
||||
/**
|
||||
* 搜索值
|
||||
*/
|
||||
private String searchValue;
|
||||
|
||||
|
||||
}
|
@@ -11,8 +11,6 @@ import jakarta.validation.constraints.*;
|
||||
import java.util.Date;
|
||||
import java.util.List;
|
||||
|
||||
import com.fasterxml.jackson.annotation.JsonFormat;
|
||||
|
||||
/**
|
||||
* 调查问卷业务对象 questionnaire
|
||||
*
|
||||
|
@@ -4,7 +4,6 @@ import cn.idev.excel.annotation.ExcelIgnoreUnannotated;
|
||||
import cn.idev.excel.annotation.ExcelProperty;
|
||||
import io.github.linpeilie.annotations.AutoMapper;
|
||||
import lombok.Data;
|
||||
import org.dromara.property.api.domain.vo.RemoteBuildingVo;
|
||||
import org.dromara.property.domain.*;
|
||||
import org.dromara.system.api.domain.vo.RemoteUserVo;
|
||||
import org.springframework.format.annotation.DateTimeFormat;
|
||||
@@ -14,7 +13,6 @@ import java.io.Serializable;
|
||||
import java.time.LocalDate;
|
||||
|
||||
|
||||
|
||||
/**
|
||||
* 排班明细视图对象 attendance_user_group
|
||||
*
|
||||
|
@@ -0,0 +1,86 @@
|
||||
package org.dromara.property.domain.vo;
|
||||
|
||||
import com.baomidou.mybatisplus.annotation.FieldFill;
|
||||
import com.baomidou.mybatisplus.annotation.TableField;
|
||||
import org.dromara.property.domain.FaqManagement;
|
||||
import cn.idev.excel.annotation.ExcelIgnoreUnannotated;
|
||||
import cn.idev.excel.annotation.ExcelProperty;
|
||||
import org.dromara.common.excel.annotation.ExcelDictFormat;
|
||||
import org.dromara.common.excel.convert.ExcelDictConvert;
|
||||
import io.github.linpeilie.annotations.AutoMapper;
|
||||
import lombok.Data;
|
||||
|
||||
import java.io.Serial;
|
||||
import java.io.Serializable;
|
||||
import java.util.Date;
|
||||
|
||||
|
||||
|
||||
/**
|
||||
* 常见问题管理视图对象 faq_management
|
||||
*
|
||||
* @author LionLi
|
||||
* @date 2025-08-18
|
||||
*/
|
||||
@Data
|
||||
@ExcelIgnoreUnannotated
|
||||
@AutoMapper(target = FaqManagement.class)
|
||||
public class FaqManagementVo implements Serializable {
|
||||
|
||||
@Serial
|
||||
private static final long serialVersionUID = 1L;
|
||||
|
||||
/**
|
||||
* id
|
||||
*/
|
||||
@ExcelProperty(value = "id")
|
||||
private Long id;
|
||||
|
||||
/**
|
||||
* 标题
|
||||
*/
|
||||
@ExcelProperty(value = "标题")
|
||||
private String head;
|
||||
|
||||
/**
|
||||
* 分类
|
||||
*/
|
||||
@ExcelProperty(value = "分类")
|
||||
private String type;
|
||||
|
||||
/**
|
||||
* 浏览量
|
||||
*/
|
||||
@ExcelProperty(value = "浏览量")
|
||||
private Long pageView;
|
||||
|
||||
/**
|
||||
* 内容
|
||||
*/
|
||||
@ExcelProperty(value = "内容")
|
||||
private String contents;
|
||||
|
||||
/**
|
||||
* 状态(1草稿 2已发布)
|
||||
*/
|
||||
@ExcelProperty(value = "状态(1草稿 2已发布)")
|
||||
private String status;
|
||||
|
||||
/**
|
||||
* 搜索值
|
||||
*/
|
||||
@ExcelProperty(value = "搜索值")
|
||||
private String searchValue;
|
||||
|
||||
/**
|
||||
* 创建时间
|
||||
*/
|
||||
|
||||
private Date createTime;
|
||||
|
||||
|
||||
/**
|
||||
* 更新时间
|
||||
*/
|
||||
private Date updateTime;
|
||||
}
|
@@ -7,11 +7,12 @@ import org.dromara.common.excel.annotation.ExcelDictFormat;
|
||||
import org.dromara.common.excel.convert.ExcelDictConvert;
|
||||
import io.github.linpeilie.annotations.AutoMapper;
|
||||
import lombok.Data;
|
||||
import org.dromara.property.domain.QuestionnaireQuestionItem;
|
||||
|
||||
import java.io.Serial;
|
||||
import java.io.Serializable;
|
||||
import java.util.Date;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
|
||||
/**
|
||||
@@ -70,5 +71,8 @@ public class QuestionnaireQuestionVo implements Serializable {
|
||||
@ExcelProperty(value = "排序")
|
||||
private Long sort;
|
||||
|
||||
|
||||
/**
|
||||
* 问题列表
|
||||
*/
|
||||
private List<QuestionnaireQuestionItemVo> questionnaireQuestionItemVos;
|
||||
}
|
||||
|
@@ -13,7 +13,7 @@ import lombok.Data;
|
||||
import java.io.Serial;
|
||||
import java.io.Serializable;
|
||||
import java.util.Date;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
|
||||
/**
|
||||
@@ -72,5 +72,8 @@ public class QuestionnaireVo implements Serializable {
|
||||
@ExcelProperty(value = "状态(1草稿2已发布3未发布)")
|
||||
private String status;
|
||||
|
||||
|
||||
/**
|
||||
* 问题列表
|
||||
*/
|
||||
private List<QuestionnaireQuestionVo> questionnaireQuestionVos;
|
||||
}
|
||||
|
@@ -0,0 +1,37 @@
|
||||
package org.dromara.property.dubbo;
|
||||
|
||||
import cn.hutool.core.bean.BeanUtil;
|
||||
import cn.hutool.core.collection.CollUtil;
|
||||
import lombok.RequiredArgsConstructor;
|
||||
import org.apache.dubbo.config.annotation.DubboService;
|
||||
import org.dromara.common.core.utils.MapstructUtils;
|
||||
import org.dromara.property.api.RemoteAttendanceService;
|
||||
import org.dromara.property.api.domain.vo.RemoteAttendanceUserGroupVo;
|
||||
import org.dromara.property.domain.vo.AttendanceUserGroupVo;
|
||||
import org.dromara.property.service.IAttendanceUserGroupService;
|
||||
|
||||
import java.util.Date;
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* 排班远程服务调用实现
|
||||
*
|
||||
* @author lxj
|
||||
*/
|
||||
@DubboService
|
||||
@RequiredArgsConstructor
|
||||
public class RemoteAttendanceServiceImpl implements RemoteAttendanceService {
|
||||
|
||||
|
||||
private final IAttendanceUserGroupService attendanceUserGroupService;
|
||||
|
||||
|
||||
public List<RemoteAttendanceUserGroupVo> queryAttendPersonInfo(Date date) {
|
||||
List<AttendanceUserGroupVo> ls = attendanceUserGroupService.queryAttendPersonInfo(date);
|
||||
if (CollUtil.isNotEmpty(ls)) {
|
||||
return BeanUtil.copyToList(ls, RemoteAttendanceUserGroupVo.class);
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
}
|
@@ -0,0 +1,19 @@
|
||||
package org.dromara.property.dubbo;
|
||||
|
||||
import lombok.RequiredArgsConstructor;
|
||||
import org.apache.dubbo.config.annotation.DubboService;
|
||||
import org.dromara.common.core.constant.GlobalConstants;
|
||||
import org.dromara.common.redis.utils.RedisUtils;
|
||||
import org.dromara.property.api.RemoteVisitoreGetCodeInfoService;
|
||||
import org.dromara.property.domain.bo.QrCodeInfo;
|
||||
|
||||
@DubboService
|
||||
@RequiredArgsConstructor
|
||||
public class RemoteVisitoreGetCodeInfo implements RemoteVisitoreGetCodeInfoService {
|
||||
|
||||
@Override
|
||||
public String getCodeInfo(String code) {
|
||||
QrCodeInfo info = RedisUtils.getCacheObject(GlobalConstants.CAPTCHA_CODE_KEY +"Qrcode" +code);
|
||||
return info.getUserid().toString();
|
||||
}
|
||||
}
|
@@ -0,0 +1,17 @@
|
||||
package org.dromara.property.mapper;
|
||||
|
||||
import org.apache.ibatis.annotations.Mapper;
|
||||
import org.dromara.property.domain.FaqManagement;
|
||||
import org.dromara.property.domain.vo.FaqManagementVo;
|
||||
import org.dromara.common.mybatis.core.mapper.BaseMapperPlus;
|
||||
|
||||
/**
|
||||
* 常见问题管理Mapper接口
|
||||
*
|
||||
* @author LionLi
|
||||
* @date 2025-08-18
|
||||
*/
|
||||
@Mapper
|
||||
public interface FaqManagementMapper extends BaseMapperPlus<FaqManagement, FaqManagementVo> {
|
||||
|
||||
}
|
@@ -1,11 +1,13 @@
|
||||
package org.dromara.property.service;
|
||||
|
||||
import org.dromara.property.domain.vo.AttendanceUserGroupVo;
|
||||
import org.dromara.property.domain.bo.AttendanceUserGroupBo;
|
||||
import org.dromara.common.mybatis.core.page.TableDataInfo;
|
||||
import org.dromara.common.mybatis.core.page.PageQuery;
|
||||
import org.dromara.common.mybatis.core.page.TableDataInfo;
|
||||
import org.dromara.property.domain.AttendanceUserGroup;
|
||||
import org.dromara.property.domain.bo.AttendanceUserGroupBo;
|
||||
import org.dromara.property.domain.vo.AttendanceUserGroupVo;
|
||||
|
||||
import java.util.Collection;
|
||||
import java.util.Date;
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
@@ -66,5 +68,14 @@ public interface IAttendanceUserGroupService {
|
||||
*/
|
||||
Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid);
|
||||
|
||||
/**
|
||||
* 根据日期查询人员排班信息
|
||||
*
|
||||
* @param date 日期
|
||||
* @return 返回排班人员信息
|
||||
*/
|
||||
List<AttendanceUserGroupVo> queryAttendPersonInfo(Date date);
|
||||
|
||||
TableDataInfo<AttendanceUserGroupVo> queryScheduleView(AttendanceUserGroupBo bo, PageQuery pageQuery);
|
||||
|
||||
}
|
||||
|
@@ -0,0 +1,69 @@
|
||||
package org.dromara.property.service;
|
||||
|
||||
import org.dromara.property.domain.FaqManagement;
|
||||
import org.dromara.property.domain.vo.FaqManagementVo;
|
||||
import org.dromara.property.domain.bo.FaqManagementBo;
|
||||
import org.dromara.common.mybatis.core.page.TableDataInfo;
|
||||
import org.dromara.common.mybatis.core.page.PageQuery;
|
||||
|
||||
import java.util.Collection;
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* 常见问题管理Service接口
|
||||
*
|
||||
* @author LionLi
|
||||
* @date 2025-08-18
|
||||
*/
|
||||
public interface IFaqManagementService {
|
||||
|
||||
/**
|
||||
* 查询常见问题管理
|
||||
*
|
||||
* @param id 主键
|
||||
* @return 常见问题管理
|
||||
*/
|
||||
FaqManagementVo queryById(Long id);
|
||||
|
||||
/**
|
||||
* 分页查询常见问题管理列表
|
||||
*
|
||||
* @param bo 查询条件
|
||||
* @param pageQuery 分页参数
|
||||
* @return 常见问题管理分页列表
|
||||
*/
|
||||
TableDataInfo<FaqManagementVo> queryPageList(FaqManagementBo bo, PageQuery pageQuery);
|
||||
|
||||
/**
|
||||
* 查询符合条件的常见问题管理列表
|
||||
*
|
||||
* @param bo 查询条件
|
||||
* @return 常见问题管理列表
|
||||
*/
|
||||
List<FaqManagementVo> queryList(FaqManagementBo bo);
|
||||
|
||||
/**
|
||||
* 新增常见问题管理
|
||||
*
|
||||
* @param bo 常见问题管理
|
||||
* @return 是否新增成功
|
||||
*/
|
||||
Boolean insertByBo(FaqManagementBo bo);
|
||||
|
||||
/**
|
||||
* 修改常见问题管理
|
||||
*
|
||||
* @param bo 常见问题管理
|
||||
* @return 是否修改成功
|
||||
*/
|
||||
Boolean updateByBo(FaqManagementBo bo);
|
||||
|
||||
/**
|
||||
* 校验并批量删除常见问题管理信息
|
||||
*
|
||||
* @param ids 待删除的主键集合
|
||||
* @param isValid 是否进行有效性校验
|
||||
* @return 是否删除成功
|
||||
*/
|
||||
Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid);
|
||||
}
|
@@ -1,5 +1,6 @@
|
||||
package org.dromara.property.service.impl;
|
||||
|
||||
import cn.hutool.core.collection.CollUtil;
|
||||
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
||||
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
||||
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||
@@ -17,6 +18,7 @@ import org.dromara.property.mapper.*;
|
||||
import org.dromara.property.service.IAttendanceUserGroupService;
|
||||
import org.dromara.system.api.RemoteDeptService;
|
||||
import org.dromara.system.api.RemoteUserService;
|
||||
import org.dromara.system.api.domain.vo.RemoteDeptVo;
|
||||
import org.dromara.system.api.domain.vo.RemoteUserVo;
|
||||
import org.springframework.stereotype.Service;
|
||||
|
||||
@@ -158,6 +160,25 @@ public class AttendanceUserGroupServiceImpl implements IAttendanceUserGroupServi
|
||||
return baseMapper.deleteByIds(ids) > 0;
|
||||
}
|
||||
|
||||
@Override
|
||||
public List<AttendanceUserGroupVo> queryAttendPersonInfo(Date date) {
|
||||
LambdaQueryWrapper<AttendanceUserGroup> lqw = Wrappers.lambdaQuery();
|
||||
lqw.le(AttendanceUserGroup::getStartDate, date)
|
||||
.ge(AttendanceUserGroup::getEndDate, date);
|
||||
// 如果今天存在排班信息。那么处理排班人员信息
|
||||
List<AttendanceUserGroupVo> attendanceUserGroupVos = this.baseMapper.selectVoList(lqw);
|
||||
if (CollUtil.isNotEmpty(attendanceUserGroupVos)) {
|
||||
attendanceUserGroupVos.forEach(attendanceUserGroupVo -> {
|
||||
// 查询排班人员信息
|
||||
RemoteUserVo remoteUserVo = remoteUserService.getUserInfoById(attendanceUserGroupVo.getEmployeeId());
|
||||
attendanceUserGroupVo.setRemoteUserVo(remoteUserVo);
|
||||
// todo 当表冗余了部门信息,以下反查操作可以去掉
|
||||
RemoteDeptVo dept = remoteDeptService.selectDeptVoById(attendanceUserGroupVo.getDeptId());
|
||||
attendanceUserGroupVo.setDeptName(dept.getDeptName());
|
||||
});
|
||||
}
|
||||
return attendanceUserGroupVos;
|
||||
}
|
||||
|
||||
/**
|
||||
* 查询排班的班表视图
|
||||
|
@@ -0,0 +1,137 @@
|
||||
package org.dromara.property.service.impl;
|
||||
|
||||
import org.dromara.common.core.utils.MapstructUtils;
|
||||
import org.dromara.common.core.utils.StringUtils;
|
||||
import org.dromara.common.mybatis.core.page.TableDataInfo;
|
||||
import org.dromara.common.mybatis.core.page.PageQuery;
|
||||
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
||||
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
||||
import lombok.RequiredArgsConstructor;
|
||||
import lombok.extern.slf4j.Slf4j;
|
||||
import org.springframework.stereotype.Service;
|
||||
import org.dromara.property.domain.bo.FaqManagementBo;
|
||||
import org.dromara.property.domain.vo.FaqManagementVo;
|
||||
import org.dromara.property.domain.FaqManagement;
|
||||
import org.dromara.property.mapper.FaqManagementMapper;
|
||||
import org.dromara.property.service.IFaqManagementService;
|
||||
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.Collection;
|
||||
|
||||
/**
|
||||
* 常见问题管理Service业务层处理
|
||||
*
|
||||
* @author LionLi
|
||||
* @date 2025-08-18
|
||||
*/
|
||||
@Slf4j
|
||||
@RequiredArgsConstructor
|
||||
@Service
|
||||
public class FaqManagementServiceImpl implements IFaqManagementService {
|
||||
|
||||
private final FaqManagementMapper baseMapper;
|
||||
|
||||
/**
|
||||
* 查询常见问题管理
|
||||
*
|
||||
* @param id 主键
|
||||
* @return 常见问题管理
|
||||
*/
|
||||
@Override
|
||||
public FaqManagementVo queryById(Long id){
|
||||
return baseMapper.selectVoById(id);
|
||||
}
|
||||
|
||||
/**
|
||||
* 分页查询常见问题管理列表
|
||||
*
|
||||
* @param bo 查询条件
|
||||
* @param pageQuery 分页参数
|
||||
* @return 常见问题管理分页列表
|
||||
*/
|
||||
@Override
|
||||
public TableDataInfo<FaqManagementVo> queryPageList(FaqManagementBo bo, PageQuery pageQuery) {
|
||||
LambdaQueryWrapper<FaqManagement> lqw = buildQueryWrapper(bo);
|
||||
Page<FaqManagementVo> result = baseMapper.selectVoPage(pageQuery.build(), lqw);
|
||||
return TableDataInfo.build(result);
|
||||
}
|
||||
|
||||
/**
|
||||
* 查询符合条件的常见问题管理列表
|
||||
*
|
||||
* @param bo 查询条件
|
||||
* @return 常见问题管理列表
|
||||
*/
|
||||
@Override
|
||||
public List<FaqManagementVo> queryList(FaqManagementBo bo) {
|
||||
LambdaQueryWrapper<FaqManagement> lqw = buildQueryWrapper(bo);
|
||||
return baseMapper.selectVoList(lqw);
|
||||
}
|
||||
|
||||
private LambdaQueryWrapper<FaqManagement> buildQueryWrapper(FaqManagementBo bo) {
|
||||
Map<String, Object> params = bo.getParams();
|
||||
LambdaQueryWrapper<FaqManagement> lqw = Wrappers.lambdaQuery();
|
||||
lqw.orderByAsc(FaqManagement::getId);
|
||||
lqw.like(StringUtils.isNotBlank(bo.getHead()), FaqManagement::getHead, bo.getHead());
|
||||
lqw.eq(StringUtils.isNotBlank(bo.getType()), FaqManagement::getType, bo.getType());
|
||||
lqw.eq(bo.getPageView() != null, FaqManagement::getPageView, bo.getPageView());
|
||||
lqw.eq(StringUtils.isNotBlank(bo.getContents()), FaqManagement::getContents, bo.getContents());
|
||||
lqw.eq(StringUtils.isNotBlank(bo.getStatus()), FaqManagement::getStatus, bo.getStatus());
|
||||
lqw.eq(StringUtils.isNotBlank(bo.getSearchValue()), FaqManagement::getSearchValue, bo.getSearchValue());
|
||||
return lqw;
|
||||
}
|
||||
|
||||
/**
|
||||
* 新增常见问题管理
|
||||
*
|
||||
* @param bo 常见问题管理
|
||||
* @return 是否新增成功
|
||||
*/
|
||||
@Override
|
||||
public Boolean insertByBo(FaqManagementBo bo) {
|
||||
FaqManagement add = MapstructUtils.convert(bo, FaqManagement.class);
|
||||
validEntityBeforeSave(add);
|
||||
boolean flag = baseMapper.insert(add) > 0;
|
||||
if (flag) {
|
||||
bo.setId(add.getId());
|
||||
}
|
||||
return flag;
|
||||
}
|
||||
|
||||
/**
|
||||
* 修改常见问题管理
|
||||
*
|
||||
* @param bo 常见问题管理
|
||||
* @return 是否修改成功
|
||||
*/
|
||||
@Override
|
||||
public Boolean updateByBo(FaqManagementBo bo) {
|
||||
FaqManagement update = MapstructUtils.convert(bo, FaqManagement.class);
|
||||
validEntityBeforeSave(update);
|
||||
return baseMapper.updateById(update) > 0;
|
||||
}
|
||||
|
||||
/**
|
||||
* 保存前的数据校验
|
||||
*/
|
||||
private void validEntityBeforeSave(FaqManagement entity){
|
||||
//TODO 做一些数据校验,如唯一约束
|
||||
}
|
||||
|
||||
/**
|
||||
* 校验并批量删除常见问题管理信息
|
||||
*
|
||||
* @param ids 待删除的主键集合
|
||||
* @param isValid 是否进行有效性校验
|
||||
* @return 是否删除成功
|
||||
*/
|
||||
@Override
|
||||
public Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid) {
|
||||
if(isValid){
|
||||
//TODO 做一些业务上的校验,判断是否需要校验
|
||||
}
|
||||
return baseMapper.deleteByIds(ids) > 0;
|
||||
}
|
||||
}
|
@@ -16,6 +16,8 @@ import org.dromara.property.domain.QuestionnaireQuestion;
|
||||
import org.dromara.property.domain.QuestionnaireQuestionItem;
|
||||
import org.dromara.property.domain.bo.QuestionnaireQuestionBo;
|
||||
import org.dromara.property.domain.bo.QuestionnaireQuestionItemBo;
|
||||
import org.dromara.property.domain.vo.QuestionnaireQuestionItemVo;
|
||||
import org.dromara.property.domain.vo.QuestionnaireQuestionVo;
|
||||
import org.dromara.property.mapper.QuestionnaireQuestionItemMapper;
|
||||
import org.dromara.property.mapper.QuestionnaireQuestionMapper;
|
||||
import org.springframework.stereotype.Service;
|
||||
@@ -53,7 +55,9 @@ public class QuestionnaireServiceImpl implements IQuestionnaireService {
|
||||
*/
|
||||
@Override
|
||||
public QuestionnaireVo queryById(Long id) {
|
||||
return baseMapper.selectVoById(id);
|
||||
QuestionnaireVo questionnaireVo = baseMapper.selectVoById(id);
|
||||
processingData(questionnaireVo,null, null);
|
||||
return questionnaireVo;
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -67,6 +71,23 @@ public class QuestionnaireServiceImpl implements IQuestionnaireService {
|
||||
public TableDataInfo<QuestionnaireVo> queryPageList(QuestionnaireBo bo, PageQuery pageQuery) {
|
||||
LambdaQueryWrapper<Questionnaire> lqw = buildQueryWrapper(bo);
|
||||
Page<QuestionnaireVo> result = baseMapper.selectVoPage(pageQuery.build(), lqw);
|
||||
if (CollUtil.isNotEmpty(result.getRecords())) {
|
||||
//收集所有的问卷id
|
||||
List<Long> questionnaireIds = result.getRecords().stream().map(QuestionnaireVo::getId).toList();
|
||||
// 一次性查询所有问题
|
||||
LambdaQueryWrapper<QuestionnaireQuestion> questionQueryWrapper = Wrappers.lambdaQuery();
|
||||
questionQueryWrapper.in(QuestionnaireQuestion::getQuestionnaireId, questionnaireIds);
|
||||
List<QuestionnaireQuestionVo> questionnaireQuestionVos = questionnaireQuestionMapper.selectVoList(questionQueryWrapper);
|
||||
//收集所有问题id
|
||||
List<Long> idList = questionnaireQuestionVos.stream().map(QuestionnaireQuestionVo::getId).toList();
|
||||
//查询所有问题选项
|
||||
LambdaQueryWrapper<QuestionnaireQuestionItem> questionItemQueryWrapper = Wrappers.lambdaQuery();
|
||||
questionItemQueryWrapper.in(QuestionnaireQuestionItem::getQuestionId, idList);
|
||||
List<QuestionnaireQuestionItemVo> questionnaireQuestionItemVos = questionnaireQuestionItemMapper.selectVoList(questionItemQueryWrapper);
|
||||
result.getRecords().stream().forEach(questionnaireVo -> {
|
||||
processingData(questionnaireVo, questionnaireQuestionVos, questionnaireQuestionItemVos);
|
||||
});
|
||||
}
|
||||
return TableDataInfo.build(result);
|
||||
}
|
||||
|
||||
@@ -91,6 +112,37 @@ public class QuestionnaireServiceImpl implements IQuestionnaireService {
|
||||
return lqw;
|
||||
}
|
||||
|
||||
/**
|
||||
* 处理数据
|
||||
*/
|
||||
private void processingData(QuestionnaireVo questionnaireVo, List<QuestionnaireQuestionVo> questionnaireQuestionVos, List<QuestionnaireQuestionItemVo> questionnaireQuestionItemVos) {
|
||||
// 在此处添加您选中的代码来获取问卷问题列表
|
||||
if (CollUtil.isEmpty(questionnaireQuestionVos)) {
|
||||
LambdaQueryWrapper<QuestionnaireQuestion> questionQueryWrapper = Wrappers.lambdaQuery();
|
||||
questionQueryWrapper.eq(QuestionnaireQuestion::getQuestionnaireId, questionnaireVo.getId());
|
||||
questionnaireQuestionVos = questionnaireQuestionMapper.selectVoList(questionQueryWrapper);
|
||||
if (CollUtil.isEmpty(questionnaireQuestionItemVos)) {
|
||||
//收集所有问题id
|
||||
List<Long> idList = questionnaireQuestionVos.stream().map(QuestionnaireQuestionVo::getId).toList();
|
||||
//查询所有问题选项
|
||||
LambdaQueryWrapper<QuestionnaireQuestionItem> questionItemQueryWrapper = Wrappers.lambdaQuery();
|
||||
questionItemQueryWrapper.in(QuestionnaireQuestionItem::getQuestionId, idList);
|
||||
questionnaireQuestionItemVos = questionnaireQuestionItemMapper.selectVoList(questionItemQueryWrapper);
|
||||
}
|
||||
}
|
||||
if (CollUtil.isNotEmpty(questionnaireQuestionVos)) {
|
||||
List<QuestionnaireQuestionItemVo> finalQuestionnaireQuestionItemVos = questionnaireQuestionItemVos;
|
||||
questionnaireQuestionVos.stream().forEach(questionnaireQuestionVo -> {
|
||||
//筛选出属于当前问题的问题项返回list
|
||||
List<QuestionnaireQuestionItemVo> list = finalQuestionnaireQuestionItemVos.stream().filter(questionnaireQuestionItemVo -> questionnaireQuestionItemVo.getQuestionId().equals(questionnaireQuestionVo.getId())).toList();
|
||||
questionnaireQuestionVo.setQuestionnaireQuestionItemVos(list);
|
||||
});
|
||||
}
|
||||
questionnaireVo.setQuestionnaireQuestionVos(questionnaireQuestionVos);
|
||||
}
|
||||
|
||||
;
|
||||
|
||||
/**
|
||||
* 新增调查问卷
|
||||
*
|
||||
|
@@ -168,11 +168,12 @@ public class ServiceWorkOrdersServiceImpl implements IServiceWorkOrdersService {
|
||||
.map(ServiceWorkOrdersType::getId)
|
||||
.collect(Collectors.toList());
|
||||
typeIds.add(bo.getType());
|
||||
List<String> statusList = Arrays.asList(bo.getStatus().split(","));
|
||||
Map<String, Object> params = bo.getParams();
|
||||
LambdaQueryWrapper<ServiceWorkOrders> lqw = Wrappers.lambdaQuery();
|
||||
lqw.orderByAsc(ServiceWorkOrders::getId);
|
||||
lqw.eq(StringUtils.isNotBlank(bo.getOrderNo()), ServiceWorkOrders::getOrderNo, bo.getOrderNo());
|
||||
lqw.eq(StringUtils.isNotBlank(bo.getStatus()), ServiceWorkOrders::getStatus, bo.getStatus());
|
||||
lqw.in(CollUtil.isNotEmpty(statusList), ServiceWorkOrders::getStatus, statusList);
|
||||
lqw.like(StringUtils.isNotBlank(bo.getOrderName()), ServiceWorkOrders::getOrderName, bo.getOrderName());
|
||||
lqw.eq(bo.getDispatchTime() != null, ServiceWorkOrders::getDispatchTime, bo.getDispatchTime());
|
||||
lqw.like(StringUtils.isNotBlank(bo.getInitiatorName()), ServiceWorkOrders::getInitiatorPeople, bo.getInitiatorName());
|
||||
|
@@ -1,6 +1,8 @@
|
||||
package org.dromara.property.service.impl;
|
||||
|
||||
import cn.hutool.core.date.DateUtil;
|
||||
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
||||
import org.apache.dubbo.config.annotation.DubboReference;
|
||||
import org.dromara.common.core.constant.GlobalConstants;
|
||||
import org.dromara.common.core.utils.MapstructUtils;
|
||||
import org.dromara.common.core.utils.StringUtils;
|
||||
@@ -13,6 +15,8 @@ import lombok.RequiredArgsConstructor;
|
||||
import lombok.extern.slf4j.Slf4j;
|
||||
import org.dromara.common.redis.utils.RedisUtils;
|
||||
import org.dromara.property.domain.bo.QrCodeInfo;
|
||||
import org.dromara.sis.api.RemoteVisitorService;
|
||||
import org.dromara.sis.api.domain.RemoteVisitor;
|
||||
import org.dromara.system.api.RemoteUserService;
|
||||
import org.dromara.system.api.domain.vo.RemoteUserVo;
|
||||
import org.springframework.stereotype.Service;
|
||||
@@ -30,7 +34,7 @@ import java.util.Collection;
|
||||
* 访客管理Service业务层处理
|
||||
*
|
||||
* @author mocheng
|
||||
* @date 2025-06-19
|
||||
* @since 2025-06-19
|
||||
*/
|
||||
@Slf4j
|
||||
@RequiredArgsConstructor
|
||||
@@ -38,7 +42,12 @@ import java.util.Collection;
|
||||
public class TbVisitorManagementServiceImpl implements ITbVisitorManagementService {
|
||||
|
||||
private final TbVisitorManagementMapper baseMapper;
|
||||
private final RemoteUserService remoteUserService;
|
||||
|
||||
@DubboReference
|
||||
private RemoteUserService remoteUserService;
|
||||
|
||||
@DubboReference
|
||||
private RemoteVisitorService remoteVisitorService;
|
||||
|
||||
/**
|
||||
* 查询访客管理
|
||||
@@ -108,6 +117,7 @@ public class TbVisitorManagementServiceImpl implements ITbVisitorManagementServi
|
||||
RedisUtils.deleteKeys(GlobalConstants.CAPTCHA_CODE_KEY + "Qrcode" + bo.getQrCodeId());
|
||||
TbVisitorManagement add = MapstructUtils.convert(bo, TbVisitorManagement.class);
|
||||
validEntityBeforeSave(add);
|
||||
assert add != null;
|
||||
add.setCreateById(info.getUserid());
|
||||
RemoteUserVo userInfoById = remoteUserService.getUserInfoById(info.getUserid());
|
||||
add.setTenantId(userInfoById.getTenantId());
|
||||
@@ -118,8 +128,12 @@ public class TbVisitorManagementServiceImpl implements ITbVisitorManagementServi
|
||||
add.setUpdateBy(userInfoById.getUserId());
|
||||
add.setCreateDept(userInfoById.getDeptId());
|
||||
boolean flag = baseMapper.insert(add) > 0;
|
||||
|
||||
if (flag) {
|
||||
bo.setId(add.getId());
|
||||
Long e8Id = syncE8PlatVisitor(bo);
|
||||
add.setEEightId(e8Id);
|
||||
baseMapper.updateById(add);
|
||||
}
|
||||
return flag;
|
||||
}
|
||||
@@ -139,11 +153,33 @@ public class TbVisitorManagementServiceImpl implements ITbVisitorManagementServi
|
||||
// add.setCreateById(info.getUserid());
|
||||
boolean flag = baseMapper.insert(add) > 0;
|
||||
if (flag) {
|
||||
assert add != null;
|
||||
bo.setId(add.getId());
|
||||
Long e8Id = syncE8PlatVisitor(bo);
|
||||
add.setEEightId(e8Id);
|
||||
baseMapper.updateById(add);
|
||||
}
|
||||
return flag;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* 访客登记同步E8平台门禁
|
||||
*
|
||||
* @param visitor 访客信息
|
||||
* @return E8平台访客ID
|
||||
*/
|
||||
private Long syncE8PlatVisitor(TbVisitorManagementBo visitor) {
|
||||
RemoteVisitor remoteVisitor = new RemoteVisitor();
|
||||
remoteVisitor.setVisitorName(visitor.getVisitorName());
|
||||
remoteVisitor.setMobilePhone(visitor.getVisitorPhone());
|
||||
remoteVisitor.setIntervieweeMobile(visitor.getInterviewedPhone());
|
||||
remoteVisitor.setVisitorStartTime(DateUtil.format(visitor.getVisitingBeginTime(), "yyyy-MM-dd HH:mm:ss"));
|
||||
remoteVisitor.setVistorEndTime(DateUtil.format(visitor.getVisitingEndTime(), "yyyy-MM-dd HH:mm:ss"));
|
||||
remoteVisitor.setVisitorFaceImg(visitor.getFacePictures());
|
||||
return remoteVisitorService.syncE8PlatVisitor(remoteVisitor);
|
||||
}
|
||||
|
||||
/**
|
||||
* 修改访客管理
|
||||
*
|
||||
|
@@ -0,0 +1,7 @@
|
||||
<?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="org.dromara.property.mapper.FaqManagementMapper">
|
||||
|
||||
</mapper>
|
@@ -139,4 +139,5 @@ public class SisAccessControlController extends BaseController {
|
||||
}
|
||||
|
||||
|
||||
|
||||
}
|
||||
|
@@ -47,6 +47,16 @@ public class SisAlarmEventAttachmentsController extends BaseController {
|
||||
return sisAlarmEventAttachmentsService.queryPageList(bo, pageQuery);
|
||||
}
|
||||
|
||||
/**
|
||||
* 查询【请填写功能名称】列表
|
||||
*/
|
||||
@SaCheckPermission("system:alarmEventAttachments:list")
|
||||
@GetMapping("/query/{alarmId}")
|
||||
public R<List<SisAlarmEventAttachmentsVo>> queryListByAlarmId(@PathVariable("alarmId") String alarmId) {
|
||||
return R.ok(sisAlarmEventAttachmentsService.queryListByAlarmId(alarmId));
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* 导出【请填写功能名称】列表
|
||||
*/
|
||||
|
@@ -0,0 +1,106 @@
|
||||
package org.dromara.sis.controller;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
import lombok.RequiredArgsConstructor;
|
||||
import jakarta.servlet.http.HttpServletResponse;
|
||||
import jakarta.validation.constraints.*;
|
||||
import cn.dev33.satoken.annotation.SaCheckPermission;
|
||||
import org.springframework.web.bind.annotation.*;
|
||||
import org.springframework.validation.annotation.Validated;
|
||||
import org.dromara.common.idempotent.annotation.RepeatSubmit;
|
||||
import org.dromara.common.log.annotation.Log;
|
||||
import org.dromara.common.web.core.BaseController;
|
||||
import org.dromara.common.mybatis.core.page.PageQuery;
|
||||
import org.dromara.common.core.domain.R;
|
||||
import org.dromara.common.core.validate.AddGroup;
|
||||
import org.dromara.common.core.validate.EditGroup;
|
||||
import org.dromara.common.log.enums.BusinessType;
|
||||
import org.dromara.common.excel.utils.ExcelUtil;
|
||||
import org.dromara.sis.domain.vo.SisAlarmEventProcessVo;
|
||||
import org.dromara.sis.domain.bo.SisAlarmEventProcessBo;
|
||||
import org.dromara.sis.service.ISisAlarmEventProcessService;
|
||||
import org.dromara.common.mybatis.core.page.TableDataInfo;
|
||||
|
||||
/**
|
||||
* 告警信息处理流程记录
|
||||
* 前端访问路由地址为:/sis/alarmEventProcess
|
||||
*
|
||||
* @author lxj
|
||||
* @date 2025-08-17
|
||||
*/
|
||||
@Validated
|
||||
@RequiredArgsConstructor
|
||||
@RestController
|
||||
@RequestMapping("/alarmEventProcess")
|
||||
public class SisAlarmEventProcessController extends BaseController {
|
||||
|
||||
private final ISisAlarmEventProcessService sisAlarmEventProcessService;
|
||||
|
||||
/**
|
||||
* 查询告警信息处理流程记录列表
|
||||
*/
|
||||
@SaCheckPermission("sis:alarmEventProcess:list")
|
||||
@GetMapping("/list")
|
||||
public TableDataInfo<SisAlarmEventProcessVo> list(SisAlarmEventProcessBo bo, PageQuery pageQuery) {
|
||||
return sisAlarmEventProcessService.queryPageList(bo, pageQuery);
|
||||
}
|
||||
|
||||
/**
|
||||
* 导出告警信息处理流程记录列表
|
||||
*/
|
||||
@SaCheckPermission("sis:alarmEventProcess:export")
|
||||
@Log(title = "告警信息处理流程记录", businessType = BusinessType.EXPORT)
|
||||
@PostMapping("/export")
|
||||
public void export(SisAlarmEventProcessBo bo, HttpServletResponse response) {
|
||||
List<SisAlarmEventProcessVo> list = sisAlarmEventProcessService.queryList(bo);
|
||||
ExcelUtil.exportExcel(list, "告警信息处理流程记录", SisAlarmEventProcessVo.class, response);
|
||||
}
|
||||
|
||||
/**
|
||||
* 获取告警信息处理流程记录详细信息
|
||||
*
|
||||
* @param id 主键
|
||||
*/
|
||||
@SaCheckPermission("sis:alarmEventProcess:query")
|
||||
@GetMapping("/{id}")
|
||||
public R<SisAlarmEventProcessVo> getInfo(@NotNull(message = "主键不能为空")
|
||||
@PathVariable("id") Long id) {
|
||||
return R.ok(sisAlarmEventProcessService.queryById(id));
|
||||
}
|
||||
|
||||
/**
|
||||
* 新增告警信息处理流程记录
|
||||
*/
|
||||
@SaCheckPermission("sis:alarmEventProcess:add")
|
||||
@Log(title = "告警信息处理流程记录", businessType = BusinessType.INSERT)
|
||||
@RepeatSubmit()
|
||||
@PostMapping()
|
||||
public R<Void> add(@Validated(AddGroup.class) @RequestBody SisAlarmEventProcessBo bo) {
|
||||
return toAjax(sisAlarmEventProcessService.insertByBo(bo));
|
||||
}
|
||||
|
||||
/**
|
||||
* 修改告警信息处理流程记录
|
||||
*/
|
||||
@SaCheckPermission("sis:alarmEventProcess:edit")
|
||||
@Log(title = "告警信息处理流程记录", businessType = BusinessType.UPDATE)
|
||||
@RepeatSubmit()
|
||||
@PutMapping()
|
||||
public R<Void> edit(@Validated(EditGroup.class) @RequestBody SisAlarmEventProcessBo bo) {
|
||||
return toAjax(sisAlarmEventProcessService.updateByBo(bo));
|
||||
}
|
||||
|
||||
/**
|
||||
* 删除告警信息处理流程记录
|
||||
*
|
||||
* @param ids 主键串
|
||||
*/
|
||||
@SaCheckPermission("sis:alarmEventProcess:remove")
|
||||
@Log(title = "告警信息处理流程记录", businessType = BusinessType.DELETE)
|
||||
@DeleteMapping("/{ids}")
|
||||
public R<Void> remove(@NotEmpty(message = "主键不能为空")
|
||||
@PathVariable("ids") Long[] ids) {
|
||||
return toAjax(sisAlarmEventProcessService.deleteWithValidByIds(List.of(ids), true));
|
||||
}
|
||||
}
|
@@ -1,26 +1,31 @@
|
||||
package org.dromara.sis.controller;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
import lombok.RequiredArgsConstructor;
|
||||
import jakarta.servlet.http.HttpServletResponse;
|
||||
import jakarta.validation.constraints.*;
|
||||
import cn.dev33.satoken.annotation.SaCheckPermission;
|
||||
import org.springframework.web.bind.annotation.*;
|
||||
import org.springframework.validation.annotation.Validated;
|
||||
import org.dromara.common.idempotent.annotation.RepeatSubmit;
|
||||
import org.dromara.common.log.annotation.Log;
|
||||
import org.dromara.common.web.core.BaseController;
|
||||
import org.dromara.common.mybatis.core.page.PageQuery;
|
||||
import jakarta.servlet.http.HttpServletResponse;
|
||||
import jakarta.validation.constraints.NotEmpty;
|
||||
import jakarta.validation.constraints.NotNull;
|
||||
import lombok.RequiredArgsConstructor;
|
||||
import org.dromara.common.core.domain.R;
|
||||
import org.dromara.common.core.validate.AddGroup;
|
||||
import org.dromara.common.core.validate.EditGroup;
|
||||
import org.dromara.common.log.enums.BusinessType;
|
||||
import org.dromara.common.excel.utils.ExcelUtil;
|
||||
import org.dromara.sis.domain.vo.SisAlarmEventsVo;
|
||||
import org.dromara.sis.domain.bo.SisAlarmEventsBo;
|
||||
import org.dromara.sis.service.ISisAlarmEventsService;
|
||||
import org.dromara.common.idempotent.annotation.RepeatSubmit;
|
||||
import org.dromara.common.log.annotation.Log;
|
||||
import org.dromara.common.log.enums.BusinessType;
|
||||
import org.dromara.common.mybatis.core.page.PageQuery;
|
||||
import org.dromara.common.mybatis.core.page.TableDataInfo;
|
||||
import org.dromara.common.satoken.utils.LoginHelper;
|
||||
import org.dromara.common.web.core.BaseController;
|
||||
import org.dromara.sis.domain.bo.SisAlarmEventsBo;
|
||||
import org.dromara.sis.domain.bo.alarm.AlarmAssignmentBo;
|
||||
import org.dromara.sis.domain.bo.alarm.AlarmCompleteBo;
|
||||
import org.dromara.sis.domain.vo.SisAlarmEventsVo;
|
||||
import org.dromara.sis.service.ISisAlarmEventsService;
|
||||
import org.dromara.system.api.model.LoginUser;
|
||||
import org.springframework.validation.annotation.Validated;
|
||||
import org.springframework.web.bind.annotation.*;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* 告警
|
||||
@@ -46,6 +51,18 @@ public class SisAlarmEventsController extends BaseController {
|
||||
return sisAlarmEventsService.queryPageList(bo, pageQuery);
|
||||
}
|
||||
|
||||
/**
|
||||
* 查询告警列表
|
||||
*/
|
||||
@SaCheckPermission("sis:alarmEvents:list")
|
||||
@GetMapping("/list/curr")
|
||||
public TableDataInfo<SisAlarmEventsVo> listCurr(SisAlarmEventsBo bo, PageQuery pageQuery) {
|
||||
LoginUser loginUser = LoginHelper.getLoginUser();
|
||||
bo.setSolveId(loginUser.getUserId());
|
||||
return sisAlarmEventsService.queryPageListCurr(bo, pageQuery);
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* 导出告警列表
|
||||
*/
|
||||
@@ -103,4 +120,46 @@ public class SisAlarmEventsController extends BaseController {
|
||||
@PathVariable("ids") Long[] ids) {
|
||||
return toAjax(sisAlarmEventsService.deleteWithValidByIds(List.of(ids), true));
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* 告警任务指派
|
||||
*
|
||||
* @param bo 指派参数
|
||||
*/
|
||||
@SaCheckPermission("sis:alarmEvents:edit")
|
||||
@Log(title = "告警任务指派", businessType = BusinessType.UPDATE)
|
||||
@RepeatSubmit()
|
||||
@PostMapping("/assignment")
|
||||
public R<Void> taskAssignment(@Validated @RequestBody AlarmAssignmentBo bo) {
|
||||
return toAjax(sisAlarmEventsService.taskAssignment(bo));
|
||||
}
|
||||
|
||||
/**
|
||||
* 告警处理完成
|
||||
*
|
||||
* @param bo 完成参数
|
||||
*/
|
||||
@SaCheckPermission("sis:alarmEvents:edit")
|
||||
@Log(title = "告警处理完成", businessType = BusinessType.UPDATE)
|
||||
@RepeatSubmit()
|
||||
@PostMapping("/complete")
|
||||
public R<Void> complete(@Validated @RequestBody AlarmCompleteBo bo) {
|
||||
return toAjax(sisAlarmEventsService.complete(bo));
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* 分页查询当前用的告警处理任务
|
||||
*
|
||||
* @param bo 查询参数
|
||||
* @return 返回当前用户要处理的告警任务
|
||||
*/
|
||||
@RepeatSubmit()
|
||||
@PutMapping("/query/curr/assignment")
|
||||
public TableDataInfo<SisAlarmEventsVo> queryCurrAssignment(@Validated @RequestBody SisAlarmEventsBo bo, PageQuery pageQuery) {
|
||||
return sisAlarmEventsService.queryCurrAssignment(bo, pageQuery);
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
@@ -0,0 +1,68 @@
|
||||
package org.dromara.sis.domain;
|
||||
|
||||
import com.baomidou.mybatisplus.annotation.TableId;
|
||||
import com.baomidou.mybatisplus.annotation.TableName;
|
||||
import lombok.Data;
|
||||
import lombok.EqualsAndHashCode;
|
||||
import org.dromara.common.tenant.core.TenantEntity;
|
||||
|
||||
import java.io.Serial;
|
||||
import java.util.Date;
|
||||
|
||||
/**
|
||||
* 告警信息处理流程记录对象 sis_alarm_event_process
|
||||
*
|
||||
* @author lxj
|
||||
* @date 2025-08-17
|
||||
*/
|
||||
@Data
|
||||
@EqualsAndHashCode(callSuper = true)
|
||||
@TableName("sis_alarm_event_process")
|
||||
public class SisAlarmEventProcess extends TenantEntity {
|
||||
|
||||
@Serial
|
||||
private static final long serialVersionUID = 1L;
|
||||
|
||||
/**
|
||||
* 主键id
|
||||
*/
|
||||
@TableId(value = "id")
|
||||
private Long id;
|
||||
|
||||
/**
|
||||
* 告警记录主键id
|
||||
*/
|
||||
private Long alarmId;
|
||||
|
||||
/**
|
||||
* 指派人员id
|
||||
*/
|
||||
private Long solveId;
|
||||
|
||||
/**
|
||||
* 指派人员名称
|
||||
*/
|
||||
private String solveName;
|
||||
|
||||
/**
|
||||
* 此次处理的状态码
|
||||
*/
|
||||
private Integer state;
|
||||
|
||||
/**
|
||||
* 工单问题回复内容
|
||||
*/
|
||||
private String workReply;
|
||||
|
||||
/**
|
||||
* 处理时间
|
||||
*/
|
||||
private Date workReplyTime;
|
||||
|
||||
/**
|
||||
* 是否已接受任务 0:未接收;1:已接收
|
||||
*/
|
||||
private Long receiveTaskTag;
|
||||
|
||||
|
||||
}
|
@@ -72,12 +72,12 @@ public class SisAlarmEvents extends TenantEntity {
|
||||
/**
|
||||
* 开始处理时间
|
||||
*/
|
||||
private Date processSt;
|
||||
private Date servBeginTime;
|
||||
|
||||
/**
|
||||
* 结束处理时间
|
||||
*/
|
||||
private Date processEt;
|
||||
private Date servEndTime;
|
||||
|
||||
/**
|
||||
* 事件状态
|
||||
@@ -89,4 +89,42 @@ public class SisAlarmEvents extends TenantEntity {
|
||||
*/
|
||||
private Long workOrderId;
|
||||
|
||||
/**
|
||||
* 当前处理人id
|
||||
*/
|
||||
private Long solveId;
|
||||
|
||||
/**
|
||||
* 当前处理人名称
|
||||
*/
|
||||
private String solveName;
|
||||
|
||||
/**
|
||||
* 处理人电话
|
||||
*/
|
||||
private String solvePhone;
|
||||
|
||||
/**
|
||||
* 处理人邮箱
|
||||
*/
|
||||
private String solveEmail;
|
||||
|
||||
/**
|
||||
* 任务接受时间
|
||||
*/
|
||||
private Date acceptTime;
|
||||
|
||||
/**
|
||||
* 任务处理时间
|
||||
*/
|
||||
private Date solveTime;
|
||||
|
||||
|
||||
/**
|
||||
* 任务完成时间
|
||||
*/
|
||||
private Date finishTime;
|
||||
|
||||
private String description;
|
||||
|
||||
}
|
||||
|
@@ -71,7 +71,7 @@ public class SisPersonLibImg extends TenantEntity {
|
||||
/**
|
||||
* 远程库图像ID
|
||||
*/
|
||||
private Long remoteHWId;
|
||||
private Long remoteHwId;
|
||||
|
||||
/**
|
||||
* 入驻员工id
|
||||
|
@@ -0,0 +1,70 @@
|
||||
package org.dromara.sis.domain.bo;
|
||||
|
||||
import io.github.linpeilie.annotations.AutoMapper;
|
||||
import jakarta.validation.constraints.NotNull;
|
||||
import lombok.Data;
|
||||
import lombok.EqualsAndHashCode;
|
||||
import org.dromara.common.core.validate.AddGroup;
|
||||
import org.dromara.common.core.validate.EditGroup;
|
||||
import org.dromara.common.mybatis.core.domain.BaseEntity;
|
||||
import org.dromara.sis.domain.SisAlarmEventProcess;
|
||||
|
||||
import java.util.Date;
|
||||
|
||||
/**
|
||||
* 告警信息处理流程记录业务对象 sis_alarm_event_process
|
||||
*
|
||||
* @author lxj
|
||||
* @date 2025-08-17
|
||||
*/
|
||||
@Data
|
||||
@EqualsAndHashCode(callSuper = true)
|
||||
@AutoMapper(target = SisAlarmEventProcess.class, reverseConvertGenerate = false)
|
||||
public class SisAlarmEventProcessBo extends BaseEntity {
|
||||
|
||||
/**
|
||||
* 主键id
|
||||
*/
|
||||
@NotNull(message = "主键id不能为空", groups = {EditGroup.class})
|
||||
private Long id;
|
||||
|
||||
/**
|
||||
* 告警记录主键id
|
||||
*/
|
||||
@NotNull(message = "告警记录主键id不能为空", groups = {AddGroup.class, EditGroup.class})
|
||||
private Long alarmId;
|
||||
|
||||
/**
|
||||
* 指派人员id
|
||||
*/
|
||||
@NotNull(message = "指派人员id不能为空", groups = {AddGroup.class, EditGroup.class})
|
||||
private Long solveId;
|
||||
|
||||
/**
|
||||
* 指派人员名称
|
||||
*/
|
||||
private String solveName;
|
||||
|
||||
/**
|
||||
* 工单问题回复内容
|
||||
*/
|
||||
private String workReply;
|
||||
|
||||
/**
|
||||
* 处理时间
|
||||
*/
|
||||
private Date workReplyTime;
|
||||
|
||||
/**
|
||||
* 是否已接受任务 0:未接收;1:已接收
|
||||
*/
|
||||
@NotNull(message = "是否已接受任务 0:未接收;1:已接收不能为空", groups = {AddGroup.class, EditGroup.class})
|
||||
private Long receiveTaskTag;
|
||||
|
||||
/**
|
||||
* 此次处理的状态码
|
||||
*/
|
||||
private Integer state;
|
||||
|
||||
|
||||
}
|
@@ -10,6 +10,7 @@ import org.dromara.common.mybatis.core.domain.BaseEntity;
|
||||
import org.dromara.sis.domain.SisAlarmEvents;
|
||||
|
||||
import java.util.Date;
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* 告警业务对象 sis_alarm_events
|
||||
@@ -73,12 +74,12 @@ public class SisAlarmEventsBo extends BaseEntity {
|
||||
/**
|
||||
* 开始处理时间
|
||||
*/
|
||||
private Date processSt;
|
||||
private Date servBeginTime;
|
||||
|
||||
/**
|
||||
* 结束处理时间
|
||||
*/
|
||||
private Date processEt;
|
||||
private Date servEndTime;
|
||||
|
||||
|
||||
/**
|
||||
@@ -86,9 +87,40 @@ public class SisAlarmEventsBo extends BaseEntity {
|
||||
*/
|
||||
private Integer state;
|
||||
|
||||
/**
|
||||
* 状态列表
|
||||
*/
|
||||
private List<Integer> states;
|
||||
/**
|
||||
* 工单id
|
||||
*/
|
||||
private Long workOrderId;
|
||||
|
||||
/**
|
||||
* 当前处理人id
|
||||
*/
|
||||
private Long solveId;
|
||||
|
||||
/**
|
||||
* 当前处理人名称
|
||||
*/
|
||||
private String solveName;
|
||||
|
||||
/**
|
||||
* 任务接受时间
|
||||
*/
|
||||
private Date acceptTime;
|
||||
|
||||
/**
|
||||
* 任务处理时间
|
||||
*/
|
||||
private Date solveTime;
|
||||
|
||||
|
||||
/**
|
||||
* 任务完成时间
|
||||
*/
|
||||
private Date finishTime;
|
||||
|
||||
private String description;
|
||||
}
|
||||
|
@@ -9,8 +9,6 @@ import lombok.Data;
|
||||
import lombok.EqualsAndHashCode;
|
||||
import jakarta.validation.constraints.*;
|
||||
|
||||
import java.util.Collection;
|
||||
|
||||
/**
|
||||
* 人像信息业务对象 tb_person_lib_img
|
||||
*
|
||||
@@ -79,7 +77,7 @@ public class SisPersonLibImgBo extends BaseEntity {
|
||||
/**
|
||||
* 远程库图像ID
|
||||
*/
|
||||
private Long remoteHWId;
|
||||
private Long remoteHwId;
|
||||
|
||||
/**
|
||||
* 入驻员工id
|
||||
|
@@ -0,0 +1,60 @@
|
||||
package org.dromara.sis.domain.bo.alarm;
|
||||
|
||||
import jakarta.validation.constraints.NotNull;
|
||||
import lombok.Data;
|
||||
|
||||
/**
|
||||
* 任务指派参数
|
||||
*
|
||||
* @author lxj
|
||||
*/
|
||||
@Data
|
||||
public class AlarmAssignmentBo {
|
||||
|
||||
/**
|
||||
* 告警任务id
|
||||
*/
|
||||
@NotNull
|
||||
private Long alarmId;
|
||||
|
||||
/**
|
||||
* 处理人id
|
||||
*/
|
||||
@NotNull
|
||||
private Long solveId;
|
||||
|
||||
/**
|
||||
* 指派人员信息
|
||||
*/
|
||||
private String solveName;
|
||||
|
||||
/**
|
||||
* 处理人电话
|
||||
*/
|
||||
private String solvePhone;
|
||||
|
||||
/**
|
||||
* 处理人邮箱
|
||||
*/
|
||||
private String solveEmail;
|
||||
|
||||
/**
|
||||
* 指派备注
|
||||
*/
|
||||
private String remark;
|
||||
|
||||
/**
|
||||
* 任务指派操作人员id
|
||||
*/
|
||||
private Long modifyUserId;
|
||||
|
||||
/**
|
||||
* 任务指派操作人员姓名
|
||||
*/
|
||||
private String modifyUserName;
|
||||
|
||||
/**
|
||||
* 任务指派操作人员部门id
|
||||
*/
|
||||
private Long modifyDeptId;
|
||||
}
|
@@ -0,0 +1,29 @@
|
||||
package org.dromara.sis.domain.bo.alarm;
|
||||
|
||||
|
||||
import jakarta.validation.constraints.NotNull;
|
||||
import lombok.Data;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
@Data
|
||||
public class AlarmCompleteBo {
|
||||
|
||||
/**
|
||||
* 告警任务id
|
||||
*/
|
||||
@NotNull
|
||||
private Long alarmId;
|
||||
|
||||
/**
|
||||
* 任务备注信息
|
||||
*/
|
||||
private String remark;
|
||||
|
||||
/**
|
||||
* 附件信息(任务完成上传的图片或者文件)
|
||||
*/
|
||||
private List<String> attachments;
|
||||
|
||||
|
||||
}
|
@@ -4,6 +4,8 @@ import cn.idev.excel.annotation.ExcelIgnoreUnannotated;
|
||||
import cn.idev.excel.annotation.ExcelProperty;
|
||||
import io.github.linpeilie.annotations.AutoMapper;
|
||||
import lombok.Data;
|
||||
import org.dromara.common.translation.annotation.Translation;
|
||||
import org.dromara.common.translation.constant.TransConstant;
|
||||
import org.dromara.sis.domain.SisAlarmEventAttachments;
|
||||
|
||||
import java.io.Serial;
|
||||
@@ -42,6 +44,10 @@ public class SisAlarmEventAttachmentsVo implements Serializable {
|
||||
@ExcelProperty(value = "时间图片id")
|
||||
private Long ossId;
|
||||
|
||||
@Translation(type = TransConstant.OSS_ID_TO_URL, mapper = "ossId")
|
||||
private String imagePath;
|
||||
|
||||
|
||||
/**
|
||||
* 1:图片,2:文件;3视频
|
||||
*/
|
||||
|
@@ -0,0 +1,80 @@
|
||||
package org.dromara.sis.domain.vo;
|
||||
|
||||
import java.util.Date;
|
||||
import com.fasterxml.jackson.annotation.JsonFormat;
|
||||
import org.dromara.sis.domain.SisAlarmEventProcess;
|
||||
import cn.idev.excel.annotation.ExcelIgnoreUnannotated;
|
||||
import cn.idev.excel.annotation.ExcelProperty;
|
||||
import org.dromara.common.excel.annotation.ExcelDictFormat;
|
||||
import org.dromara.common.excel.convert.ExcelDictConvert;
|
||||
import io.github.linpeilie.annotations.AutoMapper;
|
||||
import lombok.Data;
|
||||
|
||||
import java.io.Serial;
|
||||
import java.io.Serializable;
|
||||
import java.util.Date;
|
||||
|
||||
|
||||
|
||||
/**
|
||||
* 告警信息处理流程记录视图对象 sis_alarm_event_process
|
||||
*
|
||||
* @author lxj
|
||||
* @date 2025-08-17
|
||||
*/
|
||||
@Data
|
||||
@ExcelIgnoreUnannotated
|
||||
@AutoMapper(target = SisAlarmEventProcess.class)
|
||||
public class SisAlarmEventProcessVo implements Serializable {
|
||||
|
||||
@Serial
|
||||
private static final long serialVersionUID = 1L;
|
||||
|
||||
/**
|
||||
* 主键id
|
||||
*/
|
||||
@ExcelProperty(value = "主键id")
|
||||
private Long id;
|
||||
|
||||
/**
|
||||
* 告警记录主键id
|
||||
*/
|
||||
@ExcelProperty(value = "告警记录主键id")
|
||||
private Long alarmId;
|
||||
|
||||
/**
|
||||
* 指派人员id
|
||||
*/
|
||||
@ExcelProperty(value = "指派人员id")
|
||||
private Long solveId;
|
||||
|
||||
/**
|
||||
* 指派人员名称
|
||||
*/
|
||||
@ExcelProperty(value = "指派人员名称")
|
||||
private String solveName;
|
||||
|
||||
/**
|
||||
* 工单问题回复内容
|
||||
*/
|
||||
@ExcelProperty(value = "工单问题回复内容")
|
||||
private String workReply;
|
||||
|
||||
/**
|
||||
* 处理时间
|
||||
*/
|
||||
@ExcelProperty(value = "处理时间")
|
||||
private Date workReplyTime;
|
||||
|
||||
/**
|
||||
* 是否已接受任务 0:未接收;1:已接收
|
||||
*/
|
||||
@ExcelProperty(value = "是否已接受任务 0:未接收;1:已接收")
|
||||
private Long receiveTaskTag;
|
||||
|
||||
/**
|
||||
* 此次处理的状态码
|
||||
*/
|
||||
private Integer state;
|
||||
|
||||
}
|
@@ -1,23 +1,18 @@
|
||||
package org.dromara.sis.domain.vo;
|
||||
|
||||
import java.util.Date;
|
||||
import com.fasterxml.jackson.annotation.JsonFormat;
|
||||
import cn.idev.excel.annotation.ExcelIgnoreUnannotated;
|
||||
import cn.idev.excel.annotation.ExcelProperty;
|
||||
import io.github.linpeilie.annotations.AutoMapper;
|
||||
import lombok.Data;
|
||||
import org.dromara.common.translation.annotation.Translation;
|
||||
import org.dromara.common.translation.constant.TransConstant;
|
||||
import org.dromara.sis.domain.SisAlarmEvents;
|
||||
import cn.idev.excel.annotation.ExcelIgnoreUnannotated;
|
||||
import cn.idev.excel.annotation.ExcelProperty;
|
||||
import org.dromara.common.excel.annotation.ExcelDictFormat;
|
||||
import org.dromara.common.excel.convert.ExcelDictConvert;
|
||||
import io.github.linpeilie.annotations.AutoMapper;
|
||||
import lombok.Data;
|
||||
|
||||
import java.io.Serial;
|
||||
import java.io.Serializable;
|
||||
import java.util.Date;
|
||||
|
||||
|
||||
|
||||
/**
|
||||
* 告警视图对象 sis_alarm_events
|
||||
*
|
||||
@@ -92,12 +87,12 @@ public class SisAlarmEventsVo implements Serializable {
|
||||
/**
|
||||
* 开始处理时间
|
||||
*/
|
||||
private Date processSt;
|
||||
private Date servBeginTime;
|
||||
|
||||
/**
|
||||
* 结束处理时间
|
||||
*/
|
||||
private Date processEt;
|
||||
private Date servEndTime;
|
||||
|
||||
/**
|
||||
* 事件状态
|
||||
@@ -111,4 +106,43 @@ public class SisAlarmEventsVo implements Serializable {
|
||||
* 工单id
|
||||
*/
|
||||
private Long workOrderId;
|
||||
|
||||
/**
|
||||
* 当前处理人id
|
||||
*/
|
||||
private Long solveId;
|
||||
|
||||
/**
|
||||
* 当前处理人名称
|
||||
*/
|
||||
private String solveName;
|
||||
|
||||
/**
|
||||
* 处理人电话
|
||||
*/
|
||||
private String solvePhone;
|
||||
|
||||
/**
|
||||
* 处理人邮箱
|
||||
*/
|
||||
private String solveEmail;
|
||||
|
||||
/**
|
||||
* 任务接受时间
|
||||
*/
|
||||
private Date acceptTime;
|
||||
|
||||
/**
|
||||
* 任务处理时间
|
||||
*/
|
||||
private Date solveTime;
|
||||
|
||||
private Date createTime;
|
||||
|
||||
/**
|
||||
* 任务完成时间
|
||||
*/
|
||||
private Date finishTime;
|
||||
|
||||
private String description;
|
||||
}
|
||||
|
@@ -8,7 +8,6 @@ import org.dromara.sis.domain.SisPersonLibImg;
|
||||
|
||||
import java.io.Serial;
|
||||
import java.io.Serializable;
|
||||
import java.util.Collection;
|
||||
|
||||
|
||||
/**
|
||||
@@ -83,7 +82,7 @@ public class SisPersonLibImgVo implements Serializable {
|
||||
* 远程库图像ID
|
||||
*/
|
||||
@ExcelProperty(value = "远程库图像ID")
|
||||
private Long remoteHWId;
|
||||
private Long remoteHwId;
|
||||
|
||||
/**
|
||||
* 入驻员工id
|
||||
|
@@ -70,7 +70,6 @@ public class RemoteSisAuthServiceImpl implements RemoteSisAuthService {
|
||||
return sisAuthRecordService.deleteByPersonIds(ids, e8Ids);
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* 查询人员授权信息
|
||||
*
|
||||
@@ -93,7 +92,7 @@ public class RemoteSisAuthServiceImpl implements RemoteSisAuthService {
|
||||
@Override
|
||||
public Long queryHuaweiBoxIdByImgMd5(String imgMd5) {
|
||||
SisPersonLibImgVo vo = sisPersonLibImgService.queryByImgMd5(imgMd5);
|
||||
return vo != null ? vo.getRemoteHWId() : null;
|
||||
return vo != null ? vo.getRemoteHwId() : null;
|
||||
}
|
||||
|
||||
/**
|
||||
|
@@ -0,0 +1,60 @@
|
||||
package org.dromara.sis.dubbo;
|
||||
|
||||
import cn.hutool.core.lang.Assert;
|
||||
import lombok.RequiredArgsConstructor;
|
||||
import lombok.extern.slf4j.Slf4j;
|
||||
import org.apache.dubbo.config.annotation.DubboReference;
|
||||
import org.apache.dubbo.config.annotation.DubboService;
|
||||
import org.dromara.resource.api.RemoteFileService;
|
||||
import org.dromara.sis.api.RemoteVisitorService;
|
||||
import org.dromara.sis.api.domain.RemoteVisitor;
|
||||
import org.dromara.sis.sdk.e8.E8PlatformApi;
|
||||
import org.dromara.sis.sdk.e8.domain.visitors.req.VisitorAddReq;
|
||||
import org.dromara.sis.sdk.e8.domain.visitors.res.VisitorAddRes;
|
||||
|
||||
/**
|
||||
* @author lsm
|
||||
* @apiNote RemoteVisitorServiceImpl
|
||||
* @since 2025/8/18
|
||||
*/
|
||||
@Slf4j
|
||||
@DubboService
|
||||
@RequiredArgsConstructor
|
||||
public class RemoteVisitorServiceImpl implements RemoteVisitorService {
|
||||
|
||||
private final E8PlatformApi e8PlatformApi;
|
||||
|
||||
@DubboReference
|
||||
private RemoteFileService fileService;
|
||||
|
||||
/**
|
||||
* 访客信息写入E8平台
|
||||
*
|
||||
* @param visitor 访客信息
|
||||
* @return 访客ID
|
||||
*/
|
||||
@Override
|
||||
public Long syncE8PlatVisitor(RemoteVisitor visitor) {
|
||||
try {
|
||||
byte[] imgByte = fileService.downloadToByteArray(Long.parseLong(visitor.getVisitorFaceImg()));
|
||||
Assert.notNull(imgByte,"下载访客照片失败");
|
||||
|
||||
String imgUrl = e8PlatformApi.uploadFace(imgByte);
|
||||
Assert.notNull(imgUrl, "e8平台上传访客照片失败");
|
||||
|
||||
VisitorAddReq req = new VisitorAddReq();
|
||||
req.setVisitorName(visitor.getVisitorName());
|
||||
req.setMobilePhone(visitor.getMobilePhone());
|
||||
req.setIntervieweeMobile(visitor.getIntervieweeMobile());
|
||||
req.setVisitorStartTime(visitor.getVisitorStartTime());
|
||||
req.setVistorEndTime(visitor.getVistorEndTime());
|
||||
req.setVisitorFaceImg(imgUrl);
|
||||
VisitorAddRes res = e8PlatformApi.addVisitor(req);
|
||||
Assert.notNull(res, "e8平台新增访客登记失败");
|
||||
return res.getId();
|
||||
} catch (Exception e) {
|
||||
log.info(e.getMessage());
|
||||
return null;
|
||||
}
|
||||
}
|
||||
}
|
@@ -0,0 +1,15 @@
|
||||
package org.dromara.sis.mapper;
|
||||
|
||||
import org.dromara.sis.domain.SisAlarmEventProcess;
|
||||
import org.dromara.sis.domain.vo.SisAlarmEventProcessVo;
|
||||
import org.dromara.common.mybatis.core.mapper.BaseMapperPlus;
|
||||
|
||||
/**
|
||||
* 告警信息处理流程记录Mapper接口
|
||||
*
|
||||
* @author lxj
|
||||
* @date 2025-08-17
|
||||
*/
|
||||
public interface SisAlarmEventProcessMapper extends BaseMapperPlus<SisAlarmEventProcess, SisAlarmEventProcessVo> {
|
||||
|
||||
}
|
@@ -14,10 +14,7 @@ import java.io.IOException;
|
||||
* @since 2025/8/8
|
||||
*/
|
||||
@Slf4j
|
||||
@Component
|
||||
public class ElevatorTcpRunner implements ApplicationRunner {
|
||||
|
||||
@Override
|
||||
public class ElevatorTcpRunner{
|
||||
public void run(ApplicationArguments args) {
|
||||
// 获取单例实例
|
||||
ElevatorControlTcpUtil elevatorHelper = ElevatorControlTcpUtil.getInstance();
|
||||
|
@@ -35,6 +35,11 @@ public class VisitorAddReq {
|
||||
*/
|
||||
private String vistorEndTime;
|
||||
|
||||
/**
|
||||
* 访客人脸照
|
||||
*/
|
||||
private String visitorFaceImg;
|
||||
|
||||
/**
|
||||
* 访客登记类型 0:登记 1:邀请 2:预约
|
||||
*/
|
||||
|
@@ -280,12 +280,9 @@ public class HikAlarmCallBack implements HCNetSDK.FMSGCallBack_V31 {
|
||||
buffers1.get(bigImg);
|
||||
//设备ip
|
||||
String sAlarmInfo = new String(pAlarmer.sDeviceIP).trim();
|
||||
SisDeviceManage device = sisDeviceManageService.queryByDeviceIp(sAlarmInfo);
|
||||
if (!device.getIsComparison()) {
|
||||
log.info("海康设备告警信息上传,设备={}, 人脸图片大小={}, 背景图片大小={}", sAlarmInfo, smallImg.length, bigImg.length);
|
||||
zeroSensationPassageService.pass(sAlarmInfo, smallImg, bigImg);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* 处理人脸比对上报
|
||||
@@ -320,7 +317,6 @@ public class HikAlarmCallBack implements HCNetSDK.FMSGCallBack_V31 {
|
||||
|
||||
log.info("比对结果:{},相似度:{},人员:{},id:{}", compareResults, similarity, name, pid);
|
||||
log.info("处理前置人脸比对结果,耗时:{}", interval.interval());
|
||||
zeroSensationPassageService.handleEleOut(new String(pAlarmer.sDeviceIP).trim());
|
||||
}
|
||||
|
||||
|
||||
|
@@ -75,4 +75,11 @@ public interface ISisAlarmEventAttachmentsService {
|
||||
*/
|
||||
Boolean batchInsert(List<SisAlarmEventAttachments> ls);
|
||||
|
||||
/**
|
||||
* 通过告警id 查询告警附件信息
|
||||
* @param alarmId 告警id
|
||||
* @return 返回附件列表
|
||||
*/
|
||||
List<SisAlarmEventAttachmentsVo> queryListByAlarmId(String alarmId);
|
||||
|
||||
}
|
||||
|
@@ -0,0 +1,77 @@
|
||||
package org.dromara.sis.service;
|
||||
|
||||
import org.dromara.common.mybatis.core.page.PageQuery;
|
||||
import org.dromara.common.mybatis.core.page.TableDataInfo;
|
||||
import org.dromara.sis.domain.SisAlarmEventProcess;
|
||||
import org.dromara.sis.domain.bo.SisAlarmEventProcessBo;
|
||||
import org.dromara.sis.domain.vo.SisAlarmEventProcessVo;
|
||||
|
||||
import java.util.Collection;
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* 告警信息处理流程记录Service接口
|
||||
*
|
||||
* @author lxj
|
||||
* @date 2025-08-17
|
||||
*/
|
||||
public interface ISisAlarmEventProcessService {
|
||||
|
||||
/**
|
||||
* 查询告警信息处理流程记录
|
||||
*
|
||||
* @param id 主键
|
||||
* @return 告警信息处理流程记录
|
||||
*/
|
||||
SisAlarmEventProcessVo queryById(Long id);
|
||||
|
||||
/**
|
||||
* 分页查询告警信息处理流程记录列表
|
||||
*
|
||||
* @param bo 查询条件
|
||||
* @param pageQuery 分页参数
|
||||
* @return 告警信息处理流程记录分页列表
|
||||
*/
|
||||
TableDataInfo<SisAlarmEventProcessVo> queryPageList(SisAlarmEventProcessBo bo, PageQuery pageQuery);
|
||||
|
||||
/**
|
||||
* 查询符合条件的告警信息处理流程记录列表
|
||||
*
|
||||
* @param bo 查询条件
|
||||
* @return 告警信息处理流程记录列表
|
||||
*/
|
||||
List<SisAlarmEventProcessVo> queryList(SisAlarmEventProcessBo bo);
|
||||
|
||||
/**
|
||||
* 新增告警信息处理流程记录
|
||||
*
|
||||
* @param bo 告警信息处理流程记录
|
||||
* @return 是否新增成功
|
||||
*/
|
||||
Boolean insertByBo(SisAlarmEventProcessBo bo);
|
||||
|
||||
/**
|
||||
* 修改告警信息处理流程记录
|
||||
*
|
||||
* @param bo 告警信息处理流程记录
|
||||
* @return 是否修改成功
|
||||
*/
|
||||
Boolean updateByBo(SisAlarmEventProcessBo bo);
|
||||
|
||||
/**
|
||||
* 校验并批量删除告警信息处理流程记录信息
|
||||
*
|
||||
* @param ids 待删除的主键集合
|
||||
* @param isValid 是否进行有效性校验
|
||||
* @return 是否删除成功
|
||||
*/
|
||||
Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid);
|
||||
|
||||
/**
|
||||
* 新增处理信息
|
||||
*
|
||||
* @param process 处理信息
|
||||
* @return 返回是否写入成功
|
||||
*/
|
||||
Boolean insert(SisAlarmEventProcess process);
|
||||
}
|
@@ -3,6 +3,8 @@ package org.dromara.sis.service;
|
||||
import org.dromara.common.mybatis.core.page.PageQuery;
|
||||
import org.dromara.common.mybatis.core.page.TableDataInfo;
|
||||
import org.dromara.sis.domain.bo.SisAlarmEventsBo;
|
||||
import org.dromara.sis.domain.bo.alarm.AlarmAssignmentBo;
|
||||
import org.dromara.sis.domain.bo.alarm.AlarmCompleteBo;
|
||||
import org.dromara.sis.domain.vo.SisAlarmEventsVo;
|
||||
|
||||
import java.util.Collection;
|
||||
@@ -33,6 +35,13 @@ public interface ISisAlarmEventsService {
|
||||
*/
|
||||
TableDataInfo<SisAlarmEventsVo> queryPageList(SisAlarmEventsBo bo, PageQuery pageQuery);
|
||||
|
||||
/**
|
||||
* @param bo 查询条件
|
||||
* @param pageQuery 分页参数
|
||||
* @return 告警分页列表
|
||||
*/
|
||||
TableDataInfo<SisAlarmEventsVo> queryPageListCurr(SisAlarmEventsBo bo, PageQuery pageQuery);
|
||||
|
||||
/**
|
||||
* 查询符合条件的告警列表
|
||||
*
|
||||
@@ -71,4 +80,27 @@ public interface ISisAlarmEventsService {
|
||||
*/
|
||||
void createAlarmRecord(String deviceIp, Integer level, Integer type, String msg, byte[] smallImg, byte[] bigImg);
|
||||
|
||||
/**
|
||||
* 任务分配操作
|
||||
* @param bo 分配参数
|
||||
* @return 返回是否分配成功
|
||||
*/
|
||||
Boolean taskAssignment(AlarmAssignmentBo bo);
|
||||
|
||||
/**
|
||||
* 查询当前用户的告警处理任务
|
||||
* @param bo 查询参数
|
||||
* @param pageQuery 分页参数
|
||||
* @return 返回任务列表
|
||||
*/
|
||||
TableDataInfo<SisAlarmEventsVo> queryCurrAssignment(SisAlarmEventsBo bo, PageQuery pageQuery);
|
||||
|
||||
/**
|
||||
* 任务完成
|
||||
* @param bo 任务完成参数
|
||||
* @return 返回是否成功
|
||||
*/
|
||||
Boolean complete(AlarmCompleteBo bo);
|
||||
|
||||
|
||||
}
|
||||
|
@@ -135,4 +135,12 @@ public class SisAlarmEventAttachmentsServiceImpl implements ISisAlarmEventAttach
|
||||
public Boolean batchInsert(List<SisAlarmEventAttachments> ls) {
|
||||
return baseMapper.insertBatch(ls);
|
||||
}
|
||||
|
||||
|
||||
@Override
|
||||
public List<SisAlarmEventAttachmentsVo> queryListByAlarmId(String alarmId) {
|
||||
LambdaQueryWrapper<SisAlarmEventAttachments> lqw = Wrappers.lambdaQuery();
|
||||
lqw.eq(SisAlarmEventAttachments::getEventId, alarmId);
|
||||
return baseMapper.selectVoList(lqw);
|
||||
}
|
||||
}
|
||||
|
@@ -0,0 +1,142 @@
|
||||
package org.dromara.sis.service.impl;
|
||||
|
||||
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
||||
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
||||
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||
import lombok.RequiredArgsConstructor;
|
||||
import lombok.extern.slf4j.Slf4j;
|
||||
import org.dromara.common.core.utils.MapstructUtils;
|
||||
import org.dromara.common.core.utils.StringUtils;
|
||||
import org.dromara.common.mybatis.core.page.PageQuery;
|
||||
import org.dromara.common.mybatis.core.page.TableDataInfo;
|
||||
import org.dromara.sis.domain.SisAlarmEventProcess;
|
||||
import org.dromara.sis.domain.bo.SisAlarmEventProcessBo;
|
||||
import org.dromara.sis.domain.vo.SisAlarmEventProcessVo;
|
||||
import org.dromara.sis.mapper.SisAlarmEventProcessMapper;
|
||||
import org.dromara.sis.service.ISisAlarmEventProcessService;
|
||||
import org.springframework.stereotype.Service;
|
||||
|
||||
import java.util.Collection;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
/**
|
||||
* 告警信息处理流程记录Service业务层处理
|
||||
*
|
||||
* @author lxj
|
||||
* @date 2025-08-17
|
||||
*/
|
||||
@Slf4j
|
||||
@RequiredArgsConstructor
|
||||
@Service
|
||||
public class SisAlarmEventProcessServiceImpl implements ISisAlarmEventProcessService {
|
||||
|
||||
private final SisAlarmEventProcessMapper baseMapper;
|
||||
|
||||
/**
|
||||
* 查询告警信息处理流程记录
|
||||
*
|
||||
* @param id 主键
|
||||
* @return 告警信息处理流程记录
|
||||
*/
|
||||
@Override
|
||||
public SisAlarmEventProcessVo queryById(Long id) {
|
||||
return baseMapper.selectVoById(id);
|
||||
}
|
||||
|
||||
/**
|
||||
* 分页查询告警信息处理流程记录列表
|
||||
*
|
||||
* @param bo 查询条件
|
||||
* @param pageQuery 分页参数
|
||||
* @return 告警信息处理流程记录分页列表
|
||||
*/
|
||||
@Override
|
||||
public TableDataInfo<SisAlarmEventProcessVo> queryPageList(SisAlarmEventProcessBo bo, PageQuery pageQuery) {
|
||||
LambdaQueryWrapper<SisAlarmEventProcess> lqw = buildQueryWrapper(bo);
|
||||
Page<SisAlarmEventProcessVo> result = baseMapper.selectVoPage(pageQuery.build(), lqw);
|
||||
return TableDataInfo.build(result);
|
||||
}
|
||||
|
||||
/**
|
||||
* 查询符合条件的告警信息处理流程记录列表
|
||||
*
|
||||
* @param bo 查询条件
|
||||
* @return 告警信息处理流程记录列表
|
||||
*/
|
||||
@Override
|
||||
public List<SisAlarmEventProcessVo> queryList(SisAlarmEventProcessBo bo) {
|
||||
LambdaQueryWrapper<SisAlarmEventProcess> lqw = buildQueryWrapper(bo);
|
||||
return baseMapper.selectVoList(lqw);
|
||||
}
|
||||
|
||||
private LambdaQueryWrapper<SisAlarmEventProcess> buildQueryWrapper(SisAlarmEventProcessBo bo) {
|
||||
Map<String, Object> params = bo.getParams();
|
||||
LambdaQueryWrapper<SisAlarmEventProcess> lqw = Wrappers.lambdaQuery();
|
||||
lqw.orderByAsc(SisAlarmEventProcess::getId);
|
||||
lqw.eq(bo.getAlarmId() != null, SisAlarmEventProcess::getAlarmId, bo.getAlarmId());
|
||||
lqw.eq(bo.getSolveId() != null, SisAlarmEventProcess::getSolveId, bo.getSolveId());
|
||||
lqw.like(StringUtils.isNotBlank(bo.getSolveName()), SisAlarmEventProcess::getSolveName, bo.getSolveName());
|
||||
lqw.eq(StringUtils.isNotBlank(bo.getWorkReply()), SisAlarmEventProcess::getWorkReply, bo.getWorkReply());
|
||||
lqw.eq(bo.getWorkReplyTime() != null, SisAlarmEventProcess::getWorkReplyTime, bo.getWorkReplyTime());
|
||||
lqw.eq(bo.getReceiveTaskTag() != null, SisAlarmEventProcess::getReceiveTaskTag, bo.getReceiveTaskTag());
|
||||
return lqw;
|
||||
}
|
||||
|
||||
/**
|
||||
* 新增告警信息处理流程记录
|
||||
*
|
||||
* @param bo 告警信息处理流程记录
|
||||
* @return 是否新增成功
|
||||
*/
|
||||
@Override
|
||||
public Boolean insertByBo(SisAlarmEventProcessBo bo) {
|
||||
SisAlarmEventProcess add = MapstructUtils.convert(bo, SisAlarmEventProcess.class);
|
||||
validEntityBeforeSave(add);
|
||||
boolean flag = baseMapper.insert(add) > 0;
|
||||
if (flag) {
|
||||
bo.setId(add.getId());
|
||||
}
|
||||
return flag;
|
||||
}
|
||||
|
||||
/**
|
||||
* 修改告警信息处理流程记录
|
||||
*
|
||||
* @param bo 告警信息处理流程记录
|
||||
* @return 是否修改成功
|
||||
*/
|
||||
@Override
|
||||
public Boolean updateByBo(SisAlarmEventProcessBo bo) {
|
||||
SisAlarmEventProcess update = MapstructUtils.convert(bo, SisAlarmEventProcess.class);
|
||||
validEntityBeforeSave(update);
|
||||
return baseMapper.updateById(update) > 0;
|
||||
}
|
||||
|
||||
/**
|
||||
* 保存前的数据校验
|
||||
*/
|
||||
private void validEntityBeforeSave(SisAlarmEventProcess entity) {
|
||||
//TODO 做一些数据校验,如唯一约束
|
||||
}
|
||||
|
||||
/**
|
||||
* 校验并批量删除告警信息处理流程记录信息
|
||||
*
|
||||
* @param ids 待删除的主键集合
|
||||
* @param isValid 是否进行有效性校验
|
||||
* @return 是否删除成功
|
||||
*/
|
||||
@Override
|
||||
public Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid) {
|
||||
if (isValid) {
|
||||
//TODO 做一些业务上的校验,判断是否需要校验
|
||||
}
|
||||
return baseMapper.deleteByIds(ids) > 0;
|
||||
}
|
||||
|
||||
@Override
|
||||
public Boolean insert(SisAlarmEventProcess process) {
|
||||
return baseMapper.insert(process) > 0;
|
||||
}
|
||||
}
|
@@ -1,6 +1,10 @@
|
||||
package org.dromara.sis.service.impl;
|
||||
|
||||
import cn.dev33.satoken.context.mock.SaTokenContextMockUtil;
|
||||
import cn.hutool.core.collection.CollUtil;
|
||||
import cn.hutool.core.collection.CollectionUtil;
|
||||
import cn.hutool.core.date.DateField;
|
||||
import cn.hutool.core.date.DateUtil;
|
||||
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
||||
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
||||
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||
@@ -11,25 +15,36 @@ import org.dromara.common.core.utils.MapstructUtils;
|
||||
import org.dromara.common.core.utils.StringUtils;
|
||||
import org.dromara.common.mybatis.core.page.PageQuery;
|
||||
import org.dromara.common.mybatis.core.page.TableDataInfo;
|
||||
import org.dromara.common.satoken.utils.LoginHelper;
|
||||
import org.dromara.property.api.RemoteAttendanceService;
|
||||
import org.dromara.property.api.domain.vo.RemoteAttendanceUserGroupVo;
|
||||
import org.dromara.resource.api.RemoteFileService;
|
||||
import org.dromara.resource.api.domain.RemoteFile;
|
||||
import org.dromara.sis.domain.SisAlarmEventAttachments;
|
||||
import org.dromara.sis.domain.SisAlarmEventProcess;
|
||||
import org.dromara.sis.domain.SisAlarmEvents;
|
||||
import org.dromara.sis.domain.SisDeviceManage;
|
||||
import org.dromara.sis.domain.bo.SisAlarmEventsBo;
|
||||
import org.dromara.sis.domain.bo.alarm.AlarmAssignmentBo;
|
||||
import org.dromara.sis.domain.bo.alarm.AlarmCompleteBo;
|
||||
import org.dromara.sis.domain.enums.AlarmStatus;
|
||||
import org.dromara.sis.domain.enums.EventBigTypeEnum;
|
||||
import org.dromara.sis.domain.enums.EventSmallTypeEnum;
|
||||
import org.dromara.sis.domain.vo.SisAlarmEventsVo;
|
||||
import org.dromara.sis.mapper.SisAlarmEventsMapper;
|
||||
import org.dromara.sis.service.ISisAlarmEventAttachmentsService;
|
||||
import org.dromara.sis.service.ISisAlarmEventProcessService;
|
||||
import org.dromara.sis.service.ISisAlarmEventsService;
|
||||
import org.dromara.sis.service.ISisDeviceManageService;
|
||||
import org.dromara.system.api.model.LoginUser;
|
||||
import org.springframework.scheduling.annotation.Async;
|
||||
import org.springframework.stereotype.Service;
|
||||
import org.springframework.transaction.annotation.Transactional;
|
||||
|
||||
import java.util.*;
|
||||
import java.util.ArrayList;
|
||||
import java.util.Collection;
|
||||
import java.util.Date;
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* 告警Service业务层处理
|
||||
@@ -45,9 +60,12 @@ public class SisAlarmEventsServiceImpl implements ISisAlarmEventsService {
|
||||
private final SisAlarmEventsMapper baseMapper;
|
||||
private final ISisDeviceManageService deviceManageService;
|
||||
private final ISisAlarmEventAttachmentsService alarmEventAttachmentsService;
|
||||
private final ISisAlarmEventProcessService alarmEventProcessService;
|
||||
|
||||
@DubboReference
|
||||
private RemoteFileService remoteFileService;
|
||||
@DubboReference
|
||||
private RemoteAttendanceService remoteAttendanceService;
|
||||
|
||||
/**
|
||||
* 查询告警
|
||||
@@ -70,6 +88,15 @@ public class SisAlarmEventsServiceImpl implements ISisAlarmEventsService {
|
||||
@Override
|
||||
public TableDataInfo<SisAlarmEventsVo> queryPageList(SisAlarmEventsBo bo, PageQuery pageQuery) {
|
||||
LambdaQueryWrapper<SisAlarmEvents> lqw = buildQueryWrapper(bo);
|
||||
lqw.orderByDesc(SisAlarmEvents::getId);
|
||||
Page<SisAlarmEventsVo> result = baseMapper.selectVoPage(pageQuery.build(), lqw);
|
||||
return TableDataInfo.build(result);
|
||||
}
|
||||
|
||||
@Override
|
||||
public TableDataInfo<SisAlarmEventsVo> queryPageListCurr(SisAlarmEventsBo bo, PageQuery pageQuery) {
|
||||
LambdaQueryWrapper<SisAlarmEvents> lqw = buildQueryWrapper(bo);
|
||||
lqw.orderByDesc(SisAlarmEvents::getSolveTime);
|
||||
Page<SisAlarmEventsVo> result = baseMapper.selectVoPage(pageQuery.build(), lqw);
|
||||
return TableDataInfo.build(result);
|
||||
}
|
||||
@@ -87,10 +114,11 @@ public class SisAlarmEventsServiceImpl implements ISisAlarmEventsService {
|
||||
}
|
||||
|
||||
private LambdaQueryWrapper<SisAlarmEvents> buildQueryWrapper(SisAlarmEventsBo bo) {
|
||||
Map<String, Object> params = bo.getParams();
|
||||
LambdaQueryWrapper<SisAlarmEvents> lqw = Wrappers.lambdaQuery();
|
||||
lqw.orderByAsc(SisAlarmEvents::getId);
|
||||
lqw.eq(bo.getLevel() != null, SisAlarmEvents::getLevel, bo.getLevel());
|
||||
lqw.eq(bo.getSolveId() != null, SisAlarmEvents::getSolveId, bo.getSolveId());
|
||||
lqw.eq(bo.getState() != null, SisAlarmEvents::getState, bo.getState());
|
||||
lqw.in(CollectionUtil.isNotEmpty(bo.getStates()), SisAlarmEvents::getState, bo.getStates());
|
||||
lqw.eq(StringUtils.isNotBlank(bo.getDeviceIp()), SisAlarmEvents::getDeviceIp, bo.getDeviceIp());
|
||||
lqw.like(StringUtils.isNotBlank(bo.getDeviceName()), SisAlarmEvents::getDeviceName, bo.getDeviceName());
|
||||
lqw.eq(bo.getDeviceGroupId() != null, SisAlarmEvents::getDeviceGroupId, bo.getDeviceGroupId());
|
||||
@@ -162,18 +190,24 @@ public class SisAlarmEventsServiceImpl implements ISisAlarmEventsService {
|
||||
return;
|
||||
}
|
||||
// 生成时间信息
|
||||
Date now = new Date();
|
||||
SisAlarmEvents alarmEvents = new SisAlarmEvents();
|
||||
alarmEvents.setBigType(EventBigTypeEnum.EQUIPMENT_UP.getCode());
|
||||
//TODO 处理上报小类型
|
||||
alarmEvents.setSmallType(EventSmallTypeEnum.EQP_REPORT_SBSB.getCode());
|
||||
alarmEvents.setLevel(Long.valueOf(level));
|
||||
alarmEvents.setDeviceIp(deviceIp);
|
||||
alarmEvents.setDeviceName(sisDeviceManage.getDeviceName());
|
||||
alarmEvents.setDeviceGroupId(sisDeviceManage.getId());
|
||||
alarmEvents.setReportTime(new Date());
|
||||
alarmEvents.setReportTime(now);
|
||||
alarmEvents.setState(AlarmStatus.REPORTED.getCode());
|
||||
alarmEvents.setTenantId(sisDeviceManage.getTenantId());
|
||||
alarmEvents.setCreateDept(sisDeviceManage.getCreateDept());
|
||||
|
||||
// 默认服务时间为2个小时
|
||||
alarmEvents.setServBeginTime(now);
|
||||
alarmEvents.setServEndTime(DateUtil.offset(now, DateField.HOUR, 2));
|
||||
|
||||
|
||||
int insert = this.baseMapper.insert(alarmEvents);
|
||||
log.info("写入报警事件表完成,num={}", insert);
|
||||
// 写入附件表
|
||||
@@ -200,4 +234,103 @@ public class SisAlarmEventsServiceImpl implements ISisAlarmEventsService {
|
||||
attachments.setCreateDept(sisDeviceManage.getCreateDept());
|
||||
return attachments;
|
||||
}
|
||||
|
||||
@Override
|
||||
@Transactional(rollbackFor = Exception.class)
|
||||
public Boolean taskAssignment(AlarmAssignmentBo bo) {
|
||||
// 验证工单状态
|
||||
SisAlarmEventsVo sisAlarmEventsVo = this.baseMapper.selectVoById(bo.getAlarmId());
|
||||
if (sisAlarmEventsVo == null) {
|
||||
throw new RuntimeException("工单信息不存在!");
|
||||
}
|
||||
if (!sisAlarmEventsVo.getState().equals(AlarmStatus.REPORTED.getCode())) {
|
||||
throw new RuntimeException("当前工单已指派,请刷新后重新指派!");
|
||||
}
|
||||
|
||||
Date now = new Date();
|
||||
List<RemoteAttendanceUserGroupVo> remoteAttendanceUserGroupVos = remoteAttendanceService.queryAttendPersonInfo(now);
|
||||
if (CollUtil.isEmpty(remoteAttendanceUserGroupVos)) {
|
||||
throw new RuntimeException("当前排无排班人员.");
|
||||
}
|
||||
// 验证当前人员是否为排班人员
|
||||
RemoteAttendanceUserGroupVo attendInfo = null;
|
||||
for (RemoteAttendanceUserGroupVo item : remoteAttendanceUserGroupVos) {
|
||||
if (bo.getSolveId().equals(item.getEmployeeId())) {
|
||||
attendInfo = item;
|
||||
break;
|
||||
}
|
||||
}
|
||||
if (attendInfo == null) {
|
||||
throw new RuntimeException("当前人员不在今天排班计划内.");
|
||||
}
|
||||
|
||||
SisAlarmEvents events = new SisAlarmEvents();
|
||||
events.setId(sisAlarmEventsVo.getId());
|
||||
events.setSolveId(bo.getSolveId());
|
||||
events.setSolveName(bo.getSolveName());
|
||||
events.setSolvePhone(bo.getSolvePhone());
|
||||
events.setSolveEmail(bo.getSolveEmail());
|
||||
events.setSolveName(bo.getSolveName());
|
||||
events.setSolveTime(now);
|
||||
events.setState(AlarmStatus.CONFIRMED.getCode());
|
||||
this.baseMapper.updateById(events);
|
||||
// 写入处理流程
|
||||
SisAlarmEventProcess process = new SisAlarmEventProcess();
|
||||
process.setAlarmId(sisAlarmEventsVo.getId());
|
||||
process.setSolveId(attendInfo.getEmployeeId());
|
||||
process.setSolveName(attendInfo.getEmployeeName());
|
||||
process.setWorkReply(bo.getRemark());
|
||||
process.setState(events.getState());
|
||||
process.setWorkReplyTime(now);
|
||||
process.setReceiveTaskTag(0L);
|
||||
Boolean insert = alarmEventProcessService.insert(process);
|
||||
log.info("事件处理信息写入完成,result= {}", insert);
|
||||
//TODO 推送到执行客户端
|
||||
return true;
|
||||
}
|
||||
|
||||
@Override
|
||||
public TableDataInfo<SisAlarmEventsVo> queryCurrAssignment(SisAlarmEventsBo bo, PageQuery pageQuery) {
|
||||
LoginUser loginUser = LoginHelper.getLoginUser();
|
||||
bo.setSolveId(loginUser.getUserId());
|
||||
LambdaQueryWrapper<SisAlarmEvents> lqw = buildQueryWrapper(bo);
|
||||
Page<SisAlarmEventsVo> result = baseMapper.selectVoPage(pageQuery.build(), lqw);
|
||||
return TableDataInfo.build(result);
|
||||
}
|
||||
|
||||
@Transactional(rollbackFor = Exception.class)
|
||||
@Override
|
||||
public Boolean complete(AlarmCompleteBo bo) {
|
||||
LoginUser loginUser = LoginHelper.getLoginUser();
|
||||
// 验证工单状态
|
||||
SisAlarmEventsVo sisAlarmEventsVo = this.baseMapper.selectVoById(bo.getAlarmId());
|
||||
if (sisAlarmEventsVo == null) {
|
||||
throw new RuntimeException("工单信息不存在!");
|
||||
}
|
||||
if (sisAlarmEventsVo.getState().equals(AlarmStatus.REPORTED.getCode())) {
|
||||
throw new RuntimeException("当前工单已指派,请刷新后重新指派!");
|
||||
}
|
||||
Date now = new Date();
|
||||
SisAlarmEvents events = new SisAlarmEvents();
|
||||
events.setId(sisAlarmEventsVo.getId());
|
||||
events.setSolveId(bo.getAlarmId());
|
||||
events.setFinishTime(now);
|
||||
events.setSolveId(loginUser.getUserId());
|
||||
events.setSolveName(loginUser.getUsername());
|
||||
events.setState(AlarmStatus.RESOLVED.getCode());
|
||||
this.baseMapper.updateById(events);
|
||||
|
||||
// 写入处理流程
|
||||
SisAlarmEventProcess process = new SisAlarmEventProcess();
|
||||
process.setAlarmId(sisAlarmEventsVo.getId());
|
||||
process.setSolveId(loginUser.getUserId());
|
||||
process.setSolveName(loginUser.getUsername());
|
||||
process.setWorkReply(bo.getRemark());
|
||||
process.setState(events.getState());
|
||||
process.setWorkReplyTime(now);
|
||||
process.setReceiveTaskTag(0L);
|
||||
Boolean insert = alarmEventProcessService.insert(process);
|
||||
log.info("事件处理信息写入完成,result= {}", insert);
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
@@ -143,7 +143,7 @@ public class SisPersonLibImgServiceImpl implements ISisPersonLibImgService {
|
||||
@Transactional(rollbackFor = Exception.class)
|
||||
public Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid) {
|
||||
List<SisPersonLibImgVo> list = this.queryListByIds(ids);
|
||||
Collection<Long> remoteIds = list.stream().map(SisPersonLibImgVo::getRemoteHWId).toList();
|
||||
Collection<Long> remoteIds = list.stream().map(SisPersonLibImgVo::getRemoteHwId).toList();
|
||||
|
||||
if (!remoteIds.isEmpty()) {
|
||||
Boolean flag = huaWeiBoxApi.deletePerson(remoteIds);
|
||||
@@ -180,7 +180,7 @@ public class SisPersonLibImgServiceImpl implements ISisPersonLibImgService {
|
||||
LambdaQueryWrapper<SisPersonLibImg> lqw = new LambdaQueryWrapper<>();
|
||||
lqw.eq(SisPersonLibImg::getResidentPersonId, personId);
|
||||
SisPersonLibImg update = new SisPersonLibImg();
|
||||
update.setRemoteHWId(huaweiBoxId);
|
||||
update.setRemoteHwId(huaweiBoxId);
|
||||
update.setImgMd5Value(imgMd5);
|
||||
return baseMapper.update(update, lqw) > 0;
|
||||
}
|
||||
|
@@ -65,7 +65,7 @@ public class ZeroSensationPassageServiceImpl implements IZeroSensationPassageSer
|
||||
if (result.getCode() != 200) {
|
||||
log.info("华为盒子比对失败,msg={}", result.getMessage());
|
||||
// 产生告警数据
|
||||
alarmEventsService.createAlarmRecord(deviceIp, 1, 1, "人脸比对失败", smallImg, bigImg);
|
||||
// alarmEventsService.createAlarmRecord(deviceIp, 1, 1, "人脸比对失败", smallImg, bigImg);
|
||||
return;
|
||||
}
|
||||
log.info("人脸比对执行完成,耗时:{}ms", interval.intervalMs());
|
||||
@@ -81,14 +81,14 @@ public class ZeroSensationPassageServiceImpl implements IZeroSensationPassageSer
|
||||
} else {
|
||||
if (Objects.equals(authRecord.getRosterType(), RosterTypeEnum.BLACK_LIST.getCode())) {
|
||||
log.info("人员[{}]在黑名单中,暂不处理。", person);
|
||||
alarmEventsService.createAlarmRecord(deviceIp, 3, 1, "黑名单人员入内", smallImg, bigImg);
|
||||
// alarmEventsService.createAlarmRecord(deviceIp, 3, 1, "黑名单人员入内", smallImg, bigImg);
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
Date now = new Date();
|
||||
if (DateUtil.compare(now, authRecord.getEndDate()) > 0) {
|
||||
alarmEventsService.createAlarmRecord(deviceIp, 3, 1, "人员授权信息已过期", smallImg, bigImg);
|
||||
// alarmEventsService.createAlarmRecord(deviceIp, 3, 1, "人员授权信息已过期", smallImg, bigImg);
|
||||
log.info("当前人脸已过期,暂不处理。");
|
||||
return;
|
||||
}
|
||||
@@ -119,9 +119,9 @@ public class ZeroSensationPassageServiceImpl implements IZeroSensationPassageSer
|
||||
if (Objects.equals(item.getControlType(), ControlTypeEnum.ACCESS_CONTROL.getCode())) { // 门禁
|
||||
handleAc(item.getBindId());
|
||||
} else if (item.getControlType().equals(ControlTypeEnum.ELEVATOR_OUT_CONTROL.getCode())) { // 电梯外面面板权限
|
||||
handleEle(item.getBindId(), r.getAuthGroupId(), ControlTypeEnum.ELEVATOR_OUT_CONTROL.getCode(), item.getDeviceFloorId());
|
||||
// handleEle(item.getBindId(), r.getAuthGroupId(), ControlTypeEnum.ELEVATOR_OUT_CONTROL.getCode(), item.getDeviceFloorId());
|
||||
} else if (item.getControlType().equals(ControlTypeEnum.ELEVATOR_IN_CONTROL.getCode())) { // 电梯里面的面板
|
||||
handleEle(item.getBindId(), r.getAuthGroupId(), ControlTypeEnum.ELEVATOR_IN_CONTROL.getCode(), 0L);
|
||||
// handleEle(item.getBindId(), r.getAuthGroupId(), ControlTypeEnum.ELEVATOR_IN_CONTROL.getCode(), 0L);
|
||||
} else {
|
||||
log.info("设备绑定了未知的控制类型[{}],不处理", item.getControlType());
|
||||
}
|
||||
@@ -166,7 +166,7 @@ public class ZeroSensationPassageServiceImpl implements IZeroSensationPassageSer
|
||||
* 生成告警事件
|
||||
*/
|
||||
public void createAlarmRecord(String deviceIp, Integer level, Integer type, String msg, byte[] smallImg, byte[] bigImg) {
|
||||
alarmEventsService.createAlarmRecord(deviceIp, level, type, msg, smallImg, bigImg);
|
||||
// alarmEventsService.createAlarmRecord(deviceIp, level, type, msg, smallImg, bigImg);
|
||||
}
|
||||
|
||||
/**
|
||||
|
@@ -0,0 +1,7 @@
|
||||
<?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="org.dromara.sis.mapper.SisAlarmEventProcessMapper">
|
||||
|
||||
</mapper>
|
@@ -117,6 +117,10 @@
|
||||
<groupId>org.dromara</groupId>
|
||||
<artifactId>ruoyi-api-resource</artifactId>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>org.dromara</groupId>
|
||||
<artifactId>property-api</artifactId>
|
||||
</dependency>
|
||||
|
||||
</dependencies>
|
||||
|
||||
|
@@ -4,6 +4,9 @@ package org.dromara.resource.controller;
|
||||
import cn.dev33.satoken.annotation.SaCheckPermission;
|
||||
import cn.hutool.core.util.ObjectUtil;
|
||||
import lombok.RequiredArgsConstructor;
|
||||
import org.apache.dubbo.config.annotation.DubboReference;
|
||||
import org.apache.dubbo.config.annotation.DubboService;
|
||||
import org.dromara.common.core.constant.GlobalConstants;
|
||||
import org.dromara.common.core.domain.R;
|
||||
import org.dromara.common.core.validate.QueryGroup;
|
||||
import org.dromara.common.redis.utils.RedisUtils;
|
||||
@@ -12,6 +15,7 @@ import org.dromara.common.log.annotation.Log;
|
||||
import org.dromara.common.log.enums.BusinessType;
|
||||
import org.dromara.common.mybatis.core.page.PageQuery;
|
||||
import org.dromara.common.mybatis.core.page.TableDataInfo;
|
||||
import org.dromara.property.api.RemoteVisitoreGetCodeInfoService;
|
||||
import org.dromara.resource.domain.QrCodeInfo;
|
||||
import org.dromara.resource.domain.bo.SysOssBo;
|
||||
import org.dromara.resource.domain.vo.SysOssUploadVo;
|
||||
@@ -40,7 +44,8 @@ import java.util.List;
|
||||
public class SysOssController extends BaseController {
|
||||
|
||||
private final ISysOssService iSysOssService;
|
||||
|
||||
@DubboReference
|
||||
private RemoteVisitoreGetCodeInfoService remoteVisitoreGetCodeInfoService;
|
||||
/**
|
||||
* 查询OSS对象存储列表
|
||||
*/
|
||||
@@ -95,12 +100,13 @@ public class SysOssController extends BaseController {
|
||||
if (ObjectUtil.isNull(file)) {
|
||||
return R.fail("上传文件不能为空");
|
||||
}
|
||||
QrCodeInfo info = RedisUtils.getCacheObject("Qrcode" + code);
|
||||
if (info==null){
|
||||
String codeInfo = remoteVisitoreGetCodeInfoService.getCodeInfo(code);
|
||||
// QrCodeInfo info = RedisUtils.getCacheObject(GlobalConstants.CAPTCHA_CODE_KEY+"Qrcode" + code);
|
||||
if (codeInfo.isBlank()){
|
||||
return R.fail("二维码已过期");
|
||||
}
|
||||
|
||||
SysOssVo oss = iSysOssService.qrupload(file,info);
|
||||
SysOssVo oss = iSysOssService.qrupload(file,codeInfo);
|
||||
SysOssUploadVo uploadVo = new SysOssUploadVo();
|
||||
uploadVo.setUrl(oss.getUrl());
|
||||
uploadVo.setFileName(oss.getOriginalName());
|
||||
|
@@ -67,7 +67,7 @@ public interface ISysOssService {
|
||||
* @param file 要上传的 MultipartFile 对象
|
||||
* @return 上传成功后的 SysOssVo 对象,包含文件信息
|
||||
*/
|
||||
SysOssVo qrupload(MultipartFile file, QrCodeInfo qrCodeInfo);
|
||||
SysOssVo qrupload(MultipartFile file, String qrCodeInfo);
|
||||
|
||||
/**
|
||||
* 上传文件到对象存储服务,并保存文件信息到数据库
|
||||
|
@@ -200,7 +200,7 @@ public class SysOssServiceImpl implements ISysOssService {
|
||||
}
|
||||
|
||||
@Override
|
||||
public SysOssVo qrupload(MultipartFile file, QrCodeInfo info) {
|
||||
public SysOssVo qrupload(MultipartFile file, String info) {
|
||||
String originalfileName = file.getOriginalFilename();
|
||||
String suffix = StringUtils.substring(originalfileName, originalfileName.lastIndexOf("."), originalfileName.length());
|
||||
OssClient storage = OssFactory.instance();
|
||||
@@ -242,14 +242,14 @@ public class SysOssServiceImpl implements ISysOssService {
|
||||
return this.matchingUrl(sysOssVo);
|
||||
}
|
||||
|
||||
private SysOssVo buildResultEntityQr(String originalfileName, String suffix, String configKey, UploadResult uploadResult,QrCodeInfo info) {
|
||||
private SysOssVo buildResultEntityQr(String originalfileName, String suffix, String configKey, UploadResult uploadResult,String info) {
|
||||
SysOss oss = new SysOss();
|
||||
oss.setUrl(uploadResult.getUrl());
|
||||
oss.setFileSuffix(suffix);
|
||||
oss.setFileName(uploadResult.getFilename());
|
||||
oss.setOriginalName(originalfileName);
|
||||
oss.setService(configKey);
|
||||
oss.setCreateBy(info.getUserid());
|
||||
oss.setCreateBy(Long.valueOf(info));
|
||||
oss.setCreateTime(new Date());
|
||||
baseMapper.insert(oss);
|
||||
SysOssVo sysOssVo = MapstructUtils.convert(oss, SysOssVo.class);
|
||||
|
@@ -3,6 +3,7 @@ package org.dromara.system.dubbo;
|
||||
import cn.hutool.core.bean.BeanUtil;
|
||||
import lombok.RequiredArgsConstructor;
|
||||
import org.apache.dubbo.config.annotation.DubboService;
|
||||
import org.dromara.common.core.utils.MapstructUtils;
|
||||
import org.dromara.system.api.RemoteDeptService;
|
||||
import org.dromara.system.api.domain.vo.RemoteDeptVo;
|
||||
import org.dromara.system.domain.vo.SysDeptVo;
|
||||
@@ -57,4 +58,9 @@ public class RemoteDeptServiceImpl implements RemoteDeptService {
|
||||
return BeanUtil.copyToList(list, RemoteDeptVo.class);
|
||||
}
|
||||
|
||||
@Override
|
||||
public RemoteDeptVo selectDeptVoById(Long deptId) {
|
||||
SysDeptVo sysDeptVo = sysDeptService.selectDeptById(deptId);
|
||||
return BeanUtil.copyProperties(sysDeptVo, RemoteDeptVo.class);
|
||||
}
|
||||
}
|
||||
|
@@ -90,7 +90,7 @@ public class SysDictTypeServiceImpl implements ISysDictTypeService {
|
||||
* @param dictType 字典类型
|
||||
* @return 字典数据集合信息
|
||||
*/
|
||||
@Cacheable(cacheNames = CacheNames.SYS_DICT, key = "#dictType")
|
||||
// @Cacheable(cacheNames = CacheNames.SYS_DICT, key = "#dictType")
|
||||
@Override
|
||||
public List<SysDictDataVo> selectDictDataByType(String dictType) {
|
||||
List<SysDictDataVo> dictDatas = dictDataMapper.selectDictDataByType(dictType);
|
||||
|
@@ -42,7 +42,7 @@ db.num=1
|
||||
### Connect URL of DB:
|
||||
db.url.0=jdbc:mysql://127.0.0.1:3306/ry-config?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true&useUnicode=true&useSSL=false&serverTimezone=UTC&allowPublicKeyRetrieval=true
|
||||
db.user.0=root
|
||||
db.password.0=By@2025!
|
||||
db.password.0=123456
|
||||
|
||||
### the maximum retry times for push
|
||||
nacos.config.push.maxRetryTime=50
|
||||
|
Reference in New Issue
Block a user