forked from bashclub/zamba-lxc-toolbox
Compare commits
84 Commits
dev
...
old_dev_20
Author | SHA1 | Date | |
---|---|---|---|
ff0df2cbff | |||
5c555ab5cd | |||
446bea1b89 | |||
b56bb14264 | |||
be9c8c79ea | |||
0cf8d9b6eb | |||
07b229a084 | |||
57b8159f38 | |||
d6d854577f | |||
1788a4cf63 | |||
ccc7bd30b4 | |||
3b2eb57d58 | |||
02862eb565 | |||
1c74139ebd | |||
49be094d51 | |||
0ecabeac62 | |||
b44d99c64b | |||
022871e9d7 | |||
befc08fd4c | |||
498702b394 | |||
522a02352d | |||
965c936109 | |||
140f80afb1 | |||
f2ea8da0aa | |||
af8370a1ab | |||
5759aead8d | |||
f75624c1b3 | |||
0922ef6cb3 | |||
96ad186289 | |||
9b2d29257a | |||
395e0b71fa | |||
19da148310 | |||
f70f36550c | |||
e9b80979f9 | |||
36130b6e87 | |||
cff05a3a5f | |||
443d708886 | |||
8f59fa937b | |||
ae27f3697b | |||
cc294118ae | |||
ffb88737d1 | |||
7347aaf6d5 | |||
1d4de5ede7 | |||
afb496daf1 | |||
975480dd7e | |||
455fcb280a | |||
055f75cec7 | |||
d9de476dbc | |||
75e073c0bc | |||
8182c3b95b | |||
b6208be38d | |||
84e595d3bb | |||
0036769cc9 | |||
d6cd7e0d3f | |||
6986e124f6 | |||
21db9f37c5 | |||
b0400cb347 | |||
5d314c05f9 | |||
65050ad33e | |||
c9037d4d97 | |||
666e2b320c | |||
04f55cd566 | |||
439f2ba64b | |||
4e9af3e391 | |||
9e74bca205 | |||
21de64cd57 | |||
aea5fad54d | |||
187a2c79c5 | |||
fd7d5d7ac9 | |||
261770dec5 | |||
03ae4f61d5 | |||
cd664ba745 | |||
e9200a33ec | |||
0d227a12f6 | |||
4a112950c0 | |||
442e7a3dd5 | |||
476692b072 | |||
ccfdef4462 | |||
e01a6f67bc | |||
f52d8adfa8 | |||
6a4335c5ec | |||
2b4a533c95 | |||
c28bbc32d9 | |||
9b9354f09c |
10
README.md
10
README.md
@ -7,18 +7,24 @@ The package also provides LXC container installers for `mailpiler`, `matrix-syna
|
|||||||
### Requirements
|
### Requirements
|
||||||
Proxmox VE Server (>=6.30) with at least one configured ZFS Pool.
|
Proxmox VE Server (>=6.30) with at least one configured ZFS Pool.
|
||||||
### Included services:
|
### Included services:
|
||||||
- `checkmk` => Check_MK 2.0 Monitoring Server
|
- `bookstack` => Bookstack wiki software [bookstackapp.com](https://www.bookstackapp.com/)
|
||||||
|
- `checkmk` => Check_MK 2.0 Monitoring Server [checkmk.com](https://checkmk.com/)
|
||||||
- `debian-priv` => Debian privileged container with basic toolset
|
- `debian-priv` => Debian privileged container with basic toolset
|
||||||
- `debian-unpriv` => Debian unprivileged container with basic toolset
|
- `debian-unpriv` => Debian unprivileged container with basic toolset
|
||||||
|
- `ecodms` => Fullfeatured DMS [ecodms.de](https://www.ecodms.de)
|
||||||
- `gitea` => Lightweight and fast self-hosted git service [gitea.io](https://gitea.io)
|
- `gitea` => Lightweight and fast self-hosted git service [gitea.io](https://gitea.io)
|
||||||
- `kopano-core` => Kopano Core Grouoware [kopano.io](https://kopano.io/)
|
- `kimai` => Kimai Time-Tracking [kimai.org](https://www.kimai.org/)
|
||||||
|
- `kopano-core` => Kopano Core Groupware [kopano.io](https://kopano.io/)
|
||||||
- `mailpiler` => mailpiler mail archive [mailpiler.org](https://www.mailpiler.org/)
|
- `mailpiler` => mailpiler mail archive [mailpiler.org](https://www.mailpiler.org/)
|
||||||
- `matrix` => Matrix Synapse Homeserver [matrix.org](https://matrix.org/docs/projects/server/synapse) with Element Web [Element on github](https://github.com/vector-im/element-web)
|
- `matrix` => Matrix Synapse Homeserver [matrix.org](https://matrix.org/docs/projects/server/synapse) with Element Web [Element on github](https://github.com/vector-im/element-web)
|
||||||
- `nextcloud` => Nextcloud Server [nextcloud.com](https://nextcloud.com/) with fail2ban und redis configuration
|
- `nextcloud` => Nextcloud Server [nextcloud.com](https://nextcloud.com/) with fail2ban und redis configuration
|
||||||
|
- `omada` => TP-Link Omada SDN Controller [www.tp-link.com](https://www.tp-link.com/de/omada-sdn/)
|
||||||
- `onlyoffice` => OnlyOffice [onlyoffice.com](https://onlyoffice.com)
|
- `onlyoffice` => OnlyOffice [onlyoffice.com](https://onlyoffice.com)
|
||||||
- `open3a` => Open3a web based accounting software [open3a.de](https://open3a.de)
|
- `open3a` => Open3a web based accounting software [open3a.de](https://open3a.de)
|
||||||
- `proxmox-pbs` => Proxmox Backup Server [proxmox.com](https://proxmox.com/en/proxmox-backup-server)
|
- `proxmox-pbs` => Proxmox Backup Server [proxmox.com](https://proxmox.com/en/proxmox-backup-server)
|
||||||
|
- `unifi` => Unifi Controller [ui.com](https://ui.com)
|
||||||
- `urbackup` => UrBackup Server [urbackup.org](https://urbackup.org)
|
- `urbackup` => UrBackup Server [urbackup.org](https://urbackup.org)
|
||||||
|
- `vaultwarden` => Bitwarder compatible Passwordmanager [github.com/dani-garcia/vaultwarden](https://github.com/dani-garcia/vaultwarden)
|
||||||
- `zabbix` => Zabbix Monitoring server [zabbix.com](https://www.zabbix.com)
|
- `zabbix` => Zabbix Monitoring server [zabbix.com](https://www.zabbix.com)
|
||||||
- `zammad` => Zammad Helpdesk and Ticketing Software [zammad.org](https://zammad.org/)
|
- `zammad` => Zammad Helpdesk and Ticketing Software [zammad.org](https://zammad.org/)
|
||||||
- `zmb-ad` => ZMB (Samba) Active Directory Domain Controller, DNS Backends `SAMBA_INTERNAL` and `BIND9_DLZ` are supported
|
- `zmb-ad` => ZMB (Samba) Active Directory Domain Controller, DNS Backends `SAMBA_INTERNAL` and `BIND9_DLZ` are supported
|
||||||
|
@ -40,13 +40,14 @@ LXC_SHAREFS_MOUNTPOINT="tank"
|
|||||||
```
|
```
|
||||||
### LXC_MEM
|
### LXC_MEM
|
||||||
Defines the amount of RAM in MB your LXC container is allowed to use (default: 1024)
|
Defines the amount of RAM in MB your LXC container is allowed to use (default: 1024)
|
||||||
|
If a service needs more minimum memory, LXC_MEM will be overwritten.
|
||||||
```bash
|
```bash
|
||||||
LXC_MEM="1024"
|
LXC_MEM=1024
|
||||||
```
|
```
|
||||||
### LXC_SWAP
|
### LXC_SWAP
|
||||||
Defines the amount of swap space in MB your LXC container is allowed to use (default: 1024)
|
Defines the amount of swap space in MB your LXC container is allowed to use (default: 1024)
|
||||||
```bash
|
```bash
|
||||||
LXC_SWAP="1024"
|
LXC_SWAP=1024
|
||||||
```
|
```
|
||||||
### LXC_HOSTNAME
|
### LXC_HOSTNAME
|
||||||
Defines the hostname of your LXC container (Default: Name of installed Service)
|
Defines the hostname of your LXC container (Default: Name of installed Service)
|
||||||
|
@ -28,10 +28,10 @@ LXC_SHAREFS_STORAGE="local-zfs"
|
|||||||
LXC_SHAREFS_MOUNTPOINT="tank"
|
LXC_SHAREFS_MOUNTPOINT="tank"
|
||||||
|
|
||||||
# Defines the amount of RAM in MB your LXC container is allowed to use (default: 1024)
|
# Defines the amount of RAM in MB your LXC container is allowed to use (default: 1024)
|
||||||
LXC_MEM="1024"
|
LXC_MEM=1024
|
||||||
|
|
||||||
# Defines the amount of swap space in MB your LXC container is allowed to use (default: 1024)
|
# Defines the amount of swap space in MB your LXC container is allowed to use (default: 1024)
|
||||||
LXC_SWAP="1024"
|
LXC_SWAP=1024
|
||||||
|
|
||||||
# Defines the hostname of your LXC container
|
# Defines the hostname of your LXC container
|
||||||
LXC_HOSTNAME="${service}"
|
LXC_HOSTNAME="${service}"
|
||||||
@ -81,6 +81,15 @@ LXC_LOCALE="de_DE.UTF-8"
|
|||||||
# Set dark background for vim syntax highlighting (0 or 1)
|
# Set dark background for vim syntax highlighting (0 or 1)
|
||||||
LXC_VIM_BG_DARK=1
|
LXC_VIM_BG_DARK=1
|
||||||
|
|
||||||
|
# Default random password length
|
||||||
|
LXC_RANDOMPWD=32
|
||||||
|
|
||||||
|
# Automatically add meta tags to lxc container
|
||||||
|
LXC_AUTOTAG=1
|
||||||
|
|
||||||
|
# Add meta tags to linux container
|
||||||
|
LXC_TAGS="linux,debian,${service}"
|
||||||
|
|
||||||
############### Zamba-Server-Section ###############
|
############### Zamba-Server-Section ###############
|
||||||
|
|
||||||
# Defines the REALM for the Active Directory (AD DC, AD member)
|
# Defines the REALM for the Active Directory (AD DC, AD member)
|
||||||
@ -127,7 +136,7 @@ NEXTCLOUD_FQDN="nextcloud.zmb.rocks"
|
|||||||
NEXTCLOUD_ADMIN_USR="zmb-admin"
|
NEXTCLOUD_ADMIN_USR="zmb-admin"
|
||||||
|
|
||||||
# Build a strong password for this user. Username and password will shown at the end of the installation.
|
# Build a strong password for this user. Username and password will shown at the end of the installation.
|
||||||
NEXTCLOUD_ADMIN_PWD="$(random_password)"
|
# NEXTCLOUD_ADMIN_PWD='very_secure_password'
|
||||||
|
|
||||||
# Defines the data directory, which will be createt under LXC_SHAREFS_MOUNTPOINT
|
# Defines the data directory, which will be createt under LXC_SHAREFS_MOUNTPOINT
|
||||||
NEXTCLOUD_DATA="nc_data"
|
NEXTCLOUD_DATA="nc_data"
|
||||||
@ -159,3 +168,20 @@ KOPANO_MAILGW="192.168.100.254"
|
|||||||
# Kopano test- or subscription-key offerd from
|
# Kopano test- or subscription-key offerd from
|
||||||
# https://kopano.com/downloads-demo/?demo=Kopano+Groupware&headline=Packages&target=Debian+10
|
# https://kopano.com/downloads-demo/?demo=Kopano+Groupware&headline=Packages&target=Debian+10
|
||||||
KOPANO_REPKEY="1234567890abcdefghijklmno"
|
KOPANO_REPKEY="1234567890abcdefghijklmno"
|
||||||
|
|
||||||
|
############### Tactical-RMM Section ###############
|
||||||
|
|
||||||
|
rmmdomain=api.${LXC_DOMAIN}
|
||||||
|
frontenddomain=${LXC_HOSTNAME}.${LXC_DOMAIN}
|
||||||
|
meshdomain=mesh.${LXC_DOMAIN}
|
||||||
|
adminemail=rmm@${LXC_DOMAIN}
|
||||||
|
|
||||||
|
############### vaultwarden Section ###############
|
||||||
|
VW_SMTP_HOST=mail.bashclub.org
|
||||||
|
VW_SMTP_FROM="vaultwarden@bashclub.org"
|
||||||
|
VW_SMTP_FROM_NAME="Vaultwarden Password Manager"
|
||||||
|
VW_SMTP_PORT=587
|
||||||
|
VW_SMTP_SSL=true
|
||||||
|
VW_SMTP_EXPLICIT_TLS=false
|
||||||
|
VW_SMTP_USERNAME=vaultwarden@bashclub.org
|
||||||
|
VW_SMTP_PASSWORD='<yourEmailPassword>'
|
49
install.sh
49
install.sh
@ -20,11 +20,12 @@ prog="$(basename $0)"
|
|||||||
|
|
||||||
usage() {
|
usage() {
|
||||||
cat >&2 <<-EOF
|
cat >&2 <<-EOF
|
||||||
usage: $prog [-h] [-i CTID] [-s SERVICE] [-c CFGFILE]
|
usage: $prog [-h] [-d] [-i CTID] [-s SERVICE] [-c CFGFILE]
|
||||||
installs a preconfigured lxc container on your proxmox server
|
installs a preconfigured lxc container on your proxmox server
|
||||||
-i CTID provide a container id instead of auto detection
|
-i CTID provide a container id instead of auto detection
|
||||||
-s SERVICE provide the service name and skip the selection dialog
|
-s SERVICE provide the service name and skip the selection dialog
|
||||||
-c CFGFILE use a different config file than 'zamba.conf'
|
-c CFGFILE use a different config file than 'zamba.conf'
|
||||||
|
-d Debug mode inside LXC container
|
||||||
-h displays this help text
|
-h displays this help text
|
||||||
---------------------------------------------------------------------------
|
---------------------------------------------------------------------------
|
||||||
(C) 2021 zamba-lxc-toolbox by bashclub (https://github.com/bashclub)
|
(C) 2021 zamba-lxc-toolbox by bashclub (https://github.com/bashclub)
|
||||||
@ -37,13 +38,15 @@ usage() {
|
|||||||
ctid=0
|
ctid=0
|
||||||
service=ask
|
service=ask
|
||||||
config=$PWD/conf/zamba.conf
|
config=$PWD/conf/zamba.conf
|
||||||
|
debug=0
|
||||||
|
|
||||||
while getopts "hi:s:c:" opt; do
|
while getopts "hi:s:c:d" opt; do
|
||||||
case $opt in
|
case $opt in
|
||||||
h) usage 0 ;;
|
h) usage 0 ;;
|
||||||
i) ctid=$OPTARG ;;
|
i) ctid=$OPTARG ;;
|
||||||
s) service=$OPTARG ;;
|
s) service=$OPTARG ;;
|
||||||
c) config=$OPTARG ;;
|
c) config=$OPTARG ;;
|
||||||
|
d) debug=1 ;;
|
||||||
*) usage 1 ;;
|
*) usage 1 ;;
|
||||||
esac
|
esac
|
||||||
done
|
done
|
||||||
@ -99,19 +102,19 @@ source "$config"
|
|||||||
|
|
||||||
source "$PWD/src/$service/constants-service.conf"
|
source "$PWD/src/$service/constants-service.conf"
|
||||||
|
|
||||||
# CHeck is the newest template available, else download it.
|
if [ $LXC_MEM -lt $LXC_MEM_MIN ]; then
|
||||||
DEB_LOC=$(pveam list $LXC_TEMPLATE_STORAGE | grep $LXC_TEMPLATE_VERSION | tail -1 | cut -d'_' -f2)
|
LXC_MEM=$LXC_MEM_MIN
|
||||||
DEB_REP=$(pveam available --section system | grep $LXC_TEMPLATE_VERSION | tail -1 | cut -d'_' -f2)
|
|
||||||
TMPL_NAME=$(pveam available --section system | grep $LXC_TEMPLATE_VERSION | tail -1 | cut -d' ' -f11)
|
|
||||||
|
|
||||||
if [[ $DEB_LOC == $DEB_REP ]];
|
|
||||||
then
|
|
||||||
echo "Newest Version of $LXC_TEMPLATE_VERSION $DEB_REP exists.";
|
|
||||||
else
|
|
||||||
echo "Will now download newest $LXC_TEMPLATE_VERSION $DEP_REP.";
|
|
||||||
pveam download $LXC_TEMPLATE_STORAGE $TMPL_NAME
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
if [ $LXC_AUTOTAG -gt 0 ]; then
|
||||||
|
TAGS="--tags ${LXC_TAGS},${SERVICE_TAGS}"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Check is the newest template available, else download it.
|
||||||
|
pveam update
|
||||||
|
TMPL_NAME=$(pveam available --section system | grep $LXC_TEMPLATE_VERSION | tail -1 | cut -d' ' -f11)
|
||||||
|
pveam download $LXC_TEMPLATE_STORAGE $TMPL_NAME
|
||||||
|
|
||||||
if [ $ctid -gt 99 ]; then
|
if [ $ctid -gt 99 ]; then
|
||||||
LXC_CHK=$ctid
|
LXC_CHK=$ctid
|
||||||
else
|
else
|
||||||
@ -128,7 +131,7 @@ fi
|
|||||||
echo "Will now create LXC Container $LXC_NBR!";
|
echo "Will now create LXC Container $LXC_NBR!";
|
||||||
|
|
||||||
# Create the container
|
# Create the container
|
||||||
pct create $LXC_NBR --password $LXC_PWD -unprivileged $LXC_UNPRIVILEGED $LXC_TEMPLATE_STORAGE:vztmpl/$TMPL_NAME -rootfs $LXC_ROOTFS_STORAGE:$LXC_ROOTFS_SIZE;
|
pct create $LXC_NBR $TAGS --password $LXC_PWD -unprivileged $LXC_UNPRIVILEGED $LXC_TEMPLATE_STORAGE:vztmpl/$TMPL_NAME -rootfs $LXC_ROOTFS_STORAGE:$LXC_ROOTFS_SIZE;
|
||||||
sleep 2;
|
sleep 2;
|
||||||
|
|
||||||
# Check vlan configuration
|
# Check vlan configuration
|
||||||
@ -155,20 +158,26 @@ sleep 5;
|
|||||||
pct exec $LXC_NBR -- mkdir /root/.ssh
|
pct exec $LXC_NBR -- mkdir /root/.ssh
|
||||||
pct push $LXC_NBR $LXC_AUTHORIZED_KEY /root/.ssh/authorized_keys
|
pct push $LXC_NBR $LXC_AUTHORIZED_KEY /root/.ssh/authorized_keys
|
||||||
pct push $LXC_NBR "$config" /root/zamba.conf
|
pct push $LXC_NBR "$config" /root/zamba.conf
|
||||||
|
pct exec $LXC_NBR -- sed -i "s,\${service},${service}," /root/zamba.conf
|
||||||
|
pct exec $LXC_NBR -- echo "LXC_NBR=$LXC_NBR" /root/zamba.conf
|
||||||
pct push $LXC_NBR "$PWD/src/functions.sh" /root/functions.sh
|
pct push $LXC_NBR "$PWD/src/functions.sh" /root/functions.sh
|
||||||
pct push $LXC_NBR "$PWD/src/constants.conf" /root/constants.conf
|
pct push $LXC_NBR "$PWD/src/constants.conf" /root/constants.conf
|
||||||
pct push $LXC_NBR "$PWD/src/lxc-base.sh" /root/lxc-base.sh
|
pct push $LXC_NBR "$PWD/src/lxc-base.sh" /root/lxc-base.sh
|
||||||
pct push $LXC_NBR "$PWD/src/$service/install-service.sh" /root/install-service.sh
|
pct push $LXC_NBR "$PWD/src/$service/install-service.sh" /root/install-service.sh
|
||||||
pct push $LXC_NBR "$PWD/src/$service/constants-service.conf" /root/constants-service.conf
|
pct push $LXC_NBR "$PWD/src/$service/constants-service.conf" /root/constants-service.conf
|
||||||
|
|
||||||
echo "Installing basic container setup..."
|
if [ $debug -gt 0 ]; then dbg=-vx; else dbg=""; fi
|
||||||
lxc-attach -n$LXC_NBR bash /root/lxc-base.sh
|
|
||||||
echo "Install '$service'!"
|
|
||||||
lxc-attach -n$LXC_NBR bash /root/install-service.sh
|
|
||||||
|
|
||||||
|
echo "Installing basic container setup..."
|
||||||
|
pct exec $LXC_NBR -- su - root -c "bash $dbg /root/lxc-base.sh"
|
||||||
|
echo "Install '$service'!"
|
||||||
|
pct exec $LXC_NBR -- su - root -c "bash $dbg /root/install-service.sh"
|
||||||
|
|
||||||
|
pct shutdown $LXC_NBR
|
||||||
if [[ $service == "zmb-ad" ]]; then
|
if [[ $service == "zmb-ad" ]]; then
|
||||||
pct stop $LXC_NBR
|
|
||||||
## set nameserver, ${LXC_IP%/*} extracts the ip address from cidr format
|
## set nameserver, ${LXC_IP%/*} extracts the ip address from cidr format
|
||||||
pct set $LXC_NBR -nameserver ${LXC_IP%/*}
|
pct set $LXC_NBR -nameserver ${LXC_IP%/*}
|
||||||
pct start $LXC_NBR
|
elif [[ $service == "zmb-ad-join" ]]; then
|
||||||
|
pct set $LXC_NBR -nameserver "${LXC_IP%/*} $LXC_DNS"
|
||||||
fi
|
fi
|
||||||
|
pct start $LXC_NBR
|
26
src/bookstack/constants-service.conf
Normal file
26
src/bookstack/constants-service.conf
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Authors:
|
||||||
|
# (C) 2021 Idea an concept by Christian Zengel <christian@sysops.de>
|
||||||
|
# (C) 2021 Script design and prototype by Markus Helmke <m.helmke@nettwarker.de>
|
||||||
|
# (C) 2021 Script rework and documentation by Thorsten Spille <thorsten@spille-edv.de>
|
||||||
|
|
||||||
|
# This file contains the project constants on service level
|
||||||
|
|
||||||
|
# Debian Version, which will be installed
|
||||||
|
LXC_TEMPLATE_VERSION="debian-11-standard"
|
||||||
|
|
||||||
|
# Create sharefs mountpoint
|
||||||
|
LXC_MP="0"
|
||||||
|
|
||||||
|
# Create unprivileged container
|
||||||
|
LXC_UNPRIVILEGED="1"
|
||||||
|
|
||||||
|
# enable nesting feature
|
||||||
|
LXC_NESTING="1"
|
||||||
|
|
||||||
|
# Sets the minimum amount of RAM the service needs for operation
|
||||||
|
LXC_MEM_MIN=1024
|
||||||
|
|
||||||
|
# service dependent meta tags
|
||||||
|
SERVICE_TAGS="php-fpm,nginx,mariadb"
|
186
src/bookstack/install-service.sh
Normal file
186
src/bookstack/install-service.sh
Normal file
@ -0,0 +1,186 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
set -euo pipefail
|
||||||
|
|
||||||
|
# Authors:
|
||||||
|
# (C) 2021 Idea an concept by Christian Zengel <christian@sysops.de>
|
||||||
|
# (C) 2021 Script design and prototype by Markus Helmke <m.helmke@nettwarker.de>
|
||||||
|
# (C) 2021 Script rework and documentation by Thorsten Spille <thorsten@spille-edv.de>
|
||||||
|
|
||||||
|
source /root/functions.sh
|
||||||
|
source /root/zamba.conf
|
||||||
|
source /root/constants-service.conf
|
||||||
|
|
||||||
|
BOOKSTACK_DB_PWD=$(random_password)
|
||||||
|
webroot=/var/www/bookstack/public
|
||||||
|
|
||||||
|
apt update
|
||||||
|
|
||||||
|
DEBIAN_FRONTEND=noninteractive DEBIAN_PRIORITY=critical apt install -y -qq zip unzip nginx-full mariadb-server mariadb-client php php-cli php-fpm php-mysql php-xml php-mbstring php-gd php-tokenizer php-xml php-dompdf php-curl php-ldap php-tidy php-zip redis-server
|
||||||
|
wget -O /opt/wkhtmltox_0.12.6-1.buster_amd64.deb https://github.com/wkhtmltopdf/packaging/releases/download/0.12.6-1/wkhtmltox_0.12.6-1.buster_amd64.deb
|
||||||
|
DEBIAN_FRONTEND=noninteractive DEBIAN_PRIORITY=critical apt install -y -qq /opt/wkhtmltox_0.12.6-1.buster_amd64.deb
|
||||||
|
|
||||||
|
mkdir /etc/nginx/ssl
|
||||||
|
openssl req -x509 -nodes -days 3650 -newkey rsa:4096 -keyout /etc/nginx/ssl/open3a.key -out /etc/nginx/ssl/open3a.crt -subj "/CN=$LXC_HOSTNAME.$LXC_DOMAIN" -addext "subjectAltName=DNS:$LXC_HOSTNAME.$LXC_DOMAIN"
|
||||||
|
|
||||||
|
PHP_VERSION=$(php -v | head -1 | cut -d ' ' -f2)
|
||||||
|
|
||||||
|
cat << EOF > /etc/nginx/sites-available/default
|
||||||
|
server {
|
||||||
|
listen 80 default_server;
|
||||||
|
listen [::]:80 default_server;
|
||||||
|
server_name _;
|
||||||
|
|
||||||
|
return 301 https://$LXC_HOSTNAME.$LXC_DOMAIN;
|
||||||
|
}
|
||||||
|
|
||||||
|
server {
|
||||||
|
|
||||||
|
client_max_body_size 100M;
|
||||||
|
fastcgi_buffers 64 4K;
|
||||||
|
client_body_timeout 120s;
|
||||||
|
|
||||||
|
listen 443 http2 ssl default_server;
|
||||||
|
listen [::]:443 http2 ssl default_server;
|
||||||
|
server_name $LXC_HOSTNAME.$LXC_DOMAIN;
|
||||||
|
|
||||||
|
root $webroot;
|
||||||
|
|
||||||
|
index index.php;
|
||||||
|
|
||||||
|
ssl_certificate /etc/nginx/ssl/open3a.crt;
|
||||||
|
ssl_certificate_key /etc/nginx/ssl/open3a.key;
|
||||||
|
|
||||||
|
access_log /var/log/nginx/bookstack.access.log;
|
||||||
|
error_log /var/log/nginx/bookstack.error.log;
|
||||||
|
|
||||||
|
location / {
|
||||||
|
try_files \$uri \$uri/ /index.php?\$query_string;
|
||||||
|
}
|
||||||
|
|
||||||
|
location ~ \.php$ {
|
||||||
|
fastcgi_split_path_info ^(.+\.php)(/.+)$;
|
||||||
|
fastcgi_pass unix:/run/php/php${PHP_VERSION:0:3}-fpm.sock;
|
||||||
|
fastcgi_index index.php;
|
||||||
|
include fastcgi_params;
|
||||||
|
fastcgi_param SCRIPT_FILENAME \$document_root\$fastcgi_script_name;
|
||||||
|
fastcgi_intercept_errors off;
|
||||||
|
fastcgi_buffer_size 16k;
|
||||||
|
fastcgi_buffers 4 16k;
|
||||||
|
}
|
||||||
|
|
||||||
|
location = /favicon.ico { access_log off; log_not_found off; }
|
||||||
|
location = /robots.txt { access_log off; log_not_found off; }
|
||||||
|
|
||||||
|
location ~ /\.ht {
|
||||||
|
deny all;
|
||||||
|
}
|
||||||
|
|
||||||
|
fastcgi_hide_header X-Powered-By;
|
||||||
|
fastcgi_read_timeout 3600;
|
||||||
|
fastcgi_send_timeout 3600;
|
||||||
|
fastcgi_connect_timeout 3600;
|
||||||
|
|
||||||
|
add_header Permissions-Policy "interest-cohort=()";
|
||||||
|
add_header Referrer-Policy "no-referrer" always;
|
||||||
|
add_header X-Content-Type-Options "nosniff" always;
|
||||||
|
add_header X-Download-Options "noopen" always;
|
||||||
|
add_header X-Frame-Options "SAMEORIGIN" always;
|
||||||
|
add_header X-Permitted-Cross-Domain-Policies "none" always;
|
||||||
|
add_header X-Robots-Tag "none" always;
|
||||||
|
add_header X-XSS-Protection "1; mode=block" always;
|
||||||
|
|
||||||
|
gzip on;
|
||||||
|
gzip_vary on;
|
||||||
|
gzip_comp_level 4;
|
||||||
|
gzip_min_length 256;
|
||||||
|
gzip_proxied expired no-cache no-store private no_last_modified no_etag auth;
|
||||||
|
gzip_types application/atom+xml application/javascript application/json application/ld+json application/manifest+json application/rss+xml application/vnd.geo+json application/vnd.ms-fontobject application/x-font-ttf application/x-web-app-manifest+json application/xhtml+xml application/xml font/opentype image/bmp image/svg+xml image/x-icon text/cache-manifest text/css text/plain text/vcard text/vnd.rim.location.xloc text/vtt text/x-component text/x-cross-domain-policy;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
EOF
|
||||||
|
|
||||||
|
mysql -uroot -e "CREATE USER 'bookstack'@'localhost' IDENTIFIED BY '$BOOKSTACK_DB_PWD';
|
||||||
|
CREATE DATABASE IF NOT EXISTS bookstack;
|
||||||
|
GRANT ALL PRIVILEGES ON bookstack.* TO 'bookstack'@'localhost' IDENTIFIED BY '$BOOKSTACK_DB_PWD';
|
||||||
|
FLUSH PRIVILEGES;"
|
||||||
|
|
||||||
|
sed -i "s/post_max_size = 8M/post_max_size = 100M/g" /etc/php/7.4/fpm/php.ini
|
||||||
|
sed -i "s/upload_max_filesize = 2M/upload_max_filesize = 100M/g" /etc/php/7.4/fpm/php.ini
|
||||||
|
sed -i "s/memory_limit = 128M/memory_limit = 512M/g" /etc/php/7.4/fpm/php.ini
|
||||||
|
|
||||||
|
EXPECTED_CHECKSUM="$(php -r 'copy("https://composer.github.io/installer.sig", "php://stdout");')"
|
||||||
|
php -r "copy('https://getcomposer.org/installer', 'composer-setup.php');"
|
||||||
|
ACTUAL_CHECKSUM="$(php -r "echo hash_file('sha384', 'composer-setup.php');")"
|
||||||
|
if [ "$EXPECTED_CHECKSUM" != "$ACTUAL_CHECKSUM" ]
|
||||||
|
then
|
||||||
|
>&2 echo 'ERROR: Invalid composer installer checksum'
|
||||||
|
rm composer-setup.php
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
php composer-setup.php --quiet
|
||||||
|
rm composer-setup.php
|
||||||
|
# Move composer to global installation
|
||||||
|
mv composer.phar /usr/local/bin/composer
|
||||||
|
|
||||||
|
cd /var/www
|
||||||
|
git clone https://github.com/BookStackApp/BookStack.git --branch release --single-branch bookstack
|
||||||
|
cd bookstack
|
||||||
|
|
||||||
|
# Install BookStack composer dependencies
|
||||||
|
export COMPOSER_ALLOW_SUPERUSER=1
|
||||||
|
php /usr/local/bin/composer install --no-dev --no-plugins
|
||||||
|
|
||||||
|
|
||||||
|
# Copy and update BookStack environment variables
|
||||||
|
cp .env.example .env
|
||||||
|
sed -i.bak "s@APP_URL=.*\$@APP_URL=https://${LXC_HOSTNAME}.${LXC_DOMAIN}@" .env
|
||||||
|
sed -i.bak 's/DB_DATABASE=.*$/DB_DATABASE=bookstack/' .env
|
||||||
|
sed -i.bak 's/DB_USERNAME=.*$/DB_USERNAME=bookstack/' .env
|
||||||
|
sed -i.bak "s/DB_PASSWORD=.*\$/DB_PASSWORD=$BOOKSTACK_DB_PWD/" .env
|
||||||
|
|
||||||
|
cat << EOF >> .env
|
||||||
|
QUEUE_CONNECTION=database
|
||||||
|
STORAGE_TYPE=local_secure
|
||||||
|
APP_LANG=de_informal
|
||||||
|
FILE_UPLOAD_SIZE_LIMIT=100
|
||||||
|
SESSION_SECURE_COOKIE=true
|
||||||
|
CACHE_DRIVER=redis
|
||||||
|
SESSION_DRIVER=redis
|
||||||
|
REDIS_SERVERS=127.0.0.1:6379:0
|
||||||
|
WKHTMLTOPDF=/usr/local/bin/wkhtmltopdf
|
||||||
|
ALLOW_UNTRUSTED_SERVER_FETCHING=true
|
||||||
|
EOF
|
||||||
|
|
||||||
|
# Generate the application key
|
||||||
|
php artisan key:generate --no-interaction --force
|
||||||
|
# Migrate the databases
|
||||||
|
php artisan migrate --no-interaction --force
|
||||||
|
|
||||||
|
php artisan bookstack:db-utf8mb4 > dbupgrade.sql
|
||||||
|
mysql -u root < dbupgrade.sql
|
||||||
|
|
||||||
|
chown www-data:www-data -R bootstrap/cache public/uploads storage && chmod -R 755 bootstrap/cache public/uploads storage
|
||||||
|
|
||||||
|
cat << EOF > /etc/systemd/system/bookstack-queue.service
|
||||||
|
[Unit]
|
||||||
|
Description=BookStack Queue Worker
|
||||||
|
|
||||||
|
[Service]
|
||||||
|
User=www-data
|
||||||
|
Group=www-data
|
||||||
|
Restart=always
|
||||||
|
ExecStart=/usr/bin/php /var/www/bookstack/artisan queue:work --sleep=3 --tries=1 --max-time=3600
|
||||||
|
|
||||||
|
[Install]
|
||||||
|
WantedBy=multi-user.target
|
||||||
|
EOF
|
||||||
|
|
||||||
|
systemctl daemon-reload
|
||||||
|
systemctl enable --now bookstack-queue php7.4-fpm nginx redis-server
|
||||||
|
systemctl restart php7.4-fpm nginx bookstack-queue redis-server
|
||||||
|
|
||||||
|
LXC_IP=$(ip address show dev eth0 | grep "inet " | cut -d ' ' -f6)
|
||||||
|
|
||||||
|
echo -e "Your bookstack installation is now complete. Please continue with setup in your Browser:\nURL:\t\thttp://$(echo ${LXC_IP} | cut -d'/' -f1)\nLogin:\t\tadmin@admin.com\nPassword:\tpassword\n\n"
|
@ -20,6 +20,12 @@ LXC_UNPRIVILEGED="1"
|
|||||||
LXC_NESTING="1"
|
LXC_NESTING="1"
|
||||||
|
|
||||||
# checkmk version
|
# checkmk version
|
||||||
CMK_VERSION=2.0.0p23
|
CMK_VERSION=2.1.0p21
|
||||||
# build number of the debian package (needs to start with underscore)
|
# build number of the debian package (needs to start with underscore)
|
||||||
CMK_BUILD=_0
|
CMK_BUILD=_0
|
||||||
|
|
||||||
|
# Sets the minimum amount of RAM the service needs for operation
|
||||||
|
LXC_MEM_MIN=2048
|
||||||
|
|
||||||
|
# service dependent meta tags
|
||||||
|
SERVICE_TAGS="apache2"
|
@ -8,4 +8,4 @@
|
|||||||
# This file contains the project constants on container level
|
# This file contains the project constants on container level
|
||||||
|
|
||||||
# Define your (administrative) tools, you always want to have installed into your LXC container
|
# Define your (administrative) tools, you always want to have installed into your LXC container
|
||||||
LXC_TOOLSET_BASE="lsb-release curl git gnupg2 apt-transport-https software-properties-common"
|
LXC_TOOLSET_BASE="sudo lsb-release curl dirmngr git gnupg2 apt-transport-https software-properties-common wget ssl-cert"
|
||||||
|
@ -18,3 +18,9 @@ LXC_UNPRIVILEGED="0"
|
|||||||
|
|
||||||
# enable nesting feature
|
# enable nesting feature
|
||||||
LXC_NESTING="1"
|
LXC_NESTING="1"
|
||||||
|
|
||||||
|
# Sets the minimum amount of RAM the service needs for operation
|
||||||
|
LXC_MEM_MIN=512
|
||||||
|
|
||||||
|
# service dependent meta tags
|
||||||
|
SERVICE_TAGS="privileged"
|
@ -18,3 +18,9 @@ LXC_UNPRIVILEGED="1"
|
|||||||
|
|
||||||
# enable nesting feature
|
# enable nesting feature
|
||||||
LXC_NESTING="1"
|
LXC_NESTING="1"
|
||||||
|
|
||||||
|
# Sets the minimum amount of RAM the service needs for operation
|
||||||
|
LXC_MEM_MIN=512
|
||||||
|
|
||||||
|
# service dependent meta tags
|
||||||
|
SERVICE_TAGS=""
|
29
src/ecodms/constants-service.conf
Normal file
29
src/ecodms/constants-service.conf
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Authors:
|
||||||
|
# (C) 2021 Idea an concept by Christian Zengel <christian@sysops.de>
|
||||||
|
# (C) 2021 Script design and prototype by Markus Helmke <m.helmke@nettwarker.de>
|
||||||
|
# (C) 2021 Script rework and documentation by Thorsten Spille <thorsten@spille-edv.de>
|
||||||
|
|
||||||
|
# This file contains the project constants on service level
|
||||||
|
|
||||||
|
# Debian Version, which will be installed
|
||||||
|
LXC_TEMPLATE_VERSION="debian-11-standard"
|
||||||
|
|
||||||
|
# Create sharefs mountpoint
|
||||||
|
LXC_MP="0"
|
||||||
|
|
||||||
|
# Create unprivileged container
|
||||||
|
LXC_UNPRIVILEGED="1"
|
||||||
|
|
||||||
|
# enable nesting feature
|
||||||
|
LXC_NESTING="1"
|
||||||
|
|
||||||
|
# set ecodms release version
|
||||||
|
ECODMS_RELEASE=ecodms_220864
|
||||||
|
|
||||||
|
# Sets the minimum amount of RAM the service needs for operation
|
||||||
|
LXC_MEM_MIN=6144
|
||||||
|
|
||||||
|
# service dependent meta tags
|
||||||
|
SERVICE_TAGS="java,postgresql"
|
21
src/ecodms/install-service.sh
Normal file
21
src/ecodms/install-service.sh
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
set -euo pipefail
|
||||||
|
|
||||||
|
# Authors:
|
||||||
|
# (C) 2021 Idea an concept by Christian Zengel <christian@sysops.de>
|
||||||
|
# (C) 2021 Script design and prototype by Markus Helmke <m.helmke@nettwarker.de>
|
||||||
|
# (C) 2021 Script rework and documentation by Thorsten Spille <thorsten@spille-edv.de>
|
||||||
|
|
||||||
|
source /root/functions.sh
|
||||||
|
source /root/zamba.conf
|
||||||
|
source /root/constants-service.conf
|
||||||
|
|
||||||
|
echo "ecodmsserver ecodmsserver/language string german" | debconf-set-selections
|
||||||
|
echo "ecodmsserver ecodmsserver/license string true" | debconf-set-selections
|
||||||
|
|
||||||
|
echo -e "deb http://www.ecodms.de/${ECODMS_RELEASE}/$(lsb_release -cs) /" > /etc/apt/sources.list.d/ecodms.list
|
||||||
|
wget -qO- http://www.ecodms.de/gpg/ecodms.key | gpg --dearmor | tee /etc/apt/trusted.gpg.d/ecodms.gpg
|
||||||
|
|
||||||
|
apt update
|
||||||
|
DEBIAN_FRONTEND=noninteractive DEBIAN_PRIORITY=critical apt -y -qq install ecodmsserver
|
@ -1,8 +1,9 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
#
|
#
|
||||||
# This script has basic functions like a random password generator
|
# This script has basic functions like a random password generator
|
||||||
|
LXC_RANDOMPWD=32
|
||||||
|
|
||||||
random_password() {
|
random_password() {
|
||||||
set +o pipefail
|
set +o pipefail
|
||||||
C_CTYPE=C tr -dc 'a-zA-Z0-9' < /dev/urandom | head -c32
|
C_CTYPE=C tr -dc 'a-zA-Z0-9' < /dev/urandom 2>/dev/null | head -c${LXC_RANDOMPWD}
|
||||||
}
|
}
|
@ -14,7 +14,7 @@ LXC_TEMPLATE_VERSION="debian-11-standard"
|
|||||||
LXC_MP="1"
|
LXC_MP="1"
|
||||||
|
|
||||||
# Create unprivileged container
|
# Create unprivileged container
|
||||||
LXC_UNPRIVILEGED="0"
|
LXC_UNPRIVILEGED="1"
|
||||||
|
|
||||||
# enable nesting feature
|
# enable nesting feature
|
||||||
LXC_NESTING="1"
|
LXC_NESTING="1"
|
||||||
@ -33,3 +33,9 @@ GITEA_DB_USR="gitea"
|
|||||||
|
|
||||||
# Build a strong password for the SQL user - could be overwritten with something fixed
|
# Build a strong password for the SQL user - could be overwritten with something fixed
|
||||||
GITEA_DB_PWD="$(random_password)"
|
GITEA_DB_PWD="$(random_password)"
|
||||||
|
|
||||||
|
# Sets the minimum amount of RAM the service needs for operation
|
||||||
|
LXC_MEM_MIN=1024
|
||||||
|
|
||||||
|
# service dependent meta tags
|
||||||
|
SERVICE_TAGS="nginx,postgresql"
|
@ -17,9 +17,7 @@ echo "deb http://apt.postgresql.org/pub/repos/apt $(lsb_release -cs)-pgdg main"
|
|||||||
|
|
||||||
apt update
|
apt update
|
||||||
|
|
||||||
DEBIAN_FRONTEND=noninteractive DEBIAN_PRIORITY=critical apt install -y -qq postgresql nginx git ssl-cert unzip zip
|
DEBIAN_FRONTEND=noninteractive DEBIAN_PRIORITY=critical apt install --no-install-recommends -y -qq postgresql nginx git ssl-cert unzip zip
|
||||||
|
|
||||||
timedatectl set-timezone ${LXC_TIMEZONE}
|
|
||||||
|
|
||||||
systemctl enable --now postgresql
|
systemctl enable --now postgresql
|
||||||
|
|
||||||
@ -38,6 +36,32 @@ mkdir -p /${LXC_SHAREFS_MOUNTPOINT}/
|
|||||||
chown -R git:git /${LXC_SHAREFS_MOUNTPOINT}/
|
chown -R git:git /${LXC_SHAREFS_MOUNTPOINT}/
|
||||||
chmod -R 750 /${LXC_SHAREFS_MOUNTPOINT}/
|
chmod -R 750 /${LXC_SHAREFS_MOUNTPOINT}/
|
||||||
|
|
||||||
|
cat << EOF > /usr/local/bin/update-gitea
|
||||||
|
PATH="/bin:/usr/bin:/usr/local/bin"
|
||||||
|
echo "Checking github for new gitea version"
|
||||||
|
current_version=\$(curl -s https://api.github.com/repos/go-gitea/gitea/releases/latest | grep "tag_name" | cut -d '"' -f4)
|
||||||
|
installed_version=\$(echo v\$(gitea --version | cut -d ' ' -f3))
|
||||||
|
echo "Installed gitea version is \$installed_version"
|
||||||
|
if [ \$installed_version != \$current_version ]; then
|
||||||
|
echo "New gitea version \$current_version available. Stopping gitea.service"
|
||||||
|
systemctl stop gitea.service
|
||||||
|
echo "Downloading gitea version \$current_version..."
|
||||||
|
curl -s https://api.github.com/repos/go-gitea/gitea/releases/latest | grep browser_download_url | cut -d '"' -f 4 | grep '\linux-amd64$' | wget -q -O /usr/local/bin/gitea -i -
|
||||||
|
chmod +x /usr/local/bin/gitea
|
||||||
|
echo "Starting gitea.service..."
|
||||||
|
systemctl start gitea.service
|
||||||
|
echo "gitea update finished!"
|
||||||
|
else
|
||||||
|
echo "gitea version is up-to-date!"
|
||||||
|
fi
|
||||||
|
EOF
|
||||||
|
chmod +x /usr/local/bin/update-gitea
|
||||||
|
|
||||||
|
cat << EOF > /etc/apt/apt.conf.d/80-gitea-apt-hook
|
||||||
|
DPkg::Post-Invoke {"/usr/local/bin/update-gitea";};
|
||||||
|
EOF
|
||||||
|
chmod +x /etc/apt/apt.conf.d/80-gitea-apt-hook
|
||||||
|
|
||||||
cat << EOF > /etc/systemd/system/gitea.service
|
cat << EOF > /etc/systemd/system/gitea.service
|
||||||
[Unit]
|
[Unit]
|
||||||
Description=Gitea
|
Description=Gitea
|
||||||
|
26
src/jitsi-meet/constants-service.conf
Normal file
26
src/jitsi-meet/constants-service.conf
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Authors:
|
||||||
|
# (C) 2021 Idea an concept by Christian Zengel <christian@sysops.de>
|
||||||
|
# (C) 2021 Script design and prototype by Markus Helmke <m.helmke@nettwarker.de>
|
||||||
|
# (C) 2021 Script rework and documentation by Thorsten Spille <thorsten@spille-edv.de>
|
||||||
|
|
||||||
|
# This file contains the project constants on service level
|
||||||
|
|
||||||
|
# Debian Version, which will be installed
|
||||||
|
LXC_TEMPLATE_VERSION="debian-11-standard"
|
||||||
|
|
||||||
|
# Create sharefs mountpoint
|
||||||
|
LXC_MP="0"
|
||||||
|
|
||||||
|
# Create unprivileged container
|
||||||
|
LXC_UNPRIVILEGED="1"
|
||||||
|
|
||||||
|
# enable nesting feature
|
||||||
|
LXC_NESTING="1"
|
||||||
|
|
||||||
|
# Sets the minimum amount of RAM the service needs for operation
|
||||||
|
LXC_MEM_MIN=4096
|
||||||
|
|
||||||
|
# service dependent meta tags
|
||||||
|
SERVICE_TAGS=""
|
17
src/jitsi-meet/install-service.sh
Normal file
17
src/jitsi-meet/install-service.sh
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
set -euo pipefail
|
||||||
|
|
||||||
|
# Authors:
|
||||||
|
# (C) 2021 Idea an concept by Christian Zengel <christian@sysops.de>
|
||||||
|
# (C) 2021 Script design and prototype by Markus Helmke <m.helmke@nettwarker.de>
|
||||||
|
# (C) 2021 Script rework and documentation by Thorsten Spille <thorsten@spille-edv.de>
|
||||||
|
|
||||||
|
source /root/functions.sh
|
||||||
|
source /root/zamba.conf
|
||||||
|
source /root/constants-service.conf
|
||||||
|
|
||||||
|
curl https://download.jitsi.org/jitsi-key.gpg.key | gpg --dearmor | tee /usr/share/keyrings/jitsi-keyring.gpg
|
||||||
|
echo "deb [signed-by=/usr/share/keyrings/jitsi-keyring.gpg] https://download.jitsi.org stable/" | tee /etc/apt/sources.list.d/jitsi-stable.list
|
||||||
|
apt update
|
||||||
|
DEBIAN_FRONTEND=noninteractive DEBIAN_PRIORITY=critical apt install -y -qq jitsi-meet
|
32
src/kimai/constants-service.conf
Normal file
32
src/kimai/constants-service.conf
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Authors:
|
||||||
|
# (C) 2021 Idea an concept by Christian Zengel <christian@sysops.de>
|
||||||
|
# (C) 2021 Script design and prototype by Markus Helmke <m.helmke@nettwarker.de>
|
||||||
|
# (C) 2021 Script rework and documentation by Thorsten Spille <thorsten@spille-edv.de>
|
||||||
|
|
||||||
|
# This file contains the project constants on service level
|
||||||
|
|
||||||
|
# Debian Version, which will be installed
|
||||||
|
LXC_TEMPLATE_VERSION="debian-11-standard"
|
||||||
|
|
||||||
|
# Create sharefs mountpoint
|
||||||
|
LXC_MP="0"
|
||||||
|
|
||||||
|
# Create unprivileged container
|
||||||
|
LXC_UNPRIVILEGED="1"
|
||||||
|
|
||||||
|
# enable nesting feature
|
||||||
|
LXC_NESTING="1"
|
||||||
|
|
||||||
|
# Defines the version number of kimai mail archive to install (type in exact version number (e.g. 1.3.11) or 'latest')
|
||||||
|
KIMAI_VERSION="main"
|
||||||
|
|
||||||
|
# Defines the php version to install
|
||||||
|
KIMAI_PHP_VERSION="8.1"
|
||||||
|
|
||||||
|
# Sets the minimum amount of RAM the service needs for operation
|
||||||
|
LXC_MEM_MIN=1024
|
||||||
|
|
||||||
|
# service dependent meta tags
|
||||||
|
SERVICE_TAGS="php-fpm,nginx,mariadb"
|
167
src/kimai/install-service.sh
Normal file
167
src/kimai/install-service.sh
Normal file
@ -0,0 +1,167 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
set -euo pipefail
|
||||||
|
|
||||||
|
# Authors:
|
||||||
|
# (C) 2021 Idea an concept by Christian Zengel <christian@sysops.de>
|
||||||
|
# (C) 2021 Script design and prototype by Markus Helmke <m.helmke@nettwarker.de>
|
||||||
|
# (C) 2021 Script rework and documentation by Thorsten Spille <thorsten@spille-edv.de>
|
||||||
|
|
||||||
|
source /root/functions.sh
|
||||||
|
source /root/zamba.conf
|
||||||
|
source /root/constants-service.conf
|
||||||
|
|
||||||
|
KIMAI_DB_PWD=$(random_password)
|
||||||
|
webroot=/var/www/kimai/public
|
||||||
|
|
||||||
|
wget -q -O - https://packages.sury.org/php/apt.gpg | apt-key add -
|
||||||
|
echo "deb https://packages.sury.org/php/ $(lsb_release -cs) main" | tee /etc/apt/sources.list.d/php.list
|
||||||
|
|
||||||
|
apt update
|
||||||
|
|
||||||
|
DEBIAN_FRONTEND=noninteractive DEBIAN_PRIORITY=critical apt install -y -qq zip unzip sudo nginx-full mariadb-server mariadb-client php8.1 php8.1-intl php8.1-cli php8.1-fpm php8.1-mysql php8.1-xml php8.1-mbstring php8.1-gd php8.1-tokenizer php8.1-zip php8.1-opcache php8.1-curl
|
||||||
|
|
||||||
|
mkdir /etc/nginx/ssl
|
||||||
|
openssl req -x509 -nodes -days 3650 -newkey rsa:4096 -keyout /etc/nginx/ssl/kimai.key -out /etc/nginx/ssl/kimai.crt -subj "/CN=$LXC_HOSTNAME.$LXC_DOMAIN" -addext "subjectAltName=DNS:$LXC_HOSTNAME.$LXC_DOMAIN"
|
||||||
|
|
||||||
|
PHP_VERSION=$(php -v | head -1 | cut -d ' ' -f2)
|
||||||
|
PHP_VERSION=${PHP_VERSION:0:3}
|
||||||
|
|
||||||
|
cat << EOF > /etc/nginx/sites-available/default
|
||||||
|
server {
|
||||||
|
listen 80 default_server;
|
||||||
|
listen [::]:80 default_server;
|
||||||
|
server_name _;
|
||||||
|
|
||||||
|
return 301 https://$LXC_HOSTNAME.$LXC_DOMAIN;
|
||||||
|
}
|
||||||
|
|
||||||
|
server {
|
||||||
|
|
||||||
|
client_max_body_size 2M;
|
||||||
|
fastcgi_buffers 64 4K;
|
||||||
|
client_body_timeout 120s;
|
||||||
|
|
||||||
|
listen 443 http2 ssl default_server;
|
||||||
|
listen [::]:443 http2 ssl default_server;
|
||||||
|
server_name $LXC_HOSTNAME.$LXC_DOMAIN;
|
||||||
|
|
||||||
|
root $webroot;
|
||||||
|
|
||||||
|
index index.php;
|
||||||
|
|
||||||
|
ssl_certificate /etc/nginx/ssl/kimai.crt;
|
||||||
|
ssl_certificate_key /etc/nginx/ssl/kimai.key;
|
||||||
|
|
||||||
|
access_log /var/log/nginx/kimai.access.log;
|
||||||
|
error_log /var/log/nginx/kimai.error.log;
|
||||||
|
|
||||||
|
location / {
|
||||||
|
try_files \$uri \$uri/ /index.php?\$query_string;
|
||||||
|
}
|
||||||
|
|
||||||
|
location ~ \.php$ {
|
||||||
|
fastcgi_split_path_info ^(.+\.php)(/.+)$;
|
||||||
|
fastcgi_pass unix:/run/php/php${PHP_VERSION}-fpm.sock;
|
||||||
|
fastcgi_index index.php;
|
||||||
|
include fastcgi_params;
|
||||||
|
fastcgi_param SCRIPT_FILENAME \$document_root\$fastcgi_script_name;
|
||||||
|
fastcgi_intercept_errors off;
|
||||||
|
fastcgi_buffer_size 16k;
|
||||||
|
fastcgi_buffers 4 16k;
|
||||||
|
}
|
||||||
|
|
||||||
|
location = /favicon.ico { access_log off; log_not_found off; }
|
||||||
|
location = /robots.txt { access_log off; log_not_found off; }
|
||||||
|
|
||||||
|
location ~ /\.ht {
|
||||||
|
deny all;
|
||||||
|
}
|
||||||
|
|
||||||
|
fastcgi_hide_header X-Powered-By;
|
||||||
|
fastcgi_read_timeout 3600;
|
||||||
|
fastcgi_send_timeout 3600;
|
||||||
|
fastcgi_connect_timeout 3600;
|
||||||
|
|
||||||
|
add_header Permissions-Policy "interest-cohort=()";
|
||||||
|
add_header Referrer-Policy "no-referrer" always;
|
||||||
|
add_header X-Content-Type-Options "nosniff" always;
|
||||||
|
add_header X-Download-Options "noopen" always;
|
||||||
|
add_header X-Frame-Options "SAMEORIGIN" always;
|
||||||
|
add_header X-Permitted-Cross-Domain-Policies "none" always;
|
||||||
|
add_header X-Robots-Tag "none" always;
|
||||||
|
add_header X-XSS-Protection "1; mode=block" always;
|
||||||
|
|
||||||
|
gzip on;
|
||||||
|
gzip_vary on;
|
||||||
|
gzip_comp_level 4;
|
||||||
|
gzip_min_length 256;
|
||||||
|
gzip_proxied expired no-cache no-store private no_last_modified no_etag auth;
|
||||||
|
gzip_types application/atom+xml application/javascript application/json application/ld+json application/manifest+json application/rss+xml application/vnd.geo+json application/vnd.ms-fontobject application/x-font-ttf application/x-web-app-manifest+json application/xhtml+xml application/xml font/opentype image/bmp image/svg+xml image/x-icon text/cache-manifest text/css text/plain text/vcard text/vnd.rim.location.xloc text/vtt text/x-component text/x-cross-domain-policy;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
EOF
|
||||||
|
|
||||||
|
mysql -uroot -e "CREATE USER 'kimai'@'localhost' IDENTIFIED BY '$KIMAI_DB_PWD';
|
||||||
|
CREATE DATABASE IF NOT EXISTS kimai;
|
||||||
|
GRANT ALL PRIVILEGES ON kimai.* TO 'kimai'@'localhost' IDENTIFIED BY '$KIMAI_DB_PWD';
|
||||||
|
FLUSH PRIVILEGES;"
|
||||||
|
|
||||||
|
sed -i "s/post_max_size = 8M/post_max_size = 2M/g" /etc/php/${PHP_VERSION}/fpm/php.ini
|
||||||
|
sed -i "s/memory_limit = 128M/memory_limit = 512M/g" /etc/php/${PHP_VERSION}/fpm/php.ini
|
||||||
|
sed -i "s/;opcache.enable=1/opcache.enable=1/g" /etc/php/${PHP_VERSION}/fpm/php.ini
|
||||||
|
sed -i "s/;opcache.memory_consumption=128/opcache.memory_consumption=256/g" /etc/php/${PHP_VERSION}/fpm/php.ini
|
||||||
|
sed -i "s/opcache.interned_strings_buffer=8/opcache.interned_strings_buffer=24/g" /etc/php/${PHP_VERSION}/fpm/php.ini
|
||||||
|
sed -i "s/;opcache.max_accelerated_files=10000/opcache.max_accelerated_files=100000/g" /etc/php/${PHP_VERSION}/fpm/php.ini
|
||||||
|
sed -i "s/;opcache.validate_timestamps=1/opcache.validate_timestamps=0/g" /etc/php/${PHP_VERSION}/fpm/php.ini
|
||||||
|
sed -i "s/session.gc_maxlifetime = 1440/session.gc_maxlifetime = 604800/g" /etc/php/${PHP_VERSION}/fpm/php.ini
|
||||||
|
|
||||||
|
EXPECTED_CHECKSUM="$(php -r 'copy("https://composer.github.io/installer.sig", "php://stdout");')"
|
||||||
|
php -r "copy('https://getcomposer.org/installer', 'composer-setup.php');"
|
||||||
|
ACTUAL_CHECKSUM="$(php -r "echo hash_file('sha384', 'composer-setup.php');")"
|
||||||
|
if [ "$EXPECTED_CHECKSUM" != "$ACTUAL_CHECKSUM" ]
|
||||||
|
then
|
||||||
|
>&2 echo 'ERROR: Invalid composer installer checksum'
|
||||||
|
rm composer-setup.php
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
php composer-setup.php --quiet
|
||||||
|
rm composer-setup.php
|
||||||
|
# Move composer to global installation
|
||||||
|
mv composer.phar /usr/local/bin/composer
|
||||||
|
|
||||||
|
cd /var/www
|
||||||
|
git clone https://github.com/kimai/kimai.git --branch $KIMAI_VERSION --depth 1
|
||||||
|
cd kimai
|
||||||
|
|
||||||
|
# Install kimai composer dependencies
|
||||||
|
export COMPOSER_ALLOW_SUPERUSER=1
|
||||||
|
/usr/local/bin/composer install --optimize-autoloader -n
|
||||||
|
|
||||||
|
# Copy and update kimai environment variables
|
||||||
|
cat << EOF > .env
|
||||||
|
# For more infos about the variables, see .env.dist
|
||||||
|
DATABASE_URL=mysql://kimai:$KIMAI_DB_PWD@localhost:3306/kimai?charset=utf8&serverVersion=mariadb-10.5.8
|
||||||
|
MAILER_FROM=admin@$LXC_DOMAIN
|
||||||
|
MAILER_URL=null://null
|
||||||
|
APP_ENV=prod
|
||||||
|
APP_SECRET=$(random_password)
|
||||||
|
CORS_ALLOW_ORIGIN=^https?://localhost(:[0-9]+)?$
|
||||||
|
EOF
|
||||||
|
|
||||||
|
bin/console kimai:install -n
|
||||||
|
|
||||||
|
bin/console kimai:user:create admin admin@$LXC_DOMAIN ROLE_SUPER_ADMIN $LXC_PWD
|
||||||
|
|
||||||
|
chown -R www-data:www-data .
|
||||||
|
chmod -R g+r .
|
||||||
|
chmod -R g+rw var/
|
||||||
|
|
||||||
|
systemctl daemon-reload
|
||||||
|
systemctl enable --now php${PHP_VERSION}-fpm nginx
|
||||||
|
systemctl restart php${PHP_VERSION}-fpm nginx
|
||||||
|
|
||||||
|
LXC_IP=$(ip address show dev eth0 | grep "inet " | cut -d ' ' -f6)
|
||||||
|
|
||||||
|
echo -e "Your kimai installation is now complete. Please continue with setup in your Browser.\nURL:\t\thttp://$(echo ${LXC_IP} | cut -d'/' -f1)\nLogin:\t\tadmin@${LXC_DOMAIN}\nPassword:\t${LXC_PWD}\n\n"
|
@ -8,10 +8,10 @@
|
|||||||
# This file contains the project constants on service level
|
# This file contains the project constants on service level
|
||||||
|
|
||||||
# Debian Version, which will be installed
|
# Debian Version, which will be installed
|
||||||
LXC_TEMPLATE_VERSION="debian-10-standard"
|
LXC_TEMPLATE_VERSION="debian-11-standard"
|
||||||
|
|
||||||
# Create sharefs mountpoint
|
# Create sharefs mountpoint
|
||||||
LXC_MP="1"
|
LXC_MP="0"
|
||||||
|
|
||||||
# Create unprivileged container
|
# Create unprivileged container
|
||||||
LXC_UNPRIVILEGED="1"
|
LXC_UNPRIVILEGED="1"
|
||||||
@ -23,7 +23,7 @@ LXC_NESTING="1"
|
|||||||
KOPANO_VERSION="latest"
|
KOPANO_VERSION="latest"
|
||||||
|
|
||||||
# Defines the php version to install
|
# Defines the php version to install
|
||||||
KOPANO_PHP_VERSION="7.3"
|
KOPANO_PHP_VERSION="7.4"
|
||||||
|
|
||||||
# Defines Maria DB Version
|
# Defines Maria DB Version
|
||||||
MARIA_DB_VERS="10.5"
|
MARIA_DB_VERS="10.5"
|
||||||
@ -39,3 +39,8 @@ MARIA_DB_USER="kopano"
|
|||||||
MARIA_ROOT_PWD=$(random_password)
|
MARIA_ROOT_PWD=$(random_password)
|
||||||
MARIA_USER_PWD=$(random_password)
|
MARIA_USER_PWD=$(random_password)
|
||||||
|
|
||||||
|
# Sets the minimum amount of RAM the service needs for operation
|
||||||
|
LXC_MEM_MIN=4096
|
||||||
|
|
||||||
|
# service dependent meta tags
|
||||||
|
SERVICE_TAGS="php-fpm,nginx,mariadb"
|
@ -11,8 +11,8 @@ source /root/constants-service.conf
|
|||||||
|
|
||||||
HOSTNAME=$(hostname -f)
|
HOSTNAME=$(hostname -f)
|
||||||
|
|
||||||
wget -q -O - https://packages.sury.org/php/apt.gpg | apt-key add -
|
#wget -q -O - https://packages.sury.org/php/apt.gpg | apt-key add -
|
||||||
echo "deb https://packages.sury.org/php/ $(lsb_release -cs) main" | tee /etc/apt/sources.list.d/php.list
|
#echo "deb https://packages.sury.org/php/ $(lsb_release -cs) main" | tee /etc/apt/sources.list.d/php.list
|
||||||
|
|
||||||
wget -q -O - https://nginx.org/keys/nginx_signing.key | apt-key add -
|
wget -q -O - https://nginx.org/keys/nginx_signing.key | apt-key add -
|
||||||
echo "deb http://nginx.org/packages/debian $(lsb_release -cs) nginx" | tee /etc/apt/sources.list.d/nginx.list
|
echo "deb http://nginx.org/packages/debian $(lsb_release -cs) nginx" | tee /etc/apt/sources.list.d/nginx.list
|
||||||
@ -22,8 +22,10 @@ echo "deb https://mirror.wtnet.de/mariadb/repo/$MARIA_DB_VERS/debian $(lsb_relea
|
|||||||
|
|
||||||
apt update
|
apt update
|
||||||
|
|
||||||
|
#DEBIAN_FRONTEND=noninteractive DEBIAN_PRIORITY=critical apt install -y -qq --no-install-recommends nginx-light mariadb-server postfix postfix-ldap \
|
||||||
|
#php$KOPANO_PHP_VERSION-{cli,common,curl,fpm,gd,json,mysql,mbstring,opcache,phpdbg,readline,soap,xml,zip}
|
||||||
DEBIAN_FRONTEND=noninteractive DEBIAN_PRIORITY=critical apt install -y -qq --no-install-recommends nginx-light mariadb-server postfix postfix-ldap \
|
DEBIAN_FRONTEND=noninteractive DEBIAN_PRIORITY=critical apt install -y -qq --no-install-recommends nginx-light mariadb-server postfix postfix-ldap \
|
||||||
php$KOPANO_PHP_VERSION-{cli,common,curl,fpm,gd,json,mysql,mbstring,opcache,phpdbg,readline,soap,xml,zip}
|
php-{cli,common,curl,fpm,gd,json,mysql,mbstring,opcache,phpdbg,readline,soap,xml,zip}
|
||||||
|
|
||||||
#timedatectl set-timezone Europe/Berlin
|
#timedatectl set-timezone Europe/Berlin
|
||||||
#mkdir -p /$LXC_SHAREFS_MOUNTPOINT/$NEXTCLOUD_DATA /var/www
|
#mkdir -p /$LXC_SHAREFS_MOUNTPOINT/$NEXTCLOUD_DATA /var/www
|
||||||
@ -35,7 +37,7 @@ mysqladmin -u root password "[$MARIA_ROOT_PWD]"
|
|||||||
|
|
||||||
mysql -uroot -p$MARIA_ROOT_PWD -e"DELETE FROM mysql.user WHERE User=''"
|
mysql -uroot -p$MARIA_ROOT_PWD -e"DELETE FROM mysql.user WHERE User=''"
|
||||||
mysql -uroot -p$MARIA_ROOT_PWD -e"DELETE FROM mysql.user WHERE User='root' AND Host NOT IN ('localhost', '127.0.0.1', '::1')"
|
mysql -uroot -p$MARIA_ROOT_PWD -e"DELETE FROM mysql.user WHERE User='root' AND Host NOT IN ('localhost', '127.0.0.1', '::1')"
|
||||||
mysql -uroot -p$MARIA_ROOT_PWD -e"DROP DATABASE test;DELETE FROM mysql.db WHERE Db='test' OR Db='test_%'"
|
#mysql -uroot -p$MARIA_ROOT_PWD -e"DROP DATABASE test;DELETE FROM mysql.db WHERE Db='test' OR Db='test_%'"
|
||||||
mysql -uroot -p$MARIA_ROOT_PWD -e"FLUSH PRIVILEGES"
|
mysql -uroot -p$MARIA_ROOT_PWD -e"FLUSH PRIVILEGES"
|
||||||
|
|
||||||
#### Create user and DB for Kopano ####
|
#### Create user and DB for Kopano ####
|
||||||
@ -50,19 +52,19 @@ db-user: $MARIA_DB_USER, password: $MARIA_USER_PWD" > /root/maria.log
|
|||||||
cat > /etc/apt/sources.list.d/kopano.list << EOF
|
cat > /etc/apt/sources.list.d/kopano.list << EOF
|
||||||
|
|
||||||
# Kopano Core
|
# Kopano Core
|
||||||
deb https://download.kopano.io/supported/core:/final/Debian_10/ ./
|
deb https://download.kopano.io/supported/core:/final/Debian_11/ ./
|
||||||
|
|
||||||
# Kopano WebApp
|
# Kopano WebApp
|
||||||
deb https://download.kopano.io/supported/webapp:/final/Debian_10/ ./
|
deb https://download.kopano.io/supported/webapp:/final/Debian_11/ ./
|
||||||
|
|
||||||
# Kopano MobileDeviceManagement
|
# Kopano MobileDeviceManagement
|
||||||
deb https://download.kopano.io/supported/mdm:/final/Debian_10/ ./
|
deb https://download.kopano.io/supported/mdm:/final/Debian_11/ ./
|
||||||
|
|
||||||
# Kopano Files
|
# Kopano Files
|
||||||
deb https://download.kopano.io/supported/files:/final/Debian_10/ ./
|
deb https://download.kopano.io/supported/files:/final/Debian_11/ ./
|
||||||
|
|
||||||
# Z-Push
|
# Z-Push
|
||||||
deb https://download.kopano.io/zhub/z-push:/final/Debian_10/ ./
|
deb https://download.kopano.io/zhub/z-push:/final/Debian_11/ ./
|
||||||
|
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
@ -74,11 +76,11 @@ password $KOPANO_REPKEY
|
|||||||
|
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
curl https://serial:$KOPANO_REPKEY@download.kopano.io/supported/core:/final/Debian_10/Release.key | apt-key add -
|
curl https://serial:$KOPANO_REPKEY@download.kopano.io/supported/core:/final/Debian_11/Release.key | apt-key add -
|
||||||
curl https://serial:$KOPANO_REPKEY@download.kopano.io/supported/webapp:/final/Debian_10/Release.key | apt-key add -
|
curl https://serial:$KOPANO_REPKEY@download.kopano.io/supported/webapp:/final/Debian_11/Release.key | apt-key add -
|
||||||
curl https://serial:$KOPANO_REPKEY@download.kopano.io/supported/mdm:/final/Debian_10/Release.key | apt-key add -
|
curl https://serial:$KOPANO_REPKEY@download.kopano.io/supported/mdm:/final/Debian_11/Release.key | apt-key add -
|
||||||
curl https://serial:$KOPANO_REPKEY@download.kopano.io/supported/files:/final/Debian_10/Release.key | apt-key add -
|
curl https://serial:$KOPANO_REPKEY@download.kopano.io/supported/files:/final/Debian_11/Release.key | apt-key add -
|
||||||
curl https://serial:$KOPANO_REPKEY@download.kopano.io/zhub/z-push:/final/Debian_10/Release.key | apt-key add -
|
curl https://serial:$KOPANO_REPKEY@download.kopano.io/zhub/z-push:/final/Debian_11/Release.key | apt-key add -
|
||||||
|
|
||||||
apt update && apt full-upgrade -y
|
apt update && apt full-upgrade -y
|
||||||
|
|
||||||
@ -91,7 +93,7 @@ cat > /etc/kopano/ldap.cfg << EOF
|
|||||||
|
|
||||||
!include /usr/share/kopano/ldap.active-directory.cfg
|
!include /usr/share/kopano/ldap.active-directory.cfg
|
||||||
|
|
||||||
ldap_uri = ldap://10.10.81.12:389
|
ldap_uri = ldap://192.168.100.100:389
|
||||||
ldap_bind_user = cn=zmb-ldap,cn=Users,dc=zmb,dc=rocks
|
ldap_bind_user = cn=zmb-ldap,cn=Users,dc=zmb,dc=rocks
|
||||||
ldap_bind_passwd = Start123!
|
ldap_bind_passwd = Start123!
|
||||||
ldap_search_base = dc=zmb,dc=rocks
|
ldap_search_base = dc=zmb,dc=rocks
|
||||||
@ -112,8 +114,8 @@ mysql_user = $MARIA_DB_USER
|
|||||||
mysql_password = $MARIA_USER_PWD
|
mysql_password = $MARIA_USER_PWD
|
||||||
mysql_database = $MARIA_DB_NAME
|
mysql_database = $MARIA_DB_NAME
|
||||||
|
|
||||||
user_plugin = ldap
|
#user_plugin = ldap
|
||||||
user_plugin_config = /etc/kopano/ldap.cfg
|
#user_plugin_config = /etc/kopano/ldap.cfg
|
||||||
|
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
@ -121,7 +123,7 @@ EOF
|
|||||||
|
|
||||||
sed -i "s/define('LANG', 'en_US.UTF-8')/define('LANG', 'de_DE.UTF-8')/" /etc/kopano/webapp/config.php
|
sed -i "s/define('LANG', 'en_US.UTF-8')/define('LANG', 'de_DE.UTF-8')/" /etc/kopano/webapp/config.php
|
||||||
|
|
||||||
cat > /etc/php/7.3/fpm/pool.d/webapp.conf << EOF
|
cat > /etc/php/7.4/fpm/pool.d/webapp.conf << EOF
|
||||||
|
|
||||||
[webapp]
|
[webapp]
|
||||||
listen = 127.0.0.1:9002
|
listen = 127.0.0.1:9002
|
||||||
@ -153,9 +155,9 @@ openssl dhparam -dsaparam -out /etc/ssl/certs/dhparam.pem 4096
|
|||||||
|
|
||||||
cat > /etc/nginx/sites-available/webapp.conf << EOF
|
cat > /etc/nginx/sites-available/webapp.conf << EOF
|
||||||
upstream php-handler {
|
upstream php-handler {
|
||||||
server 127.0.0.1:9002;
|
#server 127.0.0.1:9002;
|
||||||
#server unix:/var/run/php5-fpm.sock;
|
#server unix:/var/run/php5-fpm.sock;
|
||||||
#server unix:/var/run/php/php7.3-fpm.sock;
|
server unix:/var/run/php/php7.4-fpm.sock;
|
||||||
}
|
}
|
||||||
|
|
||||||
server{
|
server{
|
||||||
@ -270,5 +272,5 @@ EOF
|
|||||||
|
|
||||||
ln -s /etc/nginx/sites-available/webapp.conf /etc/nginx/sites-enabled/
|
ln -s /etc/nginx/sites-available/webapp.conf /etc/nginx/sites-enabled/
|
||||||
|
|
||||||
systemctl restart nginx
|
phpenmod kopano
|
||||||
|
systemctl restart php7.4-fpm nginx
|
||||||
|
@ -16,6 +16,7 @@ source /root/constants-service.conf
|
|||||||
echo "Updating locales"
|
echo "Updating locales"
|
||||||
# update locales
|
# update locales
|
||||||
sed -i "s|# $LXC_LOCALE|$LXC_LOCALE|" /etc/locale.gen
|
sed -i "s|# $LXC_LOCALE|$LXC_LOCALE|" /etc/locale.gen
|
||||||
|
sed -i "s|# en_US.UTF-8|en_US.UTF-8|" /etc/locale.gen
|
||||||
cat << EOF > /etc/default/locale
|
cat << EOF > /etc/default/locale
|
||||||
LANG="$LXC_LOCALE"
|
LANG="$LXC_LOCALE"
|
||||||
LANGUAGE=$LXC_LOCALE
|
LANGUAGE=$LXC_LOCALE
|
||||||
@ -26,23 +27,23 @@ locale-gen $LXC_LOCALE
|
|||||||
if [ "$LXC_TEMPLATE_VERSION" == "debian-11-standard" ] ; then
|
if [ "$LXC_TEMPLATE_VERSION" == "debian-11-standard" ] ; then
|
||||||
|
|
||||||
cat << EOF > /etc/apt/sources.list
|
cat << EOF > /etc/apt/sources.list
|
||||||
deb https://debian.inf.tu-dresden.de/debian bullseye main contrib
|
deb http://debian.inf.tu-dresden.de/debian bullseye main contrib
|
||||||
|
|
||||||
deb https://debian.inf.tu-dresden.de/debian bullseye-updates main contrib
|
deb http://debian.inf.tu-dresden.de/debian bullseye-updates main contrib
|
||||||
|
|
||||||
# security updates
|
# security updates
|
||||||
deb https://debian.inf.tu-dresden.de/debian-security bullseye-security main contrib
|
deb http://debian.inf.tu-dresden.de/debian-security bullseye-security main contrib
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
elif [ "$LXC_TEMPLATE_VERSION" == "debian-10-standard" ] ; then
|
elif [ "$LXC_TEMPLATE_VERSION" == "debian-10-standard" ] ; then
|
||||||
|
|
||||||
cat << EOF > /etc/apt/sources.list
|
cat << EOF > /etc/apt/sources.list
|
||||||
deb https://debian.inf.tu-dresden.de/debian buster main contrib
|
deb http://debian.inf.tu-dresden.de/debian buster main contrib
|
||||||
|
|
||||||
deb https://debian.inf.tu-dresden.de/debian buster-updates main contrib
|
deb http://debian.inf.tu-dresden.de/debian buster-updates main contrib
|
||||||
|
|
||||||
# security updates
|
# security updates
|
||||||
deb https://debian.inf.tu-dresden.de/debian-security buster/updates main contrib
|
deb http://debian.inf.tu-dresden.de/debian-security buster/updates main contrib
|
||||||
EOF
|
EOF
|
||||||
else echo "LXC Debian Version false. Please check configuration files!" ; exit
|
else echo "LXC Debian Version false. Please check configuration files!" ; exit
|
||||||
fi
|
fi
|
||||||
|
@ -20,8 +20,14 @@ LXC_UNPRIVILEGED="1"
|
|||||||
LXC_NESTING="1"
|
LXC_NESTING="1"
|
||||||
|
|
||||||
# Defines the version number of piler mail archive to install (type in exact version number (e.g. 1.3.11) or 'latest')
|
# Defines the version number of piler mail archive to install (type in exact version number (e.g. 1.3.11) or 'latest')
|
||||||
PILER_VERSION="latest"
|
PILER_VERSION="1.3.12"
|
||||||
# Defines the version of sphinx to install
|
# Defines the version of sphinx to install
|
||||||
PILER_SPHINX_VERSION="3.3.1"
|
PILER_SPHINX_VERSION="3.3.1"
|
||||||
# Defines the php version to install
|
# Defines the php version to install
|
||||||
PILER_PHP_VERSION="7.4"
|
PILER_PHP_VERSION="7.4"
|
||||||
|
|
||||||
|
# Sets the minimum amount of RAM the service needs for operation
|
||||||
|
LXC_MEM_MIN=1024
|
||||||
|
|
||||||
|
# service dependent meta tags
|
||||||
|
SERVICE_TAGS="php-fpm,nginx,mariadb,sphinx"
|
@ -19,5 +19,8 @@ LXC_UNPRIVILEGED="1"
|
|||||||
# enable nesting feature
|
# enable nesting feature
|
||||||
LXC_NESTING="1"
|
LXC_NESTING="1"
|
||||||
|
|
||||||
# Define the version of Element Web
|
# Sets the minimum amount of RAM the service needs for operation
|
||||||
MATRIX_ELEMENT_VERSION="v1.9.9"
|
LXC_MEM_MIN=1024
|
||||||
|
|
||||||
|
# service dependent meta tags
|
||||||
|
SERVICE_TAGS="nginx,postgresql,element-web"
|
@ -14,6 +14,8 @@ MRX_PKE=$(random_password)
|
|||||||
ELE_DBNAME="synapse_db"
|
ELE_DBNAME="synapse_db"
|
||||||
ELE_DBUSER="synapse_user"
|
ELE_DBUSER="synapse_user"
|
||||||
ELE_DBPASS=$(random_password)
|
ELE_DBPASS=$(random_password)
|
||||||
|
ELE_PATH=/var/www/element-web
|
||||||
|
WEBROOT=/var/www
|
||||||
|
|
||||||
DEBIAN_FRONTEND=noninteractive DEBIAN_PRIORITY=critical apt install -y -qq nginx postgresql python3-psycopg2
|
DEBIAN_FRONTEND=noninteractive DEBIAN_PRIORITY=critical apt install -y -qq nginx postgresql python3-psycopg2
|
||||||
|
|
||||||
@ -67,7 +69,7 @@ server {
|
|||||||
ssl_certificate_key /etc/nginx/ssl/matrix.key;
|
ssl_certificate_key /etc/nginx/ssl/matrix.key;
|
||||||
|
|
||||||
# If you don't wanna serve a site, comment this out
|
# If you don't wanna serve a site, comment this out
|
||||||
root /var/www/$MATRIX_FQDN;
|
root $ELE_PATH;
|
||||||
index index.html index.htm;
|
index index.html index.htm;
|
||||||
|
|
||||||
location / {
|
location / {
|
||||||
@ -102,7 +104,7 @@ server {
|
|||||||
ssl_certificate_key /etc/nginx/ssl/matrix.key;
|
ssl_certificate_key /etc/nginx/ssl/matrix.key;
|
||||||
|
|
||||||
# If you don't wanna serve a site, comment this out
|
# If you don't wanna serve a site, comment this out
|
||||||
root /var/www/$MATRIX_ELEMENT_FQDN/element;
|
root $ELE_PATH;
|
||||||
index index.html index.htm;
|
index index.html index.htm;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -113,21 +115,23 @@ ln -s /etc/nginx/sites-available/$MATRIX_ELEMENT_FQDN /etc/nginx/sites-enabled/$
|
|||||||
|
|
||||||
systemctl restart nginx
|
systemctl restart nginx
|
||||||
|
|
||||||
mkdir /var/www/$MATRIX_ELEMENT_FQDN
|
cd /var/www
|
||||||
cd /var/www/$MATRIX_ELEMENT_FQDN
|
|
||||||
wget https://packages.riot.im/element-release-key.asc
|
wget -O element-release-key.asc https://packages.riot.im/element-release-key.asc
|
||||||
gpg --import element-release-key.asc
|
gpg --import element-release-key.asc
|
||||||
|
|
||||||
wget https://github.com/vector-im/element-web/releases/download/$MATRIX_ELEMENT_VERSION/element-$MATRIX_ELEMENT_VERSION.tar.gz
|
MATRIX_ELEMENT_VERSION=$(curl -s https://api.github.com/repos/vector-im/element-web/releases/latest | grep tag_name | cut -d'"' -f4)
|
||||||
wget https://github.com/vector-im/element-web/releases/download/$MATRIX_ELEMENT_VERSION/element-$MATRIX_ELEMENT_VERSION.tar.gz.asc
|
|
||||||
|
wget -O element-$MATRIX_ELEMENT_VERSION.tar.gz https://github.com/vector-im/element-web/releases/download/$MATRIX_ELEMENT_VERSION/element-$MATRIX_ELEMENT_VERSION.tar.gz
|
||||||
|
wget -O element-$MATRIX_ELEMENT_VERSION.tar.gz.asc https://github.com/vector-im/element-web/releases/download/$MATRIX_ELEMENT_VERSION/element-$MATRIX_ELEMENT_VERSION.tar.gz.asc
|
||||||
gpg --verify element-$MATRIX_ELEMENT_VERSION.tar.gz.asc
|
gpg --verify element-$MATRIX_ELEMENT_VERSION.tar.gz.asc
|
||||||
|
|
||||||
tar -xzvf element-$MATRIX_ELEMENT_VERSION.tar.gz
|
tar -xzvf element-$MATRIX_ELEMENT_VERSION.tar.gz
|
||||||
ln -s element-$MATRIX_ELEMENT_VERSION element
|
mv element-$MATRIX_ELEMENT_VERSION $ELE_PATH
|
||||||
chown www-data:www-data -R element
|
chown www-data:www-data -R $ELE_PATH
|
||||||
cp ./element/config.sample.json ./element/config.json
|
cp $ELE_PATH/config.sample.json $ELE_PATH/config.json
|
||||||
sed -i "s|https://matrix-client.matrix.org|https://$MATRIX_FQDN|" ./element/config.json
|
sed -i "s|https://matrix-client.matrix.org|https://$MATRIX_FQDN|" $ELE_PATH/config.json
|
||||||
sed -i "s|\"server_name\": \"matrix.org\"|\"server_name\": \"$MATRIX_FQDN\"|" ./element/config.json
|
sed -i "s|\"server_name\": \"matrix.org\"|\"server_name\": \"$MATRIX_FQDN\"|" $ELE_PATH/config.json
|
||||||
|
|
||||||
su postgres <<EOF
|
su postgres <<EOF
|
||||||
psql -c "CREATE USER $ELE_DBUSER WITH PASSWORD '$ELE_DBPASS';"
|
psql -c "CREATE USER $ELE_DBUSER WITH PASSWORD '$ELE_DBPASS';"
|
||||||
@ -143,12 +147,13 @@ sed -i "s|#enable_registration: false|enable_registration: true|" /etc/matrix-sy
|
|||||||
sed -i "s|name: sqlite3|name: psycopg2|" /etc/matrix-synapse/homeserver.yaml
|
sed -i "s|name: sqlite3|name: psycopg2|" /etc/matrix-synapse/homeserver.yaml
|
||||||
sed -i "s|database: /var/lib/matrix-synapse/homeserver.db|database: $ELE_DBNAME\n user: $ELE_DBUSER\n password: $ELE_DBPASS\n host: 127.0.0.1\n cp_min: 5\n cp_max: 10|" /etc/matrix-synapse/homeserver.yaml
|
sed -i "s|database: /var/lib/matrix-synapse/homeserver.db|database: $ELE_DBNAME\n user: $ELE_DBUSER\n password: $ELE_DBPASS\n host: 127.0.0.1\n cp_min: 5\n cp_max: 10|" /etc/matrix-synapse/homeserver.yaml
|
||||||
|
|
||||||
|
reg_secret=$(random_password)
|
||||||
|
echo -e "registration_shared_secret: \"$reg_secret\"" > /etc/matrix-synapse/conf.d/registration.yaml
|
||||||
|
|
||||||
systemctl restart matrix-synapse
|
systemctl restart matrix-synapse
|
||||||
|
|
||||||
register_new_matrix_user -a -u $MATRIX_ADMIN_USER -p '$MATRIX_ADMIN_PASSWORD' -c /etc/matrix-synapse/homeserver.yaml http://127.0.0.1:8008
|
rm /var/www/element-release-key.asc /var/www/element-$MATRIX_ELEMENT_VERSION.tar.gz /var/www/element-$MATRIX_ELEMENT_VERSION.tar.gz.asc
|
||||||
|
|
||||||
#curl https://download.jitsi.org/jitsi-key.gpg.key | sh -c 'gpg --dearmor > /usr/share/keyrings/jitsi-keyring.gpg'
|
register_new_matrix_user -a -u $MATRIX_ADMIN_USER -p \'$MATRIX_ADMIN_PASSWORD\' -c /etc/matrix-synapse/conf.d/registration.yaml http://127.0.0.1:8008
|
||||||
#echo 'deb [signed-by=/usr/share/keyrings/jitsi-keyring.gpg] https://download.jitsi.org stable/' | tee /etc/apt/sources.list.d/jitsi-stable.list > /dev/null
|
|
||||||
|
|
||||||
#apt update
|
echo -e "Your matrix installation is now complete. Please login into your element:\nLogin:\t\t$MATRIX_ADMIN_USER\nPassword:\t$MATRIX_ADMIN_PASSWORD\n\n"
|
||||||
#apt install -y jitsi-meet
|
|
@ -23,7 +23,7 @@ LXC_NESTING="1"
|
|||||||
NEXTCLOUD_VERSION="latest"
|
NEXTCLOUD_VERSION="latest"
|
||||||
|
|
||||||
# Defines the php version to install
|
# Defines the php version to install
|
||||||
NEXTCLOUD_PHP_VERSION="8.0"
|
NEXTCLOUD_PHP_VERSION="8.1"
|
||||||
|
|
||||||
# Defines the IP from the SQL server
|
# Defines the IP from the SQL server
|
||||||
NEXTCLOUD_DB_IP="127.0.0.1"
|
NEXTCLOUD_DB_IP="127.0.0.1"
|
||||||
@ -39,3 +39,9 @@ NEXTCLOUD_DB_USR="nextcloud"
|
|||||||
|
|
||||||
# Build a strong password for the SQL user - could be overwritten with something fixed
|
# Build a strong password for the SQL user - could be overwritten with something fixed
|
||||||
NEXTCLOUD_DB_PWD="$(random_password)"
|
NEXTCLOUD_DB_PWD="$(random_password)"
|
||||||
|
|
||||||
|
# Sets the minimum amount of RAM the service needs for operation
|
||||||
|
LXC_MEM_MIN=4096
|
||||||
|
|
||||||
|
# service dependent meta tags
|
||||||
|
SERVICE_TAGS="php-fpm,nginx,postgresql"
|
@ -6,6 +6,9 @@
|
|||||||
# (C) 2021 Script rework and documentation by Thorsten Spille <thorsten@spille-edv.de>
|
# (C) 2021 Script rework and documentation by Thorsten Spille <thorsten@spille-edv.de>
|
||||||
|
|
||||||
source /root/functions.sh
|
source /root/functions.sh
|
||||||
|
|
||||||
|
NEXTCLOUD_ADMIN_PWD=$(random_password)
|
||||||
|
|
||||||
source /root/zamba.conf
|
source /root/zamba.conf
|
||||||
source /root/constants-service.conf
|
source /root/constants-service.conf
|
||||||
|
|
||||||
@ -22,7 +25,7 @@ echo "deb http://apt.postgresql.org/pub/repos/apt $(lsb_release -cs)-pgdg main"
|
|||||||
|
|
||||||
apt update
|
apt update
|
||||||
|
|
||||||
DEBIAN_FRONTEND=noninteractive DEBIAN_PRIORITY=critical apt install -y -qq --no-install-recommends sudo tree locate screen zip ffmpeg ghostscript libfile-fcntllock-perl libfuse2 socat fail2ban ldap-utils cifs-utils redis-server imagemagick libmagickcore-6.q16-6-extra \
|
DEBIAN_FRONTEND=noninteractive DEBIAN_PRIORITY=critical apt install -y -qq --no-install-recommends tree locate screen zip ffmpeg ghostscript libfile-fcntllock-perl libfuse2 socat fail2ban ldap-utils cifs-utils redis-server imagemagick libmagickcore-6.q16-6-extra \
|
||||||
postgresql-13 nginx php$NEXTCLOUD_PHP_VERSION-{fpm,gd,mysql,pgsql,curl,xml,zip,intl,mbstring,bz2,ldap,apcu,bcmath,gmp,imagick,igbinary,redis,dev,smbclient,cli,common,opcache,readline}
|
postgresql-13 nginx php$NEXTCLOUD_PHP_VERSION-{fpm,gd,mysql,pgsql,curl,xml,zip,intl,mbstring,bz2,ldap,apcu,bcmath,gmp,imagick,igbinary,redis,dev,smbclient,cli,common,opcache,readline}
|
||||||
|
|
||||||
timedatectl set-timezone $LXC_TIMEZONE
|
timedatectl set-timezone $LXC_TIMEZONE
|
||||||
@ -399,7 +402,9 @@ array (
|
|||||||
'updater.release.channel' => 'stable',
|
'updater.release.channel' => 'stable',
|
||||||
'trusted_proxies' =>
|
'trusted_proxies' =>
|
||||||
array (
|
array (
|
||||||
'$NEXTCLOUD_REVPROX'
|
'$NEXTCLOUD_REVPROX',
|
||||||
|
'127.0.0.1',
|
||||||
|
'::1',
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
EOF
|
EOF
|
||||||
|
26
src/omada/constants-service.conf
Normal file
26
src/omada/constants-service.conf
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Authors:
|
||||||
|
# (C) 2021 Idea an concept by Christian Zengel <christian@sysops.de>
|
||||||
|
# (C) 2021 Script design and prototype by Markus Helmke <m.helmke@nettwarker.de>
|
||||||
|
# (C) 2021 Script rework and documentation by Thorsten Spille <thorsten@spille-edv.de>
|
||||||
|
|
||||||
|
# This file contains the project constants on service level
|
||||||
|
|
||||||
|
# Debian Version, which will be installed
|
||||||
|
LXC_TEMPLATE_VERSION="debian-11-standard"
|
||||||
|
|
||||||
|
# Create sharefs mountpoint
|
||||||
|
LXC_MP="0"
|
||||||
|
|
||||||
|
# Create unprivileged container
|
||||||
|
LXC_UNPRIVILEGED="1"
|
||||||
|
|
||||||
|
# enable nesting feature
|
||||||
|
LXC_NESTING="1"
|
||||||
|
|
||||||
|
# Sets the minimum amount of RAM the service needs for operation
|
||||||
|
LXC_MEM_MIN=2048
|
||||||
|
|
||||||
|
# service dependent meta tags
|
||||||
|
SERVICE_TAGS="mongodb-server,java"
|
29
src/omada/install-service.sh
Normal file
29
src/omada/install-service.sh
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
set -euo pipefail
|
||||||
|
|
||||||
|
# Authors:
|
||||||
|
# (C) 2021 Idea an concept by Christian Zengel <christian@sysops.de>
|
||||||
|
# (C) 2021 Script design and prototype by Markus Helmke <m.helmke@nettwarker.de>
|
||||||
|
# (C) 2021 Script rework and documentation by Thorsten Spille <thorsten@spille-edv.de>
|
||||||
|
|
||||||
|
source /root/functions.sh
|
||||||
|
source /root/zamba.conf
|
||||||
|
source /root/constants-service.conf
|
||||||
|
|
||||||
|
wget -qO - https://adoptopenjdk.jfrog.io/adoptopenjdk/api/gpg/key/public | apt-key add -
|
||||||
|
add-apt-repository --yes https://adoptopenjdk.jfrog.io/adoptopenjdk/deb/
|
||||||
|
|
||||||
|
wget -O /etc/apt/trusted.gpg.d/mongodb-4.4.asc https://www.mongodb.org/static/pgp/server-4.4.asc
|
||||||
|
|
||||||
|
echo "deb http://repo.mongodb.org/apt/debian buster/mongodb-org/4.4 main" > /etc/apt/sources.list.d/mongodb.list
|
||||||
|
|
||||||
|
apt update
|
||||||
|
|
||||||
|
DEBIAN_FRONTEND=noninteractive DEBIAN_PRIORITY=critical apt install -y -qq adoptopenjdk-8-hotspot jsvc mongodb-org
|
||||||
|
|
||||||
|
DL=$(wget -O - -q https://www.tp-link.com/de/support/download/omada-software-controller/ 2>/dev/null | grep Download-Detail-Software_Omada-Software-Controller | grep "Linux_x64.deb" | head -1 | cut -d'"' -f6)
|
||||||
|
|
||||||
|
wget -O /tmp/omada.deb -q $DL
|
||||||
|
|
||||||
|
DEBIAN_FRONTEND=noninteractive DEBIAN_PRIORITY=critical apt install -y -qq /tmp/omada.deb
|
@ -24,3 +24,9 @@ ONLYOFFICE_DB_HOST=localhost
|
|||||||
ONLYOFFICE_DB_NAME=onlyoffice
|
ONLYOFFICE_DB_NAME=onlyoffice
|
||||||
|
|
||||||
ONLYOFFICE_DB_USER=onlyoffice
|
ONLYOFFICE_DB_USER=onlyoffice
|
||||||
|
|
||||||
|
# Sets the minimum amount of RAM the service needs for operation
|
||||||
|
LXC_MEM_MIN=1024
|
||||||
|
|
||||||
|
# service dependent meta tags
|
||||||
|
SERVICE_TAGS="nginx,postgresql,rabbitmq"
|
25
src/onlyoffice/fix-update.sh
Normal file
25
src/onlyoffice/fix-update.sh
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
cat > /usr/local/bin/ods-apt-pre-hook << DFOE
|
||||||
|
#!/bin/bash
|
||||||
|
rm /etc/nginx/conf.d/ds-ssl.conf
|
||||||
|
systemctl stop nginx.service
|
||||||
|
DFOE
|
||||||
|
chmod +x /usr/local/bin/ods-apt-pre-hook
|
||||||
|
|
||||||
|
cat > /usr/local/bin/ods-apt-post-hook << DFOE
|
||||||
|
#!/bin/bash
|
||||||
|
rm /etc/nginx/conf.d/ds.conf
|
||||||
|
ln -sf /etc/onlyoffice/documentserver/nginx/ds-ssl.conf /etc/nginx/conf.d/ds-ssl.conf
|
||||||
|
systemctl restart nginx
|
||||||
|
DFOE
|
||||||
|
chmod +x /usr/local/bin/ods-apt-post-hook
|
||||||
|
|
||||||
|
|
||||||
|
cat << EOF > /etc/apt/apt.conf.d/80-ods-apt-pre-hook
|
||||||
|
DPkg::Pre-Invoke {"/usr/local/bin/ods-apt-pre-hook";};
|
||||||
|
EOF
|
||||||
|
|
||||||
|
cat << EOF > /etc/apt/apt.conf.d/80-ods-apt-post-hook
|
||||||
|
DPkg::Post-Invoke {"/usr/local/bin/ods-apt-post-hook";};
|
||||||
|
EOF
|
@ -44,8 +44,33 @@ openssl req -x509 -nodes -days 3650 -newkey rsa:4096 -keyout /etc/nginx/ssl/only
|
|||||||
|
|
||||||
rm /etc/nginx/conf.d/ds.conf
|
rm /etc/nginx/conf.d/ds.conf
|
||||||
cp /etc/onlyoffice/documentserver/nginx/ds-ssl.conf.tmpl /etc/onlyoffice/documentserver/nginx/ds-ssl.conf
|
cp /etc/onlyoffice/documentserver/nginx/ds-ssl.conf.tmpl /etc/onlyoffice/documentserver/nginx/ds-ssl.conf
|
||||||
|
|
||||||
|
sed -i "s|ssl_certificate {{SSL_CERTIFICATE_PATH}}|ssl_certificate /etc/nginx/ssl/onlyoffice.crt|" /etc/onlyoffice/documentserver/nginx/ds-ssl.conf
|
||||||
|
sed -i "s|ssl_certificate_key {{SSL_KEY_PATH}}|ssl_certificate_key /etc/nginx/ssl/onlyoffice.key|" /etc/onlyoffice/documentserver/nginx/ds-ssl.conf
|
||||||
|
|
||||||
ln -sf /etc/onlyoffice/documentserver/nginx/ds-ssl.conf /etc/nginx/conf.d/ds-ssl.conf
|
ln -sf /etc/onlyoffice/documentserver/nginx/ds-ssl.conf /etc/nginx/conf.d/ds-ssl.conf
|
||||||
|
|
||||||
sed -i "s|ssl_certificate {{SSL_CERTIFICATE_PATH}}|ssl_certificate /etc/nginx/ssl/onlyoffice.crt|" /etc/nginx/conf.d/ds-ssl.conf
|
cat > /usr/local/bin/ods-apt-pre-hook << DFOE
|
||||||
sed -i "s|ssl_certificate_key {{SSL_KEY_PATH}}|ssl_certificate_key /etc/nginx/ssl/onlyoffice.key|" /etc/nginx/conf.d/ds-ssl.conf
|
#!/bin/bash
|
||||||
|
rm /etc/nginx/conf.d/ds-ssl.conf
|
||||||
|
systemctl stop nginx.service
|
||||||
|
DFOE
|
||||||
|
chmod +x /usr/local/bin/ods-apt-pre-hook
|
||||||
|
|
||||||
|
cat > /usr/local/bin/ods-apt-post-hook << DFOE
|
||||||
|
#!/bin/bash
|
||||||
|
rm /etc/nginx/conf.d/ds.conf
|
||||||
|
ln -sf /etc/onlyoffice/documentserver/nginx/ds-ssl.conf /etc/nginx/conf.d/ds-ssl.conf
|
||||||
|
systemctl restart nginx
|
||||||
|
DFOE
|
||||||
|
chmod +x /usr/local/bin/ods-apt-post-hook
|
||||||
|
|
||||||
|
cat << EOF > /etc/apt/apt.conf.d/80-ods-apt-pre-hook
|
||||||
|
DPkg::Pre-Invoke {"/usr/local/bin/ods-apt-pre-hook";};
|
||||||
|
EOF
|
||||||
|
|
||||||
|
cat << EOF > /etc/apt/apt.conf.d/80-ods-apt-post-hook
|
||||||
|
DPkg::Post-Invoke {"/usr/local/bin/ods-apt-post-hook";};
|
||||||
|
EOF
|
||||||
|
|
||||||
systemctl restart nginx
|
systemctl restart nginx
|
@ -18,3 +18,9 @@ LXC_UNPRIVILEGED="1"
|
|||||||
|
|
||||||
# enable nesting feature
|
# enable nesting feature
|
||||||
LXC_NESTING="1"
|
LXC_NESTING="1"
|
||||||
|
|
||||||
|
# Sets the minimum amount of RAM the service needs for operation
|
||||||
|
LXC_MEM_MIN=1024
|
||||||
|
|
||||||
|
# service dependent meta tags
|
||||||
|
SERVICE_TAGS="php-fpm,nginx,mariadb"
|
@ -11,6 +11,7 @@ source /root/constants-service.conf
|
|||||||
|
|
||||||
webroot=/var/www/html
|
webroot=/var/www/html
|
||||||
|
|
||||||
|
LXC_RANDOMPWD=20
|
||||||
MYSQL_PASSWORD="$(random_password)"
|
MYSQL_PASSWORD="$(random_password)"
|
||||||
|
|
||||||
apt update
|
apt update
|
||||||
@ -56,7 +57,7 @@ CREATE DATABASE IF NOT EXISTS open3a;
|
|||||||
GRANT ALL PRIVILEGES ON open3a . * TO 'open3a'@'localhost';"
|
GRANT ALL PRIVILEGES ON open3a . * TO 'open3a'@'localhost';"
|
||||||
|
|
||||||
cd $webroot
|
cd $webroot
|
||||||
wget https://www.open3a.de/download/open3A%203.5.zip -O $webroot/open3a.zip
|
wget https://www.open3a.de/download/open3A%203.7.zip -O $webroot/open3a.zip
|
||||||
unzip open3a.zip
|
unzip open3a.zip
|
||||||
rm open3a.zip
|
rm open3a.zip
|
||||||
chmod 666 system/DBData/Installation.pfdb.php
|
chmod 666 system/DBData/Installation.pfdb.php
|
||||||
@ -67,7 +68,17 @@ chown -R www-data:www-data $webroot
|
|||||||
echo "sudo -u www-data /usr/bin/php $webroot/plugins/Installation/backup.php; for backup in \$(ls -r1 $webroot/system/Backup/*.gz | /bin/grep -v \$(date +%Y%m%d)); do /bin/rm \$backup;done" > /etc/cron.daily/open3a-backup
|
echo "sudo -u www-data /usr/bin/php $webroot/plugins/Installation/backup.php; for backup in \$(ls -r1 $webroot/system/Backup/*.gz | /bin/grep -v \$(date +%Y%m%d)); do /bin/rm \$backup;done" > /etc/cron.daily/open3a-backup
|
||||||
chmod +x /etc/cron.daily/open3a-backup
|
chmod +x /etc/cron.daily/open3a-backup
|
||||||
|
|
||||||
|
cat << EOF >/var/www/html/system/DBData/Installation.pfdb.php
|
||||||
|
<?php echo "This is a database-file."; /*
|
||||||
|
host&%%%&user&%%%&password&%%%&datab&%%%&httpHost
|
||||||
|
varchar(40)&%%%&varchar(20)&%%%&varchar(20)&%%%&varchar(30)&%%%&varchar(40)
|
||||||
|
localhost &%%%&open3a &%%%&$MYSQL_PASSWORD&%%%&open3a &%%%&* %%&&&
|
||||||
|
*/ ?>
|
||||||
|
EOF
|
||||||
|
|
||||||
systemctl enable --now php7.4-fpm
|
systemctl enable --now php7.4-fpm
|
||||||
systemctl restart php7.4-fpm nginx
|
systemctl restart php7.4-fpm nginx
|
||||||
|
|
||||||
|
LXC_IP=$(ip address show dev eth0 | grep "inet " | cut -d ' ' -f6)
|
||||||
|
|
||||||
echo -e "Your open3a installation is now complete. Please continue with setup in your Browser:\nURL:\t\thttp://$(echo $LXC_IP | cut -d'/' -f1)\nLogin:\t\tAdmin\nPassword:\tAdmin\n\nMysql-Settings:\nServer:\t\tlocalhost\nUser:\t\topen3a\nPassword:\t$MYSQL_PASSWORD\nDatabase:\topen3a"
|
echo -e "Your open3a installation is now complete. Please continue with setup in your Browser:\nURL:\t\thttp://$(echo $LXC_IP | cut -d'/' -f1)\nLogin:\t\tAdmin\nPassword:\tAdmin\n\nMysql-Settings:\nServer:\t\tlocalhost\nUser:\t\topen3a\nPassword:\t$MYSQL_PASSWORD\nDatabase:\topen3a"
|
||||||
|
@ -21,3 +21,9 @@ LXC_NESTING="1"
|
|||||||
|
|
||||||
# Backup ubdir where Urbackup will store backups
|
# Backup ubdir where Urbackup will store backups
|
||||||
PBS_DATA="backup"
|
PBS_DATA="backup"
|
||||||
|
|
||||||
|
# Sets the minimum amount of RAM the service needs for operation
|
||||||
|
LXC_MEM_MIN=1024
|
||||||
|
|
||||||
|
# service dependent meta tags
|
||||||
|
SERVICE_TAGS="backup"
|
@ -21,3 +21,5 @@ apt update && apt upgrade -y
|
|||||||
DEBIAN_FRONTEND=noninteractive DEBIAN_PRIORITY=critical apt install -y -o DPkg::options::="--force-confdef" -o DPkg::options::="--force-confold" proxmox-backup-server
|
DEBIAN_FRONTEND=noninteractive DEBIAN_PRIORITY=critical apt install -y -o DPkg::options::="--force-confdef" -o DPkg::options::="--force-confold" proxmox-backup-server
|
||||||
|
|
||||||
proxmox-backup-manager datastore create $PBS_DATA /$LXC_SHAREFS_MOUNTPOINT/$PBS_DATA
|
proxmox-backup-manager datastore create $PBS_DATA /$LXC_SHAREFS_MOUNTPOINT/$PBS_DATA
|
||||||
|
|
||||||
|
systemctl disable --now zfs-mount.service zfs-share.service
|
||||||
|
50
src/tactical-rmm/constants-service.conf
Normal file
50
src/tactical-rmm/constants-service.conf
Normal file
@ -0,0 +1,50 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Authors:
|
||||||
|
# (C) 2021 Idea an concept by Christian Zengel <christian@sysops.de>
|
||||||
|
# (C) 2021 Script design and prototype by Markus Helmke <m.helmke@nettwarker.de>
|
||||||
|
# (C) 2021 Script rework and documentation by Thorsten Spille <thorsten@spille-edv.de>
|
||||||
|
|
||||||
|
# This file contains the project constants on service level
|
||||||
|
|
||||||
|
# Debian Version, which will be installed
|
||||||
|
LXC_TEMPLATE_VERSION="debian-11-standard"
|
||||||
|
|
||||||
|
# Create sharefs mountpoint
|
||||||
|
LXC_MP="1"
|
||||||
|
|
||||||
|
# Create unprivileged container
|
||||||
|
LXC_UNPRIVILEGED="0"
|
||||||
|
|
||||||
|
# enable nesting feature
|
||||||
|
LXC_NESTING="1"
|
||||||
|
|
||||||
|
# Defines the IP from the SQL server
|
||||||
|
RMM_DB_IP="127.0.0.1"
|
||||||
|
|
||||||
|
# Defines the PORT from the SQL server
|
||||||
|
RMM_DB_PORT="5432"
|
||||||
|
|
||||||
|
# Sets the minimum amount of RAM the service needs for operation
|
||||||
|
LXC_MEM_MIN=4096
|
||||||
|
|
||||||
|
# Defines the name from the SQL database
|
||||||
|
RMM_DB_NAME="rmm"
|
||||||
|
|
||||||
|
# Defines the name from the SQL user
|
||||||
|
pgusername="rmm"
|
||||||
|
|
||||||
|
# Build a strong password for the SQL user - could be overwritten with something fixed
|
||||||
|
RMMUSER=tactical
|
||||||
|
pgpw="$(random_password)"
|
||||||
|
DJANGO_SEKRET="$(random_password)"
|
||||||
|
ADMINURL="$(random_password)"
|
||||||
|
MESHPASSWD="$(random_password)"
|
||||||
|
meshusername="$(random_password)"
|
||||||
|
|
||||||
|
# vars from tactical-rmm install script
|
||||||
|
SCRIPTS_DIR="/opt/trmm-community-scripts"
|
||||||
|
|
||||||
|
TMP_FILE=$(mktemp -p "" "rmminstall_XXXXXXXXXX")
|
||||||
|
osname=debian
|
||||||
|
djangousername=admin
|
712
src/tactical-rmm/install-service.sh
Normal file
712
src/tactical-rmm/install-service.sh
Normal file
@ -0,0 +1,712 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
set -euo pipefail
|
||||||
|
|
||||||
|
# Authors:
|
||||||
|
# (C) 2021 Idea an concept by Christian Zengel <christian@sysops.de>
|
||||||
|
# (C) 2021 Script design and prototype by Markus Helmke <m.helmke@nettwarker.de>
|
||||||
|
# (C) 2021 Script rework and documentation by Thorsten Spille <thorsten@spille-edv.de>
|
||||||
|
|
||||||
|
source /root/functions.sh
|
||||||
|
source /root/zamba.conf
|
||||||
|
source /root/constants-service.conf
|
||||||
|
|
||||||
|
codename=$(lsb_release -cs)
|
||||||
|
|
||||||
|
useradd -m -G sudo -s /bin/bash ${RMMUSER}
|
||||||
|
|
||||||
|
echo "deb https://repo.mongodb.org/apt/$osname buster/mongodb-org/4.4 main" > /etc/apt/sources.list.d/mongodb.list
|
||||||
|
echo "deb https://apt.postgresql.org/pub/repos/apt/ $codename-pgdg main" > /etc/apt/sources.list.d/postgres.list
|
||||||
|
echo "deb https://deb.nodesource.com/node_16.x $codename main" > /etc/apt/sources.list.d/nodejs.list
|
||||||
|
echo "deb https://dl.yarnpkg.com/debian stable main" > tee /etc/apt/sources.list.d/yarn.list
|
||||||
|
|
||||||
|
apt-key adv --fetch https://pgp.mongodb.com/server-4.4.pub
|
||||||
|
apt-key adv --fetch https://deb.nodesource.com/gpgkey/nodesource.gpg.key
|
||||||
|
apt-key adv --fetch https://dl.yarnpkg.com/debian/yarnkey.gpg
|
||||||
|
apt-key adv --fetch https://www.postgresql.org/media/keys/ACCC4CF8.asc
|
||||||
|
|
||||||
|
|
||||||
|
apt update
|
||||||
|
DEBIAN_FRONTEND=noninteractive DEBIAN_PRIORITY=critical apt install -y -qq sudo ssl-cert nginx mongodb-org gcc g++ make build-essential zlib1g-dev libncurses5-dev libgdbm-dev libnss3-dev libssl-dev libreadline-dev libffi-dev libsqlite3-dev libbz2-dev ca-certificates redis git postgresql-14 rpl
|
||||||
|
DEBIAN_FRONTEND=noninteractive DEBIAN_PRIORITY=critical apt install -y -qq nodejs
|
||||||
|
|
||||||
|
echo "${RMMUSER} ALL=(ALL) NOPASSWD:ALL" > /etc/sudoers.d/${RMMUSER}
|
||||||
|
|
||||||
|
npm install --no-fund --location=global npm
|
||||||
|
|
||||||
|
openssl req -x509 -nodes -days 3650 -newkey rsa:4096 -keyout /etc/ssl/private/${frontenddomain}.key -out /etc/ssl/certs/${frontenddomain}.pem -subj "/CN=$frontenddomain" -addext "subjectAltName=DNS:*.${frontenddomain}"
|
||||||
|
chown root:ssl-cert /etc/ssl/private/${frontenddomain}.key
|
||||||
|
chmod 640 /etc/ssl/private/${frontenddomain}.key
|
||||||
|
usermod -aG ssl-cert ${RMMUSER}
|
||||||
|
|
||||||
|
update-ca-certificates
|
||||||
|
|
||||||
|
systemctl enable mongod.service postgresql.service
|
||||||
|
|
||||||
|
# configure hosts file
|
||||||
|
echo "127.0.1.1 ${rmmdomain} ${frontenddomain} ${meshdomain}" | tee --append /etc/hosts > /dev/null
|
||||||
|
|
||||||
|
# set global nginx vars
|
||||||
|
sed -i 's/worker_connections.*/worker_connections 2048;/g' /etc/nginx/nginx.conf
|
||||||
|
sed -i 's/# server_names_hash_bucket_size.*/server_names_hash_bucket_size 64;/g' /etc/nginx/nginx.conf
|
||||||
|
|
||||||
|
# compile python3
|
||||||
|
su - ${RMMUSER} << EOF
|
||||||
|
cd ~
|
||||||
|
wget https://www.python.org/ftp/python/${PYTHON_VER}/Python-${PYTHON_VER}.tgz
|
||||||
|
tar -xf Python-${PYTHON_VER}.tgz
|
||||||
|
cd Python-${PYTHON_VER}
|
||||||
|
./configure --enable-optimizations
|
||||||
|
make -j $(nproc)
|
||||||
|
sudo make altinstall
|
||||||
|
cd ~
|
||||||
|
sudo rm -rf Python-${PYTHON_VER} Python-${PYTHON_VER}.tgz
|
||||||
|
EOF
|
||||||
|
|
||||||
|
|
||||||
|
systemctl restart mongod postgresql
|
||||||
|
systemctl stop nginx
|
||||||
|
|
||||||
|
# configure postgresql
|
||||||
|
cd /var/lib/postgresql
|
||||||
|
sudo -u postgres psql -c "CREATE DATABASE tacticalrmm;"
|
||||||
|
sudo -u postgres psql -c "CREATE USER ${pgusername} WITH PASSWORD '${pgpw}';"
|
||||||
|
sudo -u postgres psql -c "ALTER ROLE ${pgusername} SET client_encoding TO 'utf8';"
|
||||||
|
sudo -u postgres psql -c "ALTER ROLE ${pgusername} SET default_transaction_isolation TO 'read committed';"
|
||||||
|
sudo -u postgres psql -c "ALTER ROLE ${pgusername} SET timezone TO 'UTC';"
|
||||||
|
sudo -u postgres psql -c "GRANT ALL PRIVILEGES ON DATABASE tacticalrmm TO ${pgusername};"
|
||||||
|
|
||||||
|
# clone tacticalrmm
|
||||||
|
mkdir /rmm
|
||||||
|
chown ${RMMUSER}:${RMMUSER} /rmm
|
||||||
|
mkdir -p /var/log/celery
|
||||||
|
chown ${RMMUSER}:${RMMUSER} /var/log/celery
|
||||||
|
mkdir -p ${SCRIPTS_DIR}
|
||||||
|
chown ${RMMUSER}:${RMMUSER} ${SCRIPTS_DIR}
|
||||||
|
su - ${RMMUSER} << EOF
|
||||||
|
cd /rmm
|
||||||
|
git clone -b master https://github.com/amidaware/tacticalrmm.git /rmm
|
||||||
|
git config user.email "admin@example.com"
|
||||||
|
git config user.name "Bob"
|
||||||
|
cd ${SCRIPTS_DIR}
|
||||||
|
git clone -b main https://github.com/amidaware/community-scripts.git ${SCRIPTS_DIR}/
|
||||||
|
git config user.email "admin@example.com"
|
||||||
|
git config user.name "Bob"
|
||||||
|
EOF
|
||||||
|
|
||||||
|
# configure NATS server
|
||||||
|
NATS_SERVER_VER=$(grep "^NATS_SERVER_VER" /rmm/api/tacticalrmm/tacticalrmm/settings.py | awk -F'[= "]' '{print $5}')
|
||||||
|
nats_tmp=$(mktemp -d -t nats-server-XXXXXXXXXXXXX)
|
||||||
|
wget https://github.com/nats-io/nats-server/releases/download/v${NATS_SERVER_VER}/nats-server-v${NATS_SERVER_VER}-linux-amd64.tar.gz -O ${nats_tmp}/nats-server-v${NATS_SERVER_VER}-linux-amd64.tar.gz
|
||||||
|
tar -xzf ${nats_tmp}/nats-server-v${NATS_SERVER_VER}-linux-amd64.tar.gz -C ${nats_tmp}
|
||||||
|
mv ${nats_tmp}/nats-server-v${NATS_SERVER_VER}-linux-amd64/nats-server /usr/local/bin/
|
||||||
|
chmod +x /usr/local/bin/nats-server
|
||||||
|
chown ${RMMUSER}:${RMMUSER} /usr/local/bin/nats-server
|
||||||
|
rm -rf ${nats_tmp}
|
||||||
|
|
||||||
|
# fix cert in nats-rmm.conf
|
||||||
|
rpl "/etc/letsencrypt/live/${frontenddomain}/fullchain.pem" "/etc/ssl/certs/${frontenddomain}.pem" /rmm/api/tacticalrmm/nats-rmm.conf
|
||||||
|
rpl "/etc/letsencrypt/live/${frontenddomain}/privkey.pem" "/etc/ssl/private/${frontenddomain}.key" /rmm/api/tacticalrmm/nats-rmm.conf
|
||||||
|
|
||||||
|
# install meshcentral
|
||||||
|
MESH_VER=$(grep "^MESH_VER" /rmm/api/tacticalrmm/tacticalrmm/settings.py | awk -F'[= "]' '{print $5}')
|
||||||
|
|
||||||
|
mkdir -p /meshcentral/meshcentral-data
|
||||||
|
chown ${RMMUSER}:${RMMUSER} -R /meshcentral
|
||||||
|
|
||||||
|
su - ${RMMUSER} << EOF
|
||||||
|
cd /meshcentral
|
||||||
|
npm install meshcentral@${MESH_VER}
|
||||||
|
EOF
|
||||||
|
|
||||||
|
chown ${RMMUSER}:${RMMUSER} -R /meshcentral
|
||||||
|
|
||||||
|
meshcfg="$(cat << EOF
|
||||||
|
{
|
||||||
|
"settings": {
|
||||||
|
"Cert": "${meshdomain}",
|
||||||
|
"MongoDb": "mongodb://127.0.0.1:27017",
|
||||||
|
"MongoDbName": "meshcentral",
|
||||||
|
"WANonly": true,
|
||||||
|
"Minify": 1,
|
||||||
|
"Port": 4430,
|
||||||
|
"AliasPort": 443,
|
||||||
|
"RedirPort": 800,
|
||||||
|
"AllowLoginToken": true,
|
||||||
|
"AllowFraming": true,
|
||||||
|
"_AgentPing": 60,
|
||||||
|
"AgentPong": 300,
|
||||||
|
"AllowHighQualityDesktop": true,
|
||||||
|
"TlsOffload": "127.0.0.1",
|
||||||
|
"agentCoreDump": false,
|
||||||
|
"Compression": true,
|
||||||
|
"WsCompression": true,
|
||||||
|
"AgentWsCompression": true,
|
||||||
|
"MaxInvalidLogin": { "time": 5, "count": 5, "coolofftime": 30 }
|
||||||
|
},
|
||||||
|
"domains": {
|
||||||
|
"": {
|
||||||
|
"Title": "Tactical RMM",
|
||||||
|
"Title2": "Tactical RMM",
|
||||||
|
"NewAccounts": false,
|
||||||
|
"CertUrl": "https://${meshdomain}:443/",
|
||||||
|
"GeoLocation": true,
|
||||||
|
"CookieIpCheck": false,
|
||||||
|
"mstsc": true,
|
||||||
|
"force2factor": false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
EOF
|
||||||
|
)"
|
||||||
|
sudo -u ${RMMUSER} echo "${meshcfg}" > /meshcentral/meshcentral-data/config.json
|
||||||
|
|
||||||
|
localvars="$(cat << EOF
|
||||||
|
SECRET_KEY = "${DJANGO_SEKRET}"
|
||||||
|
|
||||||
|
DEBUG = False
|
||||||
|
|
||||||
|
ALLOWED_HOSTS = ['${rmmdomain}']
|
||||||
|
|
||||||
|
ADMIN_URL = "${ADMINURL}/"
|
||||||
|
|
||||||
|
CORS_ORIGIN_WHITELIST = [
|
||||||
|
"https://${frontenddomain}"
|
||||||
|
]
|
||||||
|
|
||||||
|
DATABASES = {
|
||||||
|
'default': {
|
||||||
|
'ENGINE': 'django.db.backends.postgresql',
|
||||||
|
'NAME': 'tacticalrmm',
|
||||||
|
'USER': '${pgusername}',
|
||||||
|
'PASSWORD': '${pgpw}',
|
||||||
|
'HOST': 'localhost',
|
||||||
|
'PORT': '5432',
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
MESH_USERNAME = "${meshusername}"
|
||||||
|
MESH_SITE = "https://${meshdomain}"
|
||||||
|
REDIS_HOST = "localhost"
|
||||||
|
ADMIN_ENABLED = True
|
||||||
|
EOF
|
||||||
|
)"
|
||||||
|
sudo -u ${RMMUSER} echo "${localvars}" > /rmm/api/tacticalrmm/tacticalrmm/local_settings.py
|
||||||
|
|
||||||
|
cp /rmm/natsapi/bin/nats-api /usr/local/bin
|
||||||
|
chown ${RMMUSER}:${RMMUSER} /usr/local/bin/nats-api
|
||||||
|
chmod +x /usr/local/bin/nats-api
|
||||||
|
|
||||||
|
SETUPTOOLS_VER=$(grep "^SETUPTOOLS_VER" /rmm/api/tacticalrmm/tacticalrmm/settings.py | awk -F'[= "]' '{print $5}')
|
||||||
|
WHEEL_VER=$(grep "^WHEEL_VER" /rmm/api/tacticalrmm/tacticalrmm/settings.py | awk -F'[= "]' '{print $5}')
|
||||||
|
|
||||||
|
su - ${RMMUSER} << EOF
|
||||||
|
cd /rmm/api/
|
||||||
|
/usr/local/bin/python3.10 -m venv env
|
||||||
|
source /rmm/api/env/bin/activate
|
||||||
|
cd /rmm/api/tacticalrmm
|
||||||
|
pip install --no-cache-dir --upgrade pip
|
||||||
|
pip install --no-cache-dir setuptools==${SETUPTOOLS_VER} wheel==${WHEEL_VER}
|
||||||
|
pip install --no-cache-dir -r /rmm/api/tacticalrmm/requirements.txt
|
||||||
|
python manage.py migrate
|
||||||
|
python manage.py collectstatic --no-input
|
||||||
|
python manage.py create_natsapi_conf
|
||||||
|
python manage.py load_chocos
|
||||||
|
python manage.py load_community_scripts
|
||||||
|
python manage.py create_installer_user
|
||||||
|
deactivate
|
||||||
|
EOF
|
||||||
|
|
||||||
|
# install backend
|
||||||
|
echo 'Optimizing for number of processors'
|
||||||
|
uwsgiprocs=4
|
||||||
|
if [[ "$(nproc)" == "1" ]]; then
|
||||||
|
uwsgiprocs=2
|
||||||
|
else
|
||||||
|
uwsgiprocs=$(nproc)
|
||||||
|
fi
|
||||||
|
|
||||||
|
uwsgini="$(cat << EOF
|
||||||
|
[uwsgi]
|
||||||
|
chdir = /rmm/api/tacticalrmm
|
||||||
|
module = tacticalrmm.wsgi
|
||||||
|
home = /rmm/api/env
|
||||||
|
master = true
|
||||||
|
processes = ${uwsgiprocs}
|
||||||
|
threads = ${uwsgiprocs}
|
||||||
|
enable-threads = true
|
||||||
|
socket = /rmm/api/tacticalrmm/tacticalrmm.sock
|
||||||
|
harakiri = 300
|
||||||
|
chmod-socket = 660
|
||||||
|
buffer-size = 65535
|
||||||
|
vacuum = true
|
||||||
|
die-on-term = true
|
||||||
|
max-requests = 500
|
||||||
|
disable-logging = true
|
||||||
|
EOF
|
||||||
|
)"
|
||||||
|
sudo -u ${RMMUSER} echo "${uwsgini}" > /rmm/api/tacticalrmm/app.ini
|
||||||
|
|
||||||
|
# create systemd services
|
||||||
|
|
||||||
|
rmmservice="$(cat << EOF
|
||||||
|
[Unit]
|
||||||
|
Description=tacticalrmm uwsgi daemon
|
||||||
|
After=network.target postgresql.service
|
||||||
|
|
||||||
|
[Service]
|
||||||
|
User=${RMMUSER}
|
||||||
|
Group=www-data
|
||||||
|
WorkingDirectory=/rmm/api/tacticalrmm
|
||||||
|
Environment="PATH=/rmm/api/env/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin"
|
||||||
|
ExecStart=/rmm/api/env/bin/uwsgi --ini app.ini
|
||||||
|
Restart=always
|
||||||
|
RestartSec=10s
|
||||||
|
|
||||||
|
[Install]
|
||||||
|
WantedBy=multi-user.target
|
||||||
|
EOF
|
||||||
|
)"
|
||||||
|
echo "${rmmservice}" | sudo tee /etc/systemd/system/rmm.service > /dev/null
|
||||||
|
|
||||||
|
daphneservice="$(cat << EOF
|
||||||
|
[Unit]
|
||||||
|
Description=django channels daemon
|
||||||
|
After=network.target
|
||||||
|
|
||||||
|
[Service]
|
||||||
|
User=${RMMUSER}
|
||||||
|
Group=www-data
|
||||||
|
WorkingDirectory=/rmm/api/tacticalrmm
|
||||||
|
Environment="PATH=/rmm/api/env/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin"
|
||||||
|
ExecStart=/rmm/api/env/bin/daphne -u /rmm/daphne.sock tacticalrmm.asgi:application
|
||||||
|
Restart=always
|
||||||
|
RestartSec=3s
|
||||||
|
|
||||||
|
[Install]
|
||||||
|
WantedBy=multi-user.target
|
||||||
|
EOF
|
||||||
|
)"
|
||||||
|
echo "${daphneservice}" | sudo tee /etc/systemd/system/daphne.service > /dev/null
|
||||||
|
|
||||||
|
natsservice="$(cat << EOF
|
||||||
|
[Unit]
|
||||||
|
Description=NATS Server
|
||||||
|
After=network.target
|
||||||
|
|
||||||
|
[Service]
|
||||||
|
PrivateTmp=true
|
||||||
|
Type=simple
|
||||||
|
ExecStart=/usr/local/bin/nats-server -c /rmm/api/tacticalrmm/nats-rmm.conf
|
||||||
|
ExecReload=/usr/bin/kill -s HUP \$MAINPID
|
||||||
|
ExecStop=/usr/bin/kill -s SIGINT \$MAINPID
|
||||||
|
User=${RMMUSER}
|
||||||
|
Group=www-data
|
||||||
|
Restart=always
|
||||||
|
RestartSec=5s
|
||||||
|
LimitNOFILE=1000000
|
||||||
|
|
||||||
|
[Install]
|
||||||
|
WantedBy=multi-user.target
|
||||||
|
EOF
|
||||||
|
)"
|
||||||
|
echo "${natsservice}" | sudo tee /etc/systemd/system/nats.service > /dev/null
|
||||||
|
|
||||||
|
natsapi="$(cat << EOF
|
||||||
|
[Unit]
|
||||||
|
Description=TacticalRMM Nats Api v1
|
||||||
|
After=nats.service
|
||||||
|
|
||||||
|
[Service]
|
||||||
|
Type=simple
|
||||||
|
ExecStart=/usr/local/bin/nats-api
|
||||||
|
User=${RMMUSER}
|
||||||
|
Group=${RMMUSER}
|
||||||
|
Restart=always
|
||||||
|
RestartSec=5s
|
||||||
|
|
||||||
|
[Install]
|
||||||
|
WantedBy=multi-user.target
|
||||||
|
EOF
|
||||||
|
)"
|
||||||
|
echo "${natsapi}" | sudo tee /etc/systemd/system/nats-api.service > /dev/null
|
||||||
|
|
||||||
|
celeryservice="$(cat << EOF
|
||||||
|
[Unit]
|
||||||
|
Description=Celery Service V2
|
||||||
|
After=network.target redis-server.service postgresql.service
|
||||||
|
|
||||||
|
[Service]
|
||||||
|
Type=forking
|
||||||
|
User=${RMMUSER}
|
||||||
|
Group=${RMMUSER}
|
||||||
|
EnvironmentFile=/etc/conf.d/celery.conf
|
||||||
|
WorkingDirectory=/rmm/api/tacticalrmm
|
||||||
|
ExecStart=/bin/sh -c '\${CELERY_BIN} -A \$CELERY_APP multi start \$CELERYD_NODES --pidfile=\${CELERYD_PID_FILE} --logfile=\${CELERYD_LOG_FILE} --loglevel="\${CELERYD_LOG_LEVEL}" \$CELERYD_OPTS'
|
||||||
|
ExecStop=/bin/sh -c '\${CELERY_BIN} multi stopwait \$CELERYD_NODES --pidfile=\${CELERYD_PID_FILE} --loglevel="\${CELERYD_LOG_LEVEL}"'
|
||||||
|
ExecReload=/bin/sh -c '\${CELERY_BIN} -A \$CELERY_APP multi restart \$CELERYD_NODES --pidfile=\${CELERYD_PID_FILE} --logfile=\${CELERYD_LOG_FILE} --loglevel="\${CELERYD_LOG_LEVEL}" \$CELERYD_OPTS'
|
||||||
|
Restart=always
|
||||||
|
RestartSec=10s
|
||||||
|
|
||||||
|
[Install]
|
||||||
|
WantedBy=multi-user.target
|
||||||
|
EOF
|
||||||
|
)"
|
||||||
|
echo "${celeryservice}" | sudo tee /etc/systemd/system/celery.service > /dev/null
|
||||||
|
|
||||||
|
celerybeatservice="$(cat << EOF
|
||||||
|
[Unit]
|
||||||
|
Description=Celery Beat Service V2
|
||||||
|
After=network.target redis-server.service postgresql.service
|
||||||
|
|
||||||
|
[Service]
|
||||||
|
Type=simple
|
||||||
|
User=${RMMUSER}
|
||||||
|
Group=${RMMUSER}
|
||||||
|
EnvironmentFile=/etc/conf.d/celery.conf
|
||||||
|
WorkingDirectory=/rmm/api/tacticalrmm
|
||||||
|
ExecStart=/bin/sh -c '\${CELERY_BIN} -A \${CELERY_APP} beat --pidfile=\${CELERYBEAT_PID_FILE} --logfile=\${CELERYBEAT_LOG_FILE} --loglevel=\${CELERYD_LOG_LEVEL}'
|
||||||
|
Restart=always
|
||||||
|
RestartSec=10s
|
||||||
|
|
||||||
|
[Install]
|
||||||
|
WantedBy=multi-user.target
|
||||||
|
EOF
|
||||||
|
)"
|
||||||
|
echo "${celerybeatservice}" | sudo tee /etc/systemd/system/celerybeat.service > /dev/null
|
||||||
|
|
||||||
|
meshservice="$(cat << EOF
|
||||||
|
[Unit]
|
||||||
|
Description=MeshCentral Server
|
||||||
|
After=network.target mongod.service nginx.service
|
||||||
|
[Service]
|
||||||
|
Type=simple
|
||||||
|
LimitNOFILE=1000000
|
||||||
|
ExecStart=/usr/bin/node node_modules/meshcentral
|
||||||
|
Environment=NODE_ENV=production
|
||||||
|
WorkingDirectory=/meshcentral
|
||||||
|
User=${RMMUSER}
|
||||||
|
Group=${RMMUSER}
|
||||||
|
Restart=always
|
||||||
|
RestartSec=10s
|
||||||
|
|
||||||
|
[Install]
|
||||||
|
WantedBy=multi-user.target
|
||||||
|
EOF
|
||||||
|
)"
|
||||||
|
echo "${meshservice}" | sudo tee /etc/systemd/system/meshcentral.service > /dev/null
|
||||||
|
|
||||||
|
|
||||||
|
# create nginx config
|
||||||
|
|
||||||
|
nginxrmm="$(cat << EOF
|
||||||
|
server_tokens off;
|
||||||
|
|
||||||
|
upstream tacticalrmm {
|
||||||
|
server unix:////rmm/api/tacticalrmm/tacticalrmm.sock;
|
||||||
|
}
|
||||||
|
|
||||||
|
map \$http_user_agent \$ignore_ua {
|
||||||
|
"~python-requests.*" 0;
|
||||||
|
"~go-resty.*" 0;
|
||||||
|
default 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
server {
|
||||||
|
listen 80;
|
||||||
|
listen [::]:80;
|
||||||
|
server_name ${rmmdomain};
|
||||||
|
return 301 https://\$server_name\$request_uri;
|
||||||
|
}
|
||||||
|
|
||||||
|
server {
|
||||||
|
listen 443 ssl;
|
||||||
|
listen [::]:443 ssl;
|
||||||
|
server_name ${rmmdomain};
|
||||||
|
client_max_body_size 300M;
|
||||||
|
access_log /rmm/api/tacticalrmm/tacticalrmm/private/log/access.log combined if=\$ignore_ua;
|
||||||
|
error_log /rmm/api/tacticalrmm/tacticalrmm/private/log/error.log;
|
||||||
|
ssl_certificate /etc/ssl/certs/${frontenddomain}.pem;
|
||||||
|
ssl_certificate_key /etc/ssl/private/${frontenddomain}.key;
|
||||||
|
|
||||||
|
ssl_protocols TLSv1.2 TLSv1.3;
|
||||||
|
ssl_prefer_server_ciphers on;
|
||||||
|
ssl_ciphers EECDH+AESGCM:EDH+AESGCM;
|
||||||
|
ssl_ecdh_curve secp384r1;
|
||||||
|
ssl_stapling on;
|
||||||
|
ssl_stapling_verify on;
|
||||||
|
add_header X-Content-Type-Options nosniff;
|
||||||
|
|
||||||
|
location /static/ {
|
||||||
|
root /rmm/api/tacticalrmm;
|
||||||
|
}
|
||||||
|
|
||||||
|
location /private/ {
|
||||||
|
internal;
|
||||||
|
add_header "Access-Control-Allow-Origin" "https://${frontenddomain}";
|
||||||
|
alias /rmm/api/tacticalrmm/tacticalrmm/private/;
|
||||||
|
}
|
||||||
|
|
||||||
|
location ~ ^/(natsapi) {
|
||||||
|
allow 127.0.0.1;
|
||||||
|
deny all;
|
||||||
|
uwsgi_pass tacticalrmm;
|
||||||
|
include /etc/nginx/uwsgi_params;
|
||||||
|
uwsgi_read_timeout 500s;
|
||||||
|
uwsgi_ignore_client_abort on;
|
||||||
|
}
|
||||||
|
|
||||||
|
location ~ ^/ws/ {
|
||||||
|
proxy_pass http://unix:/rmm/daphne.sock;
|
||||||
|
|
||||||
|
proxy_http_version 1.1;
|
||||||
|
proxy_set_header Upgrade \$http_upgrade;
|
||||||
|
proxy_set_header Connection "upgrade";
|
||||||
|
|
||||||
|
proxy_redirect off;
|
||||||
|
proxy_set_header Host \$host;
|
||||||
|
proxy_set_header X-Real-IP \$remote_addr;
|
||||||
|
proxy_set_header X-Forwarded-For \$proxy_add_x_forwarded_for;
|
||||||
|
proxy_set_header X-Forwarded-Host \$server_name;
|
||||||
|
}
|
||||||
|
|
||||||
|
location / {
|
||||||
|
uwsgi_pass tacticalrmm;
|
||||||
|
include /etc/nginx/uwsgi_params;
|
||||||
|
uwsgi_read_timeout 9999s;
|
||||||
|
uwsgi_ignore_client_abort on;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
EOF
|
||||||
|
)"
|
||||||
|
echo "${nginxrmm}" | sudo tee /etc/nginx/sites-available/rmm.conf > /dev/null
|
||||||
|
|
||||||
|
|
||||||
|
nginxmesh="$(cat << EOF
|
||||||
|
server {
|
||||||
|
listen 80;
|
||||||
|
listen [::]:80;
|
||||||
|
server_name ${meshdomain};
|
||||||
|
return 301 https://\$server_name\$request_uri;
|
||||||
|
}
|
||||||
|
|
||||||
|
server {
|
||||||
|
|
||||||
|
listen 443 ssl;
|
||||||
|
listen [::]:443 ssl;
|
||||||
|
proxy_send_timeout 330s;
|
||||||
|
proxy_read_timeout 330s;
|
||||||
|
server_name ${meshdomain};
|
||||||
|
ssl_certificate /etc/ssl/certs/${frontenddomain}.pem;
|
||||||
|
ssl_certificate_key /etc/ssl/private/${frontenddomain}.key;
|
||||||
|
|
||||||
|
ssl_session_cache shared:WEBSSL:10m;
|
||||||
|
|
||||||
|
ssl_protocols TLSv1.2 TLSv1.3;
|
||||||
|
ssl_prefer_server_ciphers on;
|
||||||
|
ssl_ciphers EECDH+AESGCM:EDH+AESGCM;
|
||||||
|
ssl_ecdh_curve secp384r1;
|
||||||
|
ssl_stapling on;
|
||||||
|
ssl_stapling_verify on;
|
||||||
|
add_header X-Content-Type-Options nosniff;
|
||||||
|
|
||||||
|
location / {
|
||||||
|
proxy_pass http://127.0.0.1:4430/;
|
||||||
|
proxy_http_version 1.1;
|
||||||
|
|
||||||
|
proxy_set_header Host \$host;
|
||||||
|
proxy_set_header Upgrade \$http_upgrade;
|
||||||
|
proxy_set_header Connection "upgrade";
|
||||||
|
proxy_set_header X-Forwarded-Host \$host:\$server_port;
|
||||||
|
proxy_set_header X-Forwarded-For \$proxy_add_x_forwarded_for;
|
||||||
|
proxy_set_header X-Forwarded-Proto \$scheme;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
EOF
|
||||||
|
)"
|
||||||
|
echo "${nginxmesh}" | sudo tee /etc/nginx/sites-available/meshcentral.conf > /dev/null
|
||||||
|
|
||||||
|
ln -s /etc/nginx/sites-available/rmm.conf /etc/nginx/sites-enabled/rmm.conf
|
||||||
|
ln -s /etc/nginx/sites-available/meshcentral.conf /etc/nginx/sites-enabled/meshcentral.conf
|
||||||
|
|
||||||
|
# configure celery
|
||||||
|
mkdir /etc/conf.d
|
||||||
|
|
||||||
|
celeryconf="$(cat << EOF
|
||||||
|
CELERYD_NODES="w1"
|
||||||
|
|
||||||
|
CELERY_BIN="/rmm/api/env/bin/celery"
|
||||||
|
|
||||||
|
CELERY_APP="tacticalrmm"
|
||||||
|
|
||||||
|
CELERYD_MULTI="multi"
|
||||||
|
|
||||||
|
CELERYD_OPTS="--time-limit=86400 --autoscale=20,2"
|
||||||
|
|
||||||
|
CELERYD_PID_FILE="/rmm/api/tacticalrmm/%n.pid"
|
||||||
|
CELERYD_LOG_FILE="/var/log/celery/%n%I.log"
|
||||||
|
CELERYD_LOG_LEVEL="ERROR"
|
||||||
|
|
||||||
|
CELERYBEAT_PID_FILE="/rmm/api/tacticalrmm/beat.pid"
|
||||||
|
CELERYBEAT_LOG_FILE="/var/log/celery/beat.log"
|
||||||
|
EOF
|
||||||
|
)"
|
||||||
|
echo "${celeryconf}" | sudo tee /etc/conf.d/celery.conf > /dev/null
|
||||||
|
|
||||||
|
chown ${RMMUSER}:${RMMUSER} -R /etc/conf.d/
|
||||||
|
|
||||||
|
systemctl daemon-reload
|
||||||
|
|
||||||
|
# install frontend
|
||||||
|
|
||||||
|
su - ${RMMUSER} << EOF
|
||||||
|
|
||||||
|
if [ -d ~/.npm ]; then
|
||||||
|
chown -R $RMMUSER:$RMMUSER ~/.npm
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -d ~/.config ]; then
|
||||||
|
chown -R $RMMUSER:$RMMUSER ~/.config
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo -e "PROD_URL = \"https://${rmmdomain}\"\nDEV_URL = \"https://${rmmdomain}\"" > /rmm/web/.env
|
||||||
|
|
||||||
|
cd /rmm/web
|
||||||
|
npm install
|
||||||
|
npm audit fix
|
||||||
|
npm run build
|
||||||
|
EOF
|
||||||
|
|
||||||
|
mkdir -p /var/www/rmm
|
||||||
|
cp -pvr /rmm/web/dist /var/www/rmm/
|
||||||
|
chown www-data:www-data -R /var/www/rmm/dist
|
||||||
|
|
||||||
|
nginxfrontend="$(cat << EOF
|
||||||
|
server {
|
||||||
|
server_name ${frontenddomain};
|
||||||
|
charset utf-8;
|
||||||
|
location / {
|
||||||
|
root /var/www/rmm/dist;
|
||||||
|
try_files \$uri \$uri/ /index.html;
|
||||||
|
add_header Cache-Control "no-store, no-cache, must-revalidate";
|
||||||
|
add_header Pragma "no-cache";
|
||||||
|
}
|
||||||
|
error_log /var/log/nginx/frontend-error.log;
|
||||||
|
access_log /var/log/nginx/frontend-access.log;
|
||||||
|
|
||||||
|
listen 443 ssl;
|
||||||
|
listen [::]:443 ssl;
|
||||||
|
ssl_certificate /etc/ssl/certs/${frontenddomain}.pem;
|
||||||
|
ssl_certificate_key /etc/ssl/private/${frontenddomain}.key;
|
||||||
|
|
||||||
|
ssl_protocols TLSv1.2 TLSv1.3;
|
||||||
|
ssl_prefer_server_ciphers on;
|
||||||
|
ssl_ciphers EECDH+AESGCM:EDH+AESGCM;
|
||||||
|
ssl_ecdh_curve secp384r1;
|
||||||
|
ssl_stapling on;
|
||||||
|
ssl_stapling_verify on;
|
||||||
|
add_header X-Content-Type-Options nosniff;
|
||||||
|
}
|
||||||
|
|
||||||
|
server {
|
||||||
|
if (\$host = ${frontenddomain}) {
|
||||||
|
return 301 https://\$host\$request_uri;
|
||||||
|
}
|
||||||
|
|
||||||
|
listen 80;
|
||||||
|
listen [::]:80;
|
||||||
|
server_name ${frontenddomain};
|
||||||
|
return 404;
|
||||||
|
}
|
||||||
|
EOF
|
||||||
|
)"
|
||||||
|
echo "${nginxfrontend}" | tee /etc/nginx/sites-available/frontend.conf > /dev/null
|
||||||
|
|
||||||
|
ln -s /etc/nginx/sites-available/frontend.conf /etc/nginx/sites-enabled/frontend.conf
|
||||||
|
|
||||||
|
|
||||||
|
for i in rmm.service daphne.service celery.service celerybeat.service nginx
|
||||||
|
do
|
||||||
|
systemctl enable ${i}
|
||||||
|
systemctl stop ${i}
|
||||||
|
systemctl start ${i}
|
||||||
|
done
|
||||||
|
sleep 5
|
||||||
|
systemctl enable meshcentral
|
||||||
|
|
||||||
|
systemctl restart meshcentral
|
||||||
|
|
||||||
|
CHECK_MESH_READY=1
|
||||||
|
while ! [[ $CHECK_MESH_READY ]]; do
|
||||||
|
CHECK_MESH_READY=$(sudo journalctl -u meshcentral.service -b --no-pager | grep "MeshCentral HTTP server running on port")
|
||||||
|
echo -ne "Mesh Central not ready yet...\n"
|
||||||
|
sleep 3
|
||||||
|
done
|
||||||
|
|
||||||
|
node /meshcentral/node_modules/meshcentral --logintokenkey
|
||||||
|
|
||||||
|
MESHTOKENKEY=$(node /meshcentral/node_modules/meshcentral --logintokenkey)
|
||||||
|
sudo -u ${USER} echo "MESH_TOKEN_KEY = \"$MESHTOKENKEY\"" >> /rmm/api/tacticalrmm/tacticalrmm/local_settings.py
|
||||||
|
|
||||||
|
systemctl stop meshcentral
|
||||||
|
sleep 1
|
||||||
|
cd /meshcentral
|
||||||
|
|
||||||
|
sudo -u ${RMMUSER} node node_modules/meshcentral --createaccount ${meshusername} --pass ${MESHPASSWD} --email ${adminemail}
|
||||||
|
sleep 1
|
||||||
|
sudo -u ${RMMUSER} node node_modules/meshcentral --adminaccount ${meshusername}
|
||||||
|
|
||||||
|
systemctl start meshcentral
|
||||||
|
sleep 5
|
||||||
|
|
||||||
|
|
||||||
|
sudo -u ${RMMUSER} node node_modules/meshcentral/meshctrl.js --url wss://${meshdomain}:443 --loginuser ${meshusername} --loginpass ${MESHPASSWD} AddDeviceGroup --name TacticalRMM
|
||||||
|
sleep 1
|
||||||
|
|
||||||
|
systemctl enable nats.service
|
||||||
|
su - ${RMMUSER} <<EOF
|
||||||
|
cd /rmm/api/tacticalrmm
|
||||||
|
source /rmm/api/env/bin/activate
|
||||||
|
python manage.py initial_db_setup
|
||||||
|
python manage.py reload_nats
|
||||||
|
deactivate
|
||||||
|
EOF
|
||||||
|
|
||||||
|
systemctl start nats.service
|
||||||
|
|
||||||
|
sleep 1
|
||||||
|
systemctl enable nats-api.service
|
||||||
|
systemctl start nats-api.service
|
||||||
|
|
||||||
|
## disable django admin
|
||||||
|
sudo -u ${RMMUSER} sed -i 's/ADMIN_ENABLED = True/ADMIN_ENABLED = False/g' /rmm/api/tacticalrmm/tacticalrmm/local_settings.py
|
||||||
|
|
||||||
|
echo 'Restarting services'
|
||||||
|
for i in rmm.service daphne.service celery.service celerybeat.service
|
||||||
|
do
|
||||||
|
systemctl stop ${i}
|
||||||
|
systemctl start ${i}
|
||||||
|
done
|
||||||
|
|
||||||
|
cat << EOF > /usr/local/bin/register-rmm-admin
|
||||||
|
cd /rmm/api
|
||||||
|
source /rmm/api/env/bin/activate
|
||||||
|
cd /rmm/api/tacticalrmm
|
||||||
|
printf >&2 "Please create your login for the RMM website and django admin\n"
|
||||||
|
printf >&2 "\n"
|
||||||
|
echo -ne "Username: "
|
||||||
|
read djangousername
|
||||||
|
python manage.py createsuperuser --username \${djangousername} --email ${adminemail}
|
||||||
|
#RANDBASE=\$(python manage.py generate_totp)
|
||||||
|
#python manage.py generate_barcode \${RANDBASE} \${djangousername} ${frontenddomain}
|
||||||
|
deactivate
|
||||||
|
EOF
|
||||||
|
chmod +x /usr/local/bin/register-rmm-admin
|
||||||
|
|
||||||
|
printf >&2 "Installation complete!\n\n"
|
||||||
|
printf >&2 "Access your rmm at: https://${frontenddomain}\n\n"
|
||||||
|
printf >&2 "Django admin url (disabled by default): https://${rmmdomain}/${ADMINURL}/\n\n"
|
||||||
|
printf >&2 "MeshCentral username: ${meshusername}\n"
|
||||||
|
printf >&2 "MeshCentral password: ${MESHPASSWD}\n\n"
|
||||||
|
|
||||||
|
printf >&2 "Please run 'pct exec {container id} -- su - root -c register-rmm-admin' to create an administrative rmm user.\n\n"
|
26
src/unifi/constants-service.conf
Normal file
26
src/unifi/constants-service.conf
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Authors:
|
||||||
|
# (C) 2021 Idea an concept by Christian Zengel <christian@sysops.de>
|
||||||
|
# (C) 2021 Script design and prototype by Markus Helmke <m.helmke@nettwarker.de>
|
||||||
|
# (C) 2021 Script rework and documentation by Thorsten Spille <thorsten@spille-edv.de>
|
||||||
|
|
||||||
|
# This file contains the project constants on service level
|
||||||
|
|
||||||
|
# Debian Version, which will be installed
|
||||||
|
LXC_TEMPLATE_VERSION="debian-11-standard"
|
||||||
|
|
||||||
|
# Create sharefs mountpoint
|
||||||
|
LXC_MP="0"
|
||||||
|
|
||||||
|
# Create unprivileged container
|
||||||
|
LXC_UNPRIVILEGED="1"
|
||||||
|
|
||||||
|
# enable nesting feature
|
||||||
|
LXC_NESTING="1"
|
||||||
|
|
||||||
|
# Sets the minimum amount of RAM the service needs for operation
|
||||||
|
LXC_MEM_MIN=2048
|
||||||
|
|
||||||
|
# service dependent meta tags
|
||||||
|
SERVICE_TAGS="mongodb-server,java"
|
22
src/unifi/install-service.sh
Normal file
22
src/unifi/install-service.sh
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
set -euo pipefail
|
||||||
|
|
||||||
|
# Authors:
|
||||||
|
# (C) 2021 Idea an concept by Christian Zengel <christian@sysops.de>
|
||||||
|
# (C) 2021 Script design and prototype by Markus Helmke <m.helmke@nettwarker.de>
|
||||||
|
# (C) 2021 Script rework and documentation by Thorsten Spille <thorsten@spille-edv.de>
|
||||||
|
|
||||||
|
source /root/functions.sh
|
||||||
|
source /root/zamba.conf
|
||||||
|
source /root/constants-service.conf
|
||||||
|
|
||||||
|
wget -O /etc/apt/trusted.gpg.d/mongodb-3.6.asc https://www.mongodb.org/static/pgp/server-3.6.asc
|
||||||
|
wget -O /etc/apt/trusted.gpg.d/unifi.gpg https://dl.ubnt.com/unifi/unifi-repo.gpg
|
||||||
|
|
||||||
|
echo "deb http://repo.mongodb.org/apt/debian stretch/mongodb-org/3.6 main" > /etc/apt/sources.list.d/mongodb.list
|
||||||
|
echo "deb http://www.ui.com/downloads/unifi/debian stable ubiquiti" > /etc/apt/sources.list.d/unifi.list
|
||||||
|
|
||||||
|
apt update
|
||||||
|
|
||||||
|
DEBIAN_FRONTEND=noninteractive DEBIAN_PRIORITY=critical apt install -y -qq unifi
|
@ -24,3 +24,9 @@ URBACKUP_DATA="urbackup"
|
|||||||
|
|
||||||
# OS codename for opensuse / urbackup repo
|
# OS codename for opensuse / urbackup repo
|
||||||
REPO_CODENAME="Debian_11"
|
REPO_CODENAME="Debian_11"
|
||||||
|
|
||||||
|
# Sets the minimum amount of RAM the service needs for operation
|
||||||
|
LXC_MEM_MIN=1024
|
||||||
|
|
||||||
|
# service dependent meta tags
|
||||||
|
SERVICE_TAGS="nginx"
|
35
src/vaultwarden/constants-service.conf
Normal file
35
src/vaultwarden/constants-service.conf
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Authors:
|
||||||
|
# (C) 2021 Idea an concept by Christian Zengel <christian@sysops.de>
|
||||||
|
# (C) 2021 Script design and prototype by Markus Helmke <m.helmke@nettwarker.de>
|
||||||
|
# (C) 2021 Script rework and documentation by Thorsten Spille <thorsten@spille-edv.de>
|
||||||
|
|
||||||
|
# This file contains the project constants on service level
|
||||||
|
|
||||||
|
# Debian Version, which will be installed
|
||||||
|
LXC_TEMPLATE_VERSION="debian-11-standard"
|
||||||
|
|
||||||
|
# Create sharefs mountpoint
|
||||||
|
LXC_MP="0"
|
||||||
|
|
||||||
|
# Create unprivileged container
|
||||||
|
LXC_UNPRIVILEGED="1"
|
||||||
|
|
||||||
|
# enable nesting feature
|
||||||
|
LXC_NESTING="1"
|
||||||
|
|
||||||
|
# Defines the name from the SQL database
|
||||||
|
VAULTWARDEN_DB_NAME="vaultwarden"
|
||||||
|
|
||||||
|
# Defines the name from the SQL user
|
||||||
|
VAULTWARDEN_DB_USR="vaultwarden"
|
||||||
|
|
||||||
|
# Build a strong password for the SQL user - could be overwritten with something fixed
|
||||||
|
VAULTWARDEN_DB_PWD="$(random_password)"
|
||||||
|
|
||||||
|
# Sets the minimum amount of RAM the service needs for operation
|
||||||
|
LXC_MEM_MIN=1024
|
||||||
|
|
||||||
|
# service dependent meta tags
|
||||||
|
SERVICE_TAGS="nginx,postgresql"
|
161
src/vaultwarden/install-service.sh
Normal file
161
src/vaultwarden/install-service.sh
Normal file
@ -0,0 +1,161 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Authors:
|
||||||
|
# (C) 2021 Idea an concept by Christian Zengel <christian@sysops.de>
|
||||||
|
# (C) 2021 Script design and prototype by Markus Helmke <m.helmke@nettwarker.de>
|
||||||
|
# (C) 2021 Script rework and documentation by Thorsten Spille <thorsten@spille-edv.de>
|
||||||
|
|
||||||
|
source /root/functions.sh
|
||||||
|
source /root/zamba.conf
|
||||||
|
source /root/constants-service.conf
|
||||||
|
|
||||||
|
admin_token=$(openssl rand -base64 48)
|
||||||
|
|
||||||
|
DEBIAN_FRONTEND=noninteractive DEBIAN_PRIORITY=critical apt install -y -qq postgresql nginx git ssl-cert
|
||||||
|
|
||||||
|
systemctl enable --now postgresql
|
||||||
|
|
||||||
|
wget https://raw.githubusercontent.com/jjlin/docker-image-extract/main/docker-image-extract
|
||||||
|
chmod +x docker-image-extract
|
||||||
|
./docker-image-extract vaultwarden/server:alpine
|
||||||
|
mkdir /opt/vaultwarden
|
||||||
|
mkdir -p /var/lib/vaultwarden/data
|
||||||
|
useradd vaultwarden
|
||||||
|
chown -R vaultwarden:vaultwarden /var/lib/vaultwarden
|
||||||
|
mv output/vaultwarden /opt/vaultwarden
|
||||||
|
mv output/web-vault /var/lib/vaultwarden/
|
||||||
|
rm -Rf output
|
||||||
|
rm -Rf docker-image-extract
|
||||||
|
|
||||||
|
su - postgres <<EOF
|
||||||
|
psql -c "CREATE USER ${VAULTWARDEN_DB_USR} WITH PASSWORD '${VAULTWARDEN_DB_PWD}';"
|
||||||
|
psql -c "CREATE DATABASE ${VAULTWARDEN_DB_NAME} ENCODING UTF8 TEMPLATE template0 OWNER ${VAULTWARDEN_DB_USR};"
|
||||||
|
echo "Postgres User ${VAULTWARDEN_DB_USR} and database ${VAULTWARDEN_DB_NAME} created."
|
||||||
|
EOF
|
||||||
|
|
||||||
|
cat << EOF > /var/lib/vaultwarden/.env
|
||||||
|
DATABASE_URL=postgresql://vaultwarden:${VAULTWARDEN_DB_PWD}@localhost:5432/vaultwarden
|
||||||
|
DOMAIN=https://${LXC_HOSTNAME}.${LXC_DOMAIN}
|
||||||
|
ORG_CREATION_USERS=admin@$LXC_DOMAIN
|
||||||
|
# Use `openssl rand -base64 48` to generate
|
||||||
|
ADMIN_TOKEN=$admin_token
|
||||||
|
# Uncomment this once vaults restored
|
||||||
|
SIGNUPS_ALLOWED=false
|
||||||
|
SMTP_HOST=$VW_SMTP_HOST
|
||||||
|
SMTP_FROM=$VW_SMTP_FROM
|
||||||
|
SMTP_FROM_NAME="$VW_SMTP_FROM_NAME"
|
||||||
|
SMTP_PORT=$VW_SMTP_PORT # Ports 587 (submission) and 25 (smtp) are standard without encryption and with encryption via STARTTLS (Explicit TLS). Port 465 is outdated and us>
|
||||||
|
SMTP_SSL=$VW_SMTP_SSL # (Explicit) - This variable by default configures Explicit STARTTLS, it will upgrade an insecure connection to a secure one. Unless SMTP_EXPLICIT_>
|
||||||
|
SMTP_EXPLICIT_TLS=$VW_SMTP_EXPLICIT_TLS # (Implicit) - N.B. This variable configures Implicit TLS. It's currently mislabelled (see bug #851) - SMTP_SSL Needs to be set to true for this o>
|
||||||
|
SMTP_USERNAME=$VW_SMTP_USERNAME
|
||||||
|
SMTP_PASSWORD=$VW_SMTP_PASSWORD
|
||||||
|
SMTP_TIMEOUT=15
|
||||||
|
EOF
|
||||||
|
|
||||||
|
cat << EOF > /etc/systemd/system/vaultwarden.service
|
||||||
|
[Unit]
|
||||||
|
Description=Bitwarden Server (Rust Edition)
|
||||||
|
Documentation=https://github.com/dani-garcia/vaultwarden
|
||||||
|
After=network.target
|
||||||
|
|
||||||
|
[Service]
|
||||||
|
User=vaultwarden
|
||||||
|
Group=vaultwarden
|
||||||
|
EnvironmentFile=/var/lib/vaultwarden/.env
|
||||||
|
ExecStart=/opt/vaultwarden/vaultwarden
|
||||||
|
LimitNOFILE=1048576
|
||||||
|
LimitNPROC=64
|
||||||
|
PrivateTmp=true
|
||||||
|
PrivateDevices=true
|
||||||
|
ProtectHome=true
|
||||||
|
ProtectSystem=strict
|
||||||
|
WorkingDirectory=/var/lib/vaultwarden
|
||||||
|
ReadWriteDirectories=/var/lib/vaultwarden
|
||||||
|
AmbientCapabilities=CAP_NET_BIND_SERVICE
|
||||||
|
|
||||||
|
[Install]
|
||||||
|
WantedBy=multi-user.target
|
||||||
|
EOF
|
||||||
|
|
||||||
|
cat << EOF > /etc/apt/apt.conf.d/80-vaultwarden-apt-hook
|
||||||
|
DPkg::Post-Invoke {"/var/lib/vaultwarden/update.sh";};
|
||||||
|
EOF
|
||||||
|
|
||||||
|
cat << EOF > /var/lib/vaultwarden/update.sh
|
||||||
|
PATH="/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin"
|
||||||
|
wget https://raw.githubusercontent.com/jjlin/docker-image-extract/main/docker-image-extract
|
||||||
|
chmod +x docker-image-extract
|
||||||
|
./docker-image-extract vaultwarden/server:alpine
|
||||||
|
mv output/vaultwarden /opt/vaultwarden
|
||||||
|
systemctl stop vaultwarden.service
|
||||||
|
cp -rlf output/web-vault /var/lib/vaultwarden/
|
||||||
|
rm -Rf output
|
||||||
|
rm -Rf docker-image-extract
|
||||||
|
systemctl start vaultwarden.service
|
||||||
|
EOF
|
||||||
|
|
||||||
|
chmod +x /etc/apt/apt.conf.d/80-vaultwarden-apt-hook
|
||||||
|
chmod +x /var/lib/vaultwarden/update.sh
|
||||||
|
|
||||||
|
cat << EOF > /etc/nginx/conf.d/default.conf
|
||||||
|
server {
|
||||||
|
listen 80;
|
||||||
|
listen [::]:80;
|
||||||
|
server_name _;
|
||||||
|
|
||||||
|
server_tokens off;
|
||||||
|
|
||||||
|
access_log /var/log/nginx/vaultwarden.access.log;
|
||||||
|
error_log /var/log/nginx/vaultwarden.error.log;
|
||||||
|
|
||||||
|
location /.well-known/ {
|
||||||
|
root /var/www/html;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 301 https://${LXC_HOSTNAME}.${LXC_DOMAIN}\$request_uri;
|
||||||
|
}
|
||||||
|
|
||||||
|
server {
|
||||||
|
listen 443 ssl http2;
|
||||||
|
listen [::]:443 ssl http2;
|
||||||
|
|
||||||
|
server_name ${LXC_HOSTNAME}.${LXC_DOMAIN};
|
||||||
|
|
||||||
|
server_tokens off;
|
||||||
|
ssl_certificate /etc/ssl/certs/ssl-cert-snakeoil.pem;
|
||||||
|
ssl_certificate_key /etc/ssl/private/ssl-cert-snakeoil.key;
|
||||||
|
|
||||||
|
ssl_protocols TLSv1.3 TLSv1.2;
|
||||||
|
ssl_ciphers ECDHE-ECDSA-CHACHA20-POLY1305:ECDHE-RSA-CHACHA20-POLY1305:EECDH+AESGCM:EDH+AESGCM;
|
||||||
|
ssl_dhparam /etc/nginx/dhparam.pem;
|
||||||
|
ssl_prefer_server_ciphers on;
|
||||||
|
ssl_session_cache shared:SSL:10m;
|
||||||
|
ssl_session_timeout 180m;
|
||||||
|
|
||||||
|
ssl_stapling on;
|
||||||
|
ssl_stapling_verify on;
|
||||||
|
|
||||||
|
resolver 1.1.1.1 1.0.0.1;
|
||||||
|
|
||||||
|
add_header Strict-Transport-Security "max-age=31536000" always;
|
||||||
|
|
||||||
|
access_log /var/log/nginx/vaultwarden.access.log;
|
||||||
|
error_log /var/log/nginx/vaultwarden.error.log;
|
||||||
|
|
||||||
|
client_max_body_size 50M;
|
||||||
|
|
||||||
|
location / {
|
||||||
|
proxy_set_header X-Real-IP \$remote_addr;
|
||||||
|
proxy_set_header Host \$host;
|
||||||
|
proxy_set_header X-Forwarded-For \$proxy_add_x_forwarded_for;
|
||||||
|
proxy_pass http://127.0.0.1:8000;
|
||||||
|
proxy_read_timeout 90;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
EOF
|
||||||
|
openssl dhparam -out /etc/nginx/dhparam.pem 4096
|
||||||
|
|
||||||
|
systemctl daemon-reload
|
||||||
|
systemctl enable --now vaultwarden
|
||||||
|
systemctl restart nginx
|
@ -34,3 +34,9 @@ ZABBIX_DB_USR="zabbix"
|
|||||||
|
|
||||||
# Build a strong password for the SQL user - could be overwritten with something fixed
|
# Build a strong password for the SQL user - could be overwritten with something fixed
|
||||||
ZABBIX_DB_PWD="$(random_password)"
|
ZABBIX_DB_PWD="$(random_password)"
|
||||||
|
|
||||||
|
# Sets the minimum amount of RAM the service needs for operation
|
||||||
|
LXC_MEM_MIN=4096
|
||||||
|
|
||||||
|
# service dependent meta tags
|
||||||
|
SERVICE_TAGS="php-fpm,nginx,postgresql"
|
@ -18,7 +18,7 @@ echo "deb http://apt.postgresql.org/pub/repos/apt $(lsb_release -cs)-pgdg main"
|
|||||||
apt update
|
apt update
|
||||||
|
|
||||||
DEBIAN_FRONTEND=noninteractive DEBIAN_PRIORITY=critical apt -y -qq dist-upgrade
|
DEBIAN_FRONTEND=noninteractive DEBIAN_PRIORITY=critical apt -y -qq dist-upgrade
|
||||||
DEBIAN_FRONTEND=noninteractive DEBIAN_PRIORITY=critical apt -y -qq install --no-install-recommends postgresql nginx php7.4-pgsql php7.4-fpm zabbix-server-pgsql zabbix-frontend-php zabbix-sql-scripts zabbix-agent sudo ssl-cert
|
DEBIAN_FRONTEND=noninteractive DEBIAN_PRIORITY=critical apt -y -qq install --no-install-recommends postgresql nginx php7.4-pgsql php7.4-fpm zabbix-server-pgsql zabbix-frontend-php zabbix-nginx-conf zabbix-sql-scripts zabbix-agent ssl-cert
|
||||||
|
|
||||||
unlink /etc/nginx/sites-enabled/default
|
unlink /etc/nginx/sites-enabled/default
|
||||||
|
|
||||||
@ -30,8 +30,8 @@ server {
|
|||||||
|
|
||||||
server_tokens off;
|
server_tokens off;
|
||||||
|
|
||||||
access_log /var/log/nginx/gitea.access.log;
|
access_log /var/log/nginx/zabbix.access.log;
|
||||||
error_log /var/log/nginx/gitea.error.log;
|
error_log /var/log/nginx/zabbix.error.log;
|
||||||
|
|
||||||
location /.well-known/ {
|
location /.well-known/ {
|
||||||
}
|
}
|
||||||
@ -122,8 +122,6 @@ server {
|
|||||||
}
|
}
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
ln -sf /etc/zabbix/nginx.conf /etc/nginx/sites-enabled/zabbix.conf
|
|
||||||
|
|
||||||
cat << EOF > /etc/php/7.4/fpm/pool.d/zabbix-php-fpm.conf
|
cat << EOF > /etc/php/7.4/fpm/pool.d/zabbix-php-fpm.conf
|
||||||
[zabbix]
|
[zabbix]
|
||||||
user = www-data
|
user = www-data
|
||||||
@ -151,19 +149,76 @@ php_value[max_input_time] = 300
|
|||||||
php_value[max_input_vars] = 10000
|
php_value[max_input_vars] = 10000
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
|
cat << EOF > /etc/zabbix/web/zabbix.conf.php
|
||||||
|
<?php
|
||||||
|
// Zabbix GUI configuration file.
|
||||||
|
|
||||||
|
\$DB['TYPE'] = 'POSTGRESQL';
|
||||||
|
\$DB['SERVER'] = 'localhost';
|
||||||
|
\$DB['PORT'] = '0';
|
||||||
|
\$DB['DATABASE'] = '${ZABBIX_DB_NAME}';
|
||||||
|
\$DB['USER'] = '${ZABBIX_DB_USR}';
|
||||||
|
\$DB['PASSWORD'] = '${ZABBIX_DB_PWD}';
|
||||||
|
|
||||||
|
// Schema name. Used for PostgreSQL.
|
||||||
|
\$DB['SCHEMA'] = '';
|
||||||
|
|
||||||
|
// Used for TLS connection.
|
||||||
|
\$DB['ENCRYPTION'] = true;
|
||||||
|
\$DB['KEY_FILE'] = '';
|
||||||
|
\$DB['CERT_FILE'] = '';
|
||||||
|
\$DB['CA_FILE'] = '';
|
||||||
|
\$DB['VERIFY_HOST'] = false;
|
||||||
|
\$DB['CIPHER_LIST'] = '';
|
||||||
|
|
||||||
|
// Vault configuration. Used if database credentials are stored in Vault secrets manager.
|
||||||
|
\$DB['VAULT_URL'] = '';
|
||||||
|
\$DB['VAULT_DB_PATH'] = '';
|
||||||
|
\$DB['VAULT_TOKEN'] = '';
|
||||||
|
|
||||||
|
// Use IEEE754 compatible value range for 64-bit Numeric (float) history values.
|
||||||
|
// This option is enabled by default for new Zabbix installations.
|
||||||
|
// For upgraded installations, please read database upgrade notes before enabling this option.
|
||||||
|
\$DB['DOUBLE_IEEE754'] = true;
|
||||||
|
|
||||||
|
// Uncomment and set to desired values to override Zabbix hostname/IP and port.
|
||||||
|
// \$ZBX_SERVER = '';
|
||||||
|
// \$ZBX_SERVER_PORT = '';
|
||||||
|
|
||||||
|
\$ZBX_SERVER_NAME = '${LXC_HOSTNAME}';
|
||||||
|
|
||||||
|
\$IMAGE_FORMAT_DEFAULT = IMAGE_FORMAT_PNG;
|
||||||
|
|
||||||
|
// Uncomment this block only if you are using Elasticsearch.
|
||||||
|
// Elasticsearch url (can be string if same url is used for all types).
|
||||||
|
//\$HISTORY['url'] = [
|
||||||
|
// 'uint' => 'http://localhost:9200',
|
||||||
|
// 'text' => 'http://localhost:9200'
|
||||||
|
//];
|
||||||
|
// Value types stored in Elasticsearch.
|
||||||
|
//\$HISTORY['types'] = ['uint', 'text'];
|
||||||
|
|
||||||
|
// Used for SAML authentication.
|
||||||
|
// Uncomment to override the default paths to SP private key, SP and IdP X.509 certificates, and to set extra settings.
|
||||||
|
//\$SSO['SP_KEY'] = 'conf/certs/sp.key';
|
||||||
|
//\$SSO['SP_CERT'] = 'conf/certs/sp.crt';
|
||||||
|
//\$SSO['IDP_CERT'] = 'conf/certs/idp.crt';
|
||||||
|
//\$SSO['SETTINGS'] = [];
|
||||||
|
EOF
|
||||||
|
|
||||||
timedatectl set-timezone ${LXC_TIMEZONE}
|
timedatectl set-timezone ${LXC_TIMEZONE}
|
||||||
|
|
||||||
systemctl enable --now postgresql
|
systemctl enable --now postgresql
|
||||||
|
|
||||||
su - postgres <<EOF
|
su - postgres <<EOF
|
||||||
psql -c "CREATE USER ZABBIX WITH PASSWORD '${ZABBIX_DB_PWD}';"
|
psql -c "CREATE USER ${ZABBIX_DB_USR} WITH PASSWORD '${ZABBIX_DB_PWD}';"
|
||||||
psql -c "CREATE DATABASE ${ZABBIX_DB_NAME} ENCODING UTF8 TEMPLATE template0 OWNER ${ZABBIX_DB_USR};"
|
psql -c "CREATE DATABASE ${ZABBIX_DB_NAME} ENCODING UTF8 TEMPLATE template0 OWNER ${ZABBIX_DB_USR};"
|
||||||
echo "Postgres User ${ZABBIX_DB_USR} and database ${ZABBIX_DB_NAME} created."
|
echo "Postgres User ${ZABBIX_DB_USR} and database ${ZABBIX_DB_NAME} created."
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
sed -i "s/false/true/g" /usr/share/zabbix/include/locales.inc.php
|
sed -i "s/false/true/g" /usr/share/zabbix/include/locales.inc.php
|
||||||
|
|
||||||
zcat /usr/share/doc/zabbix-sql-scripts/postgresql/server.sql.gz | sudo -u zabbix psql zabbix
|
zcat /usr/share/zabbix-sql-scripts/postgresql/server.sql.gz | sudo -u zabbix psql ${ZABBIX_DB_NAME}
|
||||||
|
|
||||||
echo "DBPassword=${ZABBIX_DB_PWD}" >> /etc/zabbix/zabbix_server.conf
|
echo "DBPassword=${ZABBIX_DB_PWD}" >> /etc/zabbix/zabbix_server.conf
|
||||||
|
|
||||||
|
@ -18,3 +18,9 @@ LXC_UNPRIVILEGED="1"
|
|||||||
|
|
||||||
# enable nesting feature
|
# enable nesting feature
|
||||||
LXC_NESTING="1"
|
LXC_NESTING="1"
|
||||||
|
|
||||||
|
# Sets the minimum amount of RAM the service needs for operation
|
||||||
|
LXC_MEM_MIN=4096
|
||||||
|
|
||||||
|
# service dependent meta tags
|
||||||
|
SERVICE_TAGS="nginx,postgresql,elasticsearch"
|
@ -15,7 +15,34 @@ wget -O /etc/apt/sources.list.d/zammad.list https://dl.packager.io/srv/zammad/za
|
|||||||
echo "deb https://artifacts.elastic.co/packages/7.x/apt stable main" > /etc/apt/sources.list.d/elastic-7.x.list
|
echo "deb https://artifacts.elastic.co/packages/7.x/apt stable main" > /etc/apt/sources.list.d/elastic-7.x.list
|
||||||
apt update
|
apt update
|
||||||
DEBIAN_FRONTEND=noninteractive DEBIAN_PRIORITY=critical apt -y -qq dist-upgrade
|
DEBIAN_FRONTEND=noninteractive DEBIAN_PRIORITY=critical apt -y -qq dist-upgrade
|
||||||
DEBIAN_FRONTEND=noninteractive DEBIAN_PRIORITY=critical apt -y -qq install ssl-cert zammad
|
DEBIAN_FRONTEND=noninteractive DEBIAN_PRIORITY=critical apt -y -qq install ssl-cert nginx-full postgresql zammad
|
||||||
|
|
||||||
|
|
||||||
|
cat << EOF >>/etc/hosts
|
||||||
|
0.0.0.0 image.zammad.com
|
||||||
|
0.0.0.0 images.zammad.com
|
||||||
|
0.0.0.0 geo.zammad.com
|
||||||
|
0.0.0.0 www.zammad.com
|
||||||
|
0.0.0.0 www.zammad.org
|
||||||
|
0.0.0.0 www.zammad.net
|
||||||
|
0.0.0.0 www.zammad.de
|
||||||
|
0.0.0.0 zammad.com
|
||||||
|
0.0.0.0 zammad.org
|
||||||
|
0.0.0.0 zammad.net
|
||||||
|
0.0.0.0 zammad.de
|
||||||
|
#
|
||||||
|
127.0.0.1 elasticsearch
|
||||||
|
0.0.0.0 geoip.elastic.co
|
||||||
|
EOF
|
||||||
|
|
||||||
|
# Java set startup environment
|
||||||
|
mkdir -p /etc/elasticsearch/jvm.options.d
|
||||||
|
cat << EOF >>/etc/elasticsearch/jvm.options.d/msmx-size.options
|
||||||
|
# INFO: https://www.elastic.co/guide/en/elasticsearch/reference/master/advanced-configuration.html#set-jvm-heap-size
|
||||||
|
# max 50% of total RAM - 2G Ram then set Xms and Xmx 1g
|
||||||
|
-Xms1g
|
||||||
|
-Xmx1g
|
||||||
|
EOF
|
||||||
|
|
||||||
# configurwe nginx
|
# configurwe nginx
|
||||||
rm -f /etc/nginx/sites-enabled/default
|
rm -f /etc/nginx/sites-enabled/default
|
||||||
@ -66,7 +93,16 @@ server {
|
|||||||
ssl_stapling_verify on;
|
ssl_stapling_verify on;
|
||||||
|
|
||||||
resolver 1.1.1.1 1.0.0.1;
|
resolver 1.1.1.1 1.0.0.1;
|
||||||
|
#
|
||||||
|
# https://webdock.io/en/docs/how-guides/security-guides/how-to-configure-security-headers-in-nginx-and-apache
|
||||||
|
#
|
||||||
|
add_header Strict-Transport-Security 'max-age=31536000; includeSubDomains; preload';
|
||||||
|
add_header Content-Security-Policy "default-src 'self'; font-src *;img-src * data:; script-src *; style-src *";
|
||||||
|
add_header Referrer-Policy "strict-origin";
|
||||||
|
add_header X-Frame-Options DENY;
|
||||||
|
add_header X-Content-Type-Options nosniff;
|
||||||
|
add_header X-XSS-Protection "1; mode=block";
|
||||||
|
add_header Permissions-Policy "geolocation=(),midi=(),sync-xhr=(),microphone=(),camera=(),magnetometer=(),gyroscope=(),fullscreen=(self),payment=()";
|
||||||
add_header Strict-Transport-Security "max-age=31536000" always;
|
add_header Strict-Transport-Security "max-age=31536000" always;
|
||||||
|
|
||||||
location = /robots.txt {
|
location = /robots.txt {
|
||||||
@ -118,6 +154,17 @@ server {
|
|||||||
}
|
}
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
|
ln -sf /etc/nginx/sites-available/zammad.conf /etc/nginx/sites-enabled/
|
||||||
|
|
||||||
openssl dhparam -out /etc/nginx/dhparam.pem 4096
|
openssl dhparam -out /etc/nginx/dhparam.pem 4096
|
||||||
|
|
||||||
systemctl restart nginx
|
systemctl enable elasticsearch.service
|
||||||
|
systemctl restart nginx elasticsearch.service
|
||||||
|
|
||||||
|
# Elasticsearch conntact to Zammad
|
||||||
|
/usr/share/elasticsearch/bin/elasticsearch-plugin install -b ingest-attachment
|
||||||
|
zammad run rails r "Setting.set('es_url', 'http://localhost:9200')"
|
||||||
|
zammad run rails r "Setting.set('es_index', Socket.gethostname.downcase + '_zammad')"
|
||||||
|
zammad run rails r "User.find_by(email: 'nicole.braun@zammad.org').destroy"
|
||||||
|
systemctl restart elasticsearch.service
|
||||||
|
zammad run rake searchindex:rebuild
|
@ -19,4 +19,20 @@ LXC_UNPRIVILEGED="0"
|
|||||||
# enable nesting feature
|
# enable nesting feature
|
||||||
LXC_NESTING="1"
|
LXC_NESTING="1"
|
||||||
|
|
||||||
|
# add optional features to samba ad dc
|
||||||
|
|
||||||
|
# CURRENTLY SUPPORTED:
|
||||||
|
# wsdd = add windows service discovery
|
||||||
|
# splitdns = add nginx to redirect to website www.domain.tld in splitdns setup
|
||||||
|
# bind9dlz = Set ZMB_DNS_BACKEND to BIND9_DLZ
|
||||||
|
|
||||||
|
# Example:
|
||||||
|
# OPTIONAL_FEATURES=(wsdd)
|
||||||
|
# OPTIONAL_FEATURES=(wsdd splitdns)
|
||||||
OPTIONAL_FEATURES=(wsdd splitdns)
|
OPTIONAL_FEATURES=(wsdd splitdns)
|
||||||
|
|
||||||
|
# Sets the minimum amount of RAM the service needs for operation
|
||||||
|
LXC_MEM_MIN=1024
|
||||||
|
|
||||||
|
# service dependent meta tags
|
||||||
|
SERVICE_TAGS="nginx,samba,dns,ntp,dc,ldap,secondary"
|
@ -53,12 +53,14 @@ restrict 2.pool.ntp.org mask 255.255.255.255 nomodify notrap nopeer noquery
|
|||||||
tinker panic 0
|
tinker panic 0
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
|
echo "deb http://ftp.de.debian.org/debian $(lsb_release -cs)-backports main contrib" > /etc/apt/sources.list.d/$(lsb_release -cs)-backports.list
|
||||||
|
|
||||||
# update packages
|
# update packages
|
||||||
apt update
|
apt update
|
||||||
DEBIAN_FRONTEND=noninteractive DEBIAN_PRIORITY=critical apt -y -qq dist-upgrade
|
DEBIAN_FRONTEND=noninteractive DEBIAN_PRIORITY=critical apt -y -qq dist-upgrade
|
||||||
# install required packages
|
# install required packages
|
||||||
DEBIAN_FRONTEND=noninteractive DEBIAN_PRIORITY=critical apt install -y -o DPkg::options::="--force-confdef" -o DPkg::options::="--force-confold" $LXC_TOOLSET $ADDITIONAL_PACKAGES rsync acl attr ntpdate rpl net-tools dnsutils ntp cifs-utils samba smbclient winbind libpam-winbind libnss-winbind krb5-user samba-dsdb-modules samba-vfs-modules lmdb-utils
|
DEBIAN_FRONTEND=noninteractive DEBIAN_PRIORITY=critical apt install -y -o DPkg::options::="--force-confdef" -o DPkg::options::="--force-confold" $LXC_TOOLSET $ADDITIONAL_PACKAGES ntpdate rpl net-tools dnsutils ntp
|
||||||
|
DEBIAN_FRONTEND=noninteractive DEBIAN_PRIORITY=critical apt install -y -o DPkg::options::="--force-confdef" -o DPkg::options::="--force-confold" -t $(lsb_release -cs)-backports acl attr samba smbclient winbind libpam-winbind libnss-winbind krb5-user samba-dsdb-modules samba-vfs-modules lmdb-utils rsync cifs-utils
|
||||||
if [[ "$ADDITIONAL_PACKAGES" == *"nginx-full"* ]]; then
|
if [[ "$ADDITIONAL_PACKAGES" == *"nginx-full"* ]]; then
|
||||||
cat << EOF > /etc/nginx/sites-available/default
|
cat << EOF > /etc/nginx/sites-available/default
|
||||||
server {
|
server {
|
||||||
@ -127,10 +129,24 @@ rm -f /etc/samba/smb.conf
|
|||||||
echo -e "$ZMB_ADMIN_PASS" | kinit -V $ZMB_ADMIN_USER
|
echo -e "$ZMB_ADMIN_PASS" | kinit -V $ZMB_ADMIN_USER
|
||||||
samba-tool domain join $ZMB_REALM DC -k yes --backend-store=mdb
|
samba-tool domain join $ZMB_REALM DC -k yes --backend-store=mdb
|
||||||
|
|
||||||
cat > /etc/cron.d/sysvol-sync << EOF
|
mkdir -p /mnt/sysvol
|
||||||
*/5 * * * * root /usr/bin/rsync -XAavz --delete-after root@$LXC_DNS:/var/lib/samba/sysvol/ /var/lib/samba/sysvol
|
|
||||||
|
cat << EOF > /root/.smbcredentials
|
||||||
|
username=$ZMB_ADMIN_USER
|
||||||
|
password=$ZMB_ADMIN_PASS
|
||||||
|
domain=$ZMB_DOMAIN
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
|
echo "//$LXC_DNS/sysvol /mnt/sysvol cifs credentials=/root/.smbcredentials 0 0" >> /etc/fstab
|
||||||
|
|
||||||
|
mount.cifs //$LXC_DNS/sysvol /mnt/sysvol -o credentials=/root/.smbcredentials
|
||||||
|
|
||||||
|
cat > /etc/cron.d/sysvol-sync << EOF
|
||||||
|
*/15 * * * * root /usr/bin/rsync -XAavz --delete-after /mnt/sysvol/ /var/lib/samba/sysvol
|
||||||
|
EOF
|
||||||
|
|
||||||
|
/usr/bin/rsync -XAavz --delete-after /mnt/sysvol/ /var/lib/samba/sysvol
|
||||||
|
|
||||||
ssh-keygen -q -f "$HOME/.ssh/id_rsa" -N "" -b 4096
|
ssh-keygen -q -f "$HOME/.ssh/id_rsa" -N "" -b 4096
|
||||||
|
|
||||||
systemctl unmask samba-ad-dc
|
systemctl unmask samba-ad-dc
|
||||||
|
@ -29,4 +29,10 @@ LXC_NESTING="1"
|
|||||||
# Example:
|
# Example:
|
||||||
# OPTIONAL_FEATURES=(wsdd)
|
# OPTIONAL_FEATURES=(wsdd)
|
||||||
# OPTIONAL_FEATURES=(wsdd splitdns)
|
# OPTIONAL_FEATURES=(wsdd splitdns)
|
||||||
OPTIONAL_FEATURES=()
|
OPTIONAL_FEATURES=(wsdd splitdns)
|
||||||
|
|
||||||
|
# Sets the minimum amount of RAM the service needs for operation
|
||||||
|
LXC_MEM_MIN=1024
|
||||||
|
|
||||||
|
# service dependent meta tags
|
||||||
|
SERVICE_TAGS="nginx,samba,dns,ntp,dc,ldap,primary"
|
@ -59,11 +59,14 @@ restrict 2.pool.ntp.org mask 255.255.255.255 nomodify notrap nopeer noquery
|
|||||||
tinker panic 0
|
tinker panic 0
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
|
echo "deb http://ftp.de.debian.org/debian $(lsb_release -cs)-backports main contrib" > /etc/apt/sources.list.d/$(lsb_release -cs)-backports.list
|
||||||
|
|
||||||
# update packages
|
# update packages
|
||||||
apt update
|
apt update
|
||||||
DEBIAN_FRONTEND=noninteractive DEBIAN_PRIORITY=critical apt -y -qq dist-upgrade
|
DEBIAN_FRONTEND=noninteractive DEBIAN_PRIORITY=critical apt -y -qq dist-upgrade
|
||||||
# install required packages
|
# install required packages
|
||||||
DEBIAN_FRONTEND=noninteractive DEBIAN_PRIORITY=critical apt install -y -o DPkg::options::="--force-confdef" -o DPkg::options::="--force-confold" $LXC_TOOLSET $ADDITIONAL_PACKAGES acl attr ntpdate rpl net-tools dnsutils ntp samba smbclient winbind libpam-winbind libnss-winbind krb5-user samba-dsdb-modules samba-vfs-modules lmdb-utils
|
DEBIAN_FRONTEND=noninteractive DEBIAN_PRIORITY=critical apt install -y -o DPkg::options::="--force-confdef" -o DPkg::options::="--force-confold" $LXC_TOOLSET $ADDITIONAL_PACKAGES ntpdate rpl net-tools dnsutils ntp
|
||||||
|
DEBIAN_FRONTEND=noninteractive DEBIAN_PRIORITY=critical apt install -y -o DPkg::options::="--force-confdef" -o DPkg::options::="--force-confold" -t $(lsb_release -cs)-backports acl attr samba smbclient winbind libpam-winbind libnss-winbind krb5-user samba-dsdb-modules samba-vfs-modules lmdb-utils
|
||||||
|
|
||||||
if [[ "$ADDITIONAL_PACKAGES" == *"nginx-full"* ]]; then
|
if [[ "$ADDITIONAL_PACKAGES" == *"nginx-full"* ]]; then
|
||||||
cat << EOF > /etc/nginx/sites-available/default
|
cat << EOF > /etc/nginx/sites-available/default
|
||||||
|
@ -18,3 +18,9 @@ LXC_UNPRIVILEGED="0"
|
|||||||
|
|
||||||
# enable nesting feature
|
# enable nesting feature
|
||||||
LXC_NESTING="1"
|
LXC_NESTING="1"
|
||||||
|
|
||||||
|
# Sets the minimum amount of RAM the service needs for operation
|
||||||
|
LXC_MEM_MIN=1024
|
||||||
|
|
||||||
|
# service dependent meta tags
|
||||||
|
SERVICE_TAGS="samba,member,fileserver"
|
@ -12,10 +12,11 @@ source /root/constants-service.conf
|
|||||||
# add wsdd package repo
|
# add wsdd package repo
|
||||||
apt-key adv --fetch-keys https://pkg.ltec.ch/public/conf/ltec-ag.gpg.key
|
apt-key adv --fetch-keys https://pkg.ltec.ch/public/conf/ltec-ag.gpg.key
|
||||||
echo "deb https://pkg.ltec.ch/public/ $(lsb_release -cs) main" > /etc/apt/sources.list.d/wsdd.list
|
echo "deb https://pkg.ltec.ch/public/ $(lsb_release -cs) main" > /etc/apt/sources.list.d/wsdd.list
|
||||||
|
echo "deb http://ftp.de.debian.org/debian $(lsb_release -cs)-backports main contrib" > /etc/apt/sources.list.d/$(lsb_release -cs)-backports.list
|
||||||
|
|
||||||
apt update
|
apt update
|
||||||
|
|
||||||
DEBIAN_FRONTEND=noninteractive DEBIAN_PRIORITY=critical apt install -y -o DPkg::options::="--force-confdef" -o DPkg::options::="--force-confold" acl samba winbind libpam-winbind libnss-winbind krb5-user krb5-config samba-dsdb-modules samba-vfs-modules wsdd
|
DEBIAN_FRONTEND=noninteractive DEBIAN_PRIORITY=critical apt install -y -o DPkg::options::="--force-confdef" -o DPkg::options::="--force-confold" -t $(lsb_release -cs)-backports acl samba winbind libpam-winbind libnss-winbind krb5-user krb5-config samba-dsdb-modules samba-vfs-modules wsdd
|
||||||
|
|
||||||
mv /etc/krb5.conf /etc/krb5.conf.bak
|
mv /etc/krb5.conf /etc/krb5.conf.bak
|
||||||
cat > /etc/krb5.conf <<EOF
|
cat > /etc/krb5.conf <<EOF
|
||||||
|
@ -18,3 +18,9 @@ LXC_UNPRIVILEGED="0"
|
|||||||
|
|
||||||
# enable nesting feature
|
# enable nesting feature
|
||||||
LXC_NESTING="1"
|
LXC_NESTING="1"
|
||||||
|
|
||||||
|
# Sets the minimum amount of RAM the service needs for operation
|
||||||
|
LXC_MEM_MIN=1024
|
||||||
|
|
||||||
|
# service dependent meta tags
|
||||||
|
SERVICE_TAGS="samba,nfs,standalone,fileserver,cockpit"
|
@ -11,18 +11,33 @@ source /root/constants-service.conf
|
|||||||
|
|
||||||
# add wsdd package repo
|
# add wsdd package repo
|
||||||
apt-key adv --fetch-keys https://pkg.ltec.ch/public/conf/ltec-ag.gpg.key
|
apt-key adv --fetch-keys https://pkg.ltec.ch/public/conf/ltec-ag.gpg.key
|
||||||
|
apt-key adv --fetch-keys https://repo.45drives.com/key/gpg.asc
|
||||||
|
echo "deb https://repo.45drives.com/debian focal main" > /etc/apt/sources.list.d/45drives.list
|
||||||
echo "deb https://pkg.ltec.ch/public/ $(lsb_release -cs) main" > /etc/apt/sources.list.d/wsdd.list
|
echo "deb https://pkg.ltec.ch/public/ $(lsb_release -cs) main" > /etc/apt/sources.list.d/wsdd.list
|
||||||
echo "deb http://ftp.de.debian.org/debian $(lsb_release -cs)-backports main contrib" > /etc/apt/sources.list.d/$(lsb_release -cs)-backports.list
|
echo "deb http://ftp.de.debian.org/debian $(lsb_release -cs)-backports main contrib" > /etc/apt/sources.list.d/$(lsb_release -cs)-backports.list
|
||||||
|
|
||||||
|
cat << EOF > /etc/apt/preferences.d/samba
|
||||||
|
Package: samba*
|
||||||
|
Pin: release a=$(lsb_release -cs)-backports
|
||||||
|
Pin-Priority: 900
|
||||||
|
EOF
|
||||||
|
|
||||||
|
cat << EOF > /etc/apt/preferences.d/winbind
|
||||||
|
Package: winbind*
|
||||||
|
Pin: release a=$(lsb_release -cs)-backports
|
||||||
|
Pin-Priority: 900
|
||||||
|
EOF
|
||||||
|
|
||||||
|
cat << EOF > /etc/apt/preferences.d/cockpit
|
||||||
|
Package: cockpit*
|
||||||
|
Pin: release a=$(lsb_release -cs)-backports
|
||||||
|
Pin-Priority: 900
|
||||||
|
EOF
|
||||||
|
|
||||||
apt update
|
apt update
|
||||||
|
|
||||||
DEBIAN_FRONTEND=noninteractive DEBIAN_PRIORITY=critical apt install -y -o DPkg::options::="--force-confdef" -o DPkg::options::="--force-confold" acl samba samba-dsdb-modules samba-vfs-modules wsdd
|
DEBIAN_FRONTEND=noninteractive DEBIAN_PRIORITY=critical apt install -y -o DPkg::options::="--force-confdef" -o DPkg::options::="--force-confold" -t $(lsb_release -cs)-backports acl samba samba-common samba-common-bin samba-dsdb-modules samba-vfs-modules samba-libs libwbclient0 winbind wsdd
|
||||||
DEBIAN_FRONTEND=noninteractive DEBIAN_PRIORITY=critical apt install -y -o DPkg::options::="--force-confdef" -o DPkg::options::="--force-confold" --no-install-recommends -t $(lsb_release -cs)-backports cockpit
|
DEBIAN_FRONTEND=noninteractive DEBIAN_PRIORITY=critical apt install -y -o DPkg::options::="--force-confdef" -o DPkg::options::="--force-confold" --no-install-recommends cockpit cockpit-identities cockpit-file-sharing cockpit-navigator
|
||||||
|
|
||||||
mkdir /usr/share/cockpit/smb
|
|
||||||
wget https://raw.githubusercontent.com/enira/cockpit-smb-plugin/master/index.html -O /usr/share/cockpit/smb/index.html
|
|
||||||
wget https://raw.githubusercontent.com/enira/cockpit-smb-plugin/master/manifest.json -O /usr/share/cockpit/smb/manifest.json
|
|
||||||
wget https://raw.githubusercontent.com/enira/cockpit-smb-plugin/master/smb.js -O /usr/share/cockpit/smb/smb.js
|
|
||||||
|
|
||||||
USER=$(echo "$ZMB_ADMIN_USER" | awk '{print tolower($0)}')
|
USER=$(echo "$ZMB_ADMIN_USER" | awk '{print tolower($0)}')
|
||||||
useradd --comment "Zamba fileserver admin" --create-home --shell /bin/bash $USER
|
useradd --comment "Zamba fileserver admin" --create-home --shell /bin/bash $USER
|
||||||
@ -30,23 +45,52 @@ echo "$USER:$ZMB_ADMIN_PASS" | chpasswd
|
|||||||
smbpasswd -x $USER
|
smbpasswd -x $USER
|
||||||
(echo $ZMB_ADMIN_PASS; echo $ZMB_ADMIN_PASS) | smbpasswd -a $USER
|
(echo $ZMB_ADMIN_PASS; echo $ZMB_ADMIN_PASS) | smbpasswd -a $USER
|
||||||
|
|
||||||
cat << EOF >> /etc/samba/smb.conf
|
usermod -aG sudo $USER
|
||||||
[$ZMB_SHARE]
|
|
||||||
comment = Main Share
|
cat << EOF | sudo tee -i /etc/samba/smb.conf
|
||||||
path = /$LXC_SHAREFS_MOUNTPOINT/$ZMB_SHARE
|
[global]
|
||||||
read only = No
|
include = registry
|
||||||
vfs objects = shadow_copy2
|
EOF
|
||||||
create mask = 0660
|
|
||||||
directory mask = 0770
|
cat << EOF | sudo tee -i /etc/samba/import.template
|
||||||
|
[global]
|
||||||
|
workgroup = WORKGROUP
|
||||||
|
log file = /var/log/samba/log.%m
|
||||||
|
max log size = 1000
|
||||||
|
logging = file
|
||||||
|
panic action = /usr/share/samba/panic-action %d
|
||||||
|
log level = 3
|
||||||
|
server role = standalone server
|
||||||
|
obey pam restrictions = yes
|
||||||
|
unix password sync = yes
|
||||||
|
passwd program = /usr/bin/passwd %u
|
||||||
|
passwd chat = *Enter\snew\s*\password:* %n\n *Retype\snew\s*\spassword:* %n\n *password\supdated\ssuccessfully* .
|
||||||
|
pam password change = yes
|
||||||
|
map to guest = bad user
|
||||||
|
vfs objects = shadow_copy2 acl_xattr catia fruit streams_xattr
|
||||||
|
map acl inherit = yes
|
||||||
|
acl_xattr:ignore system acls = yes
|
||||||
shadow: snapdir = .zfs/snapshot
|
shadow: snapdir = .zfs/snapshot
|
||||||
shadow: sort = desc
|
shadow: sort = desc
|
||||||
shadow: format = -%Y-%m-%d-%H%M
|
shadow: format = -%Y-%m-%d-%H%M
|
||||||
shadow: snapprefix = ^zfs-auto-snap_\(frequent\)\{0,1\}\(hourly\)\{0,1\}\(daily\)\{0,1\}\(weekly\)\{0,1\}\(monthly\)\{0,1\}\(backup\)\{0,1\}\(manual\)\{0,1\}
|
shadow: snapprefix = ^zfs-auto-snap_\(frequent\)\{0,1\}\(hourly\)\{0,1\}\(daily\)\{0,1\}\(weekly\)\{0,1\}\(monthly\)\{0,1\}
|
||||||
shadow: delimiter = -20
|
shadow: delimiter = -20
|
||||||
|
fruit:encoding = native
|
||||||
|
fruit:metadata = stream
|
||||||
|
fruit:zero_file_id = yes
|
||||||
|
fruit:nfs_aces = no
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
|
net conf import /etc/samba/import.template
|
||||||
|
|
||||||
mkdir -p /$LXC_SHAREFS_MOUNTPOINT/$ZMB_SHARE
|
mkdir -p /$LXC_SHAREFS_MOUNTPOINT/$ZMB_SHARE
|
||||||
chmod -R 770 /$LXC_SHAREFS_MOUNTPOINT/$ZMB_SHARE
|
chmod -R 770 /$LXC_SHAREFS_MOUNTPOINT/$ZMB_SHARE
|
||||||
chown -R $USER:root /$LXC_SHAREFS_MOUNTPOINT/$ZMB_SHARE
|
chown -R $USER:root /$LXC_SHAREFS_MOUNTPOINT/$ZMB_SHARE
|
||||||
|
|
||||||
|
net conf addshare $ZMB_SHARE /$LXC_SHAREFS_MOUNTPOINT/$ZMB_SHARE
|
||||||
|
net conf setparm $ZMB_SHARE readonly no
|
||||||
|
net conf setparm $ZMB_SHARE browseable yes
|
||||||
|
net conf setparm $ZMB_SHARE createmask 0660
|
||||||
|
net conf setparm $ZMB_SHARE directorymask 0770
|
||||||
|
|
||||||
systemctl restart smbd nmbd wsdd
|
systemctl restart smbd nmbd wsdd
|
||||||
|
Reference in New Issue
Block a user