From 0c9d7913c9a78e51eca5629e3a784a8a7778c9f9 Mon Sep 17 00:00:00 2001
From: Julien Jerphanion <git@jjerphan.xyz>
Date: Wed, 6 Feb 2019 22:59:19 +0100
Subject: [PATCH] Documenting ; changing shebang

---
 README.md                              | 38 +++++++++++++++++++++
 backup-rotation/README.md              | 37 ++++++++++----------
 checkmk/README.md                      | 14 ++++----
 database/Mongo/README                  |  4 +--
 database/Mongo/run.sh                  |  3 +-
 database/Mongo/runScript.sh            |  3 +-
 database/Mongo/set_mongodb_password.sh |  2 +-
 database/Redis/README                  |  2 +-
 database/Redis/runScript.sh            |  1 +
 db-backup/README.md                    | 37 ++++++++++----------
 db-backup/mongo-run.sh                 |  2 +-
 db-backup/mysql-run.sh                 |  2 +-
 db-backup/run.sh                       |  6 ++--
 framadate/README.md                    |  2 +-
 framadate/entrypoint.sh                |  2 +-
 grafana/README.md                      |  6 +++-
 mattermost-cleaner/README.md           | 28 ++++++++-------
 mattermost-cleaner/cron.sh             |  2 +-
 mattermost-cleaner/psqlcmd.sh          |  2 +-
 minetest/README.md                     | 21 ++++++------
 minetest/entrypoint.sh                 |  3 +-
 mysql-backup/README.md                 | 47 ++++++++++++++------------
 pica-apache/run.sh                     |  2 +-
 pica-dokuwiki/run.sh                   |  2 +-
 pica-etherpad/entrypoint.sh            |  2 +-
 pica-nginx/start.sh                    |  2 +-
 postgres-backup/README.md              | 46 +++++++++++++------------
 postgres-backup/run.sh                 |  2 +-
 28 files changed, 185 insertions(+), 135 deletions(-)
 create mode 100644 README.md

diff --git a/README.md b/README.md
new file mode 100644
index 00000000..d73c10e3
--- /dev/null
+++ b/README.md
@@ -0,0 +1,38 @@
+# Picasoft's Dockerfiles
+
+Here is the list of `DockerFile`'s used by Picasoft to deploy and maintain its services.
+
+## Services
+
+### Mattermost
+ - [`mattermost`](./mattermost)
+ - [`mattermost-cleaner`](./mattermost-cleaner)
+ - [`mattermost-integration-giphy`](./mattermost-integration-giphy)
+
+### Etherpad
+ - [`pica-etherpad`](./pica-etherpad)
+
+### Kanban
+ - [`pica-kanboard`](./pica-kanboard)
+
+## Databases
+ - [`backup-rotation`](./backup-rotation)
+ - [`database`](./database)
+ - [`db-backup`](./db-backup)
+ - [`influxdb`](./influxdb)
+ - [`postgres-backup`](./postgres-backup)
+ - [`mysql-backup`](./mysql-backup)
+
+## Deployment & Misc (or to sort)
+ - [`docker-compose`](./docker-compose)
+ - [`pica-apache`](./pica-apache)
+ - [`pica-bot`](./pica-bot)
+ - [`pica-dokuwiki`](./pica-dokuwiki)
+ - [`pica-nginx`](./pica-nginx)
+ - [`checkmk`](./checkmk)
+ - [`debian`](./debian)
+ - [`framadate`](./framadate)
+ - [`galette`](./galette)
+ - [`grafana`](./grafana)
+ - [`minetest`](./minetest)
+ - [`nextcloud-docker`](./nextcloud-docker)
diff --git a/backup-rotation/README.md b/backup-rotation/README.md
index 2ee9a370..1f1a0faf 100644
--- a/backup-rotation/README.md
+++ b/backup-rotation/README.md
@@ -4,23 +4,23 @@ Le fichier backup_data.json recense les informations sur les différents service
 
 ## Structure
 
