@signageos/cli v2.4.1
signageOS CLI
signageOS command-line interface which helps you develop your applets locally and manage devices from terminal.
Usage
npm install @signageos/cli -g
sos --helpUser Interface
cli tool allows you to run commands interactively for best user experience, please use standard bash terminal on *nix systems and gitbash, run it in windows terminal.
Autocomplete
signageOS CLI offers tab completion for commands and options, which enhances the user experience by making it easier to discover and use available commands.
Installation
To enable autocomplete in your shell, use the following command:
sos autocomplete installThis will install a completion script in your home directory and add a source line to your shell configuration file (.zshrc, .bashrc, or .bash_profile, depending on your shell).
To start using autocomplete immediately without restarting your terminal, run:
source ~/.sos-completion.shUsage
Once autocomplete is installed, you can use the TAB key to discover and complete commands:
sos [TAB]          # Show all top-level commands
sos applet [TAB]   # Show all applet subcommands
sos applet up[TAB] # Autocomplete to "sos applet upload"Uninstallation
If you want to disable autocomplete, use:
sos autocomplete uninstallThis will remove the completion script and the source line from your shell configuration file.
Test
cp .env.amy .env
npm testAPI reference
General
| Argument | Description | Default value | 
|---|---|---|
| --api-url (optional) | URL address to use for REST API | ${SOS_API_URL='https://api.signageos.io'} | 
| --profile (optional) | Profile used for separation of credentials and other configurations set in the ~/.sosrcfile | ${SOS_PROFILE} | 
Login
Requirements
- Active account. It can be obtained by manual sign-up in https://box.signageos.io
sos login- Login account to allow you to use REST API commands
- Logged account credentials are stored in ~/.sosrcfile.
- You can override login credentials using environment variables SOS_API_IDENTIFICATION&SOS_API_SECURITY_TOKEN. Go to https://box.signageos.io/settings to generate the token.
| Argument | Description | Default value | 
|---|---|---|
| --username (required) | Username or e-mail user for box | STDIN | 
Run control file
There is a file created when running command sos login in the path ~/.sosrc. This file contains by default only the following values (as default profile is used).
identification=xxxxxxxxxxxxxxxxxxxx
apiSecurityToken=xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxIf you'd like to manage more accounts/configurations on one machine, you can use environment variable SOS_PROFILE or argument --profile. The configuration file will use an INI section profile xxxx for the profile named xxxx. You can use as many profiles as you want.
[profile xxxx]
identification=xxxxxxxxxxxxxxxxxxxx
apiSecurityToken=xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxApplet
sos applet --helpApplet Generation
sos applet generate --name my-sample-applet --language=typescript
cd my-sample-applet
# Develop your applet with watching changes
npm start
# Build your applet production environment
npm run build| Argument | Description | Default value | 
|---|---|---|
| --name (required) | Name your applet | STDIN | 
| --version (optional) | Initial version | 0.0.0 | 
| --target-dir (optional) | Generate applet project to directory | ${PWD}/${name} | 
| --npm-registry (optional) | NPM registry URL (for private npm) | |
| --language (optional) | Generate applet with "typescript" or "javascript" source code | STDIN | 
| --bundler (optional) | Generate applet with "webpack" or "rspack" | webpack | 
| --git (optional) | Initialize applet as git repository "yes" or "no" | no | 
| --packager (optional) | Use preferred package manager "npm", "pnpm", "bun", "yarn" | npm | 
! Windows users note: There is an unresolved issue with NPX tool on Windows clients when your username contains spaces (e.g.:
John Doe). https://stackoverflow.com/a/58354623/4609457 To prevent this issue there is a simple hotfix. Run following command in your Command Line (replaceJohnwith your real first name): Sometimes the Administrator privileges are required (Run as Administrator)npm config set cache "C:\Users\John~1\AppData\Roaming\npm-cache" --global
Applet Upload
npm run upload
# Uploads all files in the applet directory
# Or alternatively you can use direct cli: `sos applet upload`
#Deprecated
sos applet upload --applet-path=dist/index.html
# This will upload only the one specified file
# The rest of the files will be removed from our servers- If applet is not created yet, it will create it
- The applet version is used from package.json
- Applet UID will be stored in package.jsonsos.appletUid
- You can use SOS_APPLET_UID as environment variable to specify appletUid to upload to (sos.appletUid of package.json will be overlooked).
- You can use SOS_APPLET_VERSION as environment variable to specify applet version to upload to (version of package.json will be overlooked).
- Ignore files priority (from top to bottom) .sosignore>.npmignore>.gitignore
- Only one ignore file is used or none
| Argument | Description | Default value | 
|---|---|---|
| --applet-path (optional) | Path of project directory | ${PWD} | 
| --entry-file-path (optional) | Path of applet entry file | ${PWD}/dist/index.html | 
Applet Build
sos applet build
# Build applet locally. The result is a zip file in the /tmp/signageos directory.| Argument | Description | Default value | 
|---|---|---|
| --applet-uid (required) | Applet UID | STDIN | 
| --organization-uid (required) | Organization UID | STDIN | 
Applet Start
sos applet start- It's meant to be used with applets not created using the cli
- Default values work for applet created using the cli
| Argument | Description | Default value | 
|---|---|---|
| --organization-uid (required) | Organization UID | STDIN | 
| --port (optional) | Port where the applet will run | 8090 | 
| --applet-path (optional) | Root path of applet project | ${PWD}/dist | 
| --entry-file-path (optional) | Path of built applet entry file | ${PWD}/dist/index.html | 
| --server-public-url (optional) | Public url of local machine server. Is useful when the local machine is behind a reverse proxy. | http://{CURRENT_REMOTE_ADDR}:{RANDOM_PORT} | 
| --server-port (optional) | The custom server port for local machine server. | {RANDOM_PORT} | 
| --hot-reload (optional) | Enable hot reload and build of applet | false | 
| --force (optional) | Force start applet server of hot reload even if it is already running on a different port. Kill the running server first. | false | 
| --detach (optional) | Run the applet HTTP server in the background (detached process) | false | 
| --forward-server-url (optional) | Custom forward server URL for sos device connectcommand. | https://forward.signageos.io | 
Applet Tests Upload
sos applet test upload- Upload all test files specified in package.json in sos.tests. The property is array of strings (relative paths to test files). E.g.: ["tests/sample.spec.js", "tests/sample2.spec.js"]
- It removes files which are extra on server already
| Argument | Description | Default value | 
|---|---|---|
| --yes (optional) | Skip interactive mode before it's uploaded | false | 
| --verbose (optional) | Show detailed info about changed files | false | 
Applet Tests Run
sos applet test run- Run test files uploaded to server remotely.
| Argument | Description | Default value | 
|---|---|---|
| --yes (optional) | Skip interactive mode before it's uploaded | false | 
| --test (optional) | Test files which should be run. If omitted, all test are run | {all tests} | 
Organization
sos organization --helpOrganization List
- Output is printed to STDOUT as JSON
sos organization listOrganization Get
- Output is printed to STDOUT as JSON
sos organization get| Argument | Description | Default value | 
|---|---|---|
| --organization-uid (required) | Organization UID | STDIN | 
Organization Set Default
- Sets default organization for current logged in account. This organization will be used for example in the webpack plugin of applet to register emulator
- If you do not set default organization, by default will be used the organization you will be asked to select from list where you have access to.
sos organization set-default- You can override default organization using environment variable SOS_ORGANIZATION_UID. Go to https://box.signageos.io/organizations to get the organizationUid.
| Argument | Description | Default value | 
|---|---|---|
| --organization-uid (required) | Organization UID | STDIN | 
Timing
sos timing --helpTiming List
- Output is printed to STDOUT as JSON
sos timing list| Argument | Description | Default value | 
|---|---|---|
| --organization-uid (required) | Organization UID | STDIN | 
| --device-uid (required) | Device UID | STDIN | 
Device
sos device --helpDevice Power action
Perform specified power action on a device.
sos device power-action| Argument | Description | Default value | 
|---|---|---|
| --organization-uid (required) | Organization UID | STDIN | 
| --device-uid (required) | Device UID | STDIN | 
| --type (required) | Type of power-action | STDIN | 
Device Power action types
| Argument | Description | 
|---|---|
| reload | Applet Reload | 
| displayOn | Display power On | 
| displayOff | Display power Off | 
| restart | Application restart | 
| disable | Applet disable | 
| enable | Applet enable | 
| reboot | System reboot | 
| refresh | Applet Refresh | 
Device Set-Content
sos device set-content| Argument | Description | Default value | 
|---|---|---|
| --organization-uid (required) | Organization UID | STDIN | 
| --device-uid (required) | Device UID | STDIN | 
| --applet-uid (required) | Applet UID | STDIN | 
Device connect
sos device connect
# You will be provided with setting parameters
# You should build and upload applet to box before connecting applet to device
# The applet has to be at least uploaded once with the specific version| Argument | Description | Default value | 
|---|---|---|
| --device-uid (required) | Uid of device from box | STDIN | 
| --applet-uid (required) | Applet UID | STDIN | 
| --organization-uid (required) | Organization UID | STDIN | 
| --update-package-config (optional) | Update package.json value sos.appletUidconfig when applet doesn't exist and is created | false | 
| --server-public-url (optional) | Public url of local machine server. Is useful when the local machine is behind a reverse proxy. | http://{CURRENT_REMOTE_ADDR}:{RANDOM_PORT} or https://forward.signageos.io/{random-hash} | 
| --use-forward-server (optional) | Use forward server to connect to the device instead of the local network (LAN) (https://forward.signageos.io/{random-hash}). It's useful when the device is not in the same network as the local machine. | false | 
| --server-port (optional) | The custom server port for local machine server. | {RANDOM_PORT} | 
| --force (optional) | Force start applet server even if it is already running on a different port. Kill the running server first. | false | 
| --applet-path (optional) | Root path of applet project | ${PWD}/dist | 
| --detach (optional) | Run the applet HTTP server in the background (detached process) | false | 
| --forward-server-url (optional) | Custom forward server URL. | https://forward.signageos.io | 
| --hot-reload (optional) | Enable hot reload and build of applet | false | 
Debugging
To enable debugging for the @signageos/cli:Applet:Upload:appletUploadFacade module, use:
DEBUG=@signageos/cli:Applet:Upload:appletUploadFacade sos applet uploadIf you want to enable debugging for all modules under @signageos, use the asterisk as a wildcard:
DEBUG=@signageos/* sos applet uploadYou can use export DEBUG=@signageos/* as well.
Contribution
Clone the repository and install dev dependencies
git clone git@github.com:signageos/cli.git # or https://github.com/signageos/cli.git
npm installTo try sos command directly from source code, use ts-node src/index.ts instead of sos in project directory.
Global requirements
npm install ts-node -g8 months ago
11 months ago
8 months ago
12 months ago
7 months ago
5 months ago
5 months ago
7 months ago
7 months ago
8 months ago
8 months ago
8 months ago
6 months ago
6 months ago
6 months ago
7 months ago
7 months ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
2 years ago
2 years ago
2 years ago
2 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago