示例#1
0
        public void Delete(ImportDataSearch request)
        {
            var matches = Get(request) as List <ImportData>;

            if (true != matches?.Any())
            {
                throw new HttpError(HttpStatusCode.NotFound, "No matches for request");
            }
            matches.ForEach(match =>
            {
                Delete(match);
            });
        }
示例#2
0
 public object Get(ImportDataSearch request) => GetSearchResultWithCache <ImportData, DocEntityImportData, ImportDataSearch>(DocConstantModelName.IMPORTDATA, request, _ExecSearch);
示例#3
0
        private IQueryable <DocEntityImportData> _ExecSearch(ImportDataSearch request, DocQuery query)
        {
            request = InitSearch <ImportData, ImportDataSearch>(request);
            IQueryable <DocEntityImportData> entities = null;

            query.Run(session =>
            {
                entities = query.SelectAll <DocEntityImportData>();
                if (!DocTools.IsNullOrEmpty(request.FullTextSearch))
                {
                    var fts  = new ImportDataFullTextSearch(request);
                    entities = GetFullTextSearch <DocEntityImportData, ImportDataFullTextSearch>(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.IMPORTDATA, 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.CompletedOn))
                {
                    entities = entities.Where(en => null != en.CompletedOn && request.CompletedOn.Value.Date == en.CompletedOn.Value.Date);
                }
                if (!DocTools.IsNullOrEmpty(request.CompletedOnBefore))
                {
                    entities = entities.Where(en => en.CompletedOn <= request.CompletedOnBefore);
                }
                if (!DocTools.IsNullOrEmpty(request.CompletedOnAfter))
                {
                    entities = entities.Where(en => en.CompletedOn >= request.CompletedOnAfter);
                }
                if (true == request.DataSetsIds?.Any())
                {
                    entities = entities.Where(en => en.DataSets.Any(r => r.Id.In(request.DataSetsIds)));
                }
                if (!DocTools.IsNullOrEmpty(request.Document) && !DocTools.IsNullOrEmpty(request.Document.Id))
                {
                    entities = entities.Where(en => en.Document.Id == request.Document.Id);
                }
                if (true == request.DocumentIds?.Any())
                {
                    entities = entities.Where(en => en.Document.Id.In(request.DocumentIds));
                }
                if (!DocTools.IsNullOrEmpty(request.ErrorData))
                {
                    entities = entities.Where(en => en.ErrorData.Contains(request.ErrorData));
                }
                if (!DocTools.IsNullOrEmpty(request.ErrorDatas))
                {
                    entities = entities.Where(en => en.ErrorData.In(request.ErrorDatas));
                }
                if (!DocTools.IsNullOrEmpty(request.ExtractUrl))
                {
                    entities = entities.Where(en => en.ExtractUrl.Contains(request.ExtractUrl));
                }
                if (!DocTools.IsNullOrEmpty(request.ExtractUrls))
                {
                    entities = entities.Where(en => en.ExtractUrl.In(request.ExtractUrls));
                }
                if (true == request.HighPriority?.Any())
                {
                    entities = entities.Where(en => en.HighPriority.In(request.HighPriority));
                }
                if (true == request.ImportFr?.Any())
                {
                    entities = entities.Where(en => en.ImportFr.In(request.ImportFr));
                }
                if (!DocTools.IsNullOrEmpty(request.ImportLocation) && !DocTools.IsNullOrEmpty(request.ImportLocation.Id))
                {
                    entities = entities.Where(en => en.ImportLocation.Id == request.ImportLocation.Id);
                }
                if (true == request.ImportLocationIds?.Any())
                {
                    entities = entities.Where(en => en.ImportLocation.Id.In(request.ImportLocationIds));
                }
                else if (!DocTools.IsNullOrEmpty(request.ImportLocation) && !DocTools.IsNullOrEmpty(request.ImportLocation.Name))
                {
                    entities = entities.Where(en => en.ImportLocation.Name == request.ImportLocation.Name);
                }
                if (true == request.ImportLocationNames?.Any())
                {
                    entities = entities.Where(en => en.ImportLocation.Name.In(request.ImportLocationNames));
                }
                if (true == request.ImportNewName?.Any())
                {
                    entities = entities.Where(en => en.ImportNewName.In(request.ImportNewName));
                }
                if (true == request.ImportTable?.Any())
                {
                    entities = entities.Where(en => en.ImportTable.In(request.ImportTable));
                }
                if (true == request.ImportText?.Any())
                {
                    entities = entities.Where(en => en.ImportText.In(request.ImportText));
                }
                if (!DocTools.IsNullOrEmpty(request.ImportType) && !DocTools.IsNullOrEmpty(request.ImportType.Id))
                {
                    entities = entities.Where(en => en.ImportType.Id == request.ImportType.Id);
                }
                if (true == request.ImportTypeIds?.Any())
                {
                    entities = entities.Where(en => en.ImportType.Id.In(request.ImportTypeIds));
                }
                else if (!DocTools.IsNullOrEmpty(request.ImportType) && !DocTools.IsNullOrEmpty(request.ImportType.Name))
                {
                    entities = entities.Where(en => en.ImportType.Name == request.ImportType.Name);
                }
                if (true == request.ImportTypeNames?.Any())
                {
                    entities = entities.Where(en => en.ImportType.Name.In(request.ImportTypeNames));
                }
                if (true == request.IsLegacy?.Any())
                {
                    entities = entities.Where(en => en.IsLegacy.In(request.IsLegacy));
                }
                if (request.Order.HasValue)
                {
                    entities = entities.Where(en => request.Order.Value == en.Order);
                }
                if (request.ReferenceId.HasValue)
                {
                    entities = entities.Where(en => request.ReferenceId.Value == en.ReferenceId);
                }
                if (!DocTools.IsNullOrEmpty(request.RequestedBy) && !DocTools.IsNullOrEmpty(request.RequestedBy.Id))
                {
                    entities = entities.Where(en => en.RequestedBy.Id == request.RequestedBy.Id);
                }
                if (true == request.RequestedByIds?.Any())
                {
                    entities = entities.Where(en => en.RequestedBy.Id.In(request.RequestedByIds));
                }
                if (!DocTools.IsNullOrEmpty(request.RequestedOn))
                {
                    entities = entities.Where(en => null != en.RequestedOn && request.RequestedOn.Value.Date == en.RequestedOn.Value.Date);
                }
                if (!DocTools.IsNullOrEmpty(request.RequestedOnBefore))
                {
                    entities = entities.Where(en => en.RequestedOn <= request.RequestedOnBefore);
                }
                if (!DocTools.IsNullOrEmpty(request.RequestedOnAfter))
                {
                    entities = entities.Where(en => en.RequestedOn >= request.RequestedOnAfter);
                }
                if (!DocTools.IsNullOrEmpty(request.StartedOn))
                {
                    entities = entities.Where(en => null != en.StartedOn && request.StartedOn.Value.Date == en.StartedOn.Value.Date);
                }
                if (!DocTools.IsNullOrEmpty(request.StartedOnBefore))
                {
                    entities = entities.Where(en => en.StartedOn <= request.StartedOnBefore);
                }
                if (!DocTools.IsNullOrEmpty(request.StartedOnAfter))
                {
                    entities = entities.Where(en => en.StartedOn >= request.StartedOnAfter);
                }
                if (!DocTools.IsNullOrEmpty(request.Status) && !DocTools.IsNullOrEmpty(request.Status.Id))
                {
                    entities = entities.Where(en => en.Status.Id == request.Status.Id);
                }
                if (true == request.StatusIds?.Any())
                {
                    entities = entities.Where(en => en.Status.Id.In(request.StatusIds));
                }
                else if (!DocTools.IsNullOrEmpty(request.Status) && !DocTools.IsNullOrEmpty(request.Status.Name))
                {
                    entities = entities.Where(en => en.Status.Name == request.Status.Name);
                }
                if (true == request.StatusNames?.Any())
                {
                    entities = entities.Where(en => en.Status.Name.In(request.StatusNames));
                }

                entities = ApplyFilters <DocEntityImportData, ImportDataSearch>(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(ImportDataSearch request) => Get(request);