[
  {
    "context": [
      "How can I leverage the `jq` (preferrably) to check whether the object with `\"login\": \"bar\"` is member of this array?",
      "Use [`any/1`](https://stedolan.github.io/jq/manual/#any,any(condition),any(generator;condition)).",
      "any(.login == \"bar\")"
    ],
    "utterance": "Determine if any element in the array has a login property with the value \"bar\".",
    "expressions": [
      "any(.login == \"bar\")"
    ],
    "data": [
      {
        "input": [
          {
            "login": "foo",
            "id": 111
          },
          {
            "login": "bar",
            "id": 222
          },
          {
            "login": "foobar",
            "id": 333
          }
        ],
        "output": true
      }
    ],
    "identifier": 74252532
  },
  {
    "context": [
      "in this case I want to change `id` to item_id`.",
      "the result does not error but \"id\" gets a value of `null` and there is not key called `item_id`.",
      "You can just delete the old field using `del`, and add another one using [object construction](https://stedolan.github.io/jq/manual/#ObjectConstruction%3A%7B%7D):",
      "jq '.item[]  | select(.closed == false and .id == \"1234\") | del(.id) + {item_id: .id}' data.json",
      "Or use `with_entries` to \"rename\" the old field:",
      "jq '.item[]  | select(.closed == false and .id == \"1234\") | with_entries(select(.key == \"id\").key = \"item_id\")' data.json"
    ],
    "utterance": "Rename the key 'id' to 'item_id' for objects in '.item[]' where 'closed' is false and 'id' is '1234'.",
    "expressions": [
      ".item[] | select(.closed == false and .id == \"1234\") | del(.id) + {item_id: .id}",
      ".item[] | select(.closed == false and .id == \"1234\") | with_entries(select(.key == \"id\").key = \"item_id\")"
    ],
    "identifier": 74259218
  },
  {
    "context": [
      "I managed to make a function that  turns an amount of months into days. I now want to store these days into a variable to be used in other functions later on.",
      "Before I wanted to make the variable storing the output of the function, I would run it with: .months|Months_to_Days",
      "The following jq program works just fine:",
      "(.months|to_days) as $calculated_days # store in variable\n| { days: $calculated_days }  # use variable",
      "Variables are explained in Variable / Symbolic Binding Operator: ... as $identifier | ... in the jq manual."
    ],
    "utterance": "Store the result of applying a function to a field in a variable for later use in constructing objects or further expressions",
    "expressions": [
      "(.months | Months_to_Days) as $days | {months: .months, days: $days}"
    ],
    "data": [
      {
        "input": {
          "months": "12"
        }
      }
    ],
    "identifier": 74262719
  },
  {
    "context": [
      "I want a full path jq expression that gives me the values of \"z\". Such expression should not explicitly mention  \"fffs232/232\" since that key is dynamic.",
      "You could use `..`, e.g. along the lines of:\n\n    jq '.. | objects | .z // empty'",
      ".f[][] | select(has(\"z\")).z",
      ".. | select(has(\"z\")).z"
    ],
    "utterance": "Extract all values of fields named \"z\", regardless of their parent object key, including when the parent key is dynamic.",
    "expressions": [
      ".. | objects | .z // empty",
      ".f[][] | select(has(\"z\")).z",
      ".. | select(has(\"z\")).z"
    ],
    "data": [
      {
        "input": {
          "a": 1,
          "c": {
            "ca": 1.1
          },
          "d": {},
          "e": [
            1,
            2,
            3
          ],
          "f": [
            {
              "fa": "vf1",
              "fb": "vf2",
              "fc": [],
              "fffs232/232": {
                "z": 1
              }
            },
            {
              "fa": "vf3",
              "fb": "vf4",
              "fc": [
                1.1,
                2.3
              ],
              "fffs232/232": {
                "z": 2
              }
            }
          ]
        },
        "output": [
          1,
          2
        ]
      }
    ],
    "identifier": 74242504
  },
  {
    "context": [
      "How can I change .a? to \"any key\"?  Like I wish I could put * instead of a.",
      "'[[{\"a\":\"hi there\"}]]' | jq '..|select(.a?|contains(\"hi\"))'",
      "To get all objects with at least one field containing the substring \"hi\":",
      "jq '..|objects|select(any(contains(\"hi\")?))'",
      ".. | if type == \"object\" then select(.[] | contains(\"hi\")) else empty end",
      ".. | objects|with_entries(select(.value|strings|test(\"hi\")))"
    ],
    "utterance": "Return all objects where at least one field value contains the substring \"hi\".",
    "expressions": [
      "..|objects|select(any(contains(\"hi\")?))",
      ".. | if type == \"object\" then select(.[] | contains(\"hi\")) else empty end",
      ".. | objects|with_entries(select(.value|strings|test(\"hi\")))"
    ],
    "data": [
      {
        "input": [
          [
            {
              "a": "hi there"
            }
          ]
        ],
        "output": {
          "a": "hi there"
        }
      },
      {
        "input": [
          [
            {
              "a": "hi there",
              "b": {
                "c": "hi again"
              }
            }
          ]
        ],
        "output": {
          "a": "hi there",
          "b": {
            "c": "hi again"
          }
        }
      }
    ],
    "identifier": 74265057
  },
  {
    "context": [
      "I would like to filter the json object while iterating through it and run curl command over each item from the output.",
      "Looking for some logic that will iterate through the uri under children and that is passed through curl command as $i which would be Image1, Image2 and Image3.",
      "for i in $(curl -k -s --user user:password -X GET      \"https://artifactory.com/api/releases/baseimage/\" | jq -c \".children[] |.uri)",
      "for i in $(curl -k -s --user user:password -X GET \"https://artifactory.com/api/releases/baseimage/\" | jq -r \".children[] |.uri); do curl -k -s --user user:password -X GET \"https://artifactory.com/api/releases/baseimage/${i}\"; done",
      "for uri in $( echo \"$json\" | jq '.children[].uri') ; do \n  echo curl ... ${uri}...\ndone",
      "jq -r --arg b \"$base\" '.children[].uri | \"url = \\\"\\($b)/\\(.)\\\"\"'"
    ],
    "utterance": "Extract each string value under 'children[].uri' for use in constructing per-item curl commands.",
    "expressions": [
      ".children[].uri",
      ".children[] | .uri",
      "jq -r '.children[].uri'",
      "jq -r '.children[] | .uri'"
    ],
    "data": [
      {
        "input": {
          "repo": "releases",
          "path": "/apps/releases",
          "created": "2021-04-01T10:12:23.496-01:00",
          "children": [
            {
              "uri": "/Image1",
              "folder": true,
              "created": "2022-08-09T17.12.22.987.04.000"
            },
            {
              "uri": "/Image2",
              "folder": true,
              "created": "2022-06-10T10.12.22.412.10.000"
            },
            {
              "uri": "/Image3",
              "folder": true,
              "created": "2022-10-10T07.03.14.742.01.000"
            },
            {
              "uri": "/Image4",
              "folder": true,
              "created": "2022-10-10T07.010.11.542.08.000"
            }
          ]
        },
        "output": [
          "/Image1",
          "/Image2",
          "/Image3",
          "/Image4"
        ]
      }
    ],
    "identifier": 74266931
  },
  {
    "context": [
      "Can someone tell me what jq-fu will map the `tagName` and the `date` fields into each item in `nodes[]` and skip the empty `nodes` array to produce the following desired output?",
      "You&#39;re looking for something like this:\r\n```\r\n.data.repository.releases.nodes | map({tagName, date} + .releaseAssets.nodes[])\r\n```"
    ],
    "utterance": "For each release, attach its tagName and date fields to each asset in releaseAssets.nodes, omitting releases with no assets.",
    "expressions": [
      ".data.repository.releases.nodes | map({tagName, date} + .releaseAssets.nodes[])"
    ],
    "data": [
      {
        "input": {
          "data": {
            "repository": {
              "releases": {
                "nodes": [
                  {
                    "tagName": "v2.0.0",
                    "date": "2022-10-26T14:22:15Z",
                    "releaseAssets": {
                      "nodes": [
                        {
                          "name": "foo-2.0.0.tar.gz",
                          "downloadUrl": "https://github.com/foo/foo-releases/releases/download/v2.0.0/foo-2.0.0.tar.gz"
                        },
                        {
                          "name": "foo-2.0.0-arm64.AppImage",
                          "downloadUrl": "https://github.com/foo/foo-releases/releases/download/v2.0.0/foo-2.0.0-arm64.AppImage"
                        }
                      ]
                    }
                  },
                  {
                    "tagName": "v1.3.0",
                    "date": "2021-03-10T07:10:41Z",
                    "releaseAssets": {
                      "nodes": [
                        {
                          "name": "foo-1.3.0.tar.gz",
                          "downloadUrl": "https://github.com/foo/foo-releases/releases/download/v1.3.0/foo-1.3.0.tar.gz"
                        },
                        {
                          "name": "foo-1.3.0-arm64.AppImage",
                          "downloadUrl": "https://github.com/foo/foo-releases/releases/download/v1.3.0/foo-1.3.0-arm64.AppImage"
                        }
                      ]
                    }
                  },
                  {
                    "tagName": "v0.9.9",
                    "releaseAssets": {
                      "nodes": []
                    }
                  }
                ]
              }
            }
          }
        },
        "output": [
          {
            "name": "foo-2.0.0.tar.gz",
            "downloadUrl": "https://github.com/foo/foo-releases/releases/download/v2.0.0/foo-2.0.0.tar.gz",
            "tagName": "v2.0.0",
            "date": "2022-10-26T14:22:15Z"
          },
          {
            "name": "foo-2.0.0-arm64.AppImage",
            "downloadUrl": "https://github.com/foo/foo-releases/releases/download/v2.0.0/foo-2.0.0-arm64.AppImage",
            "tagName": "v2.0.0",
            "date": "2022-10-26T14:22:15Z"
          },
          {
            "name": "foo-1.3.0.tar.gz",
            "downloadUrl": "https://github.com/foo/foo-releases/releases/download/v1.3.0/foo-1.3.0.tar.gz",
            "tagName": "v1.3.0",
            "date": "2021-03-10T07:10:41Z"
          },
          {
            "name": "foo-1.3.0-arm64.AppImage",
            "downloadUrl": "https://github.com/foo/foo-releases/releases/download/v1.3.0/foo-1.3.0-arm64.AppImage",
            "tagName": "v1.3.0",
            "date": "2021-03-10T07:10:41Z"
          }
        ]
      }
    ],
    "identifier": 74247476
  },
  {
    "context": [
      "First is to replace the GroupID with the correct GroupName matched from the `GroupsID.json` file and the Member with the User Name that matches the ID from the `UserID.json` file.",
      "It should be doable with `INDEX` and `JOIN` in a two-level nesting:",
      "jq --slurpfile users UserIds.json --slurpfile groups GroupsID.json '\n  JOIN($groups | INDEX(.ID);\n    JOIN($users | INDEX(.ID); .; .Member; add);\n  .GroupID; add) | {Name, GroupName}\n' GroupsMembers.json"
    ],
    "utterance": "For each group membership, show the user's Name and the group's GroupName by matching Member with user ID in UserIds.json and GroupID in GroupsID.json.",
    "expressions": [
      "jq --slurpfile users UserIds.json --slurpfile groups GroupsID.json '\n  JOIN($groups | INDEX(.ID);\n    JOIN($users | INDEX(.ID); .; .Member; add);\n  .GroupID; add) | {Name, GroupName}\n' GroupsMembers.json"
    ],
    "data": [
      {
        "input": [
          {
            "GroupID": "123456789-55668877-1234-5522-2255-987654321",
            "Member": "123456789-9876543210-ABCD-4321-1234"
          },
          {
            "GroupID": "1234567890-11224455-2255-5522-1343-9876543210",
            "Member": "12345678-4321-1234-2233-9876543210"
          }
        ],
        "output": [
          {
            "Name": "first.last@example.com",
            "GroupName": "sso-aws-zone-role-CloudCoreOps"
          },
          {
            "Name": "last.first@example.com",
            "GroupName": "sso-aws-zone-role-CloudCoreRO"
          }
        ]
      }
    ],
    "identifier": 74269324
  },
  {
    "context": [
      "can we use `jq` to merge contents from `file 2` into `evidences` section of `file 1`? which the result should like below",
      "All you need is `+=` to add up arrays while retaining the context, and `input` to access the second file:",
      "jq '.evidences += input' file1.json file2.json"
    ],
    "utterance": "Merge all objects from the second file into the evidences array property of the first file.",
    "expressions": [
      ".evidences += input"
    ],
    "data": [
      {
        "input": {
          "file1.json": {
            "version": "2",
            "run_id": "1",
            "crn": "crn",
            "date": "2022-11-02T02:09:30.629Z",
            "evidences": [
              {
                "version": "2",
                "id": "2d"
              },
              {
                "version": "2",
                "id": "3e"
              }
            ]
          },
          "file2.json": [
            {
              "version": "3",
              "id": "3d"
            },
            {
              "version": "2",
              "id": "3f"
            }
          ]
        },
        "output": {
          "version": "2",
          "run_id": "1",
          "crn": "crn",
          "date": "2022-11-02T02:09:30.629Z",
          "evidences": [
            {
              "version": "2",
              "id": "2d"
            },
            {
              "version": "2",
              "id": "3e"
            },
            {
              "version": "3",
              "id": "3d"
            },
            {
              "version": "2",
              "id": "3f"
            }
          ]
        }
      }
    ],
    "identifier": 74284275
  },
  {
    "context": [
      "data1 =$(cat abc.json | jq -r '.value4.value41.value411')",
      "I think your problem was you had a space between `data` and `=`. There can't be a space there.",
      "This works as you want it to (I removed the unnecessary `cat`)",
      "data1=$(jq -r '.value4.value41.value411' abc.json)"
    ],
    "utterance": "Extract the value of the key 'value411' from the nested object 'value4.value41' and assign it to a shell variable.",
    "expressions": [
      "jq -r '.value4.value41.value411' abc.json"
    ],
    "data": [
      {
        "input": {
          "value1": 5.0,
          "value2": 2.5,
          "value3": "2019-10-24T15:26:00.000Z",
          "modifier": [],
          "value4": {
            "value41": {
              "value411": 5
            }
          }
        },
        "output": 5
      }
    ],
    "identifier": 74290395
  },
  {
    "context": [
      "I need to do the following:\n- change a key name\n- be able to select specific keys to return, I don't need them all\n- be able to select and parse values\n- turn parsed values in to key value pairs and add them back in to the json",
      "This is something close to the end result that I want.\n[\n  {\n    \"trello_id\": \"1234\",\n    \"desc\": \"*Important Notes* \",\n    \"name\": \"Housing - Lawrence\"\n    \"location_address\": \"123 Hopscotch Way\"\n  }\n]",
      "Could something like this be what you are looking for?\n~~~sh\n.cards | map(\n  select(.closed == false) | {trello_id: .id, desc, name} + ([\n    .checklists[] | select(.name == \"Acct Information\")\n    | .checkItems[].name | select(contains(\"Location\"))\n    | capture(\"(?<key>[^:]*):\\s*(?<value>.*)\")\n    | .key |= (gsub(\"\\s+\"; \"_\") | ascii_downcase)\n    | .value |= gsub(\"\\*\"; \"\")\n  ] | from_entries)\n)\n~~~"
    ],
    "utterance": "For each card that is not closed, output an object containing the card's id as 'trello_id', 'desc', 'name', and extract the key-value pair from the checklist named 'Acct Information' where a checkItem's name contains 'Location', formatting the key in lowercase with underscores and the value without asterisks.",
    "expressions": [
      ".cards | map(\n  select(.closed == false) | {trello_id: .id, desc, name} + ([\n    .checklists[] | select(.name == \"Acct Information\")\n    | .checkItems[].name | select(contains(\"Location\"))\n    | capture(\"(?<key>[^:]*):\\s*(?<value>.*)\")\n    | .key |= (gsub(\"\\s+\"; \"_\") | ascii_downcase)\n    | .value |= gsub(\"\\*\"; \"\")\n  ] | from_entries)\n)"
    ],
    "data": [
      {
        "input": {
          "cards": [
            {
              "id": "1234",
              "closed": false,
              "desc": "*Important Notes* ",
              "name": "Housing - Lawrence",
              "checklists": [
                {
                  "name": "Acct Information",
                  "checkItems": [
                    {
                      "name": "Location Address: 123 Hopscotch Way"
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": [
          {
            "trello_id": "1234",
            "desc": "*Important Notes* ",
            "name": "Housing - Lawrence",
            "location_address": "123 Hopscotch Way"
          }
        ]
      }
    ],
    "identifier": 74271654
  },
  {
    "context": [
      "Ultimately, I want to present a matrix with **dir/file1.txt**, **dir/file2.txt** as rows on the left of the matrix, and all the keys to be presented as column headings, with the corresponding values.",
      "Iterate over the top-level key-value pairs obtained by `to_entries` to get access to the key names, then once again over its content array in `.value` to get the array items.",
      "Here, I chose to replace them with the literal string `\\n` using `gsub`.",
      "jq -r '\n  to_entries[] | . as {$key} | .value[] | [$key,\n    (.Setting | .SettingA, .SettingB),\n    .Rule // .Check, .Description, .Line, .Link,\n    .Message, .Severity, .Span[], .Match\n    | strings |= gsub(\"\\n\"; \"\\\\n\")\n  ] | @csv\n'"
    ],
    "utterance": "Produce a CSV with each file as a row and columns for Filename, SettingA, SettingB, Rule or Check, Description, Line, Link, Message, Severity, Span, and Match, with newlines in values replaced by literal \\n.",
    "expressions": [
      "to_entries[] | . as {$key} | .value[] | [$key, (.Setting | .SettingA, .SettingB), .Rule // .Check, .Description, .Line, .Link, .Message, .Severity, .Span[], .Match | strings |= gsub(\"\\n\"; \"\\\\n\")] | @csv"
    ],
    "data": [
      {
        "input": {
          "dir/file1.txt": [
            {
              "Setting": {
                "SettingA": "",
                "SettingB": null
              },
              "Rule": "Rulechecker.Rule15",
              "Description": "",
              "Line": 11,
              "Link": "www.sample.com",
              "Message": "Some message",
              "Severity": "error",
              "Span": [
                1,
                3
              ],
              "Match": "[id"
            },
            {
              "Setting": {
                "SettingA": "",
                "SettingB": null
              },
              "Check": "Rulechecker.Rule16",
              "Description": "",
              "Line": 27,
              "Link": "www.sample.com",
              "Message": "Fix the rule",
              "Severity": "error",
              "Span": [
                1,
                3
              ],
              "Match": "[id"
            }
          ],
          "dir/file2.txt": [
            {
              "Setting": {
                "SettingA": "",
                "SettingB": null
              },
              "Rule": "Rulechecker.Rule17",
              "Description": "",
              "Line": 51,
              "Link": "www.example.com",
              "Message": "Fix anoher 'rule'?",
              "Severity": "error",
              "Span": [
                1,
                18
              ],
              "Match": "[source,terminal]\n----\n"
            }
          ]
        },
        "output": [
          "\"dir/file1.txt\",\"\",,\"Rulechecker.Rule15\",\"\",11,\"www.sample.com\",\"Some message\",\"error\",1,3,\"[id\"",
          "\"dir/file1.txt\",\"\",,\"Rulechecker.Rule16\",\"\",27,\"www.sample.com\",\"Fix the rule\",\"error\",1,3,\"[id\"",
          "\"dir/file2.txt\",\"\",,\"Rulechecker.Rule17\",\"\",51,\"www.example.com\",\"Fix anoher 'rule'?\",\"error\",1,18,\"[source,terminal]\\n----\\n\""
        ]
      }
    ],
    "identifier": 74268555
  },
  {
    "context": [
      "What I'm looking to output on the same line such as:\n\n**.id,.redirect.source_url,.redirect.target_url,.cursors_after**",
      "Build the string you want to output, then use the `-r` command-line to emit that string as-is (instead of as a JSON literal).",
      "jq -r '\n   .result[] |\n   [\n      .id,\n      .redirect.source_url,\n      .redirect.target_url,\n      .cursors_after\n   ] |\n   @csv\n' json",
      "You can build a new array per entry containing your values and then use `join(\",\")` to join all values on a single line. `-r`/`--raw-output` omits the quotes around top-level strings:",
      "jq -r '.result[]\n| [.id,.redirect.source_url,.redirect.target_url,.cursors_after]\n| join(\",\")'"
    ],
    "utterance": "Output the id, redirect.source_url, and redirect.target_url for each result on the same line, along with the value of result_info.cursors.after appended to each line.",
    "expressions": [
      ".result[] | [ .id, .redirect.source_url, .redirect.target_url, .result_info.cursors.after ] | @csv",
      ".result[] | [ .id, .redirect.source_url, .redirect.target_url, .result_info.cursors.after ] | join(\",\")"
    ],
    "data": [
      {
        "input": {
          "result": [
            {
              "id": "fcf9728ed6e94078bae9ffe200bf1054",
              "redirect": {
                "source_url": "www.1234.com/acssurgerynews/article/248345/transgender-health/detransitioners-received-poor-evaluation-when",
                "include_subdomains": false,
                "target_url": "https://www.1234.com/viewarticle/962270",
                "status_code": 301,
                "preserve_query_string": false,
                "subpath_matching": false,
                "preserve_path_suffix": false
              },
              "created_on": "2022-09-07T17:12:21Z",
              "modified_on": "2022-09-07T17:12:21Z"
            },
            {
              "id": "fac3ab84691b44219c270a5dd073e374",
              "redirect": {
                "source_url": "www.1234.com/advanced-and-metastatic-breast-cancer/article/248363/breast-cancer/liquid-biopsy-metastatic-breast",
                "include_subdomains": false,
                "target_url": "https://www.1234.com/viewarticle/942277",
                "status_code": 301,
                "preserve_query_string": false,
                "subpath_matching": false,
                "preserve_path_suffix": false
              },
              "created_on": "2022-09-07T17:12:21Z",
              "modified_on": "2022-09-07T17:12:21Z"
            },
            {
              "id": "0ae189027c574eedac22f854b4676568",
              "redirect": {
                "source_url": "www.1234.com/advanced-and-metastatic-breast-cancer/article/249807/breast-cancer/evolving-her2-metastatic-breast",
                "include_subdomains": false,
                "target_url": "https://www.1234.com/viewarticle/963856",
                "status_code": 301,
                "preserve_query_string": false,
                "subpath_matching": false,
                "preserve_path_suffix": false
              },
              "created_on": "2022-09-07T17:12:21Z",
              "modified_on": "2022-09-07T17:12:21Z"
            }
          ],
          "success": true,
          "errors": [],
          "messages": [],
          "result_info": {
            "cursors": {
              "after": "equIy9ku2FDvBVLy0avqNewCdepOQiaIaSilEIhBNwhHDIkcF5EjJkYqPwqeewvR5Rb6UO4LB5moBKoO9puoiyJ9QY_bidbcFtbpp60QzYEl_9Hls0jD_2oINTM_CWJPCBTvzmVu7LlUCNTB_UxXE-Ox6h8vuhE"
            }
          }
        },
        "output": [
          "\"fcf9728ed6e94078bae9ffe200bf1054\",\"www.1234.com/acssurgerynews/article/248345/transgender-health/detransitioners-received-poor-evaluation-when\",\"https://www.1234.com/viewarticle/962270\",\"equIy9ku2FDvBVLy0avqNewCdepOQiaIaSilEIhBNwhHDIkcF5EjJkYqPwqeewvR5Rb6UO4LB5moBKoO9puoiyJ9QY_bidbcFtbpp60QzYEl_9Hls0jD_2oINTM_CWJPCBTvzmVu7LlUCNTB_UxXE-Ox6h8vuhE\"",
          "\"fac3ab84691b44219c270a5dd073e374\",\"www.1234.com/advanced-and-metastatic-breast-cancer/article/248363/breast-cancer/liquid-biopsy-metastatic-breast\",\"https://www.1234.com/viewarticle/942277\",\"equIy9ku2FDvBVLy0avqNewCdepOQiaIaSilEIhBNwhHDIkcF5EjJkYqPwqeewvR5Rb6UO4LB5moBKoO9puoiyJ9QY_bidbcFtbpp60QzYEl_9Hls0jD_2oINTM_CWJPCBTvzmVu7LlUCNTB_UxXE-Ox6h8vuhE\"",
          "\"0ae189027c574eedac22f854b4676568\",\"www.1234.com/advanced-and-metastatic-breast-cancer/article/249807/breast-cancer/evolving-her2-metastatic-breast\",\"https://www.1234.com/viewarticle/963856\",\"equIy9ku2FDvBVLy0avqNewCdepOQiaIaSilEIhBNwhHDIkcF5EjJkYqPwqeewvR5Rb6UO4LB5moBKoO9puoiyJ9QY_bidbcFtbpp60QzYEl_9Hls0jD_2oINTM_CWJPCBTvzmVu7LlUCNTB_UxXE-Ox6h8vuhE\""
        ]
      }
    ],
    "identifier": 74265651
  },
  {
    "context": [
      "ipAddresses=$(curl -s -X GET \"$hostUrl\" -u :\"$EncodedPAT\" | jq -r \".value[] | select(.status==\\\"offline\\\").name\")",
      "ids=$(curl -s -X GET \"$hostUrl\" -u :\"$EncodedPAT\" | jq -r \".value[] | select(.status==\\\"offline\\\").id\")",
      "expected output\n```\nipAddress: ip-172-20-94-68 id: 344\nipAddress: ip-172-20-95-119 id: 345\nipAddress: ip-172-20-95-113 id: 346\nipAddress: ip-172-20-94-96 id: 348\nipAddress: ip-172-20-94-86 id: 350\n```",
      ".value[] | select(.status == \"offline\") | \"ipAddress: \\(.name) id: \\(.id)\"",
      "Gives:\n```none\n\"ipAddress: ip-172-20-94-68 id: 344\"\n\"ipAddress: ip-172-20-95-119 id: 345\"\n```"
    ],
    "utterance": "For each object with status equal to offline, output the name and id fields in the format 'ipAddress: <name> id: <id>'.",
    "expressions": [
      ".value[] | select(.status == \"offline\") | \"ipAddress: \\(.name) id: \\(.id)\""
    ],
    "data": [
      {
        "input": {
          "count": 2,
          "value": [
            {
              "id": 344,
              "name": "ip-172-20-94-68",
              "status": "offline"
            },
            {
              "id": 345,
              "name": "ip-172-20-95-119",
              "status": "offline"
            }
          ]
        },
        "output": [
          "ipAddress: ip-172-20-94-68 id: 344",
          "ipAddress: ip-172-20-95-119 id: 345"
        ]
      }
    ],
    "identifier": 74302423
  },
  {
    "context": [
      "I am trying to convert this to a standard CSV file with the appropriate headers via jq, but having difficulties in doing so.",
      "There are also instances in which one of my JSON objects may not include the same number of values, so I need my output file to account for this and simply enter a null value between the commas to keep a consistent number of columns",
      "Assuming the keys are consistently ordered within the objects:",
      "jq -r '((first | keys_unsorted), (.[] | to_entries | map(.value))) | @csv' file.json",
      "\"endpoint\",\"date\",\"upUsage\",\"downUsage\",\"upAvgRate\",\"downAvgRate\",\"upMaxRate\",\"downMaxRate\"",
      "\"APPLE\",\"2022-11-02 12:00\",0,18000,0,600,0,800",
      "\"BANANA\",\"2022-11-02 12:00\",0,17600,0,587,0,693",
      "\"CARROT\",\"2022-11-02 12:00\",0,8000,0,533,0,533"
    ],
    "utterance": "Convert an array of objects to CSV with headers, ensuring each row contains the same columns in the same order and filling in nulls for missing values.",
    "expressions": [
      "((first | keys_unsorted), (.[] | to_entries | map(.value))) | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "endpoint": "APPLE",
            "date": "2022-11-02 12:00",
            "upUsage": 0,
            "downUsage": 18000,
            "upAvgRate": 0,
            "downAvgRate": 600,
            "upMaxRate": 0,
            "downMaxRate": 800
          },
          {
            "endpoint": "BANANA",
            "date": "2022-11-02 12:00",
            "upUsage": 0,
            "downUsage": 17600,
            "upAvgRate": 0,
            "downAvgRate": 587,
            "upMaxRate": 0,
            "downMaxRate": 693
          },
          {
            "endpoint": "CARROT",
            "date": "2022-11-02 12:00",
            "upUsage": 0,
            "downUsage": 8000,
            "upAvgRate": 0,
            "downAvgRate": 533,
            "upMaxRate": 0,
            "downMaxRate": 533
          }
        ],
        "output": [
          "\"endpoint\",\"date\",\"upUsage\",\"downUsage\",\"upAvgRate\",\"downAvgRate\",\"upMaxRate\",\"downMaxRate\"",
          "\"APPLE\",\"2022-11-02 12:00\",0,18000,0,600,0,800",
          "\"BANANA\",\"2022-11-02 12:00\",0,17600,0,587,0,693",
          "\"CARROT\",\"2022-11-02 12:00\",0,8000,0,533,0,533"
        ]
      }
    ],
    "identifier": 74292573
  },
  {
    "context": [
      "I want to replace the value of each key, with the name of key prefixed with $",
      "Is there a way to do it recursively?",
      "You\u2019re looking for something like this:\n```\n.parent |=\n  reduce paths(strings) as $p (.;\n    setpath($p; \"$\" + ($p | join(\"_\")))\n  )\n```",
      "This is the result using the recomended jq expression:\n\n`. |= reduce paths(strings) as $p (.; setpath($p; \"$\" + ($p | join(\"_\"))))`"
    ],
    "utterance": "Replace every string value in a nested structure with its full key path, joined by underscores and prefixed by $",
    "expressions": [
      ". |= reduce paths(strings) as $p (.; setpath($p; \"$\" + ($p | join(\"_\"))))",
      ".parent |= reduce paths(strings) as $p (.; setpath($p; \"$\" + ($p | join(\"_\"))))"
    ],
    "data": [
      {
        "input": {
          "parent": {
            "name": "value",
            "child": {
              "child_value1": "value",
              "child_value2": "value",
              "child_value3": [
                "value1",
                "value2"
              ],
              "child_value4": {
                "child_child_value1": "value"
              }
            }
          }
        },
        "output": {
          "parent": {
            "name": "$parent_name",
            "child": {
              "child_value1": "$parent_child_child_value1",
              "child_value2": "$parent_child_child_value2",
              "child_value3": [
                "$parent_child_child_value3_0",
                "$parent_child_child_value3_1"
              ],
              "child_value4": {
                "child_child_value1": "$parent_child_child_value4_child_child_value1"
              }
            }
          }
        }
      },
      {
        "input": {
          "apis": {
            "order": {
              "base_url": "$mapping_base_url"
            },
            "payment": {
              "base_url": "$admin_base_url"
            }
          },
          "features": {
            "authentication": {
              "authProviders": true,
              "registration": false
            }
          },
          "availableLocales": [
            "en",
            "es"
          ]
        },
        "output": {
          "apis": {
            "order": {
              "base_url": "$apis_order_base_url"
            },
            "payment": {
              "base_url": "$apis_payment_base_url"
            }
          },
          "features": {
            "authentication": {
              "authProviders": true,
              "registration": false
            }
          },
          "availableLocales": [
            "$availableLocales_0",
            "$availableLocales_1"
          ]
        }
      }
    ],
    "identifier": 74298936
  },
  {
    "context": [
      "The problem is that your `sed` substitutions are terribly imprecise. Anyway, you want to do it in `jq` instead, where you have more control over which parts you are substituting, and avoid spawning a separate process for something `jq` quite easily does natively in the first place.",
      "curl -s url |\njq -r '.property.source | to_entries[] |\n  \"\\(.key)=\\\"\\(.value)\\\"\"' > .env.test"
    ],
    "utterance": "Convert each key-value pair from the object at .property.source to lines in the format KEY=\"VALUE\".",
    "expressions": [
      ".property.source | to_entries[] | \"\u001b[34m\\(.key)=\\\"\\(.value)\\\"\\u001b[39m\""
    ],
    "identifier": 74308159
  },
  {
    "identifier": 74322530
  },
  {
    "context": [
      "\"how I can calculate **\\\"summary\\\"** values and put it to json?\"",
      "\"- \\\"success\\\" - tests with status true;\"",
      "\"- \\\"failed\\\" - tests with status false;\"",
      "\"- \\\"rating\\\" - success / total, and it can be float or int\"",
      "\"- \\\"duration\\\" - sum of \\\"duration\\\" field\"",
      "This adds (or replaces) a `.summary` field which is calculated by `reduce`ing the `.tests` array to an object, initialized as `{success: 0, failed: 0}`. For each array item, either `.success` or `.failed` is incremented, depending on the current array item's boolean `.state` field. The `.rating` field is incremented unconditionally, thus counting the total number of items which is later used to calculate the true rating. As for the duration, the array item's `.duration` field is converted into a number by chopping off the `ms` suffix, and added to the summary's (numeric) `.duration` field. After the reduction, the rating is corrected by dividing the the success count by it (and multiplied by `100` for convenience). The `? // 0` part catches division by zero issues, in case the `.tests` array was empty. Finally, the `.duration` field is re-equipped with the `ms` suffix.",
      "~~sh\n.summary = (reduce .tests[] as $t ({success: 0, failed: 0};\n  (if $t.status then .success else .failed end, .rating) += 1\n  | .duration += ($t.duration | rtrimstr(\"ms\") | tonumber)\n) | .rating = (100 * (.success / .rating)? // 0) | .duration |= \"\\(.//0)ms\")"
    ],
    "utterance": "Calculate the number of tests with status true as 'success', those with status false as 'failed', compute the percentage of 'success' over total as 'rating', and sum the numeric values of the 'duration' fields (appending 'ms'), then put these in a 'summary' object.",
    "expressions": [
      ".summary = (reduce .tests[] as $t ({success: 0, failed: 0};\n  (if $t.status then .success else .failed end, .rating) += 1\n  | .duration += ($t.duration | rtrimstr(\"ms\") | tonumber)\n) | .rating = (100 * (.success / .rating)? // 0) | .duration |= \"\\(.//0)ms\")"
    ],
    "data": [
      {
        "input": {
          "testname": "Behave test",
          "tests": [
            {
              "name": "some text",
              "status": true,
              "duration": "7ms"
            },
            {
              "name": "some text",
              "status": false,
              "duration": "27ms"
            }
          ],
          "summary": {
            "success": 1,
            "failed": 1,
            "rating": 50,
            "duration": "34ms"
          }
        },
        "output": {
          "testname": "Behave test",
          "tests": [
            {
              "name": "some text",
              "status": true,
              "duration": "7ms"
            },
            {
              "name": "some text",
              "status": false,
              "duration": "27ms"
            }
          ],
          "summary": {
            "success": 1,
            "failed": 1,
            "rating": 50,
            "duration": "34ms"
          }
        }
      }
    ],
    "identifier": 74301375
  },
  {
    "context": [
      "The jq function accepts a boolean that tells the function whether or not to reverse the array.",
      "def reverseIfTrue($reverse):\n  if $reverse then reverse else . end;\nreverseIfTrue(true)",
      "[\"a\",\"b\"]",
      "The issue is that the name of the parameter is colliding with the name of the filter, essentially creating a local that obscures the global. Naming the parameter anything else will fix it:",
      "def reverseIfTrue($rev):\n  if $rev then\n    reverse\n  else\n    .\n  end\n;"
    ],
    "utterance": "Apply a function to an array that reverses it only if a given boolean parameter is true.",
    "expressions": [
      "def reverseIfTrue($rev): if $rev then reverse else . end; reverseIfTrue(true)",
      "def reverseIfTrue($rev): if $rev then reverse else . end; reverseIfTrue(false)"
    ],
    "data": [
      {
        "input": [
          "a",
          "b"
        ],
        "output": [
          "b",
          "a"
        ]
      },
      {
        "input": [
          "a",
          "b"
        ],
        "output": [
          "a",
          "b"
        ]
      }
    ],
    "identifier": 74313225
  },
  {
    "context": [
      "I need to iterate through this list of 20k hosts, replace every computer_name with a dummy value:",
      "The dummy values I want to generate automatically such as: for each computer_name replace value with Dummy?????? where ????? is a number from 00000 to 99999 and it just iterates through this.",
      "the following should be sufficient for you to figure out that detail, since the result contains the information necessary to create the table:",
      "  def lpad($len; $fill): tostring | ($len - length) as $l | ($fill * $l)[:$l] + .;",
      ". as $in\n  | ([length|tostring|length, 5]|max) as $width\n  | [range(0; length) as $i\n     | $in[$i] \n     | . + {computer_name: (\"Dummy\" + ($i | lpad($width;\"0\"))), \n            original_name: .computer_name}]",
      "jq '. as $in | ([length|tostring|length, 5]|max) as $width | [range(0; length) as $i | $in[$i] | . + {computer_name: (\"Dummy\" + ($i | lpad($width;\"0\"))), original_name: .computer_name}]' file.json",
      "map(del(.original_name))",
      "jq -r '.[] | [.clear_name, .computer_name] | @tsv' master.json"
    ],
    "utterance": "Replace each computer_name value in an array of host objects with an auto-generated unique string DummyNNNNN, where NNNNN is a zero-padded sequence number; also produce a mapping of originals to dummies.",
    "expressions": [
      "def lpad($len; $fill): tostring | ($len - length) as $l | ($fill * $l)[:$l] + .; . as $in | ([length|tostring|length, 5]|max) as $width | [range(0; length) as $i | $in[$i] | . + {computer_name: (\"Dummy\" + ($i | lpad($width;\"0\"))), original_name: .computer_name}]",
      "map(del(.original_name))",
      ". as $in | ([length|tostring|length, 5]|max) as $width | [range(0; length) as $i | $in[$i] | . + {computer_name: (\"Dummy\" + ($i | lpad($width;\"0\"))), original_name: .computer_name}]",
      "jq -r '.[] | [.clear_name, .computer_name] | @tsv' master.json"
    ],
    "data": [
      {
        "input": [
          {
            "id": 1,
            "uptime": 0,
            "computer_name": "Computer01"
          },
          {
            "id": 2,
            "uptime": 0,
            "computer_name": "Computer02"
          }
        ],
        "output": [
          {
            "id": 1,
            "uptime": 0,
            "computer_name": "Dummy00000",
            "original_name": "Computer01"
          },
          {
            "id": 2,
            "uptime": 0,
            "computer_name": "Dummy00001",
            "original_name": "Computer02"
          }
        ]
      }
    ],
    "identifier": 74270304
  },
  {
    "context": [
      "I have a large JSON file (2.7gb) that I would like filter for only the data I&#39;m interested in to make the file smaller. The data consists of an array of objects.",
      "The following query works on a small subset of the JSON file, but when I try to run it on the 2.7gb file it doesn&#39;t work. How can I convert this into a stream query so that it can process the entire file?",
      "```\r\n.[] | {\r\n    food: .foodClass,\r\n    description: .description,\r\n    foodNutrients: [.foodNutrients[] | { nutrients: .nutrient, amount: .amount}],\r\n    upc: .gtinUpc,\r\n    servingSize: .servingSize,\r\n    servingSizeUnit: .servingSizeUnit,\r\n    ingredients: .ingredients,\r\n    fdcId: .fdcId,\r\n    dataType: .dataType,\r\n    brandOwner: .brandOwner,\r\n    marketCountry: .marketCountry,\r\n    brandedFootCategory: .brandedFoodCategory\r\n}\r\n```"
    ],
    "utterance": "Extract specific fields from each object in a large array, restructuring nested fields, using a streaming query to handle large file size.",
    "expressions": [
      "jq -c '.[] | { food: .foodClass, description: .description, foodNutrients: [ .foodNutrients[] | { nutrients: .nutrient, amount: .amount } ], upc: .gtinUpc, servingSize: .servingSize, servingSizeUnit: .servingSizeUnit, ingredients: .ingredients, fdcId: .fdcId, dataType: .dataType, brandOwner: .brandOwner, marketCountry: .marketCountry, brandedFoodCategory: .brandedFoodCategory }' largefile.json"
    ],
    "identifier": 74342977
  },
  {
    "context": [
      "Now, imagine that the filter is long, so I would like to break it into separate lines for readability while still producing the same output, conceptually like this:\r\n```\r\njq '&quot;\r\n\\(.foo)|\r\n\\(.boo)\r\n&quot;'\r\n```\r\n\r\nThis however is not valid. How to do this?",
      "Outside of strings, your jq filter may have line breaks as you see fit. As for the strings, you can piece the single parts together using `+`:\r\n~~~sh\r\necho '{\"foo\":\"bar\",\"boo\":\"moo\"}' | jq -r '\r\n  \"\\(.foo)|\" +\r\n  \"\\(.boo)\"\r\n'\r\n~~~",
      "You might also wish to consider programmatic approaches, e.g.\r\n```\r\n  map_values( \"\\(.)\" )\r\n  | join(\"|\")\r\n```"
    ],
    "utterance": "Break a long filter into multiple lines for readability while still concatenating interpolated values with '|' between them.",
    "expressions": [
      "\"\\(.foo)|\" +\n  \"\\(.boo)\"",
      "map_values(\"\\(.)\") | join(\"|\")"
    ],
    "data": [
      {
        "input": {
          "foo": "bar",
          "boo": "moo"
        },
        "output": "bar|moo"
      }
    ],
    "identifier": 74349759
  },
  {
    "context": [
      "if `adminLock = 1` Take the median \"domains\", how do I write",
      "Want to get such a result\n\n    now_array=([\"173652434\"]=\"xxx2.com\" [\"173205812\"]=\"xxx4.com\")\nHow should I do thank you",
      "You can select all `domains` where `adminLock == 1` of the inner array with this code:",
      "jq -r '.data.data[] | select(.adminLock == 1) | .domains' \"$INPUT\"",
      "Output\nxxx2.com\nxxx4.com"
    ],
    "utterance": "Extract all objects with adminLock equal to 1 and create an array mapping each domainsID to its corresponding domains value.",
    "expressions": [
      ".data.data[] | select(.adminLock == 1) | {(.domainsID): .domains}",
      "[.data.data[] | select(.adminLock == 1) | {(.domainsID): .domains}] | add"
    ],
    "data": [
      {
        "input": {
          "code": 0,
          "message": "\u6210\u529f",
          "data": {
            "recordCount": "128",
            "pageSize": 100,
            "page": 1,
            "pageCount": 2,
            "data": [
              {
                "domainsID": "173652434",
                "nsGroupID": "199",
                "groupID": "78987",
                "domains": "xxx1.com",
                "state": 3,
                "userLock": 0,
                "adminLock": 0,
                "view_type": "1"
              },
              {
                "domainsID": "173652434",
                "nsGroupID": "199",
                "groupID": "78987",
                "domains": "xxx2.com",
                "state": 3,
                "userLock": 0,
                "adminLock": 1,
                "view_type": "1"
              },
              {
                "domainsID": "173205836",
                "nsGroupID": "199",
                "groupID": "78987",
                "domains": "xxx3.com",
                "state": 3,
                "userLock": 0,
                "adminLock": 0,
                "view_type": "1"
              },
              {
                "domainsID": "173205812",
                "nsGroupID": "199",
                "groupID": "78987",
                "domains": "xxx4.com",
                "state": 3,
                "userLock": 0,
                "adminLock": 1,
                "view_type": "1"
              }
            ],
            "nextPage": 2
          }
        },
        "output": {
          "173652434": "xxx2.com",
          "173205812": "xxx4.com"
        }
      }
    ],
    "identifier": 74343931
  },
  {
    "context": [
      "I am trying to add a new user in below json which matches group NP01-RW.",
      "not able to select users under NP01-RW and return updated json.",
      "You need to make sure that the stream selects the correct values, which you can then assign:",
      "(.policyItems[] | select(.groups[] | IN(\"NP01-RO\")).users) += [$username]"
    ],
    "utterance": "Add a new user to the users array of each policyItem where groups contains NP01-RW and return the updated object.",
    "expressions": [
      "(.policyItems[] | select(.groups[] | IN(\"NP01-RW\")).users) += [$username]"
    ],
    "data": [
      {
        "input": {
          "id": 181,
          "guid": "c9b7dbde-63de-42cc-9840-1b4a06e13364",
          "isEnabled": true,
          "version": 17,
          "service": "Np-Hue",
          "name": "DATASCIENCE-CUROPT-RO",
          "policyType": 0,
          "policyPriority": 0,
          "isAuditEnabled": true,
          "resources": {
            "database": {
              "values": [
                "hive_cur_acct_1dev",
                "hive_cur_acct_1eng",
                "hive_cur_acct_1rwy",
                "hive_cur_acct_1stg",
                "hive_opt_acct_1dev",
                "hive_opt_acct_1eng",
                "hive_opt_acct_1stg",
                "hive_opt_acct_1rwy"
              ],
              "isExcludes": false,
              "isRecursive": false
            },
            "column": {
              "values": [
                "*"
              ],
              "isExcludes": false,
              "isRecursive": false
            },
            "table": {
              "values": [
                "*"
              ],
              "isExcludes": false,
              "isRecursive": false
            }
          },
          "policyItems": [
            {
              "accesses": [
                {
                  "type": "select",
                  "isAllowed": true
                },
                {
                  "type": "update",
                  "isAllowed": true
                },
                {
                  "type": "create",
                  "isAllowed": true
                },
                {
                  "type": "drop",
                  "isAllowed": true
                },
                {
                  "type": "alter",
                  "isAllowed": true
                },
                {
                  "type": "index",
                  "isAllowed": true
                },
                {
                  "type": "lock",
                  "isAllowed": true
                },
                {
                  "type": "all",
                  "isAllowed": true
                },
                {
                  "type": "read",
                  "isAllowed": true
                },
                {
                  "type": "write",
                  "isAllowed": true
                }
              ],
              "users": [
                "user1",
                "user2",
                "user3"
              ],
              "groups": [
                "NP01-RW"
              ],
              "conditions": [],
              "delegateAdmin": false
            },
            {
              "accesses": [
                {
                  "type": "select",
                  "isAllowed": true
                }
              ],
              "users": [
                "user1"
              ],
              "groups": [
                "NP01-RO"
              ],
              "conditions": [],
              "delegateAdmin": false
            }
          ],
          "denyPolicyItems": [],
          "allowExceptions": [],
          "denyExceptions": [],
          "dataMaskPolicyItems": [],
          "rowFilterPolicyItems": [],
          "options": {},
          "validitySchedules": [],
          "policyLabels": [
            "DATASCIENCE-CurOpt-RO_NP01"
          ]
        },
        "output": {
          "id": 181,
          "guid": "c9b7dbde-63de-42cc-9840-1b4a06e13364",
          "isEnabled": true,
          "version": 17,
          "service": "Np-Hue",
          "name": "DATASCIENCE-CUROPT-RO",
          "policyType": 0,
          "policyPriority": 0,
          "isAuditEnabled": true,
          "resources": {
            "database": {
              "values": [
                "hive_cur_acct_1dev",
                "hive_cur_acct_1eng",
                "hive_cur_acct_1rwy",
                "hive_cur_acct_1stg",
                "hive_opt_acct_1dev",
                "hive_opt_acct_1eng",
                "hive_opt_acct_1stg",
                "hive_opt_acct_1rwy"
              ],
              "isExcludes": false,
              "isRecursive": false
            },
            "column": {
              "values": [
                "*"
              ],
              "isExcludes": false,
              "isRecursive": false
            },
            "table": {
              "values": [
                "*"
              ],
              "isExcludes": false,
              "isRecursive": false
            }
          },
          "policyItems": [
            {
              "accesses": [
                {
                  "type": "select",
                  "isAllowed": true
                },
                {
                  "type": "update",
                  "isAllowed": true
                },
                {
                  "type": "create",
                  "isAllowed": true
                },
                {
                  "type": "drop",
                  "isAllowed": true
                },
                {
                  "type": "alter",
                  "isAllowed": true
                },
                {
                  "type": "index",
                  "isAllowed": true
                },
                {
                  "type": "lock",
                  "isAllowed": true
                },
                {
                  "type": "all",
                  "isAllowed": true
                },
                {
                  "type": "read",
                  "isAllowed": true
                },
                {
                  "type": "write",
                  "isAllowed": true
                }
              ],
              "users": [
                "user1",
                "user2",
                "user3",
                "$username"
              ],
              "groups": [
                "NP01-RW"
              ],
              "conditions": [],
              "delegateAdmin": false
            },
            {
              "accesses": [
                {
                  "type": "select",
                  "isAllowed": true
                }
              ],
              "users": [
                "user1"
              ],
              "groups": [
                "NP01-RO"
              ],
              "conditions": [],
              "delegateAdmin": false
            }
          ],
          "denyPolicyItems": [],
          "allowExceptions": [],
          "denyExceptions": [],
          "dataMaskPolicyItems": [],
          "rowFilterPolicyItems": [],
          "options": {},
          "validitySchedules": [],
          "policyLabels": [
            "DATASCIENCE-CurOpt-RO_NP01"
          ]
        }
      }
    ],
    "identifier": 74309393
  },
  {
    "context": [
      "have a very large JSON data like below",
      "Can I use JQ to make the conversion like below?",
      "Expected result",
      "[jq](https://stedolan.github.io/jq/) let&#39;s you do the conversion to CSV easily. The following code produces the desired output:",
      "jq -r 'to_entries\n       | map([.key, \n              .value.asset_id, .value.referencekey, .value.hostname, .value.fqdn,\n              .value.network_zone[0], .value.network_zone[1],\n              .value.service.name, .value.service.account, .value.service.billing,\n              .value.aws.tags.Name, .value.aws.tags.Service, .value.aws.tags.Usecase, .value.aws.tags.billing, .value.aws.tags.OsVersion,\n              .value.aws.instance_type, .value.aws.ami_imageid, .value.aws.state])\n       | [\"_key\",\"asset_id\",\"referencekey\",\"hostname\",\"fqdn\",\"network_zone/0\",\"network_zone/1\",\"service/name\",\"service/account\",\"service/billing\",\"aws/tags/Name\",\"aws/tags/Service\",\"aws/tags/Usecase\",\"aws/tags/billing\",\"aws/tags/OsVersion\",\"aws/instance_type\",\"aws/ami_imageid\",\"aws/state\"]\n         , .[]\n       | @csv' \"$INPUT\"",
      "- If some nodes in the input JSON are missing, the code does not break but fills in empty values in the CSV file.",
      "- If more than two network zones are given, only the first two are covered in the CSV file"
    ],
    "utterance": "Convert each top-level key and selected nested values into a single CSV row with specific headers, handling up to two network zones and providing empty values for missing fields.",
    "expressions": [
      "to_entries\n| map([.key, \n        .value.asset_id, .value.referencekey, .value.hostname, .value.fqdn,\n        .value.network_zone[0], .value.network_zone[1],\n        .value.service.name, .value.service.account, .value.service.billing,\n        .value.aws.tags.Name, .value.aws.tags.Service, .value.aws.tags.Usecase, .value.aws.tags.billing, .value.aws.tags.OsVersion,\n        .value.aws.instance_type, .value.aws.ami_imageid, .value.aws.state])\n| [\"_key\",\"asset_id\",\"referencekey\",\"hostname\",\"fqdn\",\"network_zone/0\",\"network_zone/1\",\"service/name\",\"service/account\",\"service/billing\",\"aws/tags/Name\",\"aws/tags/Service\",\"aws/tags/Usecase\",\"aws/tags/billing\",\"aws/tags/OsVersion\",\"aws/instance_type\",\"aws/ami_imageid\",\"aws/state\"]\n  , .[]\n| @csv"
    ],
    "data": [
      {
        "input": {
          "10.10.10.1": {
            "asset_id": 1,
            "referencekey": "ASSET-00001",
            "hostname": "testDev01",
            "fqdn": "ip-10-10.10.1.ap-northeast-2.compute.internal",
            "network_zone": [
              "DEV",
              "Dev"
            ],
            "service": {
              "name": "TEST_SVC",
              "account": "AWS_TEST",
              "billing": "Testpay"
            },
            "aws": {
              "tags": {
                "Name": "testDev01",
                "Service": "TEST_SVC",
                "Usecase": "Dev",
                "billing": "Testpay",
                "OsVersion": "20.04"
              },
              "instance_type": "t3.micro",
              "ami_imageid": "ami-e000001",
              "state": "running"
            }
          },
          "10.10.10.2": {
            "asset_id": 3,
            "referencekey": "ASSET-47728",
            "hostname": "Infra_Live01",
            "fqdn": "ip-10-10-10-2.ap-northeast-2.compute.internal",
            "network_zone": [
              "PROD",
              "Live"
            ],
            "service": {
              "name": "Infra",
              "account": "AWS_TEST",
              "billing": "infra"
            },
            "aws": {
              "tags": {
                "Name": "Infra_Live01",
                "Service": "Infra",
                "Usecase": "Live",
                "billing": "infra",
                "OsVersion": "16.04"
              },
              "instance_type": "r5.large",
              "ami_imageid": "ami-e592398b",
              "state": "running"
            }
          }
        },
        "output": "_key,asset_id,referencekey,hostname,fqdn,network_zone/0,network_zone/1,service/name,service/account,service/billing,aws/tags/Name,aws/tags/Service,aws/tags/Usecase,aws/tags/billing,aws/tags/OsVersion,aws/instance_type,aws/ami_imageid,aws/state\n10.10.10.1,1,ASSET-00001,testDev01,ip-10-10.10.1.ap-northeast-2.compute.internal,DEV,Dev,TEST_SVC,AWS_TEST,Testpay,testDev01,TEST_SVC,Dev,Testpay,20.04,t3.micro,ami-e000001,running\n10.10.10.2,3,ASSET-47728,Infra_Live01,ip-10-10-10-2.ap-northeast-2.compute.internal,PROD,Live,Infra,AWS_TEST,infra,Infra_Live01,Infra,Live,infra,16.04,r5.large,ami-e592398b,running"
      }
    ],
    "identifier": 74324886
  },
  {
    "context": [
      "How can I sum values from json object with jq",
      "`.| select(.orderNumber==2346999 and .workStep==110) | .good`",
      "**and I liketo have**\n16",
      "A simple approach using `add` to get the `sum` of the numbers.",
      "map(select(.orderNumber==2346999 and .workStep==110).good) | add",
      "Gives: `16`"
    ],
    "utterance": "Sum the values of the 'good' key where orderNumber is 2346999 and workStep is 110",
    "expressions": [
      "map(select(.orderNumber==2346999 and .workStep==110).good) | add"
    ],
    "data": [
      {
        "input": [
          {
            "orderNumber": 2346999,
            "workStep": 110,
            "good": 8,
            "bad": 0,
            "type": "1",
            "date": "2022-11-08T07:17:09",
            "time": 0,
            "result": 1
          },
          {
            "orderNumber": 2346999,
            "workStep": 110,
            "good": 8,
            "bad": 0,
            "type": "1",
            "date": "2022-11-08T07:26:57",
            "time": 0,
            "result": 1
          }
        ],
        "output": 16
      }
    ],
    "identifier": 74357065
  },
  {
    "context": [
      "And I trying to get the value from `a.b` and this json path is from string.",
      "$ echo '{\"a\": {\"b\": \"aaa\", \"c\": \"\"}, \"d\": \"bbb\"}'  | jq '\"a.b\" as $key | .[$key]'",
      "You can split the path string by the dots to get a path array, which you can use with `getpath`:",
      "jq -r '\"a.b\" as $key | getpath($key / \".\")'",
      "aaa"
    ],
    "utterance": "Retrieve the value at path a.b where the path is provided as the string \"a.b\".",
    "expressions": [
      "\"a.b\" as $key | getpath($key / \".\")"
    ],
    "data": [
      {
        "input": {
          "a": {
            "b": "aaa",
            "c": ""
          },
          "d": "bbb"
        },
        "output": "aaa"
      }
    ],
    "identifier": 74359009
  },
  {
    "context": [
      "\"I want to take the value xxx1.com, the group value of the group into an array, how should I do want to get such a result\"",
      "\"now_array=([\\\"173652434\\\"]=\\\"xxx2.com\\\" [\\\"173205812\\\"]=\\\"xxx4.com\\\")\"",
      "\"here's how to use jq to filter that JSON according to a field value, then format it to create an associative array in Bash:\"",
      "\"jq -r '\\n    .data.data[] | select(.adminLock == 1) | @sh \"[\\(.domainsID)]=\\(.domains)\"\\n  ' input.json\""
    ],
    "utterance": "Extract pairs where adminLock is 1, mapping domainsID to domains, formatted for a Bash associative array.",
    "expressions": [
      ".data.data[] | select(.adminLock == 1) | @sh \"[\\(.domainsID)]=\\(.domains)\""
    ],
    "data": [
      {
        "input": {
          "code": 0,
          "message": "\u6210\u529f",
          "data": {
            "recordCount": "128",
            "pageSize": 100,
            "page": 1,
            "pageCount": 2,
            "data": [
              {
                "domainsID": "173652434",
                "nsGroupID": "199",
                "groupID": "78987",
                "domains": "xxx1.com",
                "state": 3,
                "userLock": 0,
                "adminLock": 0,
                "view_type": "1"
              },
              {
                "domainsID": "173652434",
                "nsGroupID": "199",
                "groupID": "78987",
                "domains": "xxx2.com",
                "state": 3,
                "userLock": 0,
                "adminLock": 1,
                "view_type": "1"
              },
              {
                "domainsID": "173205836",
                "nsGroupID": "199",
                "groupID": "78987",
                "domains": "xxx3.com",
                "state": 3,
                "userLock": 0,
                "adminLock": 0,
                "view_type": "1"
              },
              {
                "domainsID": "173205812",
                "nsGroupID": "199",
                "groupID": "78987",
                "domains": "xxx4.com",
                "state": 3,
                "userLock": 0,
                "adminLock": 1,
                "view_type": "1"
              }
            ],
            "nextPage": 2
          }
        },
        "output": [
          "[173652434]=xxx2.com",
          "[173205812]=xxx4.com"
        ]
      }
    ],
    "identifier": 74354631
  },
  {
    "context": [
      "I need an output similar to\n\n```yaml \n- docker-compose_grafana_1\n- docker-compose_node-red_1\n- docker-compose_organizr_1\n- docker-compose_prometheus_1\n```",
      "I can do that with jq easy-peasy: \n```shell\njq --raw-output '.docker_compose_init_result.services[] | keys | .[]' jsondata.json\n```",
      "In a pure JMESPath way, you query should be:\n\n```none\ndocker_compose_init_result.services.*.keys(@)[]\n```"
    ],
    "utterance": "List all immediate child keys under every object in the 'services' section inside 'docker_compose_init_result'.",
    "expressions": [
      ".docker_compose_init_result.services[] | keys | .[]"
    ],
    "data": [
      {
        "input": {
          "docker_compose_init_result": {
            "changed": true,
            "failed": false,
            "services": {
              "grafana": {
                "docker-compose_grafana_1": {},
                "node-red": {
                  "docker-compose_node-red_1": {}
                },
                "organizr": {
                  "docker-compose_organizr_1": {}
                },
                "prometheus": {
                  "docker-compose_prometheus_1": {}
                }
              }
            }
          }
        },
        "output": [
          "docker-compose_grafana_1",
          "docker-compose_node-red_1",
          "docker-compose_organizr_1",
          "docker-compose_prometheus_1"
        ]
      }
    ],
    "identifier": 74339143
  },
  {
    "context": [
      "I want to get the size of all snapshots in my account older than a specific date and then add them up so that I can calculate cost.",
      "aws ec2 describe-snapshots --profile my_profile_name | jq \"[.Snapshots[].VolumeSize] | add\"",
      "[.Snapshots[] | select(.StartTime < \"2022-09-08\") | .VolumeSize] | add"
    ],
    "utterance": "Get the total size (sum of VolumeSize) of all snapshots with StartTime earlier than 2022-09-08",
    "expressions": [
      "[.Snapshots[] | select(.StartTime < \"2022-09-08\") | .VolumeSize] | add"
    ],
    "identifier": 74369542
  },
  {
    "context": [
      "I am looking to build a single file at the root level of the structure combining the objects.value array entries from all files into one file. I also have a file with an empty array I can merge them into",
      "You could use `find` to get the files, `xargs` to feed them into `jq`, and therein `reduce` to put them together:",
      "find . -name object.json | xargs jq 'reduce inputs as $in (.; \n  .parameters.objects.value += $in.parameters.objects.value\n)'",
      "find . -name object.json -exec cat {} \\; | jq 'reduce inputs as $in (.;\n  .parameters.objects.value += $in.parameters.objects.value\n)'"
    ],
    "utterance": "Combine all objects.value array entries from multiple object.json files in subdirectories into a single file, merging them into the objects.value array of a base file",
    "expressions": [
      "reduce inputs as $in (.; .parameters.objects.value += $in.parameters.objects.value)",
      "find . -name object.json | xargs jq 'reduce inputs as $in (.; .parameters.objects.value += $in.parameters.objects.value)'",
      "find . -name object.json -exec cat {} \\; | jq 'reduce inputs as $in (.; .parameters.objects.value += $in.parameters.objects.value)'"
    ],
    "data": [
      {
        "input": [
          {
            "$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentParameters.json#",
            "contentVersion": "1.0.0.0",
            "parameters": {
              "genericInformation": {
                "value": {
                  "value1": "Something",
                  "value2": "Otherthing"
                }
              },
              "objects": {
                "value": []
              }
            }
          },
          {
            "$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentParameters.json#",
            "contentVersion": "1.0.0.0",
            "parameters": {
              "genericInformation": {
                "value": {
                  "value1": "Something",
                  "value2": "Otherthing"
                }
              },
              "objects": {
                "value": [
                  {
                    "id": 1,
                    "Name": "Object1",
                    "Container": "Container1"
                  }
                ]
              }
            }
          },
          {
            "$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentParameters.json#",
            "contentVersion": "1.0.0.0",
            "parameters": {
              "genericInformation": {
                "value": {
                  "value1": "Something",
                  "value2": "Otherthing"
                }
              },
              "objects": {
                "value": [
                  {
                    "id": 2,
                    "Name": "Object2",
                    "Container": "Container2"
                  }
                ]
              }
            }
          },
          {
            "$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentParameters.json#",
            "contentVersion": "1.0.0.0",
            "parameters": {
              "genericInformation": {
                "value": {
                  "value1": "Something",
                  "value2": "Otherthing"
                }
              },
              "objects": {
                "value": [
                  {
                    "id": 3,
                    "Name": "Object3",
                    "Container": "Container3"
                  }
                ]
              }
            }
          }
        ],
        "output": {
          "$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentParameters.json#",
          "contentVersion": "1.0.0.0",
          "parameters": {
            "genericInformation": {
              "value": {
                "value1": "Something",
                "value2": "Otherthing"
              }
            },
            "objects": {
              "value": [
                {
                  "id": 1,
                  "Name": "Object1",
                  "Container": "Container1"
                },
                {
                  "id": 2,
                  "Name": "Object2",
                  "Container": "Container2"
                },
                {
                  "id": 3,
                  "Name": "Object3",
                  "Container": "Container3"
                }
              ]
            }
          }
        }
      }
    ],
    "identifier": 74307871
  },
  {
    "context": [
      "I'm trying to add a json file's name as a key to the file structure itself. For example:",
      "test.json \n{}\n",
      "Output:\n\ntest.json\n{\n    \"test\": {}\n}",
      "Using --arg and a variable initialized from outside:\n\njq --arg fn \"test\" '.[$fn] = {}' test.json",
      "Don\u2019t quote them. Things in double quotes are strings. Also make sure your command substitution surrounds the correct expression and avoid useless use of cat.",
      "output=\"$(jq --arg fn \"$file_name\" '. += {$fn: {}}' $file)\"",
      "output=\"$(jq --arg fn \"$file_name\" '.[$fn] = {}')\""
    ],
    "utterance": "Add the filename without extension as a key at the top level, whose value is an empty object.",
    "expressions": [
      "jq --arg fn \"test\" '.[$fn] = {}' test.json",
      "jq --arg fn \"$file_name\" '.[$fn] = {}'",
      "jq --arg fn \"$file_name\" '. += {$fn: {}}' $file",
      "jq '.[input_filename | rtrimstr(\".json\")] = {}' test.json"
    ],
    "data": [
      {
        "input": {},
        "output": {
          "test": {}
        }
      }
    ],
    "identifier": 74366843
  },
  {
    "context": [
      "Using [jq](https://stedolan.github.io/jq/) I want to unflatten a JSON file.",
      "**Input**\n```json\n{\n  \"b\": 1,\n  \"c\": 2,\n  \"a:e\": 3,\n  \"a:d\": 4\n}\n```",
      "**Expected output**\n```json\n{\n  \"b\": 1,\n  \"c\": 2,\n  \"a\": {\n    \"e\": 3,\n    \"d\": 4\n  }\n}\n```",
      "`keys` sorts the keys, `keys_unsorted` doesn't.",
      "However, I would rather use `to_entries`:",
      "~~~sh\nreduce to_entries[] as {$key, $value} ({}; \n  setpath($key / \":\"; $value)\n)\n~~~"
    ],
    "utterance": "Unflatten an object with colon-separated keys into nested objects while preserving insertion order.",
    "expressions": [
      ". as $obj | reduce keys_unsorted[] as $key ({}; . * setpath($key | split(\":\"); $obj[$key]))",
      "reduce to_entries[] as {$key, $value} ({}; setpath($key / \":\"; $value))"
    ],
    "data": [
      {
        "input": {
          "b": 1,
          "c": 2,
          "a:e": 3,
          "a:d": 4
        },
        "output": {
          "b": 1,
          "c": 2,
          "a": {
            "e": 3,
            "d": 4
          }
        }
      }
    ],
    "identifier": 74381447
  },
  {
    "context": [
      "I would now need to get the first level *name* (f.e. Computer) as parent and search for all children names of any depth (f.e. Icon, Pattern). Those child names should be added as array to the first level parent value. If there are no children at all (f.e. Architektur) the array should stay empty.",
      "This is what it should look like:\n\n    {\n     \"Architektur\": [],\n     \"Computer\": [\"Icon\", \"Pattern\", \"gr\u00fcn\", \"braun\"],\n     \"Fahrzeug\": [],\n     \"Kamera\": [\"Histogramm\",\"Auto\", \"Sonne\", \"Am Tag\", \"In der Nacht\"],\n     \"Sensor\": []\n    }",
      "This gives exactly the output stated (without \"Button\" in \"Computer\" section)\n\n```\njq '\ndef get_values:\n    if has(\"children\") then (.children[]? | get_values) else .name end;\nmap({name,value:[.children[]? | get_values]}) | from_entries\n' input.json\n```"
    ],
    "utterance": "For each top-level object, list its name as a key and collect all nested children names at any depth into an array as the value; if no children, the array is empty.",
    "expressions": [
      "def get_values:\n    if has(\"children\") then (.children[]? | get_values) else .name end;\nmap({name,value:[.children[]? | get_values]}) | from_entries"
    ],
    "data": [
      {
        "input": [
          {
            "name": "Architektur"
          },
          {
            "name": "Computer",
            "children": [
              {
                "name": "Icon"
              },
              {
                "name": "Pattern"
              },
              {
                "name": "Button",
                "children": [
                  {
                    "name": "gr\u00fcn"
                  },
                  {
                    "name": "braun"
                  }
                ]
              }
            ]
          },
          {
            "name": "Fahrzeug"
          },
          {
            "name": "Kamera",
            "children": [
              {
                "name": "Histogramm"
              },
              {
                "name": "Wei\u00dfableich",
                "children": [
                  {
                    "name": "Auto"
                  },
                  {
                    "name": "Sonne"
                  },
                  {
                    "name": "Bew\u00f6lkt",
                    "children": [
                      {
                        "name": "Am Tag"
                      },
                      {
                        "name": "In der Nacht"
                      }
                    ]
                  }
                ]
              },
              {
                "name": "Sensor"
              }
            ]
          }
        ],
        "output": {
          "Architektur": [],
          "Computer": [
            "Icon",
            "Pattern",
            "gr\u00fcn",
            "braun"
          ],
          "Fahrzeug": [],
          "Kamera": [
            "Histogramm",
            "Auto",
            "Sonne",
            "Am Tag",
            "In der Nacht"
          ],
          "Sensor": []
        }
      }
    ],
    "identifier": 74371182
  },
  {
    "context": [
      "I have a simple file like:\r\n\r\n```\r\nkeya=\"valuea valueb\"\r\nkeyb=\"\"\r\nkeyc=\"valuex\"\r\n```",
      "I would like to convert this file into JSON with following structure:\r\n\r\n```\r\n{\r\n    \"keya\": [\"valuea\", \"valueb\"],\r\n    \"keyb\": [],\r\n    \"keyc\": [\"valuex\"]\r\n}\r\n```",
      "jq -Rn '\r\n  [inputs | capture(\"^(?<key>[^=]+)=\\\"(?<value>.*)\\\"$\") | .value /= \" \"]\r\n  | from_entries\r\n' input.txt",
      "Output:\r\n~~~json\r\n{\r\n  \"keya\": [\r\n    \"valuea\",\r\n    \"valueb\"\r\n  ],\r\n  \"keyb\": [],\r\n  \"keyc\": [\r\n    \"valuex\"\r\n  ]\r\n}\r\n~~~"
    ],
    "utterance": "Convert a file with lines of the form key=\"value1 value2\" to an object mapping each key to an array of the values split by space, with empty values becoming empty arrays.",
    "expressions": [
      "jq -Rn '[inputs | capture(\"^(?<key>[^=]+)=\\\"(?<value>.*)\\\"$\") | .value /= \" \"] | from_entries' input.txt"
    ],
    "data": [
      {
        "input": "keya=\"valuea valueb\"\nkeyb=\"\"\nkeyc=\"valuex\"",
        "output": {
          "keya": [
            "valuea",
            "valueb"
          ],
          "keyb": [],
          "keyc": [
            "valuex"
          ]
        }
      }
    ],
    "identifier": 74383458
  },
  {
    "context": [
      "I am looking to transform a json response from an API call.",
      "Sample Input JSON:",
      "Expected JSON Output:",
      "Here's one straightforward way using `with_entries`, which lets you manipulate the `.key` and `.value` fields for each item.",
      "with_entries(\n  .value.status.items[] as $item\n  | .key += \".\\($item.id)\"\n  | .value |= {\n      name: .status.name,\n      state: .status.link.state,\n      url: \"/link/\\(.status.name)/\",\n      item: $item.id,\n      item_state: $item.state,\n      item_url: \"/link/\\(.status.name)/items/\\($item.id)/\",\n      log: $item.log\n  }\n)"
    ],
    "utterance": "Transform the input so each item under every top-level key becomes a flat key combining the section name and item id, with associated values for name, state, url, item, item_state, item_url, and log (if present), matching the structure in the Expected JSON Output.",
    "expressions": [
      "with_entries(\n  .value.status.items[] as $item\n  | .key += \".\\($item.id)\"\n  | .value |= {\n      name: .status.name,\n      state: .status.link.state,\n      url: \"/link/\\(.status.name)/\",\n      item: $item.id,\n      item_state: $item.state,\n      item_url: \"/link/\\(.status.name)/items/\\($item.id)/\",\n      log: $item.log\n  }\n)"
    ],
    "data": [
      {
        "input": {
          "realtime": {
            "status": {
              "name": "realtime",
              "link": {
                "state": "RUNNING",
                "link_id": "09-1"
              },
              "items": [
                {
                  "id": 0,
                  "state": "RUNNING",
                  "link_id": "09-1"
                },
                {
                  "id": 1,
                  "state": "STOPPED",
                  "link_id": "09-1"
                }
              ],
              "doc": "origin"
            }
          },
          "cmx": {
            "status": {
              "name": "cmx",
              "link": {
                "state": "RUNNING",
                "link_id": "09-1"
              },
              "items": [
                {
                  "id": 0,
                  "state": "FAILED",
                  "link_id": "09-1",
                  "log": "ErrorMsg"
                }
              ],
              "doc": "origin"
            }
          }
        },
        "output": {
          "realtime.0": {
            "name": "realtime",
            "state": "RUNNING",
            "url": "/link/realtime/",
            "item": 0,
            "item_state": "RUNNING",
            "item_url": "/link/realtime/items/0/",
            "log": null
          },
          "realtime.1": {
            "name": "realtime",
            "state": "RUNNING",
            "url": "/link/realtime/",
            "item": 1,
            "item_state": "STOPPED",
            "item_url": "/link/realtime/items/1/",
            "log": null
          },
          "cmx.0": {
            "name": "cmx",
            "state": "RUNNING",
            "url": "/link/cmx/",
            "item": 0,
            "item_state": "FAILED",
            "item_url": "/link/cmx/items/0/",
            "log": "ErrorMsg"
          }
        }
      }
    ],
    "identifier": 74375954
  },
  {
    "context": [
      "jq -n '1,2 | select(.)'  outputs `1 0 -1 42`",
      "It seems to me that everything that is not `false` and not `null` is considered `true`.",
      "Note that none of your examples considers the actual input for evaluation. All `select`s have a constant argument.",
      "To filter based on the input, the argument of `select` has to somehow process it (as opposed to constants which simply ignore it), e.g. `jq -n '1,2 | select(.%2 == 0)'` outputs just `2`."
    ],
    "utterance": "Filter an input stream to retain only values that are even numbers.",
    "expressions": [
      ". | select(.%2 == 0)"
    ],
    "data": [
      {
        "input": [
          1,
          2
        ],
        "output": [
          2
        ]
      }
    ],
    "identifier": 74387345
  },
  {
    "context": [
      "If CCC exists, then write out on a single line of certain values \r\n   1111, 2222, 4444 \r\nElse\r\n   Write Nothing",
      "Would like to see the values \r\n1111, 2222, 3333",
      ".environment | (map(.name) | index(\"CCC\")) as $ix | select($ix) | del(.[$ix]) | map(.value) | join(\", \")",
      ".environment | if any(.name == $wanted) then map(.value) | @csv else empty end"
    ],
    "utterance": "If an object with name equal to CCC exists in the environment array, return all the values in environment as a comma-separated line; otherwise, return nothing.",
    "expressions": [
      ".environment | if any(.name == \"CCC\") then map(.value) | @csv else empty end",
      ".environment | (map(.name) | index(\"CCC\")) as $ix | select($ix) | map(.value) | join(\", \")"
    ],
    "data": [
      {
        "input": {
          "environment": [
            {
              "name": "AAA",
              "value": "1111"
            },
            {
              "name": "BBB",
              "value": "2222"
            },
            {
              "name": "CCC",
              "value": "3333"
            },
            {
              "name": "DDD",
              "value": "4444"
            }
          ]
        },
        "output": "\"1111\",\"2222\",\"3333\",\"4444\""
      }
    ],
    "identifier": 74386325
  },
  {
    "identifier": 74395172
  },
  {
    "context": [
      "this process fails to read keys that start with numerals, like",
      "bigFolder.smallFolder.1thing",
      "jq: error: syntax error, unexpected LITERAL, expecting $end (Unix shell quoting issues?) at <top-level>, line 1:",
      "How can I make sure `jq` can properly read these path names in ?"
    ],
    "utterance": "Access the value at bigFolder.smallFolder.1thing where the final key starts with a numeral.",
    "expressions": [
      ".bigFolder.smallFolder[\"1thing\"]"
    ],
    "identifier": 74393319
  },
  {
    "context": [
      "With `jq`, how do I select only elements that contain the word \"Star\" in the following file `movies`:",
      "jq '.[] | select(.title | contains(\"Star\"))' movies"
    ],
    "utterance": "Select all objects where the title field contains the substring \"Star\".",
    "expressions": [
      ".[] | select(.title | contains(\"Star\"))"
    ],
    "data": [
      {
        "input": [
          {
            "title": "Dark Knight, The",
            "year": 2008
          },
          {
            "title": "Star Trek Beyond",
            "year": 2016
          },
          {
            "title": "Star Wars: Episode VII - The Force Awakens",
            "year": 2015
          }
        ],
        "output": [
          {
            "title": "Star Trek Beyond",
            "year": 2016
          },
          {
            "title": "Star Wars: Episode VII - The Force Awakens",
            "year": 2015
          }
        ]
      }
    ],
    "identifier": 74400075
  },
  {
    "context": [
      "I want to convert the array below to a string, keep the values to the left of the equals sign and surround each value in backticks.",
      ".values | map(\"`\\(split(\"=\") | first)`\") | join(\",\")",
      ".\"values\" | map(\"`\\(gsub(\"=\\\\w+\";\"\"))`\")| join(\",\")",
      ".values\n| map(capture( \"(?<key>^[^=]*)=\" ).key | \"`\\(.)`\" ) \n| join(\",\")"
    ],
    "utterance": "For each element in the array, extract the part before the equal sign, wrap it in backticks, and join all results with commas into a string.",
    "expressions": [
      ".values | map(\"`\\(split(\"=\") | first)`\") | join(\",\")",
      ".\"values\" | map(\"`\\(gsub(\"=\\\\w+\";\"\"))`\")| join(\",\")",
      ".values | map(capture( \"(?<key>^[^=]*)=\" ).key | \"`\\(.)`\" ) | join(\",\")"
    ],
    "data": [
      {
        "input": {
          "values": [
            "1=foo",
            "2=bar",
            "3=baz"
          ]
        },
        "output": "`1`,`2`,`3`"
      }
    ],
    "identifier": 74402306
  },
  {
    "context": [
      "Using [jq](https://stedolan.github.io/jq/), I want to convert the input `A B=1 C= D=2` to `\"A\", \"B\": \"1\", \"C\": \"\", \"D\": \"2\"`",
      "I came up with the solution\njq -Rr '. / \" \" | map(. / \"=\" | \"\\\"\\(.[0])\\\"\" + (if .[1] != null then \": \\\"\\(.[1])\\\"\" else \"\" end)) | join(\", \")'\nI am sure there is a more elegant way that avoids the `if-then-else`.",
      "Try this :\n\njq -Rr '\n    . / \" \" |\n    map(. / \"=\" |\n          \"\\\"\" + join(\"\\\": \\\"\") + \"\\\"\"\n       ) |\n    join(\", \")\n' input.json"
    ],
    "utterance": "Convert a space-separated line like 'A B=1 C= D=2' into comma-separated values where terms with '=' are formatted as '\"name\": \"value\"' and those without as '\"name\"', representing empty values as empty strings.",
    "expressions": [
      ". / \" \" | map(. / \"=\" | \"\\\"\" + join(\"\\\": \\\"\") + \"\\\"\") | join(\", \")"
    ],
    "data": [
      {
        "input": "A B=1 C= D=2",
        "output": "\"A\", \"B\": \"1\", \"C\": \"\", \"D\": \"2\""
      }
    ],
    "identifier": 74411666
  },
  {
    "context": [
      "I'd like to just count the number of entries (two) which are marked, with \"marked\" property as true.",
      "I could obtain the answer with a wc -l but the point of the question is how to get to the answer of 2, e.g. id's 1 and 3 make for two items that are marked true.",
      "Various stuff that seems like it would make sense don't parse, such as .select(.marked==true)."
    ],
    "utterance": "Count the number of values where the property \"marked\" is true.",
    "expressions": [
      "map_values(select(.marked==true)) | length",
      "to_entries | map(select(.value.marked==true)) | length",
      "[(.[] | select(.marked==true))] | length"
    ],
    "data": [
      {
        "input": {
          "1": {
            "marked": true,
            "id": 1
          },
          "2": {
            "id": 2
          },
          "3": {
            "id": 3,
            "data": "blah",
            "marked": true
          }
        },
        "output": 2
      }
    ],
    "identifier": 74418465
  },
  {
    "context": [
      "jq 'map(del(.taskDefinitionArn, .revision, .status,.requiresAttributes,.compatibilities))'",
      "jq: error (at <stdin>:139): Cannot index array with string \"taskDefinitionArn\"",
      "The program should be:",
      ".taskDefinition |= del(.taskDefinitionArn, .revision, .status, .requiresAttributes, .compatibilities)",
      "It reassigns the `taskDefinition` object to itself with all specified properties removed."
    ],
    "utterance": "Remove fields taskDefinitionArn, revision, status, requiresAttributes, and compatibilities from the taskDefinition object.",
    "expressions": [
      ".taskDefinition |= del(.taskDefinitionArn, .revision, .status, .requiresAttributes, .compatibilities)"
    ],
    "data": [
      {
        "input": {
          "taskDefinition": {
            "status": "ACTIVE",
            "networkMode": "bridge",
            "family": "decac-DSF-FarmB-BGcore-V7KAEEL71QS8",
            "placementConstraints": [],
            "requiresAttributes": [
              {
                "name": "com.amazonaws.ecs.capability.logging-driver.awslogs"
              },
              {
                "name": "com.amazonaws.ecs.capability.ecr-auth"
              },
              {
                "name": "com.amazonaws.ecs.capability.docker-remote-api.1.19"
              },
              {
                "name": "com.amazonaws.ecs.capability.docker-remote-api.1.17"
              },
              {
                "name": "com.amazonaws.ecs.capability.docker-remote-api.1.28"
              },
              {
                "name": "ecs.capability.container-health-check"
              },
              {
                "name": "com.amazonaws.ecs.capability.docker-remote-api.1.18"
              },
              {
                "name": "com.amazonaws.ecs.capability.docker-remote-api.1.29"
              }
            ],
            "cpu": "8192",
            "compatibilities": [
              "EXTERNAL",
              "EC2"
            ],
            "volumes": [],
            "memory": "12480",
            "requiresCompatibilities": [],
            "taskDefinitionArn": "arn:aws:ecs:ap-south-1:020627:task-definition/decac-DSF-FarmB-BGcore-V7KAEEL71QS8:640",
            "containerDefinitions": [
              {
                "dnsSearchDomains": [],
                "environment": [
                  {
                    "name": "BG_CONFIGURATION_SERVER_URL",
                    "value": "http://internal-BGDSF-FarmB-pp-int-ALB-1301919556.ap-south-1.elb.amazonaws.com"
                  },
                  {
                    "name": "ES_IS_ENABLED_SSL",
                    "value": "false"
                  },
                  {
                    "name": "THINKANALYTICS_ENDPOINT",
                    "value": ""
                  },
                  {
                    "name": "USE_HTTPS",
                    "value": "false"
                  },
                  {
                    "name": "BG_CONFIG_REFRESH_INTERVAL",
                    "value": "10000"
                  },
                  {
                    "name": "DECOUPLE_DCQ_ENABLED",
                    "value": "true"
                  },
                  {
                    "name": "ES_SSL_CERTIFICATE_PATH",
                    "value": ""
                  },
                  {
                    "name": "LOG_LEVEL",
                    "value": "info"
                  }
                ],
                "systemControls": [],
                "name": "BG-core-FarmB",
                "links": [],
                "mountPoints": [],
                "healthCheck": {
                  "retries": 10,
                  "interval": 60,
                  "command": [
                    "CMD-SHELL",
                    "/opt/app-root/src/readinessodejs.sh"
                  ],
                  "startPeriod": 15,
                  "timeout": 45
                },
                "image": "020627.dkr.ecr.ap-south-1.amazonaws.com/BG-core:DEE.56.03112022-122711",
                "hostname": "BG-core",
                "essential": true,
                "portMappings": [
                  {
                    "protocol": "tcp",
                    "containerPort": 3000,
                    "hostPort": 0
                  }
                ],
                "dnsServers": [],
                "dockerSecurityOptions": [],
                "entryPoint": [
                  "sh",
                  "-c"
                ],
                "ulimits": [
                  {
                    "softLimit": 51200,
                    "name": "nofile",
                    "hardLimit": 51200
                  }
                ],
                "memory": 12480,
                "logConfiguration": {
                  "logDriver": "awslogs",
                  "options": {
                    "awslogs-region": "ap-south-1",
                    "awslogs-stream-prefix": "BG-core-FarmB",
                    "awslogs-group": "decacDSF-PP-ECSInfra-KHM9B7BK1HDE-ECSLogGroup-Q2KC9BCLGILN",
                    "mode": "non-blocking"
                  }
                },
                "command": [
                  "/bin/sh -c \"/tmp/scripts/run\""
                ],
                "cpu": 8192,
                "volumesFrom": []
              }
            ],
            "revision": 640
          },
          "tags": []
        },
        "output": {
          "taskDefinition": {
            "networkMode": "bridge",
            "family": "decac-DSF-FarmB-BGcore-V7KAEEL71QS8",
            "placementConstraints": [],
            "cpu": "8192",
            "volumes": [],
            "memory": "12480",
            "requiresCompatibilities": [],
            "containerDefinitions": [
              {
                "dnsSearchDomains": [],
                "environment": [
                  {
                    "name": "BG_CONFIGURATION_SERVER_URL",
                    "value": "http://internal-BGDSF-FarmB-pp-int-ALB-1301919556.ap-south-1.elb.amazonaws.com"
                  },
                  {
                    "name": "ES_IS_ENABLED_SSL",
                    "value": "false"
                  },
                  {
                    "name": "THINKANALYTICS_ENDPOINT",
                    "value": ""
                  },
                  {
                    "name": "USE_HTTPS",
                    "value": "false"
                  },
                  {
                    "name": "BG_CONFIG_REFRESH_INTERVAL",
                    "value": "10000"
                  },
                  {
                    "name": "DECOUPLE_DCQ_ENABLED",
                    "value": "true"
                  },
                  {
                    "name": "ES_SSL_CERTIFICATE_PATH",
                    "value": ""
                  },
                  {
                    "name": "LOG_LEVEL",
                    "value": "info"
                  }
                ],
                "systemControls": [],
                "name": "BG-core-FarmB",
                "links": [],
                "mountPoints": [],
                "healthCheck": {
                  "retries": 10,
                  "interval": 60,
                  "command": [
                    "CMD-SHELL",
                    "/opt/app-root/src/readinessodejs.sh"
                  ],
                  "startPeriod": 15,
                  "timeout": 45
                },
                "image": "020627.dkr.ecr.ap-south-1.amazonaws.com/BG-core:DEE.56.03112022-122711",
                "hostname": "BG-core",
                "essential": true,
                "portMappings": [
                  {
                    "protocol": "tcp",
                    "containerPort": 3000,
                    "hostPort": 0
                  }
                ],
                "dnsServers": [],
                "dockerSecurityOptions": [],
                "entryPoint": [
                  "sh",
                  "-c"
                ],
                "ulimits": [
                  {
                    "softLimit": 51200,
                    "name": "nofile",
                    "hardLimit": 51200
                  }
                ],
                "memory": 12480,
                "logConfiguration": {
                  "logDriver": "awslogs",
                  "options": {
                    "awslogs-region": "ap-south-1",
                    "awslogs-stream-prefix": "BG-core-FarmB",
                    "awslogs-group": "decacDSF-PP-ECSInfra-KHM9B7BK1HDE-ECSLogGroup-Q2KC9BCLGILN",
                    "mode": "non-blocking"
                  }
                },
                "command": [
                  "/bin/sh -c \"/tmp/scripts/run\""
                ],
                "cpu": 8192,
                "volumesFrom": []
              }
            ]
          },
          "tags": []
        }
      }
    ],
    "identifier": 74306707
  },
  {
    "context": [
      "I have a JSON array with objects as items. Some of the objects have properties, some don't. How can I filter the list with jq to keep only non-empty objects in the list?",
      "Input:\n\n[\n  {},\n  { \"x\": 42 },\n  {},\n  { \"y\": 21 },\n  {},\n  { \"z\": 13 }\n]",
      "Expected output:\n\n[\n  { \"x\": 42 },\n  { \"y\": 21 },\n  { \"z\": 13 }\n]",
      "You need `map` to make `select` test individual objects:\n\njq 'map(select(. != {}))'",
      "map is required to apply the filter to every item in the array. Then `any` can be used: it will return `true` for objects with at least one property, and `false` if the object is empty.",
      "Solution:\n\nmap(select(any))",
      "A better approach is comparing the empty object directly or using `length`:\n\nmap(select(length>0))",
      "Just use the `del` filter:\n\njq 'del(.[] | select(length == 0))'\n\nor\n\njq 'del(.[] | select(. == {}))'"
    ],
    "utterance": "Filter an array to keep only objects that have at least one property, excluding all empty objects.",
    "expressions": [
      "map(select(. != {}))",
      "map(select(length > 0))",
      "map(select(any))",
      "del(.[] | select(length == 0))",
      "del(.[] | select(. == {}))"
    ],
    "data": [
      {
        "input": [
          {},
          {
            "x": 42
          },
          {},
          {
            "y": 21
          },
          {},
          {
            "z": 13
          }
        ],
        "output": [
          {
            "x": 42
          },
          {
            "y": 21
          },
          {
            "z": 13
          }
        ]
      }
    ],
    "identifier": 74421111
  },
  {
    "context": [
      "I only want to have the columns facilityname, time, totalplaces, occupiedplaces and bezetting",
      "jq -r '[\"naam\", \"tijd\", \"totaalAantalPlaatsen\", \"bezettePlaatsen\", \"bezetting\"] , .records[] | (.fields[] | [.facilityname, .time, .totalplaces, .occupiedplaces, .bezetting]) | @csv'",
      "But I get the error:\n\n`jq: error (at data.json:0): Cannot index array with string \"fields\"`",
      "You just need some parentheses around the `.records[] ...` part",
      "jq -r '\n  [\"name\",  \"tijd\", \"totaalAantalPlaatsen\", \"bezettePlaatsen\", \"bezetting\"],\n  (.records[].fields | [.facilityname, .time, .totalplaces, .occupiedplaces, .bezetting])\n  | @csv\n' file.json"
    ],
    "utterance": "Extract facilityname, time, totalplaces, occupiedplaces, and bezetting from each record and output as CSV with those columns as header.",
    "expressions": [
      "[\"name\",  \"tijd\", \"totaalAantalPlaatsen\", \"bezettePlaatsen\", \"bezetting\"],\n  (.records[].fields | [.facilityname, .time, .totalplaces, .occupiedplaces, .bezetting])\n  | @csv"
    ],
    "data": [
      {
        "input": {
          "nhits": 2,
          "parameters": {
            "dataset": "real-time-bezettingen-fietsenstallingen-gent",
            "rows": 10,
            "start": 0,
            "facet": [
              "facilityname"
            ],
            "format": "json",
            "timezone": "UTC"
          },
          "records": [
            {
              "datasetid": "real-time-bezettingen-fietsenstallingen-gent",
              "recordid": "d471594688a931ba8d81f8d883874a08cee84775",
              "fields": {
                "id": "48-2",
                "freeplaces": 71,
                "facilityname": "Braunplein",
                "geo_point_2d": [
                  51.05406845807926,
                  3.723722319130363
                ],
                "time": "2022-11-10T12:18:01+00:00",
                "totalplaces": 116,
                "occupiedplaces": 45,
                "bezetting": 38
              },
              "geometry": {
                "type": "Point",
                "coordinates": [
                  3.723722319130363,
                  51.05406845807926
                ]
              },
              "record_timestamp": "2022-11-10T12:18:04.838Z"
            },
            {
              "datasetid": "real-time-bezettingen-fietsenstallingen-gent",
              "recordid": "d0121748cf31c7e1c02d99712bdf07cb33156689",
              "fields": {
                "id": "48-1",
                "freeplaces": 65,
                "facilityname": "Korenmarkt",
                "geo_point_2d": [
                  51.05388288288933,
                  3.7214177570400473
                ],
                "time": "2022-11-10T12:18:01+00:00",
                "totalplaces": 235,
                "occupiedplaces": 170,
                "bezetting": 72
              },
              "geometry": {
                "type": "Point",
                "coordinates": [
                  3.7214177570400473,
                  51.05388288288933
                ]
              },
              "record_timestamp": "2022-11-10T12:18:04.838Z"
            }
          ],
          "facet_groups": [
            {
              "name": "facilityname",
              "facets": [
                {
                  "name": "Braunplein",
                  "count": 1,
                  "state": "displayed",
                  "path": "Braunplein"
                },
                {
                  "name": "Korenmarkt",
                  "count": 1,
                  "state": "displayed",
                  "path": "Korenmarkt"
                }
              ]
            }
          ]
        },
        "output": "\"name\",\"tijd\",\"totaalAantalPlaatsen\",\"bezettePlaatsen\",\"bezetting\"\n\"Braunplein\",\"2022-11-10T12:18:01+00:00\",116,45,38\n\"Korenmarkt\",\"2022-11-10T12:18:01+00:00\",235,170,72"
      }
    ],
    "identifier": 74414228
  },
  {
    "context": [
      "when value of `\"currentServer\"` is `\"foo-beta\"`, meaning anything that has a `'-'` character I get an error. I have tried the following:",
      "jq .list[\"foo-beta\"].host test.json",
      "jq .list.foo-beta.host test.json",
      "jq .list | .[\"foo-beta\"].host test.json",
      "jq '.list.\"foo-beta\".host'"
    ],
    "utterance": "Select the 'host' field from the 'foo-beta' object within 'list', where the key contains a dash.",
    "expressions": [
      ".list[\"foo-beta\"].host",
      ".list.\"foo-beta\".host"
    ],
    "data": [
      {
        "input": {
          "list": {
            "foo": {
              "host": "www.someurl1.com"
            },
            "bar": {
              "host": "www.someurl2.com"
            },
            "baz": {
              "host": "www.someurl3.com"
            },
            "foo-beta": {
              "host": "www.someurl4.com"
            }
          },
          "currentServer": "foo-beta"
        },
        "output": "www.someurl4.com"
      }
    ],
    "identifier": 74430389
  },
  {
    "context": [
      "Is there a way to filter out the attributes with key \"end\" and make the result as below?",
      "\"john.doe@contoso.com\": \"SALESMAN\",",
      "\"lorraine.doe@contoso.com\": \"SECRETARY\"",
      "Before converting the attributes to objects, select only those which do not have an `end` property:",
      ".[].attributes",
      "| map(select(has(\"end\")|not)) # <- this line is new",
      "| from_entries",
      "| select(has(\"JOB_TITLE\") and has(\"EMAIL\"))",
      "| \"\\\"\\(.EMAIL)\\\": \\\"\\(.JOB_TITLE)\\\"\"",
      "Filter them out using a `map` before running `from_entries`:",
      ".[].attributes ",
      "| map(select(.name != \"JOB_TITLE\" or (has(\"end\") | not)))",
      "| from_entries",
      "| select(has(\"JOB_TITLE\") and has(\"EMAIL\"))",
      "| \"\\\"\\(.EMAIL)\\\": \\\"\\(.JOB_TITLE)\\\"\""
    ],
    "utterance": "Create a mapping from EMAIL to JOB_TITLE for each entry, excluding attributes that have the key 'end'.",
    "expressions": [
      ".[].attributes\n| map(select(has(\"end\")|not))\n| from_entries\n| select(has(\"JOB_TITLE\") and has(\"EMAIL\"))\n| \"\\\"\\(.EMAIL)\\\": \\\"\\(.JOB_TITLE)\\\"\"",
      ".[].attributes \n| map(select(.name != \"JOB_TITLE\" or (has(\"end\") | not)))\n| from_entries\n| select(has(\"JOB_TITLE\") and has(\"EMAIL\"))\n| \"\\\"\\(.EMAIL)\\\": \\\"\\(.JOB_TITLE)\\\"\""
    ],
    "data": [
      {
        "input": [
          {
            "primary": "JOHN DOE",
            "attributes": [
              {
                "type": "double",
                "name": "BUILDING_NUMBER",
                "value": "123"
              },
              {
                "type": "double",
                "name": "FLOOR",
                "value": 10
              },
              {
                "type": "string",
                "name": "EMAIL",
                "value": "john.doe@contoso.com"
              },
              {
                "type": "string",
                "name": "JOB_TITLE",
                "value": "SALESMAN"
              },
              {
                "type": "string",
                "name": "JOB_TITLE",
                "value": "TRAINEE",
                "end": "11-09-2022"
              }
            ],
            "aliases": [
              {
                "alias": "joao.doe@contoso.com"
              }
            ]
          },
          {
            "primary": "LORRAINE DOE",
            "attributes": [
              {
                "type": "double",
                "name": "BUILDING_NUMBER",
                "value": 456
              },
              {
                "type": "double",
                "name": "FLOOR",
                "value": 10
              },
              {
                "type": "string",
                "name": "STATUS",
                "value": "Unavaliable"
              },
              {
                "type": "string",
                "name": "EMAIL",
                "value": "lorraine.doe@contoso.com"
              },
              {
                "type": "string",
                "name": "JOB_TITLE",
                "value": "Procurement",
                "end": "11-09-2021"
              },
              {
                "type": "string",
                "name": "JOB_TITLE",
                "value": "SECRETARY"
              },
              {
                "type": "string",
                "name": "JOB_TITLE",
                "value": "SALES",
                "end": "11-09-2021"
              }
            ],
            "aliases": [
              {
                "alias": "lorris.doe@contoso.com"
              },
              {
                "alias": "lorris2.doe@contoso.com"
              }
            ]
          },
          {
            "primary": "JACK DOE",
            "attributes": [
              {
                "type": "double",
                "name": "BUILDING_NUMBER",
                "value": "123"
              },
              {
                "type": "double",
                "name": "FLOOR",
                "value": 10
              },
              {
                "type": "string",
                "name": "JOB_TITLE",
                "value": "OWNER"
              }
            ],
            "aliases": [
              {
                "alias": "jack.doe@contoso.com"
              },
              {
                "alias": "jackson.doe@contoso.com"
              }
            ]
          },
          {
            "primary": "NOAH DOE",
            "attributes": [
              {
                "type": "double",
                "name": "BUILDING_NUMBER",
                "value": "123"
              },
              {
                "type": "double",
                "name": "FLOOR",
                "value": 10
              },
              {
                "type": "string",
                "name": "EMAIL",
                "value": "noah.doe@contoso.com"
              }
            ],
            "aliases": [
              {
                "alias": "noah.doe95@contoso.com"
              }
            ]
          }
        ],
        "output": [
          "\"john.doe@contoso.com\": \"SALESMAN\"",
          "\"lorraine.doe@contoso.com\": \"SECRETARY\""
        ]
      }
    ],
    "identifier": 74381739
  },
  {
    "context": [
      "The output of it currently is:\r\n\r\n```\r\n[\r\n  3067,\r\n  584\r\n]\r\n[\r\n  764,\r\n  487\r\n]\r\n```\r\n\r\nBut I need it to be formatted like: ```3067,584 764x487```.",
      "If your input is a stream of JSON arrays, you could use jq's `-s`/`--slurp` command-line option.  Join the first array with comma, the second array with \"x\"; and finally join both strings with a space:",
      "$ jq -sr '[(.[0]|join(\",\")), (.[1]|join(\"x\"))] | join(\" \")' <<JSON\n[\n  3067,\n  584\n]\n[\n  764,\n  487\n]\nJSON\n3067,584 764x487",
      "Alternatively, simply use string interpolation:\n\njq -sr '\"\\(.[0][0]),\\(.[0][1]) \\(.[1][0])x\\(.[1][1])\"'",
      "A solution that does not `--slurp` would be using `input` for every other array:\n~~~sh\njq -r 'join(\",\")+\" \"+(input|join(\"x\"))'\n~~~"
    ],
    "utterance": "Format two arrays of numbers into a single string where the first pair is joined with a comma, the second with an 'x', and both pairs are separated by a space; for example, outputting '3067,584 764x487' from [[3067,584],[764,487]].",
    "expressions": [
      "jq -sr '[(.[0]|join(\",\")), (.[1]|join(\"x\"))] | join(\" \")'",
      "jq -sr '\"\\(.[0][0]),\\(.[0][1]) \\(.[1][0])x\\(.[1][1])\"'",
      "jq -r 'join(\",\")+\" \"+(input|join(\"x\"))'"
    ],
    "data": [
      {
        "input": [
          [
            3067,
            584
          ],
          [
            764,
            487
          ]
        ],
        "output": "3067,584 764x487"
      }
    ],
    "identifier": 74427502
  },
  {
    "context": [
      "I would like to filter out dtstart, dtend, the target phone number and the connection duration from the description for each vevent which was created e.g. in January 2019 (\"2019-01.*\") and output them as a CSV.",
      "jq -r 'def getField($name; $idx): .[] | select(.[0] == $name) | .[$idx];\n       ..\n       | arrays\n       | select(.[0] == \"vevent\")[1]\n       | [\n           getField(\"dtstart\"; 3),\n           getField(\"dtend\"; 3),\n           (getField(\"description\"; 3) | match(\"call to ([^ ]*)\") | .captures[0].string),\n           (getField(\"description\"; 3) | match(\"(\\\\d+) seconds\")  | .captures[0].string)\n         ]\n       | @csv\n      '",
      "[\"start\", \"end\", \"description\"],\n(\n  .[2][][1]\n  | map({key:.[0], value:.[3]})\n  | from_entries\n  | select(.created | startswith(\"2015-01\"))\n  | [.dtstart, .dtend, .description]\n)\n| @csv"
    ],
    "utterance": "Extract dtstart, dtend, target phone number and connection duration for each vevent with created field starting with '2015-01', and output as CSV.",
    "expressions": [
      "jq -r 'def getField($name; $idx): .[] | select(.[0] == $name) | .[$idx];\n       ..\n       | arrays\n       | select(.[0] == \"vevent\")[1]\n       | [\n           getField(\"dtstart\"; 3),\n           getField(\"dtend\"; 3),\n           (getField(\"description\"; 3) | match(\"call to ([^ ]*)\") | .captures[0].string),\n           (getField(\"description\"; 3) | match(\"(\\\\d+) seconds\")  | .captures[0].string)\n         ]\n       | @csv\n      '",
      "[\"start\", \"end\", \"description\"],\n(\n  .[2][][1]\n  | map({key:.[0], value:.[3]})\n  | from_entries\n  | select(.created | startswith(\"2015-01\"))\n  | [.dtstart, .dtend, .description]\n)\n| @csv"
    ],
    "data": [
      {
        "input": [
          "vcalendar",
          [
            [
              "calscale",
              {},
              "text",
              "GREGORIAN"
            ],
            [
              "version",
              {},
              "text",
              "2.0"
            ],
            [
              "prodid",
              {},
              "text",
              "-//SabreDAV//SabreDAV//EN"
            ],
            [
              "x-wr-calname",
              {},
              "unknown",
              "Call log private"
            ],
            [
              "x-apple-calendar-color",
              {},
              "unknown",
              "#ffaa00"
            ],
            [
              "refresh-interval",
              {},
              "duration",
              "PT4H"
            ],
            [
              "x-published-ttl",
              {},
              "unknown",
              "PT4H"
            ]
          ],
          [
            [
              "vevent",
              [
                [
                  "dtstamp",
                  {},
                  "date-time",
                  "2015-04-05T16:42:10Z"
                ],
                [
                  "created",
                  {},
                  "date-time",
                  "2015-02-18T16:44:04Z"
                ],
                [
                  "uid",
                  {},
                  "text",
                  "9b23142b-8d86-3e17-2f44-2bed65b2e471"
                ],
                [
                  "last-modified",
                  {},
                  "date-time",
                  "2015-04-05T16:42:10Z"
                ],
                [
                  "description",
                  {},
                  "text",
                  "Phone call to +49xxxxxxxxxx lasted for 0 seconds."
                ],
                [
                  "summary",
                  {},
                  "text",
                  "Outgoing: +49xxxxxxx"
                ],
                [
                  "dtstart",
                  {},
                  "date-time",
                  "2015-02-18T10:58:12Z"
                ],
                [
                  "dtend",
                  {},
                  "date-time",
                  "2015-02-18T10:58:44Z"
                ],
                [
                  "transp",
                  {},
                  "text",
                  "OPAQUE"
                ]
              ],
              []
            ],
            [
              "vevent",
              [
                [
                  "dtstamp",
                  {},
                  "date-time",
                  "2015-04-05T16:42:10Z"
                ],
                [
                  "created",
                  {},
                  "date-time",
                  "2015-01-09T19:12:05Z"
                ],
                [
                  "uid",
                  {},
                  "text",
                  "c337e092-a012-5f5a-497f-932fbc6159e5"
                ],
                [
                  "last-modified",
                  {},
                  "date-time",
                  "2015-04-05T16:42:10Z"
                ],
                [
                  "description",
                  {},
                  "text",
                  "Phone call to +1xxxxxxxxxx lasted for 39 seconds."
                ],
                [
                  "summary",
                  {},
                  "text",
                  "Outgoing: +1xxxxxxxxxx"
                ],
                [
                  "dtstart",
                  {},
                  "date-time",
                  "2015-01-09T17:23:16Z"
                ],
                [
                  "dtend",
                  {},
                  "date-time",
                  "2015-01-09T17:24:19Z"
                ],
                [
                  "transp",
                  {},
                  "text",
                  "OPAQUE"
                ]
              ],
              []
            ]
          ]
        ],
        "output": "\"2015-01-09T17:23:16Z\",\"2015-01-09T17:24:19Z\",\"+1xxxxxxxxxx\",\"39\""
      }
    ],
    "identifier": 74371420
  },
  {
    "context": [
      "I want to output this entire JSON file to a new file but with the value of `filter-values` appended as a string to each `description` of the `filter` item in each `parameters` array.",
      "I am only interested in the `foo` objects",
      "Not all `foo` objects contain `parameter` arrays",
      "Not all `parameter` arrays contain filter objects",
      "Would this do what you want?\n~~~sh\n(.paths[].foo | select(all(has(\"parameters\", \"filter-values\"); .))) |= (\n  (.parameters[] | select(.name == \"filter\").description) +=\n    \" Possible values are: \\(.\"filter-values\" | join(\", \"))\"\n)\n~~~"
    ],
    "utterance": "Append the values of filter-values as a comma-separated string to the description of each filter parameter in parameters arrays within foo objects, preserving the full document structure and only modifying relevant entries.",
    "expressions": [
      "(.paths[].foo | select(all(has(\"parameters\", \"filter-values\"); .))) |= (\n  (.parameters[] | select(.name == \"filter\").description) +=\n    \" Possible values are: \\(.\"filter-values\" | join(\", \"))\"\n)"
    ],
    "data": [
      {
        "input": {
          "empty": {},
          "paths": {
            "somepath": {
              "foo": {
                "parameters": [
                  {
                    "name": "page"
                  },
                  {
                    "name": "sort"
                  },
                  {
                    "name": "filter",
                    "description": "This is the `filter` param."
                  },
                  {
                    "name": "orderby",
                    "description": "This is the `orderby` param."
                  }
                ],
                "filter-values": [
                  "1",
                  "2",
                  "3"
                ],
                "orderby-values": [
                  "a",
                  "b",
                  "c"
                ]
              },
              "bar": {}
            },
            "anotherpath": {
              "foo": {
                "parameters": [
                  {
                    "name": "page"
                  },
                  {
                    "name": "filter",
                    "description": "This is the `filter` param."
                  }
                ],
                "filter-values": [
                  "4",
                  "5",
                  "6"
                ]
              }
            },
            "yetanotherpath": {
              "foo": {
                "parameters": [
                  {
                    "name": "page"
                  }
                ]
              }
            }
          }
        },
        "output": {
          "empty": {},
          "paths": {
            "somepath": {
              "foo": {
                "parameters": [
                  {
                    "name": "page"
                  },
                  {
                    "name": "sort"
                  },
                  {
                    "name": "filter",
                    "description": "This is the `filter` param. Possible values are: 1, 2, 3"
                  },
                  {
                    "name": "orderby",
                    "description": "This is the `orderby` param."
                  }
                ],
                "filter-values": [
                  "1",
                  "2",
                  "3"
                ],
                "orderby-values": [
                  "a",
                  "b",
                  "c"
                ]
              },
              "bar": {}
            },
            "anotherpath": {
              "foo": {
                "parameters": [
                  {
                    "name": "page"
                  },
                  {
                    "name": "filter",
                    "description": "This is the `filter` param. Possible values are: 4, 5, 6"
                  }
                ],
                "filter-values": [
                  "4",
                  "5",
                  "6"
                ]
              }
            },
            "yetanotherpath": {
              "foo": {
                "parameters": [
                  {
                    "name": "page"
                  }
                ]
              }
            }
          }
        }
      }
    ],
    "identifier": 74387515
  },
  {
    "context": [
      "How can I get the id value if name equals to `y` in cli?",
      "JSON input :",
      "{\n  \"items\": [\n    {\n      \"id\": \"x\",\n      \"name\": \"y\"\n    }\n  ]\n}",
      "I've tried this",
      "json file | jq -r '.items | select(.name==\"y\")",
      "it returns",
      "> jq: error (at <stdin>:1): Cannot index array with string \"name;` error"
    ],
    "utterance": "Get the id where an object in items has name equal to y.",
    "expressions": [
      ".items[] | select(.name == \"y\") | .id"
    ],
    "data": [
      {
        "input": {
          "items": [
            {
              "id": "x",
              "name": "y"
            }
          ]
        },
        "output": "x"
      }
    ],
    "identifier": 74436923
  },
  {
    "context": [
      "How can we transform a number upto 2 precision?",
      "Requirement:\r\nfor ex: \r\n1 to 1.00,\r\n1.0 to 1.00,\r\n1.00 to 1.00,\r\n1.1 to 1.10. etc"
    ],
    "utterance": "Format a number with exactly two digits after the decimal point, including trailing zeros.",
    "expressions": [
      "(. * 100 | floor / 100) | tostring + (if tostring | test(\"\\\\.\") then \"00\" else \".00\" end) | capture(\"^(?<i>-?\\\\d+)(\\\\.(?<d>\\\\d+))?\") | \"\\(.i).\\(.d // \"00\")\" | sub(\"\\\\.(\\\\d)($|\\\\s)\", \".\\10\")"
    ],
    "data": [
      {
        "input": 1,
        "output": "1.00"
      },
      {
        "input": 1.0,
        "output": "1.00"
      },
      {
        "input": 1.0,
        "output": "1.00"
      },
      {
        "input": 1.1,
        "output": "1.10"
      }
    ],
    "identifier": 74432894
  },
  {
    "context": [
      "I am trying to get the regex right to return one or the other but not both:",
      "When I run for example the following:",
      "aws secretsmanager list-secrets | jq -r \".SecretList[] | select(.Name|match(\\\"example-*\\\")) | .Name \"",
      "it returns",
      "example-secret_key",
      "as well as",
      "examplecompany-secret_key",
      "how can I modify the command to return one and not the other?",
      "`^example-` matches strings that start with `example-`.",
      "jq -r '.SecretList[].Name | select( test( \"^example-\" ) )'",
      "If you want to match \"example-\" and don't care what comes after, simply use the regex `example-`.",
      "jq -r '.SecretList[].Name | select(test(\"example-\"))'"
    ],
    "utterance": "Return only the items whose Name starts with 'example-'.",
    "expressions": [
      ".SecretList[].Name | select(test(\"^example-\"))",
      ".SecretList[].Name | select(match(\"^example-\"))"
    ],
    "identifier": 74446715
  },
  {
    "context": [
      "Goal: Search and replace a string in a specific key in a JSON file with a string in a Bash variable using jq.",
      "siteUrl=\"docs.mysite.com\"\n\njq --arg siteUrl \"$siteUrl\" '[].name|= (gsub(\" - https://$siteUrl/\"; \"\"))' file.json > file1.json",
      "Almost. Variables are not automatically expanded within a string. You must interpolate them explicitly with \\(\u2026):",
      "jq --arg siteUrl 'docs.mysite.com' '.[].name |= (gsub(\" - https://\\($siteUrl)/\"; \"\"))' file.json"
    ],
    "utterance": "Replace the substring ' - https://docs.mysite.com/' in every 'name' field with an empty string, using a Bash variable for the site domain.",
    "expressions": [
      "jq --arg siteUrl 'docs.mysite.com' '.[].name |= (gsub(\" - https://\\($siteUrl)/\"; \"\"))' file.json"
    ],
    "data": [
      {
        "input": [
          {
            "url": "https://docs.mysite.com",
            "name": "Welcome - https://docs.mysite.com/",
            "Ocurrences": "679"
          },
          {
            "url": "https://docs.mysite.com",
            "name": "Welcome",
            "Ocurrences": "382"
          }
        ],
        "output": [
          {
            "url": "https://docs.mysite.com",
            "name": "Welcome",
            "Ocurrences": "679"
          },
          {
            "url": "https://docs.mysite.com",
            "name": "Welcome",
            "Ocurrences": "382"
          }
        ]
      }
    ],
    "identifier": 74439340
  },
  {
    "context": [
      "There maybe multiple \"base_score\" in the json(\"base_score\" path is unknown) and the corresponding value will be a number, I have to check if at least one such value is greater than some known value 7.0, and if there is, I have to do \"exit 1\".",
      "any(.. | select(type==\"object\" and (.base_score|type==\"number\")) | .base_score; . > $limit)",
      "any(..|.base_score?; . > 7)"
    ],
    "utterance": "Check whether any base_score value, anywhere in the data, is greater than 7.",
    "expressions": [
      "any(..|.base_score?; . > 7)",
      "any(.. | select(type==\"object\" and (.base_score|type==\"number\")) | .base_score; . > 7)"
    ],
    "data": [
      {
        "input": {
          "key1": {
            "key2": [
              {
                "base_score": 4.5
              }
            ]
          },
          "key3": {
            "key4": [
              {
                "base_score": 8.3
              }
            ]
          }
        },
        "output": true
      },
      {
        "input": {
          "key1": {
            "key2": [
              {
                "base_score": 4.5
              }
            ]
          },
          "key3": {
            "key4": [
              {
                "base_score": 0.5
              }
            ]
          }
        },
        "output": false
      }
    ],
    "identifier": 74441486
  },
  {
    "context": [
      "But if I want to use [tag:jq] to incorporate the input with some surrounding text, the input renders compactly",
      "Is there any way to force pretty printing here? I&#39;d like the output to be",
      "don&#39;t put the input inside string interpolation, output a stream of things:",
      "echo '{\"foo\":\"bar\", \"baz\":[1,2,3]}' | jq -r '\"My value is:\", . , \"Some other stuff\"'"
    ],
    "utterance": "Output the value with leading and trailing custom text, ensuring the value uses pretty formatting.",
    "expressions": [
      "\"My value is:\", . , \"Some other stuff\""
    ],
    "data": [
      {
        "input": {
          "foo": "bar",
          "baz": [
            1,
            2,
            3
          ]
        },
        "output": "My value is:\n{\n  \"foo\": \"bar\",\n  \"baz\": [\n    1,\n    2,\n    3\n  ]\n}\nSome other stuff"
      }
    ],
    "identifier": 74447285
  },
  {
    "context": [
      "I want to extract the resources which is having the string \"vm-managed-itg* values ( last two entries in the output)",
      "Use `select` to return entities only if they match a condition. Substring matches can be tested with `contains`:",
      "select(.ResourceARN|contains(\"vm-managed-itg\"))",
      "If you are only interested in the values of `ResourceARN`, without tags and surrounding objects, then:",
      ".ResourceARN | select(contains(\"vm-managed-itg\"))",
      "Output:\n\n\"arn:aws:cloudwatch:us-east-1:xxxx:alarm:vm-managed-itg-test1\"\n\"arn:aws:cloudwatch:us-east-1:xxxx:alarm:vm-managed-itg-test\""
    ],
    "utterance": "List all ResourceARN values that contain the substring 'vm-managed-itg'.",
    "expressions": [
      ".ResourceTagMappingList[] | select(.ResourceARN | contains(\"vm-managed-itg\")) | .ResourceARN",
      ".ResourceTagMappingList[] | .ResourceARN | select(contains(\"vm-managed-itg\"))"
    ],
    "data": [
      {
        "input": {
          "ResourceTagMappingList": [
            {
              "ResourceARN": "arn:aws:cloudwatch:us-east-1:xxxx:alarm:vm-managed-uat-test",
              "Tags": []
            },
            {
              "ResourceARN": "arn:aws:cloudwatch:us-east-1:xxxx:alarm:vm-managed-stg-test",
              "Tags": []
            },
            {
              "ResourceARN": "arn:aws:cloudwatch:us-east-1:xxxx:alarm:vm-managed-uat-test3",
              "Tags": []
            },
            {
              "ResourceARN": "arn:aws:cloudwatch:us-east-1:xxxx:alarm:vm-managed-stg-test1",
              "Tags": []
            },
            {
              "ResourceARN": "arn:aws:cloudwatch:us-east-1:xxxx:alarm:vm-managed-itg-test1",
              "Tags": []
            },
            {
              "ResourceARN": "arn:aws:cloudwatch:us-east-1:xxxx:alarm:vm-managed-itg-test",
              "Tags": []
            }
          ]
        },
        "output": [
          "arn:aws:cloudwatch:us-east-1:xxxx:alarm:vm-managed-itg-test1",
          "arn:aws:cloudwatch:us-east-1:xxxx:alarm:vm-managed-itg-test"
        ]
      }
    ],
    "identifier": 74440061
  },
  {
    "context": [
      "for i in $(cat \"c:\\Test\\output.json\" | jq -r .[].employerReferenceId); do",
      "Problem: how to reffer to the corresponding value's that belong to person in $i in the curl command data section."
    ],
    "utterance": "For each object, extract the employerReferenceId and the corresponding full object data matching that employerReferenceId.",
    "expressions": [
      ".[] | select(.employerReferenceId == \"0258741\")",
      ".[] | select(.employerReferenceId == $i)"
    ],
    "data": [
      {
        "input": [
          {
            "initials": "V.",
            "firstName": "Victor",
            "lastNamePrefix": " ",
            "lastName": "Rutherford",
            "employerReferenceId": "0258741",
            "jobDescription": "Rental"
          },
          {
            "initials": "P.",
            "firstName": "Pippa",
            "lastNamePrefix": " ",
            "lastName": "Lewis",
            "employerReferenceId": "98765431",
            "jobDescription": "Rental"
          },
          {
            "initials": "S.",
            "firstName": "Stephanie",
            "lastNamePrefix": " ",
            "lastName": "Reid",
            "employerReferenceId": "123456789",
            "jobDescription": "Rental"
          }
        ],
        "output": {
          "initials": "V.",
          "firstName": "Victor",
          "lastNamePrefix": " ",
          "lastName": "Rutherford",
          "employerReferenceId": "0258741",
          "jobDescription": "Rental"
        }
      }
    ],
    "identifier": 74460794
  },
  {
    "context": [
      "Given `input.json` as `{\"a\": 4}`",
      "this command: \n```\njq \"6-.a\" input.json\n```\nproduces \n```\n2\n```",
      "but this command: \n```\njq \"{b: 6-.a}\" input.json\n```\nproduces\n\n```\njq: error: syntax error, unexpected '-'",
      "When constructing objects with expressions as key or value, the expression needs to be surrounded by parentheses:",
      "jq \"{b: (6-.a)}\" input.json",
      "{\n  \"b\": 2\n}"
    ],
    "utterance": "Construct an object with key 'b' whose value is 6 minus the value of key 'a' from the input, where the input object has a key 'a' with value 4.",
    "expressions": [
      "{b: (6 - .a)}"
    ],
    "data": [
      {
        "input": {
          "a": 4
        },
        "output": {
          "b": 2
        }
      }
    ],
    "identifier": 74463432
  },
  {
    "context": [
      "Now I just want to get all tags except the newest three and if there are less than three tags, the result should be empty.",
      "jq -r '.tags | sort[-3][]'",
      "jq -r '.tags | sort_by(./\".\" | map(tonumber))[:-3][]'",
      "Output:\n1.0.0\n1.0.1\n1.1.0\n1.1.1\n1.1.2"
    ],
    "utterance": "Get all elements of the tags array except the newest three, using version sorting on dotted version strings.",
    "expressions": [
      ".tags | sort_by(split(\".\") | map(tonumber))[:-3][]"
    ],
    "data": [
      {
        "input": {
          "tags": [
            "1.0.0",
            "1.1.2",
            "1.2.0",
            "1.2.1",
            "1.0.1",
            "1.1.0",
            "1.1.1",
            "1.2.1"
          ]
        },
        "output": [
          "1.0.0",
          "1.0.1",
          "1.1.0",
          "1.1.1",
          "1.1.2"
        ]
      }
    ],
    "identifier": 74466564
  },
  {
    "context": [
      "Need to update value in `a` field from `actual a` to `updated a`",
      "yq 'select(.action == \"want-to-update\").foo' sample.yaml | jq '.a = \"updated a\" | tostring'",
      "Basically, remove `tostring`",
      "| jq '.a = \"updated a\"'",
      "Using `fromjson` and `tojson`, you can decode and encode JSON on the fly, so all of this can be done with just one call to [yq](https://github.com/mikefarah/yq) (no [jq](https://github.com/stedolan/jq) and no command substitution needed):",
      "fromjson | .a = \"updated a\" | tojson"
    ],
    "utterance": "Change the value of field 'a' to 'updated a' in the embedded object where 'action' is 'want-to-update'",
    "expressions": [
      ".a = \"updated a\""
    ],
    "data": [
      {
        "input": {
          "a": "actual A",
          "b": "actual B",
          "c": "actual C"
        },
        "output": {
          "a": "updated a",
          "b": "actual B",
          "c": "actual C"
        }
      }
    ],
    "identifier": 74490712
  },
  {
    "context": [
      "The name is sometimes empty, and jq doesn't want to append to null. How do I tell jq to just assume the null value is an empty string?",
      ".Tags[]|select(.Key == \"Name\").Value",
      "{together: (.InstanceId + ((.Tags[] | \" \" + select(.Key == \"Name\").Value)? // \"\"))}",
      "[ .InstanceId, (.Tags[]? | select(.Key==\"Name\").Value)  ] | join(\" \")",
      "{ together: (.InstanceId + \" \" + ((.Tags[]|select(.Key == \"Name\").Value)? // \"\")) }",
      "((.Tags[]|select(.Key == \"Name\").Value)? // \"\") as $name|{together: (.InstanceId + \" \" + $name)}"
    ],
    "utterance": "Combine the 'InstanceId' value with the value of the tag where Key is 'Name', treating a missing tag as an empty string.",
    "expressions": [
      "{together: (.InstanceId + ((.Tags[] | \" \" + select(.Key == \"Name\").Value)? // \"\"))}",
      "{ together: (.InstanceId + \" \" + ((.Tags[]|select(.Key == \"Name\").Value)? // \"\")) }",
      "((.Tags[]|select(.Key == \"Name\").Value)? // \"\") as $name|{together: (.InstanceId + \" \" + $name)}",
      "{ together: [ .InstanceId, (.Tags[]? | select(.Key==\"Name\").Value)  ] | join(\" \") }"
    ],
    "data": [
      {
        "input": {
          "InstanceId": "i-abc",
          "Tags": [
            {
              "Key": "Name",
              "Value": "Grafana"
            }
          ]
        },
        "output": {
          "together": "i-abc Grafana"
        }
      },
      {
        "input": {
          "InstanceId": "i-def"
        },
        "output": {
          "together": "i-def"
        }
      }
    ],
    "identifier": 74466550
  },
  {
    "context": [
      "I would like to extract only test and test1, but it is under data/data which is like sublist and unable to find a way to extract it.",
      "I would like to get the output something like below which I can loop through and set as variable.",
      "test=test123",
      "test1=test1234",
      "You can acess the nested object with `.data.data`. You can convert an object into a list of key-value pairs with `to_entries`. Then it is only a matter of joining:",
      "vault ... | jq -r '.data.data | to_entries[] | join(\"=\")'",
      "Output:",
      "test=test123",
      "test1=test1234"
    ],
    "utterance": "Output each key-value pair from the nested object under data.data as lines in key=value format.",
    "expressions": [
      ".data.data | to_entries[] | join(\"=\")"
    ],
    "data": [
      {
        "input": {
          "request_id": "8498e5e4-050a-51e9-deaf-64a06a0",
          "lease_id": "",
          "lease_duration": 0,
          "renewable": false,
          "data": {
            "data": {
              "test": "test123",
              "test1": "test1234"
            },
            "metadata": {
              "created_time": "2022-11-17T12:2214.93229792Z",
              "custom_metadata": null,
              "deletion_time": "",
              "destroyed": false,
              "version": 1
            }
          },
          "warnings": null
        },
        "output": [
          "test=test123",
          "test1=test1234"
        ]
      }
    ],
    "identifier": 74499585
  },
  {
    "context": [
      "I am unable to calculate the length of a string containing ANSI colour codes.",
      "Since the string only has the letter \"a\" in it, I would like to have some function that determines the length of the string to be 1.",
      "_red(\"a\") | length # gives 10",
      "def _strip_ansi: gsub(\"\\\\x1b\\\\[[0-9;]*m\"; \"\");",
      "_red(\"a\") | _strip_ansi | length # gives 1"
    ],
    "utterance": "Determine the length of a string containing the letter 'a' wrapped in ANSI color codes, excluding the escape codes.",
    "expressions": [
      "_red(\"a\") | gsub(\"\\x1b\\[[0-9;]*m\"; \"\") | length"
    ],
    "data": [
      {
        "input": "\u001b[31ma\u001b[0m",
        "output": 1
      }
    ],
    "identifier": 74500168
  },
  {
    "context": [
      "\"cat file.json | jq .items.zone/me-west-c\"",
      "jq: error: me/0 is not defined at <top-level>, line 1:",
      "\"zones/me-west1-c\": { ... }",
      "In jq, if your key contains special characters like '-' or '/', you need to use [\"key\"] syntax. For example: .[\"zones/me-west1-c\"]"
    ],
    "utterance": "Access the value associated with the top-level key named 'zones/me-west1-c' which contains special characters.",
    "expressions": [
      ".[\"zones/me-west1-c\"]"
    ],
    "data": [
      {
        "input": {
          "zones/me-west1-c": {
            "warning": {
              "code": "NO_RESULTS_ON_PAGE",
              "message": "There are no results for scope 'zones/me-west1-c' on this page.",
              "data": [
                {
                  "key": "scope",
                  "value": "zones/me-west1-c"
                }
              ]
            }
          }
        },
        "output": {
          "warning": {
            "code": "NO_RESULTS_ON_PAGE",
            "message": "There are no results for scope 'zones/me-west1-c' on this page.",
            "data": [
              {
                "key": "scope",
                "value": "zones/me-west1-c"
              }
            ]
          }
        }
      }
    ],
    "identifier": 74521305
  },
  {
    "context": [
      "I am trying to check if a string, passed in anyhow, matches any of the `.regex` in the json and if it does return the corresponding `.name`.",
      "If there are multiple matches then return all the `.name` values where the `.regex` matches the passed in string.",
      "\"Apple or Is this /melon/ a banana\" => [ \"For teachers\", \"Long and yellow\", \"Canteloupe\" ]",
      "here's an answer to the last version:\n\n```\n$ echo \"Apple or Is this /melon/ a banana\" | jq -Rr --slurpfile regex test.json '\n. as $in \n| $regex[0] \n| map(\n  select(. as $re | $in | test($re.regex))\n  | .name\n)\n'\n[\n  \"For teahcers\",\n  \"Long and yellow\",\n  \"Cantaloupe\"\n]\n```"
    ],
    "utterance": "Return all name values from the array where the passed string matches the corresponding regex property; if multiple matches, return all names.",
    "expressions": [
      ". as $in | $regex[0] | map( select(. as $re | $in | test($re.regex)) | .name )"
    ],
    "data": [
      {
        "input": [
          {
            "name": "For teachers",
            "regex": "^Apple "
          },
          {
            "name": "Long and yellow",
            "regex": "banana$"
          },
          {
            "name": "Cantaloupe",
            "regex": ".*/melon/.*"
          }
        ],
        "output": [
          "For teahcers",
          "Long and yellow",
          "Cantaloupe"
        ]
      }
    ],
    "identifier": 74522985
  },
  {
    "context": [
      "I want to echo an error notifying users that the field is invalid. Similar to below:",
      "If any instance of that field is not `true`, I want to echo an error notifying users that the field is invalid.",
      "if jq -e 'all(.. | objects | select(has(\"foo\")); .foo)' file.json >/dev/null",
      "jq 'if all(.. | objects | select(has(\"foo\")); .foo) then \"All truthy\" else \"At least one not truthy\" end'"
    ],
    "utterance": "Check if all fields named foo in all objects have the value true, and notify if any is not true.",
    "expressions": [
      "all(.. | objects | select(has(\"foo\")); .foo)",
      "if all(.. | objects | select(has(\"foo\")); .foo) then \"All truthy\" else \"At least one not truthy\" end"
    ],
    "identifier": 74526175
  },
  {
    "context": [
      "how can this be flattened to this form:\r\n\r\n\r\n```json\r\n{\"computers\":\r\n    \"host\":\"example\",\r\n    \"platform\":\"some_platform\",\r\n    \"working\":\"yes\",\r\n    \"display\":\"no\",\r\n    \"description\":\"\"\r\n}\r\n```",
      "That will alter the value of `.computers` by doing to following:\r\n* Get the `first` object\r\n* Move everything inside `.status` to the object itself\r\n* `del()` the `.status` key\r\n* `join()` on the `.display` to get single value instead of the array.",
      ".computers |= (first | . + .status | del(.status) | (.display |= join(.)))",
      "Another alternative is reassigning the computers property, similar to 0stone0&#39;s solution, but a little bit shorter:\r\n\r\n```\r\n.computers |= (first | del(.status) + (.status | .display |= first))\r\n```",
      "You can generically \"flatten\" nested objects by recursively traversing to their `scalars`, and putting them together by taking the deepest field name available:\r\n~~~sh\r\n.computers |= ([paths(scalars) as $p | {($p | map(strings)[-1]): getpath($p)}] | add)\r\n~~~"
    ],
    "utterance": "Replace the nested array at 'computers' with a single object from the array, merging 'status' properties into the top level and converting 'display' from an array to its contained string.",
    "expressions": [
      ".computers |= (first | . + .status | del(.status) | (.display |= join(.)))",
      ".computers |= (first | del(.status) + (.status | .display |= first))",
      ".computers |= ([paths(scalars) as $p | {($p | map(strings)[-1]): getpath($p)}] | add)"
    ],
    "data": [
      {
        "input": {
          "computers": [
            {
              "host": "example",
              "platform": "some_platform",
              "status": {
                "working": "yes",
                "display": [
                  "no"
                ]
              },
              "description": ""
            }
          ]
        },
        "output": {
          "computers": {
            "host": "example",
            "platform": "some_platform",
            "working": "yes",
            "display": "no",
            "description": ""
          }
        }
      }
    ],
    "identifier": 74520746
  },
  {
    "context": [
      "I want to return the value of the name key together with the value of the version key if the version key has a value. The expected output is \"name\": \"value\" , \"version\" : \"value\"",
      "I expect this:\n\nPolymer 3.5.0\n\nHammer.js 2.0.2",
      "jq -r '.[] | \"\\(.name) \\(.version // empty)\"'",
      "jq -r '.technologies[] | select(.version) | \"\\(.name) \\(.version)\"' file.json"
    ],
    "utterance": "List each object's name and version as a string, only when version is present.",
    "expressions": [
      ".technologies[] | select(.version) | \"\\(.name) \\(.version)\"",
      ".technologies[] | \"\\(.name) \\(.version // empty)\""
    ],
    "data": [
      {
        "input": {
          "urls": {
            "https://youtube.com/": {
              "status": 301
            },
            "https://www.youtube.com/": {
              "status": 200
            }
          },
          "technologies": [
            {
              "slug": "youtube",
              "name": "YouTube",
              "description": "YouTube is a video sharing service where users can create their own profile, upload videos, watch, like and comment on other videos.",
              "confidence": 100,
              "version": null,
              "icon": "YouTube.png",
              "website": "http://www.youtube.com",
              "cpe": null,
              "categories": [
                {
                  "id": 14,
                  "slug": "video-players",
                  "name": "Video players"
                }
              ],
              "rootPath": true
            },
            {
              "slug": "polymer",
              "name": "Polymer",
              "description": null,
              "confidence": 100,
              "version": "3.5.0",
              "icon": "Polymer.png",
              "website": "http://polymer-project.org",
              "cpe": null,
              "categories": [
                {
                  "id": 12,
                  "slug": "javascript-frameworks",
                  "name": "JavaScript frameworks"
                }
              ],
              "rootPath": true
            },
            {
              "slug": "hammer-js",
              "name": "Hammer.js",
              "description": null,
              "confidence": 100,
              "version": "2.0.2",
              "icon": "Hammer.js.png",
              "website": "https://hammerjs.github.io",
              "cpe": null,
              "categories": [
                {
                  "id": 59,
                  "slug": "javascript-libraries",
                  "name": "JavaScript libraries"
                }
              ],
              "rootPath": true
            }
          ]
        },
        "output": [
          "Polymer 3.5.0",
          "Hammer.js 2.0.2"
        ]
      }
    ],
    "identifier": 74465242
  },
  {
    "context": [
      "I just want to get back the values, but if I try:",
      "jq -r '.Members[] | .@odata.id'",
      "I get back an error.  Does anyone know the proper syntax to use?"
    ],
    "utterance": "Extract the values of the @odata.id field from each object in the Members array.",
    "expressions": [
      ".Members[].\"@odata.id\""
    ],
    "data": [
      {
        "input": {
          "Members": [
            {
              "@odata.id": "/redfish/v1/Managers/1/SnmpService/SNMPUsers/1"
            },
            {
              "@odata.id": "/redfish/v1/Managers/1/SnmpService/SNMPUsers/3"
            }
          ]
        },
        "output": [
          "/redfish/v1/Managers/1/SnmpService/SNMPUsers/1",
          "/redfish/v1/Managers/1/SnmpService/SNMPUsers/3"
        ]
      }
    ],
    "identifier": 74546051
  },
  {
    "context": [
      "I want to transform following type of json obj",
      "[ { \"A\": \"a\", \"Tags\": [ { \"key\":\"x\", \"value\":0}, { \"key\":\"y\", \"value\":1} ] }, {...} ]",
      "to this, including Tags list on top",
      "[ { \"A\": \"a\", \"x\": 0, \"y\": 1 }, {...} ]",
      "map(. + (.Tags | from_entries) | del(.Tags))",
      "Will map() over all the objects in the array and:",
      "* Convert .Tags to an object using from_entries",
      "* This is added to the original object (. + ())",
      "* Delete the original .Tags",
      "Output:",
      "[ { \"A\": \"a\", \"x\": 0, \"y\": 1 } ]"
    ],
    "utterance": "Transform an array of objects so that each object's Tags array of key/value pairs becomes top-level key/value pairs, and remove the Tags key.",
    "expressions": [
      "map(. + (.Tags | from_entries) | del(.Tags))"
    ],
    "data": [
      {
        "input": [
          {
            "A": "a",
            "Tags": [
              {
                "key": "x",
                "value": 0
              },
              {
                "key": "y",
                "value": 1
              }
            ]
          }
        ],
        "output": [
          {
            "A": "a",
            "x": 0,
            "y": 1
          }
        ]
      }
    ],
    "identifier": 74550307
  },
  {
    "context": [
      "The desired structure is an object rather than an array, keyed on the concatenation of the Country and Location fields, but the only nested fields that I am interested in are \"Name\" and \"Coordinates.\"",
      "jq 'INDEX(\"\\(.Country)-\\(.Location)\") | map_values({Name, Coordinates})'",
      "jq 'reduce .[] as $i ({}; .\"\\($i.Country)-\\($i.Location)\" = ($i|{Name, Coordinates}))'",
      "Output:\n\n{\n  \"AD-CAN\": {\n    \"Name\": \"Canillo\",\n    \"Coordinates\": \"4234N 00135E\"\n  }\n}"
    ],
    "utterance": "Convert an array of objects to an object keyed by the combination of Country and Location, with each value containing only the Name and Coordinates fields.",
    "expressions": [
      "INDEX(\"\\(.Country)-\\(.Location)\") | map_values({Name, Coordinates})",
      "reduce .[] as $i ({}; .\"\\($i.Country)-\\($i.Location)\" = ($i|{Name, Coordinates}))"
    ],
    "data": [
      {
        "input": [
          {
            "Change": null,
            "Coordinates": "4234N 00135E",
            "Country": "AD",
            "Date": "0307",
            "Function": "--3-----",
            "IATA": null,
            "Location": "CAN",
            "Name": "Canillo",
            "NameWoDiacritics": "Canillo",
            "Remarks": null,
            "Status": "RL",
            "Subdivision": null
          }
        ],
        "output": {
          "AD-CAN": {
            "Name": "Canillo",
            "Coordinates": "4234N 00135E"
          }
        }
      }
    ],
    "identifier": 74553238
  },
  {
    "context": [
      "iterate over an array of environment variable names as shown below:",
      "`arr = ('env_var1' 'env_var2' 'env_var3')`",
      "and, using [jq][1] generate a JSON of environment variable name-value pairs like below:",
      "{\n \"env_var1\": \"env_var1_value_is_1\",\n \"env_var2\": \"env_var2_value_is_2\",\n \"env_var3\": \"env_var3_value_is_3\"\n}",
      "jq -n '$ARGS.positional | map({ (.): env[.] }) | add' --args \"${arr[@]}\"",
      "the `env` builtin is the thing you needed to pull values out of the environment.",
      "printf '%s\\n' \"${arr[@]}\" | jq -nR '[inputs | {(.): env[.] }] | add'"
    ],
    "utterance": "Given an array of environment variable names, produce an object mapping each variable name to its corresponding environment value.",
    "expressions": [
      "jq -n '$ARGS.positional | map({ (.): env[.] }) | add' --args \"${arr[@]}\"",
      "printf '%s\\n' \"${arr[@]}\" | jq -nR '[inputs | {(.): env[.] }] | add'"
    ],
    "identifier": 74556998
  },
  {
    "context": [
      "If I wanted to override the value of apis.payment.base_url I could pass an environment variable: **APIS__PAYMENT__BASE_URL** and the value would be replaced.",
      "In order to make easy to identify which environment variables I should use, let's assume it will have a prefix of **SETTINGS**.",
      "Example of how I would override values.",
      "|         **JSON PATH**            |  **EQUIVALENT ENVIRONMENT VARIABLE**    |",
      "|  APIS.PAYMENT.BASE_URL           |     SETTINGS__APIS__PAYMENT__BASE_URL  |",
      "|   AVAILABLELOCALES[0]            | SETTINGS__AVAILABLELOCALES__0     |",
      "$ printenv|grep SETTINGS__\nSETTINGS__APIS__PAYMENT__BASE_URL=https://example2.com\nSETTINGS__AVAILABLELOCALES__0=cs",
      "jq -n '\ninputs as $i\n| [ $i\n    | ..\n    | keys_unsorted?\n    | .[]\n    | strings\n  ]\n| unique as $allKeys\n|\ndef fixCase:\n  . as $w\n  | reduce ($allKeys[]|select(length == ($w|length))) as $k\n      (\"\";. + $k|match($w;\"i\").string)\n;\ndef envpaths:\n  [\n    $ENV\n    | to_entries[]\n    | select(.key | startswith(\"SETTINGS__\"))\n    | [[ (.key|split(\"__\"))[1:][]\n         | if test(\"^[0-9]+$\") then tonumber else fixCase end\n       ],\n         .value\n      ]\n  ]\n;\nreduce envpaths[] as $p ($i; .|setpath($p[0];$p[1]))' settings.json",
      "SETTINGS__APIS__PAYMENT__BASE_URL=https://example2.com\nSETTINGS__AVAILABLELOCALES__0=cs\nSETTINGS__UNAVAILABLE__PATH=1",
      "jq 'def settings:\n      def prepareVariables:\n        [$ENV | to_entries[] | select(.key | startswith(\"SETTINGS__\"))]   # select all variables that starts with \"SETTINGS__\"\n        | map(.key |= (. / \"__\" | map(tonumber? // .))[1:]);              # convert variable names to path arrays\n\n      [paths(scalars) | [., map(ascii_upcase? // .)]] |                   # collect all leaf paths from input file and add uppercase path\n      reduce .[] as $leafPath                                             # add leaf paths to corresponding settings\n             (prepareVariables; map(select($leafPath[1] == .key) |= . + {path: $leafPath[0]})) |\n      map(select(has(\"path\")));                                           # drop settings for unknown paths\n\n    . as $input |\n    reduce settings[] as $setting                                         # apply new settings from variables to input file\n           ($input; . | setpath($setting[\"path\"]; $setting[\"value\"]))\n' input.json"
    ],
    "utterance": "Override values in the configuration file using environment variables with the SETTINGS__ prefix, where the environment variable name encodes the path to the value to override.",
    "expressions": [
      "jq -n '\ninputs as $i\n| [ $i\n    | ..\n    | keys_unsorted?\n    | .[]\n    | strings\n  ]\n| unique as $allKeys\n|\ndef fixCase:\n  . as $w\n  | reduce ($allKeys[]|select(length == ($w|length))) as $k\n      (\"\";. + $k|match($w;\"i\").string)\n;\ndef envpaths:\n  [\n    $ENV\n    | to_entries[]\n    | select(.key | startswith(\"SETTINGS__\"))\n    | [[ (.key|split(\"__\"))[1:][]\n         | if test(\"^[0-9]+$\") then tonumber else fixCase end\n       ],\n         .value\n      ]\n  ]\n;\nreduce envpaths[] as $p ($i; .|setpath($p[0];$p[1]))' settings.json",
      "jq 'def settings:\n      def prepareVariables:\n        [$ENV | to_entries[] | select(.key | startswith(\"SETTINGS__\"))]   # select all variables that starts with \"SETTINGS__\"\n        | map(.key |= (. / \"__\" | map(tonumber? // .))[1:]);              # convert variable names to path arrays\n\n      [paths(scalars) | [., map(ascii_upcase? // .)]] |                   # collect all leaf paths from input file and add uppercase path\n      reduce .[] as $leafPath                                             # add leaf paths to corresponding settings\n             (prepareVariables; map(select($leafPath[1] == .key) |= . + {path: $leafPath[0]})) |\n      map(select(has(\"path\")));                                           # drop settings for unknown paths\n\n    . as $input |\n    reduce settings[] as $setting                                         # apply new settings from variables to input file\n           ($input; . | setpath($setting[\"path\"]; $setting[\"value\"]))\n' input.json"
    ],
    "data": [
      {
        "input": {
          "apis": {
            "payment": {
              "base_url": "https://example.com/"
            },
            "order": {
              "base_url": "https://example.com/"
            }
          },
          "features": {
            "authentication": {
              "authProviders": true,
              "registration": false
            }
          },
          "availableLocales": [
            "en",
            "es"
          ]
        },
        "output": {
          "apis": {
            "payment": {
              "base_url": "https://example2.com"
            },
            "order": {
              "base_url": "https://example.com/"
            }
          },
          "features": {
            "authentication": {
              "authProviders": true,
              "registration": false
            }
          },
          "availableLocales": [
            "cs",
            "es"
          ]
        }
      }
    ],
    "identifier": 74465958
  },
  {
    "context": [
      "I want to count the number of \"domains\" for which \"adminLock\" is equal to 1.",
      "'.data.data[] | select(.adminLock == 1) | .domains'",
      "I can get the value of .domains, but how can I count how many times it occurs?",
      "This command gets the value, I want to count the domains value in the case of adminLock=1, and count the number of domains",
      "To have a single count of all resulting items, either make an array and determine its `length`:",
      ".data.data | map(select(.adminLock == 1)) | length",
      "reduce (.data.data[] | select(.adminLock == 1)) as $i (0; .+1)",
      "count(.data.data[] | select(.adminLock == 1))"
    ],
    "utterance": "Count the number of domains where adminLock equals 1.",
    "expressions": [
      ".data.data | map(select(.adminLock == 1)) | length",
      "reduce (.data.data[] | select(.adminLock == 1)) as $i (0; .+1)",
      "count(.data.data[] | select(.adminLock == 1))"
    ],
    "data": [
      {
        "input": {
          "code": 0,
          "message": "\u6210\u529f",
          "data": {
            "recordCount": "128",
            "pageSize": 100,
            "page": 1,
            "pageCount": 2,
            "data": [
              {
                "domainsID": "173652434",
                "nsGroupID": "199",
                "groupID": "78987",
                "domains": "dome1.com",
                "state": 3,
                "userLock": 0,
                "adminLock": 0,
                "view_type": "1"
              },
              {
                "domainsID": "173205836",
                "nsGroupID": "199",
                "groupID": "78987",
                "domains": "dome2.com",
                "state": 3,
                "userLock": 0,
                "adminLock": 1,
                "view_type": "1"
              },
              {
                "domainsID": "173205812",
                "nsGroupID": "199",
                "groupID": "78987",
                "domains": "dome3.com",
                "state": 3,
                "userLock": 0,
                "adminLock": 0,
                "view_type": "1"
              },
              {
                "domainsID": "173203610",
                "nsGroupID": "199",
                "groupID": "78987",
                "domains": "dome4.com",
                "state": 3,
                "userLock": 0,
                "adminLock": 1,
                "view_type": "1"
              },
              {
                "domainsID": "173203210",
                "nsGroupID": "199",
                "groupID": "78987",
                "domains": "dome5.com",
                "state": 3,
                "userLock": 0,
                "adminLock": 1,
                "view_type": "1"
              },
              {
                "domainsID": "173203131",
                "nsGroupID": "199",
                "groupID": "78987",
                "domains": "dome6.com",
                "state": 3,
                "userLock": 0,
                "adminLock": 1,
                "view_type": "1"
              },
              {
                "domainsID": "173203074",
                "nsGroupID": "199",
                "groupID": "78987",
                "domains": "dome7.com",
                "state": 3,
                "userLock": 0,
                "adminLock": 1,
                "view_type": "1"
              }
            ],
            "nextPage": 2
          }
        },
        "output": 5
      }
    ],
    "identifier": 74542915
  },
  {
    "context": [
      "Instead of those results I need each json file to be named after the \"Participant_id\" (e.g. P04_00002.json)",
      "And I want to preserve the json structure to look like that for each file",
      "What adjustments should I make to the command above to achieve this?",
      "jq -cr '.[] | (.Participant_id, .)' Metadata_01.json | awk '\n  NR%2==1 {fn=\"id.\" $0 \".json\"; next} {print >> fn; close(fn); }\n'"
    ],
    "utterance": "Split a large array into multiple files each named after the value of Participant_id, where each file contains the corresponding object.",
    "expressions": [
      "jq -cr '.[] | (.Participant_id, .)' Metadata_01.json | awk 'NR%2==1 {fn=\"id.\" $0 \".json\"; next} {print >> fn; close(fn); }'"
    ],
    "data": [
      {
        "input": [
          {
            "Participant_id": "P04_00001",
            "no_of_people": "Multiple",
            "apparent_gender": "F",
            "geographic_location": "AUS",
            "ethnicity": "Caucasian",
            "capture_device_used": "iOS 14",
            "camera_orientation": "Portrait",
            "camera_position": "Side View",
            "indoor_outdoor_env": "Indoors",
            "lighting_condition": "Bright",
            "Occluded": 1,
            "category": "Two Person",
            "camera_movement": "Still",
            "action": "No action",
            "indoor_outdoor_in_moving_car_or_train": "Indoor",
            "daytime_nighttime": "Nighttime"
          },
          {
            "Participant_id": "P04_00002",
            "no_of_people": "Single",
            "apparent_gender": "M",
            "geographic_location": "AUS",
            "ethnicity": "Caucasian",
            "capture_device_used": "iOS 14",
            "camera_orientation": "Portrait",
            "camera_position": "Frontal View",
            "indoor_outdoor_env": "Outdoors",
            "lighting_condition": "Bright",
            "Occluded": "None",
            "category": "Animals",
            "camera_movement": "Still",
            "action": "Small action",
            "indoor_outdoor_in_moving_car_or_train": "Outdoor",
            "daytime_nighttime": "Daytime"
          }
        ],
        "output": {
          "P04_00002.json": {
            "Participant_id": "P04_00002",
            "no_of_people": "Single",
            "apparent_gender": "M",
            "geographic_location": "AUS",
            "ethnicity": "Caucasian",
            "capture_device_used": "iOS 14",
            "camera_orientation": "Portrait",
            "camera_position": "Frontal View",
            "indoor_outdoor_env": "Outdoors",
            "lighting_condition": "Bright",
            "Occluded": "None",
            "category": "Animals",
            "camera_movement": "Still",
            "action": "Small action",
            "indoor_outdoor_in_moving_car_or_train": "Outdoor",
            "daytime_nighttime": "Daytime"
          }
        }
      }
    ],
    "identifier": 74551827
  },
  {
    "context": [
      "The two things I am looking to do is, remove `initial_balance` and then add `delegator_address` to the results.",
      "unbonding_responses[] ... | { delegator_address } + .entries[] | del(.initial_balance) | .balance |= tonumber/1000000",
      "You can construct your output from scratch:",
      "{ delegator_address } + (.entries[] | { creation_height, completion_time, balance: (.balance|tonumber/1000000) })"
    ],
    "utterance": "List each entry with delegator_address, creation_height, completion_time, and balance divided by 1,000,000; exclude initial_balance.",
    "expressions": [
      ".unbonding_responses[] | { delegator_address } + (.entries[] | { creation_height, completion_time, balance: (.balance|tonumber/1000000) })",
      ".unbonding_responses[] | { delegator_address } + .entries[] | del(.initial_balance) | .balance |= tonumber/1000000"
    ],
    "data": [
      {
        "input": {
          "unbonding_responses": [
            {
              "delegator_address": "tori1zkzfu5tqee0p698w3g83x8a2zswgqglj4t8z3j",
              "validator_address": "torivaloper189r2mx8h5zt7ep4cf0s4np79w38l420na3h6sa",
              "entries": [
                {
                  "creation_height": "753019",
                  "completion_time": "2022-12-13T16:00:56.664864370Z",
                  "initial_balance": "3000000",
                  "balance": "3000000"
                }
              ]
            },
            {
              "delegator_address": "tori1rjg0vg9hlu8kygnrdehzt3z0t4ea5ssu6wkm06",
              "validator_address": "torivaloper189r2mx8h5zt7ep4cf0s4np79w38l420na3h6sa",
              "entries": [
                {
                  "creation_height": "653923",
                  "completion_time": "2022-12-07T00:53:48.247870844Z",
                  "initial_balance": "50000000",
                  "balance": "50000000"
                }
              ]
            },
            {
              "delegator_address": "tori1aw44evl5zlqtw93zln83tp4v3w4kp6e9zmx64k",
              "validator_address": "torivaloper189r2mx8h5zt7ep4cf0s4np79w38l420na3h6sa",
              "entries": [
                {
                  "creation_height": "597161",
                  "completion_time": "2022-12-03T05:32:59.107845572Z",
                  "initial_balance": "2000000",
                  "balance": "2000000"
                }
              ]
            }
          ],
          "pagination": {
            "next_key": null,
            "total": "3"
          }
        },
        "output": [
          {
            "delegator_address": "tori1zkzfu5tqee0p698w3g83x8a2zswgqglj4t8z3j",
            "creation_height": "753019",
            "completion_time": "2022-12-13T16:00:56.664864370Z",
            "balance": 3
          },
          {
            "delegator_address": "tori1rjg0vg9hlu8kygnrdehzt3z0t4ea5ssu6wkm06",
            "creation_height": "653923",
            "completion_time": "2022-12-07T00:53:48.247870844Z",
            "balance": 50
          },
          {
            "delegator_address": "tori1aw44evl5zlqtw93zln83tp4v3w4kp6e9zmx64k",
            "creation_height": "597161",
            "completion_time": "2022-12-03T05:32:59.107845572Z",
            "balance": 2
          }
        ]
      }
    ],
    "identifier": 74536740
  },
  {
    "context": [
      "I would like to just retrieve the value of code, so that it would just show `503` as an output.",
      "Access the value with `.status.code`:",
      "If you want your output to be `503` (as compared to `\"503\"`), use `--raw-output`/`-r`:",
      "$ jq -r '.status.code' <<JSON\n{\n \"kind\":\"testObject\",\n \"spec\":{\n },\n \"status\":{\n  \"code\":\"503\"\n }\n}\nJSON\n503"
    ],
    "utterance": "Extract the value of the 'code' field from the 'status' object and output 503 as an unquoted string.",
    "expressions": [
      ".status.code",
      "-r .status.code"
    ],
    "data": [
      {
        "input": {
          "kind": "testObject",
          "spec": {},
          "status": {
            "code": "503"
          }
        },
        "output": "503"
      }
    ],
    "identifier": 74576298
  },
  {
    "context": [
      "I need to merge those objects into the first json, based on the same KEY value so that it would look like this",
      "But all i got is (for when there are multiple same KEY values): ... only one (last) object was added instead of all of them being appended :/",
      "Ok, i have figured it out. I have changed the .Groups[] index like that",
      "updated_project=$(echo \"$projects\" | jq \".Projects[] | select(.Project[].KEY==\\\"$key\\\") | .Project[].Permissions[].Groups[.Project[].Permissions[].Groups | length] |= $data\")",
      "And it gave me the proper output."
    ],
    "utterance": "Append multiple group-permission objects to the Groups array of the matching project where KEY equals a given value, so all group entries for the same KEY are combined.",
    "expressions": [
      ".Projects[] | select(.Project[].KEY==\"$key\") | .Project[].Permissions[].Groups[.Project[].Permissions[].Groups | length] |= $data"
    ],
    "identifier": 74570585
  },
  {
    "context": [
      "my_topic_1 p0 replica list is [4, 5, 3] and compare it with a master list (existing brokers in cluster); [3, 4, 5, 6] and append the missing broker to the partition list,",
      "So broker 6 is missing from the partition list; hence add 6 so partition list for topic becomes [4, 5, 3, 6]",
      "to add the missing item of `[3,4,5,6]` to a given array, just add one that values `18` (which is `3+4+5+6`) minus the current sum (`add`) of the array:",
      "jq '.partitions[].replicas |= . + [18-add]' file.json",
      "To make it more generic, you can provide the full array as parameter using `--argjson`:",
      "jq --argjson full '[3,4,5,6]' '\n  .partitions[].replicas |= . + [($full | add) - add]\n' file.json",
      "Or generate the full list from the arrays at hand by making an array of `unique` values:",
      "jq '\n  ([.partitions[].replicas[]] | unique | add) as $sum\n  | .partitions[].replicas |= . + [$sum - add]\n' file.json"
    ],
    "utterance": "For each partition, add the missing broker from the set [3, 4, 5, 6] to the replicas array so that all partitions have all four brokers.",
    "expressions": [
      ".partitions[].replicas |= . + [18-add]",
      ".partitions[].replicas |= . + [($full | add) - add]",
      "([.partitions[].replicas[]] | unique | add) as $sum | .partitions[].replicas |= . + [$sum - add]"
    ],
    "data": [
      {
        "input": {
          "version": 1,
          "partitions": [
            {
              "topic": "my_topic_1",
              "partition": 0,
              "replicas": [
                4,
                5,
                3
              ],
              "log_dirs": [
                "any",
                "any",
                "any"
              ]
            },
            {
              "topic": "my_topic_2",
              "partition": 0,
              "replicas": [
                3,
                6,
                4
              ],
              "log_dirs": [
                "any",
                "any",
                "any"
              ]
            },
            {
              "topic": "my_topic_2",
              "partition": 1,
              "replicas": [
                6,
                4,
                5
              ],
              "log_dirs": [
                "any",
                "any",
                "any"
              ]
            }
          ]
        },
        "output": {
          "version": 1,
          "partitions": [
            {
              "topic": "my_topic_1",
              "partition": 0,
              "replicas": [
                4,
                5,
                3,
                6
              ],
              "log_dirs": [
                "any",
                "any",
                "any"
              ]
            },
            {
              "topic": "my_topic_2",
              "partition": 0,
              "replicas": [
                3,
                6,
                4,
                5
              ],
              "log_dirs": [
                "any",
                "any",
                "any"
              ]
            },
            {
              "topic": "my_topic_2",
              "partition": 1,
              "replicas": [
                6,
                4,
                5,
                3
              ],
              "log_dirs": [
                "any",
                "any",
                "any"
              ]
            }
          ]
        }
      }
    ],
    "identifier": 74573067
  },
  {
    "context": [
      "I\u2019m looking to transform the output above back to its input.",
      "Using `to_entries` could be one way:",
      "{mods: to_entries | map({name: .key, enabled: .value})}",
      "Using `keys` or `keys_unsorted` could be another:",
      "{mods: [keys_unsorted[] as $name | {name: $name, enabled: .[$name]}]}"
    ],
    "utterance": "Convert an object with arbitrary keys and boolean values into an array of objects with 'name' and 'enabled' fields, wrapped in a 'mods' property.",
    "expressions": [
      "{mods: to_entries | map({name: .key, enabled: .value})}",
      "{mods: [keys_unsorted[] as $name | {name: $name, enabled: .[$name]}]}"
    ],
    "data": [
      {
        "input": {
          "somename": true,
          "someothername": false
        },
        "output": {
          "mods": [
            {
              "name": "somename",
              "enabled": true
            },
            {
              "name": "someothername",
              "enabled": false
            }
          ]
        }
      }
    ],
    "identifier": 74584586
  },
  {
    "context": [
      "I have a list of objects (20 in total) and I need to insert a new key-value pair with the positional number  of each object (values in range 1 to 20).",
      "The expected output is:\n{\n  \"data\": {\n    \"items\": [\n      {\n        \"id\": \"items_10244-20964274\",\n        ...\n        \"ranking\": 1,\n        ...\n      },\n      ...",
      "You could exploit the circumstance that `to_entries`, when applied to an array, will use the (0-based) item index as `.key`. Add `+1` to make it 1-based.\n~~~sh\n.data.items |= [to_entries[] | .value + {ranking: (.key+1)}]\n~~~",
      "For an approach based on `range(length)`, I'd use `transpose` to zip the items array with the indices array:\n~~~sh\n.data.items |= ([., [range(length)+1]] | transpose | map(.[0] + {ranking: .[1]}))\n~~~"
    ],
    "utterance": "Add a new key called 'ranking' to each object in the items array, assigning a value equal to the object's 1-based position within the array.",
    "expressions": [
      ".data.items |= [to_entries[] | .value + {ranking: (.key+1)}]",
      ".data.items |= ([., [range(length)+1]] | transpose | map(.[0] + {ranking: .[1]}))"
    ],
    "data": [
      {
        "input": {
          "data": {
            "items": [
              {
                "id": "items_10244-20964274",
                "size": "80 ct",
                "productId": "20964274",
                "brandName": "peets",
                "brandId": "25555",
                "retailer": {
                  "isUltrafast": false,
                  "__typename": "RetailersRetailer"
                }
              },
              {
                "id": "items_10244-17284948",
                "size": "75 ct",
                "productId": "17284948",
                "legacyId": "2991007854",
                "brandName": "peet's",
                "brandId": "50954",
                "retailer": {
                  "isUltrafast": false,
                  "__typename": "RetailersRetailer"
                }
              },
              {
                "id": "items_10244-19232655",
                "size": "3 lb",
                "productId": "19232655",
                "brandName": "kirkland signature",
                "brandId": "7632",
                "retailer": {
                  "isUltrafast": false,
                  "__typename": "RetailersRetailer"
                }
              }
            ]
          }
        },
        "output": {
          "data": {
            "items": [
              {
                "id": "items_10244-20964274",
                "size": "80 ct",
                "productId": "20964274",
                "brandName": "peets",
                "brandId": "25555",
                "retailer": {
                  "isUltrafast": false,
                  "__typename": "RetailersRetailer"
                },
                "ranking": 1
              },
              {
                "id": "items_10244-17284948",
                "size": "75 ct",
                "productId": "17284948",
                "legacyId": "2991007854",
                "brandName": "peet's",
                "brandId": "50954",
                "retailer": {
                  "isUltrafast": false,
                  "__typename": "RetailersRetailer"
                },
                "ranking": 2
              },
              {
                "id": "items_10244-19232655",
                "size": "3 lb",
                "productId": "19232655",
                "brandName": "kirkland signature",
                "brandId": "7632",
                "retailer": {
                  "isUltrafast": false,
                  "__typename": "RetailersRetailer"
                },
                "ranking": 3
              }
            ]
          }
        }
      }
    ],
    "identifier": 74564460
  },
  {
    "context": [
      "I aply the add command with jq :",
      "kubectl get secret mysecret --context dev -n dev-test -o jsonpath=\\{$.data\\} | jq ' .test = \"tests\" '",
      "Now, when i call the secret again, the output is like the original and not with the adding key",
      "How can i set this new key ?",
      "Try",
      "kubectl get secret mysecret -o json | jq --arg secret_base64 \"$(echo -n tests | base64)\" '.data.test=$secret_base64' | kubectl apply -f -"
    ],
    "utterance": "Add a new key 'test' with base64-encoded value of 'tests' to the data object of a secret and persist the change",
    "expressions": [
      ".data.test = \"$secret_base64\""
    ],
    "data": [
      {
        "input": {
          "data": {
            "example1": "Rlc3QuY29taW5hZG1pbn",
            "example2": "NYXBiN3c3c1U3NFd",
            "example3": "aW5hZG1pbnRlc3QsZGM9Y29tZGM9YWQsZGM9",
            "example4": "jMDEuYWQuaW5hZG1pbnRlbGRhcDovL2luYmRc3QuY29tOjMyNjg=",
            "example5": "YWxmcmVzY28YWRtaW50ZXN0LmNvbQ==uaW1wb3J0QGlu"
          }
        },
        "output": {
          "data": {
            "example1": "Rlc3QuY29taW5hZG1pbn",
            "example2": "NYXBiN3c3c1U3NFd",
            "example3": "aW5hZG1pbnRlc3QsZGM9Y29tZGM9YWQsZGM9",
            "example4": "jMDEuYWQuaW5hZG1pbnRlbGRhcDovL2luYmRc3QuY29tOjMyNjg=",
            "example5": "YWxmcmVzY28YWRtaW50ZXN0LmNvbQ==uaW1wb3J0QGlu",
            "test": "dGVzdHM="
          }
        }
      }
    ],
    "identifier": 74576585
  },
  {
    "context": [
      "I only want isGreaterThanOne field to be shown if it's true.",
      "I want the below as the result (doesn't need to be pretty printed)",
      "[\n\t{\n\t\t\"value\": 5,\n\t\t\"X\": \"Y\"\n\t},\n\t{\n\t\t\"value\": 1,\n\t}\n\t]",
      "Using `if`, make one branch provide an empty object `{}` which wouldn&#39;t contain the extra field:\n~~~sh\nmap({value: .a} + if .a > 1 then {X: \"Y\"} else {} end)\n~~~",
      "Alternatively, equip only `select`ed items with the extra field:\n~~~sh\nmap({value: .a} | select(.value > 1).X = \"Y\")\n~~~",
      "Output:\n~~~json\n[\n  {\n    \"value\": 5,\n    \"X\": \"Y\"\n  },\n  {\n    \"value\": 1\n  }\n]\n~~~"
    ],
    "utterance": "Return an array of objects each with a field 'value', adding field 'X' with value 'Y' only if 'a' is greater than 1.",
    "expressions": [
      "map({value: .a} + if .a > 1 then {X: \"Y\"} else {} end)",
      "map({value: .a} | select(.value > 1).X = \"Y\")"
    ],
    "data": [
      {
        "input": [
          {
            "a": 5
          },
          {
            "a": 1
          }
        ],
        "output": [
          {
            "value": 5,
            "X": "Y"
          },
          {
            "value": 1
          }
        ]
      }
    ],
    "identifier": 74587054
  },
  {
    "context": [
      "The example:\r\n```\r\nProductLine:\r\n  ProductLineName: aa\r\n  ADO_FeedsList:\r\n    - organizationName: bb\r\n      Project:\r\n        - ProjectName: cc\r\n          ProjectFeedsName: \r\n          - dd\r\n          - ee\r\n        - ProjectName: ff\r\n          ProjectFeedsName:\r\n          - gg\r\n          - hh\r\n  OtherInfo: N/A\r\n```",
      "I expected the following output:\r\n```\r\nbb,cc,dd\r\nbb,cc,ee\r\nbb,ff,gg\r\nbb,ff,hh\r\n```",
      "gojq -r --yaml-input '\n.ProductLine.ADO_FeedsList[]\n| [.organizationName] + \n  ( .Project[] | [.ProjectName] + (.ProjectFeedsName[]|[.]) )\n| @csv\n'"
    ],
    "utterance": "Extract all combinations of organizationName, ProjectName, and ProjectFeedsName from a nested data structure and output each combination as a comma-separated line.",
    "expressions": [
      ".ProductLine.ADO_FeedsList[] | [.organizationName] + ( .Project[] | [.ProjectName] + (.ProjectFeedsName[] | [.]) ) | @csv",
      ".ProductLine.ADO_FeedsList[] | [.organizationName] + ( .Project[] | [.ProjectName] + (.ProjectFeedsName[] | [.]) ) | join(\",\")"
    ],
    "data": [
      {
        "input": {
          "ProductLine": {
            "ProductLineName": "aa",
            "ADO_FeedsList": [
              {
                "organizationName": "bb",
                "Project": [
                  {
                    "ProjectName": "cc",
                    "ProjectFeedsName": [
                      "dd",
                      "ee"
                    ]
                  },
                  {
                    "ProjectName": "ff",
                    "ProjectFeedsName": [
                      "gg",
                      "hh"
                    ]
                  }
                ]
              }
            ],
            "OtherInfo": "N/A"
          }
        },
        "output": [
          "bb,cc,dd",
          "bb,cc,ee",
          "bb,ff,gg",
          "bb,ff,hh"
        ]
      }
    ],
    "identifier": 74587622
  },
  {
    "context": [
      "i want to extract the key values for mfaAuthenticated , eventSource and eventType from this given json output",
      ".userIdentity.sessionContext.attributes.mfaAuthenticated,\n  .eventSource,\n  .eventType"
    ],
    "utterance": "Extract the values of mfaAuthenticated, eventSource, and eventType fields from the input where mfaAuthenticated is nested under userIdentity.sessionContext.attributes.",
    "expressions": [
      ".userIdentity.sessionContext.attributes.mfaAuthenticated, .eventSource, .eventType"
    ],
    "data": [
      {
        "input": {
          "eventVersion": "1.08",
          "userIdentity": {
            "type": "AssumedRole",
            "principalId": "XXXXXXXXXXXXXXXXX:dkboss",
            "arn": "XXXXXXXXXXXXXXXXXXXXXXXXX/dkboss",
            "accountId": "XXXXXXXXXXXXXXXX",
            "sessionContext": {
              "sessionIssuer": {
                "type": "Role",
                "principalId": "XXXXXXXXXXXXXXXXXXXXXXXXXX",
                "arn": "XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX",
                "accountId": "XXXXXXXXXXXXXXXXXXXXXXXXXXXXX",
                "userName": "XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX"
              },
              "webIdFederationData": {},
              "attributes": {
                "creationDate": "2022-11-27T15:24:28Z",
                "mfaAuthenticated": "false"
              }
            }
          },
          "eventTime": "2022-11-27T15:24:29Z",
          "eventSource": "signin.amazonaws.com",
          "eventName": "ConsoleLogin",
          "awsRegion": "us-east-1",
          "sourceIPAddress": "1.1.1.1",
          "userAgent": "XXXXXXXXXXXXXXXXXXXXXXXXXXXXXX",
          "requestParameters": null,
          "responseElements": {
            "ConsoleLogin": "Success"
          },
          "additionalEventData": {
            "MobileVersion": "No",
            "MFAUsed": "No"
          },
          "eventID": "XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX",
          "readOnly": false,
          "eventType": "AwsConsoleSignIn",
          "managementEvent": true,
          "recipientAccountId": "XXXXXXXXXXXXXXXXXXXXXXX",
          "eventCategory": "Management",
          "tlsDetails": {
            "tlsVersion": "TLSv1.2",
            "cipherSuite": "XXXXXXXXXXXXXXXXXXXXXXXXXXXXXX",
            "clientProvidedHostHeader": "signin.aws.amazon.com"
          }
        },
        "output": [
          "false",
          "signin.amazonaws.com",
          "AwsConsoleSignIn"
        ]
      }
    ],
    "identifier": 74591535
  },
  {
    "context": [
      "I just want to ask how to add the key of an object to each item of its value and convert it to an array of objects instead.",
      "What I want to achieve is this:\n\n{\n\t\"key1\" : [\n\t\t{\n\t\t\t'parent': 'key1',\n\t\t\t'key': 'key1_key1item1',\n\t\t\t'value': 'key1_item1',\n\t\t},",
      "This should do it:\n```\nwith_entries(\n    .key as $key\n    | .value |= map(\n         {parent: $key,\n          key: ($key + (tostring)), \n          value: .}) )\n```"
    ],
    "utterance": "Transform each object's array of strings so every entry becomes an object with fields: parent set to the original key, key as the key concatenated with an underscore and the string, and value as the string.",
    "expressions": [
      "with_entries(.key as $key | .value |= map({parent: $key, key: ($key + \"_\" + .), value: .}))"
    ],
    "data": [
      {
        "input": {
          "key1": [
            "key1item1",
            "key1item2",
            "key1item3"
          ],
          "key2": [
            "key2item1",
            "key2item2"
          ]
        },
        "output": {
          "key1": [
            {
              "parent": "key1",
              "key": "key1_key1item1",
              "value": "key1item1"
            },
            {
              "parent": "key1",
              "key": "key1_key1item2",
              "value": "key1item2"
            },
            {
              "parent": "key1",
              "key": "key1_key1item3",
              "value": "key1item3"
            }
          ],
          "key2": [
            {
              "parent": "key2",
              "key": "key2_key2item1",
              "value": "key2item1"
            },
            {
              "parent": "key2",
              "key": "key2_key2item2",
              "value": "key2item2"
            }
          ]
        }
      }
    ],
    "identifier": 74595941
  },
  {
    "context": [
      "I want to get following values with `jq` command.",
      "name_AAA\nname_BBB\nname_CCC\nname_DDD",
      "You can use\n```\njq -r '.[][].name' mydata.json\n```",
      "You might also wish to consider:\n\n    jq -r '..|.name?' mydata.json"
    ],
    "utterance": "Extract all name fields from objects under any group, preserving the listed order: name_AAA, name_BBB, name_CCC, name_DDD.",
    "expressions": [
      ".[][].name",
      "..|.name?"
    ],
    "data": [
      {
        "input": {
          "group1": [
            {
              "name": "name_AAA",
              "size": 1
            },
            {
              "name": "name_BBB",
              "size": 2
            }
          ],
          "group2": [
            {
              "name": "name_CCC",
              "size": 3
            },
            {
              "name": "name_DDD",
              "size": 4
            }
          ]
        },
        "output": [
          "name_AAA",
          "name_BBB",
          "name_CCC",
          "name_DDD"
        ]
      }
    ],
    "identifier": 74604351
  },
  {
    "context": [
      "\"I want to get the optional field and if it does not exist return \\\"undefined\\\"\"",
      "\"'OptionalKey : .OptionalKey // \\\"undefined\\\",'\"",
      "\"it failed with the following error:\\n\\njq: error: syntax error, unexpected //, expecting '}' (Unix shell quoting issues?)\"",
      "\"You have to group your expression with parentheses:\"",
      "\"OptionalKey : (.OptionalKey // \\\"undefined\\\")\""
    ],
    "utterance": "Output the value of OptionalKey; if it does not exist, output \"undefined\" as the value.",
    "expressions": [
      "{ tlsDetais: .tlsDetails.tlsVersion, OptionalKey: (.OptionalKey // \"undefined\") }"
    ],
    "data": [
      {
        "input": {
          "eventVersion": "1.08",
          "OptionalKey": "Optional",
          "userIdentity": {
            "type": "AssumedRole",
            "principalId": "XXXXXXXXXXXXXXXXX:dkboss",
            "arn": "XXXXXXXXXXXXXXXXXXXXXXXXX/dkboss",
            "accountId": "XXXXXXXXXXXXXXXX",
            "sessionContext": {
              "sessionIssuer": {
                "type": "Role",
                "principalId": "XXXXXXXXXXXXXXXXXXXXXXXXXX",
                "arn": "XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX",
                "accountId": "XXXXXXXXXXXXXXXXXXXXXXXXXXXXX",
                "userName": "XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX"
              },
              "webIdFederationData": {},
              "attributes": {
                "creationDate": "2022-11-27T15:24:28Z",
                "mfaAuthenticated": "false"
              }
            }
          },
          "eventTime": "2022-11-27T15:24:29Z",
          "eventSource": "signin.amazonaws.com",
          "eventName": "ConsoleLogin",
          "awsRegion": "us-east-1",
          "sourceIPAddress": "1.1.1.1",
          "userAgent": "XXXXXXXXXXXXXXXXXXXXXXXXXXXXXX",
          "requestParameters": null,
          "responseElements": {
            "ConsoleLogin": "Success"
          },
          "additionalEventData": {
            "MobileVersion": "No",
            "MFAUsed": "No"
          },
          "eventID": "XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX",
          "readOnly": false,
          "eventType": "AwsConsoleSignIn",
          "managementEvent": true,
          "recipientAccountId": "XXXXXXXXXXXXXXXXXXXXXXX",
          "eventCategory": "Management",
          "tlsDetails": {
            "tlsVersion": "TLSv1.2",
            "cipherSuite": "XXXXXXXXXXXXXXXXXXXXXXXXXXXXXX",
            "clientProvidedHostHeader": "signin.aws.amazon.com"
          }
        },
        "output": {
          "tlsDetais": "TLSv1.2",
          "OptionalKey": "Optional"
        }
      },
      {
        "input": {
          "eventVersion": "1.08",
          "userIdentity": {},
          "eventTime": "2022-11-27T15:24:29Z",
          "tlsDetails": {
            "tlsVersion": "TLSv1.2"
          }
        },
        "output": {
          "tlsDetais": "TLSv1.2",
          "OptionalKey": "undefined"
        }
      }
    ],
    "identifier": 74602745
  },
  {
    "context": [
      "I want to create html format using jq command.<br>I want to parse message field and The desired format is:\n\n|Time|User@Host|ID|Query_time|Lock_time|Rows_sent|Rows_examined|Query|",
      "This can be done with the following jq program:",
      "[\n    [\"Time\",\"User@Host\",\"ID\",\"Query time\",\"Lock time\",\"Rows sent\",\"Rows examined\",\"Query\"],\n    (\n        .events[] | .message/\"\\n\" | map(\n            (select(startswith(\"# Time: \")) | ltrimstr(\"# Time: \")),\n            (select(startswith(\"# User@Host: \")) | ltrimstr(\"# User@Host: \")/\":\" | (\n                 (first | rtrimstr(\"  Id\")),\n                 (.[-1] | tonumber | tostring)\n            )),\n            (select(startswith(\"# Query_time\"))|[splits(\" +\";\"\")][2,4,6,8])\n        )\n        + [.[3:] | join(\"\\n\")]\n    )\n]",
      "Add the html tags (named functions make the code more understandable) and make sure to use the `@html` to escape any HTML entities:"
    ],
    "utterance": "Extract tabular fields Time, User@Host, ID, Query time, Lock time, Rows sent, Rows examined, and Query from each CloudWatch Aurora MySQL log message and format the result as an HTML table.",
    "expressions": [
      "[\n    [\"Time\",\"User@Host\",\"ID\",\"Query time\",\"Lock time\",\"Rows sent\",\"Rows examined\",\"Query\"],\n    (\n        .events[] | .message/\"\\n\" | map(\n            (select(startswith(\"# Time: \")) | ltrimstr(\"# Time: \")),\n            (select(startswith(\"# User@Host: \")) | ltrimstr(\"# User@Host: \")/\":\" | (\n                 (first | rtrimstr(\"  Id\")),\n                 (.[-1] | tonumber | tostring)\n            )),\n            (select(startswith(\"# Query_time\"))|[splits(\" +\";\"\")][2,4,6,8])\n        )\n        + [.[3:] | join(\"\\n\")]\n    )\n]\n| map(map(@html))\n| .[0] |= map(\"<th>\" + . + \"</th>\")\n| .[1:][] |= map(\"<td>\" + . + \"</td>\")\n| map(\"<tr>\" + join(\"\") + \"</tr>\")\n| join(\"\")\n| \"<table>\" + . + \"</table>\""
    ],
    "data": [
      {
        "input": {
          "events": [
            {
              "ingestionTime": 1669369490368,
              "timestamp": 1669369486225,
              "message": "# Time: 2022-11-25T09:44:46.225359Z\n# User@Host: Test[Test] @  [111.111.111.111]  Id:   346\n# Query_time: 1.000765  Lock_time: 0.000000 Rows_sent: 1  Rows_examined: 0\nuse mysql;\nSET timestamp=1669369486;\nselect sleep(1);"
            },
            {
              "ingestionTime": 1669369525539,
              "timestamp": 1669369520857,
              "message": "# Time: 2022-11-25T09:45:20.857181Z\n# User@Host: Test[Test] @  [111.111.111.111]  Id:   346\n# Query_time: 1.000153  Lock_time: 0.000000 Rows_sent: 1  Rows_examined: 0\nuse testDB;\nSET timestamp=1669369520;\nselect sleep(1);"
            }
          ]
        },
        "output": "<table><tr><th>Time</th><th>User@Host</th><th>ID</th><th>Query time</th><th>Lock time</th><th>Rows sent</th><th>Rows examined</th><th>Query</th></tr><tr><td>2022-11-25T09:44:46.225359Z</td><td>Test[Test] @  [111.111.111.111]</td><td>346</td><td>1.000765</td><td>0.000000</td><td>1</td><td>0</td><td>use mysql;\nSET timestamp=1669369486;\nselect sleep(1);</td></tr><tr><td>2022-11-25T09:45:20.857181Z</td><td>Test[Test] @  [111.111.111.111]</td><td>346</td><td>1.000153</td><td>0.000000</td><td>1</td><td>0</td><td>use testDB;\nSET timestamp=1669369520;\nselect sleep(1);</td></tr></table>"
      }
    ],
    "identifier": 74571402
  },
  {
    "context": [
      "The challenge is to pick the images that have a tag whose name includes **`*prod-build*`** (a deployed production build), but then return a the tag having **no dashes** in it, which is the tag we actually use.",
      "jq '.imageDetails[] \n  | {tag: .imageTags, sha: .imageDigest, date_pushed: .imagePushedAt} \n  | select( any(.tag[]; test(\"prod-build\")?))\n  | .tag |= map(select(test(\"^[^-]+$\")? ))'",
      "jq '.imageDetails[] | select(.imageTags | any(contains(\"prod-build\"))) | {\n  tag: .imageTags | map(select(contains(\"-\") | not)),\n  sha: .imageDigest,\n  date_pushed: .imagePushedAt\n}'",
      "selects those objects with a \"prod-build\" tag and then deletes all other tags from the list.",
      ".imageDetails[]\n| {\n    tag: .imageTags,\n    sha: .imageDigest,\n    date_pushed: .imagePushedAt\n}\n| select(.tag | contains([\"prod-build\"]))\n| del(.tag[] | select(contains(\"-\")))",
      "Output:\n{\n  \"tag\": [\n    \"6debaabc26cc82a4011ea9c71854cebac7a57250\"\n  ],\n  \"sha\": \"sha256:0fae259bcfe02c8cf0ec3746aae668b3166960e7119467496df9aedfbc2c8c5b\",\n  \"date_pushed\": \"2020-12-21T03:11:52-05:00\"\n}"
    ],
    "utterance": "Return image records where any tag contains 'prod-build', but output only the tags with no dashes, along with their image digest and pushed date.",
    "expressions": [
      ".imageDetails[] | select(.imageTags | any(contains(\"prod-build\"))) | { tag: .imageTags | map(select(contains(\"-\") | not)), sha: .imageDigest, date_pushed: .imagePushedAt }",
      ".imageDetails[] | {tag: .imageTags, sha: .imageDigest, date_pushed: .imagePushedAt} | select(any(.tag[]; test(\"prod-build\")?)) | .tag |= map(select(test(\"^[^-]+$\")? ))",
      ".imageDetails[] | { tag: .imageTags, sha: .imageDigest, date_pushed: .imagePushedAt } | select(.tag | contains([\"prod-build\"])) | del(.tag[] | select(contains(\"-\")))"
    ],
    "data": [
      {
        "input": {
          "imageDetails": [
            {
              "registryId": "997652729005",
              "repositoryName": "events",
              "imageDigest": "sha256:5b649219a3abc5e903b27fd947f375df8634c883432a69e40d245ac2393d67b2",
              "imageTags": [
                "events-test-build-340"
              ],
              "imageSizeInBytes": 314454408,
              "imagePushedAt": "2021-01-12T10:42:51-05:00",
              "imageScanStatus": {
                "status": "COMPLETE",
                "description": "The scan was completed successfully."
              },
              "imageScanFindingsSummary": {
                "imageScanCompletedAt": "2021-01-12T10:43:00-05:00",
                "vulnerabilitySourceUpdatedAt": "2021-01-12T04:45:25-05:00",
                "findingSeverityCounts": {}
              },
              "imageManifestMediaType": "application/vnd.docker.distribution.manifest.v2+json",
              "artifactMediaType": "application/vnd.docker.container.image.v1+json"
            },
            {
              "registryId": "997652729005",
              "repositoryName": "events",
              "imageDigest": "sha256:0fae259bcfe02c8cf0ec3746aae668b3166960e7119467496df9aedfbc2c8c5b",
              "imageTags": [
                "6debaabc26cc82a4011ea9c71854cebac7a57250-433",
                "6debaabc26cc82a4011ea9c71854cebac7a57250",
                "6debaabc26cc82a4011ea9c71854cebac7a57250-433-dev",
                "events-prod-build-433"
              ],
              "imageSizeInBytes": 316110570,
              "imagePushedAt": "2020-12-21T03:11:52-05:00",
              "imageScanStatus": {
                "status": "COMPLETE",
                "description": "The scan was completed successfully."
              },
              "imageScanFindingsSummary": {
                "imageScanCompletedAt": "2020-12-21T03:12:02-05:00",
                "vulnerabilitySourceUpdatedAt": "2020-11-03T20:21:09-05:00",
                "findingSeverityCounts": {}
              },
              "imageManifestMediaType": "application/vnd.docker.distribution.manifest.v2+json",
              "artifactMediaType": "application/vnd.docker.container.image.v1+json"
            }
          ]
        },
        "output": {
          "tag": [
            "6debaabc26cc82a4011ea9c71854cebac7a57250"
          ],
          "sha": "sha256:0fae259bcfe02c8cf0ec3746aae668b3166960e7119467496df9aedfbc2c8c5b",
          "date_pushed": "2020-12-21T03:11:52-05:00"
        }
      }
    ],
    "identifier": 74590808
  },
  {
    "context": [
      "and I want to check each value compared to the median and print out something like \n\nAt 1am it is cheap\n...\nAt 5pm it is expensive\n...\nAt 11pm it is cheap\n...",
      "You can use `to_entries` which will use the array's index as key:\n\n.median as $median\n| .values\n| to_entries[]\n| \"At \\(.key+1) it is \\(if .value >= $median then \"expensive\" else \"cheap\" end)\"",
      "Here's one way (assuming the first entry corresponds to 12am):\n(.values | to_entries)[] as {$key, $value}\n| \"At \\($key * 3600 | strftime(\"%l %P\")) it is \\(\n    if $value < .median then \"cheap\" else \"expensive\" end\n  )\""
    ],
    "utterance": "For each hourly price value in the array, print whether it is cheap or expensive compared to the median, labeling each line with the hour in am/pm format.",
    "expressions": [
      ".median as $median | .values | to_entries[] | \"At \\(.key+1)am it is \\(if .value >= $median then \"expensive\" else \"cheap\" end)\"",
      "(.values | to_entries)[] as {$key, $value} | \"At \\($key * 3600 | strftime(\"%l %P\")) it is \\(if $value < .median then \"cheap\" else \"expensive\" end)\""
    ],
    "data": [
      {
        "input": {
          "values": [
            71.65,
            70.76,
            70.63,
            71.43,
            73.47,
            84.35,
            88.18,
            97.98,
            112.65,
            155.36,
            155.32,
            207.12,
            252.48,
            311.12,
            350.38,
            452.02,
            461.86,
            503.09,
            487.77,
            465.18,
            401.17,
            335.88,
            298.53,
            255.61
          ],
          "median": 243.08
        },
        "output": [
          "At 1am it is cheap",
          "At 2am it is cheap",
          "At 3am it is cheap",
          "At 4am it is cheap",
          "At 5am it is cheap",
          "At 6am it is cheap",
          "At 7am it is cheap",
          "At 8am it is cheap",
          "At 9am it is cheap",
          "At 10am it is cheap",
          "At 11am it is cheap",
          "At 12pm it is cheap",
          "At 1pm it is expensive",
          "At 2pm it is expensive",
          "At 3pm it is expensive",
          "At 4pm it is expensive",
          "At 5pm it is expensive",
          "At 6pm it is expensive",
          "At 7pm it is expensive",
          "At 8pm it is expensive",
          "At 9pm it is expensive",
          "At 10pm it is expensive",
          "At 11pm it is expensive",
          "At 12am it is expensive"
        ]
      }
    ],
    "identifier": 74604480
  },
  {
    "context": [
      "`aws dynamodb scan --table-name MyTable --select ALL_ATTRIBUTES --page-size 500 --max-items 100000 --output json --profile production | jq -r '.Items' | jq -r '(.[0] | keys_unsorted) as $keys | $keys, map([.[ $keys[] ].S])[] | @csv' > export.my-table.csv`",
      "parse error: Unfinished JSON term at EOF at line 5097, column 21",
      "I believe that is a query that I wrote previously that does not work on nested attributes. You will have to modify it accordingly."
    ],
    "utterance": "Output all top-level string attributes from each DynamoDB item as CSV rows, with a header row of attribute names.",
    "expressions": [
      "(.[0] | keys_unsorted) as $keys | $keys, map([.[ $keys[] ].S])[] | @csv"
    ],
    "identifier": 74615824
  },
  {
    "context": [
      "how do I get the abuse email address(es) (the `vCardArray` entry/entries with the [role](https://www.rfc-editor.org/rfc/rfc7483#section-10.2.4) set to \"abuse\", if there is any) using `jq(1)`?",
      "entities[].entities[] | select(.roles | index(\"abuse\")).vcardArray[1][] | select(.[0] == \"email\") | last",
      "Will output `\"network-abuse@google.com\"` since:\n\n* We loop over all the `.entities[].entities[]`\n* Select those where `.roles` includes an index with the value `abuse`\n* Get the fields from the vcardArray: `.vcardArray[1]`\n* Select those where the first index `.[0]` matches `email`\n* Take the last value of that array"
    ],
    "utterance": "Extract email addresses from vCardArray entries of entities whose roles include abuse.",
    "expressions": [
      ".entities[].entities[] | select(.roles | index(\"abuse\")).vcardArray[1][] | select(.[0] == \"email\") | last"
    ],
    "data": [
      {
        "input": {
          "entities": [
            {
              "entities": [
                {
                  "roles": [
                    "abuse"
                  ],
                  "vcardArray": [
                    "vcard",
                    [
                      [
                        "fn",
                        {},
                        "text",
                        "Abuse Team"
                      ],
                      [
                        "email",
                        {},
                        "text",
                        "network-abuse@google.com"
                      ]
                    ]
                  ]
                }
              ]
            }
          ]
        },
        "output": "network-abuse@google.com"
      }
    ],
    "identifier": 74613915
  },
  {
    "context": [
      "There is this OpenAPI 3.0 file that needs some dicing based on the tags (i.e. cut into as many chunks as there are items in the `tags` property.",
      "So, all the `paths` that belong to the **Rotor Parts** tag will go into the first dictionary item. And other parts will go under the second dictionary item.",
      "You could build an array of key-value pairs based on the `.tags` array, which you can eventually convert to an object using `from_entries`. Use `del` to delete what you don't want to be included.",
      "[.tags[] as $tag | {key: \"tag_\\($tag.name | gsub(\" \"; \"\"))\", value: del(\n  \n  .openapi,\n  (.tags[] | select(. != $tag)),\n  (.paths[] | select(IN(.[].tags[]; $tag.name) | not))\n  \n)}] | from_entries",
      "Here is a solution that looks like it works:",
      ". as {$info, $paths}\n| .tags\n| map(\n    . as $tag\n    | (.name |= \"tag_\" + gsub(\" \"; \"\"))\n    | .value = {\n        $info,\n        tags: [ $tag ],\n        paths: $paths | map_values(\n            with_entries(select(IN(.value.tags[]; $tag.name)))\n            | select(length > 0)\n        )\n    }\n)\n| from_entries",
      "Here\u2019s an expected output:",
      "{\n  \"tag_RotorParts\": {\n    \"info\": \"same content here\",\n    \"tags\": [\n      {\n        \"name\": \"Rotor Parts\",\n        \"description\": \"Rotor Parts API\"\n      }\n    ],\n    \"paths\": {\n      \"/access_keys\": {\n        \"get\": {\n          \"tags\": [\n            \"Rotor Parts\"\n          ],\n          // ..."
    ],
    "utterance": "Split an OpenAPI data object into separate objects for each tag, so that each object contains only the paths and tags matching that tag, and the object's key is the tag name with spaces removed and prefixed with 'tag_'.",
    "expressions": [
      "[.tags[] as $tag | {key: \"tag_\\($tag.name | gsub(\" \"; \"\"))\", value: del(\n  \n  .openapi,\n  (.tags[] | select(. != $tag)),\n  (.paths[] | select(IN(.[].tags[]; $tag.name) | not))\n  \n)}] | from_entries",
      ". as {$info, $paths}\n| .tags\n| map(\n    . as $tag\n    | (.name |= \"tag_\" + gsub(\" \"; \"\"))\n    | .value = {\n        $info,\n        tags: [ $tag ],\n        paths: $paths | map_values(\n            with_entries(select(IN(.value.tags[]; $tag.name)))\n            | select(length > 0)\n        )\n    }\n)\n| from_entries",
      "def group(k):\n  group_by(k) | map({key:first|k, value:.}) | from_entries;\n\n. as {$info}\n| INDEX(.tags[];.name) as $tags # lookup table for tags by name\n| .paths\n| to_entries\n| group(.value[].tags[]) # group paths by their tags\n| with_entries(\n    [$tags[.key]] as $tags\n    | .key |= \"tag_\" + gsub(\" \"; \"\")  # fix property names\n    | .value |= { $info, $tags, paths: from_entries } # transform to result\n)",
      "def selection($tag):\n    map_values(\n      if type == \"object\" \n      then with_entries(\n             select(.value | objects | select(.tags) | .tags | index($tag)))\n      else .\n      end );\n\n[range(0; .tags|length) as $i\n | (.tags[$i].name) as $tag\n | {\"tag_\\($tag|gsub(\" \";\"\"))\": \n       { info,\n         tags: [.tags[$i]],\n         paths: (.paths | selection($tag ) | with_entries(select(.value != {})) )\n       }\n     } ] \n| add"
    ],
    "data": [
      {
        "input": {
          "openapi": "3.0.0",
          "info": {
            "description": "PREST APIs for external use.",
            "version": "v1",
            "title": "REST API Doc",
            "contact": {},
            "license": {
              "name": "Public"
            }
          },
          "tags": [
            {
              "name": "Rotor Parts",
              "description": "Rotor Parts API"
            },
            {
              "name": "Cloud Accounts",
              "description": "Plant Locations APIs"
            }
          ],
          "paths": {
            "/access_keys": {
              "get": {
                "tags": [
                  "Rotor Parts"
                ],
                "summary": "List Rotor Parts",
                "description": "Returns all rotor parts if you have an Admin role. Returns just your rotor parts if you don't have this role.",
                "operationId": "get-my-rotor-parts",
                "responses": {
                  "200": {
                    "description": "successful operation",
                    "content": {
                      "application/json": {
                        "schema": {
                          "type": "array",
                          "items": {
                            "$ref": "#/components/schemas/RotorPartsResponseModel"
                          }
                        }
                      }
                    }
                  },
                  "400": {
                    "description": "user_inactive_or_not_exist"
                  },
                  "403": {
                    "description": "unauthorized_to_use_rotor_parts"
                  },
                  "500": {
                    "description": "failed_fetch_user_profile"
                  }
                }
              },
              "post": {
                "tags": [
                  "Rotor Parts"
                ],
                "summary": "Add Rotor Parts",
                "description": "Adds a new rotor part for the current user. If you have API access, you can create up to two rotor parts.",
                "operationId": "add-rotor-parts",
                "requestBody": {
                  "content": {
                    "application/json": {
                      "schema": {
                        "$ref": "#/components/schemas/UserRotorPartRequestModel"
                      }
                    }
                  },
                  "description": "Model user rotor part model",
                  "required": true
                },
                "responses": {
                  "200": {
                    "description": "successful operation",
                    "content": {
                      "application/json": {
                        "schema": {
                          "$ref": "#/components/schemas/CreateUserAccessKeyResponseModel"
                        }
                      }
                    }
                  },
                  "400": {
                    "description": "invalid_expiry_access_key / already_have_two_access_keys / invalid_access_key_name_length / invalid_access_key_name"
                  },
                  "403": {
                    "description": "unauthorized_to_use_access_keys"
                  },
                  "409": {
                    "description": "duplicate_access_key_name"
                  }
                }
              }
            },
            "/account/{accountId}/config/status": {
              "get": {
                "tags": [
                  "Cloud Accounts"
                ],
                "summary": "List Account Status Details",
                "description": "Returns a list of Cloud services whose status indicates a warning or error for the given cloud account ID. Includes status details for each listed service.",
                "operationId": "list-cloud-account-status-details",
                "parameters": [
                  {
                    "name": "accountId",
                    "in": "path",
                    "description": "Cloud account ID",
                    "required": true,
                    "schema": {
                      "type": "string"
                    }
                  }
                ],
                "responses": {
                  "200": {
                    "description": "successful operation",
                    "content": {
                      "application/json; charset=UTF-8": {
                        "schema": {
                          "type": "array",
                          "items": {
                            "$ref": "#/components/schemas/CloudAccountConfigStatusView"
                          }
                        }
                      }
                    }
                  },
                  "400": {
                    "description": "bad_request"
                  },
                  "500": {
                    "description": "internal_error"
                  }
                }
              }
            }
          }
        },
        "output": {
          "tag_RotorParts": {
            "info": {
              "description": "PREST APIs for external use.",
              "version": "v1",
              "title": "REST API Doc",
              "contact": {},
              "license": {
                "name": "Public"
              }
            },
            "tags": [
              {
                "name": "Rotor Parts",
                "description": "Rotor Parts API"
              }
            ],
            "paths": {
              "/access_keys": {
                "get": {
                  "tags": [
                    "Rotor Parts"
                  ],
                  "summary": "List Rotor Parts",
                  "description": "Returns all rotor parts if you have an Admin role. Returns just your rotor parts if you don't have this role.",
                  "operationId": "get-my-rotor-parts",
                  "responses": {
                    "200": {
                      "description": "successful operation",
                      "content": {
                        "application/json": {
                          "schema": {
                            "type": "array",
                            "items": {
                              "$ref": "#/components/schemas/RotorPartsResponseModel"
                            }
                          }
                        }
                      }
                    },
                    "400": {
                      "description": "user_inactive_or_not_exist"
                    },
                    "403": {
                      "description": "unauthorized_to_use_rotor_parts"
                    },
                    "500": {
                      "description": "failed_fetch_user_profile"
                    }
                  }
                },
                "post": {
                  "tags": [
                    "Rotor Parts"
                  ],
                  "summary": "Add Rotor Parts",
                  "description": "Adds a new rotor part for the current user. If you have API access, you can create up to two rotor parts.",
                  "operationId": "add-rotor-parts",
                  "requestBody": {
                    "content": {
                      "application/json": {
                        "schema": {
                          "$ref": "#/components/schemas/UserRotorPartRequestModel"
                        }
                      }
                    },
                    "description": "Model user rotor part model",
                    "required": true
                  },
                  "responses": {
                    "200": {
                      "description": "successful operation",
                      "content": {
                        "application/json": {
                          "schema": {
                            "$ref": "#/components/schemas/CreateUserAccessKeyResponseModel"
                          }
                        }
                      }
                    },
                    "400": {
                      "description": "invalid_expiry_access_key / already_have_two_access_keys / invalid_access_key_name_length / invalid_access_key_name"
                    },
                    "403": {
                      "description": "unauthorized_to_use_access_keys"
                    },
                    "409": {
                      "description": "duplicate_access_key_name"
                    }
                  }
                }
              }
            }
          },
          "tag_CloudAccounts": {
            "info": {
              "description": "PREST APIs for external use.",
              "version": "v1",
              "title": "REST API Doc",
              "contact": {},
              "license": {
                "name": "Public"
              }
            },
            "tags": [
              {
                "name": "Cloud Accounts",
                "description": "Plant Locations APIs"
              }
            ],
            "paths": {
              "/account/{accountId}/config/status": {
                "get": {
                  "tags": [
                    "Cloud Accounts"
                  ],
                  "summary": "List Account Status Details",
                  "description": "Returns a list of Cloud services whose status indicates a warning or error for the given cloud account ID. Includes status details for each listed service.",
                  "operationId": "list-cloud-account-status-details",
                  "parameters": [
                    {
                      "name": "accountId",
                      "in": "path",
                      "description": "Cloud account ID",
                      "required": true,
                      "schema": {
                        "type": "string"
                      }
                    }
                  ],
                  "responses": {
                    "200": {
                      "description": "successful operation",
                      "content": {
                        "application/json; charset=UTF-8": {
                          "schema": {
                            "type": "array",
                            "items": {
                              "$ref": "#/components/schemas/CloudAccountConfigStatusView"
                            }
                          }
                        }
                      }
                    },
                    "400": {
                      "description": "bad_request"
                    },
                    "500": {
                      "description": "internal_error"
                    }
                  }
                }
              }
            }
          }
        }
      }
    ],
    "identifier": 74424368
  },
  {
    "context": [
      "I need a jq filter to select ONLY those methods marked with \"x-visibility\": \"public\" and leave everything else out.",
      ".paths |= map_values(map_values(select(.\"x-visibility\" == \"public\")))",
      ".paths |= map_values(\n    map_values(select(.\"x-visibility\" == \"public\"))\n    | select(. != {})\n)",
      ".paths |= map_values(\n    map_values(select(.\"x-visibility\" == \"public\"))\n    | select(length > 0)\n)",
      ".paths |= map_values(\n    map_values(select(.\"x-visibility\" == \"public\"))\n    | select(any)\n)"
    ],
    "utterance": "Keep only methods under all paths where x-visibility is exactly public.",
    "expressions": [
      ".paths |= map_values(map_values(select(.\"x-visibility\" == \"public\")))",
      ".paths |= map_values(\n    map_values(select(.\"x-visibility\" == \"public\"))\n    | select(. != {})\n)",
      ".paths |= map_values(\n    map_values(select(.\"x-visibility\" == \"public\"))\n    | select(length > 0)\n)",
      ".paths |= map_values(\n    map_values(select(.\"x-visibility\" == \"public\"))\n    | select(any)\n)"
    ],
    "data": [
      {
        "input": {
          "openapi": "3.0.1",
          "info": {
            "title": "API service",
            "description": "Exposing useful methods",
            "x-descriptionForPublicDocs": "This is a test description for public docs specifically",
            "contact": {
              "name": "Message me",
              "url": "https://message.me"
            },
            "version": "1.0"
          },
          "servers": [
            {
              "url": "http://localhost:9090",
              "description": "Generated server url"
            }
          ],
          "tags": [
            {
              "name": "AccountGroups"
            }
          ],
          "x-tags": [
            {
              "name": "TestResourceLists"
            }
          ],
          "paths": {
            "/crane/v1/resource_list/{id}": {
              "get": {
                "tags": [
                  "ResourceLists"
                ],
                "x-tags": "TestResourceLists",
                "x-visibility": "public",
                "summary": "Get Resource List by ID",
                "description": "Returns the resource list that has the specified ID.",
                "operationId": "getById",
                "parameters": [
                  {
                    "name": "id",
                    "in": "path",
                    "description": "ResourceList Id",
                    "required": true,
                    "schema": {
                      "type": "string"
                    }
                  }
                ],
                "responses": {
                  "200": {
                    "description": "Successful operation",
                    "content": {
                      "application/json; charset=UTF-8": {
                        "schema": {
                          "$ref": "#/components/schemas/ResourceListModel"
                        }
                      }
                    }
                  },
                  "400": {
                    "description": "Bad Request",
                    "content": {
                      "*/*": {
                        "schema": {
                          "type": "object"
                        }
                      }
                    }
                  },
                  "403": {
                    "description": "Forbidden",
                    "content": {
                      "*/*": {
                        "schema": {
                          "type": "object"
                        }
                      }
                    }
                  },
                  "500": {
                    "description": "Internal Server Error",
                    "content": {
                      "*/*": {
                        "schema": {
                          "type": "object"
                        }
                      }
                    }
                  },
                  "4XX": {
                    "description": "Client error",
                    "content": {
                      "application/json; charset=UTF-8": {
                        "schema": {
                          "$ref": "#/components/schemas/SpringErrorResponse"
                        }
                      }
                    }
                  }
                }
              },
              "put": {
                "tags": [
                  "ResourceLists"
                ],
                "x-visibility": "internal",
                "summary": "Update Resource List",
                "description": "Updates the resource list that has the specified ID.",
                "operationId": "update",
                "parameters": [
                  {
                    "name": "id",
                    "in": "path",
                    "description": "ResourceList Id",
                    "required": true,
                    "schema": {
                      "type": "string"
                    }
                  }
                ],
                "requestBody": {
                  "description": "Model for Resource List",
                  "content": {
                    "application/json": {
                      "schema": {
                        "$ref": "#/components/schemas/ResourceListModel"
                      },
                      "examples": {
                        "TAG": {
                          "description": "Tag ResourceList",
                          "value": {
                            "members": [
                              {
                                "string": "string"
                              }
                            ],
                            "name": "string",
                            "resourceListType": "TAG",
                            "description": "string"
                          }
                        },
                        "RESOURCE_GROUP": {
                          "description": "RESOURCE_GROUP ResourceList",
                          "value": {
                            "description": "string",
                            "members": [
                              "string",
                              "string"
                            ],
                            "name": "string",
                            "resourceListType": "RESOURCE_GROUP"
                          }
                        },
                        "COMPUTE_ACCESS_GROUP": {
                          "description": "COMPUTE_ACCESS_GROUP ResourceList",
                          "value": {
                            "description": "string",
                            "members": [
                              {
                                "appIDs": [
                                  "*"
                                ],
                                "clusters": [
                                  "*"
                                ],
                                "codeRepos": [
                                  "*"
                                ],
                                "containers": [
                                  "*"
                                ],
                                "functions": [
                                  "*"
                                ],
                                "hosts": [
                                  "*"
                                ],
                                "images": [
                                  "*"
                                ],
                                "labels": [
                                  "*"
                                ],
                                "namespaces": [
                                  "*"
                                ]
                              }
                            ],
                            "name": "string",
                            "resourceListType": "COMPUTE_ACCESS_GROUP"
                          }
                        }
                      }
                    }
                  },
                  "required": true
                },
                "responses": {
                  "200": {
                    "description": "Successful operation",
                    "content": {
                      "application/json; charset=UTF-8": {
                        "schema": {
                          "$ref": "#/components/schemas/ResourceListModel"
                        }
                      }
                    }
                  },
                  "400": {
                    "description": "Bad Request",
                    "content": {
                      "*/*": {
                        "schema": {
                          "type": "object"
                        }
                      }
                    }
                  },
                  "403": {
                    "description": "Forbidden",
                    "content": {
                      "*/*": {
                        "schema": {
                          "type": "object"
                        }
                      }
                    }
                  },
                  "500": {
                    "description": "Internal Server Error",
                    "content": {
                      "*/*": {
                        "schema": {
                          "type": "object"
                        }
                      }
                    }
                  },
                  "4XX": {
                    "description": "Client error",
                    "content": {
                      "application/json; charset=UTF-8": {
                        "schema": {
                          "$ref": "#/components/schemas/SpringErrorResponse"
                        }
                      }
                    }
                  }
                }
              },
              "delete": {
                "tags": [
                  "ResourceLists"
                ],
                "x-visibility": "internal",
                "summary": "Delete Resource List",
                "description": "Deletes the resource list that has the specified ID.",
                "operationId": "delete",
                "parameters": [
                  {
                    "name": "id",
                    "in": "path",
                    "description": "ResourceList Id",
                    "required": true,
                    "schema": {
                      "type": "string"
                    }
                  }
                ],
                "responses": {
                  "204": {
                    "description": "Successful operation"
                  },
                  "400": {
                    "description": "Bad Request",
                    "content": {
                      "*/*": {
                        "schema": {
                          "type": "object"
                        }
                      }
                    }
                  },
                  "403": {
                    "description": "Forbidden",
                    "content": {
                      "*/*": {
                        "schema": {
                          "type": "object"
                        }
                      }
                    }
                  },
                  "500": {
                    "description": "Internal Server Error",
                    "content": {
                      "*/*": {
                        "schema": {
                          "type": "object"
                        }
                      }
                    }
                  },
                  "4XX": {
                    "description": "Client error",
                    "content": {
                      "application/json; charset=UTF-8": {
                        "schema": {
                          "$ref": "#/components/schemas/SpringErrorResponse"
                        }
                      }
                    }
                  }
                }
              }
            },
            "/crane/v1/account_group/{id}": {
              "get": {
                "tags": [
                  "AccountGroups"
                ],
                "x-visibility": "public",
                "summary": "Get resource",
                "description": "Returns something",
                "operationId": "getById_1",
                "parameters": [
                  {
                    "name": "id",
                    "in": "path",
                    "description": "Account Group ID",
                    "required": true,
                    "schema": {
                      "type": "string"
                    }
                  },
                  {
                    "name": "includeAccountInfo",
                    "in": "query",
                    "description": "Include Cloud Account details",
                    "required": false,
                    "schema": {
                      "type": "boolean"
                    }
                  }
                ],
                "responses": {
                  "200": {
                    "description": "Successful operation",
                    "content": {
                      "application/json": {
                        "schema": {
                          "$ref": "#/components/schemas/AccountGroupModel"
                        }
                      }
                    }
                  },
                  "400": {
                    "description": "Bad Request",
                    "content": {
                      "*/*": {
                        "schema": {
                          "type": "object"
                        }
                      }
                    }
                  },
                  "403": {
                    "description": "Forbidden",
                    "content": {
                      "*/*": {
                        "schema": {
                          "type": "object"
                        }
                      }
                    }
                  },
                  "500": {
                    "description": "Internal Server Error",
                    "content": {
                      "*/*": {
                        "schema": {
                          "type": "object"
                        }
                      }
                    }
                  },
                  "4XX": {
                    "description": "Client error",
                    "content": {
                      "application/json; charset=UTF-8": {
                        "schema": {
                          "$ref": "#/components/schemas/SpringErrorResponse"
                        }
                      }
                    }
                  }
                }
              },
              "put": {
                "tags": [
                  "AccountGroups"
                ],
                "x-visibility": "internal",
                "summary": "Update resource",
                "description": "Update information",
                "operationId": "update_1",
                "parameters": [
                  {
                    "name": "id",
                    "in": "path",
                    "description": "AccountGroup Id",
                    "required": true,
                    "schema": {
                      "type": "string"
                    }
                  }
                ],
                "requestBody": {
                  "content": {
                    "application/json; charset=UTF-8": {
                      "schema": {
                        "$ref": "#/components/schemas/AccountGroupModel"
                      }
                    }
                  },
                  "required": true
                },
                "responses": {
                  "200": {
                    "description": "Successful operation"
                  },
                  "400": {
                    "description": "Bad Request",
                    "content": {
                      "*/*": {
                        "schema": {
                          "type": "object"
                        }
                      }
                    }
                  },
                  "403": {
                    "description": "Forbidden",
                    "content": {
                      "*/*": {
                        "schema": {
                          "type": "object"
                        }
                      }
                    }
                  },
                  "500": {
                    "description": "Internal Server Error",
                    "content": {
                      "*/*": {
                        "schema": {
                          "type": "object"
                        }
                      }
                    }
                  },
                  "4XX": {
                    "description": "Client error",
                    "content": {
                      "application/json; charset=UTF-8": {
                        "schema": {
                          "$ref": "#/components/schemas/SpringErrorResponse"
                        }
                      }
                    }
                  }
                }
              },
              "delete": {
                "tags": [
                  "AccountGroups"
                ],
                "x-visibility": "internal",
                "summary": "Delete resource",
                "description": "Deletes the resource",
                "operationId": "delete_1",
                "parameters": [
                  {
                    "name": "id",
                    "in": "path",
                    "description": "Delete resource",
                    "required": true,
                    "schema": {
                      "type": "string"
                    }
                  }
                ],
                "responses": {
                  "200": {
                    "description": "Successful operation"
                  },
                  "400": {
                    "description": "Bad Request",
                    "content": {
                      "*/*": {
                        "schema": {
                          "type": "object"
                        }
                      }
                    }
                  },
                  "403": {
                    "description": "Forbidden",
                    "content": {
                      "*/*": {
                        "schema": {
                          "type": "object"
                        }
                      }
                    }
                  },
                  "500": {
                    "description": "Internal Server Error",
                    "content": {
                      "*/*": {
                        "schema": {
                          "type": "object"
                        }
                      }
                    }
                  },
                  "4XX": {
                    "description": "Client error",
                    "content": {
                      "application/json; charset=UTF-8": {
                        "schema": {
                          "$ref": "#/components/schemas/SpringErrorResponse"
                        }
                      }
                    }
                  }
                }
              }
            }
          }
        },
        "output": {
          "openapi": "3.0.1",
          "info": {
            "title": "API service",
            "description": "Exposing useful methods",
            "x-descriptionForPublicDocs": "This is a test description for public docs specifically",
            "contact": {
              "name": "Message me",
              "url": "https://message.me"
            },
            "version": "1.0"
          },
          "servers": [
            {
              "url": "http://localhost:9090",
              "description": "Generated server url"
            }
          ],
          "tags": [
            {
              "name": "AccountGroups"
            }
          ],
          "x-tags": [
            {
              "name": "TestResourceLists"
            }
          ],
          "paths": {
            "/crane/v1/resource_list/{id}": {
              "get": {
                "tags": [
                  "ResourceLists"
                ],
                "x-tags": "TestResourceLists",
                "x-visibility": "public",
                "summary": "Get Resource List by ID",
                "description": "Returns the resource list that has the specified ID.",
                "operationId": "getById",
                "parameters": [
                  {
                    "name": "id",
                    "in": "path",
                    "description": "ResourceList Id",
                    "required": true,
                    "schema": {
                      "type": "string"
                    }
                  }
                ],
                "responses": {
                  "200": {
                    "description": "Successful operation",
                    "content": {
                      "application/json; charset=UTF-8": {
                        "schema": {
                          "$ref": "#/components/schemas/ResourceListModel"
                        }
                      }
                    }
                  },
                  "400": {
                    "description": "Bad Request",
                    "content": {
                      "*/*": {
                        "schema": {
                          "type": "object"
                        }
                      }
                    }
                  },
                  "403": {
                    "description": "Forbidden",
                    "content": {
                      "*/*": {
                        "schema": {
                          "type": "object"
                        }
                      }
                    }
                  },
                  "500": {
                    "description": "Internal Server Error",
                    "content": {
                      "*/*": {
                        "schema": {
                          "type": "object"
                        }
                      }
                    }
                  },
                  "4XX": {
                    "description": "Client error",
                    "content": {
                      "application/json; charset=UTF-8": {
                        "schema": {
                          "$ref": "#/components/schemas/SpringErrorResponse"
                        }
                      }
                    }
                  }
                }
              }
            },
            "/crane/v1/account_group/{id}": {
              "get": {
                "tags": [
                  "AccountGroups"
                ],
                "x-visibility": "public",
                "summary": "Get resource",
                "description": "Returns something",
                "operationId": "getById_1",
                "parameters": [
                  {
                    "name": "id",
                    "in": "path",
                    "description": "Account Group ID",
                    "required": true,
                    "schema": {
                      "type": "string"
                    }
                  },
                  {
                    "name": "includeAccountInfo",
                    "in": "query",
                    "description": "Include Cloud Account details",
                    "required": false,
                    "schema": {
                      "type": "boolean"
                    }
                  }
                ],
                "responses": {
                  "200": {
                    "description": "Successful operation",
                    "content": {
                      "application/json": {
                        "schema": {
                          "$ref": "#/components/schemas/AccountGroupModel"
                        }
                      }
                    }
                  },
                  "400": {
                    "description": "Bad Request",
                    "content": {
                      "*/*": {
                        "schema": {
                          "type": "object"
                        }
                      }
                    }
                  },
                  "403": {
                    "description": "Forbidden",
                    "content": {
                      "*/*": {
                        "schema": {
                          "type": "object"
                        }
                      }
                    }
                  },
                  "500": {
                    "description": "Internal Server Error",
                    "content": {
                      "*/*": {
                        "schema": {
                          "type": "object"
                        }
                      }
                    }
                  },
                  "4XX": {
                    "description": "Client error",
                    "content": {
                      "application/json; charset=UTF-8": {
                        "schema": {
                          "$ref": "#/components/schemas/SpringErrorResponse"
                        }
                      }
                    }
                  }
                }
              }
            }
          }
        }
      }
    ],
    "identifier": 74382992
  },
  {
    "context": [
      "Goal: Remove an outer array from what {was a valid JSON} on the outside.",
      "run `cat file.json | jq .rows`",
      "Observe works OK",
      "try `cat file.json | jq .rows[]`",
      "However, if you don&#39;t want to, you can use the &#39;*Precommand Modifier `noglob`*&#39; ... so:\n```\nnoglob jq .rows[] input\n```\nWill work just fine.",
      "You need to escape or quote so that `.rows[]` is passed to `jq`. \n\n```sh\njq &#39;.rows[]&#39; file.json\n```"
    ],
    "utterance": "Output each object from the top-level 'rows' array as a separate result.",
    "expressions": [
      ".rows[]",
      "'.rows[]'"
    ],
    "data": [
      {
        "input": {
          "selfLink": null,
          "id": "eyJwIjoiOGMxZjRkNjAtZDhmNS00YmU2LTg1YjMtYTA0NDExNDVkYmMwIiwicFYiOjE0fQ==",
          "title": "My Daily Discovery",
          "rows": [
            {
              "modules": [
                {
                  "id": "eyJwIjoiOGMxZjRkNjAtZDhmNS00YmU2LTg1YjMtYTA0NDExNDVkYmMwIiwicFYiOjE0LCJtIjoiMTg3ZGVhMTMtNWI1ZS00OWYwLWI5YjktYjc5ODk3M2M2MjVmIiwibVYiOjEsIm1IIjoiYmMyMTQ4NDkifQ==",
                  "type": "MIX_HEADER",
                  "width": 100,
                  "title": "",
                  "description": "",
                  "preTitle": "",
                  "mix": {
                    "id": "016574ac3abf29b2a6a1ae2c1b2f34",
                    "title": "My Daily Discovery",
                    "subTitle": "Songs by new and familiar artists inspired by your listening. Updates every morning.",
                    "graphic": {
                      "type": "SQUARES_GRID",
                      "text": "My Daily Discovery",
                      "images": [
                        {
                          "id": "dummy-placeholder",
                          "vibrantColor": "#FFFFFF",
                          "type": "ARTIST"
                        }
                      ]
                    },
                    "images": {
                      "SMALL": {
                        "width": 320,
                        "height": 320,
                        "url": "https://images.tidal.com/0/EMACGMAC/CAEQCCIDMzI2KgcjRjlBMTkyMAQ?token=03c55020deef749a0a7608833cebe3ae2f8f33f6"
                      },
                      "MEDIUM": {
                        "width": 640,
                        "height": 640,
                        "url": "https://images.tidal.com/0/EIAFGIAF/CAEQCCIDMzI2KgcjRjlBMTkyMAQ?token=c391f21c624d0b58f4badc2185211b89eb2cee7f"
                      },
                      "LARGE": {
                        "width": 1500,
                        "height": 1500,
                        "url": "https://images.tidal.com/0/ENwLGNwL/CAEQCCIDMzI2KgcjRjlBMTkyMAQ?token=b055bb723e064256026fcb7d17a6dfa6ef839c25"
                      }
                    },
                    "sharingImages": null,
                    "mixType": "DISCOVERY_MIX",
                    "mixNumber": null,
                    "contentBehavior": "UNRESTRICTED",
                    "shortSubtitle": null,
                    "master": false,
                    "titleColor": "#F9A192",
                    "subTitleColor": "#F9A192",
                    "detailImages": {
                      "SMALL": {
                        "width": 320,
                        "height": 320,
                        "url": "https://images.tidal.com/0/EMACGMAC/CAEQCCIDMzI2KgcjRjlBMTkyMAQ4AQ?token=2d26406e237b5f9e830cac45b7ec6470ce71638f"
                      },
                      "MEDIUM": {
                        "width": 640,
                        "height": 640,
                        "url": "https://images.tidal.com/0/EIAFGIAF/CAEQCCIDMzI2KgcjRjlBMTkyMAQ4AQ?token=9406f1c8bc4061c7841f35156b0f81e9dc961d0b"
                      },
                      "LARGE": {
                        "width": 1500,
                        "height": 1500,
                        "url": "https://images.tidal.com/0/ENwLGNwL/CAEQCCIDMzI2KgcjRjlBMTkyMAQ4AQ?token=b8eb265be431640046cb1b376715d0ceaef19677"
                      }
                    }
                  },
                  "playbackControls": [
                    {
                      "shuffle": false,
                      "playbackMode": "PLAY",
                      "title": "Play",
                      "icon": "play_tracks",
                      "targetModuleId": "eyJwIjoiOGMxZjRkNjAtZDhmNS00YmU2LTg1YjMtYTA0NDExNDVkYmMwIiwicFYiOjE0LCJtIjoiNmU5OWY3ZjUtMDk4My00Mzk5LWFkYjEtZDk2NzRmMGQ2ZDQ5IiwibVYiOjEsIm1IIjoiNDgyMDRjMGMifQ=="
                    },
                    {
                      "shuffle": true,
                      "playbackMode": "SHUFFLE",
                      "title": "Shuffle",
                      "icon": "shuffle_tracks",
                      "targetModuleId": "eyJwIjoiOGMxZjRkNjAtZDhmNS00YmU2LTg1YjMtYTA0NDExNDVkYmMwIiwicFYiOjE0LCJtIjoiNmU5OWY3ZjUtMDk4My00Mzk5LWFkYjEtZDk2NzRmMGQ2ZDQ5IiwibVYiOjEsIm1IIjoiNDgyMDRjMGMifQ=="
                    }
                  ]
                }
              ]
            },
            {
              "modules": [
                {
                  "id": "eyJwIjoiOGMxZjRkNjAtZDhmNS00YmU2LTg1YjMtYTA0NDExNDVkYmMwIiwicFYiOjE0LCJtIjoiNmU5OWY3ZjUtMDk4My00Mzk5LWFkYjEtZDk2NzRmMGQ2ZDQ5IiwibVYiOjEsIm1IIjoiNDgyMDRjMGMifQ==",
                  "type": "TRACK_LIST",
                  "width": 100,
                  "title": "",
                  "description": "",
                  "preTitle": null,
                  "showMore": null,
                  "supportsPaging": false,
                  "quickPlay": false,
                  "listFormat": "COVERS",
                  "scroll": "VERTICAL",
                  "layout": "LIST",
                  "pagedList": {
                    "limit": 10,
                    "offset": 0,
                    "totalNumberOfItems": 10,
                    "items": [
                      {
                        "id": 182220043,
                        "title": "Hippies and Cowboys"
                      }
                    ]
                  },
                  "showTableHeaders": true
                }
              ]
            }
          ]
        },
        "output": [
          {
            "modules": [
              {
                "id": "eyJwIjoiOGMxZjRkNjAtZDhmNS00YmU2LTg1YjMtYTA0NDExNDVkYmMwIiwicFYiOjE0LCJtIjoiMTg3ZGVhMTMtNWI1ZS00OWYwLWI5YjktYjc5ODk3M2M2MjVmIiwibVYiOjEsIm1IIjoiYmMyMTQ4NDkifQ==",
                "type": "MIX_HEADER",
                "width": 100,
                "title": "",
                "description": "",
                "preTitle": "",
                "mix": {
                  "id": "016574ac3abf29b2a6a1ae2c1b2f34",
                  "title": "My Daily Discovery",
                  "subTitle": "Songs by new and familiar artists inspired by your listening. Updates every morning.",
                  "graphic": {
                    "type": "SQUARES_GRID",
                    "text": "My Daily Discovery",
                    "images": [
                      {
                        "id": "dummy-placeholder",
                        "vibrantColor": "#FFFFFF",
                        "type": "ARTIST"
                      }
                    ]
                  },
                  "images": {
                    "SMALL": {
                      "width": 320,
                      "height": 320,
                      "url": "https://images.tidal.com/0/EMACGMAC/CAEQCCIDMzI2KgcjRjlBMTkyMAQ?token=03c55020deef749a0a7608833cebe3ae2f8f33f6"
                    },
                    "MEDIUM": {
                      "width": 640,
                      "height": 640,
                      "url": "https://images.tidal.com/0/EIAFGIAF/CAEQCCIDMzI2KgcjRjlBMTkyMAQ?token=c391f21c624d0b58f4badc2185211b89eb2cee7f"
                    },
                    "LARGE": {
                      "width": 1500,
                      "height": 1500,
                      "url": "https://images.tidal.com/0/ENwLGNwL/CAEQCCIDMzI2KgcjRjlBMTkyMAQ?token=b055bb723e064256026fcb7d17a6dfa6ef839c25"
                    }
                  },
                  "sharingImages": null,
                  "mixType": "DISCOVERY_MIX",
                  "mixNumber": null,
                  "contentBehavior": "UNRESTRICTED",
                  "shortSubtitle": null,
                  "master": false,
                  "titleColor": "#F9A192",
                  "subTitleColor": "#F9A192",
                  "detailImages": {
                    "SMALL": {
                      "width": 320,
                      "height": 320,
                      "url": "https://images.tidal.com/0/EMACGMAC/CAEQCCIDMzI2KgcjRjlBMTkyMAQ4AQ?token=2d26406e237b5f9e830cac45b7ec6470ce71638f"
                    },
                    "MEDIUM": {
                      "width": 640,
                      "height": 640,
                      "url": "https://images.tidal.com/0/EIAFGIAF/CAEQCCIDMzI2KgcjRjlBMTkyMAQ4AQ?token=9406f1c8bc4061c7841f35156b0f81e9dc961d0b"
                    },
                    "LARGE": {
                      "width": 1500,
                      "height": 1500,
                      "url": "https://images.tidal.com/0/ENwLGNwL/CAEQCCIDMzI2KgcjRjlBMTkyMAQ4AQ?token=b8eb265be431640046cb1b376715d0ceaef19677"
                    }
                  }
                },
                "playbackControls": [
                  {
                    "shuffle": false,
                    "playbackMode": "PLAY",
                    "title": "Play",
                    "icon": "play_tracks",
                    "targetModuleId": "eyJwIjoiOGMxZjRkNjAtZDhmNS00YmU2LTg1YjMtYTA0NDExNDVkYmMwIiwicFYiOjE0LCJtIjoiNmU5OWY3ZjUtMDk4My00Mzk5LWFkYjEtZDk2NzRmMGQ2ZDQ5IiwibVYiOjEsIm1IIjoiNDgyMDRjMGMifQ=="
                  },
                  {
                    "shuffle": true,
                    "playbackMode": "SHUFFLE",
                    "title": "Shuffle",
                    "icon": "shuffle_tracks",
                    "targetModuleId": "eyJwIjoiOGMxZjRkNjAtZDhmNS00YmU2LTg1YjMtYTA0NDExNDVkYmMwIiwicFYiOjE0LCJtIjoiNmU5OWY3ZjUtMDk4My00Mzk5LWFkYjEtZDk2NzRmMGQ2ZDQ5IiwibVYiOjEsIm1IIjoiNDgyMDRjMGMifQ=="
                  }
                ]
              }
            ]
          },
          {
            "modules": [
              {
                "id": "eyJwIjoiOGMxZjRkNjAtZDhmNS00YmU2LTg1YjMtYTA0NDExNDVkYmMwIiwicFYiOjE0LCJtIjoiNmU5OWY3ZjUtMDk4My00Mzk5LWFkYjEtZDk2NzRmMGQ2ZDQ5IiwibVYiOjEsIm1IIjoiNDgyMDRjMGMifQ==",
                "type": "TRACK_LIST",
                "width": 100,
                "title": "",
                "description": "",
                "preTitle": null,
                "showMore": null,
                "supportsPaging": false,
                "quickPlay": false,
                "listFormat": "COVERS",
                "scroll": "VERTICAL",
                "layout": "LIST",
                "pagedList": {
                  "limit": 10,
                  "offset": 0,
                  "totalNumberOfItems": 10,
                  "items": [
                    {
                      "id": 182220043,
                      "title": "Hippies and Cowboys"
                    }
                  ]
                },
                "showTableHeaders": true
              }
            ]
          }
        ]
      }
    ],
    "identifier": 74528005
  }
]