public ActionResult Find(Log4netFindViewModel model) { //LoggerFactory.CreateLog().Debug(string.Format(CultureInfo.InvariantCulture, "Presentation Layer - FindLog4net Controller Begin")); //int totalCount = 0; try { // Add find logic here if (ModelState.IsValid) { if (model.OrderBy == null) { model.OrderBy = "Id"; } string sort = "Id"; var filtros = GenerateExpression(model); var pagedResult = _serviceLog4net.FindPagedByFilter(filtros, null, 1, model.PageSize, model.OrderBy, "Asc", null, null); model.Paginate(pagedResult, ""); //var Log4netDetails = _serviceAlim.Query( // new Log4netQuery().Withfilter(filtros)) // .OrderBy(n => n.OrderBy("Id", "Asc")) // .SelectPage(1, model.PageSize, out totalCount); //var pagelist = new { total = totalCount, rows = Log4netDetails.ToList() }; //var pagedResult = _serviceLog4net.FindPagedByFilter(expression, includes, 1, model.PageSize, "Id", model.OrderBy, model.Ascendent, null, null); //model.Paginate(pagedResult, expression.SerializedExpression); TempData.Clear(); TempData.Add("FilterLog4net", model); //LoggerFactory.CreateLog().Debug(string.Format(CultureInfo.InvariantCulture, "Presentation Layer - FindLog4net Controller End")); return(PartialView("_Log4netFindPartialView", model)); } } catch (Exception ex) { //LoggerFactory.CreateLog().Error(string.Format(CultureInfo.InvariantCulture, "Presentation Layer - FindLog4net Controller ERROR"), ex); } ModelState.AddModelError("", PresentationResources.Error); return(View("Log4netFindView", new Log4netFindViewModel(_serviceLog4net))); }
// GET public ActionResult Find(int?page = 1, string sort = "Id", string sortDir = "ASC") { //LoggerFactory.CreateLog().Debug(string.Format(CultureInfo.InvariantCulture, "Presentation Layer - FindLog4net Controller Begin")); try { // Add find logic here Log4netFindViewModel model; if (Request.IsAjaxRequest() && TempData.ContainsKey("FilterLog4net")) { model = (Log4netFindViewModel)TempData.Peek("FilterLog4net"); var filtros = GenerateExpression(model); var pagedResult = _serviceLog4net.FindPagedByFilter(filtros, null, page != null ? (int)page : model.PageIndex, model.PageSize, sort, sortDir, null, null); model.Paginate(pagedResult, ""); //var pagedResult = _serviceLog4net.FindPagedByFilter(new CustomQuery<Log4net> { SerializedExpression = model.Filter }, null, page != null ? (int)page : model.PageIndex, model.PageSize, sort, sortDir == "ASC", null); //model.Paginate(pagedResult, model.Filter); //LoggerFactory.CreateLog().Debug(string.Format(CultureInfo.InvariantCulture, "Presentation Layer - FindPagedLog4net Controller End")); return(PartialView("_Log4netFindPartialView", model)); } else { TempData.Remove("FilterLog4net"); model = new Log4netFindViewModel(_serviceLog4net); //LoggerFactory.CreateLog().Debug(string.Format(CultureInfo.InvariantCulture, "Presentation Layer - FindLog4net Controller End")); return(View("Log4netFindView", model)); } } catch (Exception ex) { //LoggerFactory.CreateLog().Error(string.Format(CultureInfo.InvariantCulture, "Presentation Layer - FindLog4net Controller ERROR"), ex); } return(RedirectToAction("Index", "Home")); }
//private static QueryObject<Log4net> GenerateExpression(Log4netFindViewModel model) private static IEnumerable <filterRule> GenerateExpression(Log4netFindViewModel model) { //LoggerFactory.CreateLog().Debug(string.Format(CultureInfo.InvariantCulture, "Presentation Layer - FindAlim Controller Begin")); //var filters = JsonConvert.DeserializeObject<IEnumerable<filterRule>>(filterRules); //return Json(pagelist, JsonRequestBehavior.AllowGet); IList <filterRule> filtros = new List <filterRule>(); if (model != null) { if (model.Log4net.Id.HasValue) { filtros.Add(new filterRule() { op = "equal", field = "Id", value = model.Log4net.Id.Value.ToString() }); } //And(d => d.Id == model.Log4net.Id.Value); if (!string.IsNullOrEmpty(model.Log4net.Level)) { filtros.Add(new filterRule() { op = "equal", field = "Level", value = model.Log4net.Level }); } //And(d => d.Level.Contains(model.Log4net.Level)); if (!string.IsNullOrEmpty(model.Log4net.Logger)) { filtros.Add(new filterRule() { op = "equal", field = "Logger", value = model.Log4net.Logger }); } //And(d => d.Logger.Contains(model.Log4net.Logger)); if (!string.IsNullOrEmpty(model.Log4net.Host)) { filtros.Add(new filterRule() { op = "equal", field = "Host", value = model.Log4net.Host }); } //And(d => d.Host.Contains(model.Log4net.Host)); if (model.Log4net.Date.HasValue) { filtros.Add(new filterRule() { op = "equal", field = "Date", value = model.Log4net.Date.Value.ToString() }); } //And(d => d.Date == model.Log4net.Date.Value); if (!string.IsNullOrEmpty(model.Log4net.Thread)) { filtros.Add(new filterRule() { op = "equal", field = "Thread", value = model.Log4net.Thread }); } //And(d => d.Thread.Contains(model.Log4net.Thread)); if (!string.IsNullOrEmpty(model.Log4net.Message)) { filtros.Add(new filterRule() { op = "equal", field = "Message", value = model.Log4net.Message }); } //And(d => d.Message.Contains(model.Log4net.Message)); if (!string.IsNullOrEmpty(model.Log4net.Exception)) { filtros.Add(new filterRule() { op = "equal", field = "Exception", value = model.Log4net.Exception }); } //And(d => d.Exception.Contains(model.Log4net.Exception)); } return(filtros); //return new QueryObject<Log4net>(expression ?? (d => true)); }