ASR_BASE
Change-Id: Icf3719cc0afe3eeb3edc7fa80a2eb5199ca9dda1
diff --git a/external/subpack/net/crowdsec/files/crowdsec.config b/external/subpack/net/crowdsec/files/crowdsec.config
new file mode 100644
index 0000000..2cfe575
--- /dev/null
+++ b/external/subpack/net/crowdsec/files/crowdsec.config
@@ -0,0 +1,4 @@
+config crowdsec 'crowdsec'
+ option data_dir '/srv/crowdsec/data'
+ option db_path '/srv/crowdsec/data/crowdsec.db'
+
diff --git a/external/subpack/net/crowdsec/files/crowdsec.defaults b/external/subpack/net/crowdsec/files/crowdsec.defaults
new file mode 100644
index 0000000..2350616
--- /dev/null
+++ b/external/subpack/net/crowdsec/files/crowdsec.defaults
@@ -0,0 +1,26 @@
+#!/bin/sh
+
+CONFIG=/etc/crowdsec/config.yaml
+data_dir=`uci get "crowdsec.crowdsec.data_dir"`
+sed -i "s,^\(\s*data_dir\s*:\s*\).*\$,\1$data_dir," $CONFIG
+db_path=`uci get "crowdsec.crowdsec.db_path"`
+sed -i "s,^\(\s*db_path\s*:\s*\).*\$,\1$db_path," $CONFIG
+
+# Create data dir & permissions if needed
+if [ ! -d "${data_dir}" ]; then
+ mkdir -m 0755 -p "${data_dir}"
+fi;
+
+if grep -q "login:" /etc/crowdsec/local_api_credentials.yaml; then
+ echo local API already registered...
+else
+ cscli -c /etc/crowdsec/config.yaml machines add -a -f /etc/crowdsec/local_api_credentials.yaml
+fi
+if [ -s /etc/crowdsec/online_api_credentials.yaml ]; then
+ echo online API already registered...
+else
+ cscli -c /etc/crowdsec/config.yaml capi register -f /etc/crowdsec/online_api_credentials.yaml
+fi
+cscli hub update && cscli collections install crowdsecurity/linux && cscli parsers install crowdsecurity/whitelists && cscli hub upgrade
+
+exit 0
diff --git a/external/subpack/net/crowdsec/files/crowdsec.initd b/external/subpack/net/crowdsec/files/crowdsec.initd
new file mode 100755
index 0000000..9896275
--- /dev/null
+++ b/external/subpack/net/crowdsec/files/crowdsec.initd
@@ -0,0 +1,44 @@
+#!/bin/sh /etc/rc.common
+# Copyright (C) 2021-2022 Gerald Kerma <gandalf@gk2.net>
+
+START=99
+USE_PROCD=1
+NAME=crowdsec
+PROG=/usr/bin/crowdsec
+CONFIG=/etc/crowdsec/config.yaml
+RUNCONFDIR=/srv/crowdsec/data
+VARCONFIGDIR=/var/etc/crowdsec
+VARCONFIG=/var/etc/crowdsec/config.yaml
+
+service_triggers() {
+ procd_add_reload_trigger crowdsec
+}
+
+init_config() {
+ config_load crowdsec
+ config_get data_dir crowdsec data_dir "${RUNCONFDIR}"
+ config_get db_path crowdsec db_path "${RUNCONFDIR}/crowdsec.db"
+
+ # Create tmp dir & permissions if needed
+ if [ ! -d "${VARCONFIGDIR}" ]; then
+ mkdir -m 0755 -p "${VARCONFIGDIR}"
+ fi;
+
+ cp $CONFIG $VARCONFIG
+
+ sed -i "s,^\(\s*data_dir\s*:\s*\).*\$,\1$data_dir," $VARCONFIG
+ sed -i "s,^\(\s*db_path\s*:\s*\).*\$,\1$db_path," $VARCONFIG
+
+ # Create data dir & permissions if needed
+ if [ ! -d "${RUNCONFDIR}" ]; then
+ mkdir -m 0755 -p "${RUNCONFDIR}"
+ fi;
+}
+
+start_service() {
+ init_config
+
+ procd_open_instance
+ procd_set_param command "$PROG" -c "$VARCONFIG"
+ procd_close_instance
+}