Skip to content

Latest commit

 

History

History
158 lines (128 loc) · 6.94 KB

README.md

File metadata and controls

158 lines (128 loc) · 6.94 KB

Application réalisée avec le framework Django, Python 3.6 déployée à l'aide de gunicorn et nginx, sur un VPS Ubuntu Server 18.04

Exctraction des données "Compétitions" du site de la fédération française de handball : http://www.ff-handball.org/competitions

On veut centraliser les données de tous les matchs de hand de la fédération (matchs départementaux, régionaux, nationaux, du plus bas au plus niveau en france)

Deux fonctionnalités principales :

  • Récupérer le calendrier de son équipe (ou de n'importe quelle équipe en France) afin de l'importer dans son outil de calendrier personnel (Google Calendar dans mon cas). On va donc générer un lien pointant vers un fichier.ics : il faudra ajouter ce lien à vos agendas. La synchronisation avec les véritables données peuvent être de 24 à 48h.
  • Datavisualisation complète et analyse exploratoire de données provenant du hand amateur et professionel français.

Install app

  1. Install mysql/postgresql db on your computer :

Note: PostGreSQL is the db engine I used in this project, but it should be compatible with other ones Doc Django : https://docs.djangoproject.com/fr/2.1/ref/databases/ Doc Django bis : https://docs.djangoproject.com/fr/2.1/intro/tutorial02/ Tutorial (worked perfectyly on Ubuntu 18.04) : https://www.digitalocean.com/community/tutorials/how-to-install-mysql-on-ubuntu-18-04 Tutorial (worked perfectyly on Ubuntu 18.04) : https://www.digitalocean.com/community/tutorials/how-to-install-and-use-postgresql-on-ubuntu-18-04 WARNING: You must install a DB engine compatible with your system

1bis) for example for postgresql :

jimmydore@ubuntu:~/Projets$ sudo apt install postgresql postgresql-contrib
jimmydore@ubuntu:~/Projets$ sudo -u postgres createuser --interactive
jimmydore@ubuntu:~/Projets$ sudo -u postgres createdb jimmydore
  1. Clone the project and go into it:
jimmydore@ubuntu:~/Projets$ git clone https://github.com/JimmyDore/ffhb_cal.git
jimmydore@ubuntu:~/Projets$ cd ffhb_cal/
  1. Install python3 and virtualenv if not already done, and create a virtual env
jimmydore@ubuntu:~/Projets/ffhb_cal$ sudo apt-get install python3-venv
jimmydore@ubuntu:~/Projets/ffhb_cal$ python3 -m venv ffhb_venv # call it myvenv or ffhb_venv, easier for install script
  1. Create database in mysql or postgresql
  • MySQL
jimmydore@ubuntu:~/Projets/ffhb_cal$ mysql -u root -p
mysql> create database if not exists ffhb_cal_db character set UTF8mb4 collate utf8mb4_bin;
Query OK, 1 row affected (0.00 sec)
mysql> exit;
  • PostGreSQL
jimmydore@ubuntu:~/Projets/ffhb_cal$ sudo -u jimmydore psql
psql (10.5 (Ubuntu 10.5-0ubuntu0.18.04))
Type "help" for help.

jimmydore=# CREATE DATABASE "ffhb_cal_db" 
    WITH OWNER "jimmydore"
    ENCODING 'UTF8'
    LC_COLLATE = 'fr_FR.UTF-8'
    LC_CTYPE = 'fr_FR.UTF-8'
    TEMPLATE = template0;

Note: Warning it's possible that the locales fr_FR.UTF-8 are not installed on the server (https://askubuntu.com/questions/76013/how-do-i-add-locale-to-ubuntu-server)(This one worked : https://www.quennec.fr/trucs-astuces/syst%C3%A8mes/gnulinux/commandes/ubuntu-server/locale-fran%C3%A7aise-sur-ubuntu-server) :

jimmydore@ubuntu:~/Projets/ffhb_cal$ sudo su
root@ubuntu:~/Projets/ffhb_cal$ apt-get install language-pack-fr
root@ubuntu:~/Projets/ffhb_cal$ if [ -f /etc/default/locale ]; then cp /etc/default/locale /etc/default/locale_default; fi
root@ubuntu:~/Projets/ffhb_cal$ echo "LANG=fr_FR.UTF-8" > /etc/default/locale
root@ubuntu:~/Projets/ffhb_cal$ cat /etc/default/locale
LANG=fr_FR.UTF-8
root@ubuntu:~/Projets/ffhb_cal$ dpkg-reconfigure locales
  1. Create conf.local.py from conf.py in django project folder
jimmydore@ubuntu:~/Projets/ffhb_cal/$ cd ffhb_cal/ffhb_cal
jimmydore@ubuntu:~/Projets/ffhb_cal/ffhb_cal/ffhb_cal$ sudo cp conf.py conf.local.py
jimmydore@ubuntu:~/Projets/ffhb_cal/ffhb_cal/ffhb_cal$ vim conf.local.py #Here, replace values with your own id/passwords...

Note: Never push conf.local.py and push conf.py if only new fields in the file

  1. Création du superutilisateur pour le projet django
jimmydore@ubuntu:~/Projets/ffhb_cal$ source ffhb_venv/bin/activate
(ffhb_venv) jimmydore@ubuntu:~/Projets/ffhb_cal$ python ffhb_cal/manage.py createsuperuser
  1. Lancer le script d'installation
jimmydore@ubuntu:~/Projets/ffhb_cal$ ./install.sh
  1. Run the app
  • Run locally :
(ffhb_venv) jimmydore@jimmydore-XPS-13-9360:~/Documents/Projets_perso/ffhb_cal/ffhb_cal$ python manage.py runserver 8000

Le fichier de conf de gunicorn est le fichier gunicorn_start.sh Le fichier de conf de nginx est le fichier nginx_conf Le dernier fichier est le fichier de service pour gunicorn et cette app, afin de deamoniser le process gunicorn_ffhb_cal.service

Useful commands

In the virtualenv of the Django project, you can make a lot of useful commands :

  • Manage SQL shell
(myvenv) jimmydore@jimmydore-XPS-13-9360:~/Documents/Projets_perso/ffhb_cal/ffhb_cal$ python manage.py dbshell
  • Manage python shell
(myvenv) jimmydore@jimmydore-XPS-13-9360:~/Documents/Projets_perso/ffhb_cal/ffhb_cal$ python manage.py shell
  • Start server locally
(myvenv) jimmydore@jimmydore-XPS-13-9360:~/Documents/Projets_perso/ffhb_cal/ffhb_cal$ python manage.py run server 8000 #just type which port you want
  • Generate UML File from your model database (already in git hook, you don't need to do it)
(myvenv) jimmydore@jimmydore-XPS-13-9360:~/Documents/Projets_perso/ffhb_cal/ffhb_cal$ ./manage.py graph_models -a > ../ffhb_cal_UML.dot; dot ../ffhb_cal_UML.dot -Tpng -o ../ffhb_cal_UML.png
  • Go into psql console
jimmydore@jimmydore-XPS-13-9360:~/Documents/Projets_perso/ffhb_cal$ sudo -u postgres psql #postgres is the username
  • change password of DB user
ALTER USER user_name WITH PASSWORD 'new_password';
jimmydore@jimmydore-XPS-13-9360:~/Documents/Projets_perso/ffhb_cal$ sudo -u postgres psql
[sudo] Mot de passe de jimmydore : 
psql (10.5 (Ubuntu 10.5-0ubuntu0.18.04))
Type "help" for help.

postgres=# ALTER USER jimmydore WITH PASSWORD '<your-password>';

External tools