Compare commits

...
Sign in to create a new pull request.

4 commits

Author SHA1 Message Date
hx
42ab30f6c5 Unnecessary dependency removed
Signed-off-by: hx <hx@noreply.localhost>
2025-04-17 00:39:47 +00:00
h@x
122a727699 fixed a typo 2024-12-17 22:33:01 +00:00
h@x
8f668b2249 Update README.md 2024-12-17 22:30:28 +00:00
h@x
3d5410fbc4 A lot if improvements 2024-12-15 23:45:12 +00:00
9 changed files with 565 additions and 253 deletions

View file

@ -1,2 +1,48 @@
# Pandabot
## Description
**Pandabot** is a flexible bot that offers various features such as database integration, file forwarding and interactivity with users via Telegram. With a customizable configuration and PostgreSQL support, the bot is ideal for automating file and communication processes.
---
### Requirements
- **PostgreSQL**: Installed and configured.
- **Apache Webserver**: For the integration (optional).
- **Telegram Account**
### Directory structure
- A download folder: `downloads` (relative to the bot's directory).
---
## Installation
1. **Clone repository**:
```bash
git clone https://git.n64.cc/hx/Pandabot.git
cd Pandabot
```
2. set up **database**:
- Create a PostgreSQL database with the default values from ``pandabot.conf`` or customize it.
3. install **dependencies** (if needed):
```bash
pip install -r requirements.txt
```
4. customize **configuration files**:
- Edit `pandabot.conf` and `channels.conf` to customize the settings accordingly (see below).
---
## Configuration files
### `pandabot.conf`
#### Important parameters
- **Botcommand**: Command for bot interactions. Default: `paul`.
- **DB connection**: Customize the following fields:
- `dbhost`: IP address of the database server (default: `127.0.0.1`).
- `dbport`: Port of the database (default: `5432`).

View file

@ -5,6 +5,6 @@
date_default_timezone_set('Europe/Berlin');
$date=gmdate("Y-m-d H:i:s", time()+date("Z"));
$sendMsg="<b>madeline as client registered </b>: ".$date."<br>";
$sendMsg="<b>Madeline as client has been registered </b>: ".$date."<br>";
$out=made("messages", "sendMessage", array("peer" => $globalsettings["bot"]["pandaownerid"], "message" => $sendMsg, "parse_mode" => "html"));
// print_r($out);

127
bot.sh
View file

@ -1,4 +1,129 @@
#!/bin/bash
#!/bin#!/bin/bash
# Get the current timestamp for logging or unique identifier
startDate=$(date "+%Y%m%d%H%M%S")
# Log file for all actions
log_file="/var/log/pandabot.log"
# Function to log messages to both console and log file with timestamp
log_message() {
local message=$1
local timestamp=$(date '+%Y-%m-%d %H:%M:%S')
# Log to console
echo "$timestamp - $message"
# Log to file
echo "$timestamp - $message" >> "$log_file"
}
# Source external bot configuration and utility functions
. inc/sh/inc.bot.sh
# Define various bot service paths and session files
bot_root=$(pwd)
bot_pid="${bot_root}/log/tmp/pandabot.pid"
madeline_session="${bot_root}/session.madeline"
madeline_pid=$(ps -ef | grep "${madeline_session}" | grep -v grep | awk '{print $2}')
apache_pid="${bot_root}/log/tmp/httpd.pid"
fpm_pid="${bot_root}/log/tmp/php-fpm.pid"
# Configuration file for bot and services
pandabotconf="${bot_root}/conf/pandabot.conf"
services="bot|web|apache|fpm|madeline|"
# Check if pandabot.conf exists before attempting to read
if [ ! -f "$pandabotconf" ]; then
log_message "ERROR: pandabot.conf not found at $pandabotconf"
exit 2
fi
# Get the wait timer from the configuration file
waittimer=$(getpandabotconf "${pandabotconf}" "botsh_restart_wait_timer")
if [ $? -ne 0 ]; then
log_message "ERROR: botsh_restart_wait_timer not configured @ ${pandabotconf}"
exit 2
fi
# Check if madeline session file exists before trying to use it
if [ ! -f "$madeline_session" ]; then
log_message "ERROR: Madeline session file not found at $madeline_session"
exit 2
fi
# Ensure that at least one argument is provided
if [ $# -eq 0 ]; then
bot_sh_usage
exit 1
fi
# Process command line arguments and options
OPTIND=2
while getopts "s:" arg; do
case "${arg}" in
s) service=${OPTARG} ;; # Set the service if -s option is used
esac
done
# Check if the specified service is valid
if [ ! -z "${service}" ]; then
out=$(checkservice "${service}" "${services}")
if [ $? -ne 0 ]; then
log_message "ERROR: Service '${service}' not found in the list: ${services}"
bot_sh_usage
exit 4
fi
else
service="all" # Default to all services if no specific service is given
fi
# Main logic for managing services based on the command
case "$1" in
"start")
start_service "${service}"
log_message "Started service: ${service}"
;;
"stop")
stop_service "${service}"
log_message "Stopped service: ${service}"
;;
"restart")
stop_service "${service}"
log_message "Stopped service: ${service}"
echo "Wait ${waittimer} seconds"
# Validate waittimer (ensure it's a positive integer)
if ! [[ "${waittimer}" =~ ^[0-9]+$ ]] || [ "${waittimer}" -le 0 ]; then
log_message "ERROR: Invalid waittimer value in ${pandabotconf}. Must be a positive integer."
exit 3
fi
sleep "${waittimer}"
start_service "${service}"
log_message "Restarted service: ${service}"
;;
"setuptg")
echo "Setting up TG for service: ${service}"
log_message "Setting up TG for service: ${service}"
bin/setuptg.php
;;
"status")
status_service "${service}"
log_message "Checked status of service: ${service}"
;;
*)
# Default case: show usage if no valid argument is given
bot_sh_usage
log_message "ERROR: Invalid argument provided"
;;
esac
/bash
startDate=`date "+%Y%m%d%H%M%S"`;
. inc/sh/inc.bot.sh

