Releases: elastic/elasticsearch-net
5.0.0-rc4
Features
- #2164 Allow
Reindex()helper to reindex into an existing index - #2436 Add support for Sliced Scrolls
Enhancements
- #2430 Do not instantiate
QueryContainerDescriptor<T>unneccessarily - #2389 Add support for
UpdateMany()in the bulk API - #2418 Faster
enumtostringresolution - #2166 Allow
DisableDirectStreaming()on a per request basis - #2336 Allow the key of a bucket aggregation to be read as any type; previously, it was always deserialized to
string.
Bug Fixes
-
#2431 Add
include_in_allontoTypeMapping -
#2420 Fix the way in which
HttpClientare created when using theHttpConnectionon .NET Core. AHttpClientwas created based on a hashcode ofRequestDatathat included a regression bug that caused multiple instances ofHttpClientto be created. Now, forRequestDatawhere- RequestTimeout
- HttpCompression
- ProxyAddress
- ProxyUsername
- ProxyPassword
- DisableAutomaticProxyDetection
do not change, the same
HttpClientinstance will be used -
#2428 Add specific type for term vectors in
MutliTermVectorsResponseinstead of reusingTermVectorsResponse -
#2422 Use
ScriptProcessorDescriptorin the fluent API of ingest node -
#2440 Ensure that each part of the async pipeline for Desktop CLR
HttpConnectioncan be cancelled correctly
Deprecations and Removals
- #1958 Allow exceptions late in the pipeline to bubble out as
UnexpectedElasticsearchClientExceptione.g.ResolveExceptionthat can happen within the transport when serializing to json.
View the full list of issues and PRs
2.5.0
Features
- #2164 Allow
Reindex()helper to reindex into an existing index - #2413 Implement Watcher APIs 👀
Enhancements
- #2430 Do not instantiate
QueryContainerDescriptor<T>unneccessarily - #2389 Add support for
UpdateMany()in the bulk API - #2418 Faster
enumtostringresolution - #2414 Add
MinNestedScoreMode
Bug Fixes
-
#2431 Add
include_in_allontoTypeMapping -
#2420 Fix the way in which
HttpClientare created when using theHttpConnectionon .NET Core. AHttpClientwas created based on a hashcode ofRequestDatathat included a regression bug that caused multiple instances ofHttpClientto be created. Now, forRequestDatawhere- RequestTimeout
- HttpCompression
- ProxyAddress
- ProxyUsername
- ProxyPassword
- DisableAutomaticProxyDetection
do not change, the same
HttpClientinstance will be used -
#2142 Set the
ApiCalldetails on eachTermVectorsResponsein the collection of responses in aMultiTermVectorsResponse -
#2440 Ensure that each part of the async pipeline for Desktop CLR
HttpConnectioncan be cancelled correctly
View the full list of issues and PRs
5.0.0-rc3
Bug Fixes
- #2412 Fix a number of dictionary serialization issues
A recent change did not handle a number of dictionary serialization cases including
-
types that implement
IReadOnlyDictionary<TKey,TValue>e.g.
public class MyReadOnlyDictionary<TKey,TValue> : IReadOnlyDictionary<TKey,TValue> -
types that implement
IDictionary<TKey, TValue>e.g.
public class MyDictionary<TKey,TValue> : IDictionary<TKey,TValue> -
non-generic types that inherit a closed generic dictionary type
e.g.
public class MyDictionary : Dictionary<string,object> -
types that implement
IDictionarythat are not generice.g.
public class MyNonGenericDictionary : IDictionary
5.0.0-rc2
This is the 2nd release candidate compatible with Elasticsearch 5.0. Many features and fixes went into this release, including support for all the Watcher APIs.
We will be finalizing the client ready for a GA release.
Features
- #2347 Support for the Watcher/Alerting API
- #2220 Allow per document index operations on
BulkAll - #2326 Add support for
search_after - #2327 Add support for matrix stats aggregation
- #2334 Add support for Script and DotExpander ingest pipeline processors
- #2335 Infer the index name and type name from
TinSuggest<T>() - #2407 All collections on response types are either
IReadOnlyCollection<T>andIReadOnlyDictionary<TKey, TValue>. Additionally, all collections should be initialized. - #2349 inferred mapping on CLR string properties now sets
ignore_aboveto 256 on thekeywordsub field, in line with dynamic mapping in Elasticsearch
Bug Fixes
- #2331 Fix
SuffixExpressionVisitorto allow multiple calls of.AppendSuffix() - #2340 Correct time taken calculation in Audit trail to be non-negative
- #2350 SniffResponse now correctly matches on IPv6 addresses
- #2357 Correct Script serialization on bulk update operation
- #2362 Add
max_boundary_scanto highlight fields - #2344 Add back default value on
.Dynamic()mapping - #2366 404s on
Get<T>()andDelete<T>()(and async variants) now return.IsValidastrueand deserialize the response, setting.Found. - #2365
.Scoreis nullable onHit<T>
Removal / deprecations
- #2342 Remove
LanguageonUpdateRequestand rename toLang, and correct script serialization - #2399 Remove
IDictionaryfromIIsADictionary<TKey,TValue>interface definition. This was confusing and needed only for one purpose in the codebase. This has been refactored to perform better.
View the full list of issues and PRs
2.4.7
Behavioural Breaking Change
- #2367 404s on
Get<T>()andDelete<T>()(and async variants) now return.IsValidastrueand deserialize the response, setting.Found. This aligns the behaviour of 2.x with 1.x and 5.x. The implications of this are:
- when issuing a delete, if the delete actually deletes a document or the document to delete does not exist,
.IsValidistrue - when issuing a get where
.IsValidis true,.Foundshould also be checked to determine if the document existed
Features
BulkAll is designed to parallelize bulk requests to Elasticsearch by iterating a lazily constructed collection of POCO types and partitioning into multiple concurrent bulk requests. It includes simple logic for automatic backoff of requests when documents failed to be indexed due to HTTP 429 response errors and retrying in a configurable number of times in such cases.
Enhancements
- #2371 / #2323 Include the nested identity when performing
inner_hitson anestedtype - #2370 Infer the index name and type name from
TwithSuggest<T>() - #2309 / #2310 When a
ReindexOnServerResponsecomes back as 400 status code, deserialize the response so that Failures is populated with more details for why things failed.
Bug Fixes
- #2362 Add
max_boundary_scanto highlight fields - #2373 Fix script serialization when performing bulk updates
- #2357 Correct Script serialization on bulk update operation
- #2331 Fix
SuffixExpressionVisitorto allow multiple calls of.AppendSuffix() - #2319 / #2321 Fix issue where field expressions were incorrectly cached when a dynamic value and a suffix expression were used
- #2308 the
Tookfield was incorrectly mapped as anintvalue on some responses, instead oflong. Since the type cannot be changed (it would break binary compatibility), another field has been introduced,TookAsLong, that will hold the value returned from Elasticsearch;Tookwill also contain the value and for values greater thanint,Tookwill beint.MaxValue.Tookis marked withObsoleteattribute to highlight this to client consumers andTookis mapped aslongin NEST 5.x. thanks @maeserichar 👍
Deprecations and Removals
- #2346 Mark properties removed in 5.0 with
ObsoleteAttribute - #2297 Mark
MissingQuerywithObsoleteAttributeas removed in 5.0 - #2293 Mark
IndexNameon property mappings withObsoleteAttributeas removed in 5.0
View the full list of issues and PRs
5.0.0-rc1
This is the Elasticsearch 5.0.0-rc1 compatible release.
Features
#2322 Mappings: Added support for half_float and scaled_float numeric datatypes
#2337 Updated datatype properties to align with ES 5.0 across the board
#2320 Added ability to supply local metadata to mapping properties TY @ejsmith
#2292 Allow implicit conversion from string[] to Types and Indices
Bug Fixes
#2209 Several improvements in some Query DSL edge cases
#2339 SniffingConnectionPool: Fixed response parsing of _nodes when sniffing cluster state
#2319 Fixed caching of field expressions that contained both variables and constants
#2310 ReindexOnServer: Correctly handle 400 responses
#2308 Fixed deserialization of responses that contain took, which was incorrectly typed to int. TY @maeserichar !
#2295 XML doc fix. TY @niemyjski !
#2242 #2269 Enhancements to serialization of DateTime
#2195 Query on PhraseSuggestCollate is now correctly typed to ITemplateQuery
Removal / deprecations
#2297 Removed deprecated MissingQuery
#2293 Removed deprecated IndexName
View the full list of issues and PRs
5.0.0-beta1
This is the Elasticsearch 5.0.0-beta1 compatible release.
Features
#2233 Support for get task API
#2228 Support for multi search template API
#2228 Support for shrink index API
#2226 Support for rollover index API
#2246 Support for disable/enable user APIs of the X-Pack security plugin
#2241 Support for field_masking_span query (TY @yevhen!)
#2198 HttpClientHandler can now be modified in a custom HttpConnection when running on .NET Core. This makes it possible to validate HTTPS certs by setting ServerCertificateValidationCallback.
#2197 & #2247 Introduced an improved approach to ModifyJsonSerializerSettings for overriding Json.Net serialization settings using ISerializerFactory instead (TY @jonyadamit !)
Bug Fixes & Enhancements
#2274 Fix NRE when deserializing a mutli-bucket aggregate with an empty buckets object
#2261 Add missing routing option to FieldLookup
#2209 & #2209 Several improvements in some edgecase query DSL scenarios
#2221 Fixed issue with using a sniffing connection pool where a thread could potentially become blocked resulting in a timeout exception (TY @lostllama)
#2219 Add missing conflicts option to reindex API
#2215 Add missing term vector filters
#2215 add missing metadata on IGetResponse<T> and IMultiHit<T>
#2169 Move analyze query string parameters to request body
#2194 Removed deprecated Alias on GetAliasRequest (use Name instead) and added back the GetAliasesPointingToIndex() helper method.
#2193 Add missing collate_match option to geo_shape queries (TY @HarveyWilliams !)
#2187 Add relation to geo_shape queries and contains to geo_shape relations
#2178 Add ability to specify a custom similarity using both the fluent and object iniitalizer syntax
2.4.6
Features
- #2112 Support
ReindexRethrottlewhen running against Elasticsearch 2.4.0, to allow throttling of longer running tasks such as Reindex and UpdateByQuery APIs. - #2231 Support
field_masking_spanqueries. Mapped toSpanFieldMaskingQueryto align with names of other span queries.
Enhancements
- #2279 Support overloaded
UpdateByQuery()fluent methods that infer Indices and Types from generic parameter typeT - #2247 Enable conveniently overriding
JsonSerializerSettingswithout the need to implement a custom serializer. Thanks for the PR @jonyadamit 👍
Bug Fixes
- #2261
FieldLookupnow includes aRoutingproperty. ty @seanwm - #2178 Fix support for custom similarities using
CustomSimilarityobject or.Custom()fluent method onSimilaritiesDescriptor - #2170 Resolve to the smallest whole time unit when working with
DateMathas it does not support fractional values. For example,TimeSpan.FromHours(25)will serialize to25has opposed to round to1dor fractional value1.04d. ty @emmekappa - #2209 Improve boolean combinatorial logic when dealing with bool queries with many clauses
- #2168 Mark
.HighlightsonSearchResponse<T>as obsolete, to be removed in 5.x. It's a leaky abstraction when searching over multiple types that contain the same document id for different types - this will throw an exception. Highlights can be enumerated using
foreach (var hit in searchResponse.HitsMetaData.Hits)
{
foreach (var highlight in hit.Highlights)
{
// do something with highlightHit
var highlightHit = highlight.Value;
}
}- #2125 Allow use of custom highlighters (expert level option).
HighlightFieldnow contains aCustomTypestring property that can be used to specify a custom highlighter. Core highlighters can still be specified usingTypeproperty. - #2119 Allow use of per field custom similarity (expert level option).
ElasticsearchPropertyAttributeBaseand associated mapping methods allow the use of a custom similiarity through aCustomSimilaritystring property (on attributes and mapping objects) and through the.Similairy(string)fluent mapping method. Core similarities can still be specified. - #2274 Fix
NullReferenceExceptionwhen deserializing a multi-bucket aggregation that contains an empty bucket. - #2263 Do not use
IsoDateTimeConverterto handleDateTimeOffset. Take a look at #2268 for howDateTimeandDateTimeOffsetare serialized within NEST.
1.9.1
Features
- #2231 Support
field_masking_spanqueries. Mapped toSpanFieldMaskingQueryto align with names of other span queries. Thanks for the PR @yevhen 👍
Bug Fixes
- #2229 Allow
filter_keysstring array to be specified on call toClearCache(). The rest api json schema spec incorrectly identified this type asbool - #2208 Use the specified
Formatwhen serializing dates withinRangeFilter - #2191 Correctly deserialize both json representations (string or array of strings) of stop words on analyzers
- #2188 Correctly deserialize templates that contain alias definitions
2.4.5
Features
- 383623e Large performance improvements to MultiGet and MultiSearch calls:
- Cache JsonContracts per ConnectionSettings. It is recommended to share a single instance of
ConnectionSettingswithin your application for this reason. - Cache Delegates per ConnectionSettings for constructing items in a MultiGetResponse
- Cache Delegates per ConnectionSettings for constructing items in a MultiSearchResponse
- Reuse Inferrer instance on ConnectionSettings to take advantage of cached data.
- Reduce complexity in
IUrlParameter.GetString()forIndexNameandTypeName
- Cache JsonContracts per ConnectionSettings. It is recommended to share a single instance of
Thanks to @antonyfrancis for raising this 👍
Bug Fixes
- fced23c Fix description for
refreshon Index operation