mirror of
https://github.com/alexbelgium/hassio-addons.git
synced 2026-06-01 13:24:04 +02:00
Added verbose mode
This commit is contained in:
@@ -7,6 +7,7 @@ bashio::log.info "... github authentification"
|
|||||||
GITUSER=$(bashio::config 'gituser')
|
GITUSER=$(bashio::config 'gituser')
|
||||||
GITPASS=$(bashio::config 'gitpass')
|
GITPASS=$(bashio::config 'gitpass')
|
||||||
GITMAIL=$(bashio::config 'gitmail')
|
GITMAIL=$(bashio::config 'gitmail')
|
||||||
|
VERBOSE=$(bashio::config 'verbose')
|
||||||
git config --system http.sslVerify false
|
git config --system http.sslVerify false
|
||||||
git config --system credential.helper 'cache --timeout 7200'
|
git config --system credential.helper 'cache --timeout 7200'
|
||||||
git config --system user.name ${GITUSER}
|
git config --system user.name ${GITUSER}
|
||||||
@@ -14,7 +15,9 @@ git config --system user.password ${GITPASS}
|
|||||||
git config --system user.email ${GITMAIL}
|
git config --system user.email ${GITMAIL}
|
||||||
|
|
||||||
if bashio::config.has_value 'gitapi'; then
|
if bashio::config.has_value 'gitapi'; then
|
||||||
bashio::log.info "... setting github API"
|
LOGINFO="... setting github API"
|
||||||
|
if [ $VERBOSE = true ]; then bashio::log.info $LOGINFO; fi
|
||||||
|
|
||||||
export GITHUB_API_TOKEN=$(bashio::config 'gitapi')
|
export GITHUB_API_TOKEN=$(bashio::config 'gitapi')
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -28,48 +31,57 @@ for addons in $(bashio::config "addon|keys"); do
|
|||||||
BASENAME=$(basename "https://github.com/$REPOSITORY")
|
BASENAME=$(basename "https://github.com/$REPOSITORY")
|
||||||
|
|
||||||
#Create or update local version
|
#Create or update local version
|
||||||
if [ ! -d /data/$BASENAME ]; then
|
if [ ! -d /data/$BASENAME ]; then
|
||||||
bashio::log.info "... $SLUG : cloning ${REPOSITORY}"
|
LOGINFO="... $SLUG : cloning ${REPOSITORY}"
|
||||||
|
if [ $VERBOSE = true ]; then bashio::log.info $LOGINFO; fi
|
||||||
cd /data/
|
cd /data/
|
||||||
git clone "https://github.com/${REPOSITORY}"
|
git clone "https://github.com/${REPOSITORY}"
|
||||||
else
|
else
|
||||||
bashio::log.info "... $SLUG : updating ${REPOSITORY}"
|
LOGINFO="... $SLUG : updating ${REPOSITORY}"
|
||||||
|
if [ $VERBOSE = true ]; then bashio::log.info $LOGINFO; fi
|
||||||
cd "/data/$BASENAME"
|
cd "/data/$BASENAME"
|
||||||
git pull --rebase
|
git pull --rebase
|
||||||
fi
|
fi
|
||||||
|
|
||||||
#Define the folder addon
|
#Define the folder addon
|
||||||
bashio::log.info "... $SLUG : checking slug exists in repo"
|
LOGINFO="... $SLUG : checking slug exists in repo"
|
||||||
|
if [ $VERBOSE = true ]; then bashio::log.info $LOGINFO; fi
|
||||||
cd /data/${BASENAME}/${SLUG} || bashio::log.error "$SLUG addon not found in this repository. Exiting." exit
|
cd /data/${BASENAME}/${SLUG} || bashio::log.error "$SLUG addon not found in this repository. Exiting." exit
|
||||||
|
|
||||||
#Find current version
|
#Find current version
|
||||||
bashio::log.info "... $SLUG : get current version"
|
LOGINFO="... $SLUG : get current version"
|
||||||
|
if [ $VERBOSE = true ]; then bashio::log.info $LOGINFO; fi
|
||||||
CURRENT=$(jq .version config.json) || bashio::log.error "$SLUG addon version in config.json not found. Exiting." exit
|
CURRENT=$(jq .version config.json) || bashio::log.error "$SLUG addon version in config.json not found. Exiting." exit
|
||||||
|
|
||||||
#Prepare tag flag
|
#Prepare tag flag
|
||||||
if [ ${FULLTAG} = true ]; then
|
if [ ${FULLTAG} = true ]; then
|
||||||
bashio::log.info "... $SLUG : fulltag is on"
|
LOGINFO="... $SLUG : fulltag is on"
|
||||||
|
if [ $VERBOSE = true ]; then bashio::log.info $LOGINFO; fi
|
||||||
FULLTAG="--format tag"
|
FULLTAG="--format tag"
|
||||||
else
|
else
|
||||||
bashio::log.info "... $SLUG : fulltag is off"
|
LOGINFO="... $SLUG : fulltag is off"
|
||||||
|
if [ $VERBOSE = true ]; then bashio::log.info $LOGINFO; fi
|
||||||
FULLTAG=""
|
FULLTAG=""
|
||||||
fi
|
fi
|
||||||
|
|
||||||
#If beta flag, select beta version
|
#If beta flag, select beta version
|
||||||
if [ ${BETA} = true ]; then
|
if [ ${BETA} = true ]; then
|
||||||
bashio::log.info "... $SLUG : beta is on"
|
LOGINFO="... $SLUG : beta is on"
|
||||||
|
if [ $VERBOSE = true ]; then bashio::log.info $LOGINFO; fi
|
||||||
LASTVERSION='"'$(lastversion --pre "https://github.com/$UPSTREAM" $FULLTAG)'"'
|
LASTVERSION='"'$(lastversion --pre "https://github.com/$UPSTREAM" $FULLTAG)'"'
|
||||||
else
|
else
|
||||||
bashio::log.info "... $SLUG : beta is off"
|
LOGINFO="... $SLUG : beta is off"
|
||||||
|
if [ $VERBOSE = true ]; then bashio::log.info $LOGINFO; fi
|
||||||
LASTVERSION='"'$(lastversion "https://github.com/$UPSTREAM" $FULLTAG)'"'
|
LASTVERSION='"'$(lastversion "https://github.com/$UPSTREAM" $FULLTAG)'"'
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ ${CURRENT} != ${LASTVERSION} ]; then
|
if [ ${CURRENT} != ${LASTVERSION} ]; then
|
||||||
bashio::log.info "... $SLUG : update from $CURRENT to $LASTVERSION"
|
LOGINFO="... $SLUG : update from $CURRENT to $LASTVERSION"
|
||||||
|
if [ $VERBOSE = true ]; then bashio::log.info $LOGINFO; fi
|
||||||
|
|
||||||
#Change all instances of version
|
#Change all instances of version
|
||||||
bashio::log.info "... $SLUG : updating files"
|
LOGINFO="... $SLUG : updating files"
|
||||||
|
if [ $VERBOSE = true ]; then bashio::log.info $LOGINFO; fi
|
||||||
files=$(grep -rl ${CURRENT} /data/${BASENAME}/${SLUG}) && echo $files | xargs sed -i "s/${CURRENT}/${LASTVERSION}/g"
|
files=$(grep -rl ${CURRENT} /data/${BASENAME}/${SLUG}) && echo $files | xargs sed -i "s/${CURRENT}/${LASTVERSION}/g"
|
||||||
|
|
||||||
#Update changelog
|
#Update changelog
|
||||||
@@ -83,21 +95,19 @@ if [ $files != null ]; then
|
|||||||
git commit -m "Update to $LASTVERSION" /data/${BASENAME}/${SLUG}/CHANGELOG.md || true
|
git commit -m "Update to $LASTVERSION" /data/${BASENAME}/${SLUG}/CHANGELOG.md || true
|
||||||
|
|
||||||
#Git commit and push
|
#Git commit and push
|
||||||
bashio::log.info "... $SLUG : push to master"
|
LOGINFO="... $SLUG : push to github
|
||||||
|
if [ $VERBOSE = true ]; then bashio::log.info $LOGINFO; fi
|
||||||
git remote set-url origin "https://${GITUSER}:${GITPASS}@github.com/${REPOSITORY}" | echo
|
git remote set-url origin "https://${GITUSER}:${GITPASS}@github.com/${REPOSITORY}" | echo
|
||||||
git push | echo "No changes"
|
git push | echo "No changes"
|
||||||
|
|
||||||
#Update the current flag
|
|
||||||
bashio::log.info "... $SLUG : updating current flag"
|
|
||||||
sed -i "s/${CURRENT}/${LASTVERSION}/g" /data/options.json
|
|
||||||
|
|
||||||
#Log
|
#Log
|
||||||
bashio::log.info "... $SLUG : updated and published"
|
bashio::log.info "$SLUG updated to $LASTVERSION"
|
||||||
else
|
else
|
||||||
bashio::log.info "... $SLUG : couldn't update, please check the current version"
|
bashio::log.error "... $SLUG : couldn't update"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
else
|
else
|
||||||
bashio::log.info "Addon $SLUG is already up-to-date."
|
LOGINFO="Addon $SLUG is already up-to-date."
|
||||||
|
if [ $VERBOSE = true ]; then bashio::log.info $LOGINFO; fi
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
|||||||
Reference in New Issue
Block a user