Working with JSON objects can be a complex everyday task for both developers and platform engineers. Developers often need to automate workflows that incorporate JSON data, such as processing API responses, generating configuration files or analyzing logs. Meanwhile, platform engineers use JSON to create automated workflows, self-service actions and more within their platforms and portals.
While the simplicity of JSON attracted engineers at the outset, processing JSON data introduced some complexity. The difficulty in working with JSON files, particularly with larger data sets, is that it is hard to locate and manipulate the information you need. To deal with this, engineers copy and paste parts of the JSON file to calculate totals or write complex scripts for simple tasks, but this is a time-consuming process that is prone to errors that subsequently impact developer workflows.
jq, a command-line JSON processing tool, was introduced as a response to this. It empowers developers to easily manipulate data, whether that’s extracting information from a server’s response or the number of available replicas for a deployment. jq embeds these tasks in shell scripts or pipelines, which are not compatible with JSON directly.
Thus, jq provides a consistent way to handle JSON without leaving the command line. And since jq was launched, interactive jq playgrounds that let you experiment with JQ commands and filters in real time have launched, providing immediate feedback to help you learn, test and debug complex JSON transformations.
JQ use cases
There are multiple ways to use JQ to speed up developer workflows. For the purposes of this article, I’ll be talking specifically about building developer workflows in an internal developer portal.
1. Filtering and extracting data from JSON API responses
If you frequently work with APIs that return large JSON payloads, jq helps you filter and extract only the relevant pieces of information, making it easier to work with and analyze the data. This can be helpful especially when building workflows in an internal developer portal, as you can locate exact fields and data points more quickly with jq than you could with a simple JSON file.
For example, say you’ve integrated GitHub into an internal developer portal to make the backlog more actionable. You want to surface the GitHub issue with the most comments to the top of your backlog list and use the title of each GitHub issue to organize them.
You can do this using the GitHub API. Pass the API request in with this jq command:
curl -L \
-H "Accept: application/vnd.github+json" \
https://api.github.com/repos/jqlang/jq/issues | jq "max_by(.comments) | .title"
In return, the API output should be:
"Add exec/2: posix_spawn"
2. Transforming JSON structures into input for other tools
In many cases, you’ll need to reformat your JSON data structure to match the structure required by another tool or service. jq speeds up this process by allowing you to create new JSON objects, manipulate arrays and convert data formats quickly.
Continuing with the above example, you can clean up the issue object from GitHub to include only the fields you deem important into your Slack message automation.
Here is the input:
{
"url": "https://api.github.com/repos/jqlang/jq/issues/3192",
"id": 2599050572,
"node_id": "PR_kwDOAE3WVc5_K9vw",
"number": 3192,
"title": "Adds ascii_title to string manipulation",
"user": {
"login": "fabiomatavelli",
"id": 566767,
"node_id": "MDQ6VXNlcjU2Njc2Nw==",
"received_events_url": "https://api.github.com/users/fabiomatavelli/received_events",
"type": "User",
"user_view_type": "public",
"site_admin": false
},
"author_association": "NONE",
"active_lock_reason": null,
"draft": true,
"pull_request": {
"merged_at": null
},
"body": "This introduces the `ascii_title` for string manipulation. The function is set to produce a Title like string, making all the first ASCII characters of each word uppercase.",
"closed_by": {
"login": "fabiomatavelli",
"id": 566767,
"node_id": "MDQ6VXNlcjU2Njc2Nw==",
"avatar_url": "https://avatars.githubusercontent.com/u/566767?v=4",
"gravatar_id": "",
"url": "https://api.github.com/users/fabiomatavelli",
"type": "User",
"user_view_type": "public",
"site_admin": false
},
"reactions": {
"url": "https://api.github.com/repos/jqlang/jq/issues/3192/reactions",
"total_count": 0,
"+1": 0,
"-1": 0,
"laugh": 0,
"hooray": 0,
"confused": 0,
"heart": 0,
"rocket": 0,
"eyes": 0
},
"timeline_url": "https://api.github.com/repos/jqlang/jq/issues/3192/timeline",
"performed_via_github_app": null,
"state_reason": null
}
The jq command to transform this JSON payload should look like:
curl -L \
-H "Accept: application/vnd.github+json" \
https://api.github.com/repos/jqlang/jq/issues | jq '.[0] | { "title": .title, "url": .html_url, "user": .user.login, "comments": .comments }'
Finally, the output includes only the fields you want to share in a Slack message:
{
"title": "Adds ascii_title to string manipulation",
"url": "https://github.com/jqlang/jq/pull/3192",
"user": "fabiomatavelli",
"comments": 0
}
Now your portal will assist in prioritizing your backlog by sending Slack messages that alert sprint planners to GitHub issues with comments to prioritize them.
3. Automating configurations and environment variables
jq can be used in shell scripts to read, modify and write JSON configuration files. It's particularly useful in CI/CD pipelines where you need to adjust JSON configuration dynamically.
Here is an example jq command:
jq '.propertyName' config.json
You can also modify your configuration like:
jq '.propertyName = "newValue"' config.json > updated_config.json
4. Validating and pretty-printing JSON
If you need to quickly check whether a JSON file is properly formatted, or if you know you need to make it more readable and don’t want to do it manually, you can use jq to validate and format JSON with a single command. This is especially helpful when debugging issues with malformed JSON or just reviewing data.
Get up to speed using a JQ playground
jq playgrounds are online environments where you can test and experiment with jq commands and filters. A playground allows you to experiment with jq commands in real time, helping you quickly see how different filters, pipes and operators behave. This hands-on, trial-and-error approach helps you learn the syntax and functionality of jq more effectively than just reading documentation.
By providing a visual environment, playgrounds allow you to build and test jq queries in smaller, more manageable pieces before combining them into a larger script. You can also use comments and white space to break down complicated queries, making it easier to understand how different parts of your jq code work together.
Playground environments are also helpful for recall and retention because you are able to immediately see the results of your jq queries in practice, making it easier to identify and fix errors. Since you can iteratively test small changes, this step-by-step feedback helps you debug complex transformations without the overhead of saving files, running commands and waiting for output.
Playground environments make it easier to explore deeply nested or irregular JSON data. You can try different paths and transformations on the fly, immediately see the output and adjust your approach as needed. This makes it much easier to understand and navigate complex JSON without needing to write and rerun scripts repeatedly on the command line.
Using a JQ playground
Here is an example of using a JQ playground
If you want to experiment with JQ commands and filters, use this JQ playground. And if you want to discuss other ways of speeding up developer workflows, join the Port Community.
Tags:
Developer ExperienceCheck out Port's pre-populated demo and see what it's all about.
No email required
Contact sales for a technical product walkthrough
Open a free Port account. No credit card required
Watch Port live coding videos - setting up an internal developer portal & platform
Check out Port's pre-populated demo and see what it's all about.
(no email required)
Contact sales for a technical product walkthrough
Open a free Port account. No credit card required
Watch Port live coding videos - setting up an internal developer portal & platform
Book a demo right now to check out Port's developer portal yourself
Apply to join the Beta for Port's new Backstage plugin
It's a Trap - Jenkins as Self service UI
Further reading:
Example JSON block
Order Domain
Cart System
Products System
Cart Resource
Cart API
Core Kafka Library
Core Payment Library
Cart Service JSON
Products Service JSON
Component Blueprint
Resource Blueprint
API Blueprint
Domain Blueprint
System Blueprint
Microservices SDLC
Scaffold a new microservice
Deploy (canary or blue-green)
Feature flagging
Revert
Lock deployments
Add Secret
Force merge pull request (skip tests on crises)
Add environment variable to service
Add IaC to the service
Upgrade package version
Development environments
Spin up a developer environment for 5 days
ETL mock data to environment
Invite developer to the environment
Extend TTL by 3 days
Cloud resources
Provision a cloud resource
Modify a cloud resource
Get permissions to access cloud resource
SRE actions
Update pod count
Update auto-scaling group
Execute incident response runbook automation
Data Engineering
Add / Remove / Update Column to table
Run Airflow DAG
Duplicate table
Backoffice
Change customer configuration
Update customer software version
Upgrade - Downgrade plan tier
Create - Delete customer
Machine learning actions
Train model
Pre-process dataset
Deploy
A/B testing traffic route
Revert
Spin up remote Jupyter notebook
Engineering tools
Observability
Tasks management
CI/CD
On-Call management
Troubleshooting tools
DevSecOps
Runbooks
Infrastructure
Cloud Resources
K8S
Containers & Serverless
IaC
Databases
Environments
Regions
Software and more
Microservices
Docker Images
Docs
APIs
3rd parties
Runbooks
Cron jobs