==================================================
Changes from 2019-08-15 00:00:00 +0000 to present.
==================================================

----------------------------------------
version 8.0 at 2021-08-14 22:16:33 +0000
----------------------------------------

  Change: 40dbb86b7b8d9b98f4572a9f362fdd94f4d57b40
  Author: Brad Lhotsky <brad@divisionbyzero.net>
  Date : 2021-08-14 15:15:28 +0000

    Support OpenSearch 1.0.0

    Add a check to the version lookup for opensearch. If opensearch is
    discovered, set version to 7.10. 

------------------------------------------
version 7.9.2 at 2021-08-14 02:17:04 +0000
------------------------------------------

  Change: 8adedd9d89bdcaac26844547d36813bfc75f511f
  Author: Brad Lhotsky <brad@divisionbyzero.net>
  Date : 2021-08-13 19:17:04 +0000

    Fix a warning in the 7.9.1 Release

    I was unable to `Dist::Zilla` to let me tag a `7.10` release, so I went
    with `7.9.1`. This caused a warning in `::Connection` for formatting the
    version string. 

  Change: 84dd4b08f113cadc0d8f71ac7bd5448536910f3f
  Author: Brad Lhotsky <brad@divisionbyzero.net>
  Date : 2021-08-13 19:07:49 +0000

    Version number fixed in Markdown 

------------------------------------------
version 7.9.1 at 2021-08-14 01:48:01 +0000
------------------------------------------

  Change: 3eef2f64709f5b9643c91544b839a1727b7f32c0
  Author: Brad Lhotsky <brad@divisionbyzero.net>
  Date : 2021-08-13 18:48:01 +0000

    Fix POD for xtests 

  Change: bc51180e9f87730ee0d220e5c1c8b22e7e740253
  Author: Brad Lhotsky <brad@divisionbyzero.net>
  Date : 2021-08-13 18:38:33 +0000

    Aggregations Updated

    * Recursive aggregation parsing to flatten records into a row/column format
    * Documentation updates for the
    `App::ElasticSearch::Utilities::Aggregations` * Make `es-aggregate.pl` more
    useful generally and move to `scripts/` * Fix alias handling for simple
    terms aggs 

  Change: d8c8be912a60156290cb68c046e3b3c8fafbc2ae
  Author: Brad Lhotsky <brad@divisionbyzero.net>
  Date : 2021-08-04 17:26:42 +0000

    Tests started to the aggregations parser 

  Change: 25e3fc64e388b3a84002d594e68516602970eb89
  Author: Brad Lhotsky <brad@divisionbyzero.net>
  Date : 2021-08-04 17:13:23 +0000

    Suss out the es_expand_aggregate syntax

    Now looks like:

    ``` [ALIAS=]AGG:FIELD[:PARAMS]

    PARAMS := [k=v,k1=v1,v1a] ```

    Add a few additional aggregations to the supported list. 

