class Nss < Formula desc "Libraries for security-enabled client and server applications" homepage "https://developer.mozilla.org/en-US/docs/Mozilla/Projects/NSS" url "https://ftp.mozilla.org/pub/security/nss/releases/NSS_3_84_RTM/src/nss-3.84.tar.gz" sha256 "9a387ffe350ff14f001d943f96cc0c064891551d71e1a97a5ddbffe7f1207a25" license "MPL-2.0" livecheck do url "https://ftp.mozilla.org/pub/security/nss/releases/" regex(%r{href=.*?NSS[._-]v?(\d+(?:[._]\d+)+)[._-]RTM/?["' >]}i) strategy :page_match do |page, regex| page.scan(regex).map { |match| match.first.tr("_", ".") } end end bottle do sha256 cellar: :any, arm64_monterey: "75228d489e8c018cdd20b42844c303db15eaa070ddbaa79ab73c9a6656bfe4a5" sha256 cellar: :any, arm64_big_sur: "cd9f2b53e64fea28ccf9f55465165e0ccaf00d7d82e9c8738ecf6a317e205c41" sha256 cellar: :any, monterey: "99bdba48f57497bb3a4b641666065aedf4e7fb49f895202413bd6a85655f5b50" sha256 cellar: :any, big_sur: "5070d997f370ef5f1b7cceea75750056096452639553ee8de3762d03b0376bce" sha256 cellar: :any, catalina: "b4e475f02a5081793744e1d77ee479bdc8903c575a11ab5df7039e0a7f3edb64" sha256 cellar: :any_skip_relocation, x86_64_linux: "9810df24eeefbb6685ac373c2f76e45ee21509e762667602339061a0baba228e" end depends_on "nspr" uses_from_macos "sqlite" uses_from_macos "zlib" conflicts_with "arabica", because: "both install `mangle` binaries" conflicts_with "resty", because: "both install `pp` binaries" def install ENV.deparallelize cd "nss" args = %W[ BUILD_OPT=1 NSS_ALLOW_SSLKEYLOGFILE=1 NSS_DISABLE_GTESTS=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 os = OS.kernel_name Dir.glob("#{os}*/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("#{os}*/lib/*") do |file| if file.include? ".chk" cp file, libexec else cp file, lib end end # resolves conflict with openssl, see legacy-homebrew#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