Skip to main content

Flask based library to help structure an application with an eye towards CLI apps, not just web.

Project description

Flac

Flask based library to help structure an application with an eye towards CLI apps, not just web.

Features

  • App factory pattern

    • blueprints (web & CLI)
  • CLI Integration

    • custom command
    • two-phase init for blueprints
  • Configuration

    • .env & .flaskenv
    • from files
    • from environment
    • alternate settings for testing, dev, prod
  • Logging

    • logs are probably cheap, don't prematurely optimize
    • centralize your logs to an aggregation service
    • .info logs are show/saved by default
    • cli output is plain text
    • saved logs are JSON
    • saved logs go to syslog, let devops handle the aggregation
  • Testing

    • alternate DB URI
    • pytest & fixtures
  • Flask-SQLAlchemy

    • ext init
    • fixtures to get db to ensure app context
  • Celery

    • refresh process pool
  • cli integration with the ability to customize the app's configuration using global cli options

    someapp --debug --with-sentry run-some-task

  • pytest fixtures for app initialization

  • demo cli test that uses separate process

Develoment

Copier Template

Project structure and tooling mostly derives from the copier-py-package, see its documentation for context and additional instructions.

This project can be updated from the upstream repo, see updates

Project Setup

From zero to hero (passing tests that is):

  1. Ensure host dependencies are installed:
  • reqs: for virtualenv python deps
  • mise: for everything else, e.g. terraform, npm
  1. Start docker service dependencies (if applicable):

    docker compose up -d

  2. Run tests:

    nox

  3. Use mise to activate the virtualenv for local dev

  4. Install deps in active virtualenv:

    • reqs bootstrap
    • reqs sync
  5. Configure pre-commit:

    pre-commit install

Versions

Versions are date based. Tools:

  • Current version: hatch version
  • Bump version based on date, tag, push: mise run bump
    • Options: mise run bump -- --help

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

flask_flac-0.20241017.1.tar.gz (82.4 kB view details)

Uploaded Source

Built Distribution

flask_flac-0.20241017.1-py2.py3-none-any.whl (14.5 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file flask_flac-0.20241017.1.tar.gz.

File metadata

  • Download URL: flask_flac-0.20241017.1.tar.gz
  • Upload date:
  • Size: 82.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-httpx/0.27.2

File hashes

Hashes for flask_flac-0.20241017.1.tar.gz
Algorithm Hash digest
SHA256 194954378f57a40413c52243f42962fdcd0a20a7cbc7dbb1734ee86790f9e4f6
MD5 79668e77236fe54146bef520d2257234
BLAKE2b-256 774f9b83ca4c705b0213ff8554a061a9f0020e6cd80dc0c961c805d1dc49d036

See more details on using hashes here.

File details

Details for the file flask_flac-0.20241017.1-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for flask_flac-0.20241017.1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 007e9953488345e60ccd7e250c192511512ee470a3c02f01597cf8dca42ef6d2
MD5 29bd44474e8eaa20b86f0ae7f14d96dd
BLAKE2b-256 1fce39088bbf725a4d29dbd96970b42245a9b06fa5226d9ca441c31a37337b51

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