| name | github-discussion-query |
| description | Query GitHub discussions with jq filtering and reusable selectors. |
GitHub Discussion Query Skill
Query GitHub discussions efficiently with built-in jq filtering.
Important: jq Parameter is Optional
The --jq parameter is optional. Without --jq, this skill returns schema and data size information instead of full data.
Use this to avoid oversized responses and inspect structure before targeted queries.
Use --jq '.' to get all data, or use a more specific filter for targeted results.
Usage
Use this skill to query discussions from the current repository or any specified repository.
Basic Query (Returns Schema Only)
To list discussions from the current repository:
./query-discussions.sh
Get All Data
To get all discussion data:
./query-discussions.sh --jq '.'
With Repository
To query a specific repository:
./query-discussions.sh --repo owner/repo
With jq Filtering
Use the --jq argument to filter and transform the output:
./query-discussions.sh --jq '.[] | {number, title}'
./query-discussions.sh --jq '.[] | select(.author.login == "username")'
./query-discussions.sh --jq '.[] | select(.category.name == "Ideas")'
./query-discussions.sh --jq '.[] | select(.answer != null)'
./query-discussions.sh --jq 'group_by(.category.name) | map({category: .[0].category.name, count: length})'
Common Options
--limit: Maximum number of discussions to fetch. Default: 30
--repo: Repository in owner/repo format. Default: current repo
--jq: (Optional) jq expression for filtering/transforming output. If omitted, returns schema info
Example Queries
Find discussions with many comments:
./query-discussions.sh --jq '.[] | select(.comments.totalCount > 5) | {number, title, comments: .comments.totalCount}'
Get unanswered discussions:
./query-discussions.sh --jq '.[] | select(.answer == null) | {number, title, category: .category.name}'
List discussions with their labels:
./query-discussions.sh --jq '.[] | {number, title, labels: [.labels[].name]}'
Find discussions by category:
./query-discussions.sh --jq '.[] | select(.category.name == "Q&A") | {number, title, author: .author.login}'
Get recently updated discussions:
./query-discussions.sh --jq 'sort_by(.updatedAt) | reverse | .[0:10] | .[] | {number, title, updatedAt}'
Output Format
The script outputs JSON by default, making it easy to pipe through jq for additional processing.
Requirements
- GitHub CLI (
gh) authenticated
jq for filtering (installed by default on most systems)