mirror of
				https://gitee.com/dotnetchina/OpenAuth.Net.git
				synced 2025-10-25 10:19:01 +08:00 
			
		
		
		
	流程处理增加消息通知
修复消息标记已读、删除
This commit is contained in:
		
							
								
								
									
										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); | ||||||
| @@ -379,6 +387,10 @@ namespace OpenAuth.App | |||||||
|                           + reqest.VerificationOpinion |                           + reqest.VerificationOpinion | ||||||
|             }); |             }); | ||||||
|              |              | ||||||
|  |             //给流程创建人发送通知信息 | ||||||
|  |             _messageApp.SendMsgTo(flowInstance.CreateUserId,  | ||||||
|  |                 $"你的流程[{flowInstance.CustomName}]已被{user.Name}驳回。备注信息:{reqest.VerificationOpinion}"); | ||||||
|  |  | ||||||
|             UnitWork.Save(); |             UnitWork.Save(); | ||||||
|  |  | ||||||
|             wfruntime.NotifyThirdParty(_httpClientFactory.CreateClient(), tag); |             wfruntime.NotifyThirdParty(_httpClientFactory.CreateClient(), tag); | ||||||
|   | |||||||
| @@ -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,13 +30,19 @@ 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) | ||||||
|                 .Take(request.limit); |                 .Take(request.limit); | ||||||
| @@ -46,19 +55,73 @@ 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; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -41,21 +41,27 @@ 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,33 +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) |  | ||||||
|             { |  | ||||||
|                 result.Code = 500; |  | ||||||
|                 result.Message = ex.InnerException?.Message ?? ex.Message; |  | ||||||
|             } |  | ||||||
|  |  | ||||||
|             return result; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         //修改 |  | ||||||
|        [HttpPost] |  | ||||||
|         public Response Update(SysMessage obj) |  | ||||||
|         { |  | ||||||
|             var result = new Response(); |  | ||||||
|             try |  | ||||||
|             { |  | ||||||
|                 _app.Update(obj); |  | ||||||
|  |  | ||||||
|             } |             } | ||||||
|             catch (Exception ex) |             catch (Exception ex) | ||||||
| @@ -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) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 yubaolee
					yubaolee