Skip to main content

poetry-plugin-dotenv - is the plugin that automatically loads environment variables from a dotenv file into the environment before poetry commands are run.

Project description

logo

license python pypi release

black isort ruff mypy semantic_release poetry numpydoc

dependabot CI CD Dependency Review hooks wheel

codecov codeclimate downloads stars wakatime

buymeacoffee standwithukraine standwithukraine

Overview

poetry-plugin-dotenv - is the plugin that automatically loads environment variables from a dotenv file into the environment before poetry commands are run.

Features

  • Doesn't require any dependencies
  • Supports templates, interpolating variables using POSIX variable expansions
  • Fully type safe
  • 100% test coverage and "A" grade for maintainability

Installation

poetry self add poetry-plugin-dotenv

Usage and Configuration

By default, the plugin will load the .env file from the current working directory or "higher directories".

To prevent poetry from loading the dotenv file, set the ignore option.

If your dotenv file is located in a different path or has a different name you may set the location.

ignore option can accept the next values:

  • As True: y / yes / t / on / 1 / true
  • As False: n / no / f / off / 0 / false

Configuration via file

The plugin is able to read project-specific default values for its options from a pyproject.toml file. By default, poetry-plugin-dotenv looks for pyproject.toml containing a [tool.poetry.plugins.dotenv] section.

Example pyproject.toml:

[tool.poetry.plugins.dotenv]
ignore = "false"
location = ".env.dev"

[!IMPORTANT] Due to the default poetry parser, options in the plugins sections should be always strings.

Configuration via environment variables

poetry-plugin-dotenv supports the following configuration options via environment variables.

  • POETRY_PLUGIN_DOTENV_LOCATION
  • POETRY_PLUGIN_DOTENV_IGNORE

[!IMPORTANT] Due to the nature of environment variables, options should be always strings.

Lookup hierarchy

A pyproject.toml can override default values. Options provided by the user via environment variables override both.

Examples

demo
# .env
DB__HOST=localhost
DB__DBNAME=local_lakehouse
DB__USER=volodymyr
DB__PASSWORD=super_secret_password
DB__ENGINE=postgresql://${DB__USER}:${DB__PASSWORD}@${DB__HOST}/${DB__DBNAME}
# .env.dev
DB__HOST=dev.host
DB__DBNAME=dev_lakehouse
DB__USER=svc_team
DB__PASSWORD=super_secret_password
DB__ENGINE=postgresql://${DB__USER}:${DB__PASSWORD}@${DB__HOST}/${DB__DBNAME}
# pyroject.toml
[tool.poetry.plugins.dotenv]
location = ".env.dev"
# main.py
from __future__ import annotations

import os


if __name__ == "__main__":
    try:
        print(f"Host: {os.environ['DB__HOST']!r}")  # noqa: T201
        print(f"Name: {os.environ['DB__DBNAME']!r}")  # noqa: T201
        print(f"Username: {os.environ['DB__USER']!r}")  # noqa: T201
        print(f"Password: {os.environ['DB__PASSWORD']!r}")  # noqa: T201
        print(f"Engine: {os.environ['DB__ENGINE']!r}")  # noqa: T201

    except KeyError:
        print("Environment variables not set!")  # noqa: T201
poetry run -vvv python main.py
# Loading environment variables from '.env'.
# Host: 'localhost'
# Name: 'local_lakehouse'
# Username: 'volodymyr'
# Password: 'super_secret_password'
# Engine: 'postgresql://volodymyr:super_secret_password@localhost/local_lakehouse'

# set location section in pyproject.toml
poetry run -vvv python main.py
# Loading environment variables from '.env.dev'.
# Host: 'dev.host'
# Name: 'dev_lakehouse'
# Username: 'svc_team'
# Password: 'super_secret_password'
# Engine: 'postgresql://svc_team:super_secret_password@dev.host/dev_lakehouse'

# set ignore = "true" in pyproject.toml
poetry run -vvv python main.py
# Not loading environment variables.
# Environment variables not set!

export POETRY_PLUGIN_DOTENV_LOCATION=.env.dev && poetry run -vvv python main.py
# Loading environment variables from '.env.dev'.
# Host: 'dev.host'
# Name: 'dev_lakehouse'
# Username: 'svc_team'
# Password: 'super_secret_password'
# Engine: 'postgresql://svc_team:super_secret_password@dev.host/dev_lakehouse'

export POETRY_PLUGIN_DOTENV_IGNORE=true && poetry run -vvv python main.py
# Not loading environment variables.
# Environment variables not set!

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

poetry_plugin_dotenv-1.0.1.tar.gz (14.2 kB view details)

Uploaded Source

Built Distribution

poetry_plugin_dotenv-1.0.1-py3-none-any.whl (13.2 kB view details)

Uploaded Python 3

File details

Details for the file poetry_plugin_dotenv-1.0.1.tar.gz.

File metadata

  • Download URL: poetry_plugin_dotenv-1.0.1.tar.gz
  • Upload date:
  • Size: 14.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.11.9

File hashes

Hashes for poetry_plugin_dotenv-1.0.1.tar.gz
Algorithm Hash digest
SHA256 496fc0c29378fee7c86b001a0724efb97ad218de45cb3fc26e063c61c467220e
MD5 886daa3da62db65dbdba655766f07d8e
BLAKE2b-256 b4f665927d2110a797be68a0480b4245f19248f75c0892944a371c18612b2bd2

See more details on using hashes here.

Provenance

File details

Details for the file poetry_plugin_dotenv-1.0.1-py3-none-any.whl.

File metadata

File hashes

Hashes for poetry_plugin_dotenv-1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 6134ac721cadb5431cae25b2ea22caa0325e03f3a14ab55c48240f2c238821c2
MD5 4b62288a230f6a30b6c1f782cd8a9028
BLAKE2b-256 f30121258c1f71dbd0e17dde49c638ef3ec288804adcf58e20cc34de111f3752

See more details on using hashes here.

Provenance

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page