MusicTopus est une application Web permettant de gérer votre liste des CDs et Vinyles, et de l'utiliser facilement et n'importe où. https://www.musictopus.fr/
Go to file
Damien Broqua a0f9ab1f45 issue/19 (#20)
!19

Co-authored-by: dbroqua <contact@darkou.fr>
Reviewed-on: dbroqua/MyMusicLibrary#20
Co-authored-by: Damien Broqua <dbroqua@noreply.localhost>
Co-committed-by: Damien Broqua <dbroqua@noreply.localhost>
2022-03-01 16:09:46 +01:00
.husky init env 2022-02-13 14:03:04 +01:00
public issue/19 (#20) 2022-03-01 16:09:46 +01:00
sass issue/19 (#20) 2022-03-01 16:09:46 +01:00
src issue/19 (#20) 2022-03-01 16:09:46 +01:00
views issue/19 (#20) 2022-03-01 16:09:46 +01:00
.babelrc Updated env + Added SignIn/SignUp 2022-02-13 17:59:42 +01:00
.editorconfig Updated env + Added SignIn/SignUp 2022-02-13 17:59:42 +01:00
.eslintignore init env 2022-02-13 14:03:04 +01:00
.eslintrc.js Some changes in structure + add album 2022-02-15 11:03:20 +01:00
.gitignore Added dump volume for db 2022-02-22 07:49:21 +01:00
docker-compose.yml.dev #issue/17 (#18) 2022-02-22 14:50:07 +01:00
docker-compose.yml.prod #issue/17 (#18) 2022-02-22 14:50:07 +01:00
LICENSE Initial commit 2022-02-13 13:17:50 +01:00
package.json Some fixes on css 2022-02-23 08:41:30 +01:00
README.md Ajout de formspree 2022-02-23 07:51:17 +01:00

My Music Library

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ù.

Le code source est publié sous licence libre GNU GPL-3.0-or-later et est disponible sur git.darkou.fr.

Utilisation

Vous pouvez librement utiliser le service en vous inscrivant sur 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 !

Auto hébergement

Vous pouvez, si vous le souhaitez héberger l'application sur votre propre serveur.

Prérequis

Il existe 2 méthodes d'installation, soit via docker soit en mode standalone. Peu importe la méthode il vous faudra un compte sur https://formspree.io/ afin d'avoir une page nous-contacter fonctionnelle.

Pour la méthode docker il ne vous faudra rien de plus que docker et docker-compose.

En mode standalone il vous faudra :

  • NodeJS 16.x
  • Yarn
  • MongoDB

Quelque que soit la méthode, la première étape est de cloner le projet :

git clone https://git.darkou.fr/dbroqua/MyMusicLibrary.git

Installation

Docker

Une fois le projet cloné rendez-vous dans son dossier,

cd ./MyMusicLibrary

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).

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.

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.

Vous pouvez maintenant démarrer votre environnement Docker :

docker-compose up -d

C'est terminé !

Le site est accessible sur http://localhost:PORT.

Standalone

Pour la version standalone je vous conseille de faire un script embarquant les variables d'environnement que vous souhaitez modifier :

#! /bin/bash

export NODE_ENV=development
export DISCOGS_TOKEN=***

# Dev
yarn watch
# Prod
yarn run:all

Rendez le script exécutable :

chmod +x ./run.sh

Puis exécutéz le :

./run.sh

C'est terminé !

Le site est accessible sur http://localhost:3001.

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.

Aller plus loin

My Music Library est maintenant accessible en http sur un port custom (3001 par défaut) de votre serveur.

Nous allons voir comment rendre accessible en https avec un certificat Let's Encrypt. Pour le reverse proxy nous utiliserons NGINX.

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

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.

Fichier .env

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)
FORMSPREE_ID # Id du formulaire formspree pour la page "nous-contacter"

Contributeurs

  • Damien Broqua (développeur principal du projet)
  • Brunus (fournisseur d'idées 😉 )