Skip to content

Latest commit

 

History

History
2109 lines (1285 loc) · 48.5 KB

CHANGELOG.md

File metadata and controls

2109 lines (1285 loc) · 48.5 KB

Changelog

All notable changes to this project will be documented in this file.

Unreleased

3.23.0 - 2020-07-26

Added

  • Path segments in Bloblang mapping targets can now be quote-escaped.
  • New (BETA) sequence input, for sequentially chaining inputs.
  • New (BETA) csv input for consuming CSV files.
  • New (BETA) Azure table_storage output.
  • New parse_csv Bloblang method.
  • New throw Bloblang function.
  • The slice Bloblang method now supports negative low and high arguments.

Fixed

  • Manual mqtt connection handling for both the input and output. This should fix some cases where connections were dropped and never recovered.
  • Fixed Bloblang error where calls to a .get method would return null after the first query.
  • The for_each processor no longer interlaces child processors during split processing.

3.22.0 - 2020-07-19

Added

  • Added TLS fields to elasticsearch output.
  • New Bloblang methods encrypt_aes and decrypt_aes added.
  • New field static_headers added to the kafka output.
  • New field enabled added to the http config section.
  • Experimental CLI flag -resources added for specifying files containing extra resources.

Fixed

  • The amqp_0_9 now resolves type and key fields per message of a batch.

3.21.0 - 2020-07-12

Added

  • New (BETA) bloblang input for generating documents.
  • New (BETA) Azure blob_storage output.
  • Field sync_response.status added to http_server input.
  • New Bloblang errored function.

Fixed

  • The json_schema processor no longer lower cases fields within error messages.
  • The dynamodb cache no longer creates warning logs for get misses.

3.20.0 - 2020-07-05

Added

  • SASL config fields added to amqp_1 input and output.
  • The lint subcommand now supports triple dot wildcard paths: ./foo/....
  • The test subcommand now supports tests defined within the target config file being tested.

Fixed

  • Bloblang boolean operands now short circuit.

3.19.0 - 2020-06-28

Added

  • Fields strict_mode and max_in_flight added to the switch output.
  • New beta amqp_1 input and output added.

3.18.0 - 2020-06-14

Added

  • Field drop_empty_bodies added to the http_client input.

Fixed

  • Fixed deleting and skipping maps with the blobl subcommand.

3.17.0 - 2020-06-07

Added

  • New field type added to the amqp_0_9 output.
  • New bloblang methods explode and without.

Fixed

  • Message functions such as json and content now work correctly when executing bloblang with the blobl sub command.

3.16.0 - 2020-05-31

Added

  • New bloblang methods type, join, unique, escape_html, unescape_html, re_find_all and re_find_all_submatch.
  • Bloblang sort method now allows custom sorting functions.
  • Bloblang now supports if expressions.
  • Bloblang now allows joining strings with the + operator.
  • Bloblang now supports multiline strings with triple quotes.

Changed

  • The xml processor is now less strict with XML parsing, allowing unrecognised escape sequences to be passed through unchanged.

Fixed

  • The bloblang method map_each now respects Nothing mapping by copying the underlying value unchanged.
  • It's now possible to reference resource inputs and outputs in streams mode.
  • Fixed a problem with compiling old interpolation functions with arguments containing colons (i.e. ${!timestamp_utc:2006-01-02T15:04:05.000Z})

3.15.0 - 2020-05-24

Added

  • Flag log added to test sub command to allow logging during tests.
  • New subcommand blobl added for convenient mapping over the command line.
  • Lots of new bloblang methods.

Fixed

  • The redis_streams input no longer incorrectly copies message data into a metadata field.

Changed

  • Bloblang is no longer considered beta. Therefore, no breaking changes will be introduced outside of a major version release.

3.14.0 - 2020-05-17

Added

  • New ascii85 and z85 options have been added to the encode and decode processors.

Bloblang BETA Changes

  • The meta function no longer reflects changes made within the map itself.
  • Extracting data from other messages of a batch using from no longer reflects changes made within a map.
  • Meta assignments are no longer allowed within named maps.
  • Assigning deleted() to root now filters out a message entirely.
  • Lots of new methods and goodies.

3.13.0 - 2020-05-10

Added

  • New HMAC algorithms added to hash processor.
  • New (BETA) bloblang processor.
  • New (BETA) bloblang condition.

Fixed

  • Prevented a crash that might occur with high-concurrent access of http_server metrics with labels.
  • The http_client output now respects the copy_response_headers field.

3.12.0 - 2020-04-19

Added

  • Vastly improved function interpolations, including better batch handling and arithmetic operators.
  • The gcp_pubsub output now supports function interpolation on the field topic.
  • New contains_any and contains_any_cs operators added to the text condition.
  • Support for input and output resource types.
  • The broker and switch output types now allow async messages and batching within child outputs.
  • Field schema_path added to the avro processor.
  • The redis cache, redis_list inputs and outputs now support selecting a database with the URL path.
  • New field max_in_flight added to the broker output.

Changed

  • Benthos now runs in strict mode, but this can be disabled with --chilled.
  • The Benthos CLI has been revamped, the old flags are still supported but are deprecated.
  • The http_server input now accepts requests without a content-type header.

Fixed

  • Outputs that resolve function interpolations now correctly resolve the batch_size function.
  • The kinesis_balanced input now correctly establishes connections.
  • Fixed an auth transport issue with the gcp_pubsub input and output.

3.11.0 - 2020-03-08

