Skip to content

This repository contains resources that can be used to demo Nginx App Protect within a Docker environment.

Notifications You must be signed in to change notification settings

sdutta9/app_protect_base

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

27 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

NGINX App Protect Demo

Overview

This repository contains resources that can be used to demo Nginx App Protect within a Docker environment. This demo requires paid version of NGINX. Before running demo from any of the branches please make sure you have put the NGINX Plus key and cert within nginx-plus/etc/ssl/nginx/ directory. You can request for an NGINX Plus trial key by visiting www.nginx.com.

Guide

This repo has four "distinct" branches which can be used for different demos as described below.

NOTE: All App Protect related configurations are applied to the http context present inside the nginx.conf file for all the branches.

main Branch

  • This branch can be used to demonstrate basic configuration to enable App Protect.
  • The Dockerfile within nginx-plus directory has steps to install App Protect and also installs Attack Signatures and Threat campaigns packages.
  • You can test the installation of this packages by getting inside the nginx-plus container and then running the below commands:
    docker exec -it [containerID] bash
    
    #Within the container run below commands:
    apt list --installed| grep app-protect
    
    apt-cache policy app-protect-attack-signatures
    
    apt-cache policy app-protect-threat-campaigns  

advance Branch

  • This branch is based of main branch. This branch can be used to demonstrate custom log-format and custom policy in context to App Protect.
  • Toggle between various commented policy lines within nginx.conf to cover various scenarios.
  • Within this branch, App Protect related policies are also applied to \basic location block present inside the conf.d\example.com.conf file along with http context present inside the nginx.conf file.

advance_elk Branch

  • This branch is based of advance branch. This branch can be used to demostrate how App Protect logs can be streamed to an elasticsearch server and then consolidate logs can be viewed within Kibana dashboard.
  • As a prerequisite, please allocate sufficient virtual memory to docker desktop as elk consumes a significant amount of memory. (Recommended: Atleast 4GB memory)
  • The docker-compose file within this branch adds elk service which is used for Kibana dashboards.
  • The Kibana dashboard can be accessed using http://localhost:5601
  • For further details on how to setup ELK for NAP refer to https://github.com/f5devcentral/f5-waf-elk-dashboards repository.

About

This repository contains resources that can be used to demo Nginx App Protect within a Docker environment.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages