Esempio n. 1
0
 public object Get(DataClassSearch request) => GetSearchResultWithCache <DataClass, DocEntityDataClass, DataClassSearch>(DocConstantModelName.DATACLASS, request, _ExecSearch);
Esempio n. 2
0
        private IQueryable <DocEntityDataClass> _ExecSearch(DataClassSearch request, DocQuery query)
        {
            request = InitSearch <DataClass, DataClassSearch>(request);
            IQueryable <DocEntityDataClass> entities = null;

            query.Run(session =>
            {
                entities = query.SelectAll <DocEntityDataClass>();
                if (!DocTools.IsNullOrEmpty(request.FullTextSearch))
                {
                    var fts  = new DataClassFullTextSearch(request);
                    entities = GetFullTextSearch <DocEntityDataClass, DataClassFullTextSearch>(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.DATACLASS, 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 (true == request.AllowDelete?.Any())
                {
                    entities = entities.Where(en => en.AllowDelete.In(request.AllowDelete));
                }
                if (true == request.AllSelectByDefault?.Any())
                {
                    entities = entities.Where(en => en.AllSelectByDefault.In(request.AllSelectByDefault));
                }
                if (request.Base.HasValue)
                {
                    entities = entities.Where(en => request.Base.Value == en.Base);
                }
                if (!DocTools.IsNullOrEmpty(request.Bases))
                {
                    entities = entities.Where(en => en.Base.In(request.Bases));
                }
                if (request.CacheDuration.HasValue)
                {
                    entities = entities.Where(en => request.CacheDuration.Value == en.CacheDuration);
                }
                if (request.ClassId.HasValue)
                {
                    entities = entities.Where(en => request.ClassId.Value == en.ClassId);
                }
                if (true == request.CustomCollectionsIds?.Any())
                {
                    entities = entities.Where(en => en.CustomCollections.Any(r => r.Id.In(request.CustomCollectionsIds)));
                }
                if (true == request.DELETE?.Any())
                {
                    entities = entities.Where(en => en.DELETE.In(request.DELETE));
                }
                if (!DocTools.IsNullOrEmpty(request.Description))
                {
                    entities = entities.Where(en => en.Description.Contains(request.Description));
                }
                if (!DocTools.IsNullOrEmpty(request.Descriptions))
                {
                    entities = entities.Where(en => en.Description.In(request.Descriptions));
                }
                if (true == request.DontFlattenPropertiesIds?.Any())
                {
                    entities = entities.Where(en => en.DontFlattenProperties.Any(r => r.Id.In(request.DontFlattenPropertiesIds)));
                }
                if (!DocTools.IsNullOrEmpty(request.DtoSuffix))
                {
                    entities = entities.Where(en => en.DtoSuffix.Contains(request.DtoSuffix));
                }
                if (!DocTools.IsNullOrEmpty(request.DtoSuffixs))
                {
                    entities = entities.Where(en => en.DtoSuffix.In(request.DtoSuffixs));
                }
                if (true == request.FlattenReferences?.Any())
                {
                    entities = entities.Where(en => en.FlattenReferences.In(request.FlattenReferences));
                }
                if (true == request.GET?.Any())
                {
                    entities = entities.Where(en => en.GET.In(request.GET));
                }
                if (true == request.IgnorePropsIds?.Any())
                {
                    entities = entities.Where(en => en.IgnoreProps.Any(r => r.Id.In(request.IgnorePropsIds)));
                }
                if (true == request.IsInsertOnly?.Any())
                {
                    entities = entities.Where(en => en.IsInsertOnly.In(request.IsInsertOnly));
                }
                if (true == request.IsReadOnly?.Any())
                {
                    entities = entities.Where(en => en.IsReadOnly.In(request.IsReadOnly));
                }
                if (!DocTools.IsNullOrEmpty(request.Name))
                {
                    entities = entities.Where(en => en.Name.Contains(request.Name));
                }
                if (!DocTools.IsNullOrEmpty(request.Names))
                {
                    entities = entities.Where(en => en.Name.In(request.Names));
                }
                if (true == request.PATCH?.Any())
                {
                    entities = entities.Where(en => en.PATCH.In(request.PATCH));
                }
                if (true == request.POST?.Any())
                {
                    entities = entities.Where(en => en.POST.In(request.POST));
                }
                if (true == request.PropertiesIds?.Any())
                {
                    entities = entities.Where(en => en.Properties.Any(r => r.Id.In(request.PropertiesIds)));
                }
                if (true == request.PUT?.Any())
                {
                    entities = entities.Where(en => en.PUT.In(request.PUT));
                }
                if (true == request.TabsIds?.Any())
                {
                    entities = entities.Where(en => en.Tabs.Any(r => r.Id.In(request.TabsIds)));
                }

                entities = ApplyFilters <DocEntityDataClass, DataClassSearch>(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);
        }
Esempio n. 3
0
 public object Post(DataClassSearch request) => Get(request);