fluent-plugin-elasticsearch 1.18.0 → 1.18.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/History.md +3 -0
- data/README.md +7 -0
- data/fluent-plugin-elasticsearch.gemspec +1 -1
- data/lib/fluent/plugin/out_elasticsearch.rb +4 -0
- data/test/plugin/test_out_elasticsearch.rb +59 -0
- metadata +3 -4
    
        checksums.yaml
    CHANGED
    
    | @@ -1,7 +1,7 @@ | |
| 1 1 | 
             
            ---
         | 
| 2 2 | 
             
            SHA256:
         | 
| 3 | 
            -
              metadata.gz:  | 
| 4 | 
            -
              data.tar.gz:  | 
| 3 | 
            +
              metadata.gz: f4e4ff948915da51a4c267d0350157b841c6b3f09862571d9777072d60d5c337
         | 
| 4 | 
            +
              data.tar.gz: dde99b5bd72bfadad60013689d8109b5776beb6ae942d65fad1ad8777df1ecb0
         | 
| 5 5 | 
             
            SHA512:
         | 
| 6 | 
            -
              metadata.gz:  | 
| 7 | 
            -
              data.tar.gz:  | 
| 6 | 
            +
              metadata.gz: 13d604ed0ac1822333b5464efe34fd7f943b9c1151cbd2bf60c40356b028bab9164c6c66d26dd515c182d19a3f95f4b18e504d118212bf86be647b3681bd5659
         | 
