A Swift library for reading configuration in applications and libraries.
- 📚 Documentation is available on the Swift Package Index.
- 💻 Examples are available just below, in the Examples directory, and on the Example use cases page.
- 🚀 Contributions are welcome, please see CONTRIBUTING.md.
- 🪪 License is Apache 2.0, repeated in LICENSE.
- 🔒 Security issues should be reported via the process in SECURITY.md.
Swift Configuration defines an abstraction layer between configuration readers and providers.
Applications and libraries read configuration through a consistent API, while the actual provider is set up once at the application's entry point.
Swift Configuration allows you to combine multiple providers in a hierarchy, where values from higher-priority sources override those from lower-priority ones.
For example, if you have a default configuration in JSON:
And want to be able to provide an override for that using an environment variable:
The example code below creates the two relevant providers, and resolves them in the order you list:
The resolved configuration value is 15 from the environment variable. Without the environment variable, it would use 30 from the JSON file. If both sources are unavailable, the fallback default of 60 is returned.
Tip: More example use cases are described in example use cases, and complete working examples are available in the Examples directory.
Important: While this library's API is still in development, use the .upToNextMinor(from: "...") dependency constraint to avoid unexpected build breakages. Before we reach 1.0, API-breaking changes may occur between minor 0.x versions.
Add the dependency to your Package.swift:
Add the library dependency to your target:
Import and use in your code:
For more, check out the full documentation.
This package offers additional integrations you can enable using package traits. To enable an additional trait on the package, update the package dependency:
Available traits:
- JSONSupport (default): Adds support for JSONProvider, a ConfigProvider for reading JSON files.
- LoggingSupport (opt-in): Adds support for AccessLogger, a way to emit access events into a SwiftLog.Logger.
- ReloadingSupport (opt-in): Adds support for auto-reloading variants of file providers, such as ReloadingJSONProvider (when JSONSupport is enabled) and ReloadingYAMLProvider (when YAMLSupport is enabled).
- CommandLineArgumentsSupport (opt-in): Adds support for CommandLineArgumentsProvider for parsing command line arguments.
- YAMLSupport (opt-in): Adds support for YAMLProvider, a ConfigProvider for reading YAML files.
The library is supported on macOS, Linux, and Windows.
Configuration | ✅ 15+ | ✅ | ✅ 18+ | ✅ 18+ | ✅ 11+ | ✅ 2+ |
The library includes comprehensive built-in provider support:
- Environment variables: EnvironmentVariablesProvider
- Command-line arguments: CommandLineArgumentsProvider
- JSON file: JSONProvider and ReloadingJSONProvider
- YAML file: YAMLProvider and ReloadingYAMLProvider
- Directory of files: DirectoryFilesProvider
- In-memory: InMemoryProvider and MutableInMemoryProvider
- Key transforming: KeyMappingProvider
You can also implement a custom ConfigProvider for specialized configuration formats and sources.
- 3 access patterns: synchronous, asynchronous, and watching
- Provider hierarchy
- Hot reloading/watching value updates
- Namespacing and scoped readers
- Debugging and troubleshooting
- Redaction of secrets
- Consistent snapshots
- Custom key syntax
Comprehensive documentation is hosted on the Swift Package Index.