ddb32989a3
Closes Homebrew/homebrew#26468. Signed-off-by: Jack Nagel <jacknagel@gmail.com>
98 lines
2.6 KiB
Ruby
98 lines
2.6 KiB
Ruby
require 'formula'
|
|
|
|
class Openssl < Formula
|
|
homepage 'http://openssl.org'
|
|
url 'https://www.openssl.org/source/openssl-1.0.1f.tar.gz'
|
|
mirror 'http://mirrors.ibiblio.org/openssl/source/openssl-1.0.1f.tar.gz'
|
|
sha256 '6cc2a80b17d64de6b7bac985745fdaba971d54ffd7d38d3556f998d7c0c9cb5a'
|
|
|
|
bottle do
|
|
sha1 "2687c0abb5e23d765bbd0024a010e36b05a8939e" => :mavericks
|
|
sha1 "dcaee2f1e51e8d0da7614e6dab4fc334f736d0de" => :mountain_lion
|
|
sha1 "4fabb39f5db46e8e62bf0b05e0133cd7e717860a" => :lion
|
|
end
|
|
|
|
keg_only :provided_by_osx,
|
|
"The OpenSSL provided by OS X is too old for some software."
|
|
|
|
def install
|
|
args = %W[./Configure
|
|
--prefix=#{prefix}
|
|
--openssldir=#{openssldir}
|
|
zlib-dynamic
|
|
shared
|
|
enable-cms
|
|
]
|
|
|
|
if MacOS.prefer_64_bit?
|
|
args << "darwin64-x86_64-cc" << "enable-ec_nistp_64_gcc_128"
|
|
|
|
# -O3 is used under stdenv, which results in test failures when using clang
|
|
inreplace 'Configure',
|
|
%{"darwin64-x86_64-cc","cc:-arch x86_64 -O3},
|
|
%{"darwin64-x86_64-cc","cc:-arch x86_64 -Os}
|
|
|
|
setup_makedepend_shim
|
|
else
|
|
args << "darwin-i386-cc"
|
|
end
|
|
|
|
system "perl", *args
|
|
|
|
ENV.deparallelize
|
|
system "make", "depend" if MacOS.prefer_64_bit?
|
|
system "make"
|
|
system "make", "test"
|
|
system "make", "install", "MANDIR=#{man}", "MANSUFFIX=ssl"
|
|
end
|
|
|
|
def setup_makedepend_shim
|
|
path = buildpath/"brew/makedepend"
|
|
path.write <<-EOS.undent
|
|
#!/bin/sh
|
|
exec "#{ENV.cc}" -M "$@"
|
|
EOS
|
|
path.chmod 0755
|
|
ENV.prepend_path 'PATH', path.parent
|
|
end
|
|
|
|
def openssldir
|
|
etc/"openssl"
|
|
end
|
|
|
|
def cert_pem
|
|
openssldir/"cert.pem"
|
|
end
|
|
|
|
def osx_cert_pem
|
|
openssldir/"osx_cert.pem"
|
|
end
|
|
|
|
def write_pem_file
|
|
system "security find-certificate -a -p /Library/Keychains/System.keychain > '#{osx_cert_pem}.tmp'"
|
|
system "security find-certificate -a -p /System/Library/Keychains/SystemRootCertificates.keychain >> '#{osx_cert_pem}.tmp'"
|
|
system "mv", "-f", "#{osx_cert_pem}.tmp", osx_cert_pem
|
|
end
|
|
|
|
def post_install
|
|
openssldir.mkpath
|
|
|
|
if cert_pem.exist?
|
|
write_pem_file
|
|
else
|
|
cert_pem.unlink if cert_pem.symlink?
|
|
write_pem_file
|
|
openssldir.install_symlink 'osx_cert.pem' => 'cert.pem'
|
|
end
|
|
end
|
|
|
|
test do
|
|
(testpath/'testfile.txt').write("This is a test file")
|
|
expected_checksum = "91b7b0b1e27bfbf7bc646946f35fa972c47c2d32"
|
|
system "#{bin}/openssl", 'dgst', '-sha1', '-out', 'checksum.txt', 'testfile.txt'
|
|
open("checksum.txt") do |f|
|
|
checksum = f.read(100).split("=").last.strip
|
|
assert_equal checksum, expected_checksum
|
|
end
|
|
end
|
|
end
|