Added

  • Format syslog_rfc3164 added to the parse_log processor.
  • New multilevel cache.
  • New json_append, json_type and json_length functions added to the awk processor.
  • New flatten operator added to the json processor.

Changed

  • Processors that fail now set the opentracing tag error to true.

Fixed

  • Kafka connectors now correctly set username and password for all SASL strategies.

3.10.0 - 2020-02-05

Added

  • Field delete_files added to files input.
  • TLS fields added to nsq input and output.
  • Field processors added to batching fields to easily accommodate aggregations and archiving of batched messages.
  • New parse_log processor.
  • New json condition.
  • Operators flatten_array, fold_number_array and fold_string_array added to json processor.

Changed

  • The redis_streams input no longer flushes >1 fetched messages as a batch.

Fixed

  • Re-enabled Kafka connections using SASL without TLS.

3.9.0 - 2020-01-27

Added

  • New socket, socket_server inputs.
  • New socket output.
  • Kafka connectors now support SASL using OAUTHBEARER, SCRAM-SHA-256, SCRAM-SHA-512 mechanisms.
  • Experimental support for AWS CloudWatch metrics.

Changed

  • The tcp, tcp_server and udp_server inputs have been deprecated and moved into the socket and socket_server inputs respectively.
  • The udp and tcp outputs have been deprecated and moved into the socket output.

Fixed

  • The subprocess processor now correctly flags errors that occur.

3.8.0 - 2020-01-17

Added

  • New field max_in_flight added to the following outputs:
    • amqp_0_9
    • cache
    • dynamodb
    • elasticsearch
    • gcp_pubsub
    • hdfs
    • http_client
    • kafka
    • kinesis
    • kinesis_firehose
    • mqtt
    • nanomsg
    • nats
    • nats_stream
    • nsq
    • redis_hash
    • redis_list
    • redis_pubsub
    • redis_streams
    • s3
    • sns
    • sqs
  • Batching fields added to the following outputs:
    • dynamodb
    • elasticsearch
    • http_client
    • kafka
    • kinesis
    • kinesis_firehose
    • sqs
  • More TRACE level logs added throughout the pipeline.
  • Operator delete added to cache processor.
  • Operator explode added to json processor.
  • Field storage_class added to s3 output.
  • Format json_map added to unarchive processor.

Fixed

  • Function interpolated strings within the json processor value field are now correctly unicode escaped.
  • Retry intervals for kafka output have been tuned to prevent circuit breaker throttling.

3.7.0 - 2019-12-21

Added

  • New try output, which is a drop-in replacement for a broker with the try pattern.
  • Field successful_on added to the http processor.
  • The statsd metrics type now supports Datadog or InfluxDB tagging.
  • Field sync_response.headers added to http_server input.
  • New sync_response processor.
  • Field partitioner added to the kafka output.

Changed

  • The http processor now gracefully handles empty responses.

Fixed

  • The kafka input should now correctly recover from coordinator failures during an offset commit.
  • Attributes permitted by the sqs output should now have parity with real limitations.

3.6.1 - 2019-12-05

Fixed

  • Batching using an input broker now works with only one child input configured.
  • The zmq4 input now correctly supports broker based batching.

3.6.0 - 2019-12-03

Added

  • New workflow processor.
  • New resource processor.
  • Processors can now be registered within the resources section of a config.

Changed

  • The mqtt output field topic field now supports interpolation functions.

Fixed

  • The kafka output no longer attempts to send headers on old versions of the protocol.

3.5.0 - 2019-11-26

Added

  • New regexp_expand operator added to the text processor.
  • New json_schema processor.

3.4.0 - 2019-11-12

Added

  • New amqp_0_9 output which replaces the now deprecated amqp output.
  • The broker output now supports batching.

Fixed

  • The memory buffer now allows parallel processing of batched payloads.
  • Version and date information should now be correctly displayed in archive distributions.

3.3.1 - 2019-10-21

Fixed

  • The s3 input now correctly unescapes bucket keys when streaming from SQS.

3.3.0 - 2019-10-20

Added

  • Field sqs_endpoint added to the s3 input.
  • Field kms_key_id added to the s3 output.
  • Operator delete added to metadata processor.
  • New experimental metrics aggregator stdout.
  • Field ack_wait added to nats_stream input.
  • New batching field added to broker input for batching merged streams.
  • Field healthcheck added to elasticsearch output.
  • New json_schema condition.

Changed

  • Experimental kafka_cg input has been removed.
  • The kafka_balanced inputs underlying implementation has been replaced with the kafka_cg one.
  • All inputs have been updated to automatically utilise >1 processing threads, with the exception of kafka and kinesis.

3.2.0 - 2019-09-27

Added

  • New is operator added to text condition.
  • New config unit test condition content_matches.
  • Field init_values added to the memory cache.
  • New split operator added to json processor.
  • Fields user and password added to mqtt input and output.
  • New experimental amqp_0_9 input.

Changed

  • Linting is now disabled for the environment var config shipped with docker images, this should prevent the log spam on start up.
  • Go API: Experimental reader.Async component methods renamed.

3.1.1 - 2019-09-23

Fixed

  • Prevented kafka_cg input lock up after batch policy period trigger with no backlog.

3.1.0 - 2019-09-23

Added

  • New redis processor.
  • New kinesis_firehose output.
  • New experimental kafka_cg input.
  • Go API: The metrics.Local aggregator now supports labels.

Fixed

  • The json processor no longer removes content moved from a path to the same path.

3.0.0 - 2019-09-17

