mirror of
https://gitee.com/dotnetchina/OpenAuth.Net.git
synced 2025-08-24 07:22:55 +08:00
流程处理增加消息通知
修复消息标记已读、删除
This commit is contained in:
parent
c0d47e37bf
commit
8608ce78f5
14
OpenAuth.App/Base/IdRequest.cs
Normal file
14
OpenAuth.App/Base/IdRequest.cs
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
namespace OpenAuth.App.Request
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// 请求参数中只有Id
|
||||||
|
/// </summary>
|
||||||
|
/// <typeparam name="T"></typeparam>
|
||||||
|
public class IdRequest<T>
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// 操作Id
|
||||||
|
/// </summary>
|
||||||
|
public T Id { get; set; }
|
||||||
|
}
|
||||||
|
}
|
@ -41,11 +41,13 @@ namespace OpenAuth.App
|
|||||||
private FormApp _formApp;
|
private FormApp _formApp;
|
||||||
private IHttpClientFactory _httpClientFactory;
|
private IHttpClientFactory _httpClientFactory;
|
||||||
private IServiceProvider _serviceProvider;
|
private IServiceProvider _serviceProvider;
|
||||||
|
private SysMessageApp _messageApp;
|
||||||
|
|
||||||
public FlowInstanceApp(IUnitWork<OpenAuthDBContext> unitWork,
|
public FlowInstanceApp(IUnitWork<OpenAuthDBContext> unitWork,
|
||||||
IRepository<FlowInstance, OpenAuthDBContext> repository
|
IRepository<FlowInstance, OpenAuthDBContext> repository
|
||||||
, RevelanceManagerApp app, FlowSchemeApp flowSchemeApp, FormApp formApp,
|
, RevelanceManagerApp app, FlowSchemeApp flowSchemeApp, FormApp formApp,
|
||||||
IHttpClientFactory httpClientFactory, IAuth auth, IServiceProvider serviceProvider)
|
IHttpClientFactory httpClientFactory, IAuth auth, IServiceProvider serviceProvider,
|
||||||
|
SysMessageApp messageApp)
|
||||||
: base(unitWork, repository, auth)
|
: base(unitWork, repository, auth)
|
||||||
{
|
{
|
||||||
_revelanceApp = app;
|
_revelanceApp = app;
|
||||||
@ -53,6 +55,7 @@ namespace OpenAuth.App
|
|||||||
_formApp = formApp;
|
_formApp = formApp;
|
||||||
_httpClientFactory = httpClientFactory;
|
_httpClientFactory = httpClientFactory;
|
||||||
_serviceProvider = serviceProvider;
|
_serviceProvider = serviceProvider;
|
||||||
|
_messageApp = messageApp;
|
||||||
}
|
}
|
||||||
|
|
||||||
#region 流程处理API
|
#region 流程处理API
|
||||||
@ -295,6 +298,11 @@ namespace OpenAuth.App
|
|||||||
|
|
||||||
UnitWork.Update(flowInstance);
|
UnitWork.Update(flowInstance);
|
||||||
UnitWork.Add(flowInstanceOperationHistory);
|
UnitWork.Add(flowInstanceOperationHistory);
|
||||||
|
|
||||||
|
//给流程创建人发送通知信息
|
||||||
|
_messageApp.SendMsgTo(flowInstance.CreateUserId,
|
||||||
|
$"你的流程[{flowInstance.CustomName}]已被{user.Name}处理。处理情况如下:{flowInstanceOperationHistory.Content}");
|
||||||
|
|
||||||
UnitWork.Save();
|
UnitWork.Save();
|
||||||
|
|
||||||
wfruntime.NotifyThirdParty(_httpClientFactory.CreateClient(), tag);
|
wfruntime.NotifyThirdParty(_httpClientFactory.CreateClient(), tag);
|
||||||
@ -378,6 +386,10 @@ namespace OpenAuth.App
|
|||||||
+ "】【" + DateTime.Now.ToString("yyyy-MM-dd HH:mm") + "】驳回,备注:"
|
+ "】【" + DateTime.Now.ToString("yyyy-MM-dd HH:mm") + "】驳回,备注:"
|
||||||
+ reqest.VerificationOpinion
|
+ reqest.VerificationOpinion
|
||||||
});
|
});
|
||||||
|
|
||||||
|
//给流程创建人发送通知信息
|
||||||
|
_messageApp.SendMsgTo(flowInstance.CreateUserId,
|
||||||
|
$"你的流程[{flowInstance.CustomName}]已被{user.Name}驳回。备注信息:{reqest.VerificationOpinion}");
|
||||||
|
|
||||||
UnitWork.Save();
|
UnitWork.Save();
|
||||||
|
|
||||||
|
@ -2,6 +2,9 @@
|
|||||||
{
|
{
|
||||||
public class QuerySysMessageListReq : PageReq
|
public class QuerySysMessageListReq : PageReq
|
||||||
{
|
{
|
||||||
//todo:添加自己的请求字段
|
/// <summary>
|
||||||
|
/// 消息状态 0:未读;1:已读; 999:全部
|
||||||
|
/// </summary>
|
||||||
|
public int Status { get; set; }
|
||||||
}
|
}
|
||||||
}
|
}
|
9
OpenAuth.App/SysMessage/Request/ReadMsgReq.cs
Normal file
9
OpenAuth.App/SysMessage/Request/ReadMsgReq.cs
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
namespace OpenAuth.App.Request
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// 阅读消息请求
|
||||||
|
/// </summary>
|
||||||
|
public class ReadMsgReq : IdRequest<string>
|
||||||
|
{
|
||||||
|
}
|
||||||
|
}
|
@ -1,6 +1,8 @@
|
|||||||
using System.Linq;
|
using System;
|
||||||
|
using System.Linq;
|
||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
using Infrastructure;
|
using Infrastructure;
|
||||||
|
using Microsoft.Extensions.Logging;
|
||||||
using OpenAuth.App.Interface;
|
using OpenAuth.App.Interface;
|
||||||
using OpenAuth.App.Request;
|
using OpenAuth.App.Request;
|
||||||
using OpenAuth.App.Response;
|
using OpenAuth.App.Response;
|
||||||
@ -14,6 +16,7 @@ namespace OpenAuth.App
|
|||||||
public class SysMessageApp : BaseStringApp<SysMessage,OpenAuthDBContext>
|
public class SysMessageApp : BaseStringApp<SysMessage,OpenAuthDBContext>
|
||||||
{
|
{
|
||||||
private RevelanceManagerApp _revelanceApp;
|
private RevelanceManagerApp _revelanceApp;
|
||||||
|
private readonly ILogger<SysMessageApp> _logger;
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// 加载列表
|
/// 加载列表
|
||||||
@ -27,12 +30,18 @@ namespace OpenAuth.App
|
|||||||
}
|
}
|
||||||
|
|
||||||
var result = new TableData();
|
var result = new TableData();
|
||||||
var objs = UnitWork.Find<SysMessage>(u =>u.ToId == loginContext.User.Id);
|
var objs = UnitWork.Find<SysMessage>(u =>u.ToId == loginContext.User.Id && u.ToStatus != -1);
|
||||||
|
|
||||||
if (!string.IsNullOrEmpty(request.key))
|
if (!string.IsNullOrEmpty(request.key))
|
||||||
{
|
{
|
||||||
objs = objs.Where(u => u.Title.Contains(request.key) || u.Id.Contains(request.key));
|
objs = objs.Where(u => u.Title.Contains(request.key) || u.Id.Contains(request.key));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//过滤消息状态
|
||||||
|
if (request.Status != 999)
|
||||||
|
{
|
||||||
|
objs = objs.Where(u => u.ToStatus == request.Status);
|
||||||
|
}
|
||||||
|
|
||||||
result.data = objs.OrderBy(u => u.Id)
|
result.data = objs.OrderBy(u => u.Id)
|
||||||
.Skip((request.page - 1) * request.limit)
|
.Skip((request.page - 1) * request.limit)
|
||||||
@ -45,20 +54,74 @@ namespace OpenAuth.App
|
|||||||
{
|
{
|
||||||
Repository.Add(obj);
|
Repository.Add(obj);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void Update(SysMessage obj)
|
/// <summary>
|
||||||
|
/// 发送指定消息给用户
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="user"></param>
|
||||||
|
/// <param name="message"></param>
|
||||||
|
public void SendMsgTo(string userId, string message)
|
||||||
{
|
{
|
||||||
UnitWork.Update<SysMessage>(u => u.Id == obj.Id, u => new SysMessage
|
User user = null;
|
||||||
|
if (userId == Guid.Empty.ToString())
|
||||||
{
|
{
|
||||||
//todo:要修改的字段赋值
|
user = new User
|
||||||
|
{
|
||||||
|
Name = Define.SYSTEM_USERNAME,
|
||||||
|
Id = userId
|
||||||
|
};
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
user = UnitWork.FirstOrDefault<User>(u => u.Id == userId);
|
||||||
|
}
|
||||||
|
if (user == null)
|
||||||
|
{
|
||||||
|
_logger.LogError($"未能找到用户{userId},不能给该用户发送消息");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
Repository.Add(new SysMessage
|
||||||
|
{
|
||||||
|
ToId = user.Id,
|
||||||
|
ToName = user.Name,
|
||||||
|
TypeName = "系统消息",
|
||||||
|
TypeId ="SYS_MSG",
|
||||||
|
FromId = Guid.Empty.ToString(),
|
||||||
|
FromName = "系统管理员",
|
||||||
|
Content = message,
|
||||||
|
CreateTime = DateTime.Now
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 消息变为已读
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="msgid"></param>
|
||||||
|
public void Read(ReadMsgReq req)
|
||||||
|
{
|
||||||
|
UnitWork.Update<SysMessage>(u => u.Id == req.Id, u => new SysMessage
|
||||||
|
{
|
||||||
|
ToStatus = 1
|
||||||
|
});
|
||||||
|
}
|
||||||
|
/// <summary>
|
||||||
|
/// 消息采用逻辑删除
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="ids"></param>
|
||||||
|
public void Del(string[] ids)
|
||||||
|
{
|
||||||
|
UnitWork.Update<SysMessage>(u => ids.Contains(u.Id), u => new SysMessage
|
||||||
|
{
|
||||||
|
ToStatus = -1 //逻辑删除
|
||||||
});
|
});
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public SysMessageApp(IUnitWork<OpenAuthDBContext> unitWork, IRepository<SysMessage,OpenAuthDBContext> repository,
|
public SysMessageApp(IUnitWork<OpenAuthDBContext> unitWork, IRepository<SysMessage,OpenAuthDBContext> repository,
|
||||||
RevelanceManagerApp app,IAuth auth) : base(unitWork, repository, auth)
|
RevelanceManagerApp app,IAuth auth, ILogger<SysMessageApp> logger) : base(unitWork, repository, auth)
|
||||||
{
|
{
|
||||||
_revelanceApp = app;
|
_revelanceApp = app;
|
||||||
|
_logger = logger;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -40,22 +40,28 @@ namespace OpenAuth.Mvc.Controllers
|
|||||||
}
|
}
|
||||||
return JsonHelper.Instance.Serialize(Result);
|
return JsonHelper.Instance.Serialize(Result);
|
||||||
}
|
}
|
||||||
|
|
||||||
//添加或修改
|
/// <summary>
|
||||||
|
/// 阅读消息(即消息置为已读)
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="obj"></param>
|
||||||
|
/// <returns></returns>
|
||||||
[HttpPost]
|
[HttpPost]
|
||||||
public string Update(SysMessage obj)
|
public string Read(ReadMsgReq obj)
|
||||||
{
|
{
|
||||||
|
var result = new Response();
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
_app.Update(obj);
|
_app.Read(obj);
|
||||||
|
|
||||||
}
|
}
|
||||||
catch (Exception ex)
|
catch (Exception ex)
|
||||||
{
|
{
|
||||||
Result.Code = 500;
|
result.Code = 500;
|
||||||
Result.Message = ex.Message;
|
result.Message = ex.InnerException?.Message ?? ex.Message;
|
||||||
}
|
}
|
||||||
return JsonHelper.Instance.Serialize(Result);
|
|
||||||
|
return JsonHelper.Instance.Serialize(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
|
@ -19,7 +19,11 @@ namespace OpenAuth.WebApi.Controllers
|
|||||||
{
|
{
|
||||||
private readonly SysMessageApp _app;
|
private readonly SysMessageApp _app;
|
||||||
|
|
||||||
//获取详情
|
/// <summary>
|
||||||
|
/// 获取消息详情
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="id"></param>
|
||||||
|
/// <returns></returns>
|
||||||
[HttpGet]
|
[HttpGet]
|
||||||
public Response<SysMessage> Get(string id)
|
public Response<SysMessage> Get(string id)
|
||||||
{
|
{
|
||||||
@ -37,14 +41,18 @@ namespace OpenAuth.WebApi.Controllers
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
//添加
|
/// <summary>
|
||||||
|
/// 阅读消息(即消息置为已读)
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="obj"></param>
|
||||||
|
/// <returns></returns>
|
||||||
[HttpPost]
|
[HttpPost]
|
||||||
public Response Add(SysMessage obj)
|
public Response Read(ReadMsgReq obj)
|
||||||
{
|
{
|
||||||
var result = new Response();
|
var result = new Response();
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
_app.Add(obj);
|
_app.Read(obj);
|
||||||
|
|
||||||
}
|
}
|
||||||
catch (Exception ex)
|
catch (Exception ex)
|
||||||
@ -55,26 +63,7 @@ namespace OpenAuth.WebApi.Controllers
|
|||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
//修改
|
|
||||||
[HttpPost]
|
|
||||||
public Response Update(SysMessage obj)
|
|
||||||
{
|
|
||||||
var result = new Response();
|
|
||||||
try
|
|
||||||
{
|
|
||||||
_app.Update(obj);
|
|
||||||
|
|
||||||
}
|
|
||||||
catch (Exception ex)
|
|
||||||
{
|
|
||||||
result.Code = 500;
|
|
||||||
result.Message = ex.InnerException?.Message ?? ex.Message;
|
|
||||||
}
|
|
||||||
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// 加载列表
|
/// 加载列表
|
||||||
/// </summary>
|
/// </summary>
|
||||||
@ -93,7 +82,7 @@ namespace OpenAuth.WebApi.Controllers
|
|||||||
var result = new Response();
|
var result = new Response();
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
_app.Delete(ids);
|
_app.Del(ids);
|
||||||
|
|
||||||
}
|
}
|
||||||
catch (Exception ex)
|
catch (Exception ex)
|
||||||
|
Loading…
Reference in New Issue
Block a user