using Longbow.Web.Mvc; using MongoDB.Driver; using PetaPoco; using System; using System.Linq; namespace Bootstrap.DataAccess.MongoDB { /// /// /// public class Log : DataAccess.Log { /// /// /// /// /// /// /// /// public override Page Retrieves(PaginationOption po, DateTime? startTime, DateTime? endTime, string opType) { var filterBuilder = Builders.Filter; var filter = filterBuilder.Empty; if (startTime.HasValue) filter = filterBuilder.Gte("LogTime", startTime.Value); if (endTime.HasValue) filter = filterBuilder.Lt("LogTime", endTime.Value.AddDays(1).AddSeconds(-1)); if (startTime == null && endTime == null) filter = filterBuilder.Gt("LogTime", DateTime.Today.AddMonths(0 - DictHelper.RetrieveAccessLogPeriod())); if (!string.IsNullOrEmpty(opType)) filter = filterBuilder.Eq("CRUD", opType); // sort var sortBuilder = Builders.Sort; SortDefinition sort = null; switch (po.Sort) { case "CRUD": sort = po.Order == "asc" ? sortBuilder.Ascending(t => t.CRUD) : sortBuilder.Descending(t => t.CRUD); break; case "UserName": sort = po.Order == "asc" ? sortBuilder.Ascending(t => t.UserName) : sortBuilder.Descending(t => t.UserName); break; case "LogTime": sort = po.Order == "asc" ? sortBuilder.Ascending(t => t.LogTime) : sortBuilder.Descending(t => t.LogTime); break; case "Ip": sort = po.Order == "asc" ? sortBuilder.Ascending(t => t.Ip) : sortBuilder.Descending(t => t.Ip); break; case "RequestUrl": sort = po.Order == "asc" ? sortBuilder.Ascending(t => t.RequestUrl) : sortBuilder.Descending(t => t.RequestUrl); break; } var logs = DbManager.Logs.Find(filter).Sort(sort).ToList(); return new Page() { Context = logs, CurrentPage = po.PageIndex, ItemsPerPage = po.Limit, TotalItems = logs.Count, TotalPages = (long)Math.Ceiling(logs.Count * 1.0 / po.Limit), Items = logs.Skip(po.Offset).Take(po.Limit).ToList() }; } /// /// 删除日志信息 /// /// /// private static void DeleteLogAsync() => System.Threading.Tasks.Task.Run(() => DbManager.Logs.DeleteMany(log => log.LogTime < DateTime.Now.AddDays(-7))); /// /// /// /// /// public override bool Save(DataAccess.Log log) { DbManager.Logs.InsertOne(log); DeleteLogAsync(); return true; } } }