mirror of https://github.com/vapor/docs.git
186 lines
4.9 KiB
Markdown
186 lines
4.9 KiB
Markdown
---
|
|
currentMenu: guide-config
|
|
---
|
|
|
|
# Config
|
|
|
|
An application's configuration settings. Cloud applications generally require complex configurations that can adjust based on their environment. Vapor intends to provide a flexible configuration interaction that can be customized for a given user.
|
|
|
|
## QuickStart
|
|
|
|
For Vapor applications, configuration files are expected to be nested under a top level folder named `Config`. Here's an example of a basic config featuring a single `servers` configuration.
|
|
|
|
```bash
|
|
./
|
|
├── Config/
|
|
│ ├── servers.json
|
|
```
|
|
|
|
And an example of how this might look:
|
|
|
|
```JSON
|
|
{
|
|
"http": {
|
|
"host": "0.0.0.0",
|
|
"port": 8080
|
|
}
|
|
}
|
|
```
|
|
|
|
What that's saying, is that our application should start a single server named 'http' serving port `8080` on host `0.0.0.0`. This represents the following url: `http://localhost:8080`.
|
|
|
|
### Custom Keys
|
|
|
|
Let's add a custom key to the `servers.json` file:
|
|
|
|
```JSON
|
|
{
|
|
"http": {
|
|
"host": "0.0.0.0",
|
|
"port": 8080,
|
|
"custom-key": "custom value"
|
|
}
|
|
}
|
|
```
|
|
|
|
This can be accessed from your application's config using the following.
|
|
|
|
```swift
|
|
let customValue = drop.config["servers", "http", "custom-key"]?.string ?? "default"
|
|
```
|
|
|
|
That's it, feel free to add and utilize keys as necessary to make your application configuration easier.
|
|
|
|
## Config Syntax
|
|
|
|
You can access your config directory with the following syntax. `app.config[<#file-name#>, <#path#>, <#to#>, <#file#>]`. For example, let's hypothesize that in addition to the `servers.json` file we mentioned earlier, there is also a `keys.json` that looks like this:
|
|
|
|
```JSON
|
|
{
|
|
"test-names": [
|
|
"joe",
|
|
"jane",
|
|
"sara"
|
|
],
|
|
"mongo": {
|
|
"url" : "www.customMongoUrl.com"
|
|
}
|
|
}
|
|
```
|
|
|
|
We can access this file by making sure the first argument in our subscript is keys. To get the first name in our list:
|
|
|
|
```swift
|
|
let name = drop.config["keys", "test-names", 0]?.string ?? "default"
|
|
```
|
|
|
|
Or our mongo url:
|
|
|
|
```swift
|
|
let mongoUrl = drop.config["keys", "mongo", "url"]?.string ?? "default"
|
|
```
|
|
|
|
## Advanced Configurations
|
|
|
|
Having the default `servers.json` is great, but what about more complex scenarios. For example, what if we want a different host in production and in development? These complex scenarios can be achieved by adding additional folders to our `Config/` directory. Here's an example of a folder structure that's setup for production and development environments.
|
|
|
|
```bash
|
|
WorkingDirectory/
|
|
├── Config/
|
|
│ ├── servers.json
|
|
│ ├── production/
|
|
│ │ └── servers.json
|
|
│ ├── development/
|
|
│ │ └── servers.json
|
|
│ └── secrets/
|
|
│ └── servers.json
|
|
```
|
|
|
|
> You can specify the environment through the command line by using --env=. Custom environments are also available, a few are provided by default: production, development, and testing.
|
|
|
|
```bash
|
|
vapor run --env=production
|
|
```
|
|
|
|
### PRIORITY
|
|
|
|
Config files will be accessed in the following priority.
|
|
|
|
1. CLI (see below)
|
|
2. Config/secrets/
|
|
3. Config/name-of-environment/
|
|
4. Config/
|
|
|
|
What this means is that if a user calls `app.config["servers", "host"]`, the key will be searched in the CLI first, then the `secrets/` directory, then the top level default configs.
|
|
|
|
> `secrets/` directory should very likely be added to the gitignore.
|
|
|
|
### EXAMPLE
|
|
|
|
Let's start with the following JSON files.
|
|
|
|
#### `servers.json`
|
|
|
|
```JSON
|
|
{
|
|
"http": {
|
|
"host": "0.0.0.0",
|
|
"port": 9000
|
|
}
|
|
}
|
|
```
|
|
|
|
#### `production/servers.json`
|
|
|
|
```JSON
|
|
{
|
|
"http": {
|
|
"host": "127.0.0.1",
|
|
"port": "$PORT"
|
|
}
|
|
}
|
|
```
|
|
|
|
> The `"$NAME"` syntax is available for all values to access environment variables.
|
|
|
|
Please notice that `servers.json`, and `production/servers.json` both declare the same keys: `host`, and `port`. In our application, we'll call:
|
|
|
|
```swift
|
|
// will load 0.0.0.0 or 127.0.0.1 based on above config
|
|
let host = drop.config["servers", "http", "host"]?.string ?? "0.0.0.0"
|
|
// will load 9000, or environment variable port.
|
|
let port = drop.config["servers", "http", "port"]?.int ?? 9000
|
|
```
|
|
|
|
## COMMAND LINE
|
|
|
|
In addition to json files nested within the `Config/` directory, we can also use the command line to pass arguments into our config. By default, these values will be set as the "cli" file, but more complex options are also available.
|
|
|
|
#### 1. `--KEY=VALUE`
|
|
|
|
Arguments set through the command line can be accessed through config's cli file. For example, the following CLI command:
|
|
|
|
```bash
|
|
--mongo-password=$MONGO_PASSWORD
|
|
```
|
|
|
|
would be accessible within your application by using the following:
|
|
|
|
```swift
|
|
let mongoPassword = drop.config["cli", "mongo-password"]?.string
|
|
```
|
|
|
|
#### 2. `--CONFIG:FILE-NAME.KEY=CUSTOM-VALUE`
|
|
|
|
If you want command line arguments set to a file besides "cli", you can use this more advanced specification. For example, the following CLI command:
|
|
|
|
```bash
|
|
--config:keys.analytics=124ZH61F
|
|
```
|
|
|
|
would be accessible within your application by using the following:
|
|
|
|
```swift
|
|
let analyticsKey = drop.config["keys", "analytics"]?.string
|
|
```
|