parent
025fc33438
commit
908ddf8c6e
@ -1,37 +1,48 @@
|
|||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
echo "Repository name: "$DRONE_REPO_NAME
|
echo "Repository name : $DRONE_REPO_NAME"
|
||||||
echo "Repository owner: "$DRONE_REPO_OWNER
|
echo "Repository owner: $DRONE_REPO_OWNER"
|
||||||
|
|
||||||
echo "Generating and deploying documentation for user $DRONE_REPO_OWNER and repository $DRONE_REPO_NAME"
|
echo "Generating and deploying documentation for user $DRONE_REPO_OWNER and repository $DRONE_REPO_NAME"
|
||||||
|
|
||||||
mkdir -p /docs/doxygen/
|
|
||||||
mkdir -p /docs/docusaurus/
|
|
||||||
|
|
||||||
DOCDIR="Documentation"
|
DOCDIR="Documentation"
|
||||||
[ -d "/drone/src/documentation" ] && DOCDIR="documentation"
|
while [ "$1" ]; do
|
||||||
|
case "$1" in
|
||||||
[ -d "/drone/src/$DOCDIR/doxygen" ] && cd /drone/src/$DOCDIR/doxygen && doxygen Doxyfile
|
"-d" | "--dir")
|
||||||
[ -d "/drone/src/$DOCDIR/docusaurus" ] && cd /drone/src/$DOCDIR/docusaurus && npm install && npm run build
|
DOCDIR="$2"
|
||||||
|
shift 1
|
||||||
swaggerfile=$(find /docs -maxdepth 1 -type f -iname "swagger.*" -printf "%f" -quit)
|
;;
|
||||||
if [[ ! -z "$swaggerfile" ]]
|
"-t" | "--type")
|
||||||
then
|
GENERATOR_NAME="$2"
|
||||||
echo "<!DOCTYPE html>
|
GENERATOR_SCRIPT="generators/$GENERATOR_NAME.sh"
|
||||||
<html>
|
if [ ! -f "$GENERATOR_SCRIPT" ]; then
|
||||||
<head>
|
echo "type de documentation inconnue, veuillez entrer un générateur valide" >&2
|
||||||
<meta http-equiv="Refresh" content=\"0; url=/swagger?url=/documentation/$DRONE_REPO_OWNER/swagger/$DRONE_REPO_NAME/$swaggerfile\" />
|
exit 1
|
||||||
</head>
|
fi
|
||||||
<body>
|
shift 1
|
||||||
<p>Suivez <a href=\"/swagger?url=/swagger?url=/documentation/$DRONE_REPO_OWNER/swagger/$DRONE_REPO_NAME/$swaggerfile\">ce lien</a>.</p>
|
;;
|
||||||
</body>
|
*)
|
||||||
</html>" > /docs/CLICKME.html
|
echo "option inconnue $1" >&2
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
shift
|
||||||
|
done
|
||||||
|
|
||||||
|
if [ ! "$GENERATOR_SCRIPT" ]; then
|
||||||
|
echo "option -t <type> obligatoire" >&2
|
||||||
fi
|
fi
|
||||||
|
|
||||||
cd /drone/src/$DOCDIR
|
. "$GENERATOR_SCRIPT"
|
||||||
|
|
||||||
|
generate "$DOCDIR" # génère la doc avec le bon générateur
|
||||||
|
|
||||||
[ -d "/drone/src/$DOCDIR/doxygen" ] && rsync --rsync-path="mkdir -p /usr/share/nginx/html/$DRONE_REPO_OWNER/doxygen/$DRONE_REPO_NAME/ && rsync" -e "ssh -o StrictHostKeyChecking=no" -avz --delete /docs/doxygen/ root@nginx:/usr/share/nginx/html/$DRONE_REPO_OWNER/doxygen/$DRONE_REPO_NAME/
|
SERVER_TARGET="/usr/share/nginx/html/$DRONE_REPO_OWNER/$GENERATOR_NAME/$DRONE_REPO_NAME/"
|
||||||
[ -d "/docs/CLICKME.html" ] && rsync --rsync-path="mkdir -p /usr/share/nginx/html/$DRONE_REPO_OWNER/swagger/$DRONE_REPO_NAME/ && rsync" -e "ssh -o StrictHostKeyChecking=no" -avz --delete /docs/{swagger.*,CLICKME.html} root@nginx:/usr/share/nginx/html/$DRONE_REPO_OWNER/swagger/$DRONE_REPO_NAME/
|
|
||||||
[ -d "/drone/src/$DOCDIR/docusaurus" ] && rsync --rsync-path="mkdir -p /usr/share/nginx/html/$DRONE_REPO_OWNER/docusaurus/$DRONE_REPO_NAME/ && rsync" -e "ssh -o StrictHostKeyChecking=no" -avz --delete docusaurus/build/ root@nginx:/usr/share/nginx/html/$DRONE_REPO_OWNER/docusaurus/$DRONE_REPO_NAME/
|
|
||||||
|
|
||||||
exit 0
|
# lance rsync en mode archive, verbeux et compression
|
||||||
|
# créee le dossier cible ($SERVER_TARGET)
|
||||||
|
# puis envoie les fichiers générés par le générateur dans le dossier cible en supprimant les elements qui ne sont pas dans le dossier généré
|
||||||
|
rsync -avz \
|
||||||
|
--rsync-path="mkdir -p $SERVER_TARGET" \
|
||||||
|
-e "ssh -o StrictHostKeyChecking=no" \
|
||||||
|
--delete "$GEN_PATH" root@nginx:$SERVER_TARGET
|
||||||
|
@ -0,0 +1,8 @@
|
|||||||
|
GEN_PATH="/docs/docusaurus"
|
||||||
|
|
||||||
|
generate() {
|
||||||
|
mkdir -p /docs/docusaurus/
|
||||||
|
(cd /drone/src/"$1"/docusaurus && npm install && npm run build)
|
||||||
|
|
||||||
|
mv build/* $GEN_PATH
|
||||||
|
}
|
@ -0,0 +1,12 @@
|
|||||||
|
GEN_PATH="/docs/doxygen"
|
||||||
|
|
||||||
|
generate() {
|
||||||
|
mkdir -p /docs/doxygen/
|
||||||
|
if [ ! -f "$1"/Doxyfile ]; then
|
||||||
|
echo "erreure generateur doxygen : Le fichier $1/Doxyfile est manquant" >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
cd doxygen && doxygen "$1"/Doxyfile
|
||||||
|
mv html/* $GEN_PATH
|
||||||
|
}
|
@ -0,0 +1,20 @@
|
|||||||
|
GEN_PATH="/docs/swagger"
|
||||||
|
|
||||||
|
generate() {
|
||||||
|
SWAGGER_FILE=$(find DOCDIR -maxdepth 1 -type f -iname "swagger.*" -printf "%f" -quit)
|
||||||
|
if [[ ! "$SWAGGER_FILE" ]]; then
|
||||||
|
echo "fichier de configuration ($1/swagger.*) introuvable" >&2
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "<!DOCTYPE html>
|
||||||
|
<html>
|
||||||
|
<head>
|
||||||
|
<meta http-equiv=\"Refresh\" content=\"0; url=/swagger?url=/documentation/$DRONE_REPO_OWNER/swagger/$DRONE_REPO_NAME/$SWAGGER_FILE\" />
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<p>Suivez <a href=\"/swagger?url=/swagger?url=/documentation/$DRONE_REPO_OWNER/swagger/$DRONE_REPO_NAME/$SWAGGER_FILE\">ce lien</a>.</p>
|
||||||
|
</body>
|
||||||
|
</html>" > $GEN_PATH/CLICKME.html
|
||||||
|
|
||||||
|
mv "$SWAGGER_FILE" $GEN_PATH
|
||||||
|
}
|
Loading…
Reference in new issue