This provides a boilerplate template to provide 21 devs with the infrastructure necessary to develop consumer or public facing apps.
- Admin panel to provide information on 21 diagnostics
- Per user, individually provisioned wallets
- HD child address generation with QR code support
- Wallet send flow
- Public listing of 402 endpoints (nice to have)
- Public access to 402 endpoint for each user, will be centralized through 21-user for now (nice ot have)
- Admin panel accessible by the 21 owner
- All information available through 21-cli displayable for admins
- All functionality available with the 21-cli available to admins (flush, mine, etc.)
Please feel free to fill in anything else that you feel would be useful or to create an issue with your suggestion, with an emphasis on tools that have broad use cases
- 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.
- Application factory.
- Online administration.
- Static file bundling, automatic SCSS to CSS conversion and automatic minifying.
- Websockets (for example for live chatting)
- Virtual environment example.
- Heroku deployment example.
- Digital Ocean deployment example.
- Tests.
- Logging.
- Language selection.
- Flask.
- Flask-Login for the user accounts.
- Flask-SQLAlchemy interacting with the database.
- Flask-WTF and WTForms for the form handling.
- Flask-Mail for sending mails.
- itsdangerous for generating random tokens for the confirmation emails.
- Flask-Bcrypt for generating secret user passwords.
- Flask-Admin for building an administration interface.
- Semantic UI for the global style. Very similar to Bootstrap.
- Leaflet JS for the map. I only added for the sake of the example.
Everything is contained in the app/
folder.
- There you have the
static/
andtemplates/
folders. Thetemplates/
folder contains macros, error views and a common layout. - The
views/
folder separates the user and the website logic, which can be extended to the the admin views. - The same goes for the
forms/
folder. - The
models.py
script contains the SQLAlchemy code, for the while it only contains the logic for ausers
table. - The
toolbox/
folder is contains generic utils
-
Install the required libraries.
pip install -r requirements.txt
-
Create the database.
python createdb.py
-
Run the application.
python run.py
-
Navigate to
localhost:5000
.
pip install virtualenv
virtualenv venv
venv/bin/activate (venv\scripts\activate on Windows)
pip install -r requirements.txt
python createdb.py
python run.py
- Heroku
- Digital Ocean
Configuration paramaters can be set in config.py
. Please change the default params if using in a production environment.
There is a working Gmail account to confirm user email addresses and reset user passwords. 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.