Il quelques petites choses à connaître si vous voulez packager une application pour Yunohost.
Un paquet YunoHost ressemble à ça, et est composé de :
- un fichier JSON
manifest.json
- un répertoire
scripts
, qui contient les scriptsinstall
,remove
etupgrade
- d'autres répertoires optionnels, comme
sources
ouconf
si tu en a besoin
Le fichier manifest.json
défini les constantes de l'application, un ensemble de valeurs dont YunoHost a besoin pour identifier l'application et l'installer correctement. Ça ressemble à ça :
{
"name": "Roundcube",
"id": "roundcube",
"description": {
"en": "Open Source Webmail software",
"fr": "Webmail Open Source"
},
"developer": {
"name": "kload",
"email": "[email protected]",
"url": "http://kload.fr"
},
"multi_instance": "true",
"arguments": {
"install" : [
{
"name": "domain",
"ask": {
"en": "Choose a domain for Roundcube"
},
"example": "domain.org"
},
{
"name": "path",
"ask": {
"en": "Choose a path for Roundcube"
},
"example": "/webmail",
"default": "/webmail"
}
]
}
}
-
name : Le nom de l'application. Il n'a pas besoin d'être unique, mais c'est conseillé puisque c'est le nom qui apparaît dans la liste des applications pour tous les administrateurs de serveurs YunoHost.
-
id : L’identifiant unique de l'application. Vous devez vous assurer qu'il est unique avant de soumettre une demande d'intégration de l'application.
-
description : La description complète de l'application. Vous pouvez la détailler comme bon vous semble. Seulement
en
(English) est requis, mais vous pouvez la traduire enfr
:) -
developer : Quelques informations à propos du mainteneur de l'application.
-
multi_instance : Défini la possibilité de votre application a être installée plusieurs fois. Quand YunoHost essaie d'installer une seconde fois votre application, il remplaçera
id
dans votre scripts par unid__2
. Cela signifie que si voulez êtremulti_instance
, vous devez mettre toutes les valeurs identifiantes dans les scripts.
Par exemple: Dans mon script roundcube, je dois nommer ma base de donnéeroundcube
, mon répertoire d'installationroundcube
et ma configuration Nginxroundcube
. De cette manière, la seconde installation de roundcube ne rentrera pas en conflit, et sera installée dans la base de donnéeroundcube__2
, dans le répertoireroundcube__2
, et avec la configuration Nginxroundcube__2
. -
arguments : Les paramètres à demander aux administrateurs du serveur lors de l'installation.
name
est l'identifiant du paramètre, etask
la question à poser (au minimum en Anglais --en
) que vous pouvez traduire de la même manière que la description ci-dessus. Vous pouvez aussi proposer une valeur par défaut (default
) et un exemple (example
) pour aider l'administrateur à remplir le formulaire d’installation.
Pour le moment, un paquet YunoHost doit contenir trois scripts bash : install
, remove
, et upgrade
.
Ces scripts seront exécutés en tant qu'admin
sur les serveurs YunoHost.
Voici un exemple de script d'install
:
# Retrieve arguments
domain=$1
path=$2
# Check domain/path availability
sudo yunohost app checkurl $domain$path -a roundcube
if [[ ! $? -eq 0 ]]; then
exit 1
fi
# Generate random DES key & password
deskey=$(dd if=/dev/urandom bs=1 count=200 2> /dev/null | tr -c -d '[A-Za-z0-9]' | sed -n 's/\(.\{24\}\).*/\1/p')
db_pwd=$(dd if=/dev/urandom bs=1 count=200 2> /dev/null | tr -c -d '[A-Za-z0-9]' | sed -n 's/\(.\{24\}\).*/\1/p')
# Use 'roundcube' as database name and user
db_user=roundcube
# Initialize database and store mysql password for upgrade
sudo yunohost app initdb $db_user -p $db_pwd -s $(readlink -e ../sources/SQL/mysql.initial.sql)
sudo yunohost app setting roundcube mysqlpwd -v $db_pwd
# Copy files to the right place
final_path=/var/www/roundcube
sudo mkdir -p $final_path
sudo cp -a ../sources/* $final_path
sudo cp ../conf/main.inc.php $final_path/config/
sudo cp ../conf/db.inc.php $final_path/config/
sudo mv $final_path/plugins/managesieve/config.inc.php.dist $final_path/plugins/managesieve/config.inc.php
# Change variables in Roundcube configuration
sudo sed -i "s/rcmail-ynhDESkeyTOchange/$deskey/g" $final_path/config/main.inc.php
sudo sed -i "s/yunouser/$db_user/g" $final_path/config/db.inc.php
sudo sed -i "s/yunopass/$db_pwd/g" $final_path/config/db.inc.php
sudo sed -i "s/yunobase/$db_user/g" $final_path/config/db.inc.php
# Set permissions to roundcube directory
sudo chown -R www-data: $final_path
# Modify Nginx configuration file and copy it to Nginx conf directory
sed -i "s@PATHTOCHANGE@$path@g" ../conf/nginx.conf
sed -i "s@ALIASTOCHANGE@$final_path/@g" ../conf/nginx.conf
sudo cp ../conf/nginx.conf /etc/nginx/conf.d/$domain.d/roundcube.conf
# Reload Nginx and regenerate SSOwat conf
sudo service nginx reload
sudo yunohost app ssowatconf
Vous devez tout mettre dans le script pour que votre application soit entièrement installée. Cela signifie que vous devez installer les dépendances, créer les répertoires requis, initialiser les bases de donnés nécessaires, copier les sources et configurer tout dans l'unique script install
(et bien sûr faire la procédure inverse dans le script remove
).
Attention : Pour des raisons de sécurité, le script est exécuté en tant qu'admin dans YunoHost. Assurez-vous de l'essayer en tant qu'admin et de préfixer sudo
aux commandes requises.
Comme les instances de YunoHost possèdent une architecture unifié, vous serez capable de deviner la plupart des réglages nécessaires. Mais si vous avez besoin de réglages spécifiques, comme le nom de domaine ou un chemin web pour configurer l’application, vous devrez demander aux administrateurs lors de l'installation (voir la section arguments
dans manifeste ci-dessus).
Remarque : Les arguments seront passés au script dans l'ordre du manifeste. Par exemple pour roundcube, l'argument domain
sera passé en tant que $1
dans le script, et path
en tant que $2
.
La CLI moulinette fournit quelques outils pour rendre le packaging plus facile :
sudo yunohost app checkport <port>
Cette commande vérifie le port et retourne une erreur si le port déjà utilisé.
sudo yunohost app setting <id> <key> [ -v <value> ]
C'est la commande la plus importante. Elle vous permet de stocker des réglages d'un application spécifique, afin de les réutiliser plus tard ou pour que YunoHost puisse se configurer automatiquement (par exemple pour le SSO).
La commande défini la valeur si vous ajoutez ```-v ```, sinon la récupère.
sudo yunohost app checkurl <domain><path> -a <id>
Cette commande est utile pour les applications Web et vous permet d'être sûr que le chemin n'est pas utilisé par une autre application. Si non, elle « réserve » le chemin.
**Remarque** : Ne pas préfixer par `http://` ou par `https://` dans le ``.
sudo yunohost app initdb <db_user> [ -p <db_pwd> ] [ -s <SQL_file> ]
Cette commande crée une base de donnée MySQL. Si vous ne définissez pas de mot de passe avec `-p`, la commande en génère un et le retourne. Si vous ajoutez un fichier SQL avec `-s`, la commande initialise la base de donnée avec les commandes SQL du fichier.
sudo yunohost app ssowatconf
Cette commande régénère la configuration du SSO. Vous devez l'appeler à la fin des scripts lorsque vous packagez une application Web.
Afin d'essayer votre packaging d'application, vous pouvez exécuter votre script en tant qu'admin
(n'oubliez pas d'ajouter les arguments requis) :
su - admin -c "/bin/bash /path/to/my/script my_arg1 my_arg2"
Ou vous pouvez utiliser la moulinette :
yunohost app install /path/to/my/app/package
Remarque : ça fonctionne aussi avec une URL Git :
yunohost app install https://github.com/author/my_app_package.git