mirror of
https://github.com/balena-io/balena-cli.git
synced 2025-01-05 13:34:08 +00:00
792 lines
17 KiB
Markdown
792 lines
17 KiB
Markdown
# Resin CLI Documentation
|
|
|
|
This tool allows you to interact with the resin.io api from the comfort of your command line.
|
|
|
|
To get started download the CLI from npm.
|
|
|
|
$ npm install resin-cli -g
|
|
|
|
Then authenticate yourself:
|
|
|
|
$ resin login
|
|
|
|
Now you have access to all the commands referenced below.
|
|
|
|
# Table of contents
|
|
|
|
- Application
|
|
|
|
- [app create <name>](#/pages/using/cli.md#app-create-60-name-62-)
|
|
- [apps](#/pages/using/cli.md#apps)
|
|
- [app <name>](#/pages/using/cli.md#app-60-name-62-)
|
|
- [app restart <name>](#/pages/using/cli.md#app-restart-60-name-62-)
|
|
- [app rm <name>](#/pages/using/cli.md#app-rm-60-name-62-)
|
|
- [app associate <name>](#/pages/using/cli.md#app-associate-60-name-62-)
|
|
- [init](#/pages/using/cli.md#init)
|
|
|
|
- Authentication
|
|
|
|
- [login [token]](#/pages/using/cli.md#login-token-)
|
|
- [logout](#/pages/using/cli.md#logout)
|
|
- [signup](#/pages/using/cli.md#signup)
|
|
- [whoami](#/pages/using/cli.md#whoami)
|
|
|
|
- Device
|
|
|
|
- [devices](#/pages/using/cli.md#devices)
|
|
- [device <name>](#/pages/using/cli.md#device-60-name-62-)
|
|
- [device rm <name>](#/pages/using/cli.md#device-rm-60-name-62-)
|
|
- [device identify <uuid>](#/pages/using/cli.md#device-identify-60-uuid-62-)
|
|
- [device rename <name> [newName]](#/pages/using/cli.md#device-rename-60-name-62-newname-)
|
|
- [devices supported](#/pages/using/cli.md#devices-supported)
|
|
- [device await <name>](#/pages/using/cli.md#device-await-60-name-62-)
|
|
- [device init [device]](#/pages/using/cli.md#device-init-device-)
|
|
|
|
- Drive
|
|
|
|
- [drives](#/pages/using/cli.md#drives)
|
|
|
|
- Environment Variables
|
|
|
|
- [envs](#/pages/using/cli.md#envs)
|
|
- [env rm <id>](#/pages/using/cli.md#env-rm-60-id-62-)
|
|
- [env add <key> [value]](#/pages/using/cli.md#env-add-60-key-62-value-)
|
|
- [env rename <id> <value>](#/pages/using/cli.md#env-rename-60-id-62-60-value-62-)
|
|
|
|
- Examples
|
|
|
|
- [examples](#/pages/using/cli.md#examples)
|
|
- [example <id>](#/pages/using/cli.md#example-60-id-62-)
|
|
- [example clone <id>](#/pages/using/cli.md#example-clone-60-id-62-)
|
|
|
|
- Help
|
|
|
|
- [help [command...]](#/pages/using/cli.md#help-command-)
|
|
|
|
- Information
|
|
|
|
- [version](#/pages/using/cli.md#version)
|
|
|
|
- Keys
|
|
|
|
- [keys](#/pages/using/cli.md#keys)
|
|
- [key <id>](#/pages/using/cli.md#key-60-id-62-)
|
|
- [key rm <id>](#/pages/using/cli.md#key-rm-60-id-62-)
|
|
- [key add <name> [path]](#/pages/using/cli.md#key-add-60-name-62-path-)
|
|
|
|
- Logs
|
|
|
|
- [logs <uuid>](#/pages/using/cli.md#logs-60-uuid-62-)
|
|
|
|
- Notes
|
|
|
|
- [note <|note>](#/pages/using/cli.md#note-60-note-62-)
|
|
|
|
- OS
|
|
|
|
- [os download <name>](#/pages/using/cli.md#os-download-60-name-62-)
|
|
- [os install <image> [device]](#/pages/using/cli.md#os-install-60-image-62-device-)
|
|
|
|
- Plugin
|
|
|
|
- [plugins](#/pages/using/cli.md#plugins)
|
|
- [plugin install <name>](#/pages/using/cli.md#plugin-install-60-name-62-)
|
|
- [plugin update <name>](#/pages/using/cli.md#plugin-update-60-name-62-)
|
|
- [plugin rm <name>](#/pages/using/cli.md#plugin-rm-60-name-62-)
|
|
|
|
- Preferences
|
|
|
|
- [preferences](#/pages/using/cli.md#preferences)
|
|
|
|
- Update
|
|
|
|
- [update](#/pages/using/cli.md#update)
|
|
|
|
# Application
|
|
|
|
## app create <name>
|
|
|
|
Use this command to create a new resin.io application.
|
|
|
|
You can specify the application type with the `--type` option.
|
|
Otherwise, an interactive dropdown will be shown for you to select from.
|
|
|
|
You can see a list of supported device types with
|
|
|
|
$ resin devices supported
|
|
|
|
Examples:
|
|
|
|
$ resin app create MyApp
|
|
$ resin app create MyApp --type raspberry-pi
|
|
|
|
### Options
|
|
|
|
#### --type, -t <type>
|
|
|
|
application type
|
|
|
|
## apps
|
|
|
|
Use this command to list all your applications.
|
|
|
|
Notice this command only shows the most important bits of information for each app.
|
|
If you want detailed information, use resin app <name> instead.
|
|
|
|
Examples:
|
|
|
|
$ resin apps
|
|
|
|
## app <name>
|
|
|
|
Use this command to show detailed information for a single application.
|
|
|
|
Examples:
|
|
|
|
$ resin app MyApp
|
|
|
|
## app restart <name>
|
|
|
|
Use this command to restart all devices that belongs to a certain application.
|
|
|
|
Examples:
|
|
|
|
$ resin app restart MyApp
|
|
|
|
## app rm <name>
|
|
|
|
Use this command to remove a resin.io application.
|
|
|
|
Notice this command asks for confirmation interactively.
|
|
You can avoid this by passing the `--yes` boolean option.
|
|
|
|
Examples:
|
|
|
|
$ resin app rm MyApp
|
|
$ resin app rm MyApp --yes
|
|
|
|
### Options
|
|
|
|
#### --yes, -y
|
|
|
|
confirm non interactively
|
|
|
|
## app associate <name>
|
|
|
|
Use this command to associate a project directory with a resin application.
|
|
|
|
This command adds a 'resin' git remote to the directory and runs git init if necessary.
|
|
|
|
Notice this command asks for confirmation interactively.
|
|
You can avoid this by passing the `--yes` boolean option.
|
|
|
|
Examples:
|
|
|
|
$ resin app associate MyApp
|
|
$ resin app associate MyApp --project my/app/directory
|
|
|
|
## init
|
|
|
|
Use this command to initialise a directory as a resin application.
|
|
|
|
This command performs the following steps:
|
|
- Create a resin.io application.
|
|
- Initialize the current directory as a git repository.
|
|
- Add the corresponding git remote to the application.
|
|
|
|
Examples:
|
|
|
|
$ resin init
|
|
$ resin init --project my/app/directory
|
|
|
|
# Authentication
|
|
|
|
## login [token]
|
|
|
|
Use this command to login to your resin.io account.
|
|
|
|
To login, you need your token, which is accesible from the preferences page:
|
|
|
|
https://dashboard.resin.io/preferences
|
|
|
|
Examples:
|
|
|
|
$ resin login
|
|
$ resin login "eyJ0eXAiOiJKV1Qi..."
|
|
|
|
## logout
|
|
|
|
Use this command to logout from your resin.io account.o
|
|
|
|
Examples:
|
|
|
|
$ resin logout
|
|
|
|
## signup
|
|
|
|
Use this command to signup for a resin.io account.
|
|
|
|
If signup is successful, you'll be logged in to your new user automatically.
|
|
|
|
Examples:
|
|
|
|
$ resin signup
|
|
Email: me@mycompany.com
|
|
Username: johndoe
|
|
Password: ***********
|
|
|
|
$ resin signup --email me@mycompany.com --username johndoe --password ***********
|
|
|
|
$ resin whoami
|
|
johndoe
|
|
|
|
### Options
|
|
|
|
#### --email, -e <email>
|
|
|
|
user email
|
|
|
|
#### --username, -u <username>
|
|
|
|
user name
|
|
|
|
#### --password, -p <user password>
|
|
|
|
user password
|
|
|
|
## whoami
|
|
|
|
Use this command to find out the current logged in username.
|
|
|
|
Examples:
|
|
|
|
$ resin whoami
|
|
|
|
# Device
|
|
|
|
## devices
|
|
|
|
Use this command to list all devices that belong to you.
|
|
|
|
You can filter the devices by application by using the `--application` option.
|
|
|
|
Examples:
|
|
|
|
$ resin devices
|
|
$ resin devices --application MyApp
|
|
$ resin devices --app MyApp
|
|
$ resin devices -a MyApp
|
|
|
|
### Options
|
|
|
|
#### --application, --a,app, --a,app <application>
|
|
|
|
application name
|
|
|
|
## device <name>
|
|
|
|
Use this command to show information about a single device.
|
|
|
|
Examples:
|
|
|
|
$ resin device MyDevice
|
|
|
|
## device rm <name>
|
|
|
|
Use this command to remove a device from resin.io.
|
|
|
|
Notice this command asks for confirmation interactively.
|
|
You can avoid this by passing the `--yes` boolean option.
|
|
|
|
Examples:
|
|
|
|
$ resin device rm MyDevice
|
|
$ resin device rm MyDevice --yes
|
|
|
|
### Options
|
|
|
|
#### --yes, -y
|
|
|
|
confirm non interactively
|
|
|
|
## device identify <uuid>
|
|
|
|
Use this command to identify a device.
|
|
|
|
In the Raspberry Pi, the ACT led is blinked several times.
|
|
|
|
Examples:
|
|
|
|
$ resin device identify 23c73a12e3527df55c60b9ce647640c1b7da1b32d71e6a39849ac0f00db828
|
|
|
|
## device rename <name> [newName]
|
|
|
|
Use this command to rename a device.
|
|
|
|
If you omit the name, you'll get asked for it interactively.
|
|
|
|
Examples:
|
|
|
|
$ resin device rename MyDevice MyPi
|
|
$ resin device rename MyDevice
|
|
|
|
## devices supported
|
|
|
|
Use this command to get the list of all supported devices
|
|
|
|
Examples:
|
|
|
|
$ resin devices supported
|
|
|
|
## device await <name>
|
|
|
|
Use this command to await for a device to become online.
|
|
|
|
The process will exit when the device becomes online.
|
|
|
|
Notice that there is no time limit for this command, so it might run forever.
|
|
|
|
You can configure the poll interval with the --interval option (defaults to 3000ms).
|
|
|
|
Examples:
|
|
|
|
$ resin device await MyDevice
|
|
$ resin device await MyDevice --interval 1000
|
|
|
|
### Options
|
|
|
|
#### --interval, -i <interval>
|
|
|
|
poll interval
|
|
|
|
## device init [device]
|
|
|
|
Use this command to download the OS image of a certain application and write it to an SD Card.
|
|
|
|
Note that this command requires admin privileges.
|
|
|
|
If `device` is omitted, you will be prompted to select a device interactively.
|
|
|
|
Notice this command asks for confirmation interactively.
|
|
You can avoid this by passing the `--yes` boolean option.
|
|
|
|
You can quiet the progress bar by passing the `--quiet` boolean option.
|
|
|
|
You may have to unmount the device before attempting this operation.
|
|
|
|
You need to configure the network type and other settings:
|
|
|
|
Ethernet:
|
|
You can setup the device OS to use ethernet by setting the `--network` option to "ethernet".
|
|
|
|
Wifi:
|
|
You can setup the device OS to use wifi by setting the `--network` option to "wifi".
|
|
If you set "network" to "wifi", you will need to specify the `--ssid` and `--key` option as well.
|
|
|
|
You can omit network related options to be asked about them interactively.
|
|
|
|
Examples:
|
|
|
|
$ resin device init
|
|
$ resin device init --application MyApp
|
|
$ resin device init --application MyApp --network ethernet
|
|
$ resin device init /dev/disk2 --application MyApp --network wifi --ssid MyNetwork --key secret
|
|
|
|
### Options
|
|
|
|
#### --application, --a,app, --a,app <application>
|
|
|
|
application name
|
|
|
|
#### --network, -n <network>
|
|
|
|
network type
|
|
|
|
#### --ssid, -s <ssid>
|
|
|
|
wifi ssid, if network is wifi
|
|
|
|
#### --key, -k <key>
|
|
|
|
wifi key, if network is wifi
|
|
|
|
# Drive
|
|
|
|
## drives
|
|
|
|
Use this command to list all drives that are connected to your machine.
|
|
|
|
Examples:
|
|
|
|
$ resin drives
|
|
|
|
# Environment Variables
|
|
|
|
## envs
|
|
|
|
Use this command to list all environment variables for a particular application.
|
|
Notice we will support per-device environment variables soon.
|
|
|
|
This command lists all custom environment variables set on the devices running
|
|
the application. If you want to see all environment variables, including private
|
|
ones used by resin, use the verbose option.
|
|
|
|
Example:
|
|
|
|
$ resin envs --application 91
|
|
$ resin envs --application 91 --verbose
|
|
|
|
### Options
|
|
|
|
#### --application, --a,app, --a,app <application>
|
|
|
|
application name
|
|
|
|
#### --verbose, -v
|
|
|
|
show private environment variables
|
|
|
|
## env rm <id>
|
|
|
|
Use this command to remove an environment variable from an application.
|
|
|
|
Don't remove resin specific variables, as things might not work as expected.
|
|
|
|
Notice this command asks for confirmation interactively.
|
|
You can avoid this by passing the `--yes` boolean option.
|
|
|
|
Examples:
|
|
|
|
$ resin env rm 215
|
|
$ resin env rm 215 --yes
|
|
|
|
### Options
|
|
|
|
#### --yes, -y
|
|
|
|
confirm non interactively
|
|
|
|
## env add <key> [value]
|
|
|
|
Use this command to add an enviroment variable to an application.
|
|
|
|
You need to pass the `--application` option.
|
|
|
|
If value is omitted, the tool will attempt to use the variable's value
|
|
as defined in your host machine.
|
|
|
|
If the value is grabbed from the environment, a warning message will be printed.
|
|
Use `--quiet` to remove it.
|
|
|
|
Examples:
|
|
|
|
$ resin env add EDITOR vim -a 91
|
|
$ resin env add TERM -a 91
|
|
|
|
### Options
|
|
|
|
#### --application, --a,app, --a,app <application>
|
|
|
|
application name
|
|
|
|
## env rename <id> <value>
|
|
|
|
Use this command to rename an enviroment variable from an application.
|
|
|
|
Examples:
|
|
|
|
$ resin env rename 376 emacs
|
|
|
|
# Examples
|
|
|
|
## examples
|
|
|
|
Use this command to list available example applications from resin.io
|
|
|
|
Example:
|
|
|
|
$ resin examples
|
|
|
|
## example <id>
|
|
|
|
Use this command to show information of a single example application
|
|
|
|
Example:
|
|
|
|
$ resin example 3
|
|
|
|
## example clone <id>
|
|
|
|
Use this command to clone an example application to the current directory
|
|
|
|
This command outputs information about the cloning process.
|
|
Use `--quiet` to remove that output.
|
|
|
|
Example:
|
|
|
|
$ resin example clone 3
|
|
|
|
# Help
|
|
|
|
## help [command...]
|
|
|
|
Get detailed help for an specific command.
|
|
|
|
Examples:
|
|
|
|
$ resin help apps
|
|
$ resin help os download
|
|
|
|
# Information
|
|
|
|
## version
|
|
|
|
Display the Resin CLI version.
|
|
|
|
# Keys
|
|
|
|
## keys
|
|
|
|
Use this command to list all your SSH keys.
|
|
|
|
Examples:
|
|
|
|
$ resin keys
|
|
|
|
## key <id>
|
|
|
|
Use this command to show information about a single SSH key.
|
|
|
|
Examples:
|
|
|
|
$ resin key 17
|
|
|
|
## key rm <id>
|
|
|
|
Use this command to remove a SSH key from resin.io.
|
|
|
|
Notice this command asks for confirmation interactively.
|
|
You can avoid this by passing the `--yes` boolean option.
|
|
|
|
Examples:
|
|
|
|
$ resin key rm 17
|
|
$ resin key rm 17 --yes
|
|
|
|
### Options
|
|
|
|
#### --yes, -y
|
|
|
|
confirm non interactively
|
|
|
|
## key add <name> [path]
|
|
|
|
Use this command to associate a new SSH key with your account.
|
|
|
|
If `path` is omitted, the command will attempt
|
|
to read the SSH key from stdin.
|
|
|
|
Examples:
|
|
|
|
$ resin key add Main ~/.ssh/id_rsa.pub
|
|
$ cat ~/.ssh/id_rsa.pub | resin key add Main
|
|
|
|
# Logs
|
|
|
|
## logs <uuid>
|
|
|
|
Use this command to show logs for a specific device.
|
|
|
|
By default, the command prints all log messages and exit.
|
|
|
|
To limit the output to the n last lines, use the `--num` option along with a number.
|
|
This is similar to doing `resin logs <uuid> | tail -n X`.
|
|
|
|
To continuously stream output, and see new logs in real time, use the `--tail` option.
|
|
|
|
Note that for now you need to provide the whole UUID for this command to work correctly.
|
|
|
|
This is due to some technical limitations that we plan to address soon.
|
|
|
|
Examples:
|
|
|
|
$ resin logs 23c73a12e3527df55c60b9ce647640c1b7da1b32d71e6a39849ac0f00db828
|
|
$ resin logs 23c73a12e3527df55c60b9ce647640c1b7da1b32d71e6a39849ac0f00db828 --num 20
|
|
$ resin logs 23c73a12e3527df55c60b9ce647640c1b7da1b32d71e6a39849ac0f00db828 --tail
|
|
|
|
### Options
|
|
|
|
#### --num, -n <num>
|
|
|
|
number of lines to display
|
|
|
|
#### --tail, -t
|
|
|
|
continuously stream output
|
|
|
|
# Notes
|
|
|
|
## note <|note>
|
|
|
|
Use this command to set or update a device note.
|
|
|
|
If note command isn't passed, the tool attempts to read from `stdin`.
|
|
|
|
To view the notes, use $ resin device <name>.
|
|
|
|
Examples:
|
|
|
|
$ resin note "My useful note" --device MyDevice
|
|
$ cat note.txt | resin note --device MyDevice
|
|
|
|
### Options
|
|
|
|
#### --device, --d,dev, --d,dev <device>
|
|
|
|
device name
|
|
|
|
# OS
|
|
|
|
## os download <name>
|
|
|
|
Use this command to download the device OS configured to a specific network.
|
|
|
|
Ethernet:
|
|
You can setup the device OS to use ethernet by setting the `--network` option to "ethernet".
|
|
|
|
Wifi:
|
|
You can setup the device OS to use wifi by setting the `--network` option to "wifi".
|
|
If you set "network" to "wifi", you will need to specify the `--ssid` and `--key` option as well.
|
|
|
|
Alternatively, you can omit all kind of network configuration options to configure interactively.
|
|
|
|
You have to specify an output location with the `--output` option.
|
|
|
|
Examples:
|
|
|
|
$ resin os download MyApp --output ~/MyResinOS.zip
|
|
$ resin os download MyApp --network ethernet --output ~/MyResinOS.zip
|
|
$ resin os download MyApp --network wifi --ssid MyNetwork --key secreykey123 --output ~/MyResinOS.zip
|
|
$ resin os download MyApp --network ethernet --output ~/MyResinOS.zip
|
|
|
|
### Options
|
|
|
|
#### --network, -n <network>
|
|
|
|
network type
|
|
|
|
#### --ssid, -s <ssid>
|
|
|
|
wifi ssid, if network is wifi
|
|
|
|
#### --key, -k <key>
|
|
|
|
wifi key, if network is wifi
|
|
|
|
#### --output, -o <output>
|
|
|
|
output file
|
|
|
|
## os install <image> [device]
|
|
|
|
Use this command to write an operating system image to a device.
|
|
|
|
Note that this command requires admin privileges.
|
|
|
|
If `device` is omitted, you will be prompted to select a device interactively.
|
|
|
|
Notice this command asks for confirmation interactively.
|
|
You can avoid this by passing the `--yes` boolean option.
|
|
|
|
You can quiet the progress bar by passing the `--quiet` boolean option.
|
|
|
|
Examples:
|
|
|
|
$ resin os install rpi.iso /dev/disk2
|
|
|
|
### Options
|
|
|
|
#### --yes, -y
|
|
|
|
confirm non interactively
|
|
|
|
# Plugin
|
|
|
|
## plugins
|
|
|
|
Use this command to list all the installed resin plugins.
|
|
|
|
Examples:
|
|
|
|
$ resin plugins
|
|
|
|
## plugin install <name>
|
|
|
|
Use this command to install a resin plugin
|
|
|
|
Use `--quiet` to prevent information logging.
|
|
|
|
Examples:
|
|
|
|
$ resin plugin install hello
|
|
|
|
## plugin update <name>
|
|
|
|
Use this command to update a resin plugin
|
|
|
|
Use `--quiet` to prevent information logging.
|
|
|
|
Examples:
|
|
|
|
$ resin plugin update hello
|
|
|
|
## plugin rm <name>
|
|
|
|
Use this command to remove a resin.io plugin.
|
|
|
|
Notice this command asks for confirmation interactively.
|
|
You can avoid this by passing the `--yes` boolean option.
|
|
|
|
Examples:
|
|
|
|
$ resin plugin rm hello
|
|
$ resin plugin rm hello --yes
|
|
|
|
### Options
|
|
|
|
#### --yes, -y
|
|
|
|
confirm non interactively
|
|
|
|
# Preferences
|
|
|
|
## preferences
|
|
|
|
Use this command to open the preferences form.
|
|
|
|
In the future, we will allow changing all preferences directly from the terminal.
|
|
For now, we open your default web browser and point it to the web based preferences form.
|
|
|
|
Examples:
|
|
|
|
$ resin preferences
|
|
|
|
# Update
|
|
|
|
## update
|
|
|
|
Use this command to update the Resin CLI
|
|
|
|
This command outputs information about the update process.
|
|
Use `--quiet` to remove that output.
|
|
|
|
The Resin CLI checks for updates once per day.
|
|
|
|
Major updates require a manual update with this update command,
|
|
while minor updates are applied automatically.
|
|
|
|
Examples:
|
|
|
|
$ resin update
|
|
|