🎹 Usage

🎹 Usage

πŸ“¨ Valet commands

Valet is a CLI tool that exposes usable commands (e.g. valet help) or sub commands (e.g. valet self update).

Each command can accept options (e.g. --help or -v) and/or arguments (e.g. in valet self extend my-extension, my-extension is an argument of the valet self extend command).

Each command has properties that enable Valet to:

  • Display its usage (e.g. a description, some examples…),
  • parse the options and arguments of that command.

You can access the help of a command by either typing valet help my-command or valet my-command --help.

Commands can be nested under another parent command which is what we call sub commands. E.g. the self update command is a sub command of the self command. There is no limit to the level of nesting for sub commands.

ℹ️
By default, Valet will try to match a miss-spelled command or option in a process called fuzzy finding. For instance, typing mcmd can match the command mycommand if it exists. You can opt-out of this behavior through configuration.

Behind the scene, a command refers to a bash function written in a bash script file which is source’d before calling the function. Commands are indexed ahead of time in a process called build (the valet self build command) in order to not waste time searching for the command script during execution.

πŸ€” About options and arguments

Options

Options can have multiple long name (--my-option is long name) and up to one short name (-v is a short composed of a single letter).

Short names can be grouped together, e.g. -fsL is equivalent to -f -s -L or equivalent to the long name options --force --silent --follow.

  • Options can be simple flags (i.e. we check if the option is present or not).
  • Or can have a value, in which case they are represented as such: --my-option <value> and the user is expected to provide a value.

Each option can be set using a environment variable matching the option long name in UPPER_SNAKE_CASE (e.g. –my-option can be set using export MY_OPTION="value").

Arguments

Arguments are always mandatory and must be provided by the user.

An argument that starts with a - character can be wrongly interpreted as an option. You can use -- to mark the separation between options and commands. E.g. valet my-command -- -my-argument- allows to interpret -my-argument- as the first and only argument of my-command instead of an option.

πŸ“– Command menu

Calling valet without any arguments (you can pass options) will open the interactive search for commands.

Type your query (fuzzy matching is active so you can skip some letters), press ⬇️/⬆️ to select the command and hit enter to run it. Press ⬅️/➑️ (or [PAGE_DOWN]/[PAGE_UP] and [HOME]/[END]) to navigate a command help. Press ESC to leave without selecting a command.

The command property hideInMenu can prevent a command from being displayed in the menu. These commands are still executable by passing the command name directly to Valet (i.e. you can call valet self setup even if it is hidden in the menu).

Similarly, you can execute a parent command (e.g. valet self) to open an interactive menu with only the commands that are nested under it.

🌳 Environments variables

Almost all options in Valet are configurable with environment variables. Even options that you can pass to your custom commands can be set through variables (check the --help)!

This makes Valet particularly suitable for automation (in CI/CD pipelines for instance).

Additionally, at the beginning of its execution, Valet will source a file named .env located in the current directory, which enables you to set up command options (this file name can be changed if needed).

βœ’οΈ Adding your own commands and libraries

Valet is pre-configured with some example commands so you can try it immediately and see how it feels.

However, the main goal is to extend Valet and create your own commands. Valet takes care of the boilerplate stuff (parsing arguments, proper log functions, help, testing your command…) so you can focus on the feature of your command.

To create a new command, follow this documentation.

To create a new library, follow this documentation.

πŸͺ„ Use Valet library functions directly in bash

Thanks to the self export command, you can export Valet functions so they are usable directly in your bash session:

eval "$(valet self export -a)"

log::info "Cool logs!"
if interactive::promptYesNo "Do you want to continue?"; then echo "Yes."; else echo "No."; fi