Skip to content

Latest commit

 

History

History
106 lines (87 loc) · 3.59 KB

README.md

File metadata and controls

106 lines (87 loc) · 3.59 KB

teslarent

Translations

Preparation

  • Install npm
  • npm install grunt --save-dev
  • npm install grunt-angular-gettext --save-dev

Extract translations

PATH=$PATH:./node_modules/.bin grunt nggettext_extract

Translate

https://angular-gettext.rocketeer.be/dev-guide/translate/

Compile translations

PATH=$PATH:./node_modules/.bin grunt nggettext_compile

Setup

Choose between Docker, Generic Setup and Heroku

Docker

docker run -d -v $PWD/db:/var/lib/postgresql/data -p 5432:5432 --name teslarent-postgres postgres

docker build -t teslarent .
docker run -d -p 444:443 --link teslarent-postgres:postgres -e DJANGO_ALLOWED_HOST='*' -e DJANGO_SECRET_KEY=$DJANGO_SECRET_KEY --name teslarent teslarent

Production deployment

Environment variables

  • DATABASE_URL=postgres db config, e.g. postgres://postgres:password@192.168.100.100:5432/dbname
  • DJANGO_ALLOWED_HOST=your_domain
  • DJANGO_SECRET_KEY=random 50 symbol string, generate one with from django.utils.crypto import get_random_string; get_random_string(50, 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789!@#$%^&*(-_=+)')
  • these variables cannot be set in Apache with SetEnv, either set them as global environment variables or define them in ./project/settings_prod.py
  • make sure DJANGO_DEBUG is NOT set to True

Generic Setup

Requirements

Setup

  • Fetch source code and install requirements
git clone https://github.com/flarno11/teslarent.git
cd teslarent
git checkout release
python3 -m venv venv
source venv/bin/activate
pip install -r requirements.txt
cp project/settings_prod_sample.py project/settings_prod.py
  • Make sure config variables are set correctly before continuing, either in project/settings_prod.py or via global environment variables
  • Run checks and initialize database
export DJANGO_SETTINGS_MODULE=project.settings_prod
python manage.py check --deploy
python manage.py migrate
python manage.py collectstatic --no-input
  • Create admin user
python manage.py createsuperuser

and follow the instructions

  • Open https://your_domain/manage/ in your browser and login

Upgrade

  • Fetch updated source code and install new requirements if necessary
cd teslarent
git pull
source venv/bin/activate
pip install -r requirements.txt
export DJANGO_SETTINGS_MODULE=project.settings_prod
python manage.py migrate
python manage.py collectstatic --no-input
  • Reload web server, e.g. with service httpd reload

Setup using Heroku (heroku.com)

  • Create new app
  • Go to Resources, add Postgres database
  • Enable automatic deployment from this github repo, choose the release branch
  • From the command line
  • `export APP_NAME=your_heroku_app_name
  • heroku config:set --app $APP_NAME DJANGO_SETTINGS_MODULE=project.settings
    • do the same for DJANGO_ALLOWED_HOST and DJANGO_SECRET_KEY
  • Verify config with heroku config --app $APP_NAME
  • heroku run --app $APP_NAME python manage.py check --deploy
  • heroku run --app $APP_NAME python manage.py migrate
  • heroku run --app $APP_NAME python manage.py createsuperuser
  • Open https://your_domain/manage/ in your browser and login