Pleasant CLI is a simple CLI that lets you interact with Pleasant Password Server instances through the command line. It uses the Pleasant Password Server API to communicate with the server.
It should work with any instance that supports API version 5 (/api/v5/
).
Go to Releases and download the latest release for your platform.
Extract the archive to a location in your $PATH
, e.g. on Ubuntu: /usr/local/bin
.
First, you need to set the server URL for the CLI to connect to.
It must be specified as <PROTOCOL>://<URL>:<PORT>
.
pleasant-cli config serverurl <SERVER URL>
The server URL will be saved to the configuration file (default: $HOME/.pleasant-cli.yaml
).
If you want to use a different config path, add the flag --config <PATH>
to all commands.
Next, log into the Pleasant Password Server:
pleasant-cli login
Note: this will perform an interactive login. You can also pass your credentials as flags.
pleasant-cli login --username <USERNAME> --password <PASSWORD>
This will retrieve an access token and save it to a file (default: $HOME/.pleasant-token.yaml
) for subsequent commands.
If you want to save/use the token in a different location, add the flag --token <PATH>
to all commands.
In order to view all available commands, run the CLI without any arguments.
$ pleasant-cli
pleasant-cli is an easy to use CLI that uses the Pleasant Password Server
API to interact with a Pleasant Password Server instance.
To use pleasant-cli, you must first set your server URL by running the following command:
pleasant-cli config serverurl <SERVER URL>
You can then log in by running:
pleasant-cli login
Usage:
pleasant-cli [command]
Available Commands:
apply Applies a configuration to entries or folders
completion Generate the autocompletion script for the specified shell
config Interact with pleasant-cli configuration
create Creates entries or folders
delete Archives or deletes entries or folders or user access assignments for them
get Gets entries, folders, access levels, server info or password strength
help Help about any command
login Log in to Pleasant Password Server
patch Partially updates entries or folders or adds user access assignments for them
search Search for entries and folders matching a query
Flags:
--config string config file (default is $HOME/.pleasant-cli.yaml)
-h, --help help for pleasant-cli
-t, --toggle Help message for toggle
--token string token file (default is $HOME/.pleasant-token.yaml)
-v, --version version for pleasant-cli
Use "pleasant-cli [command] --help" for more information about a command.
To view information on (sub)commands, append --help
to any command.
$ pleasant-cli login --help
Log into Pleasant Password Server with username and password.
Username and password can either be entered interactively or by using flags.
Examples:
pleasant-cli login
pleasant-cli login --username <USERNAME> --password <PASSWORD>
Usage:
pleasant-cli login [flags]
Flags:
-h, --help help for login
-p, --password string Password for Pleasant Password Server
-u, --username string Username for Pleasant Password Server
Global Flags:
--config string config file (default is $HOME/.pleasant-cli.yaml)
--token string token file (default is $HOME/.pleasant-token.yaml)
A minimal Alpine-based Docker image is provided here:
Latest version
docker pull ghcr.io/marevers/pleasant-cli:latest
Specific version
docker pull ghcr.io/marevers/pleasant-cli:<version>
To build with Go, you must have Go installed (version 1.23).
go build
This creates the pleasant-cli
executable in the current location.
It is also possible to run certain commands directly without first building. For example:
go run . get entry --id <id>
To build the project as a Nix flake (ensure you have Nix installed with flakes enabled):
nix build
This creates a result
symlink pointing to the built package in your Nix store.
To run it directly:
nix run
To enter a development environment with all necessary dependencies:
nix develop
To install it in your current profile:
nix profile install
You may also want to update the locked dependencies in flake.lock
:
nix flake update
As Nix uses hashes to ensure reproducibility between builds, you may need to update the vendor hash in flake.nix
when Go dependencies change (for example after go get -u
).
To do so, run nix build
as usual: this will fail giving the expected new hash that you can use to update the vendorHash
variable in flake.nix
. Once updated, the rebuild should work as expected.
For more information about using flakes in Nix and NixOS environments please have a look at the documentation.
Clipboard support
I am planning to at some point add clipboard support, meaning, you will be able to run a get
command and immediately store the response on the clipboard, for example to retrieve a password and immediately paste it into another program.
Currently I cannot implement this without breaking the CLI on any platform where the clipboard package wouldn't be available, but should that change then most likely it will be added.
Pleasant CLI is released under the Apache 2.0 license. See LICENSE.txt