This is a major version release, for more information and guidance on how to migrate please refer to https://benthos.dev/docs/guides/migration/v3.

Added

  • The json processor now allows you to move from either a root source or to a root destination.
  • Added interpolation to the metadata processor key field.
  • Granular retry fields added to kafka output.

Changed

  • Go modules are now fully supported, imports must now include the major version (e.g. github.com/Jeffail/benthos/v3).
  • Removed deprecated mmap_file buffer.
  • Removed deprecated (and undocumented) metrics paths.
  • Moved field prefix from root of metrics into relevant child components.
  • Names of process_dag stages must now match the regexp [a-zA-Z0-9_-]+.
  • Go API: buffer constructors now take a types.Manager argument in parity with other components.
  • JSON dot paths within the following components have been updated to allow array-based operations:
    • awk processor
    • json processor
    • process_field processor
    • process_map processor
    • check_field condition
    • json_field function interpolation
    • s3 input
    • dynamodb output

Fixed

  • The sqs output no longer attempts to send invalid attributes with payloads from metadata.
  • During graceful shutdown Benthos now scales the attempt to propagate acks for sent messages with the overall system shutdown period.

2.15.1 - 2019-09-10

Fixed

  • The s3 and sqs inputs should now correctly log handles and codes from failed SQS message deletes and visibility timeout changes.

2.15.0 - 2019-09-03

Added

  • New message_group_id and message_deduplication_id fields added to sqs output for supporting FIFO queues.

2.14.0 - 2019-08-29

Added

  • Metadata field gcp_pubsub_publish_time_unix added to gcp_pubsub input.
  • New tcp and tcp_server inputs.
  • New udp_server input.
  • New tcp and udp outputs.
  • Metric paths output.batch.bytes and output.batch.latency added.
  • New rate_limit processor.

Fixed

  • The json processor now correctly stores parsed value JSON when using set on the root path.

2.13.0 - 2019-08-27

Added

  • The sqs input now adds some message attributes as metadata.
  • Added field delete_message to sqs input.
  • The sqs output now sends metadata as message attributes.
  • New batch_policy field added to memory buffer.
  • New xml processor.

Fixed

  • The prometheus metrics exporter adds quantiles back to timing metrics.

2.12.2 - 2019-08-19

Fixed

  • Capped slices from lines reader are now enforced.
  • The json processor now correctly honours a null value.

2.12.1 - 2019-08-16

Changed

  • Disabled kinesis_balanced input for WASM builds.

2.12.0 - 2019-08-16

Added

  • Field codec added to process_field processor.
  • Removed experimental status from sync responses components, which are now considered stable.
  • Field pattern_definitions added to grok processor.

Changed

  • Simplified serverless lambda main function body for improving plugin documentation.

Fixed

  • Fixed a bug where the prepend and append operators of the text processor could result in invalid messages when consuming line-based inputs.

2.11.2 - 2019-08-06

Added

  • Field clean_session added to mqtt input.
  • The http_server input now adds request query parameters to messages as metadata.

2.11.1 - 2019-08-05

Fixed

  • Prevent concurrent access race condition on nested parallel process_map processors.

2.11.0 - 2019-08-03

Added

  • New beta input kinesis_balanced.
  • Field profile added to AWS components credentials config.

2.10.0 - 2019-07-29

Added

  • Improved error messages attached to payloads that fail process_dag. post mappings.
  • New redis_hash output.
  • New sns output.

2.9.3 - 2019-07-18

Added

  • Allow extracting metric rename submatches into labels.
  • Field use_patterns added to redis_pubsub input for subscribing to channels using glob-style patterns.

2.9.2 - 2019-07-17

Changed

  • Go API: It's now possible to specify a custom config unit test file path suffix.

2.9.1 - 2019-07-15

Added

  • New rate limit and websocket message fields added to http_server input.
  • The http processor now optionally copies headers from response into resulting message metadata.
  • The http processor now sets a http_status_code metadata value into resulting messages (provided one is received.)

Changed

  • Go API: Removed experimental Block functions from the cache and rate limit packages.

2.9.0 - 2019-07-12

Added

  • New (experimental) command flags --test and --gen-test added.
  • All http client components output now set a metric request_timeout.

2.8.6 - 2019-07-10

Added

  • All errors caught by processors should now be accessible via the ${!error} interpolation function, rather than just flagged as true.

Fixed

  • The process_field processor now propagates metadata to the original payload with the result_type set to discard. This allows proper error propagation.

2.8.5 - 2019-07-03

Added

  • Field max_buffer added to subprocess processor.

Fixed

  • The subprocess processor now correctly logs and recovers subprocess pipeline related errors (such as exceeding buffer limits.)

2.8.4 - 2019-07-02

Added

  • New json_delete function added to the awk processor.

Fixed

  • SQS output now correctly waits between retry attempts and escapes error loops during shutdown.

2.8.3 - 2019-06-28

Added

  • Go API: Add RunWithOpts opt OptOverrideConfigDefaults.

Fixed

  • The filter and filter_parts config sections now correctly marshall when printing with --all.

2.8.2 - 2019-06-28

Added

  • Go API: A new service method RunWithOpts has been added in order to accomodate service customisations with opt funcs.

2.8.1 - 2019-06-28

  • New interpolation function error.

2.8.0 - 2019-06-24

Added

  • New number condition.
  • New number processor.
  • New avro processor.
  • Operator enum added to text condition.
  • Field result_type added to process_field processor for marshalling results into non-string types.
  • Go API: Plugin APIs now allow nil config constructors.
  • Registering plugins automatically adds plugin documentation flags to the main Benthos service.

