Пример #1
0
        public void Delete(TermMasterSearch request)
        {
            var matches = Get(request) as List <TermMaster>;

            if (true != matches?.Any())
            {
                throw new HttpError(HttpStatusCode.NotFound, "No matches for request");
            }
            matches.ForEach(match =>
            {
                Delete(match);
            });
        }
Пример #2
0
 public object Get(TermMasterSearch request) => GetSearchResultWithCache <TermMaster, DocEntityTermMaster, TermMasterSearch>(DocConstantModelName.TERMMASTER, request, _ExecSearch);
Пример #3
0
        private IQueryable <DocEntityTermMaster> _ExecSearch(TermMasterSearch request, DocQuery query)
        {
            request = InitSearch <TermMaster, TermMasterSearch>(request);
            IQueryable <DocEntityTermMaster> entities = null;

            query.Run(session =>
            {
                entities = query.SelectAll <DocEntityTermMaster>();
                if (!DocTools.IsNullOrEmpty(request.FullTextSearch))
                {
                    var fts  = new TermMasterFullTextSearch(request);
                    entities = GetFullTextSearch <DocEntityTermMaster, TermMasterFullTextSearch>(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.TERMMASTER, 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.BioPortal))
                {
                    entities = entities.Where(en => en.BioPortal.Contains(request.BioPortal));
                }
                if (!DocTools.IsNullOrEmpty(request.BioPortals))
                {
                    entities = entities.Where(en => en.BioPortal.In(request.BioPortals));
                }
                if (true == request.CategoriesIds?.Any())
                {
                    entities = entities.Where(en => en.Categories.Any(r => r.Id.In(request.CategoriesIds)));
                }
                if (!DocTools.IsNullOrEmpty(request.CUI))
                {
                    entities = entities.Where(en => en.CUI.Contains(request.CUI));
                }
                if (!DocTools.IsNullOrEmpty(request.CUIs))
                {
                    entities = entities.Where(en => en.CUI.In(request.CUIs));
                }
                if (!DocTools.IsNullOrEmpty(request.Enum) && !DocTools.IsNullOrEmpty(request.Enum.Id))
                {
                    entities = entities.Where(en => en.Enum.Id == request.Enum.Id);
                }
                if (true == request.EnumIds?.Any())
                {
                    entities = entities.Where(en => en.Enum.Id.In(request.EnumIds));
                }
                if (true == request.EnumNames?.Any())
                {
                    entities = entities.Where(en => en.Enum.Name.In(request.EnumNames));
                }
                if (!DocTools.IsNullOrEmpty(request.MedDRA))
                {
                    entities = entities.Where(en => en.MedDRA.Contains(request.MedDRA));
                }
                if (!DocTools.IsNullOrEmpty(request.MedDRAs))
                {
                    entities = entities.Where(en => en.MedDRA.In(request.MedDRAs));
                }
                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 (!DocTools.IsNullOrEmpty(request.RxNorm))
                {
                    entities = entities.Where(en => en.RxNorm.Contains(request.RxNorm));
                }
                if (!DocTools.IsNullOrEmpty(request.RxNorms))
                {
                    entities = entities.Where(en => en.RxNorm.In(request.RxNorms));
                }
                if (!DocTools.IsNullOrEmpty(request.SNOWMED))
                {
                    entities = entities.Where(en => en.SNOWMED.Contains(request.SNOWMED));
                }
                if (!DocTools.IsNullOrEmpty(request.SNOWMEDs))
                {
                    entities = entities.Where(en => en.SNOWMED.In(request.SNOWMEDs));
                }
                if (true == request.SynonymsIds?.Any())
                {
                    entities = entities.Where(en => en.Synonyms.Any(r => r.Id.In(request.SynonymsIds)));
                }
                if (!DocTools.IsNullOrEmpty(request.TUI))
                {
                    entities = entities.Where(en => en.TUI.Contains(request.TUI));
                }
                if (!DocTools.IsNullOrEmpty(request.TUIs))
                {
                    entities = entities.Where(en => en.TUI.In(request.TUIs));
                }
                if (!DocTools.IsNullOrEmpty(request.URI))
                {
                    entities = entities.Where(en => en.URI.Contains(request.URI));
                }
                if (!DocTools.IsNullOrEmpty(request.URIs))
                {
                    entities = entities.Where(en => en.URI.In(request.URIs));
                }

                entities = ApplyFilters <DocEntityTermMaster, TermMasterSearch>(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);
        }
Пример #4
0
 public object Post(TermMasterSearch request) => Get(request);