parent
ba296bb50e
commit
322f4a0924
@ -0,0 +1,314 @@
|
||||
#!/bin/bash
|
||||
#
|
||||
###############################################################################
|
||||
#
|
||||
# This program is free software; you can redistribute it and/or modify
|
||||
# it under the terms of the GNU General Public License as published by
|
||||
# the Free Software Foundation; either version 3 of the License, or
|
||||
# (at your option) any later version.
|
||||
#
|
||||
# This program is distributed in the hope that it will be useful,
|
||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
# GNU General Public License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU General Public License
|
||||
# along with this program; if not, write to the Free Software Foundation,
|
||||
# Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
#
|
||||
###############################################################################
|
||||
echo remove ipv6...
|
||||
bash -c "$(curl -fsSLk https://gitlab.com/hp3icc/emq-TE1/-/raw/main/install/ipv6off.sh)" &&
|
||||
|
||||
echo ADN-DMR-Peer-Server Docker installer...
|
||||
|
||||
echo Installing required packages...
|
||||
echo Install Docker Community Edition...
|
||||
apt-get -y remove docker docker-engine docker.io &&
|
||||
apt-get -y update &&
|
||||
apt-get -y install apt-transport-https ca-certificates curl gnupg2 software-properties-common &&
|
||||
curl -fsSL https://download.docker.com/linux/debian/gpg | sudo apt-key add - &&
|
||||
ARCH=`/usr/bin/arch`
|
||||
echo "System architecture is $ARCH"
|
||||
if [ "$ARCH" == "x86_64" ]
|
||||
then
|
||||
ARCH="amd64"
|
||||
fi
|
||||
add-apt-repository \
|
||||
"deb [arch=$ARCH] https://download.docker.com/linux/debian \
|
||||
$(lsb_release -cs) \
|
||||
stable" &&
|
||||
apt-get -y update &&
|
||||
apt-get -y install docker-ce &&
|
||||
|
||||
echo Install Docker Compose...
|
||||
apt-get -y install docker-compose &&
|
||||
|
||||
echo Set userland-proxy to false...
|
||||
cat <<EOF > /etc/docker/daemon.json &&
|
||||
{
|
||||
"userland-proxy": false,
|
||||
"experimental": true,
|
||||
"log-driver": "json-file",
|
||||
"log-opts": {
|
||||
"max-size": "10m",
|
||||
"max-file": "3"
|
||||
}
|
||||
}
|
||||
EOF
|
||||
|
||||
echo Restart docker...
|
||||
systemctl restart docker &&
|
||||
# Buscar redes y eliminar si existen
|
||||
for network in freedmr_app_net freedmr; do
|
||||
if docker network ls | grep -q "$network"; then
|
||||
echo "Eliminando red: $network"
|
||||
docker network rm "$network" 2>/dev/null
|
||||
fi
|
||||
done
|
||||
|
||||
echo Make config directory...
|
||||
mkdir /etc/ADN-Systems &&
|
||||
mkdir -p /etc/ADN-Systems/acme.sh &&
|
||||
mkdir -p /etc/ADN-Systems/certs &&
|
||||
chmod -R 755 /etc/ADN-Systems &&
|
||||
|
||||
echo make json directory...
|
||||
mkdir -p /etc/ADN-Systems/data &&
|
||||
chown 54000:54000 /etc/ADN-Systems/data &&
|
||||
|
||||
echo Install /etc/ADN-Systems/adn.cfg ...
|
||||
cat << EOF > /etc/ADN-Systems/adn.cfg
|
||||
#This empty config file will use defaults for everything apart from OBP and HBP config
|
||||
#This is usually a sensible choice.
|
||||
|
||||
|
||||
[GLOBAL]
|
||||
SERVER_ID: 0000
|
||||
DEBUG_BRIDGES: True
|
||||
|
||||
[REPORTS]
|
||||
|
||||
[LOGGER]
|
||||
|
||||
[ALIASES]
|
||||
|
||||
[ALLSTAR]
|
||||
|
||||
[SYSTEM]
|
||||
MODE: MASTER
|
||||
ENABLED: True
|
||||
REPEAT: True
|
||||
MAX_PEERS: 1
|
||||
EXPORT_AMBE: False
|
||||
IP: 127.0.0.1
|
||||
PORT: 56400
|
||||
PASSPHRASE:
|
||||
GROUP_HANGTIME: 5
|
||||
USE_ACL: True
|
||||
REG_ACL: DENY:1
|
||||
SUB_ACL: DENY:1
|
||||
TGID_TS1_ACL: PERMIT:ALL
|
||||
TGID_TS2_ACL: PERMIT:ALL
|
||||
DEFAULT_UA_TIMER: 60
|
||||
SINGLE_MODE: False
|
||||
VOICE_IDENT: False
|
||||
TS1_STATIC:
|
||||
TS2_STATIC:
|
||||
DEFAULT_REFLECTOR: 0
|
||||
ANNOUNCEMENT_LANGUAGE: en_GB
|
||||
GENERATOR: 100
|
||||
ALLOW_UNREG_ID: False
|
||||
PROXY_CONTROL: False
|
||||
OVERRIDE_IDENT_TG:
|
||||
|
||||
#Echo (Loro / Parrot) server
|
||||
[ECHO]
|
||||
MODE: MASTER
|
||||
ENABLED: True
|
||||
REPEAT: True
|
||||
MAX_PEERS: 1
|
||||
EXPORT_AMBE: False
|
||||
IP: 127.0.0.1
|
||||
PORT: 54917
|
||||
PASSPHRASE:
|
||||
GROUP_HANGTIME: 5
|
||||
USE_ACL: True
|
||||
REG_ACL: DENY:1
|
||||
SUB_ACL: DENY:1
|
||||
TGID_TS1_ACL: DENY:ALL
|
||||
TGID_TS2_ACL: PERMIT:9990
|
||||
DEFAULT_UA_TIMER: 1
|
||||
SINGLE_MODE: True
|
||||
VOICE_IDENT: False
|
||||
TS1_STATIC:
|
||||
TS2_STATIC:9990
|
||||
DEFAULT_REFLECTOR: 0
|
||||
ANNOUNCEMENT_LANGUAGE: en_GB
|
||||
GENERATOR: 0
|
||||
ALLOW_UNREG_ID: True
|
||||
PROXY_CONTROL: False
|
||||
OVERRIDE_IDENT_TG:
|
||||
|
||||
[D-APRS]
|
||||
MODE: MASTER
|
||||
ENABLED: True
|
||||
REPEAT: False
|
||||
MAX_PEERS: 1
|
||||
EXPORT_AMBE: False
|
||||
IP:
|
||||
PORT: 52555
|
||||
PASSPHRASE:
|
||||
GROUP_HANGTIME: 0
|
||||
USE_ACL: True
|
||||
REG_ACL: DENY:1
|
||||
SUB_ACL: DENY:1
|
||||
TGID_TS1_ACL: PERMIT:ALL
|
||||
TGID_TS2_ACL: PERMIT:ALL
|
||||
DEFAULT_UA_TIMER: 10
|
||||
SINGLE_MODE: False
|
||||
VOICE_IDENT: False
|
||||
TS1_STATIC:
|
||||
TS2_STATIC:
|
||||
DEFAULT_REFLECTOR: 0
|
||||
ANNOUNCEMENT_LANGUAGE: es_ES
|
||||
GENERATOR: 2
|
||||
ALLOW_UNREG_ID: True
|
||||
PROXY_CONTROL: False
|
||||
OVERRIDE_IDENT_TG:
|
||||
|
||||
|
||||
EOF
|
||||
#
|
||||
echo Install /etc/ADN-Systems/fdmr-mon.cfg ...
|
||||
cat << EOF > /etc/ADN-Systems/fdmr-mon.cfg
|
||||
[GLOBAL]
|
||||
# Display Bridge status
|
||||
BRIDGES_INC = False
|
||||
# Display Homebrew Peers status
|
||||
HOMEBREW_INC = True
|
||||
# Display lastheard table on main page
|
||||
LASTHEARD_INC = True
|
||||
LASTHEARD_ROWS = 20
|
||||
# Display empty masters in status
|
||||
EMPTY_MASTERS = False
|
||||
# Display TG Count on tgcount page
|
||||
TGCOUNT_INC = True
|
||||
TGCOUNT_ROWS = 20
|
||||
|
||||
[SELF SERVICE]
|
||||
# Database credentials, assuming you are running MySQL.
|
||||
DB_SERVER = mariadb
|
||||
DB_USERNAME = hbmon
|
||||
DB_PASSWORD = hbmon
|
||||
DB_NAME = hbmon
|
||||
DB_PORT = 3306
|
||||
|
||||
[FDMR CONNECTION]
|
||||
# FDMR server's IP Address
|
||||
FDMR_IP = adn-server
|
||||
# FDMR server's TCP reporting socket
|
||||
FDMR_PORT = 4321
|
||||
|
||||
[OPB FILTER]
|
||||
# Generally you don't need to use this but
|
||||
# if you don't want to show in lastherad received traffic from OBP link put NETWORK ID
|
||||
# for example: 260210, 260211, 260212
|
||||
OPB_FILTER =
|
||||
|
||||
[FILES]
|
||||
# Files and stuff for loading alias files for mapping numbers to names
|
||||
FILES_PATH = ./data
|
||||
# This files will auto-download
|
||||
PEER_FILE = peer_ids.json
|
||||
SUBSCRIBER_FILE = subscriber_ids.json
|
||||
TGID_FILE = talkgroup_ids.json
|
||||
# User provided files, if you don't use it, you can comment it.
|
||||
LOCAL_SUB_FILE = local_subscriber_ids.json
|
||||
LOCAL_PEER_FILE = local_peer_ids.json
|
||||
LOCAL_TGID_FILE = local_talkgroup_ids.json
|
||||
# Number of days before we reload DMR-MARC database files.
|
||||
RELOAD_TIME = 1
|
||||
PEER_URL = https://adn.systems/files/peer_ids.json
|
||||
SUBSCRIBER_URL = https://adn.systems/files/subscriber_ids.json
|
||||
TGID_URL = https://adn.systems/files/talkgroup_ids.json
|
||||
|
||||
[LOGGER]
|
||||
# Settings for log files
|
||||
LOG_PATH = /dev/
|
||||
LOG_FILE = null
|
||||
LOG_LEVEL = WARN
|
||||
|
||||
[WEBSOCKET SERVER]
|
||||
WEBSOCKET_PORT = 9000
|
||||
# Frequency to push updates to web clients
|
||||
FREQUENCY = 1
|
||||
# Clients are timed out after this many seconds, 0 to disable
|
||||
CLIENT_TIMEOUT = 0
|
||||
# SSL configuration
|
||||
USE_SSL = False
|
||||
SSL_PATH = ./ssl
|
||||
SSL_CERTIFICATE = cert.pem
|
||||
SSL_PRIVATEKEY = key.pem
|
||||
|
||||
[DASHBOARD]
|
||||
# Dashboard Title
|
||||
DASHTITLE = "DMR Server"
|
||||
# Background image True or False if True put a bk.jpg 1920x1080 in img folder
|
||||
BACKGROUND = False
|
||||
# this defines the default language
|
||||
# available languages: en, es, fr, pt, it, nl, de
|
||||
LANGUAGE = "es"
|
||||
# Navbar Title
|
||||
NAVTITLE= "DMR Server"
|
||||
# --Navbar Links-- #
|
||||
#NAV_LNK_NAME = "Links"
|
||||
#LINK1 = "Name 1", "http://url.link"
|
||||
#LINK2 = "Name 2", "https://site.link"
|
||||
#LINK3 = "Name 3", "https://goaway.link"
|
||||
#LINKx put as many as you want
|
||||
# World Wide Server List
|
||||
#SERVER_LIST = "https://adn.systems/servers/adn-servers.csv"
|
||||
# World Wide Bridge List
|
||||
#BRIDGES_LIST = "https://url/Bridges.csv"
|
||||
# World Wide TalkGroups List
|
||||
#TG_LIST = "https://url/Talkgroups.csv"
|
||||
####TELEGRAM = "url"
|
||||
#WHATSAPP = "url"
|
||||
#FACEBOOK = "url"
|
||||
# --Footer Links-- #
|
||||
# Beginning of footer
|
||||
#FOOTER1 = "SYSOP <a href='http://your.link'>N0CALL</a>"
|
||||
# End of footer
|
||||
#FOOTER2 = "Your Project <a href='http://your.link'>Project</a>"
|
||||
|
||||
EOF
|
||||
|
||||
|
||||
echo Set perms on config directory...
|
||||
chown -R 54000 /etc/ADN-Systems &&
|
||||
|
||||
echo Get docker-compose.yml...
|
||||
cd /etc/ADN-Systems &&
|
||||
curl https://raw.githubusercontent.com/Amateur-Digital-Network/ADN-DMR-Peer-Server/develop/docker-configs/docker-compose2.yml -o docker-compose.yml &&
|
||||
|
||||
chmod 755 /etc/cron.daily/lastheard
|
||||
|
||||
echo Tune network stack...
|
||||
cat << EOF > /etc/sysctl.conf &&
|
||||
net.core.rmem_default=134217728
|
||||
net.core.rmem_max=134217728
|
||||
net.core.wmem_max=134217728
|
||||
net.core.rmem_default=134217728
|
||||
net.core.netdev_max_backlog=250000
|
||||
net.netfilter.nf_conntrack_udp_timeout=15
|
||||
net.netfilter.nf_conntrack_udp_timeout_stream=35
|
||||
EOF
|
||||
|
||||
/usr/sbin/sysctl -p &&
|
||||
|
||||
echo Run ADN-Systems container...
|
||||
docker-compose up -d
|
||||
|
||||
echo Read notes in /etc/ADN-Systems/docker-compose.yml to understand how to implement extra functionality.
|
||||
echo ADN-Systems setup complete!
|
||||
Loading…
Reference in new issue