using System.Data;
using System.Linq.Expressions;
using AgileObjects.AgileMapper;
using Microsoft.AspNetCore.Http;
using OfficeOpenXml.FormulaParsing.Excel.Functions.Text;
using SqlSugar;
using Tiobon.Core.Common;
using Tiobon.Core.Common.DB.Dapper;
using Tiobon.Core.Common.DB.Dapper.Extensions;
using Tiobon.Core.Common.Enums;
using Tiobon.Core.Common.Extensions;
using Tiobon.Core.Common.Helper;
using Tiobon.Core.Common.UserManager;
using Tiobon.Core.DataAccess;
using Tiobon.Core.IRepository.Base;
using Tiobon.Core.IServices;
using Tiobon.Core.IServices.BASE;
using Tiobon.Core.Model;
using Tiobon.Core.Model.Models.RootTkey;
namespace Tiobon.Core.Services.BASE;
///
/// 增删改查基础服务
///
///
///
///
///
public class BaseServices : IBaseServices where TEntity : class, new()
{
public BaseServices(IBaseRepository BaseDal = null)
{
this.BaseDal = BaseDal;
}
//public IBaseRepository baseDal = new BaseRepository();
public IBaseRepository BaseDal { get; set; } //通过在子类的构造函数中注入,这里是基类,不用构造函数
public ISqlSugarClient Db => BaseDal.Db;
///
/// 根据ID查询实体数据是否存在
///
///
///
public async Task AnyAsync(object objId)
{
var data = await BaseDal.AnyAsync(objId);
return data;
}
public async Task QueryById(object objId)
{
var data = await BaseDal.QueryById(objId);
var dto = Mapper.Map(data).ToANew();
#region 系统信息
var getType = typeof(TEntityDto).GetProperties();
if (getType.Any(p => p.Name == "CreateDataInfo") && getType.Any(p => p.Name == "UpdateDataInfo"))
{
var userIds = new List();
var CreateDataInfo = getType.Where(p => p.Name == "CreateDataInfo").FirstOrDefault();
var UpdateDataInfo = getType.Where(p => p.Name == "UpdateDataInfo").FirstOrDefault();
var CreateBy = getType.Where(p => p.Name == "CreateBy").FirstOrDefault();
var UpdateBy = getType.Where(p => p.Name == "UpdateBy").FirstOrDefault();
var CreateTime = getType.Where(p => p.Name == "CreateTime").FirstOrDefault();
var UpdateTime = getType.Where(p => p.Name == "UpdateTime").FirstOrDefault();
var createBy = CreateBy.GetValue(dto, null);
var updateBy = UpdateBy.GetValue(dto, null);
DateTime? createTime = CreateTime.GetValue(dto, null) != null ? Convert.ToDateTime(CreateTime.GetValue(dto, null)) : null;
DateTime? updateTime = UpdateTime.GetValue(dto, null) != null ? Convert.ToDateTime(UpdateTime.GetValue(dto, null)) : null;
if (createBy != null)
{
var dt = await Db.Ado.GetDataTableAsync($"SELECT UserId, UserName FROM Ghrs_User WHERE UserId='{createBy}'");
if (dt.Rows.Count > 0)
CreateDataInfo.SetValue(dto, $"创建信息 {dt.Rows[0]["UserName"]} 于 {(createTime != null ? createTime.Value.ToString(@"yyyy\/MM\/dd HH:mm") : null)} 创建");
}
if (updateBy != null)
{
var dt = await Db.Ado.GetDataTableAsync($"SELECT UserId, UserName FROM Ghrs_User WHERE UserId='{updateBy}'");
UpdateDataInfo.SetValue(dto, $"修改信息 {dt.Rows[0]["UserName"]} 于 {(updateTime != null ? updateTime.Value.ToString(@"yyyy\/MM\/dd HH:mm") : null)} 最后修改");
}
}
//if (exampaper.CreateBy != null)
// userIds.Add(Convert.ToInt32(exampaper.CreateBy.Value));
//if (exampaper.UpdateBy != null)
// userIds.Add(Convert.ToInt32(exampaper.UpdateBy.Value));
//var users = await _ghrs_UserServices.Query(x => userIds.Contains(x.UserId));
//if (exampaper.CreateBy != null)
// input.CreateDataInfo =
//if (exampaper.UpdateBy != null)
// input.CreateDataInfo = ;
#endregion
return dto;
}
///
/// 根据ID查询一条数据
///
/// id(必须指定主键特性 [SugarColumn(IsPrimaryKey=true)]),如果是联合主键,请使用Where条件
/// 是否使用缓存
/// 数据实体
public async Task QueryById(object objId, bool blnUseCache = false)
{
var data = await BaseDal.QueryById(objId, blnUseCache);
return Mapper.Map(data).ToANew();
}
///
/// 根据ID查询数据
///
/// id列表(必须指定主键特性 [SugarColumn(IsPrimaryKey=true)]),如果是联合主键,请使用Where条件
/// 数据实体列表
public async Task> QueryByIDs(object[] lstIds)
{
var data = await BaseDal.QueryByIDs(lstIds);
return Mapper.Map(data).ToANew>();
}
#region 新增
///
/// 写入实体数据
///
/// 实体类
///
public async Task Add(TInsertDto entity)
{
HttpRequest request = UserContext.Context.Request;
var api = request.Path.ObjToString().TrimEnd('/').ToLower();
var ip = GetUserIp(UserContext.Context);
var entity1 = Mapper.Map(entity).ToANew();
BasePoco ent = entity1 as BasePoco;
ent.CreateIP = ip;
ent.CreateProg = api;
#region 检查是否存在相同值
CheckOnly(entity1);
#endregion
return await BaseDal.Add(entity1);
}
///
/// 批量插入实体(速度快)
///
/// 实体集合
/// 影响行数
public async Task> Add(List listEntity)
{
var userId = UserContext.Current.User_Id;
HttpRequest request = UserContext.Context.Request;
var api = request.Path.ObjToString().TrimEnd('/').ToLower();
var ip = GetUserIp(UserContext.Context);
var list = Mapper.Map(listEntity).ToANew>();
list.ForEach(entity =>
{
BasePoco ent = entity as BasePoco;
ent.CreateIP = ip;
ent.CreateProg = api;
#region 检查是否存在相同值
CheckOnly(entity);
#endregion
});
return await BaseDal.Add(list);
}
#endregion
///
/// 更新实体数据
///
/// 博文实体类
///
public async Task Update(long Id, TEditDto editModel)
{
HttpRequest request = UserContext.Context.Request;
var api = request.Path.ObjToString().TrimEnd('/').ToLower();
var ip = GetUserIp(UserContext.Context);
if (editModel == null || !await BaseDal.AnyAsync(Id))
return false;
var entity = await BaseDal.QueryById(Id);
ConvertTEditDto2TEntity(editModel, entity);
BasePoco ent = entity as BasePoco;
ent.UpdateIP = ip;
ent.UpdateProg = api;
CheckOnly(entity, Id);
return await BaseDal.Update(entity);
}
public async Task Update(Dictionary editModels)
{
HttpRequest request = UserContext.Context.Request;
var api = request.Path.ObjToString().TrimEnd('/').ToLower();
var ip = GetUserIp(UserContext.Context);
List entities = new List();
foreach (var keyValuePairs in editModels)
{
if (keyValuePairs.Value == null || !BaseDal.Any(keyValuePairs.Key))
continue;
var entity = await BaseDal.QueryById(keyValuePairs.Key);
ConvertTEditDto2TEntity(keyValuePairs.Value, entity);
BasePoco ent = entity as BasePoco;
ent.UpdateIP = ip;
ent.UpdateProg = api;
CheckOnly(entity, keyValuePairs.Key);
entities.Add(entity);
}
return await BaseDal.Update(entities);
}
///
/// 更新实体数据
///
/// 博文实体类
///
public async Task Update(List listEntity)
{
HttpRequest request = UserContext.Context.Request;
var api = request.Path.ObjToString().TrimEnd('/').ToLower();
var ip = GetUserIp(UserContext.Context);
listEntity.ForEach(entity =>
{
BasePoco ent = entity as BasePoco;
ent.UpdateIP = ip;
ent.UpdateProg = api;
});
return await BaseDal.Update(listEntity);
}
public async Task Update(TEntity entity, string where)
{
HttpRequest request = UserContext.Context.Request;
var api = request.Path.ObjToString().TrimEnd('/').ToLower();
var ip = GetUserIp(UserContext.Context);
BasePoco ent = entity as BasePoco;
ent.UpdateIP = ip;
ent.UpdateProg = api;
return await BaseDal.Update(entity, where);
}
public async Task Update(object operateAnonymousObjects)
{
return await BaseDal.Update(operateAnonymousObjects);
}
public async Task Update(TEntity entity, List lstColumns = null, List lstIgnoreColumns = null, string where = "")
{
return await BaseDal.Update(entity, lstColumns, lstIgnoreColumns, where);
}
///
/// 根据实体删除一条数据
///
/// 博文实体类
///
public async Task Delete(TEntity entity)
{
return await BaseDal.Delete(entity);
}
///
/// 删除指定ID的数据
///
/// 主键ID
///
public async Task DeleteById(object id)
{
return await BaseDal.DeleteById(id);
}
///
/// 删除指定ID的数据
///
/// 主键ID
///
public async Task DeleteById1(object id)
{
var entity = await BaseDal.QueryById(id);
BasePoco ent = entity as BasePoco;
ent.IsEnable = 0;
return await BaseDal.Update(entity);
}
///
/// 删除指定ID集合的数据(批量删除)
///
/// 主键ID集合
///
public async Task DeleteByIds(object[] ids)
{
return await BaseDal.DeleteByIds(ids);
}
///
/// 删除指定ID集合的数据(批量删除)
///
/// 主键ID集合
///
public async Task DeleteByIds1(long[] ids)
{
HttpRequest request = UserContext.Context.Request;
var api = request.Path.ObjToString().TrimEnd('/').ToLower();
var ip = GetUserIp(UserContext.Context);
List entities = new List();
foreach (var id in ids)
{
if (id == null || !BaseDal.Any(id))
continue;
var entity = await BaseDal.QueryById(id);
BasePoco ent = entity as BasePoco;
ent.UpdateIP = ip;
ent.UpdateProg = api;
ent.IsEnable = 0;
entities.Add(entity);
}
return await BaseDal.Update(entities);
}
///
/// 根据表达式,删除实体
///
/// 表达式
///
public async Task Delete(Expression> whereExpression)
{
return await BaseDal.Delete(whereExpression);
}
///
/// 查询所有数据
///
/// 数据列表
public async Task> Query()
{
return await BaseDal.Query();
}
///
/// 查询数据列表
///
/// 条件
/// 数据列表
public async Task> Query(string where)
{
return await BaseDal.Query(where);
}
///
/// 查询数据列表
///
/// whereExpression
/// 数据列表
public async Task> Query(Expression> whereExpression)
{
return await BaseDal.Query(whereExpression);
}
///
/// 按照特定列查询数据列表
///
///
///
///
public async Task> Query(Expression> expression)
{
return await BaseDal.Query(expression);
}
///
/// 按照特定列查询数据列表带条件排序
///
///
/// 过滤条件
/// 查询实体条件
/// 排序条件
///
public async Task> Query(Expression> expression, Expression> whereExpression, string orderByFileds)
{
return await BaseDal.Query(expression, whereExpression, orderByFileds);
}
///
/// 查询一个列表
///
/// 条件表达式
/// 排序字段,如name asc,age desc
/// 数据列表
public async Task> Query(Expression> whereExpression, Expression> orderByExpression, bool isAsc = true)
{
return await BaseDal.Query(whereExpression, orderByExpression, isAsc);
}
public async Task> Query(Expression> whereExpression, string orderByFileds)
{
return await BaseDal.Query(whereExpression, orderByFileds);
}
///
/// 查询一个列表
///
/// 条件
/// 排序字段,如name asc,age desc
/// 数据列表
public async Task> Query(string where, string orderByFileds)
{
return await BaseDal.Query(where, orderByFileds);
}
///
/// 根据sql语句查询
///
/// 完整的sql语句
/// 参数
/// 泛型集合
public async Task> QuerySql(string sql, SugarParameter[] parameters = null)
{
return await BaseDal.QuerySql(sql, parameters);
}
///
/// 根据sql语句查询
///
/// 完整的sql语句
/// 参数
/// DataTable
public async Task QueryTable(string sql, SugarParameter[] parameters = null)
{
return await BaseDal.QueryTable(sql, parameters);
}
///
/// 查询前N条数据
///
/// 条件表达式
/// 前N条
/// 排序字段,如name asc,age desc
/// 数据列表
public async Task> Query(Expression> whereExpression, int top, string orderByFileds)
{
return await BaseDal.Query(whereExpression, top, orderByFileds);
}
///
/// 查询前N条数据
///
/// 条件
/// 前N条
/// 排序字段,如name asc,age desc
/// 数据列表
public async Task> Query(string where, int top, string orderByFileds)
{
return await BaseDal.Query(where, top, orderByFileds);
}
///
/// 分页查询
///
/// 条件表达式
/// 页码(下标0)
/// 页大小
/// 排序字段,如name asc,age desc
/// 数据列表
public async Task> Query(Expression> whereExpression, int pageIndex, int pageSize, string orderByFileds)
{
return await BaseDal.Query(whereExpression, pageIndex, pageSize, orderByFileds);
}
///
/// 分页查询
///
/// 条件
/// 页码(下标0)
/// 页大小
/// 排序字段,如name asc,age desc
/// 数据列表
public async Task> Query(string where, int pageIndex, int pageSize, string orderByFileds)
{
return await BaseDal.Query(where, pageIndex, pageSize, orderByFileds);
}
public async Task> QueryPage(Expression> whereExpression, int pageIndex = 1, int pageSize = 20, string orderByFileds = null)
{
return await BaseDal.QueryPage(whereExpression, pageIndex, pageSize, orderByFileds);
}
public virtual async Task> QueryFilterPage(QueryBody body)
{
var data = await BaseDal.QueryFilterPage(body);
return new ServicePageResult(body.pageNum, data.result.DT_TablePageInfoT1.TotalCount, body.pageSize, Mapper.Map(data.result.DT_TableDataT1).ToANew>());
}
public async Task> Export(QueryBody body)
{
var data = await BaseDal.QueryFilterPage(body);
var fileId = await ReportHelper.SendFile(data.result.DT_TableDataT1.AsQueryable(), $"测试测试", null, null, null, null);
return ServiceResult.OprateSuccess("导出成功", fileId);
}
public async Task> QueryMuch(Expression> joinExpression, Expression> selectExpression, Expression> whereLambda = null) where T : class, new()
{
return await BaseDal.QueryMuch(joinExpression, selectExpression, whereLambda);
}
public async Task> QueryPage(PaginationModel pagination)
{
var express = DynamicLinqFactory.CreateLambda(pagination.Conditions);
return await QueryPage(express, pagination.PageIndex, pagination.PageSize, pagination.OrderByFileds);
}
#region 分表
public async Task> AddSplit(TEntity entity)
{
return await BaseDal.AddSplit(entity);
}
public async Task UpdateSplit(TEntity entity, DateTime dateTime)
{
return await BaseDal.UpdateSplit(entity, dateTime);
}
///
/// 根据实体删除一条数据
///
/// 博文实体类
///
public async Task DeleteSplit(TEntity entity, DateTime dateTime)
{
return await BaseDal.DeleteSplit(entity, dateTime);
}
public async Task QueryByIdSplit(object objId)
{
return await BaseDal.QueryByIdSplit(objId);
}
public async Task> QueryPageSplit(Expression> whereExpression, DateTime beginTime, DateTime endTime, int pageIndex = 1, int pageSize = 20, string orderByFields = null)
{
return await BaseDal.QueryPageSplit(whereExpression, beginTime, endTime, pageIndex, pageSize, orderByFields);
}
#endregion
public static string GetUserIp(HttpContext context)
{
string realIP = null;
string forwarded = null;
string remoteIpAddress = context.Connection.RemoteIpAddress.ToString();
if (context.Request.Headers.ContainsKey("X-Real-IP"))
{
realIP = context.Request.Headers["X-Real-IP"].ToString();
if (realIP != remoteIpAddress)
{
remoteIpAddress = realIP;
}
}
if (context.Request.Headers.ContainsKey("X-Forwarded-For"))
{
forwarded = context.Request.Headers["X-Forwarded-For"].ToString();
if (forwarded != remoteIpAddress)
{
remoteIpAddress = forwarded;
}
}
remoteIpAddress = remoteIpAddress.Replace("::ffff:", null);
return remoteIpAddress;
}
#region 辅助方法
///
/// 转换TEditDto2TEntity
///
///
///
///
protected void ConvertTEditDto2TEntity(TEditDto source, TEntity dest)
{
foreach (System.Reflection.PropertyInfo mItem in typeof(TEditDto).GetProperties())
{
if (dest.HasField(mItem.Name))
dest.SetValueForField(mItem.Name, mItem.GetValue(source, null));
}
//dest.SetValueForField(DbConsts.ColunmName_LastModificationTime, DateTimeHelper.Now());
//if (_currentUserId != default)
//{
// //dest.SetValueForField(DbConsts.ColunmName_LastModifierId, _currentUserId);
// dest.SetValueForField(DbConsts.ColunmName_LastModifier, _currentUserName);
//}
//if (_currentTenantId != null)
//{
// dest.SetValueForField(DbConsts.ColunmName_TenantId, _currentTenantId);
//}
}
///
/// 获取根据ID查询的条件
///
///
///
protected QueryFilter QueryFilterById(Guid id)
{
return new QueryFilter
{
PageIndex = 1,
PageSize = 1,
Sorting = string.Empty,
Conditions = string.Empty
};
}
#region 检查表中是否已经存在相同代码的数据
public static void CheckOnly(TEntity entity, long? id = null)
{
Type entityType = typeof(TEntity);
var tableName = entityType.GetEntityTableName();
var names = new List();
var values = new List