diff options
author | Adam J. Stewart <ajstewart426@gmail.com> | 2016-09-28 13:58:51 -0500 |
---|---|---|
committer | Todd Gamblin <tgamblin@llnl.gov> | 2016-09-28 14:58:51 -0400 |
commit | 66c2ac0bc9639888f98cd0bd54688ac721045781 (patch) | |
tree | e27a738533b87eb8f32e39059f9c1f1c07cd532d /var | |
parent | 9aa77178f33793103653da1c81a73dd6a9e250be (diff) | |
download | spack-66c2ac0bc9639888f98cd0bd54688ac721045781.tar.gz spack-66c2ac0bc9639888f98cd0bd54688ac721045781.tar.bz2 spack-66c2ac0bc9639888f98cd0bd54688ac721045781.tar.xz spack-66c2ac0bc9639888f98cd0bd54688ac721045781.zip |
Tell Mercurial where to find CA certs (#1873)
Diffstat (limited to 'var')
-rw-r--r-- | var/spack/repos/builtin/packages/mercurial/package.py | 35 |
1 files changed, 30 insertions, 5 deletions
diff --git a/var/spack/repos/builtin/packages/mercurial/package.py b/var/spack/repos/builtin/packages/mercurial/package.py index e51069662f..ea77953f15 100644 --- a/var/spack/repos/builtin/packages/mercurial/package.py +++ b/var/spack/repos/builtin/packages/mercurial/package.py @@ -22,23 +22,48 @@ # License along with this program; if not, write to the Free Software # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA ############################################################################## - from spack import * +import llnl.util.tty as tty +import os class Mercurial(Package): """Mercurial is a free, distributed source control management tool.""" + homepage = "https://www.mercurial-scm.org" url = "https://www.mercurial-scm.org/release/mercurial-3.9.tar.gz" - version('3.9' , 'e2b355da744e94747daae3a5339d28a0') + version('3.9.1', '3759dd10edb8c1a6dfb8ff0ce82658ce') + version('3.9', 'e2b355da744e94747daae3a5339d28a0') version('3.8.4', 'cec2c3db688cb87142809089c6ae13e9') version('3.8.3', '97aced7018614eeccc9621a3dea35fda') version('3.8.2', 'c38daa0cbe264fc621dc3bb05933b0b3') version('3.8.1', '172a8c588adca12308c2aca16608d7f4') - depends_on("python @2.6:2.7.999") - depends_on("py-docutils", type="build") + extends('python') + depends_on('python@2.6:2.8') + depends_on('py-docutils', type='build') def install(self, spec, prefix): - make('PREFIX=%s' % prefix, 'install') + make('install', 'PREFIX={0}'.format(prefix)) + + # Configuration of HTTPS certificate authorities + # https://www.mercurial-scm.org/wiki/CACertificates + hgrc_filename = join_path(prefix.etc, 'mercurial', 'hgrc') + mkdirp(os.path.dirname(hgrc_filename)) + + with open(hgrc_filename, 'w') as hgrc: + if os.path.exists('/etc/ssl/certs/ca-certificates.crt'): + # Debian/Ubuntu/Gentoo/Arch Linux + hgrc.write('[web]\ncacerts = /etc/ssl/certs/ca-certificates.crt') # noqa + elif os.path.exists('/etc/pki/tls/certs/ca-bundle.crt'): + # Fedora/RHEL/CentOS + hgrc.write('[web]\ncacerts = /etc/pki/tls/certs/ca-bundle.crt') + elif os.path.exists('/etc/ssl/ca-bundle.pem'): + # openSUSE/SLE + hgrc.write('[web]\ncacerts = /etc/ssl/ca-bundle.pem') + else: + tty.warn('CA certificate not found. You may not be able to ' + 'connect to an HTTPS server. If your CA certificate ' + 'is in a non-standard location, you should add it to ' + '{0}'.format(hgrc_filename)) |