From 4777fda4389e0cd525fda995ce57294a1bea5637 Mon Sep 17 00:00:00 2001 From: Mathieu Martin Date: Wed, 25 Nov 2020 15:52:55 -0500 Subject: [PATCH] Reinforce the exclusion of the leading dot from url.extension (#1151) --- code/go/ecs/url.go | 5 ++++- docs/field-details.asciidoc | 4 +++- experimental/generated/beats/fields.ecs.yml | 7 +++++-- experimental/generated/csv/fields.csv | 2 +- experimental/generated/ecs/ecs_flat.yml | 10 +++++++--- experimental/generated/ecs/ecs_nested.yml | 9 ++++++--- generated/beats/fields.ecs.yml | 7 +++++-- generated/csv/fields.csv | 2 +- generated/ecs/ecs_flat.yml | 10 +++++++--- generated/ecs/ecs_nested.yml | 9 ++++++--- schemas/url.yml | 8 ++++++-- 11 files changed, 51 insertions(+), 22 deletions(-) diff --git a/code/go/ecs/url.go b/code/go/ecs/url.go index 6c1ac3be75..ec00f75914 100644 --- a/code/go/ecs/url.go +++ b/code/go/ecs/url.go @@ -87,11 +87,14 @@ type Url struct { // differentiate between the two cases. Query string `ecs:"query"` - // The field contains the file extension from the original request url. + // The field contains the file extension from the original request url, + // excluding the leading dot. // The file extension is only set if it exists, as not every url has a file // extension. // The leading period must not be included. For example, the value must be // "png", not ".png". + // Note that when the file name has multiple extensions (example.tar.gz), + // only the last one should be captured ("gz", not "tar.gz"). Extension string `ecs:"extension"` // Portion of the url after the `#`, such as "top". diff --git a/docs/field-details.asciidoc b/docs/field-details.asciidoc index d728ba703a..83dbc5d65a 100644 --- a/docs/field-details.asciidoc +++ b/docs/field-details.asciidoc @@ -6230,12 +6230,14 @@ example: `www.elastic.co` // =============================================================== | url.extension -| The field contains the file extension from the original request url. +| The field contains the file extension from the original request url, excluding the leading dot. The file extension is only set if it exists, as not every url has a file extension. The leading period must not be included. For example, the value must be "png", not ".png". +Note that when the file name has multiple extensions (example.tar.gz), only the last one should be captured ("gz", not "tar.gz"). + type: keyword diff --git a/experimental/generated/beats/fields.ecs.yml b/experimental/generated/beats/fields.ecs.yml index 99808bb3b6..82174d1bcf 100644 --- a/experimental/generated/beats/fields.ecs.yml +++ b/experimental/generated/beats/fields.ecs.yml @@ -5224,12 +5224,15 @@ type: keyword ignore_above: 1024 description: 'The field contains the file extension from the original request - url. + url, excluding the leading dot. The file extension is only set if it exists, as not every url has a file extension. The leading period must not be included. For example, the value must be "png", - not ".png".' + not ".png". + + Note that when the file name has multiple extensions (example.tar.gz), only + the last one should be captured ("gz", not "tar.gz").' example: png - name: fragment level: extended diff --git a/experimental/generated/csv/fields.csv b/experimental/generated/csv/fields.csv index 44c5d6fd23..02764f4015 100644 --- a/experimental/generated/csv/fields.csv +++ b/experimental/generated/csv/fields.csv @@ -629,7 +629,7 @@ ECS_Version,Indexed,Field_Set,Field,Type,Level,Normalization,Example,Description 1.7.0+exp,true,trace,trace.id,keyword,extended,,4bf92f3577b34da6a3ce929d0e0e4736,Unique identifier of the trace. 1.7.0+exp,true,transaction,transaction.id,keyword,extended,,00f067aa0ba902b7,Unique identifier of the transaction within the scope of its trace. 1.7.0+exp,true,url,url.domain,wildcard,extended,,www.elastic.co,Domain of the url. -1.7.0+exp,true,url,url.extension,keyword,extended,,png,File extension from the original request url. +1.7.0+exp,true,url,url.extension,keyword,extended,,png,"File extension from the request url, excluding the leading dot." 1.7.0+exp,true,url,url.fragment,keyword,extended,,,Portion of the url after the `#`. 1.7.0+exp,true,url,url.full,wildcard,extended,,https://www.elastic.co:443/search?q=elasticsearch#top,Full unparsed URL. 1.7.0+exp,true,url,url.full.text,text,extended,,https://www.elastic.co:443/search?q=elasticsearch#top,Full unparsed URL. diff --git a/experimental/generated/ecs/ecs_flat.yml b/experimental/generated/ecs/ecs_flat.yml index 4cbf562f31..f41cfc97d0 100644 --- a/experimental/generated/ecs/ecs_flat.yml +++ b/experimental/generated/ecs/ecs_flat.yml @@ -7980,19 +7980,23 @@ url.domain: type: wildcard url.extension: dashed_name: url-extension - description: 'The field contains the file extension from the original request url. + description: 'The field contains the file extension from the original request url, + excluding the leading dot. The file extension is only set if it exists, as not every url has a file extension. The leading period must not be included. For example, the value must be "png", - not ".png".' + not ".png". + + Note that when the file name has multiple extensions (example.tar.gz), only the + last one should be captured ("gz", not "tar.gz").' example: png flat_name: url.extension ignore_above: 1024 level: extended name: extension normalize: [] - short: File extension from the original request url. + short: File extension from the request url, excluding the leading dot. type: keyword url.fragment: dashed_name: url-fragment diff --git a/experimental/generated/ecs/ecs_nested.yml b/experimental/generated/ecs/ecs_nested.yml index 6a2f613137..b38f73aa69 100644 --- a/experimental/generated/ecs/ecs_nested.yml +++ b/experimental/generated/ecs/ecs_nested.yml @@ -9224,19 +9224,22 @@ url: url.extension: dashed_name: url-extension description: 'The field contains the file extension from the original request - url. + url, excluding the leading dot. The file extension is only set if it exists, as not every url has a file extension. The leading period must not be included. For example, the value must be "png", - not ".png".' + not ".png". + + Note that when the file name has multiple extensions (example.tar.gz), only + the last one should be captured ("gz", not "tar.gz").' example: png flat_name: url.extension ignore_above: 1024 level: extended name: extension normalize: [] - short: File extension from the original request url. + short: File extension from the request url, excluding the leading dot. type: keyword url.fragment: dashed_name: url-fragment diff --git a/generated/beats/fields.ecs.yml b/generated/beats/fields.ecs.yml index 0c109b8317..6e22f3e1c4 100644 --- a/generated/beats/fields.ecs.yml +++ b/generated/beats/fields.ecs.yml @@ -5312,12 +5312,15 @@ type: keyword ignore_above: 1024 description: 'The field contains the file extension from the original request - url. + url, excluding the leading dot. The file extension is only set if it exists, as not every url has a file extension. The leading period must not be included. For example, the value must be "png", - not ".png".' + not ".png". + + Note that when the file name has multiple extensions (example.tar.gz), only + the last one should be captured ("gz", not "tar.gz").' example: png - name: fragment level: extended diff --git a/generated/csv/fields.csv b/generated/csv/fields.csv index 340d0d5975..0590354d55 100644 --- a/generated/csv/fields.csv +++ b/generated/csv/fields.csv @@ -629,7 +629,7 @@ ECS_Version,Indexed,Field_Set,Field,Type,Level,Normalization,Example,Description 1.7.0,true,trace,trace.id,keyword,extended,,4bf92f3577b34da6a3ce929d0e0e4736,Unique identifier of the trace. 1.7.0,true,transaction,transaction.id,keyword,extended,,00f067aa0ba902b7,Unique identifier of the transaction within the scope of its trace. 1.7.0,true,url,url.domain,keyword,extended,,www.elastic.co,Domain of the url. -1.7.0,true,url,url.extension,keyword,extended,,png,File extension from the original request url. +1.7.0,true,url,url.extension,keyword,extended,,png,"File extension from the request url, excluding the leading dot." 1.7.0,true,url,url.fragment,keyword,extended,,,Portion of the url after the `#`. 1.7.0,true,url,url.full,keyword,extended,,https://www.elastic.co:443/search?q=elasticsearch#top,Full unparsed URL. 1.7.0,true,url,url.full.text,text,extended,,https://www.elastic.co:443/search?q=elasticsearch#top,Full unparsed URL. diff --git a/generated/ecs/ecs_flat.yml b/generated/ecs/ecs_flat.yml index 81a1ee4950..71dd2eae23 100644 --- a/generated/ecs/ecs_flat.yml +++ b/generated/ecs/ecs_flat.yml @@ -8064,19 +8064,23 @@ url.domain: type: keyword url.extension: dashed_name: url-extension - description: 'The field contains the file extension from the original request url. + description: 'The field contains the file extension from the original request url, + excluding the leading dot. The file extension is only set if it exists, as not every url has a file extension. The leading period must not be included. For example, the value must be "png", - not ".png".' + not ".png". + + Note that when the file name has multiple extensions (example.tar.gz), only the + last one should be captured ("gz", not "tar.gz").' example: png flat_name: url.extension ignore_above: 1024 level: extended name: extension normalize: [] - short: File extension from the original request url. + short: File extension from the request url, excluding the leading dot. type: keyword url.fragment: dashed_name: url-fragment diff --git a/generated/ecs/ecs_nested.yml b/generated/ecs/ecs_nested.yml index 0aa8c9d343..a2e13cce81 100644 --- a/generated/ecs/ecs_nested.yml +++ b/generated/ecs/ecs_nested.yml @@ -9313,19 +9313,22 @@ url: url.extension: dashed_name: url-extension description: 'The field contains the file extension from the original request - url. + url, excluding the leading dot. The file extension is only set if it exists, as not every url has a file extension. The leading period must not be included. For example, the value must be "png", - not ".png".' + not ".png". + + Note that when the file name has multiple extensions (example.tar.gz), only + the last one should be captured ("gz", not "tar.gz").' example: png flat_name: url.extension ignore_above: 1024 level: extended name: extension normalize: [] - short: File extension from the original request url. + short: File extension from the request url, excluding the leading dot. type: keyword url.fragment: dashed_name: url-fragment diff --git a/schemas/url.yml b/schemas/url.yml index 8a523fbc8d..0253f316e8 100644 --- a/schemas/url.yml +++ b/schemas/url.yml @@ -133,13 +133,17 @@ - name: extension level: extended type: keyword - short: File extension from the original request url. + short: File extension from the request url, excluding the leading dot. description: > - The field contains the file extension from the original request url. + The field contains the file extension from the original request url, + excluding the leading dot. The file extension is only set if it exists, as not every url has a file extension. The leading period must not be included. For example, the value must be "png", not ".png". + + Note that when the file name has multiple extensions (example.tar.gz), + only the last one should be captured ("gz", not "tar.gz"). example: png - name: fragment