# Configuration `cuddle-please` requires configuration to function, it is quite flexible, and tries to help you as much as possible filling out values for you, or using sane defaults. First of all, you can either use the `cuddle.yaml` if using `cuddle`, or `cuddle.please.yaml` if using standalone. ```yaml # file: cuddle.yaml please: <contents of cuddle.please.yaml> --- # file: cuddle.please.yaml project: owner: kjuulh repository: cuddle-please branch: main settings: api_url: https://git.front.kjuulh.io ``` This is all the configuration, most of these won't be needed when running in CI. `cuddle` fetches configuration items from different sources, each level is able to override the previous layer. 1. Execution environment 2. Configuration files 3. Stdin 4. Env variables 5. Cli arguments 6. User input Lets break each down. ### Execution environment Execution environment, is the environment under which cuddle-please is run, if running in CI, we're able to take some variables, without requiring input from the user, or configuration values. Right now only `drone-ci` is supported, but github actions and such, are nearly done. #### Drone CI Drone CI, will automatically fill out ```yaml project: owner: <drone> repository: <drone> branch: <drone> ``` This means that the only thing the user needs to configure is the `api_url` and the access `<token>` ### Configuration files Already shown above, this allows setting hard-coded values, especially useful for the `api_url`. ### Stdin All the configurations can be passed via. stdin ```bash cat cuddle.please.yaml | cuddle-please release --stdin ``` ### Env variables The CLI shows which env variables are available via. `cuddle-please release --help`. ### CLI args The CLI shows which args are available via. `cuddle-please release -h # or --help` `-h` gives a shorthand description and `--help` provides a longer explanation of each arg. There are some args, which are exclusive to the cli or env variables, such as `<token>`. This is because it is a secret and it shouldn't be leaked in the configuration. There are some exceptions such as `GITHUB_TOKEN` which is picked in the environment variable layer. ### Interactive (User input) cuddle-please will determine whether or not it is running with a user interactive `stdin`, and will prompt for missing values if running locally. This is disabled without a proper tty, or if running in one of the CI execution environments by default. Otherwise `--no-interactive` can be passed to any command.