2020-09-18 14:35:36 +00:00
|
|
|
# balenaCLI
|
2014-12-09 19:20:22 +00:00
|
|
|
|
2020-09-18 14:35:36 +00:00
|
|
|
The official balena Command Line Interface.
|
2016-01-11 15:26:34 +00:00
|
|
|
|
2018-10-19 14:38:50 +00:00
|
|
|
[![npm version](https://badge.fury.io/js/balena-cli.svg)](http://badge.fury.io/js/balena-cli)
|
|
|
|
[![dependencies](https://david-dm.org/balena-io/balena-cli.svg)](https://david-dm.org/balena-io/balena-cli)
|
2014-12-09 19:20:22 +00:00
|
|
|
|
2019-04-18 15:49:17 +00:00
|
|
|
## About
|
2019-04-17 16:56:33 +00:00
|
|
|
|
2020-09-18 14:35:36 +00:00
|
|
|
balenaCLI is a Command Line Interface for [balenaCloud](https://www.balena.io/cloud/) or
|
|
|
|
[openBalena](https://www.balena.io/open/). It is a software tool available for Windows, macOS and
|
|
|
|
Linux, used through a command prompt / terminal window. It can be used interactively or invoked in
|
|
|
|
scripts. balenaCLI builds on the [balena API](https://www.balena.io/docs/reference/api/overview/)
|
|
|
|
and the [balena SDK](https://www.balena.io/docs/reference/sdk/node-sdk/), and can also be directly
|
|
|
|
imported in Node.js applications. balenaCLI is an [open-source project on
|
|
|
|
GitHub](https://github.com/balena-io/balena-cli/), and your contribution is also welcome!
|
2017-01-18 15:57:52 +00:00
|
|
|
|
2019-04-18 15:49:17 +00:00
|
|
|
## Installation
|
2017-09-22 13:27:24 +00:00
|
|
|
|
2020-09-18 14:35:36 +00:00
|
|
|
Check the [balenaCLI installation instructions on
|
|
|
|
GitHub](https://github.com/balena-io/balena-cli/blob/master/INSTALL.md).
|
2017-01-18 15:57:52 +00:00
|
|
|
|
2020-09-18 14:35:36 +00:00
|
|
|
## Choosing a shell (command prompt/terminal)
|
2014-12-09 19:20:22 +00:00
|
|
|
|
2019-04-29 15:33:09 +00:00
|
|
|
On **Windows,** the standard Command Prompt (`cmd.exe`) and
|
|
|
|
[PowerShell](https://docs.microsoft.com/en-us/powershell/scripting/getting-started/getting-started-with-windows-powershell?view=powershell-6)
|
2020-09-18 14:35:36 +00:00
|
|
|
are supported. Alternative shells include:
|
2014-12-09 19:20:22 +00:00
|
|
|
|
2019-10-09 15:32:54 +00:00
|
|
|
* [MSYS2](https://www.msys2.org/):
|
|
|
|
* Install additional packages with the command:
|
|
|
|
`pacman -S git openssh rsync`
|
|
|
|
* [Set a Windows environment variable](https://www.onmsft.com/how-to/how-to-set-an-environment-variable-in-windows-10): `MSYS2_PATH_TYPE=inherit`
|
|
|
|
* Note that a bug in the MSYS2 launch script (`msys2_shell.cmd`) makes text-based interactive CLI
|
|
|
|
menus to break. [Check this Github issue for a
|
|
|
|
workaround](https://github.com/msys2/MINGW-packages/issues/1633#issuecomment-240583890).
|
|
|
|
* [MSYS](http://www.mingw.org/wiki/MSYS): select the `msys-rsync` and `msys-openssh` packages too
|
2019-05-25 21:11:26 +00:00
|
|
|
* [Git for Windows](https://git-for-windows.github.io/)
|
2019-11-20 23:35:17 +00:00
|
|
|
* During the installation, you will be prompted to choose between _"Use MinTTY"_ and _"Use
|
|
|
|
Windows' default console window"._ Choose the latter, because of the same [MSYS2
|
|
|
|
bug](https://github.com/msys2/MINGW-packages/issues/1633) mentioned above (Git for Windows
|
|
|
|
actually uses MSYS2). For a screenshot, check this
|
|
|
|
[comment](https://github.com/balena-io/balena-cli/issues/598#issuecomment-556513098).
|
2019-10-09 15:32:54 +00:00
|
|
|
* Microsoft's [Windows Subsystem for Linux](https://docs.microsoft.com/en-us/windows/wsl/about)
|
|
|
|
(WSL). In this case, a Linux distribution like Ubuntu is installed via the Microsoft Store, and a
|
2020-09-18 14:35:36 +00:00
|
|
|
balenaCLI release **for Linux** should be selected. See
|
|
|
|
[FAQ](https://github.com/balena-io/balena-cli/blob/master/TROUBLESHOOTING.md) for using balenaCLI
|
|
|
|
with WSL and Docker Desktop for Windows.
|
2017-12-14 12:01:55 +00:00
|
|
|
|
2020-09-18 14:35:36 +00:00
|
|
|
On **macOS** and **Linux,** the standard terminal window is supported. Optionally, `bash` command
|
2019-04-29 15:33:09 +00:00
|
|
|
auto completion may be enabled by copying the
|
|
|
|
[balena-completion.bash](https://github.com/balena-io/balena-cli/blob/master/balena-completion.bash)
|
|
|
|
file to your system's `bash_completion` directory: check [Docker's command completion
|
|
|
|
guide](https://docs.docker.com/compose/completion/) for system setup instructions.
|
|
|
|
|
2020-09-18 14:35:36 +00:00
|
|
|
## Logging in
|
2019-04-18 15:49:17 +00:00
|
|
|
|
2019-04-29 15:33:09 +00:00
|
|
|
Several CLI commands require access to your balenaCloud account, for example in order to push a
|
|
|
|
new release to your application. Those commands require creating a CLI login session by running:
|
2014-12-10 18:12:12 +00:00
|
|
|
|
|
|
|
```sh
|
2018-10-19 14:38:50 +00:00
|
|
|
$ balena login
|
2014-12-10 18:12:12 +00:00
|
|
|
```
|
|
|
|
|
2020-09-18 14:35:36 +00:00
|
|
|
## Proxy support
|
2016-01-13 04:20:18 +00:00
|
|
|
|
2020-01-24 18:43:04 +00:00
|
|
|
HTTP(S) proxies can be configured through any of the following methods, in precedence order
|
|
|
|
(from higher to lower):
|
|
|
|
|
|
|
|
* The `BALENARC_PROXY` environment variable in URL format, with protocol (`http` or `https`),
|
|
|
|
host, port and optionally basic auth. Examples:
|
|
|
|
* `export BALENARC_PROXY='https://bob:secret@proxy.company.com:12345'`
|
|
|
|
* `export BALENARC_PROXY='http://localhost:8000'`
|
|
|
|
|
|
|
|
* The `proxy` setting in the [CLI config
|
|
|
|
file](https://www.npmjs.com/package/balena-settings-client#documentation). It may be:
|
|
|
|
* A string in URL format, e.g. `proxy: 'http://localhost:8000'`
|
|
|
|
* An object in the format:
|
|
|
|
|
|
|
|
```yaml
|
|
|
|
proxy:
|
|
|
|
protocol: 'http'
|
|
|
|
host: 'proxy.company.com'
|
|
|
|
port: 12345
|
|
|
|
proxyAuth: 'bob:secret'
|
|
|
|
```
|
|
|
|
|
|
|
|
* The `HTTPS_PROXY` and/or `HTTP_PROXY` environment variables, in the same URL format as
|
|
|
|
`BALENARC_PROXY`.
|
|
|
|
|
2020-09-18 14:35:36 +00:00
|
|
|
### Proxy setup for balena ssh
|
2020-09-16 13:53:46 +00:00
|
|
|
|
|
|
|
In order to work behind a proxy server, the `balena ssh` command requires the
|
|
|
|
[`proxytunnel`](http://proxytunnel.sourceforge.net/) package (command-line tool) to be installed.
|
|
|
|
`proxytunnel` is available for Linux distributions like Ubuntu/Debian (`apt install proxytunnel`),
|
|
|
|
and for macOS through [Homebrew](https://brew.sh/). Windows support is limited to the [Windows
|
|
|
|
Subsystem for Linux](https://docs.microsoft.com/en-us/windows/wsl/about) (e.g., by installing
|
|
|
|
Ubuntu through the Microsoft App Store).
|
|
|
|
|
|
|
|
Ensure that the proxy server is configured to allow proxy requests to ssh port 22, using
|
|
|
|
SSL encryption. For example, in the case of the [Squid](http://www.squid-cache.org/) proxy
|
|
|
|
server, it should be configured with the following rules in the `squid.conf` file:
|
|
|
|
`acl SSL_ports port 22`
|
|
|
|
`acl Safe_ports port 22`
|
2020-03-29 22:59:44 +00:00
|
|
|
|
2020-09-18 14:35:36 +00:00
|
|
|
### Proxy exclusion
|
2020-03-29 22:59:44 +00:00
|
|
|
|
|
|
|
The `BALENARC_NO_PROXY` variable may be used to exclude specified destinations from proxying.
|
|
|
|
|
2020-09-18 14:35:36 +00:00
|
|
|
> * This feature requires balenaCLI version 11.30.8 or later. In the case of the npm [installation
|
2020-03-29 22:59:44 +00:00
|
|
|
> option](https://github.com/balena-io/balena-cli/blob/master/INSTALL.md), it also requires
|
|
|
|
> Node.js version 10.16.0 or later.
|
|
|
|
> * To exclude a `balena ssh` target from proxying (IP address or `.local` hostname), the
|
|
|
|
> `--noproxy` option should be specified in addition to the `BALENARC_NO_PROXY` variable.
|
|
|
|
|
|
|
|
By default (if `BALENARC_NO_PROXY` is not defined), all [private IPv4
|
|
|
|
addresses](https://en.wikipedia.org/wiki/Private_network) and `'*.local'` hostnames are excluded
|
|
|
|
from proxying. Other hostnames that resolve to private IPv4 addresses are **not** excluded by
|
|
|
|
default, because matching takes place before name resolution.
|
|
|
|
|
|
|
|
`localhost` and `127.0.0.1` are always excluded from proxying, regardless of the value of
|
|
|
|
BALENARC_NO_PROXY.
|
2020-01-24 18:43:04 +00:00
|
|
|
|
|
|
|
The format of the `BALENARC_NO_PROXY` environment variable is a comma-separated list of patterns
|
|
|
|
that are matched against hostnames or IP addresses. For example:
|
|
|
|
|
|
|
|
```
|
|
|
|
export BALENARC_NO_PROXY='*.local,dev*.mycompany.com,192.168.*'
|
|
|
|
```
|
|
|
|
|
2020-03-29 22:59:44 +00:00
|
|
|
Matched patterns are excluded from proxying. Wildcard expressions are documented at
|
|
|
|
[matcher](https://www.npmjs.com/package/matcher#usage). Matching takes place _before_ name
|
|
|
|
resolution, so a pattern like `'192.168.*'` will **not** match a hostname that resolves to an IP
|
|
|
|
address like `192.168.1.2`.
|
2016-01-01 02:00:39 +00:00
|
|
|
|
2019-04-18 15:49:17 +00:00
|
|
|
## Command reference documentation
|
2016-01-01 02:00:39 +00:00
|
|
|
|
2019-04-18 15:49:17 +00:00
|
|
|
The full CLI command reference is available [on the web](https://www.balena.io/docs/reference/cli/
|
2020-09-18 14:35:36 +00:00
|
|
|
) or by running `balena help --verbose`.
|
2016-01-13 04:20:18 +00:00
|
|
|
|
2019-04-18 15:49:17 +00:00
|
|
|
## Support, FAQ and troubleshooting
|
2016-01-13 04:20:18 +00:00
|
|
|
|
2019-04-18 15:49:17 +00:00
|
|
|
If you come across any problems or would like to get in touch:
|
2016-01-13 04:20:18 +00:00
|
|
|
|
2019-04-18 15:49:17 +00:00
|
|
|
* Check our [FAQ / troubleshooting document](https://github.com/balena-io/balena-cli/blob/master/TROUBLESHOOTING.md).
|
|
|
|
* Ask us a question through the [balenaCloud forum](https://forums.balena.io/c/balena-cloud).
|
|
|
|
* For bug reports or feature requests,
|
|
|
|
[have a look at the GitHub issues or create a new one](https://github.com/balena-io/balena-cli/issues/).
|
2016-01-13 04:20:18 +00:00
|
|
|
|
2020-05-11 08:12:27 +00:00
|
|
|
## Deprecation policy
|
|
|
|
|
2020-09-18 14:35:36 +00:00
|
|
|
balenaCLI uses [semver versioning](https://semver.org/), with the concepts
|
2020-05-11 08:12:27 +00:00
|
|
|
of major, minor and patch version releases.
|
|
|
|
|
2020-09-18 14:35:36 +00:00
|
|
|
The latest release of a major version of balenaCLI will remain compatible with
|
|
|
|
the balenaCloud backend services for at least one year from the date when the
|
|
|
|
following major version is released. For example, balenaCLI v10.17.5, as the
|
2020-05-11 08:12:27 +00:00
|
|
|
latest v10 release, would remain compatible with the balenaCloud backend for one
|
|
|
|
year from the date when v11.0.0 is released.
|
|
|
|
|
|
|
|
At the end of this period, the older major version is considered deprecated and
|
|
|
|
some of the functionality that depends on balenaCloud services may stop working
|
|
|
|
at any time.
|
2020-09-18 14:35:36 +00:00
|
|
|
Users are encouraged to regularly update balenaCLI to the latest version.
|
2020-05-11 08:12:27 +00:00
|
|
|
|
2019-05-25 21:11:26 +00:00
|
|
|
## Contributing (including editing documentation files)
|
2016-01-01 02:00:39 +00:00
|
|
|
|
2019-05-25 21:11:26 +00:00
|
|
|
Please have a look at the [CONTRIBUTING.md](./CONTRIBUTING.md) file for some guidance before
|
|
|
|
submitting a pull request or updating documentation (because some files are automatically
|
|
|
|
generated). Thank you for your help and interest!
|
2018-10-24 10:06:03 +00:00
|
|
|
|
2019-04-18 15:49:17 +00:00
|
|
|
## License
|
2015-09-21 11:56:24 +00:00
|
|
|
|
2019-04-18 15:49:17 +00:00
|
|
|
The project is licensed under the [Apache 2.0 License](https://www.apache.org/licenses/LICENSE-2.0).
|
|
|
|
A copy is also available in the LICENSE file in this repository.
|