2014-12-09 21:00:17 +01:00
#!/bin/bash
2017-03-19 18:28:38 +01:00
#=================================================
# GENERIC STARTING
#=================================================
# IMPORT GENERIC HELPERS
#=================================================
2016-11-30 17:45:05 +01:00
2017-03-19 22:50:12 +01:00
source _common.sh
2017-03-19 18:28:38 +01:00
source /usr/share/yunohost/helpers
2017-09-05 00:20:40 +02:00
# Load common variables for all scripts.
source _variables
2017-03-19 18:28:38 +01:00
#=================================================
# MANAGE FAILURE OF THE SCRIPT
#=================================================
ynh_clean_setup () {
2016-11-30 17:45:05 +01:00
# Nettoyage des résidus d'installation non pris en charge par le script remove.
2016-11-30 17:52:00 +01:00
if test -n "$PID_TAIL"
then
2017-03-19 18:28:38 +01:00
SUPPRESS_WARNING kill -s 15 $PID_TAIL # Arrête l'exécution de tail.
2017-09-05 00:20:40 +02:00
SUPPRESS_WARNING kill -s 15 $pid_change_port # Arrête l'exécution de change_port
2017-05-15 14:34:58 +02:00
ynh_secure_remove "$tempfile"
2016-11-30 17:52:00 +01:00
fi
2016-11-30 17:52:46 +01:00
# Clean hosts
2017-09-05 00:20:40 +02:00
sed -i '/#jenkins/d' /etc/hosts
2016-11-30 17:52:46 +01:00
2016-11-30 17:45:05 +01:00
echo ""
}
2017-03-19 18:28:38 +01:00
ynh_abort_if_errors # Active trap pour arrêter le script si une erreur est détectée.
#=================================================
# RETRIEVE ARGUMENTS FROM THE MANIFEST
#=================================================
2016-11-30 17:45:05 +01:00
domain=$YNH_APP_ARG_DOMAIN
2017-03-19 18:28:38 +01:00
path_url=$YNH_APP_ARG_PATH
2016-11-30 17:45:05 +01:00
is_public=$YNH_APP_ARG_IS_PUBLIC
app=$YNH_APP_INSTANCE_NAME
2017-03-19 18:28:38 +01:00
#=================================================
# CHECK IF THE APP CAN BE INSTALLED WITH THIS ARGS
#=================================================
2016-11-30 17:45:05 +01:00
final_path=/var/lib/$app
2017-09-05 00:20:40 +02:00
test ! -e "$final_path" || ynh_die "This path already contains a folder"
# Normalize the url path syntax
path_url=$(ynh_normalize_url_path $path_url)
# Check web path availability
ynh_webpath_available $domain $path_url
# Register (book) web path
ynh_webpath_register $app $domain $path_url
2014-12-09 21:00:17 +01:00
2017-03-19 18:28:38 +01:00
#=================================================
# STORE SETTINGS FROM MANIFEST
#=================================================
2016-11-30 17:45:05 +01:00
2016-11-30 17:55:46 +01:00
ynh_app_setting_set $app domain $domain
2017-03-19 18:28:38 +01:00
ynh_app_setting_set $app path $path_url
2016-11-30 17:55:46 +01:00
ynh_app_setting_set $app is_public $is_public
ynh_app_setting_set $app final_path $final_path
2016-11-30 17:45:05 +01:00
2017-03-19 18:28:38 +01:00
#=================================================
# STANDARD MODIFICATIONS
#=================================================
# FIND AND OPEN A PORT
#=================================================
port=$(ynh_find_port 8080) # Cherche un port libre.
ynh_app_setting_set $app port $port
#=================================================
# INSTALL DEPENDENCIES
#=================================================
2016-11-30 17:45:05 +01:00
2017-09-05 00:20:40 +02:00
ynh_install_app_dependencies $app_depencencies
2017-03-19 18:28:38 +01:00
#=================================================
# NGINX CONFIGURATION
#=================================================
2017-09-05 00:20:40 +02:00
ynh_add_nginx_config
2017-03-19 18:28:38 +01:00
#=================================================
# SPECIFIC SETUP
2017-05-15 14:34:58 +02:00
#=================================================
# FIX THE PORT TO USE
#=================================================
change_port() {
# Wait for the creation of the jenkins service file
while [ ! -e /etc/default/jenkins ]
do
sleep 0.5
done
# And modify the port as soon as possible, to prevent a crach of jenkins if the default port is already used.
ynh_replace_string "^HTTP_PORT=.*" "HTTP_PORT=$port" /etc/default/jenkins
}
change_port &
2017-09-05 00:20:40 +02:00
pid_change_port=$!
2017-05-15 14:34:58 +02:00
#=================================================
# INSTALL JENKINS
#=================================================
2017-09-05 00:20:40 +02:00
wget --no-verbose https://pkg.jenkins.io/debian-stable/binary/jenkins_${version}_all.deb
dpkg --install jenkins_${version}_all.deb
2017-05-15 14:34:58 +02:00
2017-03-19 18:28:38 +01:00
#=================================================
# SETUP JENKINS
#=================================================
2014-12-16 08:14:48 +01:00
2016-11-30 17:45:05 +01:00
# Ignore le Setup Wizard
2017-05-15 14:34:58 +02:00
ynh_replace_string "-Djava.awt.headless=true" "& -Djenkins.install.runSetupWizard=false" /etc/default/jenkins
2016-11-30 17:43:02 +01:00
2017-03-19 18:28:38 +01:00
if [ "$path_url" != "/" ];
2016-11-30 17:45:05 +01:00
then # Ajoute le path en cas d'installation en sous-dossier dans les options de démarrage de Jenkins
2017-09-05 00:20:40 +02:00
sed -i "$ s@--httpPort=\$HTTP_PORT@& --prefix=$path_url@g" /etc/default/jenkins
2014-12-16 08:14:48 +01:00
fi
2017-03-19 18:28:38 +01:00
#=================================================
# START JENKINS IN BACKGROUND
#=================================================
2017-09-05 00:20:40 +02:00
systemctl restart $app # Redémarre jenkins pour prendre en compte les modifications
2016-11-30 17:41:41 +01:00
tempfile="$(mktemp)"
tail -f -n1 /var/log/$app/$app.log > "$tempfile" & # Suit le démarrage dans le log
PID_TAIL=$! # Récupère le PID de la commande tail, qui est passée en arrière plan.
2014-12-09 21:00:17 +01:00
2017-03-19 18:28:38 +01:00
#=================================================
# FORCE PUBLIC ACCESS
#=================================================
2016-11-30 17:41:41 +01:00
2016-11-30 17:45:05 +01:00
# Jenkins est public par défaut, au moins pour le téléchargement de jenkins-cli.jar
2016-11-30 17:55:46 +01:00
ynh_app_setting_set $app unprotected_uris "/"
2014-12-16 00:14:01 +01:00
2017-09-05 00:20:40 +02:00
systemctl reload nginx
yunohost app ssowatconf
2016-11-30 17:41:41 +01:00
2017-03-19 18:28:38 +01:00
#=================================================
# ENABLE SERVICE IN ADMIN PANEL
#=================================================
2017-09-05 00:20:40 +02:00
yunohost service add $app --log /var/log/$app/$app.log
2017-03-19 18:28:38 +01:00
#=================================================
# CHECK JENKINS STARTING
#=================================================
2016-11-30 17:45:05 +01:00
2016-11-30 17:41:41 +01:00
config_OK=0
2016-12-18 22:44:04 +01:00
timeout=3600
2017-09-05 00:20:40 +02:00
echo "127.0.0.1 $domain #jenkins" | tee -a /etc/hosts # Renseigne le domain dans le host, pour prévenir d'un dns pas encore propagé.
2017-05-15 14:34:58 +02:00
jenkins_cli="java -jar /var/lib/jenkins/jenkins-cli.jar -remoting -s http://$domain$path_url"
2016-12-18 22:44:04 +01:00
for i in `seq 1 $timeout`
do # La boucle attend le démarrage de jenkins Ou $timeout (Le démarrage sur arm est trèèèèèèèèès long...).
if grep -q "Jenkins is fully up and running" "$tempfile" && [ "$config_OK" -eq 0 ]; then
2016-12-22 11:07:07 +01:00
# Si le log annonce une première fois le démarrage de jenkins. Installe les plugins
2017-09-05 00:20:40 +02:00
wget -nv --no-check-certificate https://$domain$path_url/jnlpJars/jenkins-cli.jar -O /var/lib/jenkins/jenkins-cli.jar
2017-03-19 18:28:38 +01:00
WARNING echo ""
2016-12-18 22:44:04 +01:00
for i in `seq 1 $timeout`
2016-12-22 11:07:07 +01:00
do # La boucle attend la mise à jour des dépôts de plugins.
2016-11-30 17:41:41 +01:00
if test -e /var/lib/jenkins/updates/default.json; then
break;
else
2017-03-19 18:28:38 +01:00
WARNING echo -n "."
2016-11-30 17:41:41 +01:00
sleep 1
fi
done
2016-11-30 17:52:00 +01:00
2016-12-01 17:43:29 +01:00
# Installation du plugin pour l'authentification ldap et http auth
2017-05-15 14:34:58 +02:00
$jenkins_cli install-plugin reverse-proxy-auth-plugin
2016-11-30 17:41:41 +01:00
2016-11-30 17:49:37 +01:00
# Installation des plugins recommandés (Lors de l'install avec le Setup Wizard)
2017-05-15 14:34:58 +02:00
$jenkins_cli install-plugin cloudbees-folder # Folders Plugin
$jenkins_cli install-plugin antisamy-markup-formatter # OWASP Markup Formatter Plugin
$jenkins_cli install-plugin pam-auth # PAM Authentication plugin
$jenkins_cli install-plugin mailer # Mailer Plugin
$jenkins_cli install-plugin ldap # LDAP Plugin
$jenkins_cli install-plugin matrix-auth # Matrix Authorization Strategy Plugin
$jenkins_cli install-plugin build-timeout # Build timeout plugin
$jenkins_cli install-plugin credentials-binding # Credentials Binding Plugin
$jenkins_cli install-plugin timestamper # Timestamper
$jenkins_cli install-plugin ws-cleanup # Workspace Cleanup Plugin
$jenkins_cli install-plugin ant # Ant Plugin
$jenkins_cli install-plugin gradle # Gradle Plugin
$jenkins_cli install-plugin workflow-aggregator # Pipeline
$jenkins_cli install-plugin pipeline-stage-view # Pipeline: Stage View Plugin
$jenkins_cli install-plugin git # Git plugin
$jenkins_cli install-plugin github-organization-folder # GitHub Organization Folder Plugin
$jenkins_cli install-plugin subversion # Subversion Plug-in
$jenkins_cli install-plugin email-ext # Email Extension Plugin
$jenkins_cli install-plugin ssh-slaves # SSH Slaves plugin
2016-11-30 17:49:37 +01:00
2016-12-01 17:43:29 +01:00
# Installation de plugins supplémentaires pour le confort
2017-05-15 14:34:58 +02:00
$jenkins_cli install-plugin ansicolor # Prise en charge des couleurs pour la sortie console. Améliore la lisibilité de la console (par contre les couleurs ne passent pas...)
$jenkins_cli install-plugin fstrigger # Monitoring sur le système de fichier local. Pour surveiller des dossiers de code et builder sur les changements.
2016-12-01 17:43:29 +01:00
2016-11-30 17:45:05 +01:00
# Configure la sécurité globale avec ldap par défaut.
2017-09-05 00:20:40 +02:00
cp ../conf/config.xml /var/lib/jenkins/
chown jenkins: /var/lib/jenkins/config.xml
2016-11-30 17:41:41 +01:00
2017-09-05 00:20:40 +02:00
systemctl restart $app # Puis redémarre à nouveau le service.
2016-11-30 17:41:41 +01:00
cat /dev/null > "$tempfile" # Purge le log de suivi du démarrage.
2017-03-19 18:28:38 +01:00
config_OK=1
2016-11-30 17:41:41 +01:00
i=1;
fi
2016-12-18 22:44:04 +01:00
if grep -q "Jenkins is fully up and running" "$tempfile" && [ "$config_OK" -eq 1 ]; then
2017-03-19 18:28:38 +01:00
WARNING echo "Le service $app a démarré correctement."
2016-11-30 17:45:05 +01:00
break # Si le log annonce une deuxième fois le démarrage de jenkins, sort de la boucle.
2016-11-30 17:41:41 +01:00
fi
2017-03-19 18:28:38 +01:00
WARNING echo -n "."
2016-11-30 17:41:41 +01:00
sleep 1
done
2017-03-19 18:28:38 +01:00
SUPPRESS_WARNING kill -s 15 $PID_TAIL # Arrête l'exécution de tail.
2017-05-15 14:34:58 +02:00
ynh_secure_remove "$tempfile"
2016-12-18 22:44:04 +01:00
if [ "$i" -ge $timeout ]; then
2017-03-19 18:28:38 +01:00
ynh_die "\nLe service $app n'a pas démarré dans le temps imparti."
2016-12-17 19:52:21 +01:00
fi
2016-11-30 17:45:05 +01:00
2017-03-19 18:28:38 +01:00
#=================================================
# SETUP SSOWAT
#=================================================
2016-11-30 17:45:05 +01:00
# Si Jenkins est privé, retire l'autorisation publique.
2017-03-19 18:28:38 +01:00
if [ $is_public -eq 0 ]
2016-11-30 17:45:05 +01:00
then # Retire l'accès public
2016-11-30 17:55:46 +01:00
ynh_app_setting_delete $app unprotected_uris
2016-12-01 17:43:29 +01:00
ynh_app_setting_set $app skipped_uris "/github-webhook" # /path/github-webhook doit rester accessible pour les webhooks de github.
2016-11-30 17:45:05 +01:00
fi
2016-11-30 17:52:46 +01:00
2017-03-19 18:28:38 +01:00
#=================================================
# CLEAN HOSTS FILE
#=================================================
2017-09-05 00:20:40 +02:00
sed -i '/#jenkins/d' /etc/hosts