| 7 | 
            +
              data.tar.gz: d90733254d79a977a12adc64a47f01315acfe391c3841f82c055be6aef20b1c209dd6e0d86620a581efd1b8b5f90b433fb6fb640126cda122b427802fc1beec3
         | 
    
        data/History.md
    CHANGED
    
    
    
        data/README.md
    CHANGED
    
    | @@ -60,6 +60,7 @@ Note: For Amazon Elasticsearch Service please consider using [fluent-plugin-aws- | |
| 60 60 | 
             
              + [reload_after](#reload_after)
         | 
| 61 61 | 
             
              + [Not seeing a config you need?](#not-seeing-a-config-you-need)
         | 
| 62 62 | 
             
              + [Dynamic configuration](#dynamic-configuration)
         | 
| 63 | 
            +
              + [suppress_doc_wrap](#suppress_doc_wrap)
         | 
| 63 64 | 
             
            * [Contact](#contact)
         | 
| 64 65 | 
             
            * [Contributing](#contributing)
         | 
| 65 66 | 
             
            * [Running tests](#running-tests)
         | 
| @@ -638,6 +639,12 @@ If you want configurations to depend on information in messages, you can use `el | |
| 638 639 |  | 
| 639 640 | 
             
            **Please note, this uses Ruby's `eval` for every message, so there are performance and security implications.**
         | 
| 640 641 |  | 
| 642 | 
            +
            ### suppress_doc_wrap
         | 
| 643 | 
            +
             | 
| 644 | 
            +
            By default, record body is wrapped by 'doc'. This behavior can not handle update script requests. You can set this to suppress doc wrapping and allow record body to be untouched.
         | 
| 645 | 
            +
            
         | 
| 646 | 
            +
            Default value is `false`.
         | 
| 647 | 
            +
             | 
| 641 648 | 
             
            ## Contact
         | 
| 642 649 |  | 
| 643 650 | 
             
            If you have a question, [open an Issue](https://github.com/uken/fluent-plugin-elasticsearch/issues).
         | 
| @@ -3,7 +3,7 @@ $:.push File.expand_path('../lib', __FILE__) | |
| 3 3 |  | 
| 4 4 | 
             
            Gem::Specification.new do |s|
         | 
| 5 5 | 
             
              s.name          = 'fluent-plugin-elasticsearch'
         | 
| 6 | 
            -
              s.version       = '1.18. | 
| 6 | 
            +
              s.version       = '1.18.1'
         | 
| 7 7 | 
             
              s.authors       = ['diogo', 'pitr']
         | 
| 8 8 | 
             
              s.email         = ['pitr.vern@gmail.com', 'me@diogoterror.com']
         | 
| 9 9 | 
             
              s.description   = %q{Elasticsearch output plugin for Fluent event collector}
         | 
| @@ -90,6 +90,7 @@ class Fluent::ElasticsearchOutput < Fluent::ObjectBufferedOutput | |
| 90 90 | 
             
              config_param :emit_error_for_missing_id, :bool, :default => false
         | 
| 91 91 | 
             
              config_param :sniffer_class_name, :string, :default => nil
         | 
| 92 92 | 
             
              config_param :reload_after, :integer, :default => DEFAULT_RELOAD_AFTER
         | 
| 93 | 
            +
              config_param :suppress_doc_wrap, :bool, :default => false
         | 
| 93 94 |  | 
| 94 95 | 
             
              include Fluent::ElasticsearchIndexTemplate
         | 
| 95 96 | 
             
              include Fluent::ElasticsearchConstants
         | 
| @@ -322,6 +323,9 @@ class Fluent::ElasticsearchOutput < Fluent::ObjectBufferedOutput | |
| 322 323 |  | 
| 323 324 | 
             
              def update_body(record, op)
         | 
| 324 325 | 
             
                update = remove_keys(record)
         | 
| 326 | 
            +
                if @suppress_doc_wrap
         | 
| 327 | 
            +
                  return update
         | 
| 328 | 
            +
                end
         | 
| 325 329 | 
             
                body = {"doc".freeze => update}
         | 
| 326 330 | 
             
                if op == UPSERT_OP
         | 
| 327 331 | 
             
                  if update == record
         | 
| @@ -1732,4 +1732,63 @@ class ElasticsearchOutput < Test::Unit::TestCase | |
| 1732 1732 | 
             
                assert_logs_include(log.out.logs, /In Fluent::ElasticsearchSimpleSniffer hosts/, 2)
         | 
| 1733 1733 | 
             
              end
         | 
| 1734 1734 |  | 
| 1735 | 
            +
              def test_suppress_doc_wrap
         | 
| 1736 | 
            +
                driver.configure('write_operation update
         | 
| 1737 | 
            +
                                  id_key id
         | 
| 1738 | 
            +
                                  remove_keys id
         | 
| 1739 | 
            +
                                  suppress_doc_wrap true')
         | 
| 1740 | 
            +
                stub_elastic_ping
         | 
| 1741 | 
            +
                stub_elastic
         | 
| 1742 | 
            +
                doc_body = {'field' => 'value'}
         | 
| 1743 | 
            +
                doc_record = {'id' => 1, 'doc' => doc_body}
         | 
| 1744 | 
            +
                script_body = {'source' => 'ctx._source.counter += params.param1',
         | 
| 1745 | 
            +
                               'lang' => 'painless',
         | 
| 1746 | 
            +
                               'params' => {'param1' => 1}}
         | 
| 1747 | 
            +
                upsert_body = {'counter' => 1}
         | 
| 1748 | 
            +
                script_record = {'id' => 2, 'script' => script_body, 'upsert' => upsert_body}
         | 
| 1749 | 
            +
                driver.emit(doc_record, 1)
         | 
| 1750 | 
            +
                driver.emit(script_record, 2)
         | 
| 1751 | 
            +
                driver.run
         | 
| 1752 | 
            +
                assert(
         | 
| 1753 | 
            +
                  index_cmds[1] == {'doc' => doc_body}
         | 
| 1754 | 
            +
                )
         | 
| 1755 | 
            +
                assert(
         | 
| 1756 | 
            +
                  index_cmds[3] == {
         | 
| 1757 | 
            +
                    'script' => script_body,
         | 
| 1758 | 
            +
                    'upsert' => upsert_body
         | 
| 1759 | 
            +
                  }
         | 
| 1760 | 
            +
                )
         | 
| 1761 | 
            +
              end
         | 
| 1762 | 
            +
             | 
| 1763 | 
            +
              def test_suppress_doc_wrap_should_handle_record_as_is_at_upsert
         | 
| 1764 | 
            +
                driver.configure('write_operation upsert
         | 
| 1765 | 
            +
                                  id_key id
         | 
| 1766 | 
            +
                                  remove_keys id
         | 
| 1767 | 
            +
                                  suppress_doc_wrap true')
         | 
| 1768 | 
            +
                stub_elastic_ping
         | 
| 1769 | 
            +
                stub_elastic
         | 
| 1770 | 
            +
                doc_body = {'field' => 'value'}
         | 
| 1771 | 
            +
                doc_record = {'id' => 1, 'doc' => doc_body, 'doc_as_upsert' => true}
         | 
| 1772 | 
            +
                script_body = {'source' => 'ctx._source.counter += params.param1',
         | 
| 1773 | 
            +
                               'lang' => 'painless',
         | 
| 1774 | 
            +
                               'params' => {'param1' => 1}}
         | 
| 1775 | 
            +
                upsert_body = {'counter' => 1}
         | 
| 1776 | 
            +
                script_record = {'id' => 2, 'script' => script_body, 'upsert' => upsert_body}
         | 
| 1777 | 
            +
                driver.emit(doc_record, 1)
         | 
| 1778 | 
            +
                driver.emit(script_record, 2)
         | 
| 1779 | 
            +
                driver.run
         | 
| 1780 | 
            +
                assert(
         | 
| 1781 | 
            +
                  index_cmds[1] == {
         | 
| 1782 | 
            +
                    'doc' => doc_body,
         | 
| 1783 | 
            +
                    'doc_as_upsert' => true
         | 
| 1784 | 
            +
                  }
         | 
| 1785 | 
            +
                )
         | 
| 1786 | 
            +
                assert(
         | 
| 1787 | 
            +
                  index_cmds[3] == {
         | 
| 1788 | 
            +
                    'script' => script_body,
         | 
| 1789 | 
            +
                    'upsert' => upsert_body
         | 
| 1790 | 
            +
                  }
         | 
| 1791 | 
            +
                )
         | 
| 1792 | 
            +
              end
         | 
| 1793 | 
            +
             | 
| 1735 1794 | 
             
            end
         | 
    
        metadata
    CHANGED
    
    | @@ -1,7 +1,7 @@ | |
| 1 1 | 
             
            --- !ruby/object:Gem::Specification
         | 
| 2 2 | 
             
            name: fluent-plugin-elasticsearch
         | 
| 3 3 | 
             
            version: !ruby/object:Gem::Version
         | 
| 4 | 
            -
              version: 1.18. | 
| 4 | 
            +
              version: 1.18.1
         | 
| 5 5 | 
             
            platform: ruby
         | 
| 6 6 | 
             
            authors:
         | 
| 7 7 | 
             
            - diogo
         | 
| @@ -9,7 +9,7 @@ authors: | |
| 9 9 | 
             
            autorequire: 
         | 
| 10 10 | 
             
            bindir: bin
         | 
| 11 11 | 
             
            cert_chain: []
         | 
| 12 | 
            -
            date:  | 
| 12 | 
            +
            date: 2019-03-08 00:00:00.000000000 Z
         | 
| 13 13 | 
             
            dependencies:
         | 
| 14 14 | 
             
            - !ruby/object:Gem::Dependency
         | 
| 15 15 | 
             
              name: fluentd
         | 
| @@ -176,8 +176,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement | |
| 176 176 | 
             
                - !ruby/object:Gem::Version
         | 
| 177 177 | 
             
                  version: '0'
         | 
| 178 178 | 
             
            requirements: []
         | 
| 179 | 
            -
             | 
| 180 | 
            -
            rubygems_version: 2.7.6
         | 
| 179 | 
            +
            rubygems_version: 3.0.1
         | 
| 181 180 | 
             
            signing_key: 
         | 
| 182 181 | 
             
            specification_version: 4
         | 
| 183 182 | 
             
            summary: Elasticsearch output plugin for Fluent event collector
         |