public object Get(UserRequestSearch request) => GetSearchResultWithCache <UserRequest, DocEntityUserRequest, UserRequestSearch>(DocConstantModelName.USERREQUEST, request, _ExecSearch);
private IQueryable <DocEntityUserRequest> _ExecSearch(UserRequestSearch request, DocQuery query) { request = InitSearch <UserRequest, UserRequestSearch>(request); IQueryable <DocEntityUserRequest> entities = null; query.Run(session => { entities = query.SelectAll <DocEntityUserRequest>(); if (!DocTools.IsNullOrEmpty(request.FullTextSearch)) { var fts = new UserRequestFullTextSearch(request); entities = GetFullTextSearch <DocEntityUserRequest, UserRequestFullTextSearch>(fts, entities); } if (null != request.Ids && request.Ids.Any()) { entities = entities.Where(en => en.Id.In(request.Ids)); } if (!DocTools.IsNullOrEmpty(request.Updated)) { entities = entities.Where(e => null != e.Updated && e.Updated.Value.Date == request.Updated.Value.Date); } if (!DocTools.IsNullOrEmpty(request.UpdatedBefore)) { entities = entities.Where(e => null != e.Updated && e.Updated <= request.UpdatedBefore); } if (!DocTools.IsNullOrEmpty(request.UpdatedAfter)) { entities = entities.Where(e => null != e.Updated && e.Updated >= request.UpdatedAfter); } if (!DocTools.IsNullOrEmpty(request.Created)) { entities = entities.Where(e => null != e.Created && e.Created.Value.Date == request.Created.Value.Date); } if (!DocTools.IsNullOrEmpty(request.CreatedBefore)) { entities = entities.Where(e => null != e.Created && e.Created <= request.CreatedBefore); } if (!DocTools.IsNullOrEmpty(request.CreatedAfter)) { entities = entities.Where(e => null != e.Created && e.Created >= request.CreatedAfter); } if (true == request.Archived?.Any() && currentUser.HasProperty(DocConstantModelName.USERREQUEST, nameof(Reference.Archived), DocConstantPermission.VIEW)) { entities = entities.Where(en => en.Archived.In(request.Archived)); } else { entities = entities.Where(en => !en.Archived); } if (true == request.Locked?.Any()) { entities = entities.Where(en => en.Locked.In(request.Locked)); } if (!DocTools.IsNullOrEmpty(request.App) && !DocTools.IsNullOrEmpty(request.App.Id)) { entities = entities.Where(en => en.App.Id == request.App.Id); } if (true == request.AppIds?.Any()) { entities = entities.Where(en => en.App.Id.In(request.AppIds)); } if (!DocTools.IsNullOrEmpty(request.Method)) { entities = entities.Where(en => en.Method.Contains(request.Method)); } if (!DocTools.IsNullOrEmpty(request.Methods)) { entities = entities.Where(en => en.Method.In(request.Methods)); } if (!DocTools.IsNullOrEmpty(request.Page) && !DocTools.IsNullOrEmpty(request.Page.Id)) { entities = entities.Where(en => en.Page.Id == request.Page.Id); } if (true == request.PageIds?.Any()) { entities = entities.Where(en => en.Page.Id.In(request.PageIds)); } if (!DocTools.IsNullOrEmpty(request.Path)) { entities = entities.Where(en => en.Path.Contains(request.Path)); } if (!DocTools.IsNullOrEmpty(request.Paths)) { entities = entities.Where(en => en.Path.In(request.Paths)); } if (!DocTools.IsNullOrEmpty(request.URL)) { entities = entities.Where(en => en.URL.Contains(request.URL)); } if (!DocTools.IsNullOrEmpty(request.URLs)) { entities = entities.Where(en => en.URL.In(request.URLs)); } if (!DocTools.IsNullOrEmpty(request.UserSession) && !DocTools.IsNullOrEmpty(request.UserSession.Id)) { entities = entities.Where(en => en.UserSession.Id == request.UserSession.Id); } if (true == request.UserSessionIds?.Any()) { entities = entities.Where(en => en.UserSession.Id.In(request.UserSessionIds)); } entities = ApplyFilters <DocEntityUserRequest, UserRequestSearch>(request, entities); if (request.Skip > 0) { entities = entities.Skip(request.Skip.Value); } if (request.Take > 0) { entities = entities.Take(request.Take.Value); } if (true == request?.OrderBy?.Any()) { entities = entities.OrderBy(request.OrderBy); } if (true == request?.OrderByDesc?.Any()) { entities = entities.OrderByDescending(request.OrderByDesc); } }); return(entities); }
public object Post(UserRequestSearch request) => Get(request);