using Attribute;
using Model;
using Model.Base;
using Repository;
using Service;
using Microsoft.AspNetCore.Mvc;
using Vo.Admin;
namespace Services
{
///
/// 日志表Service业务层处理
///
[AppService(ServiceType = typeof(ISysLogService), ServiceLifetime = LifeTime.Transient)]
public class SysLogService : BaseService, ISysLogService
{
///
/// 日志表-列表
///
/// 参数请求体
/// 分页参数
/// 列表
public PagedInfo getSysLogList([FromQuery] PagerInfo page, [FromQuery] SysLog param)
{
//拼装查询条件
var predicate = Expressionable.Create();
predicate = predicate.AndIF(!string.IsNullOrEmpty(param.Title), m => m.Title.Contains(param.Title));
predicate = predicate.AndIF(!string.IsNullOrEmpty(param.CreateBy), m => m.CreateBy.Contains(param.CreateBy));
predicate = predicate.AndIF(!string.IsNullOrEmpty(param.UpdateBy), m => m.UpdateBy.Contains(param.UpdateBy));
predicate = predicate.AndIF(!string.IsNullOrEmpty(param.Method), m => m.Method.Contains(param.Method));
var response = Queryable()
.Where(predicate.ToExpression())
.SplitTable(DateTime.Now.AddMonths(-3), DateTime.Now)
.OrderByDescending(m => m.Id)
.ToPage(page);
return response;
}
///
/// 日志表-详情
///
/// 参数请求体
/// 详情
public SysLog getSysLogQuery([FromQuery] SysLog param)
{
//拼装查询条件
var predicate = Expressionable.Create();
predicate = predicate.AndIF(param.Id > 0, m => m.Id == param.Id);
var response = Queryable()
.Where(predicate.ToExpression())
.SplitTable(DateTime.Now.AddMonths(-3), DateTime.Now)
.First();
return response;
}
///
/// 日志表-添加
///
/// 添加
public long addSysLog([FromBody] SysLog param)
{
return Insertable(param).SplitTable().ExecuteReturnSnowflakeId();
}
///
/// 日志表-修改
///
/// 参数请求体
/// 修改
public long updateSysLog([FromBody] SysLog param)
{
return Context.Updateable(param).SplitTable().ExecuteCommand();
}
///
/// 日志表-删除
///
/// 参数请求体
/// 删除
public long deleteSysLog(long id)
{
return Context.Deleteable(id).SplitTable().ExecuteCommand();
}
}
}