diff options
author | mail_redacted_for_web | 2019-10-16 10:16:34 -0700 |
---|---|---|
committer | mail_redacted_for_web | 2019-10-16 10:26:21 -0700 |
commit | ada94157a42e1d20112eaa74618e2f22db4ed560 (patch) | |
tree | 1ff2a4cba732da1c118cc8bb460178643ea14193 /scripts/config_version-rugged.rb | |
parent | 415a71dd59c17093684efd3a1376afe1bfb8824d (diff) | |
download | control-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-rugged.rb')
-rwxr-xr-x | scripts/config_version-rugged.rb | 25 |
1 files changed, 25 insertions, 0 deletions
diff --git a/scripts/config_version-rugged.rb b/scripts/config_version-rugged.rb new file mode 100755 index 0000000..abb3390 --- /dev/null +++ b/scripts/config_version-rugged.rb @@ -0,0 +1,25 @@ +#!/opt/puppetlabs/puppet/bin/ruby +begin + require 'rugged' + require 'socket' +rescue LoadError + t = Time.new + puts t.to_i +else + environmentpath = ARGV[0] + environment = ARGV[1] + + # Get the hostname of the Puppet master compiling the catalog. + # Sometimes the hostname is the fqdn, so we'll take the first segment. + compiling_master = Socket.gethostname.split('.').first + + # Get the path to the environment being compiled. + repo = Rugged::Repository.discover(File.join(environmentpath, environment)) + head = repo.head + + # First 12 characters of the sha1 hash of the newest commit. + commit_id = head.target_id[0...11] + + # Show the compiling master, environment name, and commit ID. + puts "#{compiling_master}-#{environment}-#{commit_id}" +end |