Giter Club home page Giter Club logo

flask-dotenv's Introduction

Flask-DotEnv

https://travis-ci.org/grauwoelfchen/flask-dotenv.svg?branch=master
Adds support for .env file to flask applications.
From version 0.0.3, set config var without os.environ.

Flask-DotEnv will directly set (add, update and map as alias) variable from .env file, and cast to Python native types as appropriate.

Install

$ pip install Flask-DotEnv

Usage

DotEnv

from flask import Flask
from flask.ext.dotenv import DotEnv

app = Flask(__name__)
env = DotEnv(app)

As factory pattern.

env = DotEnv()
env.init_app(app)
This env module may be usefull in your Config class.
e.g.
class Config:
    SECRET_KEY = ":'("
    ...

    @classmethod
    def init_app(self, app)
        env = DotEnv()
        env.init_app(app)

Then in your app:

from config import config

app = Flask(__name__)
app.config.from_object(config[config_name])

See also:

flask.Config.from_object (API โ€” Flask Documentation)

Arguments

You can pass .env file path as second argument of init_app().

env.init_app(app, env_file="/path/to/.env", verbose_mode=True)
The second argument (env_file) is optional. default is os.path.join(os.getcwd(), '.env').
The third argument (verbose_mode) is also optional. default False.
If verbose_mode is True, then server outputs nice log message which vars will be set.
like this:
* Overwriting an existing config var: SECRET_KEY
* Setting an entirely new config var: DEVELOPMENT_DATABASE_URL
* Mapping a specified var as a alias: DEVELOPMENT_DATABASE_URL => SQLALCHEMY_DATABASE_URI
...

Alias

alias() method takes a dict argment.

env.alias(maps={
  'TEST_DATABASE_URL': 'SQLALCHEMY_DATABASE_URI',
  'TEST_HOST': 'HOST'
})

This is example usage of alias:

class Config:
    SECRET_KEY = ":'("
    ...

    @classmethod
    def init_app(self, app)
        env = DotEnv()
        env.init_app(app)

        # this will set var like a `DEVELOPMENT_DATABASE_URL` as `SQLALCHEMY_DATABASE_URI`
        prefix = self.__name__.replace('Config', '').upper()
        env.alias(maps={
            prefix + '_DATABASE_URL': 'SQLALCHEMY_DATABASE_URI'
        })


class DevelopmentConfig(Config):
    DEBUG = True
    SQLALCHEMY_DATABASE_URI = None


config = {
    'development': DevelopmentConfig
}

Development

Run unittest.

$ python setup.py test

Link

Inspired from:

See another packages, its also set config vars:

License

BSD 2-Clause License

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.