2.7.0 - 2019-06-20

Added

  • Output http_client is now able to propagate responses from each request back to inputs supporting sync responses.
  • Added support for Gzip compression to http_server output sync responses.
  • New check_interpolation condition.

2.6.0 - 2019-06-18

Added

  • New sync_response output type, with experimental support added to the http_server input.
  • SASL authentication fields added to all Kafka components.

2.5.0 - 2019-06-14

Added

  • The s3 input now sets s3_content_encoding metadata (when not using the download manager.)
  • New trace logging for the rename, blacklist and whitelist metric components to assist with debugging.

2.4.0 - 2019-06-06

Added

  • Ability to combine sync and async responses in serverless distributions.

Changed

  • The insert_part, merge_json and unarchive processors now propagate message contexts.

2.3.2 - 2019-06-05

Fixed

  • JSON processors no longer escape &, <, and > characters by default.

2.3.1 - 2019-06-04

Fixed

  • The http processor now preserves message metadata and contexts.
  • Any http components that create requests with messages containing empty bodies now correctly function in WASM.

2.3.0 - 2019-06-04

Added

  • New fetch_buffer_cap field for kafka and kafka_balanced inputs.
  • Input gcp_pubsub now has the field max_batch_count.

Changed

  • Reduced allocations under most JSON related processors.
  • Streams mode API now logs linting errors.

2.2.4 - 2019-06-02

Added

  • New interpolation function batch_size.

2.2.3 - 2019-05-31

Fixed

  • Output elasticsearch no longer reports index not found errors on connect.

2.2.2 - 2019-05-30

Fixed

  • Input reader no longer overrides message contexts for opentracing spans.

2.2.1 - 2019-05-29

Fixed

  • Improved construction error messages for broker and switch input and outputs.

Changed

  • Plugins that don't use a configuration structure can now return nil in their sanitise functions in order to have the plugin section omitted.

2.2.0 - 2019-05-22

Added

  • The kafka and kafka_balanced inputs now set a kafka_lag metadata field to incoming messages.
  • The awk processor now has a variety of typed json_set functions json_set_int, json_set_float and json_set_bool.
  • Go API: Add experimental function for blocking cache and ratelimit constructors.

Fixed

  • The json processor now defaults to an executable operator (clean).

2.1.3 - 2019-05-20

Added

  • Add experimental function for blocking processor constructors.

2.1.2 - 2019-05-20

Added

  • Core service logic has been moved into new package service, making it easier to maintain plugin builds that match upstream Benthos.

2.1.1 - 2019-05-17

Added

  • Experimental support for WASM builds.

2.1.0 - 2019-05-16

Added

  • Config linting now reports line numbers.
  • Config interpolations now support escaping.

2.0.0 - 2019-05-14

Added

  • API for creating cache implementations.
  • API for creating rate_limit implementations.

Changed

This is a major version released due to a series of minor breaking changes, you can read the full migration guide here.

Configuration

  • Benthos now attempts to infer the type of config sections whenever the field is omitted, for more information please read this overview: Concise Configuration.
  • Field unsubscribe_on_close of the nats_stream input is now false by default.

Service

  • The following commandline flags have been removed: swap-envs, plugins-dir, list-input-plugins, list-output-plugins, list-processor-plugins, list-condition-plugins.

Go API

  • Package github.com/Jeffail/benthos/lib/processor/condition changed to github.com/Jeffail/benthos/lib/condition.
  • Interface types.Cache now has types.Closable embedded.
  • Interface types.RateLimit now has types.Closable embedded.
  • Add method GetPlugin to interface types.Manager.
  • Add method WithFields to interface log.Modular.

1.20.4 - 2019-05-13

Fixed

  • Ensure process_batch processor gets normalised correctly.

1.20.3 - 2019-05-11

Added

  • New for_each processor with the same behaviour as process_batch, process_batch is now considered an alias for for_each.

1.20.2 - 2019-05-10

Changed

  • The sql processor now executes across the batch, documentation updated to clarify.

1.20.1 - 2019-05-10

Fixed

  • Corrected result_codec field in sql processor config.

1.20.0 - 2019-05-10

Added

  • New sql processor.

Fixed

  • Using json_map_columns with the dynamodb output should now correctly store null and array values within the target JSON structure.

1.19.2 - 2019-05-09

Added

  • New encode and decode scheme hex.

Fixed

  • Fixed potential panic when attempting an invalid HTTP client configuration.

1.19.1 - 2019-05-08

Fixed

  • Benthos in streams mode no longer tries to load directory /benthos/streams by default.

1.19.0 - 2019-05-07

Added

  • Field json_map_columns added to dynamodb output.

1.18.0 - 2019-05-06

Added

  • JSON references are now supported in configuration files.

1.17.0 - 2019-05-04

Added

  • The hash processor now supports sha1.
  • Field force_path_style_urls added to s3 components.
  • Field content_type of the s3 output is now interpolated.
  • Field content_encoding added to s3 output.

Fixed

  • The benthos-lambda distribution now correctly returns all message parts in synchronous execution.

Changed

  • Docker builds now use a locally cached vendor for dependencies.
  • All s3 components no longer default to enforcing path style URLs.

1.16.0 - 2019-04-30

Added

  • New output drop_on_error.
  • Field retry_until_success added to switch output.

Fixed

  • Improved error and output logging for subprocess processor when the process exits unexpectedly.

1.15.0 - 2019-04-26

