The Heroku CLI is used to manage Heroku apps from the command line.
For more about Heroku see https://www.heroku.com/home
To get started see https://devcenter.heroku.com/start
This is the next generation Go/Node-based Heroku CLI. Currently, it is not feature complete with the existing CLI and not intended to be used standalone. It is used internally inside the existing Ruby CLI for some commands.
The goals of this project were to make plugins more flexible, remove Ruby as a runtime dependency, and make the CLI faster.
We are in the process of migrating commands over, some you can try out include: heroku status
, heroku fork
, and heroku git:remote
.
This CLI is written both in Go and node. The core part of the CLI is this Go project and manages a node installation in ~/.heroku
. It handles taking in arguments, updating itself and node plugins, as well as some core commands like heroku login
.
Most commands are plugins. An example of one would be heroku-git. You can install it with heroku plugins:install
and use it with heroku git:remote
. When you install it, it uses npm to install the plugin into ~/.heroku/node_plugins/heroku-git
. Then, the commands become available to the CLI.
We have shims in place for some commands inside the current Ruby CLI which will setup this Go/Node CLI, install the plugin, and exec the command. Here is the shim for heroku-git.
Once we have plugins to replicate every command in the Ruby CLI, we will then ship this CLI standalone.
For more on developing plugins, read the blog announcement
For problems directly related to the CLI, add an issue on GitHub.
For other issues, submit a support ticket.