mirror of
https://github.com/PurpleComputing/mdmscripts.git
synced 2026-02-03 14:13:27 +00:00
Update !Script-Template.sh
Updated Comments and Indentation
This commit is contained in:
@@ -22,30 +22,29 @@
|
||||
# Program Variables #
|
||||
####################################################################################################
|
||||
|
||||
# The version of this script, it is used in the logs so you can see which version of the script has
|
||||
# been used and will help with script debugging
|
||||
scriptver="1.0"
|
||||
# The version of this script is used in the logs and will help with script debugging
|
||||
scriptver="1.0"
|
||||
|
||||
# The url of the webpage to scrape for the latest version number and download link.
|
||||
releaseNotesUrl='https://vendorweb.com/product_history/release_notes'
|
||||
releaseNotesUrl='https://vendorweb.com/product_history/release_notes'
|
||||
|
||||
# Installation Method, are we using a DMG or PKG to install the app?
|
||||
installMethod="PKG"
|
||||
installMethod="PKG"
|
||||
|
||||
# This is the name of the file we download this might be a dmg or a pkg.
|
||||
dnldfile='Application Name.pkg'
|
||||
dnldfile='Application Name.pkg'
|
||||
|
||||
# The name of the application once it is installed without the .app extension
|
||||
appName='Installed Application Name'
|
||||
appName='Installed Application Name'
|
||||
|
||||
# Do we want to force quit the existing application before updating
|
||||
forceQuit='Y'
|
||||
forceQuit='Y'
|
||||
|
||||
# The 2 Log files we create as were progressing through the script
|
||||
# logfile is the main log which has each step and any errors sent to it
|
||||
# deplog is used to update the depnotify application with statuses and increments the progress bar
|
||||
logfile="/Library/Logs/${appName}InstallScript.log"
|
||||
deplog="/var/tmp/depnotify.log"
|
||||
logfile="/Library/Logs/${appName}InstallScript.log"
|
||||
deplog="/var/tmp/depnotify.log"
|
||||
|
||||
|
||||
####################################################################################################
|
||||
@@ -53,22 +52,22 @@ deplog="/var/tmp/depnotify.log"
|
||||
####################################################################################################
|
||||
|
||||
# Create log files if they don't exist
|
||||
if [[ ! -e ${logfile} ]]; then
|
||||
/bin/echo "---- New Log ----" >> $logfile
|
||||
fi
|
||||
if [[ ! -e ${logfile} ]]; then
|
||||
/bin/echo "---- New Log ----" >> $logfile
|
||||
fi
|
||||
|
||||
if [[ ! -e ${deplog} ]]; then
|
||||
/bin/echo "---- New Log ----" >> $deplog
|
||||
fi
|
||||
if [[ ! -e ${deplog} ]]; then
|
||||
/bin/echo "---- New Log ----" >> $deplog
|
||||
fi
|
||||
|
||||
# Open the log files if the openconsole parameter has been passed to the script
|
||||
if [[ $@ == "openconsole" ]]; then
|
||||
open ${logfile}
|
||||
open ${deplog}
|
||||
fi
|
||||
if [[ $@ == "openconsole" ]]; then
|
||||
open ${logfile}
|
||||
open ${deplog}
|
||||
fi
|
||||
|
||||
# Log the script version and date
|
||||
/bin/echo "`date`: Running script version: ${scriptver}" >> ${logfile}
|
||||
/bin/echo "`date`: Running script version: ${scriptver}" >> ${logfile}
|
||||
|
||||
|
||||
####################################################################################################
|
||||
@@ -76,22 +75,22 @@ fi
|
||||
####################################################################################################
|
||||
|
||||
# To get just the latest version number from the Release Notes URL
|
||||
/bin/echo "`date`: Getting latest version number" >> ${logfile}
|
||||
/bin/echo "Getting latest version number"
|
||||
latestver=$(curl -s ${releaseNotesUrl} | grep 'find all lines with this word' | grep -vim 1 'find the first instance that excludes this word' | cut -f2 -d'"' | cut -f2 -d"-" | sed -e 's/\.[^.]*$//')
|
||||
/bin/echo "`date`: Getting latest version number" >> ${logfile}
|
||||
/bin/echo "Getting latest version number"
|
||||
latestver=$(curl -s ${releaseNotesUrl} | grep 'find all lines with this word' | grep -vim 1 'find the first instance that excludes this word' | cut -f2 -d'"' | cut -f2 -d"-" | sed -e 's/\.[^.]*$//')
|
||||
|
||||
####################################################################################################
|
||||
# Gathering the download url #
|
||||
####################################################################################################
|
||||
|
||||
# To get the latest download link from the Release Notes URL
|
||||
/bin/echo "`date`: Getting download url" >> ${logfile}
|
||||
/bin/echo "Getting download url"
|
||||
url=$(curl -s ${releaseNotesUrl} | grep 'download' | grep -vim 1 'beta' | cut -f2 -d'"')
|
||||
/bin/echo "`date`: Getting download url" >> ${logfile}
|
||||
/bin/echo "Getting download url"
|
||||
url=$(curl -s ${releaseNotesUrl} | grep 'download' | grep -vim 1 'beta' | cut -f2 -d'"')
|
||||
|
||||
# Display the latest version available in the logs
|
||||
/bin/echo "`date`: Latest version number is: ${latestver}" >> ${logfile}
|
||||
/bin/echo "Latest version number is: ${latestver}"
|
||||
/bin/echo "`date`: Latest version number is: ${latestver}" >> ${logfile}
|
||||
/bin/echo "Latest version number is: ${latestver}"
|
||||
|
||||
####################################################################################################
|
||||
# Check to see if app already installed and get the version if it is #
|
||||
@@ -103,11 +102,11 @@ url=$(curl -s ${releaseNotesUrl} | grep 'download' | grep -vim 1 'beta' | cut -f
|
||||
# Read the version number from the info.plist
|
||||
currentinstalledver=`/usr/bin/defaults read "/Applications/${appName}.app/Contents/Info" CFBundleShortVersionString`
|
||||
|
||||
# Display the current installed version number in the logs
|
||||
# Display the current installed version number in the logs
|
||||
/bin/echo "Current installed version is: $currentinstalledver"
|
||||
/bin/echo "`date`: Current installed version is: $currentinstalledver" >> ${logfile}
|
||||
|
||||
# Check to see if the latest available version is the same as the installed version
|
||||
# Check to see if the latest available version is the same as the installed version
|
||||
if [[ ${latestver} = ${currentinstalledver} ]]; then
|
||||
/bin/echo "${appName} is current. Exiting"
|
||||
/bin/echo "`date`: ${appName} is current. Exiting" >> ${logfile}
|
||||
@@ -115,7 +114,7 @@ url=$(curl -s ${releaseNotesUrl} | grep 'download' | grep -vim 1 'beta' | cut -f
|
||||
exit 0
|
||||
fi
|
||||
else
|
||||
# update the logs to indicate that app is not already installed
|
||||
# update the logs to indicate that app is not already installed
|
||||
currentinstalledver="none"
|
||||
/bin/echo "${appName} is not installed"
|
||||
/bin/echo "`date`: ${appName} is not installed" >> ${logfile}
|
||||
@@ -136,63 +135,63 @@ url=$(curl -s ${releaseNotesUrl} | grep 'download' | grep -vim 1 'beta' | cut -f
|
||||
/bin/echo "`date`: Available ${appName} version: ${latestver}" >> ${logfile}
|
||||
/bin/echo "Available ${appName} version: ${latestver}"
|
||||
|
||||
# Download the file
|
||||
# Download the file
|
||||
/bin/echo "`date`: Downloading newer version." >> ${logfile}
|
||||
/bin/echo "Downloading newer version."
|
||||
/usr/bin/curl -s -o /tmp/${dnldfile} ${url}
|
||||
|
||||
# Force quit the application
|
||||
if [[ "${forceQuit}" = "Y" ]]; then
|
||||
killall ${appName}
|
||||
fi
|
||||
# Force quit the application
|
||||
if [[ "${forceQuit}" = "Y" ]]; then
|
||||
killall ${appName}
|
||||
fi
|
||||
####################################################################################################
|
||||
# Choose the correct installation method. #
|
||||
# Choose the correct installation method. #
|
||||
####################################################################################################
|
||||
|
||||
if [[ $installMethod = "DMG"]]; then
|
||||
|
||||
# Mount the DMG
|
||||
/bin/echo "`date`: Mounting installer disk image." >> ${logfile}
|
||||
/usr/bin/hdiutil attach /tmp/${dnldfile} -nobrowse -quiet
|
||||
# Mount the DMG
|
||||
/bin/echo "`date`: Mounting installer disk image." >> ${logfile}
|
||||
/usr/bin/hdiutil attach /tmp/${dnldfile} -nobrowse -quiet
|
||||
|
||||
# Copy the file to the Applications folder - you may need to change the mounted volume name
|
||||
/bin/echo "`date`: Installing..." >> ${logfile}
|
||||
ditto -rsrc "/Volumes/${appName}/${appName}.app" "/Applications/${appName}.app"
|
||||
/bin/sleep 10
|
||||
/bin/echo "`date`: Installing..." >> ${logfile}
|
||||
ditto -rsrc "/Volumes/${appName}/${appName}.app" "/Applications/${appName}.app"
|
||||
/bin/sleep 10
|
||||
|
||||
# Unmount the DMG
|
||||
/bin/echo "`date`: Unmounting installer disk image." >> ${logfile}
|
||||
/usr/bin/hdiutil detach $(/bin/df | /usr/bin/grep AppName | awk '{print $1}') -quiet
|
||||
/bin/sleep 10
|
||||
/bin/echo "`date`: Unmounting installer disk image." >> ${logfile}
|
||||
/usr/bin/hdiutil detach $(/bin/df | /usr/bin/grep AppName | awk '{print $1}') -quiet
|
||||
/bin/sleep 10
|
||||
|
||||
else
|
||||
|
||||
|
||||
# Open the PKG with installer
|
||||
cd /tmp
|
||||
/usr/sbin/installer -pkg ${dnldfile} -target /
|
||||
# Open the PKG with installer
|
||||
cd /tmp
|
||||
/usr/sbin/installer -pkg ${dnldfile} -target /
|
||||
|
||||
|
||||
fi
|
||||
# Clean up after the installation
|
||||
/bin/sleep 5
|
||||
/bin/echo "`date`: Deleting the downloaded file." >> ${logfile}
|
||||
/bin/rm /tmp/${dnldfile}
|
||||
/bin/sleep 5
|
||||
/bin/echo "`date`: Deleting the downloaded file." >> ${logfile}
|
||||
/bin/rm /tmp/${dnldfile}
|
||||
|
||||
|
||||
####################################################################################################
|
||||
# Check to see if the update was successful. #
|
||||
####################################################################################################
|
||||
|
||||
# Get the version of the app from the info.plist
|
||||
# Get the version of the app from the info.plist
|
||||
newlyinstalledver=`/usr/bin/defaults read "/Applications/${appName}.app/Contents/Info" CFBundleShortVersionString`
|
||||
|
||||
# Compare the installed version against the latest version
|
||||
# Compare the installed version against the latest version
|
||||
if [[ "${latestver}" = "${newlyinstalledver}" ]]; then
|
||||
/bin/echo "`date`: SUCCESS: ${appName} has been updated to version ${newlyinstalledver}" >> ${logfile}
|
||||
/bin/echo "SUCCESS: ${appName} has been updated to version ${newlyinstalledver}"
|
||||
|
||||
# If dockutil is installed remove existing dock icon and add new one
|
||||
# If dockutil is installed remove existing dock icon and add new one
|
||||
if [[ -e "/usr/local/bin/dockutil" ]]; then
|
||||
/bin/echo "`date`: Removing Existing Dock Icon." >> ${logfile}
|
||||
/bin/echo "Removing Existing Dock Icon."
|
||||
@@ -203,7 +202,7 @@ url=$(curl -s ${releaseNotesUrl} | grep 'download' | grep -vim 1 'beta' | cut -f
|
||||
/usr/local/bin/dockutil --add "/Applications/${appName}.app" --position 1 --allhomes >> ${logfile}
|
||||
/bin/sleep 3
|
||||
fi
|
||||
# Update log with Failed install and exit with exit code 1
|
||||
# Update log with Failed install and exit with exit code 1
|
||||
else
|
||||
/bin/echo "`date`: ERROR: ${appName} update unsuccessful, version remains at ${currentinstalledver}." >> ${logfile}
|
||||
/bin/echo "ERROR: ${appName} update unsuccessful, version remains at ${currentinstalledver}."
|
||||
@@ -212,17 +211,17 @@ url=$(curl -s ${releaseNotesUrl} | grep 'download' | grep -vim 1 'beta' | cut -f
|
||||
fi
|
||||
|
||||
# App is up to date already so we log it.
|
||||
else
|
||||
/bin/echo "`date`: ${appName} is already up to date, running ${currentinstalledver}." >> ${logfile}
|
||||
/bin/echo "${appName} is already up to date, running ${currentinstalledver}."
|
||||
fi
|
||||
else
|
||||
/bin/echo "`date`: ${appName} is already up to date, running ${currentinstalledver}." >> ${logfile}
|
||||
/bin/echo "${appName} is already up to date, running ${currentinstalledver}."
|
||||
fi
|
||||
|
||||
# Update log so show end of script
|
||||
/bin/echo "---- End of script ----" >> ${logfile}
|
||||
/bin/echo "---- End of script ----" >> ${logfile}
|
||||
|
||||
# Update DEP Notify to increment the progress bar - when used with multiple scripts
|
||||
/bin/echo "Command: DeterminateManualStep: 1" >> ${deplog}
|
||||
/bin/echo "Command: DeterminateManualStep: 1" >> ${deplog}
|
||||
|
||||
#Exit script with exit code 0
|
||||
exit 0
|
||||
exit 0
|
||||
|
||||
|
||||
Reference in New Issue
Block a user