Changed

  • The main docker image is now based on busybox.
  • Lint rule added for batch processors outside of the input section.

1.14.3 - 2019-04-25

Fixed

  • Removed potential benthos-lambda panic on shut down.

1.14.2 - 2019-04-25

Fixed

  • The redis cache no longer incorrectly returns a "key not found" error instead of connection errors.

1.14.1 - 2019-04-24

Changed

  • Changed docker tag format from vX.Y.Z to X.Y.Z.

1.14.0 - 2019-04-24

Added

  • Output broker pattern fan_out_sequential.
  • Output type drop for dropping all messages.
  • New interpolation function timestamp_utc.

1.13.0 - 2019-04-22

Added

  • New benthos-lambda distribution for running Benthos as a lambda function.

1.12.0 - 2019-04-21

Added

  • New s3 cache implementation.
  • New file cache implementation.
  • Operators quote and unquote added to the text processor.
  • Configs sent via the streams mode HTTP API are now interpolated with environment variable substitutes.

Changed

  • All AWS s3 components now enforce path style syntax for bucket URLs. This improves compatibility with third party endpoints.

1.11.0 - 2019-04-12

Added

  • New parallel processor.

Fixed

  • The dynamodb cache get call now correctly reports key not found versus general request error.

1.10.10 - 2019-04-10

Added

  • New sqs_bucket_path field added to s3 input.

Fixed

  • The sqs input now rejects messages that fail by resetting the visibility timeout.
  • The sqs input no longer fails to delete consumed messages when the batch contains duplicate message IDs.

1.10.9 - 2019-04-05

Fixed

  • The metric processor no longer mixes label keys when processing across parallel pipelines.

1.10.8 - 2019-04-03

Added

  • Comma separated kafka and kafka_balanced address and topic values are now trimmed for whitespace.

1.10.6 - 2019-04-02

Added

  • Field max_processing_period added to kafka and kafka_balanced inputs.

Fixed

  • Compaction intervals are now respected by the memory cache type.

1.10.5 - 2019-03-29

Fixed

  • Improved kafka_balanced consumer group connection behaviour.

1.10.4 - 2019-03-29

Added

  • More kafka_balanced input config fields for consumer group timeouts.

1.10.3 - 2019-03-28

Added

  • New config interpolation function uuid_v4.

1.10.2 - 2019-03-21

Fixed

  • The while processor now correctly checks conditions against the first batch of the result of last processor loop.

1.10.1 - 2019-03-19

Added

  • Field max_loops added to while processor.

1.10.0 - 2019-03-18

Added

  • New while processor.

1.9.0 - 2019-03-17

Added

  • New cache processor.
  • New all condition.
  • New any condition.

1.8.0 - 2019-03-14

Added

  • Function interpolation for field subject added to nats output.

Changed

  • Switched underlying kafka_balanced implementation to sarama consumer.

1.7.10 - 2019-03-11

Fixed

  • Always allow acknowledgement flush during graceful termination.

1.7.9 - 2019-03-08

Fixed

  • Removed unnecessary subscription check from gcp_pubsub input.

1.7.7 - 2019-03-08

Added

  • New field fields added to log processor for structured log output.

1.7.3 - 2019-03-05

Added

  • Function interpolation for field channel added to redis_pubsub output.

1.7.2 - 2019-03-01

Added

  • Field byte_size added to split processor.

1.7.1 - 2019-02-27

Fixed

  • Field dependencies of children of the process_dag processor now correctly parsed from config files.

1.7.0 - 2019-02-26

Added

  • Field push_job_name added to prometheus metrics type.
  • New rename metrics target.

Fixed

  • Removed potential race condition in process_dag with raw bytes conditions.

1.6.1 - 2019-02-21

Added

  • Field max_batch_count added to s3 input.
  • Field max_number_of_messages added to sqs input.

1.6.0 - 2019-02-20

Added

  • New blacklist metrics target.
  • New whitelist metrics target.
  • Initial support for opentracing, including a new tracer root component.
  • Improved generated metrics documentation and config examples.
  • The nats_stream input now has a field unsubscribe_on_close that when disabled allows durable subscription offsets to persist even when all connections are closed.
  • Metadata field nats_stream_sequence added to nats_stream input.

1.5.1 - 2019-02-11

Fixed

  • The subprocess processor no longer sends unexpected empty lines when messages end with a line break.

1.5.0 - 2019-02-07

Added

  • New switch processor.

Fixed

  • Printing configs now sanitises resource sections.

1.4.1 - 2019-02-04

Fixed

  • The headers field in http configs now detects and applies host keys.

1.4.0 - 2019-02-04

Added

  • New json_documents format added to the unarchive processor.
  • Field push_interval added to the prometheus metrics type.

1.3.2 - 2019-01-31

Fixed

  • Brokers now correctly parse configs containing plugin types as children.

1.3.1 - 2019-01-30

Fixed

  • Output broker types now correctly allocates nested processors for fan_out and try patterns.
  • JSON formatted loggers now correctly escape error messages with line breaks.

1.3.0 - 2019-01-29

Added

  • Improved error logging for s3 input download failures.
  • More metadata fields copied to messages from the s3 input.
  • Field push_url added to the prometheus metrics target.

1.2.1 - 2019-01-28

Added

  • Resources (including plugins) that implement Closable are now shutdown cleanly.

1.2.0 - 2019-01-28

Added

  • New json_array format added to the archive and unarchive processors.
  • Preliminary support added to the resource manager API to allow arbitrary shared resource plugins.

