homebrew-core/Formula/john-jumbo.rb
2015-11-22 15:27:37 -08:00

101 lines
3.2 KiB
Ruby

class JohnJumbo < Formula
desc "Enhanced version of john, a UNIX password cracker"
homepage "http://www.openwall.com/john/"
url "http://openwall.com/john/j/john-1.8.0-jumbo-1.tar.xz"
version "1.8.0"
sha256 "bac93d025995a051f055adbd7ce2f1975676cac6c74a6c7a3ee4cfdd9c160923"
bottle do
cellar :any
revision 5
sha256 "d42a48a458820727be0108d222165d83bb307042e0f27b20fd013b5089521ad4" => :el_capitan
sha256 "180d93eb1b3ca38c76be1b6d67ff924b4c1b070884924f11bf44590e7654498c" => :yosemite
sha256 "5022fb58f6d60107bf3dc4eda6bb21efecc0c7250e6e4f61fb0f4f76abd5050d" => :mavericks
end
conflicts_with "john", :because => "both install the same binaries"
option "without-completion", "bash/zsh completion will not be installed"
depends_on "pkg-config" => :build
depends_on "openssl"
depends_on "gmp"
# Patch taken from MacPorts, tells john where to find runtime files.
# https://github.com/magnumripper/JohnTheRipper/issues/982
patch :DATA
fails_with :llvm do
build 2334
cause "Don't remember, but adding this to whitelist 2336."
end
# https://github.com/magnumripper/JohnTheRipper/blob/bleeding-jumbo/doc/INSTALL#L133-L143
fails_with :gcc do
cause "Upstream have a hacky workaround for supporting gcc that we can't use."
end
def install
cd "src" do
args = []
if build.bottle?
args << "--disable-native-tests" << "--disable-native-macro"
end
system "./configure", *args
system "make", "clean"
system "make", "-s", "CC=#{ENV.cc}"
end
# Remove the symlink and install the real file
rm "README"
prefix.install "doc/README"
doc.install Dir["doc/*"]
# Only symlink the main binary into bin
(share/"john").install Dir["run/*"]
bin.install_symlink share/"john/john"
if build.with? "completion"
bash_completion.install share/"john/john.bash_completion" => "john.bash"
zsh_completion.install share/"john/john.zsh_completion" => "_john"
end
# Source code defaults to "john.ini", so rename
mv share/"john/john.conf", share/"john/john.ini"
end
# The test is currently failing against the sandbox since john
# always writes to the user's home directory; see
# https://github.com/magnumripper/JohnTheRipper/issues/1901
#
# test do
# touch "john2.pot"
# (testpath/"test").write "dave:#{`printf secret | /usr/bin/openssl md5`}"
# assert_match(/secret/, shell_output("#{bin}/john --nolog --pot=#{testpath}/john2.pot --format=raw-md5 test"))
# assert_match(/secret/, (testpath/"john2.pot").read)
# end
end
__END__
--- a/src/params.h 2012-08-30 13:24:18.000000000 -0500
+++ b/src/params.h 2012-08-30 13:25:13.000000000 -0500
@@ -70,15 +70,15 @@
* notes above.
*/
#ifndef JOHN_SYSTEMWIDE
-#define JOHN_SYSTEMWIDE 0
+#define JOHN_SYSTEMWIDE 1
#endif
#if JOHN_SYSTEMWIDE
#ifndef JOHN_SYSTEMWIDE_EXEC /* please refer to the notes above */
-#define JOHN_SYSTEMWIDE_EXEC "/usr/libexec/john"
+#define JOHN_SYSTEMWIDE_EXEC "HOMEBREW_PREFIX/share/john"
#endif
#ifndef JOHN_SYSTEMWIDE_HOME
-#define JOHN_SYSTEMWIDE_HOME "/usr/share/john"
+#define JOHN_SYSTEMWIDE_HOME "HOMEBREW_PREFIX/share/john"
#endif
#define JOHN_PRIVATE_HOME "~/.john"
#endif