Three different options, best first...
SOURCE_VERSION
environment variable (build-time)
From 1st April 2015, there's a SOURCE_VERSION
environment variable available to builds running on Heroku. For git-push builds, this is the git commit SHA-1 of the source being built:
https://devcenter.heroku.com/changelog-items/630
(thanks to @srtech for pointing that out!)
/etc/heroku/dyno
metadata file (run-time)
Heroku have beta functionality to write out a /etc/heroku/dyno
metadata file onto your running dyno. If you email support you can probably get added to the beta. Here's a place where Heroku themselves are using it:
https://github.com/heroku/fix/blob/6c8ab7a/lib/heroku_dyno_metadata.rb
The contents look like this:
{
"dyno":{
"physical_id":"161bfad9-9e83-40b7-b385-78305db2f168",
"size":1,
"name":"run.7145"
},
"app":{
"id":null
},
"release":{
"id":50,
"commit":"2c3a0b24069af49b3de35b8e8c26765c1dba9ff0",
"description":null
}
}
..so release.commit
is the field you're after.
SBT-specific: use sbt-heroku
to build slug locally
My initial solution was to use the sbt-heroku
plugin published by Heroku themselves. This means no longer doing deploys by git push
(having the slug compiled on Heroku's own infrastructure), but instead compiling the slug locally and uploading that directly to Heroku. Because the slug is compiled locally, in my work repo, the Git information is all there and the build process can easily identify the commit id and embed it into the app's code.
The slug is substantially larger in size that a Git diff (90MB vs 0.5KB), but apart from that the solution works reasonably well. I'm actually using Travis to do continuous deployment, and so Travis was doing the sbt stage deployHeroku
for me (the Git commit id is available in that environment while building), meaning I could git-push from my laptop on the move, and Travis will do the large slug upload to Heroku.
git init
orgit clone
git copies the initial content from some template directory. The default template has sample hooks in it, for instance. So whatever process is creating those repos the slug compiler is cleaning out, it's also doing a checkout for the contents. Make the repo template that process uses have the checkout hook you want. – Krimmergit pull
and then find the top entry ingit reflog
you will have the commit id. – DeflectiveSOURCE_VERSION
, the best answer is no longer SBT-specific, and so an existing question applies just as well: https://mcmap.net/q/372025/-access-current-git-commit-number-from-within-heroku-app – Euphroe