1
0
mirror of https://gitlab.crans.org/bde/nk20 synced 2024-11-26 18:37:12 +00:00
Go to file
2020-01-28 21:15:36 +01:00
apps An activity entry transaction is not mandatory. 2020-01-21 22:16:07 +01:00
locale/fr/LC_MESSAGES Move locales to project root 2019-08-14 15:15:02 +02:00
note_kfet the server is running 2020-01-28 19:56:04 +00:00
static Merge branch 'master' into 'app_member' 2019-08-15 19:53:40 +00:00
templates fixed footer (again ?) 2019-09-23 12:51:09 +02:00
.coveragerc Fix CI 2019-08-14 15:31:46 +02:00
.gitignore split settings config between development and production 2020-01-27 20:49:02 +00:00
.gitlab-ci.yml Regroup everything here 2019-07-08 12:55:48 +02:00
.pylintrc Regroup everything here 2019-07-08 12:55:48 +02:00
COPYING Add COPYING 2019-07-08 07:58:44 +02:00
LICENSE Added LICENSE file 2019-09-18 14:46:10 +02:00
manage.py and so it begins 2019-07-07 20:49:02 +00:00
nginx_note.conf and so it begins 2019-07-07 20:49:02 +00:00
README.md plus d'excuse pour déployer en prod 2020-01-28 21:15:36 +01:00
requirements.txt add Django Guardian 2020-01-21 22:09:20 +01:00
tox.ini Make continuous integration integrate well 2019-08-14 15:19:25 +02:00
uwsgi_note.ini split settings config between development and production 2020-01-27 20:49:02 +00:00
uwsgi_params and so it begins 2019-07-07 20:49:02 +00:00

NoteKfet 2020

License: GPL v3 pipeline status coverage report

Installation sur un serveur

On supposera pour la suite que vous utiliser debian/ubuntu sur un serveur tout nu ou bien configuré.

  1. Paquets nécessaires

     $ sudo apt install nginx python3 python3-pip python3-dev uwsgi
     $ sudo apt install uwsgi-plugin-python3 python3-virtualenv git
    
  2. Clonage du dépot

    on se met au bon endroit :

     $ cd /var/www/
     $ mkdir note_kfet
     $ cd note_kfet
     $ git clone git@gitlab.crans.org:bde/nk20.git .
    
  3. Environment Virtuel

    À la racine du projet:

     $ virtualenv env
     $ source /env/bin/activate
     (env)$ pip install -r requirements.txt
     (env)$ deactivate
    
  4. uwsgi et Nginx

    On utilise uwsgi et Nginx pour gérer le coté serveu :

     $ sudo ln -sf /var/www/note_kfet/nginx_note.conf /etc/nginx/sites-enabled/
    

    Modifier la config nginx pour l'adapter à votre server!

    Si l'on a un emperor (plusieurs instance uwsgi):

     $ sudo ln -sf /var/www/note_kfet/uwsgi_note.ini /etc/uwsgi/sites/
    

    Sinon:

     $ sudo ln -sf /var/www/note_kfet/uwsgi_note.ini /etc/uwsgi/apps-enabled/
    
  5. Base de données

    En prod on utilise postgresql.

     $ sudo apt-get install postgresql postgresql-contrib libpq-dev
     (env)$ pip install psycopg2
    

    La config de la base de donnée se fait comme suit:

    a. On se connecte au shell de psql

     $ sudo su - postgres
     $ psql
    

    b. On sécurise l'utilisateur postgres

     postgres=# \password
     Enter new password:
    

    Conservez ce mot de passe de la meme manière que tous les autres.

    c. On créer la basse de donnée, et l'utilisateur associé

     postgres=# CREATE USER note WITH PASSWORD 'un_mot_de_passe_sur';
     CREATE ROLE
     postgres=# CREATE DATABASE note_db OWNER note;
     CREATE DATABASE
    

    Si tout va bien:

     postgres=#\list
     List of databases
        Name    |  Owner   | Encoding |   Collate   |    Ctype    |   Access privileges   
     -----------+----------+----------+-------------+-------------+-----------------------
      note_db   | note     | UTF8     | fr_FR.UTF-8 | fr_FR.UTF-8 | 
      postgres  | postgres | UTF8     | fr_FR.UTF-8 | fr_FR.UTF-8 | 
      template0 | postgres | UTF8     | fr_FR.UTF-8 | fr_FR.UTF-8 | =c/postgres+postgres=CTc/postgres
      template1 | postgres | UTF8     | fr_FR.UTF-8 | fr_FR.UTF-8 | =c/postgres  +postgres=CTc/postgres
     (4 rows)
    

NB: cette config est en adéquation avec note_kfet/settings/production.py. penser à changer le mots de passe dans note_kfet/settings/secrets.py

  1. Variable d'environnement et Migrations

     on modifie le fichier d'environnement:
     ```
     # env/bin/activate:
    
     deactivate () {
     ...
    
     # Unset local environment variables
     unset DJANGO_APP_STAGE
     unset DJANGO_DB_PASSWORD
     unset DJANGO_SECRET_KEY
     }
     ...
     #at end of the file:
     export DJANGO_APP_STAGE="prod"
     export DJANGO_DB_PASSWORD="a_long_and_secure_password"
     export DJANGO_SECRET_KEY="a_long_and_secure_secret_key"
    

Ensuite on bascule dans l'environement virtuel et on lance les migrations

    $ source /env/bin/activate
    (env)$ ./manage.py makemigrations
    (env)$ ./manage.py migrate
  1. Enjoy

Installer en local

Il est tout a fait possible de travailler en local, vive ./manage.py runserver !

  1. Cloner le dépot là ou vous voulez:

     $ git clone git@gitlab.crans.org:bde/nk20.git
    
  2. Initialiser l'environnement Virtuel

     $ cd nk20
     $ virtualenv env
     $ source /env/bin/activate
     (env)$ pip install -r requirements.txt
    
  3. Migrations:

     (env)$ ./manage.py makemigrations
     (env)$ ./manage.py migrate
    
  4. Enjoy:

     (env)$ ./manage.py runserver
    

Minimal Setup

  1. Créer un superuser :

     (env)$ ./manage.py createsuperuser
    

Avec ce dernier vous pouvez vous connecter à l'interface admin de Django, avoir accès à la doc auto-générée du projet, jouer avec des models, etc ...

Cahier des Charges

Il est disponible ici.

Documentation

La documentation est générée par django et son module admindocs. *Commenter votre code !