# dj_settings: project settings the UNIX way
[![tests][test_badge]][test_url]
[![license][licence_badge]][licence_url]
[![pypi][pypi_badge]][pypi_url]
[![downloads][pepy_badge]][pepy_url]
[![code style: black][black_badge]][black_url]
[![build automation: yam][yam_badge]][yam_url]
[![Lint: ruff][ruff_badge]][ruff_url]
`dj_settings` offers way to add project settings in a way that has been battle-tested for years
in numerous UNIX apps, reading from the value `/etc/<config_file>` or `~/.config/<config_file>` or
`/path/to/project/<config_file>` or an `ENV VAR`, allowing overriding from the next read location.
All of them allow overriding `/path/to/config/file.ext` with `/path/to/config/file.ext.d/<filename>.ext`.
It started by targeting django, but it has grown to be used as a general settings or config parser.
### Usage
`dj_settings` will read from various config files to get the value of a variable, in a way
that's very familiar to all UNIX users. It allows setting default values, and overriding
with ENV VARs and .d directories.
## Links
- [Documentation]
- [Changelog]
[test_badge]: https://github.com/spapanik/dj_settings/actions/workflows/tests.yml/badge.svg
[test_url]: https://github.com/spapanik/dj_settings/actions/workflows/tests.yml
[licence_badge]: https://img.shields.io/pypi/l/dj_settings
[licence_url]: https://github.com/spapanik/dj_settings/blob/main/docs/LICENSE.md
[pypi_badge]: https://img.shields.io/pypi/v/dj_settings
[pypi_url]: https://pypi.org/project/dj_settings
[pepy_badge]: https://pepy.tech/badge/dj_settings
[pepy_url]: https://pepy.tech/project/dj_settings
[black_badge]: https://img.shields.io/badge/code%20style-black-000000.svg
[black_url]: https://github.com/psf/black
[yam_badge]: https://img.shields.io/badge/build%20automation-yamk-success
[yam_url]: https://github.com/spapanik/yamk
[ruff_badge]: https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/charliermarsh/ruff/main/assets/badge/v1.json
[ruff_url]: https://github.com/charliermarsh/ruff
[Documentation]: https://dj-settings.readthedocs.io/en/stable/
[Changelog]: https://github.com/spapanik/dj_settings/blob/main/docs/CHANGELOG.md
Raw data
{
"_id": null,
"home_page": "https://dj-settings.readthedocs.io/en/stable/",
"name": "dj-settings",
"maintainer": null,
"docs_url": null,
"requires_python": ">=3.9",
"maintainer_email": null,
"keywords": "configuration, settings",
"author": "Stephanos Kuma",
"author_email": "\"Stephanos Kuma\" <stephanos@kuma.ai>",
"download_url": "https://files.pythonhosted.org/packages/c3/16/63c4e0da735b119ca9c82dd9c5e3e8ae82a691dd79f0316fe8225959eaa4/dj_settings-6.0.0.tar.gz",
"platform": null,
"description": "# dj_settings: project settings the UNIX way\n\n[![tests][test_badge]][test_url]\n[![license][licence_badge]][licence_url]\n[![pypi][pypi_badge]][pypi_url]\n[![downloads][pepy_badge]][pepy_url]\n[![code style: black][black_badge]][black_url]\n[![build automation: yam][yam_badge]][yam_url]\n[![Lint: ruff][ruff_badge]][ruff_url]\n\n`dj_settings` offers way to add project settings in a way that has been battle-tested for years\nin numerous UNIX apps, reading from the value `/etc/<config_file>` or `~/.config/<config_file>` or\n`/path/to/project/<config_file>` or an `ENV VAR`, allowing overriding from the next read location.\nAll of them allow overriding `/path/to/config/file.ext` with `/path/to/config/file.ext.d/<filename>.ext`.\nIt started by targeting django, but it has grown to be used as a general settings or config parser.\n\n### Usage\n\n`dj_settings` will read from various config files to get the value of a variable, in a way\nthat's very familiar to all UNIX users. It allows setting default values, and overriding\nwith ENV VARs and .d directories.\n\n## Links\n\n- [Documentation]\n- [Changelog]\n\n[test_badge]: https://github.com/spapanik/dj_settings/actions/workflows/tests.yml/badge.svg\n[test_url]: https://github.com/spapanik/dj_settings/actions/workflows/tests.yml\n[licence_badge]: https://img.shields.io/pypi/l/dj_settings\n[licence_url]: https://github.com/spapanik/dj_settings/blob/main/docs/LICENSE.md\n[pypi_badge]: https://img.shields.io/pypi/v/dj_settings\n[pypi_url]: https://pypi.org/project/dj_settings\n[pepy_badge]: https://pepy.tech/badge/dj_settings\n[pepy_url]: https://pepy.tech/project/dj_settings\n[black_badge]: https://img.shields.io/badge/code%20style-black-000000.svg\n[black_url]: https://github.com/psf/black\n[yam_badge]: https://img.shields.io/badge/build%20automation-yamk-success\n[yam_url]: https://github.com/spapanik/yamk\n[ruff_badge]: https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/charliermarsh/ruff/main/assets/badge/v1.json\n[ruff_url]: https://github.com/charliermarsh/ruff\n[Documentation]: https://dj-settings.readthedocs.io/en/stable/\n[Changelog]: https://github.com/spapanik/dj_settings/blob/main/docs/CHANGELOG.md\n",
"bugtrack_url": null,
"license": "BSD-3-Clause",
"summary": "project settings the UNIX way",
"version": "6.0.0",
"project_urls": {
"Documentation": "https://dj-settings.readthedocs.io/en/stable/",
"Homepage": "https://dj-settings.readthedocs.io/en/stable/",
"Repository": "https://github.com/spapanik/dj_settings"
},
"split_keywords": [
"configuration",
" settings"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "cc876a7c11fd9bb5874593417fd983fdb564ad0d6acae602b6ebf9dbe36ffc6f",
"md5": "cb00badc78280c543cddbc22b42091f5",
"sha256": "70d1525a70d0a5c2eb5097a554f1678b1f7c352366ee45d1b05145ed52e08fbe"
},
"downloads": -1,
"filename": "dj_settings-6.0.0-py3-none-any.whl",
"has_sig": false,
"md5_digest": "cb00badc78280c543cddbc22b42091f5",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": ">=3.9",
"size": 6819,
"upload_time": "2024-09-24T13:31:31",
"upload_time_iso_8601": "2024-09-24T13:31:31.970852Z",
"url": "https://files.pythonhosted.org/packages/cc/87/6a7c11fd9bb5874593417fd983fdb564ad0d6acae602b6ebf9dbe36ffc6f/dj_settings-6.0.0-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "c31663c4e0da735b119ca9c82dd9c5e3e8ae82a691dd79f0316fe8225959eaa4",
"md5": "ce05aa240edf429531d3e313a13e8738",
"sha256": "8540c10890b722056be442e3f306adbf9884f75fd505a58fe4310f674664b033"
},
"downloads": -1,
"filename": "dj_settings-6.0.0.tar.gz",
"has_sig": false,
"md5_digest": "ce05aa240edf429531d3e313a13e8738",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.9",
"size": 5441,
"upload_time": "2024-09-24T13:31:33",
"upload_time_iso_8601": "2024-09-24T13:31:33.291529Z",
"url": "https://files.pythonhosted.org/packages/c3/16/63c4e0da735b119ca9c82dd9c5e3e8ae82a691dd79f0316fe8225959eaa4/dj_settings-6.0.0.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-09-24 13:31:33",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "spapanik",
"github_project": "dj_settings",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"lcname": "dj-settings"
}