open-appsec is a machine learning security engine that preemptively and automatically prevent threats against Web Application & APIs.
open-appsec Attachments connect between processes that provide HTTP data and the open-appsec Agent security logic.
An attachment gets HTTP data (URL, Header, Body, Response) from a hosting process and delivers it to an open-appsec process known as HTTP Transaction handler.
To deal with potential issues where the HTTP Transaction handler process is not responding, the Attachment implements a retry mechanism and configurable fail-open/fail-close mechanism.
This repository will host Attachment for different platforms. The first one is the open-appsec attachment for NGINX, implemented as a standard NGINX dynamically loadable module (plugin).
The attachment can be compiled to support an existing alpine based nginx server or an nginx/ingress-nginx alpine based docker.
Your compilation environment must be alpine based and contain git, docker, cmake and g++.
Before compiling, ensure the latest development versions of the following libraries:
- PCRE
- libxml2
- zlib
- OpenSSL
- Geoip
$ apk update
$ apk add pcre-dev libxml2-dev zlib-dev openssl-dev geoip-dev
On your existing nginx server:
- Run command to extract nginx compilation flags to a file
$ nginx -V &> /tmp/nginx.ver
On your compilation environment:
- Clone this repository
- Copy the file created on your nginx server (the previous section) to your compilation environment to the path /tmp/nginx.ver
- Run Configuration script
- Run CMake command
- Run make command
$ git clone https://github.com/openappsec/attachment.git
$ ./attachments/nginx/ngx_module/nginx_version_configuration.sh --conf /tmp/nginx.ver build_out
$ cmake -DCMAKE_INSTALL_PREFIX=build_out .
$ make install
The NGINX plugin uses these libraries: shmem_ipc, compression_utils, and nginx_attachment_util.
They can be found under the lib
directory in the <output path>
given to the CMake.
- Copy the associated libraries to /usr/lib on your existing nginx server
- Copy the nginx attachment file lib/libngx_module.so to the following path on your existing nginx server: /usr/lib/nginx/modules/
- Load the attachment on your nginx by adding the following command to the main nginx.conf file:
load_module /usr/lib/nginx/modules/libngx_module.so;
- Restart your nginx server.
Compiling the attachment code and creating a docker image for an existing nginx/ingress-nginx alpine docker
This step requires Docker to be installed on your compilation environment
- Clone this repository
- Run Configuration script with the required docker image name and tag
- Run CMake command
- Run make command
$ git clone https://github.com/openappsec/attachment.git
$ ./attachments/nginx/ngx_module/nginx_version_configuration.sh --docker <input docker image> build_out
$ cmake -DCMAKE_INSTALL_PREFIX=build_out -DOUTPUT_DOCKER_IMAGE=<output docker image> .
$ make install
$ make docker
Later on, you can push the image to your own registry and use it as needed.
For deployment on docker you can deploy it using the same docker command you used before with regular nginx container, just make sure to add the parameter --ipc=host
.
open-appsec/attachment is open source and available under the Apache 2.0 license.