using JNPF.Common.Core.Manager; using JNPF.Common.Enums; using JNPF.Common.Filter; using JNPF.DependencyInjection; using JNPF.DynamicApiController; using JNPF.FriendlyException; using JNPF.Systems.Entitys.Dto.ModuleDataAuthorizeScheme; using JNPF.Systems.Entitys.Permission; using JNPF.Systems.Entitys.System; using JNPF.Systems.Interfaces.System; using Mapster; using Microsoft.AspNetCore.Mvc; using SqlSugar; namespace JNPF.Systems; /// /// 数据权限 /// 版 本:V3.2 /// 版 权:拓通智联科技有限公司(http://www.tuotong-tech.com) /// 日 期:2021-06-01. /// [ApiDescriptionSettings(Tag = "System", Name = "ModuleDataAuthorizeScheme", Order = 214)] [Route("api/system/[controller]")] public class ModuleDataAuthorizeSchemeService : IModuleDataAuthorizeSchemeService, IDynamicApiController, ITransient { /// /// 服务基础仓储. /// private readonly ISqlSugarRepository _repository; /// /// 用户管理器. /// private readonly IUserManager _userManager; /// /// 初始化一个类型的新实例. /// /// /// public ModuleDataAuthorizeSchemeService( ISqlSugarRepository repository, IUserManager userManager) { _repository = repository; _userManager = userManager; } #region GET /// /// 列表. /// /// 功能主键. /// 参数. /// [HttpGet("{moduleId}/List")] public async Task GetList(string moduleId, [FromQuery] KeywordInput input) { var list = await GetList(moduleId); if (!string.IsNullOrEmpty(input.keyword)) list = list.FindAll(t => t.EnCode.Contains(input.keyword) || t.FullName.Contains(input.keyword)); return new { list = list.Adapt>() }; } /// /// 信息. /// /// 主键值. /// [HttpGet("{id}")] public async Task GetInfo_Api(string id) { var data = await _repository.GetFirstAsync(x => x.Id == id && x.DeleteMark == null); return data.Adapt(); } #endregion #region POST /// /// 删除. /// /// 主键值. /// [HttpDelete("{id}")] public async Task Delete(string id) { if (!await _repository.IsAnyAsync(x => x.Id == id && x.DeleteMark == null)) throw Oops.Oh(ErrorCode.COM1005); var isOk = await _repository.AsUpdateable().SetColumns(it => new ModuleDataAuthorizeSchemeEntity() { DeleteMark = 1, DeleteUserId = _userManager.UserId, DeleteTime = SqlFunc.GetDate() }).Where(it => it.Id == id).ExecuteCommandHasChangeAsync(); if (!isOk) throw Oops.Oh(ErrorCode.COM1002); } /// /// 新建. /// /// 实体对象. /// [HttpPost("")] public async Task Create([FromBody] ModuleDataAuthorizeSchemeCrInput input) { if (await _repository.IsAnyAsync(x => (x.EnCode == input.enCode || x.FullName == input.fullName) && x.DeleteMark == null && x.ModuleId == input.moduleId)) throw Oops.Oh(ErrorCode.COM1004); var entity = input.Adapt(); var isOk = await _repository.AsInsertable(entity).IgnoreColumns(ignoreNullColumn: true).CallEntityMethod(m => m.Creator()).ExecuteCommandAsync(); if (isOk < 1) throw Oops.Oh(ErrorCode.COM1000); } /// /// 编辑. /// /// 主键值. /// 实体对象. /// [HttpPut("{id}")] public async Task Update(string id, [FromBody] ModuleDataAuthorizeSchemeUpInput input) { if (await _repository.IsAnyAsync(x => (x.EnCode == input.enCode || x.FullName == input.fullName) && x.DeleteMark == null && x.ModuleId == input.moduleId && x.Id != id)) throw Oops.Oh(ErrorCode.COM1004); var entity = input.Adapt(); var isOk = await _repository.AsUpdateable(entity).IgnoreColumns(ignoreAllNullColumns: true).CallEntityMethod(m => m.LastModify()).ExecuteCommandHasChangeAsync(); if (!isOk) throw Oops.Oh(ErrorCode.COM1001); } #endregion #region PublicMethod /// /// 列表. /// /// 功能主键. /// [NonAction] public async Task> GetList(string? moduleId) { return await _repository.AsQueryable().Where(x => x.DeleteMark == null && x.ModuleId == moduleId).OrderBy(a => a.SortCode).OrderBy(a => a.CreatorTime, OrderByType.Desc).OrderBy(a => a.LastModifyTime, OrderByType.Desc).ToListAsync(); } /// /// 获取用户资源列表. /// [NonAction] public async Task GetResourceList() { var output = new List(); if (!_userManager.IsAdministrator) { var roles = _userManager.Roles; if (roles.Any()) { var items = await _repository.AsSugarClient().Queryable().In(a => a.ObjectId, roles).Where(a => a.ItemType == "resource").Select(a => a.ItemId).ToListAsync(); var buttons = await _repository.AsQueryable().Where(a => items.Contains(a.Id)).Where(a => a.EnabledMark == 1 && a.DeleteMark == null).Select().OrderBy(q => q.SortCode).ToListAsync(); output = buttons.Adapt>(); } } else { var buttons = await _repository.AsQueryable().Where(a => a.EnabledMark == 1 && a.DeleteMark == null).Select().OrderBy(q => q.SortCode).ToListAsync(); output = buttons.Adapt>(); } return output; } #endregion }