aboutsummaryrefslogtreecommitdiffstats
path: root/Library/Formula/sqlmap.rb
diff options
context:
space:
mode:
authorAlessio Bogon2015-01-16 00:06:50 +0100
committerTim D. Smith2015-01-18 19:18:16 -0800
commit467068071b5f36ea962a5084246bcbce4bdc34c5 (patch)
tree3cf6332ea7e6099f90a06aa750b5c8852c19ad6e /Library/Formula/sqlmap.rb
parenta9291533cafcbdb0b21f3c05674c59cd6f50af73 (diff)
downloadhomebrew-467068071b5f36ea962a5084246bcbce4bdc34c5.tar.bz2
sqlmap: clean up, add test
* Remove outdated resources and options. * Remove python dependency (sqlmap works with python 2.6 and 2.7) * Symlink `sqlmapapi.py` if available * More useful test Closes #35921. Signed-off-by: Tim D. Smith <git@tim-smith.us>
Diffstat (limited to 'Library/Formula/sqlmap.rb')
-rw-r--r--Library/Formula/sqlmap.rb87
1 files changed, 22 insertions, 65 deletions
diff --git a/Library/Formula/sqlmap.rb b/Library/Formula/sqlmap.rb
index fc53d4364..5d5097505 100644
--- a/Library/Formula/sqlmap.rb
+++ b/Library/Formula/sqlmap.rb
@@ -1,5 +1,3 @@
-require "formula"
-
class Sqlmap < Formula
homepage "http://sqlmap.org"
url "https://github.com/sqlmapproject/sqlmap/archive/0.9.tar.gz"
@@ -7,76 +5,35 @@ class Sqlmap < Formula
head "https://github.com/sqlmapproject/sqlmap.git"
revision 1
- option "with-mysql", "Install with support for direct connection to MySQL"
- option "with-postgresql", "Install with support for direct connection to PostgreSQL"
- option "with-unixodbc", "Install with ODBC driver"
-
- depends_on :python if MacOS.version <= :snow_leopard
- depends_on "mysql" => :optional
- depends_on "postgresql" => :optional
- depends_on "unixodbc" => :optional
-
- resource "ibm-db" do
- url "https://pypi.python.org/packages/source/i/ibm-db-sa-py3/ibm-db-sa-py3-0.3.0-1.tar.gz"
- sha1 "a48bc74ea0aafba5c56c6981db5213a23c55a33c"
- end
-
- resource "impacket" do
- url "https://pypi.python.org/packages/source/i/impacket/impacket-0.9.11.tar.gz"
- sha1 "c78855be24f7730182c7914a64b9895f8b244ea2"
- end
-
- resource "mysql-python" do
- url "https://pypi.python.org/packages/source/M/MySQL-python/MySQL-python-1.2.4.zip"
- sha1 "9af66e09713a79a08a312a7da87f0f0dccfc0a91"
- end
-
- resource "ntlm" do
- url "https://pypi.python.org/packages/source/p/python-ntlm/python-ntlm-1.0.1.tar.gz"
- sha1 "91644247682f9fe128ce63496cf77b53605f085d"
- end
-
- resource "pyodbc" do
- url "http://pyodbc.googlecode.com/files/pyodbc-3.0.7.zip"
- sha1 "88cb519411116012402aa0a0d5d7484949ddd99c"
- end
-
- resource "psycopg2" do
- url "https://pypi.python.org/packages/source/p/psycopg2/psycopg2-2.5.2.tar.gz"
- sha1 "96d071f8e4faa07810976640078742b0a944cd13"
- end
-
- resource "pysqlite" do
- url "https://pypi.python.org/packages/source/p/pysqlite/pysqlite-2.6.3.tar.gz"
- sha1 "b1eed16107232aebec1826b671c99a76e26afa7b"
- end
-
def install
- ENV["PYTHONPATH"] = lib+"python2.7/site-packages"
- ENV.prepend_create_path "PYTHONPATH", libexec+"lib/python2.7/site-packages"
- install_args = [ "setup.py", "install", "--prefix=#{libexec}" ]
+ libexec.install Dir["*"]
- res = %w{ibm-db impacket ntlm pysqlite}
- res << "mysql-python" if build.with? "mysql"
- res << "psycopg2" if build.with? "postgresql"
- res << "pyodbc" if build.with? "unixodbc"
-
- res.each do |r|
- resource(r).stage { system "python", *install_args }
- end
+ bin.install_symlink libexec/"sqlmap.py"
+ bin.install_symlink bin/"sqlmap.py" => "sqlmap"
- prefix.install "doc", "extra", "plugins", "shell", "tamper", "txt", "udf", "xml", "sqlmap.conf"
- bin.install "sqlmap.py"
- (libexec+"lib").install Dir["lib/*"]
if build.head?
- prefix.install "procs", "thirdparty", "waf"
- bin.install "sqlmapapi.py"
+ bin.install_symlink libexec/"sqlmapapi.py"
+ bin.install_symlink bin/"sqlmapapi.py" => "sqlmapapi"
end
- bin.env_script_all_files(prefix, :PYTHONPATH => ENV["PYTHONPATH"] + ':' + libexec)
- bin.install_symlink bin+"sqlmap.py" => "sqlmap"
end
test do
- system bin+"sqlmap", "--version"
+ query_path = testpath/"school_insert.sql"
+ query_path.write <<-EOS.undent
+ create table students (name text, age integer);
+ insert into students (name, age) values ('Bob', 14);
+ insert into students (name, age) values ('Sue', 12);
+ insert into students (name, age) values ('Tim', 13);
+ EOS
+
+ query_select = "select name, age from students order by age asc;"
+
+ # Create the test database
+ `sqlite3 < #{query_path} school.sqlite`
+
+ output = `#{bin}/sqlmap --batch -d "sqlite://school.sqlite" --sql-query "#{query_select}"`
+ assert_match /Bob,\s14/, output
+ assert_match /Sue,\s12/, output
+ assert_match /Tim,\s13/, output
end
end