Skip to content

Latest commit

 

History

History
208 lines (169 loc) · 7.18 KB

INSTALL.md

File metadata and controls

208 lines (169 loc) · 7.18 KB

Installation

Development Environment Deployment

  • Clone git repo git clone https://github.com/qgis/QGIS-Django.git

  • Run $ pwd in order to get your current directory

  • Path to your repo should be <your current directory>/QGIS-Django

  • Go to dockerize directory cd QGIS-Django/dockerize

  • Build and spin container

$ make build
$ make web
$ make devweb
  • Run migrate
$ make migrate

If you have a backup, you can restore it:

make dbrestore

otherwise, you can seed initial data from fixtures:

make dbseed
  • Set up python interpreter in PyCharm or just runserver from devweb container:
$ make devweb-runserver

and now, you can see your site at http://0.0.0.0:62202 (skip this step if you are using PyCharm interpreter)


Setup git-hooks and local linting

In the root directory of the repo, run:

pip install -r REQUIREMENTS-dev.txt

pre-commit install --config .pre-commit-config.yaml

Setting up a remote interpreter in PyCharm

  • PyCharm -> Preferences -> Project: QGIS-Django
  • Click on the gear icon next to project interpreter -> add
  • SSH Interpreter -> New server configuration
  • Host : localhost
  • Port : 62203
  • Username: root
  • Click next button
  • Auth type: password (and tick 'save password')
  • Click next button
  • password : docker
  • Interpreter : /usr/local/bin/python
  • Sync folders -> click on the folder icon
    • local : <path to your repo>/dockerize/qgis-app
    • remote : /home/web/django_project After that you should see something like this in sync folder: <Project root>/django_project→/home/web/django_project
  • Automatically upload project files to the server -> untick the checkbox to avoid overwriting in your files.
  • Click the Apply button

In settings, django support:

  • Language & Framework -> Django
  • tick to Enable Django Support.
  • Django project root: <path to your repo>/qgis_app
  • Settings: setting_docker.py
  • Click the Apply button

Create the django run configuration

  • Run -> Edit configurations
  • Click the + icon in the top left corner
  • Choose Django server from the popup list

Now set these options:

  • Name: Django Server

  • Host: 0.0.0.0

  • Port: 8080

  • Additional options: --settings=settings.docker

  • Run browser If checked, it will open the url after you click run. You should be able to access the running on 0.0.0.0:62202 (the port that mapped to 8080)

  • Environment vars , you can add the variables value one-by-one by clicking on browse icon at right corner in the input field, or just copy-paste this value: PYTHONUNBUFFERED=1;DJANGO_SETTINGS_MODULE=settings_docker;RABBITMQ_HOST=rabbitmq;DATABASE_NAME=gis;DATABASE_USERNAME=docker;DATABASE_PASSWORD=docker;DATABASE_HOST=db

  • Python interpreter: Ensure it is set you your remote interpreter (should be set to that by default)

  • Path mappings: Here you need to indicate path equivalency between your host filesystem and the filesystem in the remote (docker) host. Click the ellipsis and add a run that points to your git checkout on your local host and the /home/web directory in the docker host. e.g.

    • Local path: /QGIS-Django/qgis-app
    • Remote path: /home/web/django_project
  • click OK to save your run configuration

Now you can run the server using the green triangle next to the Django server label in the run configurations pull down. Debug will also work and you will be able to step through views etc as you work.


Setup Style Managers Group

The members of this group will receive style related emails. Follow these steps for setting up:

  • Open admin page: http://0.0.0.0:62202/admin, login with superuser account.
  • Create new Group: Authentication and Authorization > Groups > Add group
  • Set the options:
    • Name: Style Managers
    • Permissions: choose all styles | in Available permissions by typing styles in search input and click Choose all
      • styles | style | Can add style
      • styles | style | Can change style
      • styles | style | Can delete style
      • styles | style | Can view style
      • styles | style review | Can add style review
      • styles | style review | Can change style review
      • styles | style review | Can delete style review
      • styles | style review | Can view style review
      • styles | style type | Can add style type
      • styles | style type | Can change style type
      • styles | style type | Can delete style type
      • styles | style type | Can view style type

Backup and Restore

  • Go to repo directory and run backup.sh
$ ./backup.sh
  • You will find dumps file in backups directory
$ tree -L 3 backups
backups
├── 2016
├── 2017
├── 2018
├── 2019
├── 2020
│   ├── April
│   │   └── PG_QGIS_PLUGINS_gis.07-April-2020.dmp
│   ├── August
│   ├── December
│   │   ├── PG_QGIS_PLUGINS_gis.01-December-2020.dmp
│   │   ├── PG_QGIS_PLUGINS_gis.02-December-2020.dmp
│   │   ├── PG_QGIS_PLUGINS_gis.03-December-2020.dmp
│   │   ├── PG_QGIS_PLUGINS_gis.04-December-2020.dmp
│   │   ├── PG_QGIS_PLUGINS_gis.05-December-2020.dmp
│   │   ├── PG_QGIS_PLUGINS_gis.06-December-2020.dmp
│   │   ├── PG_QGIS_PLUGINS_gis.07-December-2020.dmp
│   │   ├── PG_QGIS_PLUGINS_gis.08-December-2020.dmp
│   │   ├── PG_QGIS_PLUGINS_gis.09-December-2020.dmp
│   │   ├── PG_QGIS_PLUGINS_gis.10-December-2020.dmp
│   │   ├── PG_QGIS_PLUGINS_gis.11-December-2020.dmp
│   │   ├── PG_QGIS_PLUGINS_gis.12-December-2020.dmp
│   │   ├── PG_QGIS_PLUGINS_gis.13-December-2020.dmp
│   │   ├── PG_QGIS_PLUGINS_gis.14-December-2020.dmp
│   │   ├── PG_QGIS_PLUGINS_gis.15-December-2020.dmp
│   │   └── PG_QGIS_PLUGINS_gis.16-December-2020.dmp
│`
  • Copy the dump file you wish to restore to dockerize/backups/latest.dmp file
$ cp backups/2020/December/PG_QGIS_PLUGINS_gis.16-December-2020.dmp dockerize/backups/latest.dmp
  • Restore the dump file
$ cd dockerize
$ make dbrestore

Deploy Update with Rancher

  • Go to https://rancher.qgis.org

  • Click the home icon in the top left corner, and choose the environment: plugins.qgis.org

  • You will be redirected to User Stacks page, choose the plugins stack by clicking on plugins link

  • Next, let's go inside the container, click on uwsgi link.

    image

  • In Containers tab, click on tripe-dot icon > Execute Shell

    image

    Now you are inside the container and ready to deploy your update.

    image

  • Pull the latest commit: git pull origin master

  • Run migration: python manage.py migrate

  • Run collectstatic: python manage.py collectstatic

  • Reload uwsgi: uwsgi --reload /tmp/django.pid