----------------------------------------
version 7.9 at 2021-07-30 18:19:09 +0000
----------------------------------------

  Change: f386e7003a442a0419fc62aa30d576312afa9efa
  Author: Brad Lhotsky <brad@divisionbyzero.net>
  Date : 2021-07-30 11:19:09 +0000

    Release 7.9

    * Fix timeout handling * Allow for connection preferences into the `meta`
    settings section * Allow `_id` to be shown by `es-search.pl` * Look in
    `~/.config` for `es-utils.yaml` * Started some work on library for handling
    aggregation queries 

  Change: ba56db091ef15fd365100e034b17a8de530333e6
  Author: Brad Lhotsky <brad@divisionbyzero.net>
  Date : 2021-07-14 15:07:21 +0000

    WIP: Substantial progress on the multi level aggregation script 

  Change: 5c2517a1264b4a381b11387125e63dada6fcef2a
  Author: Brad Lhotsky <brad@divisionbyzero.net>
  Date : 2021-07-08 14:50:45 +0000

    Adding es-aggregate.pl script

    `es-search.pl` has a lot of cruft. Creating `es-aggregate.pl` as a
    proof-of-concept starting from a clean slate to see if I can make the code
    more readable and more reusable. The idea being to push this code back into
    the library to make working with aggregations easier and cleaner. 

  Change: cfd98ad2e84ee1ea8791debe7f6e1809bd6a9af6
  Author: Brad Lhotsky <brad@divisionbyzero.net>
  Date : 2021-07-08 07:34:21 +0000

    Move the aggregation parsing out to it's own sub

    This is a long time coming, the handling of aggregations needs a major
    cleanup. First step is to break things up into more parseable blocks. 

  Change: ea453e9190173af63adce15b684dcad13e3b13c5
  Author: Brad Lhotsky <brad@divisionbyzero.net>
  Date : 2021-07-08 07:15:14 +0000

    Pass timeout to the object creation

    When converting to `App::ElasticSearch::Utilities::Connection`, I
    mistakenly removed the pass through of the `--timeout` parameter to the
    object creation. This restores the timeout capability. 

  Change: c8f664cfb09b928831945f82607eab5830faa066
  Author: Brad Lhotsky <brad@divisionbyzero.net>
  Date : 2021-07-08 07:14:50 +0000

    Allow HTTP username/password in meta

    The previous commit allowed overriding the destination for the connection.
    This allows users to override the HTTP basic auth username/password.

    ```yaml host: es-main.int.example.com meta:

    access:

    timestamp: t

    security:

    timestamp: @timestamp

    host: es-security.int.example.com

    proto: https

    http-username: bob

    password-exec: ~/bin/get-es-security-password.sh ``` 

  Change: 7c56813974cc069a6214daef8667551a8d31de65
  Author: Brad Lhotsky <brad@divisionbyzero.net>
  Date : 2021-07-08 06:55:14 +0000

    Added connection details to the meta section

    This update allows the metadata in the `~/.es-utils.yaml` file to include
    the `host`, `port`, and `proto`.

    Example:

    ```yaml host: es-main.int.example.com port: 80 meta:

    security:

    host: es-security.int.example.com

    port: 443

    proto: https ``` 

  Change: 797199f7af436597ffa67c486d5ea275b825e471
  Author: Matthew Feinberg <mattf@intex.com>
  Date : 2021-06-24 14:03:07 +0000

    For es-search.pl allow _id to be shown as a column when using --show and
    display _id when showing full result records. 

  Change: 6547b9893ad05e7cef565f4a2caf51b321091de0
  Author: Andrei Grechkin <andrei.grechkin@booking.com>
  Date : 2021-06-11 10:11:34 +0000

    Add support for the XDG Base Directory Specification

    Support configuration file placed in
    `$XDG_CONFIG_HOME/es-utils/config.yaml` 

  Change: 0f799636f22bf8bff51c25a890f12341f6f7b9d7
  Author: Brad Lhotsky <brad@divisionbyzero.net>
  Date : 2021-06-05 14:57:35 +0000

    Fix warning in es_request()

    When the index is undefined, the code throws a warning. 

  Change: fa084386a44bbda1a75ee961f8ea6228ab62fe0c
  Author: Brad Lhotsky <brad@divisionbyzero.net>
  Date : 2021-03-20 17:17:13 +0000

    The GitHub::Meta plugin stopped working and needed configuration 

  Change: c118b27b05d5e5e75b444b9537362d78e099176f
  Author: Brad Lhotsky <brad@divisionbyzero.net>
  Date : 2020-10-08 13:42:10 +0000

    Fix warnings when we encounter an unallocated shard 

----------------------------------------
version 7.8 at 2020-09-16 18:12:23 +0000
----------------------------------------

  Change: 7dbb50ff27914898417120f617def09279f8adc0
  Author: Brad Lhotsky <brad@divisionbyzero.net>
  Date : 2020-09-16 11:12:23 +0000

    Better handling of percentages

    For `--top` queries, be consistent about handling of the number of decimal
    places. Default to showing 3 digits to the right of the decimal, but allow
    a user to override it with `--precision`.

    Show the percentages in the summary when using `--days` greater than 1.

    Update the documentation. 

  Change: e55ca5e32f64bc10c1def43c4766b93fe1430679
  Author: Brad Lhotsky <brad@divisionbyzero.net>
  Date : 2020-09-04 13:00:37 +0000

    Add percentages to es-search.pl aggs

    Whenever an aggregation is used, output the percentage from 0-1 with the
    doc count. Additionally, in sub aggs, calculate the percentage of the
    parent bucket. 

  Change: 27a31a79da70aef08ec04586b9496160f2127007
  Author: Brad Lhotsky <brad@divisionbyzero.net>
  Date : 2020-06-08 09:52:42 +0000

    Remove the HOME paths from the lookup

    In the previous release, I added a check for the HOME environment variable,
    but I neglected to remove the originals from the search path. 

----------------------------------------
version 7.7 at 2020-06-08 15:34:40 +0000
----------------------------------------

  Change: 5cbe34afdc85b490d2938aa9e37a39f9b34ae6d6
  Author: Brad Lhotsky <brad@divisionbyzero.net>
  Date : 2020-06-08 08:34:40 +0000

    Bugfix release

    * Sending "0" value query parameters did not work previously * Only add the
    ~/.es-utils.* to the config search path if HOME is set * Fix typo in the
    documentation 

