URI parts processor

URI parts processor

Parses a Uniform Resource Identifier (URI) string and extracts its components as an object. This URI object includes properties for the URI’s domain, path, fragment, port, query, scheme, user info, username, and password.

Table 43. URI Parts Options

NameRequiredDefaultDescription

field

yes

-

Field containing the URI string.

target_field

no

url

Output field for the URI object.

keep_original

no

true

If true, the processor copies the unparsed URI to <target_field>.original.

remove_if_successful

no

false

If true, the processor removes the field after parsing the URI string. If parsing fails, the processor does not remove the field.

description

no

-

Description of the processor. Useful for describing the purpose of the processor or its configuration.

if

no

-

Conditionally execute the processor. See Conditionally run a processor.

ignore_failure

no

false

Ignore failures for the processor. See Handling pipeline failures.

on_failure

no

-

Handle failures for the processor. See Handling pipeline failures.

tag

no

-

Identifier for the processor. Useful for debugging and metrics.

Here is an example definition of the URI parts processor:

  1. {
  2. "description" : "...",
  3. "processors" : [
  4. {
  5. "uri_parts": {
  6. "field": "input_field",
  7. "target_field": "url",
  8. "keep_original": true,
  9. "remove_if_successful": false
  10. }
  11. }
  12. ]
  13. }

When the above processor executes on the following document:

  1. {
  2. "_source": {
  3. "input_field": "http://myusername:mypassword@www.example.com:80/foo.gif?key1=val1&key2=val2#fragment"
  4. }
  5. }

It produces this result:

  1. "_source" : {
  2. "input_field" : "http://myusername:mypassword@www.example.com:80/foo.gif?key1=val1&key2=val2#fragment",
  3. "url" : {
  4. "path" : "/foo.gif",
  5. "fragment" : "fragment",
  6. "extension" : "gif",
  7. "password" : "mypassword",
  8. "original" : "http://myusername:mypassword@www.example.com:80/foo.gif?key1=val1&key2=val2#fragment",
  9. "scheme" : "http",
  10. "port" : 80,
  11. "user_info" : "myusername:mypassword",
  12. "domain" : "www.example.com",
  13. "query" : "key1=val1&key2=val2",
  14. "username" : "myusername"
  15. }
  16. }