.. author:: Christian <christian@kuntzsch.me>
.. tag:: lang-python
.. tag:: web
.. tag_list::
Baby Buddy is an open source activity management system for your infant child. It is designed to keep track of sleep, feedings, diaper changes and tummy time "[...] to learn about and predict baby's needs without (as much) guess work". It is written in :manual:`Python <lang-python>` and based on the popular :lab:`Django-Framework <guide_django>`.
Note
For this guide you should be familiar with the basic concepts of
All relevant legal information can be found here
Your URL needs to be setup:
You need pipenv, a package manager/virtual environment tool for Python, so install that:
[isabell@stardust ~]$ pip3.6 install pipenv --user
Collecting pipenv
Downloading https://files.pythonhosted.org/packages/13/b4/3ffa55f77161cff9a5220f162670f7c5eb00df52e00939e203f601b0f579/pipenv-2018.11.26-py3-none-any.whl (5.2MB)
100% |████████████████████████████████| 5.2MB 242kB/s
Requirement already satisfied: setuptools>=36.2.1 in /usr/lib/python3.6/site-packages (from pipenv)
Collecting virtualenv (from pipenv)
Downloading https://files.pythonhosted.org/packages/33/5d/314c760d4204f64e4a968275182b7751bd5c3249094757b39ba987dcfb5a/virtualenv-16.4.3-py2.py3-none-any.whl (2.0MB)
100% |████████████████████████████████| 2.0MB 614kB/s
[…]
[isabell@stardust ~]$
During the installation process, you want to use Python in version 3.6. Set an alias for that:
[isabell@stardust ~]$ alias python=python3.6
[isabell@stardust ~]$ python --version
Python 3.6.7
[isabell@stardust ~]$
Baby Buddy will store its data in a :manual:`MySQL <database-mysql>` database. Create one with the name <username>_babybuddy
.
[isabell@stardust ~]$ mysql -e "CREATE DATABASE ${USER}_babybuddy DEFAULT CHARACTER SET utf8 DEFAULT COLLATE utf8_general_ci;"
[isabell@stardust ~]$
Create two folders, one for the source code and one for the application's data.
[isabell@stardust ~]$ mkdir -p ~/babybuddy/public ~/babybuddy/data/media
[isabell@stardust ~]$
Clone the Baby Buddy source code from Github into the first folder.
[isabell@stardust ~]$ git clone https://github.com/cdubz/babybuddy.git ~/babybuddy/public
[...]
remote: Total 4593 (delta 27), reused 80 (delta 19), pack-reused 4477
Receiving objects: 100% (4593/4593), 8.15 MiB | 3.33 MiB/s, done.
Resolving deltas: 100% (2734/2734), done.
[isabell@stardust ~]$
Install all the requirements. Since we are working with Python 3, we need to use a flag:
--three
: Use Python 3 when creating virtualenv
[isabell@stardust ~]$ cd ~/babybuddy/public/
[isabell@stardust public]$ pipenv install --three
[...]
🐍 ▉▉▉▉▉▉▉▉▉▉▉▉▉▉▉▉▉▉▉▉▉▉▉▉▉▉▉▉▉▉▉▉ 39/39 — 00:00:54
To activate this project's virtualenv, run pipenv shell.
Alternatively, run a command inside the virtualenv with pipenv run.
[isabell@stardust ~/babybuddy/public]$
Also, install the package mysqlclient
:
[isabell@stardust public]$ pipenv install mysqlclient --three
[...]
🐍 ▉▉▉▉▉▉▉▉▉▉▉▉▉▉▉▉▉▉▉▉▉▉▉▉▉▉▉▉▉▉▉▉ 40/40 — 00:00:02
To activate this project's virtualenv, run pipenv shell.
Alternatively, run a command inside the virtualenv with pipenv run.
[isabell@stardust public]$ cd
[isabell@stardust ~]$
Copy the template configuration file and adapt it based on the following example.
[isabell@stardust ~]$ cp ~/babybuddy/public/babybuddy/settings/production.example.py ~/babybuddy/public/babybuddy/settings/production.py
[isabell@stardust ~]$
Warning
Replace <secretkey>
with a random sequence of characters!
Use this snippet to generate a random string to use as secret key:
[isabell@stardust ~] < /dev/urandom tr -dc _A-Z-a-z-0-9 | head -c${1:-32};echo;
extremerandom
[isabell@stardust ~]$
Warning
Replace <host>
with your host!
Warning
Replace <username>
with your username!
Warning
Replace <databasepassword>
with your database password!
from .base import *
# Production settings
# See babybuddy.settings.base for additional settings information.
SECRET_KEY = '<secretkey>'
ALLOWED_HOSTS = ['<host>']
# Database
# https://docs.djangoproject.com/en/1.11/ref/settings/#databases
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': '<username>_babybuddy',
'USER': '<username>',
'PASSWORD': '<databasepassword>',
'HOST': '127.0.0.1',
'PORT': '3306',
}
}
# Static files
MEDIA_ROOT = os.path.join(BASE_DIR, '../data/media')
To work correctly with the Uberspace Proxy, you need to add this option to the end of the file:
USE_X_FORWARDED_HOST = True
In our example, the file ~/babybuddy/public/babybuddy/settings/production.py
should look like this:
from .base import *
# Production settings
# See babybuddy.settings.base for additional settings information.
SECRET_KEY = 'MyRandomSecretKey'
ALLOWED_HOSTS = ['isabell.uber.space']
# Database
# https://docs.djangoproject.com/en/1.11/ref/settings/#databases
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'isabell_babybuddy',
'USER': 'isabell',
'PASSWORD': 'MySuperSecretPassword',
'HOST': '127.0.0.1',
'PORT': '3306',
}
}
# Static files
MEDIA_ROOT = os.path.join(BASE_DIR, '../data/media')
USE_X_FORWARDED_HOST = True
Enter the virtual environment, initialize the database tables and exit the virtual environemt again:
[isabell@stardust ~]$ cd ~/babybuddy/public/
[isabell@stardust ~/babybuddy/public]$ pipenv shell
Launching subshell in virtual environment…
. /home/isabell/.local/share/virtualenvs/public-xxxxxx/bin/activate
[isabell@stardust ~/babybuddy/public]$ export DJANGO_SETTINGS_MODULE=babybuddy.settings.production
[isabell@stardust ~/babybuddy/public]$ python manage.py migrate
[...]
[isabell@stardust ~/babybuddy/public]$ exit && cd
[isabell@stardust ~]$
Note
babybuddy is running on port 8000.
To deploy your application with uwsgi, create a file at ~/uwsgi/apps-enabled/babybuddy.ini
with the following content:
Warning
Replace <username>
with your username! (4 times)
Note
Find the location of the pipenv virtual environment for the virtualenv
parameter with the following command:
[isabell@stardust ~]$ cd ~/babybuddy/public/ && pipenv --venv
/home/isabell/.local/share/virtualenvs/public-xxxxxx
[uwsgi]
project = babybuddy
base_dir = $(HOME)/babybuddy
virtualenv = $(HOME)/.local/share/virtualenvs/public-xxxxxx
chdir = %(base_dir)/public
module = %(project).wsgi:application
env = DJANGO_SETTINGS_MODULE=%(project).settings.production
master = True
vacuum = True
http = :8000
wsgi-file = %(base)/public/babybuddy/wsgi.py
touch-reload = %(wsgi-file)
app = wsgi
plugin = python
uid = $(USER)
gid = $(USER)
Point your browser to https://isabell.uber.space and log in with the default credentials admin
/admin
.
Warning
Change the default credentials as soon as possible! Otherwise anyone knowing the URL of your instance can login to download, edit or delete your data.
.. author_list::