# Introduction to gh alias
# Manual
See https://cli.github.com//manual/gh_alias_set (opens new window)
# gh alias set
➜ gh alias set <alias> <expansion> [flags]
Declare a word as a command alias that will expand to the specified command(s).
The expansion may specify additional arguments and flags. If the expansion
includes positional placeholders such as $1
, $2
, etc., any extra arguments
that follow the invocation of an alias will be inserted appropriately.
If --shell
is specified, the alias will be run through a shell interpreter (sh).
- This allows you
to compose commands with
|
or redirect with>
. - Note that extra arguments following the alias will not be automatically passed to the expanded expression.
- To have a shell alias receive
arguments, you must explicitly accept them using
$1
,$2
, etc., or$@
to accept all of them.
Quotes must always be used when defining a command as in the examples.
# Simple Example
La opción --paginate
nos permite obtener todos los items.
La opción --jq
nos permite
filtrar los items usando jq (opens new window).
➜ gh alias set org-list-names "api --paginate /user/memberships/orgs --jq '.[].organization.login'"
- Adding alias for org-list-names: api --paginate /user/memberships/orgs --jq '.[].organization.login'
✓ Added alias.
➜ gh org-list-names | grep 23
ULL-ESIT-DMSI-2223
ULL-ESIT-PL-2223
ULL-MII-SYTWS-2223
ULL-MFP-AET-2223
ULL-ESIT-LPP-2223
2
3
4
5
6
7
8
9
See the GitHub docs (opens new window) for the REST API.
# Example search for members of an organization
Este request nos da un JSON con información sobre los miembros de una org:
➜ gh alias set org-ms 'api --paginate "/orgs/$1/members"'
- Adding alias for org-ms: api --paginate "/orgs/$1/members"
✓ Added alias.
2
3
Que lo podemos usar así:
➜ gh org-ms ULL-MII-SYTWS-2223 --jq '.[].login'
algorithms-ull
alu0101225562
alu0101229942
casiano
claudio4
crguezl
JobabaEV
SantiagoVV
2
3
4
5
6
7
8
9
# Exercise: Search for repos inside an organization
Let us search for repos inside our organization using GitHub API v3:
➜ gh api '/search/repositories?q=iaas+org:ULL-MII-SYTWS-2021+in:name' --paginate | jless
A query can contain any combination of search qualifiers supported on GitHub. The format of the search query is:
SEARCH_KEYWORD_1 ... SEARCH_KEYWORD_N QUALIFIER_1 ... QUALIFIER_N
1In the example above
iaas
is a SEARCH_KEYWORD andorg:ULL-MII-SYTWS-2021
andin:name
are qualifiersYou can use qualifiers to narrow your search and focus on specific categories of information. They are the same qualifiers as the web interface for GitHub.
- Finding files on GitHub (opens new window)
- Searching for repositories (opens new window)
- Searching topics (opens new window)
- Searching code (opens new window)
- Searching commits (opens new window)
- Searching issues and pull requests (opens new window)
- Searching discussions (opens new window)
- Searching GitHub Marketplace (opens new window)
- Searching users (opens new window)
- Searching for packages (opens new window)
- Searching wikis (opens new window)
- Searching in forks (opens new window)
+
sign has a semantic meaning in the query string. It is used to represent a space.Another character that has semantic importance in the query string is
&
which is used to separate the variousvar=value
pairs in the query stringSee the SEARCH (opens new window) section of the REST API GitHub docs to know more about the API.
See section Search Repositories (opens new window) for more info on how to search for repos
Now we can use gh alias set
to make an alias get-lab
to get the repos:
➜ gh alias set get-labs 'api /search/repositories?q=$2+org:$1+in:name --paginate'
- Adding alias for get-labs: api /search/repositories?q=$2+org:$1+in:name
✓ Added alias.
➜ gh alias list
co: pr checkout
get-labs: api /search/repositories?q=$2+org:$1+in:name --paginate
2
3
4
5
6
And now we can use it:
➜ gh get-labs ULL-MII-SYTWS-2021 iaas
Next we can pipe the output to jq to get the names of the repos and the date of the last push:
➜ gh get-labs ULL-MII-SYTWS-2021 iaas | \
jq '[ .items[] | { name: .name, last: .pushed_at } ] | sort_by(.last)'
[
{
"name": "p01-t1-iaas-fcohdezc",
"last": "2020-10-06T17:51:52Z"
},
{
"name": "p01-t1-iaas-lardabi",
"last": "2020-10-06T18:01:16Z"
},
{
"name": "p01-t1-iaas-alu0101040882",
"last": "2020-10-17T16:53:39Z"
},
{
"name": "p01-t1-iaas-crguezl",
"last": "2020-10-19T13:50:13Z"
},
{
"name": "p01-t1-iaas-alu0100886870",
"last": "2020-10-21T17:05:08Z"
},
{
"name": "p01-t1-iaas-juanchojbarroso",
"last": "2020-11-02T11:44:16Z"
}
]
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
Make an alias get-lab-names
to get the names of the repos inside an organization