----------------------------------------
version 7.6 at 2020-03-27 22:43:58 +0000
----------------------------------------

  Change: 6cb7406e8cf4b112efe4fffd0a0138089d841597
  Author: Brad Lhotsky <brad@divisionbyzero.net>
  Date : 2020-03-27 15:43:58 +0000

    Release Version 7.6

    * In `::Query`, the `fields` element was deprecated a long time ago, so

    overload it as a source filter. * `es-search.pl`

    * Ensure `--missing` and `--exists` can be specified more than once

    * Enable source filtering when the user specifies `--show`

    * Honor `--max-batch-size` when `--all` is specified 

  Change: 8ef098984362da46348bec5bbb66de15f57c07a7
  Author: Brad Lhotsky <brad@divisionbyzero.net>
  Date : 2020-03-09 17:20:26 +0000

    Added es-index-blocks.pl to manage index blocks 

  Change: 7804940e5562e5edc9e4472c7e9dcb3c9eeeb97e
  Author: Brad Lhotsky <brad@divisionbyzero.net>
  Date : 2019-12-31 11:05:36 +0000

    Ensure error message isn't blank 

  Change: 6743298fac9c15c55ea719e61eb63d5397e2f60e
  Author: Brad Lhotsky <brad@divisionbyzero.net>
  Date : 2019-12-31 11:00:24 +0000

    Change aggregation ID and make debug output more useful.

    The debug output is now in a better format to paste to a Kibana instance
    for debugging. 

  Change: cc0f7b846e85d6a8397dea24ff4102083990cd3e
  Author: Vitaly Shupak <vitaly.shupak@deshaw.com>
  Date : 2019-12-09 18:03:10 +0000

    use LWP::UserAgent request instead of simple_request

    simple_request does not handle authentication responses, which breaks in
    environments where ElasticSearch requires Kerberos authentication. 

----------------------------------------
version 7.5 at 2019-11-21 21:39:18 +0000
----------------------------------------

  Change: eef552859755c3b446755232ef5cdab4fe39713f
  Author: Brad Lhotsky <brad@divisionbyzero.net>
  Date : 2019-11-21 13:39:18 +0000

    Version 7.5 Release 

  Change: fdccadaf74838e2876b5d370978ba780a8bbb819
  Author: Brad Lhotsky <brad@divisionbyzero.net>
  Date : 2019-11-21 13:33:31 +0000

    Include count in the --by ordering

    The default sort order for --by does not take into account the count of the
    sub buckets. This adds a secondary sort descending on the count of objects
    in each bucket. 

  Change: a27a8b23f9bfd25259539dbae83a54ffc5a40cc7
  Author: Brad Lhotsky <brad@divisionbyzero.net>
  Date : 2019-11-21 13:10:17 +0000

    Make ::Query objects able to execute

    This was an oversight on my part. The `::Query` object now supports
    `->execute( $list_of_indexes )` directly. This makes working with the
    library easier as folks don't need to read docs on the `es_request()`
    function to figure out how to construct a search.

    Additionally, `scroll_id`'s are automatically extracted from the result
    set. Calls to `->scroll_results()` will allow scrolling without having to
    understand the mechanics of the scroll. 

----------------------------------------
version 7.4 at 2019-10-20 13:24:50 +0000
----------------------------------------

  Change: be1145db74f2394ae9c4f2747332cc03d3f7ca07
  Author: Brad Lhotsky <brad@divisionbyzero.net>
  Date : 2019-10-20 09:24:50 +0000

    Ready v7.4 Release

    * Docs updated * Update tests to handle the new IP range query 

  Change: feca6053d575b523277743a937a51cb226781d66
  Author: Brad Lhotsky <brad@divisionbyzero.net>
  Date : 2019-10-20 09:03:07 +0000

    Add Support for --or and IPv6

    * Added support to change the default token joiner to OR to es-search.pl *
    Added support for IPv6 to the ::QueryString::IP expander * Converted
    ::QueryString::IP to use a range query 

  Change: 17e80653b2a90e665e59c545eda7776b2fae7c90
  Author: Brad Lhotsky <brad@divisionbyzero.net>
  Date : 2019-10-19 10:46:48 +0000

    Update the examples/es-utils.yml file for new options

    This file had gotten outdated. 

  Change: 31c3caf10224615723e8036eae28ac7789a1824d
  Author: Brad Lhotsky <brad@divisionbyzero.net>
  Date : 2019-10-09 20:23:57 +0000

    Use a better name for fields metadata 

  Change: f6369b88f311751908dec2addad33d999a452c75
  Author: Brad Lhotsky <brad@divisionbyzero.net>
  Date : 2019-10-09 20:19:38 +0000

    Some code cleanup for es-search.pl 

  Change: 29bbf1415b2be39cf79d0281608832ade50565a9
  Author: Brad Lhotsky <brad@divisionbyzero.net>
  Date : 2019-10-09 20:18:57 +0000

    Allow field metadata sharing with ::Query

    This will enable automatic detection of and working with nested fields in
    the near term. Possibly other features in the long term. 

