Skip to content

policycompass/policycompass-services

Repository files navigation

Policy Compass Services

Web Services for the Policy Compass

Manual

This manual is tested under Ubuntu 14.04!

Requirements

  • Python 3.4 should be already installed, but make sure with the following command:
  python3
  • Install the following packages:
  apt-get install python-virtualenv python3-dev libpq-dev
  • Install SQLite (easier for development) or PostgreSQL:

Either do

  apt-get install sqlite3

or

  apt-get install postgresql
  pip install psycopg2==2.5.4

If you chose PostgreSQL, you want to create a postgres user and a database:

  sudo -u postgres createuser pcompass -W
  sudo -u postgres createdb pcompass --owner pcompass

Installation

  • Create a new directory for the project
  mkdir services
  • Create a Python Virtual Environment with Python 3 and activate it
  virtualenv services --python=python3
  cd services
  source bin/activate
  git clone git@github.com:policycompass/policycompass-services.git
  cd policycompass-services
  • Install the Requirements
  pip install -r requirements.txt
  • Create a local settings file
  cp config/settings.sample.py config/settings.py
	python manage.py migrate
    python manage.py syncdb
	python manage.py loaddata metrics events common references visualizations indicators ags
  • Start the application
	python manage.py runserver

Elastic search setup

  • Download the elasticsearch from http://www.elasticsearch.org/download/
  • Unzip elasticsearch into a folder
  • Run ./bin/elasticsearch
  • Check elasticsearch URL setting in policycompass-services/settings.py (should be ok by default localhost:9200)
  • With elasticsearch and policy-compass backend services running execute the following command to rebuild index
	python manage.py rebuild_index

Coding style

All python code in this repository shall be compliant with the rules of pep8 and pyflakes except E501 (forbid long lines) and F403 (forbid from xx import *) and they don't have to be applied to the django migration files.

Read the flake8 docs for a list of all rules.

The rules can be checked with the following command:

bin/flake8 apps policycompass_services --ignore E501,F403 --exclude migrations

If the Makefile from the main policycompass repository is used, a pre commit hook is installed, which checks for flake8 compliance as defined above. If this repository is checked out manually and not as a submodule of the main repository, you can create a pre commit hook manually by creating a file .git/hooks/pre-commit with the following content:

#!/bin/sh
bin/flake8 apps policycompass_services --ignore E501,F403 --exclude migrations

Policy Compass is Free Software

This project (i.e. all files in this repository if not declared otherwise) is licensed under the GNU Affero General Public License (AGPLv3), see LICENSE.txt.