Automates terminal operations.
cLive requires ttyd (version 1.7.4 or higher) to be installed.
For example, if you are using homebrew, you can install it with brew install.
$ brew install ttydSee the ttyd documentation for more information.
Note
There are prerequisites for using cLive. See Prerequisite for details.
$ brew install koki-develop/tap/clive$ brew install clive$ go install github.com/koki-develop/clive@latestDownload the binary from the releases page.
First, run clive init.
$ clive init
Created ./clive.ymlA file named clive.yml will then be created with the following contents:
# documentation: https://github.com/koki-develop/clive#settings
settings:
loginCommand: ["bash", "--login"]
fontSize: 22
defaultSpeed: 10
# documentation: https://github.com/koki-develop/clive#actions
actions:
- pause
- type: echo 'Welcome to cLive!'
- key: enterFinally, run clive start to launch the browser and start cLive.
$ clive startAvailable commands:
init- Create a config file.start- Start cLive actions.validate- Validate a config file.completion- Generate the autocompletion script for the specified shell.
Create a config file.
$ clive init| Flag | Default | Description |
|---|---|---|
-c, --config |
./clive.yml |
Config file name. |
Start cLive actions.
See Configuration for the config file.
$ clive start| Flag | Default | Description |
|---|---|---|
-c, --config |
./clive.yml |
Config file name. |
Validate a config file.
$ clive validate| Flag | Default | Description |
|---|---|---|
-c, --config |
./clive.yml |
Config file name. |
Generate the autocompletion script for clive for the specified shell.
See each sub-command's help for details on how to use the generated script.
$ clive completion <shell>
# e.g.
$ clive completion bash
$ clive completion bash --helpAvailable shells:
- bash
- fish
- powershell
- zsh
The config file consists of actions and settings.
Basic settings.
Available settings:
loginCommand- Login command and args.fontSize- Font size.fontFamily- Font family.defaultSpeed- Default interval between key typing.skipPauseBeforeQuit- Whether to skip pausing before quitting.screenshotsDir- Directory to save screenshots.browserBin- Path to an executable browser binary.headless- Whether to run the browser in headless mode.width- Window width.height- Window height.
Login command and args.
Default: ["bash", "--login"].
# e.g.
settings:
loginCommand: ["zsh", "--login"]Font size.
Default: 22
# e.g.
settings:
fontSize: 36Font family.
# e.g.
settings:
fontFamily: monospaceDefault interval between key typing.
Default: 10
# e.g.
settings:
defaultSpeed: 100Whether to skip pausing before quitting.
Default: false
# e.g.
settings:
skipPauseBeforeQuit: trueDirectory to save screenshots.
Default: screenshots
# e.g.
settings:
screenshotsDir: path/to/picturesPath to an executable browser binary.
See the go-rod documentation for supported browsers.
# e.g.
settings:
browserBin: /Applications/Vivaldi.app/Contents/MacOS/Vivaldi # use VivaldiWhether to run the browser in headless mode.
Default: false
# e.g.
settings:
headless: trueWindow width.
# e.g.
settings:
width: 1600Window height.
# e.g.
settings:
height: 800Actions to run.
Available actions:
type- Type characters.key- Enter special keys.ctrl- Press the Ctrl key with other keys.sleep- Sleep for a specified number of milliseconds.pause- Pause actions.screenshot- Take a screenshot.
Type characters.
| Field | Required | Default | Description |
|---|---|---|---|
type |
Yes | N/A | Characters to type. |
count |
No | 1 |
Number of times to repeat the action. |
speed |
No | 10 |
Interval between key typing (milliseconds). |
# e.g.
actions:
- type: echo 'Hello World'
count: 10 # Optional
speed: 100 # OptionalEnter special keys.
Available keys:
escbackspacetabenterleftuprightdownspace
| Field | Required | Default | Description |
|---|---|---|---|
key |
Yes | N/A | Special key to type. |
count |
No | 1 |
Number of times to repeat the action. |
speed |
No | 10 |
Interval between key typing (milliseconds). |
# e.g.
actions:
- key: enter
count: 10 # Optional
speed: 100 # OptionalPress the Ctrl key with other keys.
| Field | Required | Default | Description |
|---|---|---|---|
ctrl |
Yes | N/A | Characters to enter with the ctrl key. |
count |
No | 1 |
Number of times to repeat the action. |
speed |
No | 10 |
Interval between key typing (milliseconds). |
# e.g.
actions:
- ctrl: c # Ctrl+c
count: 10 # Optional
speed: 100 # OptionalSleep for a specified number of milliseconds.
| Field | Required | Default | Description |
|---|---|---|---|
sleep |
Yes | N/A | Time to sleep (milliseconds). |
# e.g.
actions:
- sleep: 3000 # Sleep for 3 seconds.Pause actions.
Press enter to continue.
# e.g.
actions:
- pauseTake a screenshot.
Screenshots are saved in screenshots/.
The directory to save the screenshots can be changed in settings.screenshotsDir.
| Field | Required | Default | Description |
|---|---|---|---|
screenshot |
No | <ACTION_INDEX>_<yyyymmddHHMMSS>.png |
File name of the screenshot. |
# e.g.
actions:
- screenshot
- screenshot: foobar.png # OptionalFor more examples see the examples/ directory.
If you like this project, please consider buying me a coffee.

