Application mobile pour traiter de thématiques autour de la vie affective et la santé sexuelle.
 
 
 
 
 
 
Aller au fichier
Jérôme Lebleu 625828bc49 feat(models): renomme la catégorie LGBTQI en Genres 2021-11-24 11:18:06 +01:00
frontend feat(models): renomme la catégorie LGBTQI en Genres 2021-11-24 11:18:06 +01:00
onoseenparler feat(models): renomme la catégorie LGBTQI en Genres 2021-11-24 11:18:06 +01:00
requirements feat(core): passe à Django 3.2 et Wagtail 2.14 2021-08-05 17:07:54 +02:00
.editorconfig fix(lint): supprime la conf. redondante de .editorconfig 2020-12-11 11:30:19 +01:00
.gitattributes initial commit 2020-12-07 11:42:38 +01:00
.gitignore initial commit 2020-12-07 11:42:38 +01:00
LICENSE initial commit 2020-12-07 11:42:38 +01:00
Makefile feat(make): ajoute une cible test-wip 2020-12-14 15:30:50 +01:00
README.md doc(README): corrige les commandes du frontend 2021-09-17 11:01:29 +02:00
config.env.example fix(backend): adapte les settings pour les URLs 2020-12-16 11:24:21 +01:00
manage.py ref(backend): renomme le projet en onoseenparler 2020-12-11 15:48:05 +01:00
pyproject.toml ref(backend): renomme le projet en onoseenparler 2020-12-11 15:48:05 +01:00
requirements.txt initial commit 2020-12-07 11:42:38 +01:00
setup.cfg feat(make): ajoute une cible test-wip 2020-12-14 15:30:50 +01:00

README.md

On ose en parler

Application mobile, sous forme de site Web, pour conseiller et répondre aux questionnements sur les différentes thématiques liées à la vie affective et la santé sexuelle.

Ce projet est commandité par les Centres Sociaux Connectés du Bassin Minier en lien avec un groupe d'habitante.

Table of content

Give a try

On a Debian-based host - running at least Debian Stretch:

$ sudo apt install python3 virtualenv git make
$ git clone https://forge.cliss21.org/cliss21/csc-onoseenparler
$ cd csc-onoseenparler/

$ make init
A configuration will be created interactively; you can uncomment:
 ENV=development

$ make serve

Then visit http://127.0.0.1:8000/ in your web browser.

Installation

Requirements

On a Debian-based host, you will need the following packages:

  • python3
  • python3-psycopg2 (in case of PostgreSQL database)
  • python3-mysqldb (in case of MySQL /MariaDB database)
  • virtualenv
  • make
  • git (recommended for getting the source)

Quick start

It assumes that you already have the application source code locally - the best way is by cloning this repository - and that you are in this folder.

  1. Define your local configuration in a file named config.env, which can be copied from config.env.example and edited to suits your needs.

    Depending on your environment, you will have to create your database and the user at first.

  2. Run make init.

    Note that if there is no config.env file, it will be created interactively.

That's it! Your environment is now initialized with the application installed. To update it, once the source code is checked out, simply run make update.

You can also check that your application is well configured by running make check.

Deployment

Here is an example deployment using NGINX - as the Web server - and uWSGI - as the application server.

The uWSGI configuration doesn't require a special configuration, except that we are using Python 3 and a virtual environment. Note that if you serve the application on a sub-location, you will have to add route-run = fixpathinfo: to your uWSGI configuration (from v2.0.11).

In the server block of your NGINX configuration, add the following blocks and set the path to your application instance and to the uWSGI socket:

root <app_instance_path>/frontend/dist;
index index.html;

# Frontend
location / {
  try_files $uri $uri/ @frontend;
}
location @frontend {
  rewrite ^(.+)$ /index.html last;
}

# Backend (Admin & API)
location ~ ^\/admin\/static\/(.*)$ {
  alias <app_instance_path>/var/static/$1;
  # Optional: don't log access to assets
  access_log off;
}
location ~ ^\/(?:admin|api)(?:$|\/) {
  include uwsgi_params;
  uwsgi_pass unix:<uwsgi_socket_path>;
}

# Media files
location ~ ^\/media\/(.*)$ {
  alias <app_instance_path>/var/media/$1;

  expires max;
  add_header Pragma public;
  add_header Cache-Control "public, immutable";
}

# Caching for frontend static files
location ~* \.(?:css|js|woff2?|svg|gif|jpe?g|png)$ {
  etag off;
  expires max;
  add_header Pragma public;
  add_header Cache-Control "public, immutable";
}

Structure

Overview

All the application files - e.g. Django code including settings, templates and statics - are located into onoseenparler/.

Two environments are defined - either for requirements and settings:

  • development: for local application development and testing. It uses a SQLite3 database and enable debugging by default, add some useful settings and applications for development purpose - i.e. the django-debug-toolbar.
  • production: for production. It checks that configuration is set and correct, try to optimize performances and enforce some settings - i.e. HTTPS related ones.

Local changes

You can override and extend statics and templates locally. This can be useful if you have to change the logo for a specific instance for example. For that, just put your files under the local/static/ and local/templates/ folders.

Regarding the statics, do not forget to collect them after that. Note also that the local/ folder is ignored by git.

Variable content

All the variable content - e.g. user-uploaded media, collected statics - are stored inside the var/ folder. It is also ignored by git as it's specific to each application installation.

So, you will have to configure your Web server to serve the var/media/ and var/static/ folders, which should point to /media/ and /static/, respectively.

Development

The easiest way to deploy a development environment is by using the Makefile.

Before running make init, ensure that you have either set ENV=development in the config.env file or have this environment variable. Note that you can still change this variable later and run make init again.

There is some additional rules when developing, which are mainly wrappers for manage.py. You can list all of them by running make help. Here are the main ones:

  • make serve: run a development server
  • make test: test the whole application
  • make lint: check the Python code syntax

Frontend

The frontend application is built with Vue.js thanks to Nuxt.js. A static site is generated for production use.

The source files live in frontend/ and the generated ones in frontend/dist/.

Requirements

All you need is npm. It is included in Debian since Buster and also in the stretch-backports repository.

Usage

Start by moving to the frontend/ directory and install the application dependencies - which are defined in package.json - by running: npm install.

The following tasks are then available:

  • npm run dev: serve the application in development with hot reload
  • npm run lint: lint the JavaScript and the SCSS code
  • npm run generate: build for production and generate a static site
  • npm run serve: build for production and serve the application

Note that in a development environment, the Django server will serve the generated static site at the root path.

License

On ose en parler is developed by Cliss XXI and licensed under the AGPLv3+.