]> git.ipfire.org Git - people/teissler/ipfire-2.x.git/blame - lfs/suricata
perl-Module-Install: New package
[people/teissler/ipfire-2.x.git] / lfs / suricata
CommitLineData
67752a95
SS
1###############################################################################
2# #
3# IPFire.org - A linux based firewall #
30f306a3 4# Copyright (C) 2007-2022 IPFire Team <info@ipfire.org> #
67752a95
SS
5# #
6# This program is free software: you can redistribute it and/or modify #
7# it under the terms of the GNU General Public License as published by #
8# the Free Software Foundation, either version 3 of the License, or #
9# (at your option) any later version. #
10# #
11# This program is distributed in the hope that it will be useful, #
12# but WITHOUT ANY WARRANTY; without even the implied warranty of #
13# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the #
14# GNU General Public License for more details. #
15# #
16# You should have received a copy of the GNU General Public License #
17# along with this program. If not, see <http://www.gnu.org/licenses/>. #
18# #
19###############################################################################
20
21###############################################################################
22# Definitions
23###############################################################################
24
25include Config
26
30f306a3 27VER = 5.0.9
67752a95
SS
28
29THISAPP = suricata-$(VER)
30DL_FILE = $(THISAPP).tar.gz
31DL_FROM = $(URL_IPFIRE)
32DIR_APP = $(DIR_SRC)/$(THISAPP)
33TARGET = $(DIR_INFO)/$(THISAPP)
aa81aaf8 34
67752a95
SS
35###############################################################################
36# Top-level Rules
37###############################################################################
38
39objects = $(DL_FILE)
40
41$(DL_FILE) = $(DL_FROM)/$(DL_FILE)
42
30f306a3 43$(DL_FILE)_BLAKE2 = 02ab99585233a47b1577e55060ba1141c339718e5bd39b6f4d38bb9384fd459aae353f313083048128507f9023a8bcfea3e5a5bcc9ea0c75cfc9c288ca9db6b6
67752a95
SS
44
45install : $(TARGET)
46
47check : $(patsubst %,$(DIR_CHK)/%,$(objects))
48
49download :$(patsubst %,$(DIR_DL)/%,$(objects))
50
9a7e4d85 51b2 : $(subst %,%_BLAKE2,$(objects))
67752a95
SS
52
53###############################################################################
9a7e4d85 54# Downloading, checking, b2sum
67752a95
SS
55###############################################################################
56
57$(patsubst %,$(DIR_CHK)/%,$(objects)) :
58 @$(CHECK)
59
60$(patsubst %,$(DIR_DL)/%,$(objects)) :
61 @$(LOAD)
62
9a7e4d85
PM
63$(subst %,%_BLAKE2,$(objects)) :
64 @$(B2SUM)
67752a95
SS
65
66###############################################################################
67# Installation Details
68###############################################################################
69
70$(TARGET) : $(patsubst %,$(DIR_DL)/%,$(objects))
71 @$(PREBUILD)
72 @rm -rf $(DIR_APP) && cd $(DIR_SRC) && tar zxf $(DIR_DL)/$(DL_FILE)
30f306a3
MF
73 cd $(DIR_APP) && patch -Np1 < $(DIR_SRC)/src/patches/suricata/suricata-5.0-stream-tcp-Handle-retransmitted-SYN-with-TSval.patch
74 cd $(DIR_APP) && patch -Np1 < $(DIR_SRC)/src/patches/suricata/suricata-disable-sid-2210059.patch
75 cd $(DIR_APP) && patch -Np1 < $(DIR_SRC)/src/patches/suricata/suricata-5.0.8-fix-level1-cache-line-size-detection.patch
66970ccb 76 cd $(DIR_APP) && LDFLAGS="$(LDFLAGS)" ./configure \
67752a95
SS
77 --prefix=/usr \
78 --sysconfdir=/etc \
79 --localstatedir=/var \
80 --enable-gccprotect \
81 --disable-gccmarch-native \
82 --enable-non-bundled-htp \
83 --enable-nfqueue \
e8b1b397
SS
84 --disable-static \
85 --disable-python \
21a83823
EK
86 --with-libjansson-libraries=/usr/lib \
87 --with-libjansson-includes=/usr/include \
1a65ea1b
SS
88 --disable-suricata-update \
89 --enable-rust
90
67752a95
SS
91 cd $(DIR_APP) && make $(MAKETUNING)
92 cd $(DIR_APP) && make install
93 cd $(DIR_APP) && make install-conf
d2e6bf6e
SS
94
95 # Remove default suricata config file.
96 rm -rvf /etc/suricata/suricata.yaml
97
98 # Install IPFire related config file.
4c6d6c1e 99 install -m 0644 $(DIR_SRC)/config/suricata/suricata.yaml /etc/suricata
21cab141
SS
100
101 # Create emtpy rules directory.
102 -mkdir -p /var/lib/suricata
103
d44d4ccf
SS
104 # Create empty cache directory.
105 -mkdir -p /var/cache/suricata
106
21cab141
SS
107 # Move config files for references, threshold and classification
108 # to the rules directory.
5a3e97b8 109 rm -rfv /etc/suricata/*.config
728f3d2e 110
9e9d89ae
SS
111 # Set correct ownership for the classifiction config file.
112 # (File has to be writeable for the nobody user)
113 chown nobody:nobody /usr/share/suricata/classification.config
114
0d99255c
SS
115 # Create empty threshold config file.
116 touch /usr/share/suricata/threshold.config
117
118 # Set correct ownership for the threshold.config file.
119 chown nobody:nobody /usr/share/suricata/threshold.config
120
728f3d2e
SS
121 # Set correct ownership for /var/lib/suricata and the
122 # contained files
123 chown -R nobody:nobody /var/lib/suricata
89a12b38 124
d44d4ccf
SS
125 # Set correct ownership for the cache directory.
126 chown nobody:nobody /var/cache/suricata
127
21cab141 128 # Create logging directory.
67752a95 129 -mkdir -p /var/log/suricata
21cab141 130
f717b1dc
SS
131 # Set correct ownership for /var/log/suricata.
132 chown suricata:suricata /var/log/suricata
133
40811ff3
PM
134 # Install converter script needed for Core Update 167
135 install -m 0755 $(DIR_SRC)/config/suricata/convert-ids-backend-files /usr/sbin/convert-ids-backend-files
136
67752a95
SS
137 @rm -rf $(DIR_APP)
138 @$(POSTBUILD)