Upgrade Nuget
大石头 编写于 2024-09-28 08:10:09
NewLife.Cube
using System.Runtime.Serialization;
using System.Web.Script.Serialization;
using System.Xml.Serialization;
using NewLife.Data;
using NewLife.Log;
using XCode;
using XCode.Exceptions;

namespace NewLife.Cube.Entity;

/// <summary>应用日志。用于OAuthServer的子系统</summary>
public partial class AppLog : Entity<AppLog>
{
    #region 对象操作
    static AppLog()
    {
        // 累加字段
        //Meta.Factory.AdditionalFields.Add(__.Logins);

        // 过滤器 UserModule、TimeModule、IPModule
        Meta.Modules.Add<UserModule>();
        Meta.Modules.Add<TimeModule>();
        Meta.Modules.Add<IPModule>();

        //Meta.Table.DataTable.InsertOnly = true;
    }
    #endregion

    #region 扩展属性
    /// <summary>应用</summary>
    [XmlIgnore, ScriptIgnore, IgnoreDataMember]
    public App App => Extends.Get(nameof(App), k => App.FindById(AppId));

    /// <summary>应用</summary>
    [Map(__.AppId, typeof(App), "Id")]
    public String AppName => App + "";
    #endregion

    #region 扩展查询
    /// <summary>根据编号查找</summary>
    /// <param name="id">编号</param>
    /// <returns>实体对象</returns>
    public static AppLog FindById(Int64 id)
    {
        if (id <= 0) return null;

        //// 实体缓存
        //if (Meta.Session.Count < 1000) return Meta.Cache.Find(e => e.Id == id);

        // 单对象缓存
        return Meta.SingleCache[id];

        //return Find(_.Id == id);
    }

    /// <summary>根据应用查找</summary>
    /// <param name="appId">应用</param>
    /// <returns>实体列表</returns>
    public static IList<AppLog> FindAllByAppId(Int32 appId)
    {
        if (appId <= 0) return new List<AppLog>();

        // 实体缓存
        if (Meta.Session.Count < 1000) return Meta.Cache.FindAll(e => e.AppId == appId);

        return FindAll(_.AppId == appId);
    }
    #endregion

    #region 高级查询
    /// <summary>高级搜索</summary>
    /// <param name="appId"></param>
    /// <param name="start"></param>
    /// <param name="end"></param>
    /// <param name="key"></param>
    /// <param name="page"></param>
    /// <returns></returns>
    public static IList<AppLog> Search(Int32 appId, DateTime start, DateTime end, String key, PageParameter page)
    {
        var exp = new WhereExpression();

        if (appId >= 0) exp &= _.AppId == appId;
        exp &= _.Id.Between(start, end, Meta.Factory.Snow);

        return FindAll(exp, page);
    }
    #endregion

    #region 业务操作
    /// <summary>创建日志</summary>
    /// <param name="appid"></param>
    /// <param name="action"></param>
    /// <param name="success"></param>
    /// <param name="remark"></param>
    /// <returns></returns>
    public static AppLog Create(Int32 appid, String action, Boolean success, String remark)
    {
        var log = new AppLog
        {
            AppId = appid,
            Action = action,
            Success = success,
            TraceId = DefaultSpan.Current?.TraceId,
            Remark = remark,
            CreateTime = DateTime.Now,
        };
        log.SaveAsync();

        return log;
    }

    /// <summary>删除指定日期之前的数据</summary>
    /// <param name="date"></param>
    /// <returns></returns>
    public static Int32 DeleteBefore(DateTime date) => Delete(_.Id < Meta.Factory.Snow.GetId(date) & _.Action == "Authorize" & _.CreateUser.IsNull());
    #endregion
}