----------------------------------------
version 7.3 at 2019-09-08 18:32:53 +0000
----------------------------------------

  Change: 56b99467e968c2a4dcb6eeb5e49f62ff55213ca2
  Author: Brad Lhotsky <brad@divisionbyzero.net>
  Date : 2019-09-08 11:32:53 +0000

    Release 7.3 ready to go 

  Change: cb5e39b38c73c19f02def6851daecb257b228759
  Author: Brad Lhotsky <brad@divisionbyzero.net>
  Date : 2019-09-08 11:27:57 +0000

    Fix search API for ES < 6.x

    The `track_total_hits` was added in ES 6.0.0. Remove that parameter for
    versions before 6.0.0. 

  Change: 5a681c12f47a607293148b44be469a54dd490597
  Author: Brad Lhotsky <brad@divisionbyzero.net>
  Date : 2019-09-05 15:42:16 +0000

    Add documentation for the new parameters and allow scroll to be undef

    When working with aggregations, we need to disable the scroll, so allow
    scroll to be undef. 

  Change: 37fb74c14732e998163a2b46c8960717e69514b7
  Author: Brad Lhotsky <brad@divisionbyzero.net>
  Date : 2019-09-04 18:25:02 +0000

    Fixes for ::Query to handle parameters better

    Drop all the `Maybe` from `::Query`. Make handling non-array parameters in
    the `bool` section of the query work. Added the following parameters:

    * `search_type` - Set to an `Enum` consistent with viable ES options *
    `track_scores` - Can be 'true' or 'false' * `track_total_hits` - Defaults
    'true' * `rest_total_hits_as_int` - Defaults 'true' *
    `minimum_should_match` - Allow users to control the minimum should

    match parameter.

    `es-search.pl` remove redundant parameters. Set `--tail` batch size to
    `max-batch-size` and check if `size` is less than `max-batch-size` and just
    return `size` docs instead of `max-batch-size` docs. 

  Change: 350c919e7b7128c306bc4b5ef8237a9d2caf7910
  Author: Brad Lhotsky <brad@divisionbyzero.net>
  Date : 2019-09-04 17:24:28 +0000

    Make ::Query->add_bool() more flexible

    Now `add_bool()` supports adding multiple conditions at once. Allow users
    to set `search_type` and `track_scores`. 

----------------------------------------
version 7.2 at 2019-08-28 22:38:01 +0000
----------------------------------------

  Change: 1c04c77be9fd7c0366ce28e2b8abe694babe468f
  Author: Brad Lhotsky <brad@divisionbyzero.net>
  Date : 2019-08-28 15:38:01 +0000

    Documentation update for 7.2 release 

  Change: 7469f0aab1a9f93a2ebf4fbe8848a25689ff5cf5
  Author: Brad Lhotsky <brad@divisionbyzero.net>
  Date : 2019-08-28 15:35:07 +0000

    Enhance es-apply-settings.pl

    * New `es_flatten_hash()` function to perform compatible list flattening

    to that found in Elastic's documentation. * Replace all instances of
    `Hash::Flatten::flatten` with a call to

    `es_flatten_hash()` for consistency * Use the `es_flatten_hash()` function
    with `Test::Deep`'s

    `cmp_details()` and `subhashof()` to check if an index requires a

    settings change. * Configure `es-apply-settings.pl` to ignore indices with
    protected

    aliases. * Allow protected indices to have settings applied with
    `--no-skip` * Skip checking the existing index settings with `--no-diff` 

  Change: bc5ce3686a5d7542fea53d70352f618bd1676a15
  Author: Brad Lhotsky <brad@divisionbyzero.net>
  Date : 2019-08-23 15:04:28 +0000

    Tweaks for working with ElasticSearch 6.x and 7.x

    * Field metadata extraction works on both versions * Filter out invalid
    parameters to `_search` when using an older ES

    version * Set `es-search.pl` to use the new parameters to track the total
    hits 

  Change: 84142a2fa49ad8e819be1cc189b17a246783c762
  Author: Brad Lhotsky <brad@divisionbyzero.net>
  Date : 2019-08-05 11:40:16 +0000

    Make skipped aliases in maintenance more visible.

    Moving the skipped message from `verbose` to `output` to ensure proper
    reporting of these indexes. 

  Change: 75e684c51aa125e6d8590bf95c3a7c0e3c43933f
  Author: Brad Lhotsky <brad@divisionbyzero.net>
  Date : 2019-08-01 17:10:46 +0000

    Adapt es-search.pl --bases to use _all

    If the user sets a default base in their `~/.es-utils.yaml`, then they'd
    only see that base in via `--bases`. This ensures users can see all of the
    indices available. 

=================================================
Plus 78 releases after 2019-08-15 00:00:00 +0000.
=================================================