This project uses towncrier for changelog generation.
to_unix_timestamp
,to_float
, anduuid_v7
can now return an error if the supplied timestamp is unrepresentable as a nanosecond timestamp. Previously the function calls would panic. (#979)
- Added new
crc
function to calculate CRC (Cyclic Redundancy Check) checksum - Add
parse_cbor
function (#1152) - Added new
zip
function to iterate over an array of arrays and produce a new arrays containing an item from each one. (#1158) - Add new
decode_charset
,encode_charset
functions to decode and encode strings between different charsets. (#1162) - Added new
object_from_array
function to create an object from an array of value pairs such as whatzip
can produce. (#1164) - Added support for multi-unit duration strings (e.g.,
1h2s
,2m3s
) in theparse_duration
function. (#1197) - Added new
parse_bytes
function to parse given bytes string such as1MiB
or1TB
either in binary or decimal base. (#1198) - Add
main
log format forparse_nginx_log
. (#1202) - Added support for optional
timezone
argument in theparse_timestamp
function. (#1207)
- Fix a panic in float subtraction that produces NaN values. (#1186)
- Reverted
to_float
change because the new logic is too restrictive e.g. attempting to convert "0" returns an error. (#1179)
- Fixes the
to_float
function to return an error instead off64::INFINITY
when parsing non-normal numbers. (#1107)
- The
decrypt
andencrypt
VRL functions now support aes-siv (RFC 5297) encryption and decryption. (#1100)
decode_punycode
andencode_punycode
withvalidate
flag set to false should be faster now, in cases when input data needs no encoding or decoding. (#1104)vrl::value::Value
now implementsPartialCmp
that first checks whether the enum discriminants (that both are floats for example), and if they are callspartial_cmp
on the inner values. Otherwise, it will returnNone
. (#1117)- The
encode_proto
function was enhanced to automatically convert valid string fields to numeric proto fields. (#1114)
- The
parse_groks
VRL function and Datadog grok parsing now catch the panic coming fromrust-onig
on too many regex match retries, and handles it as a custom error. (#1079) encode_punycode
withvalidate
flag set to false should be more consistent withvalidate
set to true, turning all uppercase character to lowercase besides doing punycode encoding (#1115)- Removed false warning when using
set_semantic_meaning
. (#1148)
- The multi-line mode of the
parse_groks
VRL function is now enabled by default. Use the(?-m)
modifier to disable this behaviour. (#1022)
- The
keyvalue
grok filter is extended to match Datadog implementation. (#1015)
- The
parse_xml
function now doesn't add an unnecessarytext
key when processing single nodes. (#849) parse_grok
andparse_groks
no longer require field names containing a hyphen (e.g.@a-b
) to be quoted.- The function
match_datadog_query
doesn't panic if an invalid path is passed, instead it returns an error. (#1031) - The
parse_ruby_hash
parser is extended to match Datadog implementation. Previously it would parse the key in{:key => "value"}
as:key
, now it will parse it askey
. (#1050)
-
Added
unflatten
function to inverse the result of theflatten
function. This function is useful when you want to convert a flattened object back to its original form. -
The
parse_json
function now accepts an optionallossy
parameter (which defaults totrue
).This new parameter allows to control whether the UTF-8 decoding should be lossy or not, replacing invalid UTF-8 sequences with the Unicode replacement character (U+FFFD) if set to
true
or raising an error if set tofalse
and an invalid utf-8 sequence is found. (#269) -
Added casing functions
camelcase
,kebabcase
,screamingsnakecase
,snakecase
,pascalcase
(#973) -
Added
parse_influxdb
function to parse events encoded using the InfluxDB line protocol.
- The
match_datadog_query
function now accepts||
in place ofOR
and&&
in place ofAND
in the query string, which is common Datadog syntax. (#1001)
decode_base64
no longer requires canonical padding. (#960)- The assumption of a Datadog Logs-based intake event structure has been removed
from the
match_datadog_query
function. (#1003) - For the
parse_influxdb
function thetimestamp
andtags
fields of returned objects are now correctly marked as nullable.
parse_logfmt
now processes 3 escape sequences when parsing:\n
,\"
and\\
. This means that for example,\n
in the input will be replaced with an actual newline character in parsed keys or values. (#777)
server
option fordns_lookup
now properly replaces default server settings (https://github.com/vectordotdev/vrl/pull/910/files)
- The deprecated coalesce paths (i.e.
(field1|field2)
) feature is now removed. (#836)
-
Added experimental
dns_lookup
function. It should be used with caution, since it involves network calls and is therefore very slow. -
Added
psl
argument to theparse_etld
function. It enables customizing used public suffix list. If none is provided the default (https://publicsuffix.org/list/public_suffix_list.dat) is used, which is that was used before this change.
- Add traceability_id field support to parse_aws_alb_log (#862)
- Coalesce paths (i.e.
(field1|field2)
) are deprecated and will be removed in a future version. This feature is rarely used and not very useful. (#815)
- Add
uuid_from_friendly_id
for converting base62-encoded 128-bit identifiers to the hyphenated UUID format (#803)
parse_json
now supports round-tripable float parsing by activating thefloat_roundtrip
feature in serde_json (#755)
- fixed
parse_logfmt
handling of escapes in values that could cause spurious keys to be created. As a result of this fix, the breaking change has been made to no longer allow empty keys in key-value pair formats (#725)
-
Added the
return
expression as per RFC 7496. This expression can be used to terminate the VRL program early while still emitting a value. (#712) -
Added
sieve
string function, which can remove unwanted characters from a string using a regex of allowed patterns. (#724) -
Add VRL function
uuid_v7
that generates UUIDv7 timestamp-based unique identifiers. (#738) -
Added
encode_proto
andparse_proto
functions, which can be used to encode and decode protobufs.parse_proto
accepts a bytes value, a proto descriptor file path and a message type and returns the VRL value as parsed from the proto.encode_proto
does the reverse and converts a VRL value into a protobuf bytes value. (#739)
parse_nginx
now accepts empty values for http referer (#643)
- Added
validate
option toencode_punycode
anddecode_punycode
, which defaults to true, but can be used to skip validation when set to false. (#709)
- Added
parse_etld
function for extracting eTLD and eTLD+1 (#669) - Added
encode_punycode
anddecode_punycode
functions (#672)
- Introduced a
redactor
option inredact
function to enable the substitution of redacted content with either a custom string or a hash representation. (#633) - Add VRL function
get_timezone_name
to return the configured/resolved IANA timezone name.
- Fixed a bug in exporting paths containing more than one "coalesce" segment. (#679)
- Introduced an unused expression checker. It's designed to detect and report unused expressions, helping users to clean up and optimize their VRL scripts. Note that this checker will not catch everything, but it does aim to eliminate false positives. For example, shadowed variables are not reported as unused. (#622)
- Add a
replace_with
function that is similar toreplace
but takes a closure instead of a replacement string. (#628)
- Added the
alias_sources
parameter forparse_groks
to read sources from files. (#194)
- Support for WASM features using
chrono
was readded. This was accidentally dropped in 0.9.0.
parse_regex_all
pattern
param can now be resolved from a variable- fixed
parse_json
data corruption issue for numbers greater or equal toi64::MAX
- support timestamp comparison using operators <, <=, >, >=
- added
contains_all
function (#468) from_unix_timestamp
now accepts a new unit: Microseconds. (#492)parse_nginx_log
no longer fails ifupstream_response_length
,upstream_response_time
,upstream_status
are missing (#498)- added
parse_float
function (#484) - improved fallibility diagnostics (#523)
- added
encode_snappy
anddecode_snappy
functions (#543)
parse_nginx_log
doesn't fail if the values of key-value pairs in error logs is missing (#442)encode_gzip
andencode_zlib
now correctly check the compression level (preventing a panic) (#393)- fix the type definition of array/object literal expressions where one of the values is undefined (#401)
parse_aws_vpc_flow_log
now handles account-id value as a string, avoiding loss of leading zeros and case where value isunknown
(#263)
parse_key_value
can now parse values enclosed in single quote characters (#382)- added
pretty
parameter forencode_json
vrl function to produce pretty-printed JSON string (#370) - added
community_id
function for generation of V1 Community IDs (#360) - updated aws vpc flow log parsing to include version 5 fields (#227)
- removed deprecated
to_timestamp
function (#452) - changed
truncate
arguments, it now accepts a suffix string instead of a boolean (#454)
- enquote values containing
=
inencode_logfmt
vrl function (vectordotdev/vector#17855) - breaking change to
parse_nginx_log()
to make it compatible to more unstandardized events (#249)
- deprecated
to_timestamp
vrl function (#285) - add support for chacha20poly1305, xchacha20poly1305, xsalsa20poly1305 algorithms for encryption/decryption (#293)
- add support for resolving variables to
Expr::resolve_constant
(#304) - introduce new encryption/decryption algorithm options (
"AES-*-CTR-BE"
,"AES-*-CTR-LE"
) #299
- added \0 (null) character literal to lex parser (#259)
- added the
timezone
argument to theformat_timestamp
vrl function. (#247) - removed feature flags for each individual VRL function. (#251)
- fixed a panic when arithmetic overflows. It now always wraps (only in debug builds). (#252)
ingress_upstreaminfo
log format has been added toparse_nginx_log
function (#193)- fixed type definitions for side-effects inside of queries (#258)
- replaced
Program::final_type_state
withProgram::final_type_info
to give access to the type definitions of both the target and program result (#262) - added
from_unix_timestamp
vrl function (#277)
- consolidated all crates into the root
vrl
crate. The external API stayed the same, with the exception of macros, which are now all exported at the root of thevrl
crate. - published VRL to crates.io. Standard crate versioning will now be used instead of git tags.
- fixed a type definition bug for assignments where the right-hand side of the assignment expression resolved to the
never
type - removed the deprecated
FieldBuf
fromField
- removed the lookup v1 code
- renamed the
lookup
crate topath
- re-exported all sub-crates in the root
vrl
crate - fix the
value
macro so it works when re-exported
- added guard for the
limit
param of thesplit
function to ensure it's not negative - renamed
Expression::as_value
toExpression::resolve_constant
match
function now precompiles static regular expressions- enabled the
encrypt
anddecrypt
VRL functions on the WASM playground - update default branch to
main
- the following VRL functions now compile on WASM (but abort at runtime)
get_hostname
- `log'
- `reverse_dns'
parse_grok
parse_groks
- VRL was split from the Vector repo