forked from abh/ElasticSearch.pm
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathChanges
533 lines (428 loc) · 19.6 KB
/
Changes
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
Revision history for ElasticSearch
0.61 2012-11-09
ENHANCEMENT
Ignore empty queryb/filterb sections
0.60 2012-11-07
ENHANCEMENT:
Added a max_content_length attribute to ElasticSearch::Transport
to avoid posting too large a body to elasticsearch. The value
is auto-detected in versions 0.19.12 onwards.
Added doc param to update()
0.59 2012-10-31
BREAKING CHANGE:
Added the 'explain' parameter to validate_query(), which now returns
a hash instead of true|false
BUG FIXES:
The queryb->query, filterb->filter SearchBuilder conversions no longer
change the original parameters
ENHANCEMENTS:
Added cluster_reroute()
Added type_exists()
Added warmer APIs
Added explain API
Added upsert to update()
Added ignore_indices param to search(), searchqs() and msearch()
Bulk error handlers now receive the element number of the error
to identify the original item in the array (required for Elastic::Model)
Errors now have string comparison overloaded
0.58 2012-08-09
Added a _method_name parameter to reindex() so that objects other
than ScrolledSearch can be passed as the $source. The scrolling
defaults to $source->next, but with $method_name will be called
as $source->$method_name.
0.57 2012-07-31
Minor changes to ElasticSearch::TestServer to make it work consistently
on Travis CI
0.56 2012-07-31
BUG FIXES
- Trying to bulk create a doc that already exists should also trigger
a conflict error, not a general error.
0.55 2012-07-06
ENHANCEMENTS
- Added on_conflict and on_error callbacks to bulk actions and reindex()
0.54 2012-06-30
NEW FEATURES
- Added exists()
ENHANCEMENTS
- An ElasticSearch::Error::Conflict object now contains the latest
version number
- delete_mapping() now throws an error when the index or type is
- get() now accepts a 'parent' param
- searchqs() now accecpts 'lenient', 'quote_analyzer' and
'quote_field_suffix' params
- msearch() now accepts a 'search_type' param
BUG FIXES
- Removed dependencies on Module::Build and base
missing
- Worked around bug https://github.com/elasticsearch/elasticsearch/issues/2072
in ES which causes the default HTTP backend to hang by returning
a response body to a HEAD request
- Fixed current_server_version() to work with async backends
0.53 2012-04-14
Bug fix:
- the timestamp param to index() should be a 'string', not
a 'duration'
0.52 2012-03-17
BREAKING CHANGE:
- get_alias() now uses the native GET alias request, and its output
format has changed.
Bug fix:
- put_mapping() incorrectly required a single index. Now it
can contain zero or more indices
0.51 2012-03-05
index() and create() were missing consistency and replication parameters
0.50 2012-03-02
- Added msearch()
- The short-circuit functions for bulk/mget weren't working correctly
either with as_json or async backends
- Fixed bug in TestServer where it wasn't shutting down ES correctly
if it failed to create a new ES.pm object
0.49 2012-02-17
Don't pass a custom port param through to ElasticSearch::TestServer
0.48 2012-02-17
BREAKING CHANGE:
Updated the bulk* methods to support index, type, timestamp and ttl
args. As a result, the method signatures have changed.
ENHANCEMENTS:
- index(), create() and the index/create bulk actions now accept
a JSON encoded string as a value for the 'data' param.
- added update()
- Added 'fields' to clear_cache
- Added index_segments()
- Added validate_query()
- Added ClusterBlock exception (code 403)
- Added NotReady exception (code 503)
- index_stats() now supports the 'all' flag
- Added params to nodes():
- http, jvm, network, os, process, thread_pool, transport
- Added params to nodes_stats():
- indices, clear, all, fs, http, jvm, network, os, process,
thread_pool, transport
- Added params to analyze():
- tokenizer, filters, field
- Added param 'partial_fields' to search()
- ElasticSearch::TestServer will now die if it can't find the
PID of the started ES process
- Added drain_buffer(), refill_buffer() and facets() to
ElasticSearch::ScrolledSearch
BUG FIXES:
- Fixed support for as_json in ScrolledSearch
- Fixed implicit IO::Handle bug when trying to log in older Perls
- Fixed a bug in index_stats and addded 'get' stats and groups.
- Corrected spelling of 'quorom' to 'quorum'
- create() now uses the index op_type instead of /_create to
fix a bug when creating a doc without an ID
- put_mapping wasn't respecting a type set with use_type()
0.47 2011-10-24
Merged patch from AVAR, which ensures that the servers are used in
random order.
0.46 2011-09-07
Fixed support for parent/child in reindex() - thanks to PERLER for
reporting
0.45 2011-08-27
Doc typo corrected
0.44 2011-08-27
Added support for deflate() to all HTTP Transport modules.
0.43 2011-08-26
Added ElasticSearch::Transport::AECurl, and async backend which uses
libcurl, via AnyEvent::Curl::Multi
0.42 2011-08-26
Dull Dist::Zilla change, for CPAN
0.41 2011-08-26
BREAKING CHANGES:
- ElasticSearch::Transport::Thrift is now in a separate release
- delete_index() and delete_mapping() now require an index
parameter, to avoid accidental deletes.
- the return value for the bulk() methods, when { as_json => 1}
is specified, is now the JSON equivalent of the normal
return value, not the raw value from ES
OTHER:
- started using Dist::Zilla
- Added ElasticSearch::Transport::Curl, as a separate release
- get_aliases now works with {as_json => 1}
0.40 2011-08-10
BREAKING CHANGE:
- index_exists now returns an empty list if the index doesn't exist.
Previously, it threw an error.
OTHER:
- Deprecated the use of top level mapping parameters in put_mapping()
in favour of just using the 'mapping' param
- IDs could not contain eg "/" before - now fixed with Any::URI::Escape
ie (URI::Escape or URI::Escape::XS)
- The 'servers' param to new() now defaults to localhost if not
specified
- The "scroll" param to scrolled_search() now defaults to '1m'
- added search_from and search_size to mlt()
- added analyze_wildcard and lowercase_expanded_terms to searchqs()
- mget() now returns [] if no docs specified, instead of dieing
- Made Test::More v 0.96 a dependency, and fixed the hashbang path
in the example (thanks to AVAR)
0.39 2011-07-19
- "type" is now optional for get() requests
- added index_exists()
- added mget()
- added SearchBuilder integration for aliases
0.38 2011-07-03
- Integrated ElasticSearch::SearchBuilder
- Deprecated the use of query types as top level params to count()
and delete_by_query() in favour of query or queryb
- trace_calls() now also accepts a filehandle (thanks FERREIRA)
- TestServer now supports ES_TRANSPORT=all
0.37 2011-05-01
BREAKING CHANGES:
- ElasticSearch::ScrolledSearch
$scrolled_search->next() now returns 1 result by default, instead
of $size results, to make it easier to write:
while (my $result = $scroll->next) {}
- ElasticSearch::TestServer is now an object which subclasses
ElasticSearch itself. connect_to_server() has been removed.
Also, the port parameter can be used to specify a custom start port
when starting the test server, making it easier to run the
test server while there is an existing ES server running.
0.36 2011-04-24
Updated ElasticSearch.pm to work with ElasticSearch version 0.16.0
New features:
- no_refresh:
Disable the automatic discovery of live nodes, to work with
remote clusters or proxied clusters
- scrolled_search():
Convenience iterator to wrap search/scroll requests
- reindex():
Utility to reindex data from one index to another, or one
cluster to another
- use_index()/use_type():
Set default index/type parameters
- searchqs():
URI/query string search, (as opposed to search() which uses a
request body)
- New search_type's : 'scan' and 'count'
- index_settings():
Retrieve index settings
0.35 2011-04-07
Added the 'dynamic_templates' option to put_mapping
0.34 2011-03-20
Fixed the tests for scrolling - turns out sorting when scrolling works
correctly. It was my tests which were bad.
0.33 2011-03-19
Added the ElasticSearch::Transport::HTTPTiny backend
0.32 2011-03-19
- Added as_json as an arg to all ES requests.
- Fixed a logic bug when setting the port manually in
ElasticSearch::TestServer
- Fixed a bug in ElasticSearch::TestServer which was
preventing it from working on OSX
Thanks to PERLER for the above
- Changed some query syntax in t/10-queryparser.t for perl 5.8.3
0.31 2011-03-16
Fixed a bad test plan
0.30 2011-03-16
- Added some missing requirements to Build.PL
- scroll() now accepts a 'scroll' parameter and works (but
sorting when scrolling still broken on the server)
- reindex_es.pl now also preserves the _parent and _routing fields
0.29 2011-03-15
- Updated the Changes file
0.28 2011-03-14
Support added for:
- Percolators
- create_percolator()
- delete_percolator()
- get_percolator()
- percolate()
- Open / Close index
- open_index()
- close_index()
- Index templates
- create_index_template()
- delete_index_template()
- index_template()
- Routing
- Parent docs
- Versioning
- Analyzer
- analyze()
- ElasticSearch::QueryParser
- Parses and filters query strings, to ensure that user
data is in an acceptable form for passing to ES
- ElasticSearch::TestServer
- starts a test server for use by the test suite
- factored out to make it easier for others to use
Also:
- create_index() now supports adding mappings at the same time
- Added bulk_create(), bulk_index() and bulk_delete()
- Bulk actions now accept _id and id etc, which means that
search results can be passed directly to bulk without renaming
these parameters
- Added river_status()
- New errors
- ElasticSearch::Error::Conflict - versioning conflict
- ElasticSearch::Error::Missing - requested index/doct etc missing
- both these errors inherit from ElasticSearch::Error::Request
- Added ignore_missing to many methods which allows you to ignore
Missing errors
- Added query_parser
- added timeout() as sugar for $es->transport->timeout()
- added refresh_servers() as sugar for $es->transport->refresh_servers()
In ElasticSearch::Transport
- added max_requests() to force a refresh of known live nodes
every $max_requests
- on the first request, the list of live nodes is automatically
updated
- made httplite recognise more error states as temporary Connection
errors
- added support for recognising 404 and 409 HTTP codes
- upgraded Thrift to version 5.0
- improvements to logging
Miscellaneous:
- added examples/reindex_es.pl
- fixed a bug in the Makefile.PL
0.27 2010-10-21
Fixed an undefined bug in Transport::refresh_servers which would
die if no nodes were found
0.26 2010-10-20
Added a missing dependency on parent.pm
0.25 2010-10-20
Another ambiguous use of localtime in ElasticSearch::Transport
0.24 2010-10-20
Corrected an ambiguous use of localtime in ElasticSearch::Transport
Added examples/search_issues.pl
Minor tidying to tests
0.23 2010-10-19
POD corrections
0.22 2010-10-19
Support ElasticSearch version 0.12.0
Added the bulk() method, for bulk indexing, creating and deleting
Added create_river(), delete_river() and get_river()
Added delete_mapping()
Added error_trace()
Completely refactored ElasticSearch to enable pluggable backends:
- The request parser methods now live in ElasticSearch/RequestParser.pm
although they are loaded into the ElasticSeach namespace
- Added ElasticSearch::Transport as a transport base class
- Added ElasticSearch::Transport::HTTP (default) as the LWP backend
- Added ElasticSearch::Transport::HTTPLite as the HTTP::Lite backend
- Added ElasticSearch::Transport::Thrift as the Thrift backend
- Added ElasticSearch::Error class for exception objects
- Added ElasticSearch::Util with some generally useful utilities
- A number of methods have from ElasticSearch to
ElasticSearch::transport including current_server(), servers(),
refresh_servers()
- Removed the debug() method - now use $ElasticSearch::DEBUG instead
- Added filter_keywords to ElasticSearch::Util
0.21 2010-09-18
Supports ElasticSearch version 0.10.0
Added the _source parameter to put_mapping()
0.20 2010-09-04
Supports ElasticSearch version 0.10.0
Added update_index_settings() plus test
Added pod coverage test
0.19 2010-08-19
Supports ElasticSearch version 0.9.1
Minor bug fix to cluster_state
Updated tests to use facet_filter instead of filter
0.18 2010-08-01
Updated Changes file
0.17 2010-08-01
Supports ElasticSearch version 0.9, which removes support for some
features of older versions.
- In search() added support for 'script_fields'
- In count() and delete_by_query() added support for 'custom_score',
'fuzzy', 'span_term', 'span_first', 'span_near', 'span_not',
'span_or'
- Removed terms() - now handled by search facets
- Added the 'full' parameter to flush_index()
- Changed put_mapping() to automatically prefix the type properties
definition with the type name
- Removed get_mapping() and replaced it with mapping(), which uses
the newly exposed GET _mapping API
- Added current_server_version()
- Added the 'filter_nodes', 'filter_metadata', 'filter_routing_table'
and 'filter_indices' params to cluster_state()
0.16 2010-05-20
Added an ElasticSearch::Error::Timeout error class, to catch
occassions when the request times out, instead of failing
for a different reason.
Also, catch 'Server closed connection' errors, and automatically
refresh_servers and retry the request.
0.15 2010-05-16
Fixed a bug in refresh_servers() introduced in 0.14, when forking
processes.
0.14 2010-05-16
The object now stores the original servers parameter, so that
if the nodes disassociate and the live server list is limited,
the object can still try the original servers.
0.13 2010-05-13
Added nodes_stats(), shutdown(), restart() and camel_case()
Removed Alien::ElasticSearch, as it is now easier to install
ElasticSearch directly.
Tested against ElasticSearch version 0.7.0
0.12 2010-04-16
Added scroll() and the indices_boost param to search()
Tested against ElasticSearch version 0.6.0
0.11 2010-04-07
Updated changelog
0.10 2010-04-07
Fixed the duration regex
Improved docs for shutdown()
0.09 2010-04-07
Changed refresh_servers to handle http_address and httpAddress
Added a terms filter test
0.08 2010-04-05
- Changed all_field to _all
0.07 2010-04-05
- All tests pass as of version 8cfa04cea3bc2317ee613384ced4da20cf2737aa
on 2010-04-04:
http://github.com/elasticsearch/elasticsearch/commit/8cfa04cea3bc2317ee613384ced4da20cf2737aa
- Updated the API to take into account ElasticSearch's change from
using camelCase to underscore_separators
- create() now uses the /_create postfix instead of op_type=create,
although that flag is still available through index() and set()
- Changed more_like_this and more_like_this_field to mlt and mlt_field
- Changed fuzzy_like_this and fuzzy_like_this_field to flt and flt_field
- Changed term() to use gt/gte/lt/lte instead of from/to and
fromInclusive/toInclusive
- put_mapping now defaults to { ignore_conflicts => 0 }, so the
default now is to complain
- In mlt, boost_terms:boolean and boost_terms_factor:float have now
been merged to boost_terms:float
0.06 2010-04-03
- The test suite now requires Alien::ElasticSearch, and uses its own
config file and work dir, so as not to interfere with existing
data
- Added clear_cache()
- Added fuzzy_like_this and fuzzy_like_this_field clauses to
count() and delete_by_query()
- Added more_like_this()
- Added more_like_this/more_like_this_field clauses to count()
and delete_by_query()
- Changed exclude_from and exclude_to to from_inclusive and to_inclusive
in the terms() query
- the filteredQuery clause renamed to 'filtered' as per a change in ES
- Added aliases() and get_aliases()
- Deleted the QueryDSL doc, as the ElasticSearch docs are much improved
0.05 2010-03-04
- Delayed connecting to the cluster until actually required (previously
it refreshed the server list in new() )
- Restructured the internals again, to make it easier to read
- Added cluster_health()
- Fixed the test suite so that auto-started nodes don't take over
the terminal
- Enabled more tests as ElasticSearch now less buggy
0.04 2010-02-23
- Added terms()
- Added get_mapping()
- Renamed create_mapping() to put_mapping()
- Added ignore_duplicate param to put_mapping
- skip create-duplicate-mapping test if cluster has more than one nodes
0.03 2010-02-21
- Corrected the docs for search/count/delete_by_query
- Added POD for the Query DSL
- Added a SIG{INT} to the test file, so that it shuts down the servers
if the test suite is interrupted
0.02 2010-02-21
- Rewrote the module completely to use a dispatch table -
makes it easier to extend
- Added a test suite
- Added Alien::ElasticSearch so that we can test against a live server
0.01 2010-02-16
First version, released on an unsuspecting world.