mirror of
				https://github.com/openwrt/packages.git
				synced 2025-11-04 08:09:39 +00:00 
			
		
		
		
	Running as a dedicated user is better from both a security and an isolation perspective than running as root. Signed-off-by: John Audia <therealgraysky@proton.me>
		
			
				
	
	
		
			112 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			Makefile
		
	
	
	
	
	
			
		
		
	
	
			112 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			Makefile
		
	
	
	
	
	
#
 | 
						|
# This is free software, licensed under the GNU General Public License v2.
 | 
						|
# See /LICENSE for more information.
 | 
						|
#
 | 
						|
 | 
						|
include $(TOPDIR)/rules.mk
 | 
						|
 | 
						|
PKG_NAME:=snort3
 | 
						|
PKG_VERSION:=3.9.6.0
 | 
						|
PKG_RELEASE:=2
 | 
						|
 | 
						|
PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.gz
 | 
						|
PKG_SOURCE_URL:=https://codeload.github.com/snort3/snort3/tar.gz/$(PKG_VERSION)?
 | 
						|
PKG_HASH:=2335678bc5ff4f876dcdb6985407a5312b0f3bb470da29e2926f57f942ce3b94
 | 
						|
 | 
						|
PKG_MAINTAINER:=W. Michael Petullo <mike@flyn.org>, John Audia <therealgraysky@proton.me>
 | 
						|
PKG_LICENSE:=GPL-2.0-only
 | 
						|
PKG_LICENSE_FILES:=COPYING
 | 
						|
PKG_CPE_ID:=cpe:/a:snort:snort
 | 
						|
 | 
						|
include $(INCLUDE_DIR)/package.mk
 | 
						|
include $(INCLUDE_DIR)/cmake.mk
 | 
						|
 | 
						|
define Package/snort3
 | 
						|
  SUBMENU:=Firewall
 | 
						|
  SECTION:=net
 | 
						|
  CATEGORY:=Network
 | 
						|
  DEPENDS:=+libstdcpp +libdaq3 +libdnet +libopenssl +libpcap +libpcre2 \
 | 
						|
    +libpthread +libuuid +zlib +libhwloc +USE_MUSL:libtirpc @HAS_LUAJIT_ARCH +luajit +libatomic \
 | 
						|
    +kmod-nft-queue +liblzma +ucode +ucode-mod-fs +ucode-mod-uci \
 | 
						|
    +PACKAGE_gperftools:gperftools \
 | 
						|
    +PACKAGE_vectorscan:vectorscan
 | 
						|
  USERID:=snort=975:snort=975
 | 
						|
  TITLE:=Lightweight Network Intrusion Detection System
 | 
						|
  URL:=http://www.snort.org/
 | 
						|
  MENU:=1
 | 
						|
endef
 | 
						|
 | 
						|
define Package/snort3/description
 | 
						|
  Snort is an open source network intrusion detection and prevention system.
 | 
						|
  It is capable of performing real-time traffic analysis, alerting, blocking
 | 
						|
  and packet logging on IP networks.  It utilizes a combination of protocol
 | 
						|
  analysis and pattern matching in order to detect anomalies, misuse and
 | 
						|
  attacks.
 | 
						|
 | 
						|
  Note:
 | 
						|
    When compiling from source, and if your target supports them, optionally
 | 
						|
    enable runtime dependencies for improved performance:
 | 
						|
      - gperftools
 | 
						|
      - vectorscan
 | 
						|
    These are not enabled by default and must be manually selected in menuconfig
 | 
						|
    to take advantage of their benefits.
 | 
						|
endef
 | 
						|
 | 
						|
