[Buildroot] [git commit] nginx-nasxi: new package
Thomas Petazzoni
thomas.petazzoni at free-electrons.com
Fri Jul 15 20:49:56 UTC 2016
commit: https://git.buildroot.net/buildroot/commit/?id=7f299f02b20fb9d194d3ca583fb702b39c346b92
branch: https://git.buildroot.net/buildroot/commit/?id=refs/heads/master
Naxsi is a third party nginx module reads a small subset of simple rules
containing a list of known patterns involved in website vulnerabilities.
This module behaves like a DROP-by-default firewall for nginx.
Signed-off-by: Adam Duskett <aduskett at codeblue.com>
[Thomas:
- include Config.in file directly from package/Config.in and not from
package/nginx/Config.
- improve Config.in help text with more details
- rename the package prompt from ngx_http_naxsi_module to nginx-naxsi
- remove NGINX_NAXSI_SOURCE, and fix the definition of
NGINX_NAXSI_SITE
- change license from GPLv3 to GPLv2+ with OpenSSL exception
- cange license file from LICENSE to naxsi_src/naxsi_json.c. The
LICENSE file exists in the latest Git master of the project, but
not in the 0.54 tag that we're packaging.]
Signed-off-by: Thomas Petazzoni <thomas.petazzoni at free-electrons.com>
---
package/Config.in | 1 +
package/nginx-naxsi/Config.in | 26 ++++++++++++++++++++++++++
package/nginx-naxsi/nginx-naxsi.hash | 2 ++
package/nginx-naxsi/nginx-naxsi.mk | 12 ++++++++++++
package/nginx/nginx.mk | 5 +++++
5 files changed, 46 insertions(+)
diff --git a/package/Config.in b/package/Config.in
index 7756a4c..fe6ca65 100644
--- a/package/Config.in
+++ b/package/Config.in
@@ -1501,6 +1501,7 @@ menu "Networking applications"
source "package/nginx/Config.in"
if BR2_PACKAGE_NGINX
menu "External nginx modules"
+ source "package/nginx-naxsi/Config.in"
source "package/nginx-upload/Config.in"
endmenu
endif
diff --git a/package/nginx-naxsi/Config.in b/package/nginx-naxsi/Config.in
new file mode 100644
index 0000000..2f7c2da
--- /dev/null
+++ b/package/nginx-naxsi/Config.in
@@ -0,0 +1,26 @@
+config BR2_PACKAGE_NGINX_NAXSI
+ bool "nginx-naxsi"
+ help
+ NAXSI means Nginx Anti XSS & SQL Injection.
+
+ Technically, it is a third party nginx module, available as
+ a package for many UNIX-like platforms. This module, by
+ default, reads a small subset of simple (and readable) rules
+ containing 99% of known patterns involved in website
+ vulnerabilities. For example, <, | or drop are not supposed
+ to be part of a URI.
+
+ Being very simple, those patterns may match legitimate
+ queries, it is the Naxsi's administrator duty to add
+ specific rules that will whitelist legitimate
+ behaviours. The administrator can either add whitelists
+ manually by analyzing nginx's error log, or (recommended)
+ start the project with an intensive auto-learning phase that
+ will automatically generate whitelisting rules regarding a
+ website's behaviour.
+
+ In short, Naxsi behaves like a DROP-by-default firewall, the
+ only task is to add required ACCEPT rules for the target
+ website to work properly.
+
+ https://github.com/nbs-system/naxsi
diff --git a/package/nginx-naxsi/nginx-naxsi.hash b/package/nginx-naxsi/nginx-naxsi.hash
new file mode 100644
index 0000000..238993e
--- /dev/null
+++ b/package/nginx-naxsi/nginx-naxsi.hash
@@ -0,0 +1,2 @@
+# Locally calculated
+sha256 9cc2c09405bc71f78ef26a8b6d70afcea3fccbe8125df70cb0cfc480133daba5 nginx-naxsi-0.54.tar.gz
diff --git a/package/nginx-naxsi/nginx-naxsi.mk b/package/nginx-naxsi/nginx-naxsi.mk
new file mode 100644
index 0000000..0e1f714
--- /dev/null
+++ b/package/nginx-naxsi/nginx-naxsi.mk
@@ -0,0 +1,12 @@
+################################################################################
+#
+# nginx-naxsi
+#
+################################################################################
+
+NGINX_NAXSI_VERSION = 0.54
+NGINX_NAXSI_SITE = $(call github,nbs-system,naxsi,$(NGINX_NAXSI_VERSION))
+NGINX_NAXSI_LICENSE = GPLv2+ with OpenSSL exception
+NGINX_NAXSI_LICENSE_FILES = naxsi_src/naxsi_json.c
+
+$(eval $(generic-package))
diff --git a/package/nginx/nginx.mk b/package/nginx/nginx.mk
index 018d0f8..d57f3d0 100644
--- a/package/nginx/nginx.mk
+++ b/package/nginx/nginx.mk
@@ -156,6 +156,11 @@ else
NGINX_CONF_OPTS += --without-http_gzip_module
endif
+ifeq ($(BR2_PACKAGE_NGINX_NAXSI),y)
+NGINX_DEPENDENCIES += nginx-naxsi
+NGINX_CONF_OPTS += --add-module=$(NGINX_NAXSI_DIR)/naxsi_src
+endif
+
ifeq ($(BR2_PACKAGE_NGINX_HTTP_REWRITE_MODULE),y)
NGINX_DEPENDENCIES += pcre
else
More information about the buildroot
mailing list