v3.0.0
After 3 months, it's finally here. There have been no functional modifications since v3.0.0-beta7, only improved error checks and messages. The following is a summary of all the changes that went out in the beta versions.
Breaking Changes
DocumentDatareplaced byResourceObject. Thanks @btecu! (#400 via #403)- #317 via #428: rename
ContextGraphtoResourceGraph - #359 via #416 Nested Sort. Thanks @milosloub!
SortQuery: use public attribute string name when constructingSortQuery(SortDirection, AttrAttribute)toSortQuery(SortDirection, string)SortedAttributetoAttribute
IQueryableExtensionSort<T>(IQueryable<TSource>, List<SortQuery>)to
Sort<T>(IQueryable<TSource>, IJsonApiContext, List<SortQuery>)Sort<T>(IQueryable<TSource>, SortQuery)to
Sort<T>(IQueryable<TSource>, IJsonApiContext, SortQuery)Sort<T>(IOrderedQueryable<TSource>, SortQuery)to
Sort<T>(IOrderedQueryable<TSource>, IJsonApiContext, SortQuery)
Non-Breaking Changes
- #425 via #427: fix DocumentBuilder;
includesmember missing when fetching HasManyThrough. Thanks @maurei! - Naming conventions (#293 via #409)
[Attr] // → "compound-name"
public string CompoundName { get; set; }
builder.AddResource<TestResource>(); // → "test-resources"services.AddResourceService<FooService>();public class FooResource : ResourceDefinition<Foo>
{
protected override QueryFilters GetQueryFilters() => new QueryFilters {
{ "key1", (query, value) => query.Where(x => x == value) },
{ "key2", (query, value) => query.Where(x => x != value) },
};
public override PropertySortOrder<Foo> GetDefaultSortOrder() => new PropertySortOrder {
(foo => foo.Bar, SortDirection.Ascending),
(foo => foo.Baz, SortDirection.Descending),
}
}public class Article : Identifiable
{
[NotMapped] // ← tells EF to ignore this property
[HasManyThrough(nameof(ArticleTags))] // ← tells JADNC to use this as an alias to ArticleTags.Tags
public List<Tag> Tags { get; set; }
// this is the EF join relationship
public List<ArticleTag> ArticleTags { get; set; }
}- #382 via #395: Identifiable causes exceptions in Post
- #39 via #378: Deeply Nested Inclusions. Thanks @NullVoxPopuli for all the help landing this!
- #388 Exact Error Codes for Error Collections thanks @rtablada !
- #387 Additional filter operations: isnull and isnotnull thanks @NullVoxPopuli !
Usage
This change introduces two new filter operators isnull and isnotnull. Like all other operators, it is appended by a colon (:), however, any value provided after the colon is ignored.
GET /api/v1/todo-items?filter[updated-date]=isnull: HTTP/1.1
Accept: application/vnd.api+json