Test Grok pattern API

Test Grok pattern API

New API reference

For the most up-to-date API details, refer to Text structure APIs.

Tests a Grok pattern on lines of text, see also Grokking grok.

Request

GET _text_structure/test_grok_pattern

POST _text_structure/test_grok_pattern

Description

The test Grok pattern API allows you to execute a Grok pattern on one or more lines of text. It returns whether the lines match the pattern together with the offsets and lengths of the matched substrings.

Query parameters

ecs_compatibility

(Optional, string) The mode of compatibility with ECS compliant Grok patterns. Use this parameter to specify whether to use ECS Grok patterns instead of legacy ones when the structure finder creates a Grok pattern. Valid values are disabled and v1. The default value is disabled.

Request body

grok_pattern

(Required, string) The Grok pattern to run on the lines of text.

text

(Required, array of strings) The lines of text to run the Grok pattern on.

Examples

  1. resp = client.text_structure.test_grok_pattern(
  2. grok_pattern="Hello %{WORD:first_name} %{WORD:last_name}",
  3. text=[
  4. "Hello John Doe",
  5. "this does not match"
  6. ],
  7. )
  8. print(resp)
  1. response = client.text_structure.test_grok_pattern(
  2. body: {
  3. grok_pattern: 'Hello %{WORD:first_name} %{WORD:last_name}',
  4. text: [
  5. 'Hello John Doe',
  6. 'this does not match'
  7. ]
  8. }
  9. )
  10. puts response
  1. const response = await client.textStructure.testGrokPattern({
  2. grok_pattern: "Hello %{WORD:first_name} %{WORD:last_name}",
  3. text: ["Hello John Doe", "this does not match"],
  4. });
  5. console.log(response);
  1. GET _text_structure/test_grok_pattern
  2. {
  3. "grok_pattern": "Hello %{WORD:first_name} %{WORD:last_name}",
  4. "text": [
  5. "Hello John Doe",
  6. "this does not match"
  7. ]
  8. }

The API returns the following response:

  1. {
  2. "matches": [
  3. {
  4. "matched": true,
  5. "fields": {
  6. "first_name": [
  7. {
  8. "match": "John",
  9. "offset": 6,
  10. "length": 4
  11. }
  12. ],
  13. "last_name": [
  14. {
  15. "match": "Doe",
  16. "offset": 11,
  17. "length": 3
  18. }
  19. ]
  20. }
  21. },
  22. {
  23. "matched": false
  24. }
  25. ]
  26. }