MCPcopy
hub / github.com/cli/cli

github.com/cli/cli @v2.96.0 sqlite

repository ↗ · DeepWiki ↗ · release v2.96.0 ↗ · compare 2 versions
7,052 symbols 43,539 edges 886 files 1,547 documented · 22%
README

GitHub CLI

gh is GitHub on the command line. It brings pull requests, issues, and other GitHub concepts to the terminal next to where you are already working with git and your code.

screenshot of gh pr status

GitHub CLI is supported for users on GitHub.com, GitHub Enterprise Cloud, and GitHub Enterprise Server 2.20+ with support for macOS, Windows, and Linux.

Documentation

For installation options see below, for usage instructions see the manual.

Agent skills

An agent skill is available for driving gh from coding agents. Install or update it with the built-in gh skill command:

# Install the skill (user scope recommended)
gh skill install cli/cli gh --scope user

# Update the skill after a `gh` release
gh skill update gh

Contributing

If anything feels off or if you feel that some functionality is missing, please check out the contributing page. There you will find instructions for sharing your feedback, building the tool locally, and submitting pull requests to the project.

If you are a hubber and are interested in shipping new commands for the CLI, check out our doc on internal contributions

Installation

macOS

For additional macOS packages and installers, see community-supported docs

Linux & Unix

For additional Linux & Unix packages and installers, see community-supported docs

Windows

For additional Windows packages and installers, see community-supported docs

Build from source

See here on how to build GitHub CLI from source.

GitHub Codespaces

To add GitHub CLI to your codespace, add the following to your devcontainer file:

"features": {
  "ghcr.io/devcontainers/features/github-cli:1": {}
}

GitHub Actions

GitHub-hosted runners have the GitHub CLI pre-installed, which is updated weekly.

If a specific version is needed, your GitHub Actions workflow will need to install it based on the macOS, Linux & Unix, or Windows instructions above.

For information on all pre-installed tools, see actions/runner-images

Verification of binaries

Starting with v2.93.0, releases of gh are published as immutable releases. For more information, see Immutable releases.

Since version 2.50.0, gh has been producing Build Provenance Attestation, enabling a cryptographically verifiable paper-trail back to the origin GitHub repository, git revision, and build instructions used. The build provenance attestations are signed and rely on Public Good Sigstore for PKI.

There are two common ways to verify a downloaded release, depending on whether gh is already installed or not. If gh is installed, it's trivial to verify a new release:

  • Option 1: Using gh if already installed:

```shell $ gh at verify -R cli/cli gh_2.62.0_macOS_arm64.zip Loaded digest sha256:fdb77f31b8a6dd23c3fd858758d692a45f7fc76383e37d475bdcae038df92afc for file://gh_2.62.0_macOS_arm64.zip Loaded 1 attestation from GitHub API ✓ Verification succeeded!

sha256:fdb77f31b8a6dd23c3fd858758d692a45f7fc76383e37d475bdcae038df92afc was attested by: REPO PREDICATE_TYPE WORKFLOW cli/cli https://slsa.dev/provenance/v1 .github/workflows/deployment.yml@refs/heads/trunk ```

  • Option 2: Using Sigstore cosign:

To perform this, download the attestation for the downloaded release and use cosign to verify the authenticity of the downloaded release:

shell $ cosign verify-blob-attestation --bundle cli-cli-attestation-3120304.sigstore.json \ --new-bundle-format \ --certificate-oidc-issuer="https://token.actions.githubusercontent.com" \ --certificate-identity="https://github.com/cli/cli/.github/workflows/deployment.yml@refs/heads/trunk" \ gh_2.62.0_macOS_arm64.zip Verified OK

Comparison with hub

For many years, hub was the unofficial GitHub CLI tool. gh is a new project that helps us explore what an official GitHub CLI tool can look like with a fundamentally different design. While both tools bring GitHub to the terminal, hub behaves as a proxy to git, and gh is a standalone tool. Check out our more detailed explanation to learn more.

Extension points exported contracts — how you extend this code

AutolinkListClient (Interface)
(no doc) [12 implementers]
pkg/cmd/repo/autolink/list/list.go
Runnable (Interface)
Runnable is typically an exec.Cmd or its stub in tests [4 implementers]
internal/run/run.go
Prompter (Interface)
go:generate moq -rm -out prompter_mock.go . Prompter [4 implementers]
internal/prompter/prompter.go
ExtensionManager (Interface)
go:generate moq -rm -out manager_mock.go . ExtensionManager [3 implementers]
pkg/extensions/extension.go
Interface (Interface)
Interface describes an object that represents a GitHub repository [3 implementers]
internal/ghrepo/repo.go
Disabler (Interface)
(no doc) [5 implementers]
internal/gh/ghtelemetry/telemetry.go
TelemetryAPI (Interface)
====================== TelemetryAPI Interface ====================== TelemetryAPI receives telemetry events from client [3 …
internal/barista/observability/telemetry.twirp.go
Exporter (Interface)
(no doc) [4 implementers]
pkg/cmdutil/json_flags.go

Core symbols most depended-on inside this repo

Equal
called by 3381
pkg/set/string_set.go
Register
called by 3100
pkg/httpmock/registry.go
REST
called by 1459
pkg/httpmock/stub.go
Errorf
called by 1305
pkg/httpmock/registry.go
GraphQL
called by 1074
pkg/httpmock/stub.go
StringResponse
called by 1057
pkg/httpmock/stub.go
Run
called by 1052
internal/run/run.go
Join
called by 730
internal/safepaths/absolute.go

Shape

Function 3,904
Method 1,866
Struct 1,069
Interface 134
TypeAlias 58
FuncType 21

Languages

Go100%

Modules by API surface

pkg/cmd/project/shared/queries/queries.go155 symbols
api/queries_repo.go88 symbols
pkg/iostreams/iostreams.go74 symbols
internal/barista/observability/telemetry.twirp.go69 symbols
git/client.go61 symbols
internal/config/auth_config_test.go58 symbols
git/client_test.go56 symbols
internal/config/config.go55 symbols
api/queries_issue.go54 symbols
internal/skills/discovery/discovery.go52 symbols
api/queries_pr_review.go51 symbols
api/queries_pr.go50 symbols

Dependencies from manifests, versioned

charm.land/bubbles/v2v2.1.0 · 1×
charm.land/bubbletea/v2v2.0.7 · 1×
charm.land/huh/v2v2.0.3 · 1×
charm.land/lipgloss/v2v2.0.4 · 1×
dario.cat/mergov1.0.2 · 1×
github.com/AlecAivazis/survey/v2v2.3.7 · 1×
github.com/MakeNowJust/heredocv1.0.0 · 1×
github.com/Masterminds/goutilsv1.1.1 · 1×
github.com/Masterminds/semver/v3v3.4.0 · 1×
github.com/Masterminds/sprig/v3v3.3.0 · 1×
github.com/Netflix/go-expectv0.0.0-2022010404335 · 1×
github.com/alecthomas/chroma/v2v2.19.0 · 1×

For agents

$ claude mcp add cli \
  -- python -m otcore.mcp_server <graph>

⬇ download graph artifact