public void Delete(JunctionSearch request) { var matches = Get(request) as List <Junction>; if (true != matches?.Any()) { throw new HttpError(HttpStatusCode.NotFound, "No matches for request"); } matches.ForEach(match => { Delete(match); }); }
public object Get(JunctionSearch request) => GetSearchResultWithCache <Junction, DocEntityJunction, JunctionSearch>(DocConstantModelName.JUNCTION, request, _ExecSearch);
private IQueryable <DocEntityJunction> _ExecSearch(JunctionSearch request, DocQuery query) { request = InitSearch <Junction, JunctionSearch>(request); IQueryable <DocEntityJunction> entities = null; query.Run(session => { entities = query.SelectAll <DocEntityJunction>(); if (!DocTools.IsNullOrEmpty(request.FullTextSearch)) { var fts = new JunctionFullTextSearch(request); entities = GetFullTextSearch <DocEntityJunction, JunctionFullTextSearch>(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.JUNCTION, 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.ChildrenIds?.Any()) { entities = entities.Where(en => en.Children.Any(r => r.Id.In(request.ChildrenIds))); } if (request.OwnerId.HasValue) { entities = entities.Where(en => request.OwnerId.Value == en.OwnerId); } if (!DocTools.IsNullOrEmpty(request.OwnerType)) { entities = entities.Where(en => en.OwnerType.Contains(request.OwnerType)); } if (!DocTools.IsNullOrEmpty(request.OwnerTypes)) { entities = entities.Where(en => en.OwnerType.In(request.OwnerTypes)); } if (!DocTools.IsNullOrEmpty(request.Parent) && !DocTools.IsNullOrEmpty(request.Parent.Id)) { entities = entities.Where(en => en.Parent.Id == request.Parent.Id); } if (true == request.ParentIds?.Any()) { entities = entities.Where(en => en.Parent.Id.In(request.ParentIds)); } if (request.TargetId.HasValue) { entities = entities.Where(en => request.TargetId.Value == en.TargetId); } if (!DocTools.IsNullOrEmpty(request.TargetType)) { entities = entities.Where(en => en.TargetType.Contains(request.TargetType)); } if (!DocTools.IsNullOrEmpty(request.TargetTypes)) { entities = entities.Where(en => en.TargetType.In(request.TargetTypes)); } if (!DocTools.IsNullOrEmpty(request.Type) && !DocTools.IsNullOrEmpty(request.Type.Id)) { entities = entities.Where(en => en.Type.Id == request.Type.Id); } if (true == request.TypeIds?.Any()) { entities = entities.Where(en => en.Type.Id.In(request.TypeIds)); } else if (!DocTools.IsNullOrEmpty(request.Type) && !DocTools.IsNullOrEmpty(request.Type.Name)) { entities = entities.Where(en => en.Type.Name == request.Type.Name); } if (true == request.TypeNames?.Any()) { entities = entities.Where(en => en.Type.Name.In(request.TypeNames)); } if (!DocTools.IsNullOrEmpty(request.User) && !DocTools.IsNullOrEmpty(request.User.Id)) { entities = entities.Where(en => en.User.Id == request.User.Id); } if (true == request.UserIds?.Any()) { entities = entities.Where(en => en.User.Id.In(request.UserIds)); } entities = ApplyFilters <DocEntityJunction, JunctionSearch>(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(JunctionSearch request) => Get(request);