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); }); }
public object Get(ImportDataSearch request) => GetSearchResultWithCache <ImportData, DocEntityImportData, ImportDataSearch>(DocConstantModelName.IMPORTDATA, request, _ExecSearch);
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); }
public object Post(ImportDataSearch request) => Get(request);