CMAKE_OPTIONS += \
 | 
						|
	-DUSE_TIRPC=$(if $(CONFIG_USE_MUSL),ON,OFF) \
 | 
						|
	-DENABLE_STATIC_DAQ:BOOL=NO \
 | 
						|
	-DDAQ_INCLUDE_DIR=$(STAGING_DIR)/usr/include/daq3 \
 | 
						|
	-DDAQ_LIBRARIES_DIR_HINT:PATH=$(STAGING_DIR)/usr/lib/daq3 \
 | 
						|
	-DFLEX_INCLUDES:PATH=$(STAGING_DIR_HOST)/include \
 | 
						|
	-DENABLE_COREFILES:BOOL=NO \
 | 
						|
	-DENABLE_GDB:BOOL=NO \
 | 
						|
	-DMAKE_DOC:BOOL=NO \
 | 
						|
	-DMAKE_HTML_DOC:BOOL=NO \
 | 
						|
	-DMAKE_PDF_DOC:BOOL=NO \
 | 
						|
	-DMAKE_TEXT_DOC:BOOL=NO \
 | 
						|
	-DHAVE_LIBUNWIND=OFF \
 | 
						|
	-DHAVE_LZMA=ON \
 | 
						|
	-DENABLE_TCMALLOC=$(if $(CONFIG_PACKAGE_gperftools),ON,OFF) \
 | 
						|
	-DENABLE_HYPERSCAN=$(if $(CONFIG_PACKAGE_vectorscan),ON,OFF) \
 | 
						|
	$(if $(CONFIG_PACKAGE_vectorscan),-DHS_INCLUDE_DIRS=$(STAGING_DIR)/usr/include/hs)
 | 
						|
 | 
						|
TARGET_CFLAGS += -I$(STAGING_DIR)/usr/include/daq3
 | 
						|
 | 
						|
define Package/snort3/conffiles
 | 
						|
/etc/config/snort
 | 
						|
/etc/snort/
 | 
						|
endef
 | 
						|
 | 
						|
define Package/snort3/install
 | 
						|
	$(INSTALL_DIR) $(1)/usr/bin
 | 
						|
	$(INSTALL_BIN) $(PKG_INSTALL_DIR)/usr/bin/snort $(1)/usr/bin/
 | 
						|
	$(INSTALL_BIN) $(PKG_INSTALL_DIR)/usr/bin/snort2lua $(1)/usr/bin/
 | 
						|
	$(INSTALL_BIN) $(PKG_INSTALL_DIR)/usr/bin/u2{boat,spewfoo} $(1)/usr/bin/
 | 
						|
	$(INSTALL_BIN) ./files/snort-{mgr,rules} $(1)/usr/bin/
 | 
						|
 | 
						|
	$(INSTALL_DIR) $(1)/usr/lib/snort
 | 
						|
	$(CP) $(PKG_INSTALL_DIR)/usr/lib/snort/daq/daq_{hext,file}.so $(1)/usr/lib/snort/
 | 
						|
 | 
						|
	$(INSTALL_DIR) $(1)/usr/share/lua
 | 
						|
	$(CP) $(PKG_INSTALL_DIR)/usr/include/snort/lua/snort_plugin.lua $(1)/usr/share/lua/
 | 
						|
 | 
						|
	$(INSTALL_DIR) $(1)/usr/share/snort
 | 
						|
	$(INSTALL_CONF) ./files/main.uc $(1)/usr/share/snort/
 | 
						|
 | 
						|
	$(INSTALL_DIR) $(1)/usr/share/snort/templates
 | 
						|
	$(INSTALL_CONF) ./files/{nftables,snort}.uc $(1)/usr/share/snort/templates/
 | 
						|
 | 
						|
	$(INSTALL_DIR) $(1)/etc/snort/{rules,lists,builtin_rules,so_rules}
 | 
						|
 | 
						|
	$(INSTALL_CONF) $(PKG_INSTALL_DIR)/usr/etc/snort/*.lua $(1)/etc/snort
 | 
						|
	$(INSTALL_CONF) $(PKG_INSTALL_DIR)/usr/etc/snort/file_magic.rules $(1)/etc/snort
 | 
						|
 | 
						|
	$(INSTALL_DIR) $(1)/etc/init.d
 | 
						|
	$(INSTALL_BIN) ./files/snort.init $(1)/etc/init.d/snort
 | 
						|
 | 
						|
	$(INSTALL_DIR) $(1)/etc/config
 | 
						|
	$(INSTALL_CONF) ./files/snort.config $(1)/etc/config/snort
 | 
						|
endef
 | 
						|
 | 
						|
$(eval $(call BuildPackage,snort3))
 |