using JNPF.Common.Enums; using JNPF.Common.Extension; using JNPF.Common.Filter; using JNPF.Common.Security; using JNPF.DependencyInjection; using JNPF.DynamicApiController; using JNPF.FriendlyException; using JNPF.Message.Entitys.Dto.MessageTemplate; using JNPF.Message.Entitys.Entity; using JNPF.Message.Entitys.Model.MessageTemplate; using JNPF.Systems.Entitys.Permission; using Mapster; using Microsoft.AspNetCore.Mvc; using SqlSugar; namespace JNPF.Message.Service; /// /// 消息监控 /// 版 本:V3.2 /// 版 权:拓通智联科技有限公司(http://www.tuotong-tech.com) /// 日 期:2021-06-01. /// [ApiDescriptionSettings(Tag = "Message", Name = "MessageTemplate", Order = 240)] [Route("api/message/MessageTemplateConfig")] public class MessageTemplateService : IDynamicApiController, ITransient { private readonly ISqlSugarRepository _repository; public MessageTemplateService( ISqlSugarRepository repository) { _repository = repository; } #region Get /// /// 列表. /// /// 请求参数. /// [HttpGet("")] public async Task GetList([FromQuery] MessageTemplateQuery input) { var list = await _repository.AsSugarClient().Queryable() .Where(a => a.DeleteMark == null) .WhereIF(input.messageSource.IsNotEmptyOrNull(), a => a.MessageSource == input.messageSource) .WhereIF(input.messageType.IsNotEmptyOrNull(), a => a.MessageType == input.messageType) .WhereIF(input.templateType.IsNotEmptyOrNull(), a => a.TemplateType == input.templateType) .WhereIF(input.enabledMark.IsNotEmptyOrNull(), a => a.EnabledMark == input.enabledMark) .WhereIF(input.keyword.IsNotEmptyOrNull(), a => a.FullName.Contains(input.keyword) || a.EnCode.Contains(input.keyword)) .OrderBy(a => a.SortCode) .OrderBy(a => a.CreatorTime, OrderByType.Desc) .OrderBy(a => a.LastModifyTime, OrderByType.Desc) .Select(a => new MessageTemplateListOutput { id = a.Id, fullName = a.FullName, enCode = a.EnCode, templateType = a.TemplateType, messageType = SqlFunc.Subqueryable().Where(u => u.Type == "1" && u.EnCode == a.MessageType).Select(u => u.FullName), messageSource = SqlFunc.Subqueryable().Where(u => u.Type == "4" && u.EnCode == a.MessageSource).Select(u => u.FullName), creatorUser = SqlFunc.Subqueryable().Where(u => u.Id == a.CreatorUserId).Select(u => SqlFunc.MergeString(u.RealName, "/", u.Account)), creatorTime = a.CreatorTime, lastModifyTime = a.LastModifyTime, sortCode = a.SortCode, enabledMark = a.EnabledMark, }).ToPagedListAsync(input.currentPage, input.pageSize); return PageResult.SqlSugarPageResult(list); } /// /// 详情. /// /// [HttpGet("{id}")] public async Task GetInfo(string id) { var output = (await _repository.GetFirstAsync(x => x.Id == id && x.DeleteMark == null)).Adapt(); output.smsFieldList = (await _repository.AsSugarClient().Queryable().Where(x => x.TemplateId == id && x.DeleteMark == null).ToListAsync()).ToObject>(); output.templateParamList = (await _repository.AsSugarClient().Queryable().Where(x => x.TemplateId == id && x.DeleteMark == null).ToListAsync()).ToObject>(); return output; } #endregion #region POST /// /// 新建. /// /// 实体对象. /// [HttpPost("")] public async Task Create([FromBody] MessageTemplateListOutput input) { if (await _repository.IsAnyAsync(x => (x.EnCode == input.enCode || x.FullName == input.fullName) && x.DeleteMark == null)) throw Oops.Oh(ErrorCode.COM1004); if (input.enCode.Contains("MBXTLC")) throw Oops.Oh(ErrorCode.D7011); var entity = input.Adapt(); var result = await _repository.AsInsertable(entity).IgnoreColumns(ignoreNullColumn: true).CallEntityMethod(m => m.Creator()).ExecuteReturnEntityAsync(); if (input.templateParamList.Any()) { foreach (var item in input.templateParamList) { var paramEntity = item.Adapt(); paramEntity.TemplateId = result.Id; await _repository.AsSugarClient().Insertable(paramEntity).IgnoreColumns(ignoreNullColumn: true).CallEntityMethod(m => m.Creator()).ExecuteCommandAsync(); } } if (input.smsFieldList.Any()) { foreach (var item in input.smsFieldList) { var smsFieldEntity = item.Adapt(); smsFieldEntity.TemplateId = result.Id; await _repository.AsSugarClient().Insertable(smsFieldEntity).IgnoreColumns(ignoreNullColumn: true).CallEntityMethod(m => m.Creator()).ExecuteCommandAsync(); } } if (result.IsNullOrEmpty()) throw Oops.Oh(ErrorCode.COM1000); } /// /// 修改. /// /// 主键值. /// 实体对象. /// [HttpPut("{id}")] public async Task Update(string id, [FromBody] MessageTemplateListOutput input) { if (await _repository.IsAnyAsync(x => x.Id != id && (x.EnCode == input.enCode || x.FullName == input.fullName) && x.DeleteMark == null)) throw Oops.Oh(ErrorCode.COM1004); if (input.enCode.Contains("MBXTLC")) throw Oops.Oh(ErrorCode.D7011); var entity = input.Adapt(); if (input.templateParamList.Any()) { await _repository.AsSugarClient().Deleteable(x => x.TemplateId == id).ExecuteCommandAsync(); foreach (var item in input.templateParamList) { var paramEntity = item.Adapt(); paramEntity.TemplateId = id; await _repository.AsSugarClient().Insertable(paramEntity).IgnoreColumns(ignoreNullColumn: true).CallEntityMethod(m => m.Creator()).ExecuteCommandAsync(); } } if (input.smsFieldList.Any()) { await _repository.AsSugarClient().Deleteable(x => x.TemplateId == id).ExecuteCommandAsync(); foreach (var item in input.smsFieldList) { var smsFieldEntity = item.Adapt(); smsFieldEntity.TemplateId = id; await _repository.AsSugarClient().Insertable(smsFieldEntity).IgnoreColumns(ignoreNullColumn: true).CallEntityMethod(m => m.Creator()).ExecuteCommandAsync(); } } var isOk = await _repository.AsUpdateable(entity).IgnoreColumns(ignoreAllNullColumns: true).CallEntityMethod(m => m.LastModify()).ExecuteCommandHasChangeAsync(); if (!isOk) throw Oops.Oh(ErrorCode.COM1001); } /// /// 删除. /// /// 主键. /// [HttpDelete("{id}")] public async Task Delete(string id) { var entity = await _repository.GetFirstAsync(x => x.Id == id && x.DeleteMark == null); if (entity == null) throw Oops.Oh(ErrorCode.COM1005); await _repository.AsSugarClient().Deleteable(x => x.TemplateId == id).ExecuteCommandAsync(); await _repository.AsSugarClient().Deleteable(x => x.TemplateId == id).ExecuteCommandAsync(); var isOk = await _repository.AsUpdateable(entity).CallEntityMethod(m => m.Delete()).UpdateColumns(it => new { it.DeleteMark, it.DeleteTime, it.DeleteUserId }).ExecuteCommandHasChangeAsync(); if (!isOk) throw Oops.Oh(ErrorCode.COM1002); } /// /// 复制. /// /// 主键值. /// [HttpPost("copy/{id}")] public async Task ActionsCopy(string id) { var entity = await _repository.GetFirstAsync(x => x.Id == id && x.DeleteMark == null); var random = RandomExtensions.NextLetterAndNumberString(new Random(), 5).ToLower(); entity.FullName = string.Format("{0}副本{1}", entity.FullName, random); entity.EnCode = string.Format("{0}{1}", entity.EnCode, random); entity.Id = SnowflakeIdHelper.NextId(); entity.EnabledMark = 0; entity.TemplateType = "0"; entity.LastModifyTime = null; entity.LastModifyUserId = null; if (entity.FullName.Length >= 50 || entity.EnCode.Length >= 50) throw Oops.Oh(ErrorCode.COM1009); var templateParamList = await _repository.AsSugarClient().Queryable().Where(x => x.TemplateId == id && x.DeleteMark == null).ToListAsync(); foreach (var item in templateParamList) { var paramEntity = item.Adapt(); paramEntity.TemplateId = entity.Id; paramEntity.Id = SnowflakeIdHelper.NextId(); await _repository.AsSugarClient().Insertable(paramEntity).IgnoreColumns(ignoreNullColumn: true).CallEntityMethod(m => m.Create()).ExecuteCommandAsync(); } var smsFieldList = await _repository.AsSugarClient().Queryable().Where(x => x.TemplateId == id && x.DeleteMark == null).ToListAsync(); foreach (var item in smsFieldList) { var smsFieldEntity = item.Adapt(); smsFieldEntity.TemplateId = entity.Id; smsFieldEntity.Id = SnowflakeIdHelper.NextId(); await _repository.AsSugarClient().Insertable(smsFieldEntity).IgnoreColumns(ignoreNullColumn: true).CallEntityMethod(m => m.Creator()).ExecuteCommandAsync(); } var isOk = await _repository.AsInsertable(entity).IgnoreColumns(ignoreNullColumn: true).CallEntityMethod(m => m.Create()).ExecuteCommandAsync(); if (isOk < 1) throw Oops.Oh(ErrorCode.COM1008); } #endregion }