99 lines
2.9 KiB
Ruby
99 lines
2.9 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_47_1_RTM/src/nss-3.47.1.tar.gz"
|
|
sha256 "1ae3d1cb1de345b258788f2ef6b10a460068034c3fd64f42427a183d8342a6fb"
|
|
|
|
bottle do
|
|
cellar :any
|
|
sha256 "4846b7c4ace8ef8aef508f033ac7f469f735585a7ae71ffd1b3cb8ac7ddcc3fa" => :catalina
|
|
sha256 "34f810fe40095377254dc3a388131f736f3711a3526ba475fd8f661c1738b106" => :mojave
|
|
sha256 "71db0fcc573796d7b0aaf2d5c23469e7ca19cbf23ec035814b7b1ffed4b3abe5" => :high_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
|