Skip to content

Flask boilerplate inspired of The Flask Mega-Tutorial by Miguel Grinberg

License

Notifications You must be signed in to change notification settings

pdamoune/boilerplate

Repository files navigation

Flask Boilerplate

Flask boilerplate inspired by The Flask Mega-Tutorial by Miguel Grinberg

License

When i started learning Flask, I found a lot of boilerplates on the web. However, I decided to create mine as i was learning, in order to have a clean custom base for future projects. Special thanks to Miguel Grinberg for his amazing tutorial, and Max Halford for the inspiration of doing my own boilerplate.

Features

  • User account sign up, sign in, password reset, all through asynchronous email confirmation.
  • Form generation.
  • Error handling.
  • HTML macros and layout file.
  • "Functional" file structure.
  • Python 3.x compliant.
  • Asynchronous AJAX calls.
  • Administration panel.
  • Static file bundling, automatic SCSS to CSS conversion and automatic minifying.
  • Websockets (for example for live chatting)
  • Virtual environment example.
  • Digital Ocean deployment example.
  • Tests.
  • Logging.
  • Language selection.
  • Automatic API views.
  • API key generator.

I am open to any suggestions or help, don't hesitate to contact me at [email protected] or create an issue.

Libraries

Backend

Frontend

Structure

I did what most people recommend for the application's structure. Basically, everything is contained in the app/ folder.

  • There you have the classic static/ and templates/ folders. The templates/ folder contains macros, error views and a common layout.
  • I added a views/ folder to separate the user and the website logic, which could be extended to the the admin views.
  • The same goes for the forms/ folder, as the project grows it will be useful to split the WTForms code into separate files.
  • The models.py script contains the SQLAlchemy code, for the while it only contains the logic for a users table.
  • The toolbox/ folder is a personal choice, in it I keep all the other code the application will need.
  • Management commands should be included in manage.py. Enter python manage.py -? to get a list of existing commands.
  • I added a Makefile for setup tasks, it can be quite useful once a project grows.

Setup

Vanilla

  • Install the requirements and setup the development environment.

    make install && make dev

  • Create the database.

    python manage.py initdb

  • Run the application.

    python manage.py runserver

  • Navigate to localhost:5000.

Virtual environment

pip install virtualenv virtualenv venv venv/bin/activate (venv\scripts\activate on Windows) make install make dev python manage.py initdb python manage.py runserver

Deployment

The current application can be deployed with Docker in a few commands.

cd ~/path/to/application/
docker-machine create -d virtualbox --virtualbox-memory 512 --virtualbox-cpu-count 1 dev
docker-machine env dev
eval "$(docker-machine env dev)"
docker-compose build
docker-compose up -d
docker-compose run web make dev
docker-compose run web python3 manage.py initdb

Then access the IP address given by docker-machine ip dev et voilà. This is exactly how OpenBikes's API is being deployed.

Configuration

The goal is to keep most of the application's configuration in a single file called config.py. I added a config_dev.py and a config_prod.py who inherit from config_common.py. The trick is to symlink either of these to config.py. This is done in by running make dev or make prod.

I have included a working Gmail account to confirm user email addresses and reset user passwords, although in production you should't include the file if you push to GitHub because people can see it. The same goes for API keys, you should keep them secret. You can read more about secret configuration files here.

Read this for information on the possible configuration options.

Examples

Inspiration

Other possibilities

License

The MIT License (MIT). Please see the license file for more information.

About

Flask boilerplate inspired of The Flask Mega-Tutorial by Miguel Grinberg

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published