-*  Nom du service : Contient une structure de données contenant les informations relatives au service telles qu'indiquées ci-dessous
-*  "Host" : Indique l'hôte de la base de données
-*  "Port" : Indique le port pour se connecter au service
-*  "Database" : Indique le nom de la base de données
-*  "Folder" : Indique le nom du dossier de backup utilisé par le script de backup et de rotation
-*  "Cron" : Indique la fréquence de temps à laquelle les backups sont effectués par le script de rotation au format cron
-*  "Backup-Rota" : Contient les paramètres pour la rotation des backups dans une structure de données comme indiqué ci-dessous
-    *     "Hour" : nombre de backups horaires à conserver
-    *     "Day" : nombre de backups quotidiens à conserver
-    *     "Week" : nombre de backups hebdomadaires à conserver
-    *     "Month": nombre de backups mensuels à conserver
+- Nom du service : Contient une structure de données contenant les informations relatives au service telles qu'indiquées ci-dessous
+- "Host" : Indique l'hôte de la base de données
+- "Port" : Indique le port pour se connecter au service
+- "Database" : Indique le nom de la base de données
+- "Folder" : Indique le nom du dossier de backup utilisé par le script de backup et de rotation
+- "Cron" : Indique la fréquence de temps à laquelle les backups sont effectués par le script de rotation au format cron
+- "Backup-Rota" : Contient les paramètres pour la rotation des backups dans une structure de données comme indiqué ci-dessous
+    - "Hour" : nombre de backups horaires à conserver
+    - "Day" : nombre de backups quotidiens à conserver
+    - "Week" : nombre de backups hebdomadaires à conserver
+    - "Month": nombre de backups mensuels à conserver
 
 ## Exemple
 
