The CLI is the main way to interact with a serene server. It uses the API of the server to add and manipulate the packages that are managed by the server. It is not required to just use the built packages from the server though, as this is purely done through pacman.
This section will cover some of the ways one can use the cli to interact with the server.
To get exhaustive options and information about a (sub-) command, you should still refer to the --help
page of that item, as only some options are shown here.
Listing all packages: To list all packages built by the server, their version and build status, use:
# List all managed packages:
serene list
Adding packages: Serene currently supports three types of packages, those from the AUR, custom git repositories, and custom PKGBUILDs. The custom git repositories must be formulated the same way as AUR repositories are. An added package is built immediately. Supplying --replace
replaces the source of a package if it is already added, which is often used when updating custom pkgbuilds. Adding them is straight forward:
# Adding an AUR package called `my-package`.
serene add my-package
# Adding a custom repository from github. The optional devel flag specifies that it is a development package (e.g. it works like -git).
serene add --custom --devel https://github.com/my-user/my-package
# Adding a custom pkgbuild for a git package from the filesystem, replacing the previous version. We load the pkgbuild from the filesystem.
serene add --pkgbuild --devel --replace --file ./PKGBUILD
# Adding and automatically installing `my-package` from the AUR without showing build logs.
serene add --install --quiet my-pacakge
Removing packages: To remove a package, just call the remove subcommand with the package base:
# Removes `my-package`.
serene remove my-package
Build package now: To build a package now, run this subcommand with the package base:
# Builds `my-package` now.
serene build my-package
# Builds `my-package` in a clean container and install it now.
serene build --clean --install my-package
See package information: To see all information for a package, you can use the info command and its various subcommands:
# Get an overview about the package `my-package`. Add `--all` to see all, and not just the latest eight builds.
serene info my-package
# Print the PKGBUILD used for the package currently in the repository to stdout.
serene info my-package pkgbuild
# See more information about the latest build. Supply an id for a specific one.
serene info my-package build
# See the logs of the latest build. Supply an id for a specific one. Add `--subscribe` to get live logs until next build is finished and `--linger` to indefinitely attach to live logs.
serene info my-package logs
Changing package properties: To change properties of a package and how it is built, you can use the set subcommand of info:
# Enable clean build, meaning the container is removed after each build and recreated. Any boolean value can be supplied.
serene info my-package set clean true
# Disable automatic building of the package. Any boolean value can be supplied.
serene info my-package set enable false
# Set a custom schedule for this package only. Expects a valid cron string.
serene info my-package set schedule "0 * * * *"
# Set commands to run before the package is built. This is mainly used to add e.g. required keys, or change something else about the container. It will be executed with bash.
serene info my-package set prepare "echo 'i am run before the makepkg'"
# Set additional flags which are passed to makepkg when building. See `makepkg --help` for more information. Note that only some options are supported.
serene info my-package set flags "nocheck" "holdver"
Manage the server: To manage some server properties, you can use the manage subcommand:
# See general server information
serene manage info
# Request and print the webhook secret for the package `my-package`
serene manage webhook my-package
Print the local secret of the CLI: To print the local secret again, run the following:
# Prints the secret to add to the `authorized_secrets` file.
serene secret
There are various ways to build and install the cli on your own system. By default, the serene server builds a package for the cli automatically. This package can then be downloaded and installed, either through pacman, or manually. This is the recommended way, but the package can also be installed entirely manually:
A PKGBUILD
for the cli is provided in this repository. It is used by the serene server when building the package, but can also be used manually. However, since it is not in a normal, empty repository, the workflow would look like this:
git clone https://github.com/VirtCode/serene-aur
cd serene-aur/cli
makepkg -irsc
Shell completions will be automatically installed alongside the package.
You can also build the package directly using cargo. To do that, clone the repository and build it from the root directory of the package:
cargo build --release --bin serene-cli
Now, copy the built binary (at target/release/serene-cli
) to your path, preferably as serene
, as that is how the package will call the binary.
You can generate shell completions for your current shell and add them manually. Use the following command to generate the completions:
serene completions
The cli does not offer much local configuration. It does set up everything needed automatically on the first startup, like prompting the user for the location of the server, generating a secret, etc. This makes it very easy to set up.
This configuration is stored at ~/.config/serene.yml
(or wherever your xdg-config-home is) as YAML. It contains the following attributes:
# Local secret used by the cli in plain text.
secret: [my-secret]
# Url of the server that is used.
url: [my-server-url]
As seen in the Building Manually section, the cli includes shell completions. These will be installed automatically for most shells (unless you're building directly). Make sure to enable them in your preferred shell.
Some shells (currently only Bash) also feature dynamic completions. This means you can complete package names for commands like serene info
or serene build
. The names that can be completed are sourced from a cache file, which is updated every time serene list
is invoked. This avoids unintended network usage when just completing your command, but might not be totally accurate.
So if your package completions are not up-to-date, make sure your shell supports them and run serene list
to update the completions in the background. Contributions for support for other shells are welcomed.