101 lines
3 KiB
Ruby
101 lines
3 KiB
Ruby
class Nss < Formula
|
|
desc "Libraries for security-enabled client and server applications"
|
|
homepage "https://developer.mozilla.org/docs/NSS"
|
|
url "https://ftp.mozilla.org/pub/security/nss/releases/NSS_3_46_RTM/src/nss-3.46.tar.gz"
|
|
sha256 "6b699649d285602ba258a4b0957cb841eafc94eff5735a9da8da0adbb9a10cef"
|
|
revision 1
|
|
|
|
bottle do
|
|
cellar :any
|
|
sha256 "c2002d855d1dc0d49c7bb1dca844b2d9840184d68c13d613efc045aaa1408cc7" => :catalina
|
|
sha256 "d695d9640c058b292d1d109345d840f51ea6c18f894500750178e8c0f8c27264" => :mojave
|
|
sha256 "5bdba8a61eb2e7899e50070372367357a52868ba91d13a1797235994142bdb45" => :high_sierra
|
|
sha256 "a9102f547a4bc47346caa3b598e626f951d4bc71f8c3f2eb4b3116ac151fc341" => :sierra
|
|
end
|
|
|
|
depends_on "nspr"
|
|
|
|
def install
|
|
ENV.deparallelize
|
|
cd "nss"
|
|
|
|
args = %W[
|
|
BUILD_OPT=1
|
|
NSS_ALLOW_SSLKEYLOGFILE=1
|
|
NSS_USE_SYSTEM_SQLITE=1
|
|
NSPR_INCLUDE_DIR=#{Formula["nspr"].opt_include}/nspr
|
|
NSPR_LIB_DIR=#{Formula["nspr"].opt_lib}
|
|
USE_64=1
|
|
]
|
|
|
|
# Remove the broken (for anyone but Firefox) install_name
|
|
inreplace "coreconf/Darwin.mk", "-install_name @executable_path", "-install_name #{lib}"
|
|
inreplace "lib/freebl/config.mk", "@executable_path", lib
|
|
|
|
system "make", "all", *args
|
|
|
|
# We need to use cp here because all files get cross-linked into the dist
|
|
# hierarchy, and Homebrew's Pathname.install moves the symlink into the keg
|
|
# rather than copying the referenced file.
|
|
cd "../dist"
|
|
bin.mkpath
|
|
Dir.glob("Darwin*/bin/*") do |file|
|
|
cp file, bin unless file.include? ".dylib"
|
|
end
|
|
|
|
include_target = include + "nss"
|
|
include_target.mkpath
|
|
Dir.glob("public/{dbm,nss}/*") { |file| cp file, include_target }
|
|
|
|
lib.mkpath
|
|
libexec.mkpath
|
|
Dir.glob("Darwin*/lib/*") do |file|
|
|
if file.include? ".chk"
|
|
cp file, libexec
|
|
else
|
|
cp file, lib
|
|
end
|
|
end
|
|
# resolves conflict with openssl, see #28258
|
|
rm lib/"libssl.a"
|
|
|
|
(bin/"nss-config").write config_file
|
|
(lib/"pkgconfig/nss.pc").write pc_file
|
|
end
|
|
|
|
test do
|
|
# See: https://developer.mozilla.org/docs/Mozilla/Projects/NSS/tools/NSS_Tools_certutil
|
|
(testpath/"passwd").write("It's a secret to everyone.")
|
|
system "#{bin}/certutil", "-N", "-d", pwd, "-f", "passwd"
|
|
system "#{bin}/certutil", "-L", "-d", pwd
|
|
end
|
|
|
|
# A very minimal nss-config for configuring firefox etc. with this nss,
|
|
# see https://bugzil.la/530672 for the progress of upstream inclusion.
|
|
def config_file; <<~EOS
|
|
#!/bin/sh
|
|
for opt; do :; done
|
|
case "$opt" in
|
|
--version) opt="--modversion";;
|
|
--cflags|--libs) ;;
|
|
*) exit 1;;
|
|
esac
|
|
pkg-config "$opt" nss
|
|
EOS
|
|
end
|
|
|
|
def pc_file; <<~EOS
|
|
prefix=#{prefix}
|
|
exec_prefix=${prefix}
|
|
libdir=${exec_prefix}/lib
|
|
includedir=${prefix}/include/nss
|
|
|
|
Name: NSS
|
|
Description: Mozilla Network Security Services
|
|
Version: #{version}
|
|
Requires: nspr >= 4.12
|
|
Libs: -L${libdir} -lnss3 -lnssutil3 -lsmime3 -lssl3
|
|
Cflags: -I${includedir}
|
|
EOS
|
|
end
|
|
end
|