-```
+```json
 {
-  "wekan": 
+  "wekan":
     {
       "Host": "wekan-db",
       "Port": "27017",
@@ -60,10 +60,10 @@ Le fichier backup_data.json recense les informations sur les différents service
 }
 ```
 
-##Exemple d'implémentation dans le docker-compose
+## Exemple d'implémentation dans le docker-compose
 
 
-```
+```yaml
 ##############################
 ####### Backup rotation ######
 ##############################
@@ -75,7 +75,6 @@ Le fichier backup_data.json recense les informations sur les différents service
       - /DATA/CONFIG:/config
 ```
 
-
-*   /DATA/BACKUP : Dossier contenant les backups à effecter
-*   /DATA/CONFIG : Dossier contenant le fichier .json de données
-
+Avec :
+ - `/DATA/BACKUP` : Dossier contenant les backups à effecter
+ - `/DATA/CONFIG` : Dossier contenant le fichier .json de données
diff --git a/checkmk/README.md b/checkmk/README.md
index 3b18595f..63bc8631 100644
--- a/checkmk/README.md
+++ b/checkmk/README.md
@@ -1,6 +1,6 @@
 # CheckMK
 
-Docker image for CheckMK monitoring system.
+Docker image for [CheckMK](https://mathias-kettner.com/) monitoring system.
 
 ## Configuration
 This image need some environment variables to be set in order to work:
@@ -14,7 +14,7 @@ You can also add some optionnal variables to customize your container:
 
 ## Deploy
 Here is a `docker-compose.yml` example to deploy CheckMK behind Traefik.
-```
+```yaml
 checkmk:
   image: registry.picasoft.net:5000/checkmk:1.4.0p19
   container_name: checkmk
@@ -32,14 +32,14 @@ checkmk:
 
 ## Upgrade
 CheckMK provide a tool to upgrade a site version. Unfortunately this tools need that both CheckMK versions (old and new one) are installed. This is something tricky when working with containers, so the upgrade process of an existing site is quite manual. First, enter in your current container (with `docker exec -it checkmk bash`), install new CheckMK version and run upgrade process.
-```
+```bash
 # Replace 1.4.0p22 with the new version you want to use
 NEW_CHECKMK_VERSION=1.4.0p22
 # Get new version
-wget -O checkmk.deb "https://mathias-kettner.de/support/"$NEW_CHECKMK_VERSION"/check-mk-raw-"$NEW_CHECKMK_VERSION"_0.stretch_amd64.deb"
-dpkg -i checkmk.deb
+$ wget -O checkmk.deb "https://mathias-kettner.de/support/"$NEW_CHECKMK_VERSION"/check-mk-raw-"$NEW_CHECKMK_VERSION"_0.stretch_amd64.deb"
+$ dpkg -i checkmk.deb
 # Upgrade the site
-omd stop $SITE_NAME
-omd update $SITE_NAME
+$ omd stop $SITE_NAME
+$ omd update $SITE_NAME
 ```
 When everything is ok, you can exit and kill your container. Then build a new CheckMK image with the new version you want to use in your Dockerfile, and use this image to start again your CheckMK service. Your site will be working on the new CheckMK version.
diff --git a/database/Mongo/README b/database/Mongo/README
index 6f57b601..c2e6f111 100644
--- a/database/Mongo/README
+++ b/database/Mongo/README
@@ -1,5 +1,5 @@
 Ce dockerfile permet de mettre un mot de passe sur la base Mongo via une variable d'environnement (contrairement au build officiel).
 
-Build le dockerfile puis créer le container grâce à runScript.sh
+Build le dockerfile puis créer le container grâce à `runScript.sh`
 
-Basé sur la version de tutumcloud (Github)
\ No newline at end of file
+Basé sur la version de tutumcloud (Github)
diff --git a/database/Mongo/run.sh b/database/Mongo/run.sh
index bcd9e0a7..37e48c22 100755
--- a/database/Mongo/run.sh
+++ b/database/Mongo/run.sh
@@ -1,4 +1,5 @@
-#!/bin/bash
+#!/usr/bin/env bash
+
 set -m
 
 mongodb_cmd="mongod --storageEngine $STORAGE_ENGINE"
diff --git a/database/Mongo/runScript.sh b/database/Mongo/runScript.sh
index 198bb0de..43aea7ec 100755
--- a/database/Mongo/runScript.sh
+++ b/database/Mongo/runScript.sh
@@ -1,3 +1,2 @@
-#!/bin/bash
-
+#!/usr/bin/env bash
 docker run -v /root/mongo/data:/data/db -d --name mongoLatex -p 27017:27017 -p 28017:28017 -e MONGODB_USER="USERNAME" -e MONGODB_DATABASE="DBNAME" -e MONGODB_PASS="PASSWORD" dockerfile/mongodb
diff --git a/database/Mongo/set_mongodb_password.sh b/database/Mongo/set_mongodb_password.sh
index e70fd805..61fd20f5 100755
--- a/database/Mongo/set_mongodb_password.sh
+++ b/database/Mongo/set_mongodb_password.sh
@@ -1,4 +1,4 @@
-#!/bin/bash
+#!/usr/bin/env bash
 
 USER=${MONGODB_USER:-"admin"}
 DATABASE=${MONGODB_DATABASE:-"admin"}
diff --git a/database/Redis/README b/database/Redis/README
index b71330b8..c2ff0f88 100644
--- a/database/Redis/README
+++ b/database/Redis/README
@@ -1 +1 @@
-Build then run runScript.sh
\ No newline at end of file
+Build then modify `runScript.sh` and run it.
diff --git a/database/Redis/runScript.sh b/database/Redis/runScript.sh
index 34bc276e..c181b4d9 100755
--- a/database/Redis/runScript.sh
+++ b/database/Redis/runScript.sh
@@ -1,2 +1,3 @@
+#!/usr/bin/env bash
 docker pull redis
 docker run -d -p 6379:6379 -v ~/PATH/TO/FOLDER:/data --name redis dockerfile/redis redis-server /etc/redis/redis.conf --requirepass PASSWORDHERE
diff --git a/db-backup/README.md b/db-backup/README.md
index 2ee9a370..54fabe79 100644
--- a/db-backup/README.md
+++ b/db-backup/README.md
@@ -4,23 +4,23 @@ Le fichier backup_data.json recense les informations sur les différents service
 
 ## Structure
 
-*  Nom du service : Contient une structure de données contenant les informations relatives au service telles qu'indiquées ci-dessous
-*  "Host" : Indique l'hôte de la base de données
-*  "Port" : Indique le port pour se connecter au service
-*  "Database" : Indique le nom de la base de données
-*  "Folder" : Indique le nom du dossier de backup utilisé par le script de backup et de rotation
-*  "Cron" : Indique la fréquence de temps à laquelle les backups sont effectués par le script de rotation au format cron
-*  "Backup-Rota" : Contient les paramètres pour la rotation des backups dans une structure de données comme indiqué ci-dessous
-    *     "Hour" : nombre de backups horaires à conserver
-    *     "Day" : nombre de backups quotidiens à conserver
-    *     "Week" : nombre de backups hebdomadaires à conserver
-    *     "Month": nombre de backups mensuels à conserver
+ - Nom du service : Contient une structure de données contenant les informations relatives au service telles qu'indiquées ci-dessous
+ - "Host" : Indique l'hôte de la base de données
+ - "Port" : Indique le port pour se connecter au service
+ - "Database" : Indique le nom de la base de données
+ - "Folder" : Indique le nom du dossier de backup utilisé par le script de backup et de rotation
+ - "Cron" : Indique la fréquence de temps à laquelle les backups sont effectués par le script de rotation au format cron
+ - "Backup-Rota" : Contient les paramètres pour la rotation des backups dans une structure de données comme indiqué ci-dessous
+     - "Hour" : nombre de backups horaires à conserver
+     - "Day" : nombre de backups quotidiens à conserver
+     - "Week" : nombre de backups hebdomadaires à conserver
+     - "Month": nombre de backups mensuels à conserver
 
 ## Exemple
 
-```
+```json
 {
-  "wekan": 
+  "wekan":
     {
       "Host": "wekan-db",
       "Port": "27017",
@@ -60,10 +60,10 @@ Le fichier backup_data.json recense les informations sur les différents service
 }
 ```
 
-##Exemple d'implémentation dans le docker-compose
+## Exemple d'implémentation dans le docker-compose
 
 
-```
+```yaml
 ##############################
 ####### Backup rotation ######
 ##############################
@@ -75,7 +75,6 @@ Le fichier backup_data.json recense les informations sur les différents service
       - /DATA/CONFIG:/config
 ```
 
-
-*   /DATA/BACKUP : Dossier contenant les backups à effecter
-*   /DATA/CONFIG : Dossier contenant le fichier .json de données
-
+Avec:
+ - `/DATA/BACKUP` : Dossier contenant les backups à effecter
+ - `/DATA/CONFIG` : Dossier contenant le fichier .json de données
diff --git a/db-backup/mongo-run.sh b/db-backup/mongo-run.sh
index 96023aeb..b8a162c2 100755
--- a/db-backup/mongo-run.sh
+++ b/db-backup/mongo-run.sh
@@ -1,4 +1,4 @@
-#!/bin/bash
+#!/usr/bin/env bash
 # Antoine Barbare 18/02/18 <antoine@barbare.me>
 
 BACKUP_FOLDER=${BACKUP_FOLDER:-"/backup/"}
diff --git a/db-backup/mysql-run.sh b/db-backup/mysql-run.sh
index 950feecd..21b85bf1 100755
--- a/db-backup/mysql-run.sh
+++ b/db-backup/mysql-run.sh
@@ -1,4 +1,4 @@
-#!/bin/bash
+#!/usr/bin/env bash
 
 if [ "${MYSQL_ENV_MYSQL_PASS}" == "**Random**" ]; then
         unset MYSQL_ENV_MYSQL_PASS
diff --git a/db-backup/run.sh b/db-backup/run.sh
index 6a0f5860..4e77087c 100755
--- a/db-backup/run.sh
+++ b/db-backup/run.sh
@@ -1,4 +1,4 @@
-#!/bin/bash
+#!/usr/bin/env bash
 
 # DB_TYPE : MYSQL|POSTGRES
 
@@ -11,8 +11,8 @@
 # MYSQL_DB_LIST			POSTGRES_DB_LIST                  MONGO_DB_LIST
 # MYSQL_INIT_BACKUP_LIST	POSTGRES_INIT_BACKUP_LIST         MONGO_INIT_BACKUP_LIST
 # MYSQL_CRON_TIME_LIST		POSTGRES_CRON_TIME_LIST           MONGO_CRON_TIME_LIST
-# MYSQL_EXTRA_OPTS_LIST		POSTGRES_EXTRA_OPTS-LIST          MONGO_BACKUP_FOLDER_LIST 
-# MYSQL_BACKUP_FOLDER_LIST	POSTGRESQL_BACKUP_FOLDER_LIST     
+# MYSQL_EXTRA_OPTS_LIST		POSTGRES_EXTRA_OPTS-LIST          MONGO_BACKUP_FOLDER_LIST
+# MYSQL_BACKUP_FOLDER_LIST	POSTGRESQL_BACKUP_FOLDER_LIST
 
 #####################
 # Create the arrays #
diff --git a/framadate/README.md b/framadate/README.md
index 3753bef9..2c5fc389 100644
--- a/framadate/README.md
+++ b/framadate/README.md
@@ -6,7 +6,7 @@ Image Docker pour le déploiement de Framadate
 ## Configuration
 ### Base de données
 Pour fonctionner, Framadate a besoin d'une base de données. Dans notre cas nous utilisons MySQL, que l'on déploie avec Docker. Afin que Framadate fonctionne correctement, nous devons désactiver le *SQL MODE* `NO_ZERO_DATE` de MySQL. On peut donc déployer une base de données pour Framadate ainsi (avec Docker Compose):
-```
+```yaml
 framadate-db:
   image: mysql:5.7
   container_name: framadate-db
diff --git a/framadate/entrypoint.sh b/framadate/entrypoint.sh
index e5c41ef2..2e681867 100755
--- a/framadate/entrypoint.sh
+++ b/framadate/entrypoint.sh
@@ -1,4 +1,4 @@
-#!/bin/bash
+#!/usr/bin/env bash
 
 # Read environment variables or set default values
 FRAMADATE_CONFIG=${FRAMADATE_CONFIG:-/var/www/framadate/app/inc/config.php}
diff --git a/grafana/README.md b/grafana/README.md
index 31628364..c36e9f5d 100644
--- a/grafana/README.md
+++ b/grafana/README.md
@@ -10,4 +10,8 @@ There are some evironment variable you can use to configure the instance :
 - `GF_SECURITY_ADMIN_PASSWORD` : Admin password
 
 ## Data persistence
-In order to ensure data persistence for your Grafana datasources and dashboard, you should mount a volume on `/var/lib/grafana`. Because Grafana is not execute as root user, you need to specify correct access right to this volume. Is using bind mount, you should do something like `mkdir volumes/grafana && chown 472:472 volumes/grafana`.
+In order to ensure data persistence for your Grafana datasources and dashboard, you should mount a volume on `/var/lib/grafana`. Because Grafana is not execute as root user, you need to specify correct access right to this volume. If using bind mount, you should do something like:
+
+```bash
+$ mkdir volumes/grafana && chown 472:472 volumes/grafana
+```
diff --git a/mattermost-cleaner/README.md b/mattermost-cleaner/README.md
index fdddeb8a..1d25c9d0 100644
--- a/mattermost-cleaner/README.md
+++ b/mattermost-cleaner/README.md
@@ -1,16 +1,15 @@
 # mattermost-cleaner
 
-This image runs a cron to delete automatic messages from Mattermost teams (alpha version, only run on one team).
-Delete command is run once when container starts and then every hour (depending on parameter) via cron.
+This image runs a `cron` to delete automatic messages from Mattermost teams (alpha version, only run on one team).
+Delete command is run once when container starts and then every hour (depending on parameter) via `cron`.
 
-**Warning** The commande delete directly data from database, which is bad pratice
-https://docs.mattermost.com/install/troubleshooting.html#important-notes
-https://docs.mattermost.com/deployment/on-boarding.html#do-not-manipulate-the-mattermost-database
+**Warning** The commande delete directly data from database, which is bad pratice ; see [here](https://docs.mattermost.com/install/troubleshooting.html#important-notes) and [there](https://docs.mattermost.com/deployment/on-boarding.html#do-not-manipulate-the-mattermost-database)
 
 
 ## Usage:
 
-docker run -d \
+```bash
+$ docker run -d \
     --name mattermost-cleaner \
     --env POSTGRES_HOST=mattermost-db \
     --env POSTGRES_PORT=5432 \
@@ -21,18 +20,20 @@ docker run -d \
     --net docker_default \
     --link mattermost-db:mattermost-db \
     registry.picasoft.net:5000/mattermost-cleaner:alpha
-
+```
 ## Parameters
 
-POSTGRES_HOST      the name of the container
-POSTGRES_PORT      the port number of the postgres database
-POSTGRES_USER      the username of the postgres database
-POSTGRES_PASS      the password of the postgres database
-POSTGRES_DB        the name of the postgres database
-CRON_TIME          the interval of cron job to run postgresdump. `0 * * * *` by default, which is every hour
+Here are the different parameters
+ - `POSTGRES_HOST`      the name of the container
+ - `POSTGRES_PORT`      the port number of the postgres database
+ - `POSTGRES_USER`      the username of the postgres database
+ - `POSTGRES_PASS`      the password of the postgres database
+ - `POSTGRES_DB`        the name of the postgres database
+ - `CRON_TIME`          the interval of cron job to run postgresdump. `0 * * * *` by default, which is every hour
 
 ## Docker-compose
 
+```yaml
 version: "2"
 services:
   mattermost-cleaner:
@@ -47,3 +48,4 @@ services:
       - POSTGRES_PASS=password
       - POSTGRES_DB=mattermost
       - MATTERMOST_TEAM=team
+```
diff --git a/mattermost-cleaner/cron.sh b/mattermost-cleaner/cron.sh
index 85dda8e0..0830d04b 100755
--- a/mattermost-cleaner/cron.sh
+++ b/mattermost-cleaner/cron.sh
@@ -1,4 +1,4 @@
-#!/bin/bash
+#!/usr/bin/env bash
 sh psqlcmd.sh
 echo "${CRON_TIME} /psqlcmd.sh" > /crontab.conf
 crontab  /crontab.conf
diff --git a/mattermost-cleaner/psqlcmd.sh b/mattermost-cleaner/psqlcmd.sh
index fa3014db..6cbf330c 100755
--- a/mattermost-cleaner/psqlcmd.sh
+++ b/mattermost-cleaner/psqlcmd.sh
@@ -1,4 +1,4 @@
-#!/bin/bash
+#!/usr/bin/env bash
 
 [ -z "${POSTGRES_HOST}" ] && { echo "=> POSTGRES_HOST cannot be empty" && exit 1; }
 [ -z "${POSTGRES_PORT}" ] && { echo "=> POSTGRES_PORT cannot be empty" && exit 1; }
diff --git a/minetest/README.md b/minetest/README.md
index 9a09176f..5af91de5 100644
--- a/minetest/README.md
+++ b/minetest/README.md
@@ -21,19 +21,18 @@ To set the log level of your container, you can use the `LOGLEVEL` environment v
 Default (and recommended) level is 1.
 
 ## Install Framinetest pack Framasoft
-```
-cd /tmp
-wget https://framinetest.org/dl/worldmods.tar.gz https://framinetest.org/dl/textures.tar.gz
+```bash
+$ cd /tmp
+$ wget https://framinetest.org/dl/worldmods.tar.gz https://framinetest.org/dl/textures.tar.gz
 
-cd /PATH/TO/DATA/VOLUME/textures
-tar xvf /tmp/textures.tar.gz
+$ cd /PATH/TO/DATA/VOLUME/textures
+$ tar xvf /tmp/textures.tar.gz
 
-cd /PATH/TO/DATA/VOLUME/worlds
-mkdir myworldname
-cd myworldname
-tar xvf /tmp/worldmods.tar.gz
+$ cd /PATH/TO/DATA/VOLUME/worlds
+$ mkdir myworldname
+$ cd myworldname
+$ tar xvf /tmp/worldmods.tar.gz
 ```
 
 ## TODO
-- Support other backend ? (PostgreSQL ? => https://wiki.minetest.net/Database_backends/fr )
-
+- Support other backend ? (For PostgreSQL see [this](https://wiki.minetest.net/Database_backends/fr) ?)
diff --git a/minetest/entrypoint.sh b/minetest/entrypoint.sh
index ccb98487..a1002440 100755
--- a/minetest/entrypoint.sh
+++ b/minetest/entrypoint.sh
@@ -1,4 +1,4 @@
-#!/bin/bash
+#!/usr/bin/env bash
 
 # Check if there is a configurtion file
 if [ ! -f /root/.minetest/minetest.conf ]
@@ -28,4 +28,3 @@ esac
 
 # Run the server
 /usr/games/minetestserver "$logoption" --gameid minetest --config /root/.minetest/minetest.conf
-
diff --git a/mysql-backup/README.md b/mysql-backup/README.md
index bf9e75f0..18f7a744 100644
--- a/mysql-backup/README.md
+++ b/mysql-backup/README.md
@@ -4,13 +4,15 @@ This image runs mysqldump to backup data using cronjob to folder `/backup`
 
 ## Usage:
 
-    docker run -d \
-        --env MYSQL_HOST=mysql.host \
-        --env MYSQL_PORT=27017 \
-        --env MYSQL_USER=admin \
-        --env MYSQL_PASS=password \
-        --volume host.folder:/backup
-        tutum/mysql-backup
+```bash
+docker run -d \
+    --env MYSQL_HOST=mysql.host \
+    --env MYSQL_PORT=27017 \
+    --env MYSQL_USER=admin \
+    --env MYSQL_PASS=password \
+    --volume host.folder:/backup
+    tutum/mysql-backup
+```
 
 Moreover, if you link `tutum/mysql-backup` to a mysql container(e.g. `tutum/mysql`) with an alias named mysql, this image will try to auto load the `host`, `port`, `user`, `pass` if possible.
 
@@ -19,23 +21,26 @@ Moreover, if you link `tutum/mysql-backup` to a mysql container(e.g. `tutum/mysq
 
 ## Parameters
 
-    MYSQL_HOST      the host/ip of your mysql database
-    MYSQL_PORT      the port number of your mysql database
-    MYSQL_USER      the username of your mysql database
-    MYSQL_PASS      the password of your mysql database
-    MYSQL_DB        the database name to dump. Default: `--all-databases`
-    EXTRA_OPTS      the extra options to pass to mysqldump command
-    CRON_TIME       the interval of cron job to run mysqldump. `0 0 * * *` by default, which is every day at 00:00
-    MAX_BACKUPS     the number of backups to keep. When reaching the limit, the old backup will be discarded. No limit by default
-    INIT_BACKUP     if set, create a backup when the container starts
-    INIT_RESTORE_LATEST if set, restores latest backup
+Here are the parameters usable:
+    - `MYSQL_HOST` the host/ip of your mysql database
+    - `MYSQL_PORT` the port number of your mysql database
+    - `MYSQL_USER` the username of your mysql database
+    - `MYSQL_PASS` the password of your mysql database
+    - `MYSQL_DB`  the database name to dump. Default: `--all-databases`
+    - `EXTRA_OPTS` the extra options to pass to mysqldump command
+    - `CRON_TIME` the interval of cron job to run mysqldump. `0 0 * * *` by default, which is every day at 00:00
+    - `MAX_BACKUPS` the number of backups to keep. When reaching the limit, the old backup will be discarded. No limit by default
+    - `INIT_BACKUP` if set, create a backup when the container starts
+    - `INIT_RESTORE_LATEST` if set, restores latest backup
 
 ## Restore from a backup
 
 See the list of backups, you can run:
-
-    docker exec tutum-backup ls /backup
+```bash
+docker exec tutum-backup ls /backup
+```
 
 To restore database from a certain backup, simply run:
-
-    docker exec tutum-backup /restore.sh /backup/2015.08.06.171901
+```bash
+docker exec tutum-backup /restore.sh /backup/2015.08.06.171901
+```
diff --git a/pica-apache/run.sh b/pica-apache/run.sh
index d0d447f6..64f96a3a 100644
--- a/pica-apache/run.sh
+++ b/pica-apache/run.sh
@@ -1,4 +1,4 @@
-#!/bin/bash
+#!/usr/bin/env bash
 chown www-data:www-data /app -R
 
 if [ "$ALLOW_OVERRIDE" = "**False**" ]; then
diff --git a/pica-dokuwiki/run.sh b/pica-dokuwiki/run.sh
index 5433076a..288ea6c9 100755
--- a/pica-dokuwiki/run.sh
+++ b/pica-dokuwiki/run.sh
@@ -1,4 +1,4 @@
-#!/bin/bash
+#!/usr/bin/env bash
 
 # EXPLAINING THE SCRIPT run.sh
 # This is a poor man's supervisord. The only thing this script does is watching its forked (background) processes and as soon as one dies, it terminates all the others and exits with the code of the first dying process.
diff --git a/pica-etherpad/entrypoint.sh b/pica-etherpad/entrypoint.sh
index 6d440b5c..a3ca9967 100644
--- a/pica-etherpad/entrypoint.sh
+++ b/pica-etherpad/entrypoint.sh
@@ -1,4 +1,4 @@
-#!/bin/bash
+#!/usr/bin/env bash
 set -e
 
 if [ -z "$MYSQL_PORT_3306_TCP_ADDR" ]; then
diff --git a/pica-nginx/start.sh b/pica-nginx/start.sh
index 45b1bfc1..8b930f80 100755
--- a/pica-nginx/start.sh
+++ b/pica-nginx/start.sh
@@ -1,4 +1,4 @@
-#!/bin/sh
+#!/usr/bin/env sh
 
 set -e
 
diff --git a/postgres-backup/README.md b/postgres-backup/README.md
index ae7e4536..851ef159 100644
--- a/postgres-backup/README.md
+++ b/postgres-backup/README.md
@@ -3,33 +3,37 @@
 This image runs postgresdump to backup data using cronjob to folder `/backup`
 
 ## Usage:
-
-    docker run -d \
-        --env POSTGRES_HOST=postgres.host \
-        --env POSTGRES_PORT=27017 \
-        --env POSTGRES_USER=admin \
-        --env POSTGRES_PASS=password \
-        --volume host.folder:/backup
-        tutum/postgres-backup
-
+```bash
+docker run -d \
+    --env POSTGRES_HOST=postgres.host \
+    --env POSTGRES_PORT=27017 \
+    --env POSTGRES_USER=admin \
+    --env POSTGRES_PASS=password \
+    --volume host.folder:/backup
+    tutum/postgres-backup
+```
 ## Parameters
 
-    POSTGRES_HOST      the host/ip of your postgres database
-    POSTGRES_PORT      the port number of your postgres database
-    POSTGRES_USER      the username of your postgres database
-    POSTGRES_PASS      the password of your postgres database
-    CRON_TIME       the interval of cron job to run postgresdump. `0 0 * * *` by default, which is every day at 00:00
-    POSTGRES_DB     the DB to backup
-    MAX_BACKUPS     the number of backups to keep. When reaching the limit, the old backup will be discarded. No limit by default
-    INIT_BACKUP     if set, create a backup when the container starts
-    INIT_RESTORE_LATEST if set, restores latest backup
+Here are the parameters:
+ - `POSTGRES_HOST` the host/ip of your postgres database
+ - `POSTGRES_PORT` the port number of your postgres database
+ - `POSTGRES_USER` the username of your postgres database
+ - `POSTGRES_PASS` the password of your postgres database
+ - `CRON_TIME`  the interval of cron job to run postgresdump. `0 0 * * *` by default, which is every day at 00:00
+ - `POSTGRES_DB` the DB to backup
+ - `MAX_BACKUPS` the number of backups to keep. When reaching the limit, the old backup will be discarded. No limit by default
+ - `INIT_BACKUP` if set, create a backup when the container starts
+ - `INIT_RESTORE_LATEST` if set, restores latest backup
 
 ## Restore from a backup
 
 See the list of backups, you can run:
 
-    docker exec postgres-backup ls /backup
+```bash
+$ docker exec postgres-backup ls /backup
+```
 
 To restore database from a certain backup, simply run:
-
-    docker exec tutum-backup /restore.sh /backup/2015.08.06.171901
+```bash
+$ docker exec tutum-backup /restore.sh /backup/2015.08.06.171901
+```
diff --git a/postgres-backup/run.sh b/postgres-backup/run.sh
index 2fe57848..0cfde05d 100755
--- a/postgres-backup/run.sh
+++ b/postgres-backup/run.sh
@@ -1,4 +1,4 @@
-#!/bin/bash
+#!/usr/bin/env bash
 
 [ -z "${POSTGRES_HOST}" ] && { echo "=> POSTGRES_HOST cannot be empty" && exit 1; }
 [ -z "${POSTGRES_PORT}" ] && { echo "=> POSTGRES_PORT cannot be empty" && exit 1; }
-- 
GitLab