ingress-nginx-helm/images/nginx/rootfs/build.sh

563 lines
17 KiB
Bash
Raw Normal View History

#!/bin/bash
2017-01-31 18:19:58 +00:00
# Copyright 2015 The Kubernetes Authors.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
2017-10-08 13:57:29 +00:00
set -o errexit
set -o nounset
set -o pipefail
2017-01-31 18:19:58 +00:00
2019-06-26 12:12:00 +00:00
export DEBIAN_FRONTEND=noninteractive
2019-08-14 21:57:27 +00:00
export OPENRESTY_VERSION=1.15.8.2
2019-05-26 02:02:47 +00:00
export NGINX_DIGEST_AUTH=cd8641886c873cf543255aeda20d23e4cd603d05
2017-01-31 18:19:58 +00:00
export NGINX_SUBSTITUTIONS=bc58cb11844bc42735bbaef7085ea86ace46d05b
2019-02-09 21:48:10 +00:00
export NGINX_OPENTRACING_VERSION=0.8.0
export OPENTRACING_CPP_VERSION=1.5.1
2018-08-17 15:23:24 +00:00
export ZIPKIN_CPP_VERSION=0.5.2
2019-02-09 21:48:10 +00:00
export JAEGER_VERSION=cdfaf5bb25ff5f8ec179fd548e6c7c2ade9a6a09
export MSGPACK_VERSION=3.1.1
export DATADOG_CPP_VERSION=1.0.1
export MODSECURITY_VERSION=d7101e13685efd7e7c9f808871b202656a969f4b
export MODSECURITY_LIB_VERSION=3.0.3
export OWASP_MODSECURITY_CRS_VERSION=3.1.0
2019-06-22 23:18:24 +00:00
export LUA_BRIDGE_TRACER_VERSION=da8889d872dbea9864f45ed8c04680a01a9dd2e6
2019-05-26 02:02:47 +00:00
export NGINX_INFLUXDB_VERSION=5b09391cb7b9a889687c0aa67964c06a2d933e8b
2018-10-28 20:26:31 +00:00
export GEOIP2_VERSION=3.2
2018-08-04 12:02:20 +00:00
export NGINX_AJP_VERSION=bf6cd93f2098b59260de8d494f0f4b1f11a84627
2019-06-22 23:18:24 +00:00
export RESTY_LUAROCKS_VERSION=3.1.3
2019-06-25 10:58:27 +00:00
export LUA_RESTY_BALANCER_VERSION=0.03
2017-01-31 18:19:58 +00:00
export BUILD_PATH=/tmp/build
2017-11-12 03:34:40 +00:00
ARCH=$(uname -m)
2017-01-31 18:19:58 +00:00
get_src()
{
hash="$1"
url="$2"
f=$(basename "$url")
2019-02-20 13:09:25 +00:00
echo "Downloading $url"
2017-01-31 18:19:58 +00:00
curl -sSL "$url" -o "$f"
echo "$hash $f" | sha256sum -c - || exit 10
tar xzf "$f"
rm -rf "$f"
}
apt-get update && apt-get dist-upgrade -y
2017-01-31 18:19:58 +00:00
# install required packages to build
2017-11-12 03:34:40 +00:00
clean-install \
2017-01-31 18:19:58 +00:00
bash \
build-essential \
curl ca-certificates \
libgeoip1 \
libgeoip-dev \
patch \
libpcre3 \
libpcre3-dev \
2018-01-17 11:55:05 +00:00
libssl-dev \
2017-01-31 18:19:58 +00:00
zlib1g \
zlib1g-dev \
libaio1 \
libaio-dev \
openssl \
2017-09-17 21:30:44 +00:00
libperl-dev \
cmake \
2017-10-08 13:57:29 +00:00
util-linux \
lmdb-utils \
2017-10-08 13:57:29 +00:00
wget \
2017-09-17 21:30:44 +00:00
libcurl4-openssl-dev \
2018-07-21 22:12:29 +00:00
libprotobuf-dev protobuf-compiler \
libz-dev \
2017-10-10 18:16:15 +00:00
procps \
git g++ pkgconf flex bison doxygen libyajl-dev liblmdb-dev libtool dh-autoreconf libxml2 libpcre++-dev libxml2-dev \
python \
libmaxminddb-dev \
2018-08-04 12:02:20 +00:00
dumb-init \
2018-08-14 13:32:26 +00:00
gdb \
bc \
2019-06-22 23:18:24 +00:00
unzip \
nano \
2019-06-26 12:12:00 +00:00
ssdeep \
2017-11-12 03:34:40 +00:00
|| exit 1
2017-01-31 18:19:58 +00:00
2019-06-26 12:12:00 +00:00
# https://www.mail-archive.com/debian-bugs-dist@lists.debian.org/msg1667178.html
if [[ ${ARCH} == "armv7l" ]]; then
echo "Fixing ca-certificates"
touch /etc/ssl/certs/ca-certificates.crt
c_rehash
fi
mkdir -p /etc/nginx
# Get the GeoIP data
GEOIP_FOLDER=/etc/nginx/geoip
mkdir -p $GEOIP_FOLDER
2018-10-28 20:27:18 +00:00
function geoip2_get {
wget -O $GEOIP_FOLDER/$1.tar.gz $2 || { echo "Could not download $1, exiting." ; exit 1; }
mkdir $GEOIP_FOLDER/$1 \
&& tar xf $GEOIP_FOLDER/$1.tar.gz -C $GEOIP_FOLDER/$1 --strip-components 1 \
&& mv $GEOIP_FOLDER/$1/$1.mmdb $GEOIP_FOLDER/$1.mmdb \
&& rm -rf $GEOIP_FOLDER/$1 \
&& rm -rf $GEOIP_FOLDER/$1.tar.gz
2018-10-28 20:27:18 +00:00
}
2018-07-30 21:33:36 +00:00
2018-10-28 20:27:18 +00:00
geoip2_get "GeoLite2-City" "http://geolite.maxmind.com/download/geoip/database/GeoLite2-City.tar.gz"
geoip2_get "GeoLite2-ASN" "http://geolite.maxmind.com/download/geoip/database/GeoLite2-ASN.tar.gz"
2017-09-17 21:30:44 +00:00
2017-11-12 03:34:40 +00:00
mkdir --verbose -p "$BUILD_PATH"
cd "$BUILD_PATH"
2017-01-31 18:19:58 +00:00
# download, verify and extract the source files
2019-06-22 23:18:24 +00:00
get_src 89a1238ca177692d6903c0adbea5bdf2a0b82c383662a73c03ebf5ef9f570842 \
"https://openresty.org/download/openresty-$OPENRESTY_VERSION.tar.gz"
2017-01-31 18:19:58 +00:00
2019-05-26 02:02:47 +00:00
get_src fe683831f832aae4737de1e1026a4454017c2d5f98cb88b08c5411dc380062f8 \
2017-01-31 18:19:58 +00:00
"https://github.com/atomx/nginx-http-auth-digest/archive/$NGINX_DIGEST_AUTH.tar.gz"
get_src 618551948ab14cac51d6e4ad00452312c7b09938f59ebff4f93875013be31f2d \
2017-01-31 18:19:58 +00:00
"https://github.com/yaoweibin/ngx_http_substitutions_filter_module/archive/$NGINX_SUBSTITUTIONS.tar.gz"
2019-02-09 21:48:10 +00:00
get_src b2159297814d5df153cf45f355bcd8ffdb71f2468e8149ad549d4f9c0cdc81ad \
"https://github.com/opentracing-contrib/nginx-opentracing/archive/v$NGINX_OPENTRACING_VERSION.tar.gz"
2017-09-17 21:30:44 +00:00
2019-02-09 21:48:10 +00:00
get_src 015c4187f7a6426a2b5196f0ccd982aa87f010cf61f507ae3ce5c90523f92301 \
2017-10-24 20:49:30 +00:00
"https://github.com/opentracing/opentracing-cpp/archive/v$OPENTRACING_CPP_VERSION.tar.gz"
2017-09-17 21:30:44 +00:00
2018-08-17 15:23:24 +00:00
get_src 30affaf0f3a84193f7127cc0135da91773ce45d902414082273dae78914f73df \
2017-10-24 20:49:30 +00:00
"https://github.com/rnburn/zipkin-cpp-opentracing/archive/v$ZIPKIN_CPP_VERSION.tar.gz"
2017-09-17 21:30:44 +00:00
get_src 5c8d25e68fb852f61489b669aebb7bd8ca8c88ebb5e5f969212fcceff3ee2d0b \
"https://github.com/SpiderLabs/ModSecurity-nginx/archive/$MODSECURITY_VERSION.tar.gz"
2019-02-09 21:48:10 +00:00
get_src 3183450d897baa9309347c8617edc0c97c5b29ffc32bd2d12f498edf2dcbeffa \
2018-08-10 21:33:30 +00:00
"https://github.com/jaegertracing/jaeger-client-cpp/archive/$JAEGER_VERSION.tar.gz"
2017-01-31 18:19:58 +00:00
get_src bda49f996a73d2c6080ff0523e7b535917cd28c8a79c3a5da54fc29332d61d1e \
"https://github.com/msgpack/msgpack-c/archive/cpp-$MSGPACK_VERSION.tar.gz"
get_src f7fb2ad541f812c36fd78f9a38e4582d87dadb563ab80bee3f7c3a2132a425c5 \
"https://github.com/DataDog/dd-opentracing-cpp/archive/v$DATADOG_CPP_VERSION.tar.gz"
2019-06-22 23:18:24 +00:00
get_src f5470132d8756eef293833e30508926894883924a445e3b9a07c869d26d4706d \
"https://github.com/opentracing/lua-bridge-tracer/archive/$LUA_BRIDGE_TRACER_VERSION.tar.gz"
2018-03-03 02:02:17 +00:00
2019-05-26 02:02:47 +00:00
get_src 1af5a5632dc8b00ae103d51b7bf225de3a7f0df82f5c6a401996c080106e600e \
"https://github.com/influxdata/nginx-influxdb-module/archive/$NGINX_INFLUXDB_VERSION.tar.gz"
2018-10-28 20:26:31 +00:00
get_src 15bd1005228cf2c869a6f09e8c41a6aaa6846e4936c473106786ae8ac860fab7 \
2018-07-30 21:33:36 +00:00
"https://github.com/leev/ngx_http_geoip2_module/archive/$GEOIP2_VERSION.tar.gz"
2018-03-03 02:02:17 +00:00
2018-08-04 12:02:20 +00:00
get_src 5f629a50ba22347c441421091da70fdc2ac14586619934534e5a0f8a1390a950 \
"https://github.com/yaoweibin/nginx_ajp_module/archive/$NGINX_AJP_VERSION.tar.gz"
2019-06-22 23:18:24 +00:00
get_src c573435f495aac159e34eaa0a3847172a2298eb6295fcdc35d565f9f9b990513 \
"https://luarocks.github.io/luarocks/releases/luarocks-${RESTY_LUAROCKS_VERSION}.tar.gz"
2019-06-25 10:58:27 +00:00
get_src 82209d5a5d9545c6dde3db7857f84345db22162fdea9743d5e2b2094d8d407f8 \
"https://github.com/openresty/lua-resty-balancer/archive/v${LUA_RESTY_BALANCER_VERSION}.tar.gz"
2018-03-03 02:02:17 +00:00
# improve compilation times
CORES=$(($(grep -c ^processor /proc/cpuinfo) - 0))
export MAKEFLAGS=-j${CORES}
export CTEST_BUILD_FLAGS=${MAKEFLAGS}
export HUNTER_JOBS_NUMBER=${CORES}
2018-11-04 23:59:16 +00:00
export HUNTER_KEEP_PACKAGE_SOURCES=false
export HUNTER_USE_CACHE_SERVERS=true
2018-03-03 02:02:17 +00:00
2019-06-26 12:12:00 +00:00
if [[ ${ARCH} == "armv7l" ]]; then
export PCRE_DIR=/usr/lib/arm-linux-gnueabihf
fi
if [[ ${ARCH} == "x86_64" ]]; then
export PCRE_DIR=/usr/lib/x86_64-linux-gnu
fi
2018-10-10 13:14:07 +00:00
if [[ ${ARCH} == "aarch64" ]]; then
export PCRE_DIR=/usr/lib/aarch64-linux-gnu
fi
cd "$BUILD_PATH"
2018-03-03 02:02:17 +00:00
2019-06-22 23:18:24 +00:00
export PATH=$PATH:/usr/local/openresty/luajit
2018-09-12 00:55:35 +00:00
# install openresty-gdb-utils
cd /
git clone --depth=1 https://github.com/openresty/openresty-gdb-utils.git
cat > ~/.gdbinit << EOF
directory /openresty-gdb-utils
py import sys
py sys.path.append("/openresty-gdb-utils")
source luajit20.gdb
source ngx-lua.gdb
source luajit21.py
source ngx-raw-req.py
set python print-stack full
EOF
2017-09-17 21:30:44 +00:00
# build opentracing lib
2017-10-24 20:49:30 +00:00
cd "$BUILD_PATH/opentracing-cpp-$OPENTRACING_CPP_VERSION"
2017-09-17 21:30:44 +00:00
mkdir .build
cd .build
2018-07-21 22:12:29 +00:00
cmake -DCMAKE_BUILD_TYPE=Release \
2018-08-10 21:33:30 +00:00
-DCMAKE_CXX_FLAGS="-fPIC" \
-DBUILD_TESTING=OFF \
-DBUILD_MOCKTRACER=OFF \
..
2018-07-21 22:12:29 +00:00
2017-09-17 21:30:44 +00:00
make
make install
2019-06-26 12:12:00 +00:00
if [[ ${ARCH} != "armv7l" ]]; then
# build jaeger lib
cd "$BUILD_PATH/jaeger-client-cpp-$JAEGER_VERSION"
sed -i 's/-Werror/-Wno-psabi/' CMakeLists.txt
2018-07-21 22:12:29 +00:00
2019-06-26 12:12:00 +00:00
cat <<EOF > export.map
2018-07-30 21:33:36 +00:00
{
global:
OpenTracingMakeTracerFactory;
local: *;
};
2018-07-21 22:12:29 +00:00
EOF
2019-06-26 12:12:00 +00:00
mkdir .build
cd .build
2018-07-21 22:12:29 +00:00
2019-06-26 12:12:00 +00:00
cmake -DCMAKE_BUILD_TYPE=Release \
-DBUILD_TESTING=OFF \
-DJAEGERTRACING_BUILD_EXAMPLES=OFF \
-DJAEGERTRACING_BUILD_CROSSDOCK=OFF \
-DJAEGERTRACING_COVERAGE=OFF \
-DJAEGERTRACING_PLUGIN=ON \
-DHUNTER_CONFIGURATION_TYPES=Release \
-DJAEGERTRACING_WITH_YAML_CPP=ON ..
2018-07-21 22:12:29 +00:00
2019-06-26 12:12:00 +00:00
make
make install
2018-07-21 22:12:29 +00:00
2019-06-26 12:12:00 +00:00
export HUNTER_INSTALL_DIR=$(cat _3rdParty/Hunter/install-root-dir) \
2018-07-21 22:12:29 +00:00
2019-06-26 12:12:00 +00:00
mv libjaegertracing_plugin.so /usr/local/lib/libjaegertracing_plugin.so
fi
2017-09-17 21:30:44 +00:00
# build zipkin lib
2017-10-24 20:49:30 +00:00
cd "$BUILD_PATH/zipkin-cpp-opentracing-$ZIPKIN_CPP_VERSION"
2018-07-21 22:12:29 +00:00
2018-07-30 21:33:36 +00:00
cat <<EOF > export.map
{
global:
OpenTracingMakeTracerFactory;
local: *;
};
2018-07-21 22:12:29 +00:00
EOF
2017-09-17 21:30:44 +00:00
mkdir .build
cd .build
2018-07-21 22:12:29 +00:00
cmake -DCMAKE_BUILD_TYPE=Release \
-DBUILD_SHARED_LIBS=ON \
-DBUILD_PLUGIN=ON \
-DBUILD_TESTING=OFF ..
2018-07-21 22:12:29 +00:00
2017-09-17 21:30:44 +00:00
make
make install
# build msgpack lib
cd "$BUILD_PATH/msgpack-c-cpp-$MSGPACK_VERSION"
mkdir .build
cd .build
cmake -DCMAKE_BUILD_TYPE=Release \
-DCMAKE_CXX_FLAGS="-fPIC" \
-DBUILD_SHARED_LIBS=OFF \
-DBUILD_TESTING=OFF \
-DBUILD_MOCKTRACER=OFF \
..
make
make install
# build datadog lib
cd "$BUILD_PATH/dd-opentracing-cpp-$DATADOG_CPP_VERSION"
mkdir .build
cd .build
cmake ..
make
make install
# Get Brotli source and deps
2017-10-08 13:57:29 +00:00
cd "$BUILD_PATH"
git clone --depth=1 https://github.com/google/ngx_brotli.git
cd ngx_brotli
git submodule init
git submodule update
2017-10-08 13:57:29 +00:00
# build modsecurity library
cd "$BUILD_PATH"
git clone -b v$MODSECURITY_LIB_VERSION https://github.com/SpiderLabs/ModSecurity
cd ModSecurity/
git submodule init
git submodule update
sh build.sh
./configure --disable-doxygen-doc --disable-examples --disable-dependency-tracking
make
make install
2017-09-17 21:30:44 +00:00
mkdir -p /etc/nginx/modsecurity
cp modsecurity.conf-recommended /etc/nginx/modsecurity/modsecurity.conf
cp unicode.mapping /etc/nginx/modsecurity/unicode.mapping
# Download owasp modsecurity crs
cd /etc/nginx/
2019-06-22 23:18:24 +00:00
git clone -b v$OWASP_MODSECURITY_CRS_VERSION https://github.com/SpiderLabs/owasp-modsecurity-crs
cd owasp-modsecurity-crs
mv crs-setup.conf.example crs-setup.conf
mv rules/REQUEST-900-EXCLUSION-RULES-BEFORE-CRS.conf.example rules/REQUEST-900-EXCLUSION-RULES-BEFORE-CRS.conf
mv rules/RESPONSE-999-EXCLUSION-RULES-AFTER-CRS.conf.example rules/RESPONSE-999-EXCLUSION-RULES-AFTER-CRS.conf
cd ..
# OWASP CRS v3 rules
echo "
Include /etc/nginx/owasp-modsecurity-crs/crs-setup.conf
Include /etc/nginx/owasp-modsecurity-crs/rules/REQUEST-900-EXCLUSION-RULES-BEFORE-CRS.conf
Include /etc/nginx/owasp-modsecurity-crs/rules/REQUEST-901-INITIALIZATION.conf
Include /etc/nginx/owasp-modsecurity-crs/rules/REQUEST-903.9001-DRUPAL-EXCLUSION-RULES.conf
Include /etc/nginx/owasp-modsecurity-crs/rules/REQUEST-903.9002-WORDPRESS-EXCLUSION-RULES.conf
Include /etc/nginx/owasp-modsecurity-crs/rules/REQUEST-905-COMMON-EXCEPTIONS.conf
Include /etc/nginx/owasp-modsecurity-crs/rules/REQUEST-910-IP-REPUTATION.conf
Include /etc/nginx/owasp-modsecurity-crs/rules/REQUEST-911-METHOD-ENFORCEMENT.conf
Include /etc/nginx/owasp-modsecurity-crs/rules/REQUEST-912-DOS-PROTECTION.conf
Include /etc/nginx/owasp-modsecurity-crs/rules/REQUEST-913-SCANNER-DETECTION.conf
Include /etc/nginx/owasp-modsecurity-crs/rules/REQUEST-920-PROTOCOL-ENFORCEMENT.conf
Include /etc/nginx/owasp-modsecurity-crs/rules/REQUEST-921-PROTOCOL-ATTACK.conf
Include /etc/nginx/owasp-modsecurity-crs/rules/REQUEST-930-APPLICATION-ATTACK-LFI.conf
Include /etc/nginx/owasp-modsecurity-crs/rules/REQUEST-931-APPLICATION-ATTACK-RFI.conf
Include /etc/nginx/owasp-modsecurity-crs/rules/REQUEST-932-APPLICATION-ATTACK-RCE.conf
Include /etc/nginx/owasp-modsecurity-crs/rules/REQUEST-933-APPLICATION-ATTACK-PHP.conf
Include /etc/nginx/owasp-modsecurity-crs/rules/REQUEST-941-APPLICATION-ATTACK-XSS.conf
Include /etc/nginx/owasp-modsecurity-crs/rules/REQUEST-942-APPLICATION-ATTACK-SQLI.conf
Include /etc/nginx/owasp-modsecurity-crs/rules/REQUEST-943-APPLICATION-ATTACK-SESSION-FIXATION.conf
Include /etc/nginx/owasp-modsecurity-crs/rules/REQUEST-949-BLOCKING-EVALUATION.conf
Include /etc/nginx/owasp-modsecurity-crs/rules/RESPONSE-950-DATA-LEAKAGES.conf
Include /etc/nginx/owasp-modsecurity-crs/rules/RESPONSE-951-DATA-LEAKAGES-SQL.conf
Include /etc/nginx/owasp-modsecurity-crs/rules/RESPONSE-952-DATA-LEAKAGES-JAVA.conf
Include /etc/nginx/owasp-modsecurity-crs/rules/RESPONSE-953-DATA-LEAKAGES-PHP.conf
Include /etc/nginx/owasp-modsecurity-crs/rules/RESPONSE-954-DATA-LEAKAGES-IIS.conf
Include /etc/nginx/owasp-modsecurity-crs/rules/RESPONSE-959-BLOCKING-EVALUATION.conf
Include /etc/nginx/owasp-modsecurity-crs/rules/RESPONSE-980-CORRELATION.conf
Include /etc/nginx/owasp-modsecurity-crs/rules/RESPONSE-999-EXCLUSION-RULES-AFTER-CRS.conf
" > /etc/nginx/owasp-modsecurity-crs/nginx-modsecurity.conf
2017-01-31 18:19:58 +00:00
# build nginx
2019-06-22 23:18:24 +00:00
cd "$BUILD_PATH/openresty-$OPENRESTY_VERSION"
WITH_FLAGS="--with-debug \
2018-06-14 20:12:23 +00:00
--with-compat \
--with-pcre-jit \
--with-http_ssl_module \
--with-http_stub_status_module \
--with-http_realip_module \
--with-http_auth_request_module \
--with-http_addition_module \
--with-http_dav_module \
--with-http_geoip_module \
--with-http_gzip_static_module \
--with-http_sub_module \
--with-http_v2_module \
--with-stream \
--with-stream_ssl_module \
--with-stream_ssl_preread_module \
--with-threads \
2018-09-25 19:18:27 +00:00
--with-http_secure_link_module \
2019-06-22 23:18:24 +00:00
--with-http_gunzip_module \
--with-md5-asm \
--with-sha1-asm \
-j${CORES} "
2018-03-03 02:02:17 +00:00
# "Combining -flto with -g is currently experimental and expected to produce unexpected results."
# https://gcc.gnu.org/onlinedocs/gcc/Optimize-Options.html
2018-07-30 21:33:36 +00:00
CC_OPT="-g -Og -fPIE -fstack-protector-strong \
-Wformat \
-Werror=format-security \
-Wno-deprecated-declarations \
-fno-strict-aliasing \
-D_FORTIFY_SOURCE=2 \
--param=ssp-buffer-size=4 \
-DTCP_FASTOPEN=23 \
-fPIC \
-Wno-cast-function-type"
2019-06-26 12:12:00 +00:00
LD_OPT="-fPIE -fPIC -pie -Wl,-z,relro -Wl,-z,now"
if [[ ${ARCH} != "armv7l" ]]; then
CC_OPT+=" -I$HUNTER_INSTALL_DIR/include"
LD_OPT+=" -L$HUNTER_INSTALL_DIR/lib"
fi
if [[ ${ARCH} != "aarch64" ]]; then
WITH_FLAGS+=" --with-file-aio"
fi
2018-03-03 02:02:17 +00:00
if [[ ${ARCH} == "x86_64" ]]; then
2018-03-03 02:02:17 +00:00
CC_OPT+=' -m64 -mtune=native'
fi
2019-06-22 23:18:24 +00:00
WITH_MODULES="--add-module=$BUILD_PATH/nginx-http-auth-digest-$NGINX_DIGEST_AUTH \
2017-10-08 13:57:29 +00:00
--add-module=$BUILD_PATH/ngx_http_substitutions_filter_module-$NGINX_SUBSTITUTIONS \
--add-module=$BUILD_PATH/nginx-influxdb-module-$NGINX_INFLUXDB_VERSION \
--add-dynamic-module=$BUILD_PATH/nginx-opentracing-$NGINX_OPENTRACING_VERSION/opentracing \
--add-dynamic-module=$BUILD_PATH/ModSecurity-nginx-$MODSECURITY_VERSION \
--add-dynamic-module=$BUILD_PATH/ngx_http_geoip2_module-${GEOIP2_VERSION} \
2018-08-04 12:02:20 +00:00
--add-module=$BUILD_PATH/nginx_ajp_module-${NGINX_AJP_VERSION} \
--add-module=$BUILD_PATH/ngx_brotli"
2017-11-12 03:34:40 +00:00
2017-01-31 18:19:58 +00:00
./configure \
${WITH_FLAGS} \
2017-01-31 18:19:58 +00:00
--without-mail_pop3_module \
--without-mail_smtp_module \
--without-mail_imap_module \
--without-http_uwsgi_module \
--without-http_scgi_module \
--with-cc-opt="${CC_OPT}" \
2017-09-17 21:30:44 +00:00
--with-ld-opt="${LD_OPT}" \
2018-08-04 12:02:20 +00:00
--user=www-data \
--group=www-data \
${WITH_MODULES}
2018-10-10 12:17:01 +00:00
2018-08-04 12:02:20 +00:00
make || exit 1
make install || exit 1
2018-07-21 22:12:29 +00:00
2019-06-22 23:18:24 +00:00
cd "$BUILD_PATH/luarocks-${RESTY_LUAROCKS_VERSION}"
./configure \
--prefix=/usr/local/openresty/luajit \
--with-lua=/usr/local/openresty/luajit \
--lua-suffix=jit-2.1.0-beta3 \
--with-lua-include=/usr/local/openresty/luajit/include/luajit-2.1
make || exit 1
make install || exit 1
export PATH=$PATH:/usr/local/openresty/luajit/bin
cd /usr/local/openresty
# build and install lua-resty-waf with dependencies
export LUA_LIB_DIR=/usr/local/openresty/lualib
2019-06-26 12:12:00 +00:00
export LUA_INCLUDE_DIR=/tmp/build/openresty-$OPENRESTY_VERSION/build/luajit-root/usr/local/openresty/luajit/include/luajit-2.1
2019-06-22 23:18:24 +00:00
luarocks install lrexlib-pcre 2.7.2-1 PCRE_LIBDIR=${PCRE_DIR}
luarocks install lua-resty-iputils 0.3.0-1
luarocks install lua-resty-cookie 0.1.0-1
2019-06-25 10:58:27 +00:00
cd "$BUILD_PATH/lua-resty-balancer-$LUA_RESTY_BALANCER_VERSION"
make
make install
2019-06-22 23:18:24 +00:00
ln -s $LUA_INCLUDE_DIR /usr/include/lua5.1
2019-06-26 12:12:00 +00:00
if [[ ${ARCH} != "armv7l" ]]; then
/install_lua_resty_waf.sh
fi
2019-06-22 23:18:24 +00:00
# build Lua bridge tracer
cd "$BUILD_PATH/lua-bridge-tracer-$LUA_BRIDGE_TRACER_VERSION"
mkdir .build
cd .build
cmake ..
make
make install
2017-01-31 18:19:58 +00:00
echo "Cleaning..."
cd /
apt-mark unmarkauto \
bash \
curl ca-certificates \
libgeoip1 \
libpcre3 \
zlib1g \
libaio1 \
2018-08-14 13:32:26 +00:00
gdb \
2017-01-31 18:19:58 +00:00
geoip-bin \
2017-10-08 13:57:29 +00:00
libyajl2 liblmdb0 libxml2 libpcre++ \
gzip \
2017-01-31 18:19:58 +00:00
openssl
apt-get remove -y --purge \
build-essential \
libgeoip-dev \
libpcre3-dev \
libssl-dev \
zlib1g-dev \
libaio-dev \
linux-libc-dev \
2017-10-08 13:57:29 +00:00
cmake \
2017-10-10 18:16:15 +00:00
wget \
2018-07-30 21:33:36 +00:00
patch \
protobuf-compiler \
2018-08-10 21:33:30 +00:00
python \
xz-utils \
2018-11-04 23:59:16 +00:00
bc \
2017-11-12 03:34:40 +00:00
git g++ pkgconf flex bison doxygen libyajl-dev liblmdb-dev libgeoip-dev libtool dh-autoreconf libpcre++-dev libxml2-dev
2017-01-31 18:19:58 +00:00
apt-get autoremove -y
rm -rf "$BUILD_PATH"
rm -Rf /usr/share/man /usr/share/doc
rm -rf /tmp/* /var/tmp/*
rm -rf /var/lib/apt/lists/*
rm -rf /var/cache/apt/archives/*
2017-10-08 13:57:29 +00:00
rm -rf /usr/local/modsecurity/bin
rm -rf /usr/local/modsecurity/include
rm -rf /usr/local/modsecurity/lib/libmodsecurity.a
2018-07-30 21:33:36 +00:00
rm -rf /root/.cache
2018-04-04 15:18:17 +00:00
rm -rf /etc/nginx/owasp-modsecurity-crs/.git
rm -rf /etc/nginx/owasp-modsecurity-crs/util/regression-tests
rm -rf $HOME/.hunter
2019-06-22 23:18:24 +00:00
rm -rf $LUA_INCLUDE_DIR /usr/include/lua5.1
# update image permissions
writeDirs=( \
/etc/nginx \
2019-06-22 23:18:24 +00:00
/usr/local/openresty/nginx \
/opt/modsecurity/var/log \
/opt/modsecurity/var/upload \
/opt/modsecurity/var/audit \
);
for dir in "${writeDirs[@]}"; do
mkdir -p ${dir};
chown -R www-data.www-data ${dir};
done