Exemplo n.º 1
0
 public object Get(UserRequestSearch request) => GetSearchResultWithCache <UserRequest, DocEntityUserRequest, UserRequestSearch>(DocConstantModelName.USERREQUEST, request, _ExecSearch);
Exemplo n.º 2
0
        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);
        }
Exemplo n.º 3
0
 public object Post(UserRequestSearch request) => Get(request);