Skip to main content

A web framework built on Flask & SQLAlchemy. Somewhere North of Flask but South of Django.

Project description

https://codecov.io/github/level12/keg/coverage.svg?branch=master https://img.shields.io/pypi/v/Keg.svg https://img.shields.io/pypi/l/keg.svg https://img.shields.io/pypi/pyversions/keg.svg https://img.shields.io/pypi/status/Keg.svg AppVeyor Build

Keg is an opinionated but flexible web framework built on Flask and SQLAlchemy.

Keg’s Goal

The goal for this project is to encapsulate Flask best practices and libraries so devs can avoid boilerplate and work on the important stuff.

We will lean towards being opinionated on the big things (like SQLAlchemy as our ORM) while supporting hooks and customizations as much as possible.

Think North of Flask but South of Django.

Features

Default Logging Configuration

We highly recommend good logging practices and, as such, a Keg application does basic setup of the Python logging system:

  • Sets the log level on the root logger to INFO

  • Creates two handlers and assigns them to the root logger:

    • outputs to stderr

    • outputs to syslog

  • Provides an optional json formatter

The thinking behind that is:

  • In development, a developer will see log messages on stdout and doesn’t have to monitor a file.

  • Log messages will be in syslog by default and available for review there if no other action is taken by the developer or sysadmin. This avoids the need to manage log placement, permissions, rotation, etc.

  • It’s easy to configure syslog daemons to forward log messages to different files or remote log servers and it’s better to handle that type of need at the syslog level than in the app.

  • Structured log files (json) provide metadata details in a easy-to-parse format and should be easy to generate.

  • The options and output should be easily configurable from the app to account for different needs in development and deployed scenarios.

  • Keg’s logging setup should be easy to turn off and/or completely override for situations where it hurts more than it helps.

Installation

pip install keg

App Configuration

CLI Command

The command <myapp> develop config will give detailed information about the files and objects being used to configure an application.

Profile Prority

All configuration classes with the name DefaultProfile will be applied to the app’s config first.

Then, the configuration classes that match the “selected” profile will be applied on top of the app’s existing configuration. This makes the settings from the “selected” profile override any settings from the DefaultProfile.

Practically speaking, any configuration that applies to the entire app regardless of what context it is being used in will generally go in myapp.config in the DefaultProfile class.

Selecting a Configuration Profile

The “selected” profile is the name of the objects that the Keg configuration handling code will look for. It should be a string.

A Keg app considers the “selected” profile as follows:

  • If config_profile was passed into myapp.init() as an argument, use it as the selected profile. The --profile cli option uses this method to set the selected profile and therefore has the highest priority.

  • Look in the app’s environment namespace for “CONFIG_PROFILE”. If found, use it.

  • If running tests, use “TestProfile”. Whether or not the app is operating in this mode is controlled by the use of:

    • myapp.init(use_test_profile=True) which is used by MyApp.testing_prep()

    • looking in the app’s environment namespace for “USE_TEST_PROFILE” which is used by keg.testing.invoke_command()

  • Look in the app’s main config file (app.config) and all it’s other config files for the variable DEFAULT_PROFILE. If found, use the value from the file with highest priority.

Keg Development

To develop on keg, begin by installing dependencies and running the tests:

git clone https://github.com/level12/keg keg-src
cd keg-src

cp keg_apps/db/user-config-tpl.py ~/.config/keg_apps.db/keg_apps.db-config.py
# edit the DB connection info in this file (you don't have to use vim):
vim ~/.config/keg_apps.db/keg_apps.db-config.py

pipenv --python=python3.6
pipenv install
pipenv run pytest keg

You can then examine tox.ini for insights into our development process. In particular, we:

  • use py.test for testing (and coverage analysis)

  • use flake8 for linting

Preview Readme

When updating the readme, use restview --long-description to preview changes.

Issues & Discussion

Please direct questions, comments, bugs, feature requests, etc. to: https://github.com/level12/keg/issues

Current Status

  • Stable in a relatively small number of production environments.

  • API is likely to change with smaller compatibility breaks happening more frequently than larger ones.

Changelog

0.6.5 released 2018-05-28

  • Update readme, start using pipenv, pin Flask < 1.0 (abdc9bf)

0.6.4 released 2018-01-09

  • when testing, don’t log to syslog by default (304a0a7)

0.6.3 released 2018-01-09

0.6.2 released 2017-12-19

  • db: get rid of code to replace session object (149b42c)

0.6.1 released 2017-11-16

  • fix quiet logging (e46fd2b)

  • a few small updates/fixes to readme (2044439)

0.6.0 released 2017-08-18

  • ADD: make CLIBase operate off current_app as last resort (1b358c1)

  • ADD: –quiet option to script options (6eb723f)

  • BREAKING CHANGE: adjust cli API on KegApp (af45880)

0.5.1 released 2017-08-15

  • ADD: mitigate CSRF bug in Flask-WTF (42a2e70)

  • ADD: config, init, and routing enhancements (cdfa901)

  • MAINT: upgrade to CircleCI 2.0 (60e3bfa)

0.5.0 released 2017-06-27

  • prep for pyp usage (23424b9)

  • Merge branch ‘logging-improvements’ (PR66)

0.4.1 - 2017-02-09

  • BUG: Properly quote pgsql identifiers during create (86852ad)

0.4.0 - 2016-12-19

  • BUG: Properly Update Keyring Config Data (7f1908f)

  • MSSQL dialect support (df7e89d)

  • MAINT: Refactor keyring to accept bytes (15bc04b)

  • MAINT: Remove deprecated flask hooks (4f7e2bf)

  • Remove unicode_literal futures (dc2fa85)

  • MAINT: Create windows build environment (983e040)

  • MAINT: Run CI with Docker (bc7a877)

  • Remove extra cp in readme (7e94815)

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

Keg-0.6.5.tar.gz (48.6 kB view details)

Uploaded Source

Built Distribution

Keg-0.6.5-py2.py3-none-any.whl (62.7 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file Keg-0.6.5.tar.gz.

File metadata

  • Download URL: Keg-0.6.5.tar.gz
  • Upload date:
  • Size: 48.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for Keg-0.6.5.tar.gz
Algorithm Hash digest
SHA256 4fe7ba5c228b4056d7fd8a326d70f54699b5fa286d450c07e5a1ef363473b622
MD5 2e7f990d41522d916a0166dea20175e0
BLAKE2b-256 05a1bd8d479fb38160b74a44be3abfb0d55e296a7238921409cc6d4a92dd3ea4

See more details on using hashes here.

File details

Details for the file Keg-0.6.5-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for Keg-0.6.5-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 77a29b8b758ef4fb60f1caea5b8a33bb07e0c02817c969b704b1bd40865af6df
MD5 336a062d150cc972b8ccd6ef3e295a5a
BLAKE2b-256 8f4294769575482e07fa65f0fc6e9af8a162f8ce5e11023c4509f76a7ebc7e2e

See more details on using hashes here.

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