MusicTopus/README.md

185 lines
5.4 KiB
Markdown
Raw Normal View History

# My Music Library
2022-02-13 13:17:50 +01:00
2022-02-21 11:30:16 +01:00
My Music Library est une application Web (que vous pouvez auto-héberger) et un site Web (sur lequel vous pouvez créer un compte) permettant de gérer votre liste des CDs et Vinyles et de l'utiliser facilement n'importe où.
2022-02-15 11:03:20 +01:00
2022-02-21 14:23:05 +01:00
Le code source est publié sous licence libre [GNU GPL-3.0-or-later](LICENSE) et est disponible sur [git.darkou.fr](https://git.darkou.fr/dbroqua/MyMusicLibrary).
## Utilisation
Vous pouvez librement utiliser le service en vous inscrivant sur [https://mml.darkou.fr](https://mml.darkou.fr).
Une fois inscrit vous pourrez saisir vos CDs et Vinyles sur votre espace personnel le tout gratuitement, sans tracker et sans utilisation de vos données personnelles !
2022-02-15 11:03:20 +01:00
2022-02-21 08:23:36 +01:00
## Auto hébergement
2022-02-15 11:03:20 +01:00
2022-02-21 14:23:05 +01:00
Vous pouvez, si vous le souhaitez héberger l'application sur votre propre serveur.
2022-02-21 08:23:36 +01:00
### Prérequis
2022-02-15 11:03:20 +01:00
2022-02-21 08:23:36 +01:00
Il existe 2 méthodes d'installation, soit via docker soit en mode standalone.
2022-02-15 11:03:20 +01:00
2022-02-21 08:23:36 +01:00
Pour la méthode docker il vous faut simplement Docker sur votre serveur.
2022-02-15 11:03:20 +01:00
2022-02-21 14:23:05 +01:00
En mode standalone il vous faudra :
2022-02-21 08:23:36 +01:00
- NodeJS 16.x
- Yarn
- MongoDB
2022-02-21 14:23:05 +01:00
Quelque que soit la méthode, la première étape est de cloner le projet :
2022-02-21 08:23:36 +01:00
```bash
git clone https://git.darkou.fr/dbroqua/MyMusicLibrary.git
2022-02-15 11:03:20 +01:00
```
2022-02-21 08:23:36 +01:00
### Installation
2022-02-15 11:03:20 +01:00
2022-02-21 08:23:36 +01:00
#### Docker
2022-02-15 11:03:20 +01:00
2022-02-21 08:23:36 +01:00
Une fois le projet cloné rendez-vous dans son dossier,
2022-02-15 11:03:20 +01:00
2022-02-21 08:23:36 +01:00
```bash
cd ./MyMusicLibrary
2022-02-15 11:03:20 +01:00
```
2022-02-21 08:23:36 +01:00
2022-02-21 14:23:05 +01:00
puis créez le fichier `.env` qui contiendra les variables d'environnement nécessaire au bon fonctionnement du projet ([voir à la fin pour la liste des variables](#env-file)).
2022-02-21 08:23:36 +01:00
Une fois votre fichier d'environnement créé vous devez copier le bon fichier `docker-compose.yml.{dev,prod}` en `docker-compose.yml` en fonction de vos choix.
2022-02-21 14:23:05 +01:00
La version `.dev` redémarrera à chaque changement d'un fichier `.js` alors que la version `prod` ne redémarrera pas automatiquement si vous éditez un fichier.
2022-02-21 08:23:36 +01:00
Vous pouvez maintenant démarrer votre environnement Docker :
```bash
2022-02-15 11:03:20 +01:00
docker-compose up -d
```
2022-02-21 08:23:36 +01:00
C'est terminé !
Le site est accessible sur [http://localhost:PORT](http://localhost:PORT).
#### Standalone
Pour la version standalone je vous conseille de faire un script embarquant les variables d'environnement que vous souhaitez modifier :
```bash
#! /bin/bash
export NODE_ENV=development
export DISCOGS_TOKEN=***
2022-02-15 11:03:20 +01:00
2022-02-21 08:23:36 +01:00
# Dev
yarn watch
# Prod
yarn run:all
```
Rendez le script exécutable :
```bash
2022-02-21 14:23:05 +01:00
chmod +x ./run.sh
```
Puis exécutéz le :
```bash
./run.sh
2022-02-21 08:23:36 +01:00
```
C'est terminé !
Le site est accessible sur [http://localhost:3001](http://localhost:3001).
2022-02-21 14:23:05 +01:00
:information_source: Information : Vous pouvez, et vous dreviez, également regarder du côté de `systemd`, `pm2` ou encore `supervisor` pour que le service démarre en même temps que votre serveur.
2022-02-21 08:23:36 +01:00
### Aller plus loin
2022-02-21 14:23:05 +01:00
My Music Library est maintenant accessible en http sur un port custom (3001 par défaut) de votre serveur.
2022-02-21 08:23:36 +01:00
Nous allons voir comment rendre accessible en https avec un certificat [Let's Encrypt](https://letsencrypt.org/fr/). Pour le reverse proxy nous utiliserons [NGINX](https://nginx.org/).
Pour la suite je pars du principe que vous êtes un minimum familier avec Nginx et Let's Encrypt et que ces 2 outils sont déjà présents sur votre serveur. De plus vous avez une entrée DNS qui pointe vers votre serveur.
#### Obtenir le certificat
```bash
certbot certonly --nginx -d mml.darkou.fr
```
#### Créer le vhost
Pour ma part j'aime bien créer un fichier dans `/etc/nginx/sites-available` qui comporte le nom du site, ici par exemple `mml.darkou.fr`.
En voici son contenu :
```
upstream mml-env {
server 0.0.0.0:3001;
}
server {
listen 80;
listen [::]:80;
server_name mml.darkou.fr;
if ($host = mml.darkou.fr) {
return 301 https://$host$request_uri;
}
root /dev/null;
location /.well-known/acme-challenge/ { allow all; }
}
server {
listen 443 ssl http2;
server_name mml.darkou.fr;
root /dev/null;
access_log /var/log/nginx/mml.darkou.fr-access.log;
error_log /var/log/nginx/mml.darkou.fr-error.log;
add_header X-Content-Type-Options nosniff;
add_header X-XSS-Protection "1; mode=block";
client_max_body_size 1m;
location / {
proxy_read_timeout 300;
proxy_connect_timeout 300;
proxy_redirect off;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_set_header Host $http_host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-Ssl on;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Frame-Options SAMEORIGIN;
proxy_pass http://mml-env;
}
include conf/ssl.conf;
ssl_certificate /etc/letsencrypt/live/mml.darkou.fr/fullchain.pem; # managed by Certbot
ssl_certificate_key /etc/letsencrypt/live/mml.darkou.fr/privkey.pem; # managed by Certbot
}
```
Une fois le vhost activé (lien symbolique dans le dossier site-enable) et nginx rechargé votre site sera alors accessible en https.
2022-02-21 14:23:05 +01:00
### Fichier .env {#env-file}
2022-02-21 08:23:36 +01:00
Voici la liste des variables configurables :
```
NODE_ENV # Environnement dans lequel exécuter le projet (development ou production)
PORT # Port sur lequel éxécuter le serveur (par défaut 3001)
MONGODB_URI # Url du serveur mongo (par défaut mongodb://mymusiclibrary-db/mymusiclibrary)
SECRET # Hash utilisé pour pour sauvegardé les dessions (par défaut waemaeMe5ahc6ce1chaeKohKa6Io8Eik)
DISCOGS_TOKEN # Token Discogs (vous devez créer un compte sur discogs afin d'en obtenir un gratuitement)
```
2022-02-21 14:55:08 +01:00
## Contributeurs
- Damien Broqua (développeur principal du projet)
- Brunus (fournisseur d'idées :wink: )