View file

@ -1,8 +1,8 @@
# attention: bot rewrite hes own conf file in human readable form
# all "to:" channels automatical r mode and will be readed
# all channels without "to:" will be still readed and saved in database
# from and section names must be unique, otherwise, the last find will be used
# example section config:
# Attention: bot rewrite hes own conf file in human readable form
# All "to:" channels automatical r mode and will be read.
# All channels without "to:" will be still read and saved in the database
# From and section names must be unique, otherwise, the last find will be used
# Example section config:
# -----------------------
#
# '<unique name>':

View file

@ -1,183 +1,247 @@
# Check if process ID is valid
function checkpid() {
if [ -f ${1} ]; then
out=`cat ${1}`
[ -z "`ps -ef | awk -v pid=${out} '{if ($2 == pid) {print $2}}'`" ] && exit 1
if [ -f "$1" ]; then
out=$(cat "$1")
if [ -z "$(ps -ef | awk -v pid="$out" '{if ($2 == pid) {print $2}}')" ]; then
exit 1
fi
else
exit 1
fi
echo "${out}"
echo "$out"
}
# Kill a service
function kill_service() {
if [ ${1} -ne 0 ]; then
echo "${2} not running"
if [ "$1" -ne 0 ]; then
echo "$2 not running"
else
kill ${4} ${3} > /dev/null 2>&1
kill "$4" "$3" > /dev/null 2>&1
fi
}
# Remove Apache built-in modules
function removeapachebuildinmodules() {
${2} -l | grep -v "Compiled in modules" | sed "s|\.c$|.so|g" | while read -r line; do
sed -i "/^LoadModule.*\/${line}$/d" ${1}
"$2" -l | grep -v "Compiled in modules" | sed "s|\.c$|.so|g" | while read -r line; do
sed -i "/^LoadModule.*\/${line}$/d" "$1"
done
}
# Get PandaBot configuration from YAML
function getpandabotconf() {
out=`echo "${1}@@${2}" | php -R '$in=explode("@@", $argn); if (array_key_exists($in[1], yaml_parse_file($in[0]))) { echo yaml_parse_file($in[0])[$in[1]];} else exit(1);'`
[ $? -ne 0 ] && exit 1
echo "${out}"
out=$(echo "$1@@$2" | php -R '
$in=explode("@@", $argn);
$config = yaml_parse_file($in[0]);
if (array_key_exists($in[1], $config)) {
echo $config[$in[1]];
} else {
exit(1);
}
')
if [ $? -ne 0 ]; then
exit 1
fi
echo "$out"
}
# Get the path of the HTTP daemon (httpd or apache2)
function httpdbin() {
out=`which httpd 2> /dev/null`
out=$(which httpd 2> /dev/null)
if [ $? -ne 0 ]; then
out=`which apache2 2> /dev/null`
out=$(which apache2 2> /dev/null)
if [ $? -ne 0 ]; then
exit 1
fi
fi
echo "${out}"
echo "$out"
}
# Find PHP-FPM binary
function phpfpmbin() {
out=`find /usr/sbin/ -name php-fpm* 2> /dev/null | head -1`
[ -z "${out}" ] && exit 1
echo "${out}"
out=$(find /usr/sbin/ -name php-fpm* 2> /dev/null | head -1)
if [ -z "$out" ]; then
exit 1
fi
echo "$out"
}
# Find Apache mod_mpm_event.so path
function apachemod() {
out=`find /usr -name "mod_mpm_event.so" 2> /dev/null | awk -F / '{for (i=1;i<NF;i++) {printf ("%s/",$i)}}'`
[ -z "${out}" ] && exit 1
echo "${out}"
out=$(find /usr -name "mod_mpm_event.so" 2> /dev/null | awk -F / '{for (i=1;i<NF;i++) {printf ("%s/",$i)}}')
if [ -z "$out" ]; then
exit 1
fi
echo "$out"
}
# Check if the service is running
function checkservice() {
out=`echo "${2}" | while read -d "|" arg; do
[ "${arg}" = "${1}" ] && echo "${1}" && break
done`
[ -z "${out}" ] && echo "${1}" && exit 1
echo "${out}"
out=$(echo "$2" | while read -d "|" arg; do
if [ "$arg" = "$1" ]; then
echo "$1"
break
fi
done)
if [ -z "$out" ]; then
echo "$1"
exit 1
fi
echo "$out"
}
# Prepare web server environment variables
function prepare_web() {
apache_serverroot=${bot_root}
apache_start=`getpandabotconf "${pandabotconf}" "apache_start"`
[ $? -ne 0 ] && echo "ERR: apache_start not configured @ ${pandabotconf}" && exit 1
apache_serverroot="$bot_root"
apache_start=$(getpandabotconf "$pandabotconf" "apache_start")
[ "${apache_start}" != "1" ] && echo "apache_start is not set yes @ ${pandabotconf}" && exit 1
if [ $? -ne 0 ]; then
echo "ERR: apache_start not configured @ $pandabotconf"
exit 1
fi
if [ `id -u` -eq 0 ]; then
if [ "$apache_start" != "1" ]; then
echo "apache_start is not set yes @ $pandabotconf"
exit 1
fi
if [ "$(id -u)" -eq 0 ]; then
apache_user="nobody"
apache_group="nobody"
else
apache_user=`id -un`
apache_group=`id -gn`
fi # if [ `id -u` -eq 0 ]; then
apache_user=$(id -un)
apache_group=$(id -gn)
fi
apache_port=`getpandabotconf "${pandabotconf}" "apache_port"`
[ $? -ne 0 ] && echo "ERR: apache_port not configured @ ${pandabotconf}" && exit 1
[ ${apache_port} -lt 1025 ] && echo "ERR: apache_port must be greater than 1024 @ ${pandabotconf}" && exit 1
apache_port=$(getpandabotconf "$pandabotconf" "apache_port")
if [ $? -ne 0 ]; then
echo "ERR: apache_port not configured @ $pandabotconf"
exit 1
fi
if [ "$apache_port" -lt 1025 ]; then
echo "ERR: apache_port must be greater than 1024 @ $pandabotconf"
exit 1
fi
}
# Start PHP-FPM service
function start_fpm() {
prepare_web
php_fpm_bin=`phpfpmbin`
[ $? -ne 0 ] && echo "ERR: php-fpm installation not found" && exit 1
php_fpm_bin=$(phpfpmbin)
cat ${apache_serverroot}/conf/templates/template.php-fpm.conf \
| sed "s|@@apache_serverroot@@|${apache_serverroot}|g" \
| sed "s|@@apache_user@@|${apache_user}|g" \
| sed "s|@@apache_group@@|${apache_group}|g" \
| sed "s|@@apache_port@@|${apache_port}|g" \
> ${apache_serverroot}/conf/php-fpm.conf
if [ $? -ne 0 ]; then
echo "ERR: php-fpm installation not found"
exit 1
fi
${php_fpm_bin} -y ${apache_serverroot}/conf/php-fpm.conf 2> /dev/null
cat "${apache_serverroot}/conf/templates/template.php-fpm.conf" | \
sed "s|@@apache_serverroot@@|$apache_serverroot|g" \
| sed "s|@@apache_user@@|$apache_user|g" \
| sed "s|@@apache_group@@|$apache_group|g" \
| sed "s|@@apache_port@@|$apache_port|g" \
> "${apache_serverroot}/conf/php-fpm.conf"
"$php_fpm_bin" -y "${apache_serverroot}/conf/php-fpm.conf" 2> /dev/null
if [ $? -ne 0 ]; then
echo "php-fpm already running"
out=`checkpid "${fpm_pid}"`
kill ${out} > /dev/null 2>&1
${php_fpm_bin} -y ${apache_serverroot}/conf/php-fpm.conf 2> /dev/null
out=$(checkpid "$fpm_pid")
kill "$out" > /dev/null 2>&1
"$php_fpm_bin" -y "${apache_serverroot}/conf/php-fpm.conf" 2> /dev/null
echo "php-fpm restarted"
else
echo "php-fpm started"
fi # if [ $? -ne 0 ]; then
fi
}
# Start Apache service
function start_apache() {
prepare_web
apachebin=`httpdbin`
[ $? -ne 0 ] && echo "ERR: apache installation not found" && exit 1
apachebin=$(httpdbin)
apache_modules=`apachemod`
[ $? -ne 0 ] && echo "ERR: no apache modules pfad found" && exit 1
if [ $? -ne 0 ]; then
echo "ERR: apache installation not found"
exit 1
fi
rm -rf ${apache_serverroot}/log/access_log > /dev/null 2>&1 # clear access_log file...
apache_modules=$(apachemod)
apache_pid=${apache_serverroot}/log/tmp/httpd.pid
if [ $? -ne 0 ]; then
echo "ERR: no apache modules path found"
exit 1
fi
rm -rf "${apache_serverroot}/log/access_log" > /dev/null 2>&1 # clear access_log file...
apache_pid="${apache_serverroot}/log/tmp/httpd.pid"
apache_documentroot="${apache_serverroot}/pb-web"
cat ${apache_serverroot}/conf/templates/template.httpd.conf \
| sed "s|@@apache_modules@@|${apache_modules}|g" \
| sed "s|@@apache_serverroot@@|${apache_serverroot}|g" \
| sed "s|@@apache_user@@|${apache_user}|g" \
| sed "s|@@apache_group@@|${apache_group}|g" \
| sed "s|@@apache_port@@|${apache_port}|g" \
| sed "s|@@apache_documentroot@@|${apache_documentroot}|g" \
| sed "s|@@apache_pid@@|${apache_pid}|g" \
> ${apache_serverroot}/conf/httpd.conf
cat "${apache_serverroot}/conf/templates/template.httpd.conf" | \
sed "s|@@apache_modules@@|$apache_modules|g" \
| sed "s|@@apache_serverroot@@|$apache_serverroot|g" \
| sed "s|@@apache_user@@|$apache_user|g" \
| sed "s|@@apache_group@@|$apache_group|g" \
| sed "s|@@apache_port@@|$apache_port|g" \
| sed "s|@@apache_documentroot@@|$apache_documentroot|g" \
| sed "s|@@apache_pid@@|$apache_pid|g" \
> "${apache_serverroot}/conf/httpd.conf"
removeapachebuildinmodules "${apache_serverroot}/conf/httpd.conf" "${apachebin}"
removeapachebuildinmodules "${apache_serverroot}/conf/httpd.conf" "$apachebin"
chmod -R a+rwx ${apache_documentroot} 2>&1 /dev/null
chmod -R a+rwx ${apache_serverroot}/log 2>&1 /dev/null
chmod -R a+rwx "$apache_documentroot" 2>&1 /dev/null
chmod -R a+rwx "${apache_serverroot}/log" 2>&1 /dev/null
${apachebin} -f ${apache_serverroot}/conf/httpd.conf -k restart > /dev/null 2>&1
"$apachebin" -f "${apache_serverroot}/conf/httpd.conf" -k restart > /dev/null 2>&1
if [ $? -eq 0 ]; then
echo "apache (re)started @ port: ${apache_port}"
echo "Apache (re)started @ port: $apache_port"
else
echo "ERR: apache not started, something is wrong..."
fi # if [ $? -eq 0 ]; then
echo "ERR: Apache not started, something is wrong..."
fi
}
# Start the bot
function start_bot() {
out=`checkpid "${bot_pid}"`
[ ! -z "${out}" ] && echo "bot already running, exit!" && exit 1
out=$(checkpid "$bot_pid")
if [ -n "$out" ]; then
echo "Bot already running, exit!"
exit 1
fi
cp conf/channels.conf log/conf/${startDate}_channels.conf
cp conf/pandabot.conf log/conf/${startDate}_pandabot.conf
cp conf/channels.conf "log/conf/${startDate}_channels.conf"
cp conf/pandabot.conf "log/conf/${startDate}_pandabot.conf"
ls -r1 log/*_pandabot.app.log | awk 'begin {c=0;} {c++; if (c>=10) {print $0}}' | xargs -n1 rm -f # logrotation? function?
ls -r1 log/conf/*pandabot.conf | awk 'begin {c=0;} {c++; if (c>=10) {print $0}}' | xargs -n1 rm -f
ls -r1 log/conf/*channels.conf | awk 'begin {c=0;} {c++; if (c>=10) {print $0}}' | xargs -n1 rm -f
# Clean up old log files
ls -r1 log/*_pandabot.app.log | awk 'NR >= 10' | xargs -n1 rm -f
ls -r1 log/conf/*pandabot.conf | awk 'NR >= 10' | xargs -n1 rm -f
ls -r1 log/conf/*channels.conf | awk 'NR >= 10' | xargs -n1 rm -f
if [ `id -u` -eq 0 ]; then
if [ "$(id -u)" -eq 0 ]; then
chown -R nobody *
su nobody -c "nohup bin/pandabot.php 2>&1 | tee log.pandabot.log 2>&1 | tee log/${startDate}_pandabot.app.log > /dev/null &"
if [ $? -ne 0 ]; then
echo "change user nobody from nologin to bash"
echo "Change user nobody from nologin to bash"
usermod -s /usr/bin/bash nobody
su nobody -c "nohup bin/pandabot.php 2>&1 | tee log.pandabot.log 2>&1 | tee log/${startDate}_pandabot.app.log > /dev/null &"
[ $? -ne 0 ] && "ERR: change user nobody manually from /sbin/nologin to /bin/bash @ /etc/passwd, or start bot in usercontext" && exit 1
fi # if [ $? -ne 0 ]; then
if [ $? -ne 0 ]; then
echo "ERR: Change user nobody manually from /sbin/nologin to /bin/bash @ /etc/passwd, or start bot in user context"
exit 1
fi
fi
else
nohup bin/pandabot.php 2>&1 | tee log.pandabot.log 2>&1 | tee log/${startDate}_pandabot.app.log > /dev/null &
fi # if [ `id -u` -eq 0 ]; then
fi
}
# Start a specific service
function start_service() {
echo "start ${1}"
case "${1}" in
"bot")
start_bot
;;
echo "Start $1"
case "$1" in
"bot") start_bot ;;
"apache")
start_apache
sleep 2
status_service "${1}"
;;
"fpm")
start_fpm
status_service "apache"
;;
"fpm") start_fpm ;;
"web")
start_service "apache"
start_service "fpm"
@ -189,23 +253,24 @@ function start_service() {
esac
}
# Stop a specific service
function stop_service() {
echo "stop ${1}"
case "${1}" in
echo "Stop $1"
case "$1" in
"bot")
out=`checkpid "${bot_pid}"`
kill_service "${?}" "${1}" "${out}" "-9"
out=$(checkpid "$bot_pid")
kill_service "$?" "$1" "$out" "-9"
;;
"apache")
out=`checkpid "${apache_pid}"`
kill_service "${?}" "${1}" "${out}" ""
out=$(checkpid "$apache_pid")
kill_service "$?" "$1" "$out" ""
;;
"fpm")
out=`checkpid "${fpm_pid}"`
kill_service "${?}" "${1}" "${out}" ""
out=$(checkpid "$fpm_pid")
kill_service "$?" "$1" "$out" ""
;;
"madeline")
kill_service "0" "${1}" "${madeline_pid}" "-9"
kill_service "0" "$1" "$madeline_pid" "-9"
;;
"web")
stop_service "apache"
@ -219,36 +284,49 @@ function stop_service() {
esac
}
status_service() {
case "${1}" in
# Get the status of a service
function status_service() {
case "$1" in
"bot")
out=`checkpid "${bot_pid}"`
if [ ${?} -eq 0 ]; then echo "${1} running"; else echo "${1} not running"; fi
out=$(checkpid "$bot_pid")
if [ $? -eq 0 ]; then
echo "$1 running"
else
echo "$1 not running"
fi
;;
"apache")
out=`checkpid "${apache_pid}"`
if [ ${?} -eq 0 ]; then
apache_ip_running=`ip -br address | grep -iwv lo | awk '{print $3}' | awk -F / '{print $1}'`
apache_port=`getpandabotconf "${pandabotconf}" "apache_port"`
echo "${1} running on: http://${apache_ip_running}:${apache_port}/";
out=$(checkpid "$apache_pid")
if [ $? -eq 0 ]; then
apache_ip_running=$(ip -br address | grep -iwv lo | awk '{print $3}' | awk -F / '{print $1}')
apache_port=$(getpandabotconf "$pandabotconf" "apache_port")
echo "$1 running on: http://$apache_ip_running:$apache_port/"
else
echo "${1} not running"
echo "$1 not running"
fi
;;
"fpm")
out=`checkpid "${fpm_pid}"`
if [ ${?} -eq 0 ]; then echo "${1} running"; else echo "${1} not running"; fi
out=$(checkpid "$fpm_pid")
if [ $? -eq 0 ]; then
echo "$1 running"
else
echo "$1 not running"
fi
;;
"madeline") ## grummel
if [ ${?} -eq 0 ]; then echo "${1} running"; else echo "${1} not running"; fi
"madeline")
if [ $? -eq 0 ]; then
echo "$1 running"
else
echo "$1 not running"
fi
;;
"web")
echo "status ${1}"
echo "Status $1"
status_service "apache"
status_service "fpm"
;;
"all")
echo "status ${1}"
echo "Status $1"
status_service "web"
status_service "bot"
status_service "madeline"
@ -256,8 +334,9 @@ status_service() {
esac
}
# Bot script usage guide
function bot_sh_usage() {
echo "usage:
echo "Usage:
./bot.sh start
./bot.sh stop
./bot.sh restart
@ -269,7 +348,7 @@ echo "usage:
./bot.sh stop -s [bot|web]
./bot.sh restart -s [bot|web]
./bot.sh status -s [bot|web]
eg.
Example:
./bot.sh restart -s bot
./bot.sh restart -s web
"

View file

@ -2,7 +2,7 @@
<html>
<head>
<meta charset="UTF-8"/>
<title>pandabot</title>
<title>Pandabot</title>
<link rel="icon" href="img/pb-favicon.jpg">
<link rel="stylesheet" href="css/jquery-ui.css">
<link rel="stylesheet" href="css/pandabot.css">

View file

@ -1,32 +0,0 @@
[ `id -u` -ne 0 ] && echo "ERR: must be run as: root" && exit 1
[ ! -f /etc/centos-release ] && echo "ERR: works only on centos" && exit 1
dnf install https://dl.fedoraproject.org/pub/epel/epel-release-latest-9.noarch.rpm -y
dnf install https://rpms.remirepo.net/enterprise/remi-release-9.rpm -y
dnf module install php:remi-8.3 -y
yum install net-tools postgresql postgresql-server httpd php-fpm -y
yum install php-pecl-yaml php-pgsql php-pdo -y
/usr/bin/postgresql-setup --initdb
cd /var/lib/pgsql/data
cat pg_hba.conf | sed 's|host all all 127.0.0.1/32 ident|host all all 0.0.0.0/0 trust|g' > pg_hba.conf1
cp pg_hba.conf1 pg_hba.conf
rm -rf pg_hba.conf1
systemctl restart postgresql
su - postgres -c 'echo "CREATE DATABASE pandabot;" | psql'
printf "\n------------------------- --- -- - -\n"
echo "edit conf/pandabot.conf && conf/channels.conf"
echo "dbname: pandabot"
echo "dbhost: `ip -br address | grep -iwv lo | awk '{print $3}' | awk -F / '{print $1}'`"
echo "dbport: 5432"
echo "dbuser: postgres"
echo "dbpass: false"
printf "\n"
echo "setup tg session with ./bot.sh setuptg"
echo "start bot with ./bot.sh start"
echo "stop bot with ./bot.sh stop"
echo "------------------------- --- -- - -"

View file

@ -0,0 +1,94 @@
#!/bin/bash
# Ensure the script is run as root
[ "$(id -u)" -ne 0 ] && echo "ERR: must be run as: root" && exit 1
# Detect the operating system
OS=$(cat /etc/*release | grep -i "centos\|debian" | head -n 1 | awk -F= '{print $2}' | tr -d '[:space:]')
if [[ "$OS" =~ "CentOS" ]]; then
PACKAGE_MANAGER="dnf"
REPO_INSTALL_CMD="dnf install"
PHP_INSTALL_CMD="dnf module install php:remi-8.3 -y"
elif [[ "$OS" =~ "Debian" ]]; then
PACKAGE_MANAGER="apt"
REPO_INSTALL_CMD="apt-get install"
PHP_INSTALL_CMD="apt-get install php php-cli php-fpm php-pgsql php-yaml php-pdo -y"
else
echo "ERR: Unsupported OS, must be CentOS or Debian."
exit 1
fi
# Install necessary repositories for CentOS or Debian
if [[ "$OS" =~ "CentOS" ]]; then
$REPO_INSTALL_CMD https://dl.fedoraproject.org/pub/epel/epel-release-latest-9.noarch.rpm -y
$REPO_INSTALL_CMD https://rpms.remirepo.net/enterprise/remi-release-9.rpm -y
$PHP_INSTALL_CMD
elif [[ "$OS" =~ "Debian" ]]; then
$REPO_INSTALL_CMD lsb-release wget curl -y
# PHP installation is already included in the above command
fi
# Install required packages (PostgreSQL, Apache, PHP, and utilities)
$REPO_INSTALL_CMD net-tools postgresql postgresql-server httpd php-fpm -y
$REPO_INSTALL_CMD php-pecl-yaml php-pgsql php-pdo -y
# Setup PostgreSQL
if [[ "$OS" =~ "CentOS" ]]; then
/usr/bin/postgresql-setup --initdb
systemctl enable postgresql
systemctl start postgresql
elif [[ "$OS" =~ "Debian" ]]; then
service postgresql start
fi
# Configure PostgreSQL to allow external connections securely
cd /var/lib/pgsql/data || exit
cp pg_hba.conf pg_hba.conf.backup
# Allow connections from any IP (recommended to restrict IP range later)
sed -i 's|host all all 127.0.0.1/32 ident|host all all 0.0.0.0/0 md5|g' pg_hba.conf
# Restart PostgreSQL to apply changes
systemctl restart postgresql
# Create the Pandabot database
su - postgres -c 'psql -c "CREATE DATABASE pandabot;"'
# Display configuration instructions
echo -e "\n------------------------- --- -- - -"
echo "Edit conf/pandabot.conf and conf/channels.conf"
echo "Database settings:"
echo "dbname: pandabot"
echo "dbhost: $(hostname -I | awk '{print $1}')"
echo "dbport: 5432"
echo "dbuser: postgres"
echo "dbpass: <set_your_password_here>"
echo -e "\nTo setup the Telegram session, run: ./bot.sh setuptg"
echo "To start the bot, run: ./bot.sh start"
echo "To stop the bot, run: ./bot.sh stop"
echo -e "------------------------- --- -- - -\n"
# Check if firewall is enabled and add necessary rules for PostgreSQL and Apache
if systemctl is-active --quiet firewalld; then
echo "Configuring firewall for PostgreSQL (5432) and HTTP (80/443)"
firewall-cmd --zone=public --add-port=5432/tcp --permanent
firewall-cmd --zone=public --add-service=http --permanent
firewall-cmd --reload
elif ufw status | grep -q "active"; then
echo "Configuring UFW for PostgreSQL (5432) and HTTP (80/443)"
ufw allow 5432/tcp
ufw allow http
ufw allow https
ufw reload
fi
# SELinux setup for CentOS (optional step, recommended to allow postgresql and httpd)
if [[ "$OS" =~ "CentOS" ]]; then
echo "Setting up SELinux to allow PostgreSQL and Apache to work together"
setsebool -P httpd_can_network_connect_db 1
setsebool -P httpd_can_network_connect 1
fi
echo "Installation and setup complete."