1.1.4 - 2019-01-23

Fixed

  • The s3 input now caps and iterates batched SQS deletes.

1.1.3 - 2019-01-22

Fixed

  • The archive processor now interpolates the path per message of the batch.

1.1.2 - 2019-01-21

Fixed

  • Fixed environment variable interpolation when combined with embedded function interpolations.
  • Fixed break down metric indexes for input and output brokers.

1.1.0 - 2019-01-17

Added

  • Input s3 can now toggle the use of a download manager, switching off now downloads metadata from the target file.
  • Output s3 now writes metadata to the uploaded file.
  • Operator unescape_url_query added to text processor.

Fixed

  • The nats_steam input and output now actively attempt to recover stale connections.
  • The awk processor prints errors and flags failure when the program exits with a non-zero status.

1.0.2 - 2019-01-07

Fixed

  • The subprocess processor now attempts to read all flushed stderr output from a process when it fails.

1.0.1 - 2019-01-05

Added

  • Function print_log added to awk processor.

Fixed

  • The awk processor function json_get no longer returns string values with quotes.

1.0.0 - 2019-01-01

Changed

  • Processor awk codecs changed.

0.42.4 - 2018-12-31

Changed

  • Output type sqs now supports batched message sends.

0.42.3 - 2018-12-28

Added

  • Functions json_get and json_set added to awk processor.

0.42.1 - 2018-12-20

Added

  • Functions timestamp_format, timestamp_format_nano, metadata_get and metadata_set added to awk processor.

0.42.0 - 2018-12-19

Added

  • New sleep processor.
  • New awk processor.

Changed

  • Converted all integer based time period fields to string based, e.g. timeout_ms: 5000 would now be timeout: 5s. This will may potentially be disruptive but the --strict flag should catch all deprecated fields in an existing config.

0.41.0 - 2018-12-12

Changed

  • Renamed max_batch_size to max_batch_count for consistency.

0.40.2 - 2018-12-12

Added

  • New max_batch_size field added to kafka, kafka_balanced and amqp inputs. This provides a mechanism for creating message batches optimistically.

0.40.0 - 2018-12-10

Added

  • New subprocess processor.

Changed

  • API: The types.Processor interface has been changed in order to add lifetime cleanup methods (added CloseAsync and WaitForClose). For the overwhelming majority of processors these functions will be no-ops.
  • More consistent condition metrics.

0.39.2 - 2018-12-07

Added

  • New try and catch processors for improved processor error handling.

0.39.1 - 2018-12-07

Added

  • All processors now attach error flags.
  • S3 input is now more flexible with SNS triggered SQS events.

Changed

  • Processor metrics have been made more consistent.

0.39.0 - 2018-12-05

Added

  • New endpoint /ready that returns 200 when both the input and output components are connected, otherwise 503. This is intended to be used as a readiness probe.

Changed

  • Large simplifications to all metrics paths.
  • Fully removed the previously deprecated combine processor.
  • Input and output plugins updated to support new connection health checks.

0.38.10 - 2018-12-04

Added

  • Field role_external_id added to all S3 credential configs.
  • New processor_failed condition and improved processor error handling which can be read about here

0.38.8 - 2018-11-29

Added

  • New content_type field for the s3 output.

0.38.6 - 2018-11-28

Added

  • New group_by_value processor.

0.38.5 - 2018-11-27

Added

  • Lint errors are logged (level INFO) during normal Benthos operation.
  • New --strict command flag which causes Benthos to abort when linting errors are found in a config file.

0.38.4 - 2018-11-26

Added

  • New --lint command flag for linting config files.

0.38.1 - 2018-11-23

Changed

  • The s3 output now attempts to batch uploads.
  • The s3 input now exposes errors in deleting SQS messages during acks.

0.38.0 - 2018-11-22

Changed

  • Resource based conditions no longer benefit from cached results. In practice this optimisation was easy to lose in config and difficult to maintain.

0.37.4 - 2018-11-22

Added

  • Metadata is now sent to kafka outputs.
  • New max_inflight field added to the nats_stream input.

Fixed

  • Fixed relative path trimming for streams from file directories.

0.37.2 - 2018-11-15

Fixed

  • The dynamodb cache and output types now set TTL columns as unix timestamps.

0.37.1 - 2018-11-13

Added

  • New escape_url_query operator for the text processor.

0.37.0 - 2018-11-09

Changed

  • Removed submatch indexes in the text processor find_regexp operator and added documentation for expanding submatches in the replace_regexp operator.

0.36.4 - 2018-11-09

Added

  • Allow submatch indexes in the find_regexp operator for the text processor.

0.36.3 - 2018-11-08

Added

  • New find_regexp operator for the text processor.

0.36.1 - 2018-11-07

Added

  • New aws fields to the elasticsearch output to allow AWS authentication.

0.36.0 - 2018-11-06

Added

  • Add max-outstanding fields to gcp_pubsub input.
  • Add new dynamodb output.

Changed

  • The s3 output now calculates path field function interpolations per message of a batch.

0.35.1 - 2018-10-31

Added

  • New set operator for the text processor.

0.35.0 - 2018-10-30

Added

  • New cache output type.

0.34.13 - 2018-10-29

Added

  • New group_by processor.
  • Add bulk send support to elasticsearch output.

0.34.8 - 2018-10-10

Added

  • New content interpolation function.

0.34.7 - 2018-10-04

Added

  • New redis cache type.

0.34.5 - 2018-10-02

Changed

  • The process_map processor now allows map target path overrides when a target is the parent of another target.

