A simple Magic 8-Ball app demonstrating many of the basic features of Python, Django and Javascript/jQuery.
This app talks to the Magic 8-Ball API at https://8ball.delegator.com/ and randomly generates Magic 8-Ball responses to yes/no questions. It uses Python 3 and Django 2.0.6, as well as standard HTML5, CSS3 and Javascript/jQuery for front end design. The following extra features have been added to demonstrate the power of Django and Python:
- Authentication and authorization with user registration, login/logout, password resets and a simple profile page
- Note: Password resets log the reset email to the console. If you want to actually reset your password, copy/paste the link from your terminal into the address bar
- An email authentication backend has been written to allow either username or email authentication
- Design methodology is mobile-first, so it is responsive across multiple screen layouts
- Local browser storage is used to store API response history data
- Response history data is persistent between refreshes, browser restarts, and even user login/logout (try creating multiple users and logging in/out - it will remember your response history until you clear it!)
- A nav menu and footer have been added, providing navigation throughout the site and a link to my personal Github
- Django template inheritance, template tagging and form validation have been used throughout the site
- The Django messages framework has been utilized for various messages throughout the app (primarily in the authentication/registration views)
- Some crude Javascript data cleansing has been implemented on the question submission form to prevent some CORS violations (try entering just a question mark, for example)
- All HTML and CSS has been validated with the W3C validators. JS has been validated at jslint.com with the following properties:
- Global variables: $, localStorage
- Tolerate: Long lines,
this
, and whitespace mess
- Python 3.x (you can check this with
python --version
) - Django 2.x
- Pip (to install requirements)
- (Optional) Virtualenv or some other virtual environment management tool if you want to run it in a venv
- (Optional) Create a virtual environment (see https://virtualenv.pypa.io/en/stable/)
- Download or clone this repo
- Install requirements:
pip install -r requirements.txt
(may requiresudo
) - (Optional) Make migrations:
python manage.py makemigrations
(it will say no changes detected unless you've modifed the models) - Migrate changes:
python manage.py migrate
- (Optional) Create a superuser:
python manage.py createsuperuser
and follow the prompts - Run the local development server:
python manage.py runserver
(IMPORTANT: see notes below) - Navigate to http://127.0.0.1:21337 - you will be redirected to the login page
- If you created a superuser above, you can use your superuser to log in
- (Optional) If you opted not to create a superuser, register for an account and you will be automatically logged in with your new standard user
- The local development server runs on port 21337. For convenience,
manage.py
has been modified so it will start there automatically. If for some reason this does not work, start the server withpython manage.py runserver <desired port>
- For convenience, this project automatically generates a secret key in
<YOUR_SETTINGS_DIRECTORY>/secret_key.py
for you when you run the development server for the first time. If you plan to launch the app in production, please refer to the Django Deployment Checklist for how to properly handle yourSECRET_KEY
. - Due to the above, you must have write access to your settings directory in order to generate the secret key. If you prefer to set it yourself, or it fails for some reason, simply generate your own, replace lines 14-28 in
settings.py
withSECRET_KEY = <your secret key>
- Use of
django-registration-redux
instead of self-builtaccounts
app for faster setup of registration/auth system - Use of
django-crispy-forms
instead ofdjango-forms-bootstrap
for better form flexibility and better formatting of validation errors - Use of class-based views for accounts/auth/registration views to consolidate code
- Implementation of server side API calls instead of client side, and/or implementation of a React front end
- Live launch on Heroku/PaaS Provider w/ base/dev/staging/prod settings
- Migration from Sqlite to Postgres
- Testing w/
unittest
and Jasmine