git.lirion.de

Of git, get, and gud

summaryrefslogtreecommitdiffstats
path: root/scripts/config_version.sh
diff options
context:
space:
mode:
authormail_redacted_for_web 2019-10-16 10:16:34 -0700
committermail_redacted_for_web 2019-10-16 10:26:21 -0700
commitada94157a42e1d20112eaa74618e2f22db4ed560 (patch)
tree1ff2a4cba732da1c118cc8bb460178643ea14193 /scripts/config_version.sh
parent415a71dd59c17093684efd3a1376afe1bfb8824d (diff)
downloadcontrol-repo-template-ada94157a42e1d20112eaa74618e2f22db4ed560.tar.bz2
Restore and clarify config_version functionality
This branch is intended as a portability fix. Some functionailty had been inadvertently removed as unused, but testing revealed that it had a purpose. Because the purpose was unclear, this commit restores the functionality AND clarifies it in the script names and comments in config_version.sh.
Diffstat (limited to 'scripts/config_version.sh')
-rwxr-xr-xscripts/config_version.sh31
1 files changed, 26 insertions, 5 deletions
diff --git a/scripts/config_version.sh b/scripts/config_version.sh
index 1dc54f7..d6981a1 100755
--- a/scripts/config_version.sh
+++ b/scripts/config_version.sh
@@ -1,14 +1,35 @@
#!/bin/sh
+# Usage
if [ $# -ne 2 -o ! -d "$1" -o ! -d "$1/$2" ]; then
echo "usage: $0 <environmentpath> <environment>" >&2
exit 1
fi
-ruby=ruby
+# For portability, identify a preferred ruby executable to use
+ruby() {
+ [ -x /opt/puppetlabs/puppet/bin/ruby ] \
+ && /opt/puppetlabs/puppet/bin/ruby "$@" \
+ || /usr/bin/env ruby "$@"
+}
-if [ -x /opt/puppetlabs/puppet/bin/ruby ]; then
- ruby=/opt/puppetlabs/puppet/bin/ruby
-fi
+# Determine how best to calculate a config_version
+if [ -e $1/$2/.r10k-deploy.json ]; then
+ # The environment was deployed using r10k. We will calculate the config
+ # version using the r10k data.
+ ruby $1/$2/scripts/config_version-r10k.rb $1 $2
+
+elif [ -e /opt/puppetlabs/server/pe_version ]; then
+ # This is a Puppet Enterprise system and we can rely on the rugged ruby gem
+ # being available.
+ ruby $1/$2/scripts/config_version-rugged.rb $1 $2
+
+elif [ -x /usr/bin/git ]; then
+ # The git command is available.
+ /usr/bin/git --git-dir $1/$2/.git rev-parse HEAD
-"${ruby}" "$1/$2/scripts/code_manager_config_version.rb" "$1" "$2"
+else
+ # Nothing else available; just use the date.
+ date +%s
+
+fi