0.34.4 - 2018-10-02

Added

  • Field pipeline and sniff added to the elasticsearch output.
  • Operators to_lower and to_upper added to the text processor.

0.34.3 - 2018-09-29

Added

  • Field endpoint added to all AWS types.

0.34.2 - 2018-09-27

Changed

  • Allow log config field static_fields to be fully overridden.

0.34.0 - 2018-09-27

Added

  • New process_dag processor.
  • New static_fields map added to log config for setting static log fields.

Changed

  • JSON log field containing component path moved from @service to component.

0.33.0 - 2018-09-22

Added

  • New gcp_pubsub input and outputs.
  • New log processor.
  • New lambda processor.

0.32.0 - 2018-09-18

Added

  • New process_batch processor.
  • Added count field to batch processor.
  • Metrics for kinesis output throttles.

Changed

  • The combine processor is now considered DEPRECATED, please use the batch processor instead.
  • The batch processor field byte_size is now set at 0 (and therefore ignored) by default. A log warning has been added in case anyone was relying on the default.

0.31.4 - 2018-09-16

Added

  • New rate_limit resource with a local type.
  • Field rate_limit added to http based processors, inputs and outputs.

0.31.2 - 2018-09-14

Added

  • New prefetch_count field added to nats input.

0.31.0 - 2018-09-11

Added

  • New bounds_check condition type.
  • New check_field condition type.
  • New queue field added to nats input.
  • Function interpolation for the topic field of the nsq output.

Changed

  • The nats input now defaults to joining a queue.

0.30.1 - 2018-09-06

Changed

  • The redundant nsq output field max_in_flight has been removed.
  • The files output now interpolates paths per message part of a batch.

0.30.0 - 2018-09-06

Added

  • New hdfs input and output.
  • New switch output.
  • New enum and has_prefix operators for the metadata condition.
  • Ability to set tls client certificate fields directly.

0.29.0 - 2018-09-02

Added

  • New retry output.
  • Added regex_partial and regex_exact operators to the metadata condition.

Changed

  • The kinesis output field retries has been renamed max_retries in order to expose the difference in its zero value behaviour (endless retries) versus other retry fields (zero retries).

0.28.0 - 2018-09-01

Added

  • New endpoint field added to kinesis input.
  • New dynamodb cache type.

0.27.0 - 2018-08-30

Added

  • Function interpolation for the topic field of the kafka output.
  • New target_version field for the kafka_balanced input.
  • TLS config fields for client certificates.

Changed

  • TLS config field cas_file has been renamed root_cas_file.

0.26.3 - 2018-08-29

Added

  • New zip option for the archive and unarchive processors.

Changed

  • The kinesis output type now supports batched sends and per message interpolation.

0.26.2 - 2018-08-27

Added

  • New metric processor.

0.26.1 - 2018-08-26

Added

  • New redis_streams input and output.

0.26.0 - 2018-08-25

Added

  • New kinesis input and output.

0.25.0 - 2018-08-22

Added

  • The index field of the elasticsearch output can now be dynamically set using function interpolation.
  • New hash processor.

Changed

  • API: The metrics.Type interface has been changed in order to add labels.

0.24.0 - 2018-08-17

Changed

  • Significant restructuring of amqp inputs and outputs. These changes should be backwards compatible for existing pipelines, but changes the way in which queues, exchanges and bindings are declared using these types.

0.23.17 - 2018-08-17

Added

  • New durable fields for amqp input and output types.

0.23.15 - 2018-08-16

Changed

  • Improved statsd client with better cached aggregation.

0.23.14 - 2018-08-16

Added

  • New tls fields for amqp input and output types.

0.23.12 - 2018-08-14

Added

  • New type field for elasticsearch output.

0.23.9 - 2018-08-10

Added

  • New throttle processor.

0.23.6 - 2018-08-09

Added

  • New less_than and greater_than operators for metadata condition.

0.23.4 - 2018-08-09

Added

  • New metadata condition type.
  • More metadata fields for kafka input.
  • Field commit_period_ms for kafka and kafka_balanced inputs for specifying a commit period.

0.23.1 - 2018-08-06

Added

  • New retries field to s3 input, to cap the number of download attempts made on the same bucket item.
  • Added metadata based mechanism to detect final message from a read_until input.
  • Added field to split processor for specifying target batch sizes.

0.23.0 - 2018-08-06

Added

  • Metadata fields are now per message part within a batch.
  • New metadata_json_object function interpolation to return a JSON object of metadata key/value pairs.

Changed

  • The metadata function interpolation now allows part indexing and no longer returns a JSON object when no key is specified, this behaviour can now be done using the metadata_json_object function.

0.22.0 - 2018-08-03

Added

  • Fields for the http processor to enable parallel requests from message batches.

Changed

  • Broker level output processors are now applied before the individual output processors.
  • The dynamic input and output HTTP paths for CRUD operations are now /inputs/{input_id} and /outputs/{output_id} respectively.
  • Removed deprecated amazon_s3, amazon_sqs and scalability_protocols input and output types.
  • Removed deprecated json_fields field from the dedupe processor.

0.21.0 - 2018-07-31

Added

  • Add conditions to process_map processor.

Changed

  • TLS config fields have been cleaned up for multiple types. This affects the kafka, kafka_balanced and http_client input and output types, as well as the http processor type.

0.20.8 - 2018-07-30

Added

  • New delete_all and delete_prefix operators for metadata processor.
  • More metadata fields extracted from the AMQP input.
  • HTTP clients now support function interpolation on the URL and header values, this includes the http_client input and output as well as the http processor.

0.20.7 - 2018-07-27

Added

  • New key field added to the dedupe processor, allowing you to deduplicate using function interpolation. This deprecates the json_paths array field.

0.20.6 - 2018-07-27

Added

  • New s3 and sqs input and output types, these replace the now deprecated amazon_s3 and amazon_sqs types respectively, which will eventually be removed.
  • New nanomsg input and output types, these replace the now deprecated scalability_protocols types, which will eventually be removed.

0.20.5 - 2018-07-27

Added

  • Metadata fields are now collected from MQTT input.
  • AMQP output writes all metadata as headers.
  • AMQP output field key now supports function interpolation.

0.20.1 - 2018-07-26

Added

  • New metadata processor and configuration interpolation function.

0.20.0 - 2018-07-26

Added

  • New config interpolator function json_field for extracting parts of a JSON message into a config value.

Changed

  • Log level config field no longer stutters, logger.log_level is now logger.level.

0.19.1 - 2018-07-25

Added

  • Ability to create batches via conditions on message payloads in the batch processor.
  • New --examples flag for generating specific examples from Benthos.

0.19.0 - 2018-07-23

Added

  • New text processor.

Changed

  • Processor process_map replaced field strict_premapping with premap_optional.

0.18.0 - 2018-07-20

Added

  • New process_field processor.
  • New process_map processor.

Changed

  • Removed mapping fields from the http processor, this behaviour has been put into the new process_map processor instead.

0.17.0 - 2018-07-17

Changed

  • Renamed content condition type to text in order to clarify its purpose.

0.16.4 - 2018-07-17

Added

  • Latency metrics for caches.
  • TLS options for kafka and kafka_partitions inputs and outputs.

Changed

  • Metrics for items configured within the resources section are now namespaced under their identifier.

0.16.3 - 2018-07-16

Added

  • New copy and move operators for the json processor.

0.16.2 - 2018-07-12

Added

  • Metrics for recording http request latencies.

0.16.0 - 2018-07-09

Changed

  • Improved and rearranged fields for http_client input and output.

0.15.5 - 2018-07-08

Added

  • More compression and decompression targets.
  • New lines option for archive/unarchive processors.
  • New encode and decode processors.
  • New period_ms field for the batch processor.
  • New clean operator for the json processor.

0.15.4 - 2018-07-04

Added

  • New http processor, where payloads can be sent to arbitrary HTTP endpoints and the result constructed into a new payload.
  • New inproc inputs and outputs for linking streams together.

0.15.3 - 2018-07-03

Added

  • New streams endpoint /streams/{id}/stats for obtaining JSON metrics for a stream.

Changed

  • Allow comma separated topics for kafka_balanced.

0.15.0 - 2018-06-28

Added

  • Support for PATCH verb on the streams mode /streams/{id} endpoint.

Changed

  • Sweeping changes were made to the environment variable configuration file. This file is now auto generated along with its supporting document. This change will impact the docker image.

0.14.7 - 2018-06-24

Added

  • New filter_parts processor for filtering individual parts of a message batch.
  • New field open_message for websocket input.

Changed

  • No longer setting default input processor.

0.14.6 - 2018-06-21

Added

  • New root_path field for service wide http config.

0.14.5 - 2018-06-21

Added

  • New regexp_exact and regexp_partial content condition operators.

0.14.4 - 2018-06-19

Changed

  • The statsd metrics target will now periodically report connection errors.

0.14.2 - 2018-06-18

Changed

  • The json processor will now append array values in expanded form.

0.14.0 - 2018-06-15

Added

  • More granular config options in the http_client output for controlling retry logic.
  • New try pattern for the output broker type, which can be used in order to configure fallback outputs.
  • New json processor, this replaces delete_json, select_json, set_json.

Changed

  • The streams API endpoints have been changed to become more "RESTy".
  • Removed the delete_json, select_json and set_json processors, please use the json processor instead.

0.13.5 - 2018-06-10

Added

  • New grok processor for creating structured objects from unstructured data.

0.13.4 - 2018-06-08

Added

  • New files input type for reading multiple files as discrete messages.

Changed

  • Increase default max_buffer for stdin, file and http_client inputs.
  • Command flags --print-yaml and --print-json changed to provide sanitised outputs unless accompanied by new --all flag.

Removed

  • Badger based buffer option has been removed.

0.13.3 - 2018-06-06

Added

  • New metrics wrapper for more basic interface implementations.
  • New delete_json processor.
  • New field else_processors for conditional processor.

0.13.2 - 2018-06-03

Added

  • New websocket endpoint for http_server input.
  • New websocket endpoint for http_server output.
  • New websocket input type.
  • New websocket output type.

0.13.1 - 2018-06-02

Added

  • Goreleaser config for generating release packages.

Changed

  • Back to using Scratch as base for Docker image, instead taking ca-certificates from the build image.

0.13.0 - 2018-06-02

Added

  • New batch processor for combining payloads up to a number of bytes.
  • New conditional processor, allows you to configure a chain of processors to only be run if the payload passes a condition.
  • New --stream mode features:
    • POST verb for /streams path now supported.
    • New --streams-dir flag for parsing a directory of stream configs.

Changed

  • The condition processor has been renamed filter.
  • The custom_delimiter fields in any line reader types file, stdin, stdout, etc have been renamed delimiter, where the behaviour is the same.
  • Now using Alpine as base for Docker image, includes ca-certificates.