forked from SimplesIP/docker-pabx-app
rodgger
7 months ago
15 changed files with 1291 additions and 0 deletions
@ -0,0 +1,89 @@
|
||||
|
||||
|
||||
# Configuração do PABX versão 1.8 no docker |
||||
|
||||
Inicie a aplicação PABX de maneira fácil e sincronizada. |
||||
|
||||
## Preparando o ambiente no Windows |
||||
|
||||
### Configurando o WSL |
||||
|
||||
- Certifique-se de que o WSL2 está instalado no Windows. Caso não esteja, siga a documentação para realizar a instalação: [Instalação do WSL2](https://learn.microsoft.com/pt-br/windows/wsl/install). |
||||
|
||||
Após a instalação do WSL2, instale uma distribuição Linux. |
||||
|
||||
* Recomendamos a utilização do Debian. Para isso, execute o seguinte comando no PowerShell: |
||||
```bash |
||||
wsl --install -d Debian |
||||
``` |
||||
|
||||
* Em seguida, digite o seguinte comando no PowerShell para entrar em uma instância do Debian: |
||||
```bash |
||||
wsl -d Debian |
||||
``` |
||||
### Desabilite o Firewall e o Defender do Windows |
||||
Para conseguir realizar o download de alguns repositórios. |
||||
|
||||
|
||||
|
||||
## Clonando o repositório |
||||
|
||||
* Clone o projeto: docker-pabx-app. |
||||
```bash |
||||
git clone http://192.168.115.233:3000/SimplesIP/docker-pabx-app.git |
||||
``` |
||||
|
||||
## Deploy |
||||
|
||||
* Entre no diretório que contém os arquivos de inicialização do container. |
||||
```bash |
||||
cd docker-pabx-app/debian |
||||
``` |
||||
|
||||
Crie uma cópia do arquivo 'env-example' com o nome de '.env'. |
||||
```bash |
||||
cp env-example .env |
||||
``` |
||||
|
||||
Defina as variáveis dentro do arquivo .env: |
||||
- pasta_do_projeto - a pasta onde se encontra o projeto PABX. |
||||
- pasta_do_postgresql11 - onde deverá sincronizar o banco de dados. |
||||
- postgresql_version - por agora, não deve mudar o valor. |
||||
|
||||
### Execute o container com o docker-compose: |
||||
```bash |
||||
sudo docker-compose up -d |
||||
``` |
||||
Esse comando tentará compilar e levantar container. |
||||
|
||||
## FAQ |
||||
|
||||
|
||||
* ### Para que serve o arquivo `.env` ? |
||||
|
||||
Serve para definir variáveis a serem usadas no compose. Leia o arquivo '.env-example' para mais informações. |
||||
|
||||
* ### Quais arquivos estão sicronizados ? |
||||
|
||||
Grande parte dos arquivos do projeto estão sincronizados, porém existe os arquivos que não estão sincronizados. Os arquivos não sincronizados serão apagados quando seu container for encerrado e reescritos pelos arquivos da imagem quando o container for iniciado. |
||||
|
||||
Não sincronizados: |
||||
- `/etc/init.d/cnvrtd` - sem sincronização no arquivo |
||||
|
||||
Sincronizados: |
||||
- `/var/lib/postgresql/data` - Sincronizado os arquivo do banco de dados |
||||
- `/var/www/html/aplicativo` - Sincronizado |
||||
- `/var/www/html/include` - sincronizado |
||||
- `/hdaux/utilitarios/scripts` - sincronizado |
||||
|
||||
Obs: |
||||
- `/projeto/base` será replicado no container postgres `/base` para poder puxar o banco de dados. |
||||
|
||||
|
||||
* ### Qual as portas ? |
||||
|
||||
- `8080` - apache (web) |
||||
- `5432` - postgresql |
||||
|
||||
* ### Se o pabx criar arquivos que não estão no projeto gitea? |
||||
Coloque em `.gitignore` e mande a correção. |
@ -0,0 +1,62 @@
|
||||
version: '3.7' |
||||
networks: |
||||
working: |
||||
driver: bridge |
||||
services: |
||||
postgres: |
||||
build: |
||||
context: postgres-13 |
||||
args: |
||||
# definir o id do usuário para ter acesso ao volume |
||||
- ID_USER_VOLUME=${id_user} |
||||
container_name: v0.1-monitor-postgres13 |
||||
restart: always |
||||
environment: |
||||
# Obter as informacoes que o docker criara por default |
||||
- POSTGRES_USER=contacte |
||||
- POSTGRES_PASSWORD=ctepgSQL |
||||
- POSTGRES_DB=pbx |
||||
# Variavel de ambiente do container para manter setado usuario, banco de dados e senha |
||||
# Isso nao sera necessario definir em psql |
||||
- PGUSER=contacte |
||||
- PGPASSWORD=ctepgSQL |
||||
- PGDATABASE=pbx |
||||
ports: |
||||
- 5432:5432 |
||||
networks: |
||||
- working |
||||
volumes: |
||||
# copiar a pasta /projeto/base do pabx |
||||
- ${pasta_do_projeto}/projeto/base:/base |
||||
# copiar a pasta /var/lib/pgsql/data |
||||
- ${pasta_do_postgresql}:/var/lib/postgresql/data |
||||
aplicativo: |
||||
build: |
||||
context: pabx |
||||
args: |
||||
# usar para compilar dockerfile |
||||
# DB_HOST DB_PORT DB_BASE - necessário para colocar no crontab |
||||
# environment compose é para depois do dockerfile |
||||
- DB_HOST=postgres |
||||
- DB_PORT=5432 |
||||
- DB_BASE=pbx |
||||
- ID_USER_VOLUME=${id_user} |
||||
restart: always |
||||
container_name: v0.1-monitor |
||||
working_dir: /var/www/html/ |
||||
ports: |
||||
- 8080:80 |
||||
privileged: true |
||||
depends_on: |
||||
- postgres |
||||
networks: |
||||
- working |
||||
links: |
||||
- postgres |
||||
volumes: |
||||
- ${pasta_do_projeto}:/var/www/html/aplicativo |
||||
- ${pasta_do_projeto}/include:/var/www/html/include |
||||
- ${pasta_do_projeto}/asterisk/hdaux_utilitarios_scripts/:/hdaux/utilitarios/scripts |
||||
volumes: |
||||
storage: |
||||
db: |
@ -0,0 +1,22 @@
|
||||
|
||||
|
||||
# Pasta aonde está o projeto pabx para ser sincronizado no container |
||||
# |
||||
# Exemplo: |
||||
#pasta_do_projeto=/home/user/source_pabx |
||||
#pasta_do_projeto=c://Usuario/User/source_pabx |
||||
pasta_do_projeto="" |
||||
|
||||
|
||||
# Pasta do host para sincronizar a pasta /var/lib/pgsql/data (versão 13) |
||||
# Isso será usada para manter o banco de dados caso queira levantar |
||||
# outra instância. |
||||
# |
||||
# Essa pasta pode ser enviado ao repositório caso queira compartilhar |
||||
# o banco |
||||
pasta_do_postgresql="" |
||||
|
||||
|
||||
|
||||
|
||||
|
@ -0,0 +1,148 @@
|
||||
#!/bin/bash |
||||
|
||||
set -ex |
||||
|
||||
/usr/sbin/groupadd "pbx" |
||||
# Este é o id do usuário para fora do container ter acesso |
||||
/usr/sbin/useradd -u $1 -s "/usr/bin/bash" -d '/var/lib/asterisk/' 'pbx' -g 'pbx' |
||||
|
||||
/usr/sbin/groupadd "simples" |
||||
/usr/sbin/useradd -s "/usr/bin/bash" -m 'simples' -g 'simples' |
||||
|
||||
|
||||
|
||||
apt-get -y update |
||||
|
||||
apt-get install lsb-release apt-transport-https ca-certificates software-properties-common -y |
||||
apt-get install wget |
||||
|
||||
wget -O /etc/apt/trusted.gpg.d/php.gpg https://packages.sury.org/php/apt.gpg |
||||
sh -c 'echo "deb https://packages.sury.org/php/ $(lsb_release -sc) main" > /etc/apt/sources.list.d/php.list' |
||||
|
||||
apt-get -y update |
||||
|
||||
|
||||
apt-get install -y \ |
||||
supervisor \ |
||||
cron \ |
||||
curl \ |
||||
daemon \ |
||||
libcurl4-openssl-dev \ |
||||
libncurses-dev \ |
||||
libssl-dev \ |
||||
tar \ |
||||
curl \ |
||||
bison \ |
||||
git \ |
||||
vim \ |
||||
apache2 \ |
||||
libjansson-dev \ |
||||
ffmpeg \ |
||||
build-essential \ |
||||
libedit-dev \ |
||||
libsqlite3-dev \ |
||||
uuid-dev \ |
||||
libxml2-dev \ |
||||
libspeex-dev \ |
||||
libspeexdsp-dev \ |
||||
libogg-dev \ |
||||
libvorbis-dev \ |
||||
libasound2-dev \ |
||||
libcurl4-openssl-dev \ |
||||
xmlstarlet \ |
||||
flex \ |
||||
libpq-dev \ |
||||
unixodbc-dev \ |
||||
libneon27-dev \ |
||||
libgmime-3.0-dev \ |
||||
liblua5.2-dev \ |
||||
liburiparser-dev \ |
||||
libxslt1-dev \ |
||||
libssl-dev \ |
||||
libmariadb-dev-compat \ |
||||
libmariadb-dev \ |
||||
libbluetooth-dev \ |
||||
libradcli-dev \ |
||||
freetds-dev \ |
||||
libosptk-dev \ |
||||
libjack-jackd2-dev \ |
||||
libcap-dev \ |
||||
libsnmp-dev \ |
||||
libiksemel-dev \ |
||||
libcorosync-common-dev \ |
||||
libcpg-dev \ |
||||
libcfg-dev \ |
||||
libnewt-dev \ |
||||
libpopt-dev \ |
||||
libical-dev \ |
||||
libspandsp-dev \ |
||||
libresample1-dev \ |
||||
libc-client2007e-dev \ |
||||
binutils-dev \ |
||||
libsrtp2-dev \ |
||||
libgsm1-dev \ |
||||
graphviz \ |
||||
sudo \ |
||||
zlib1g-dev \ |
||||
libldap2-dev \ |
||||
bzip2 \ |
||||
patch \ |
||||
php8.2 \ |
||||
php8.2-cli \ |
||||
php8.2-common \ |
||||
php8.2-dev \ |
||||
php8.2-gd \ |
||||
php8.2-mbstring \ |
||||
php8.2-mysql \ |
||||
php8.2-common \ |
||||
php8.2-snmp \ |
||||
php8.2-soap \ |
||||
php8.2-xml \ |
||||
php8.2-xmlrpc \ |
||||
php8.2-pgsql \ |
||||
php8.2-curl |
||||
|
||||
apt-get clean |
||||
apt-get autoremove -y |
||||
|
||||
mkdir /var/log/asterisk/ |
||||
chown -R pbx:pbx /var/log/asterisk/ |
||||
|
||||
|
||||
|
||||
### CONFIGURANDO O PHP ### |
||||
sed -i 's/^error_reporting = .*/error_reporting = E_ALL | E_STRICT/g' /etc/php/8.2/cli/php.ini |
||||
sed -i 's/^error_reporting = .*/error_reporting = E_ALL | E_STRICT/g' /etc/php/8.2/apache2/php.ini |
||||
|
||||
sed -i 's/display_errors = .*/display_errors = Off/g' /etc/php/8.2/cli/php.ini |
||||
sed -i 's/display_errors = .*/display_errors = Off/g' /etc/php/8.2/apache2/php.ini |
||||
|
||||
sed -i 's/^display_startup_errors = .*/display_startup_errors = Off/g' /etc/php/8.2/cli/php.ini |
||||
sed -i 's/^display_startup_errors = .*/display_startup_errors = Off/g' /etc/php/8.2/apache2/php.ini |
||||
|
||||
sed -i 's/^upload_max_filesize = .*/upload_max_filesize = 100M/g' /etc/php/8.2/cli/php.ini |
||||
sed -i 's/^upload_max_filesize = .*/upload_max_filesize = 100M/g' /etc/php/8.2/apache2/php.ini |
||||
|
||||
sed -i 's/memory_limit = .*/memory_limit = -1/g' /etc/php/8.2/cli/php.ini |
||||
sed -i 's/memory_limit = .*/memory_limit = 256M/g' /etc/php/8.2/apache2/php.ini |
||||
|
||||
sed -i 's/;error_log = php_errors.*/error_log = \/var\/log\/aplsimples.log/g' /etc/php/8.2/cli/php.ini |
||||
sed -i 's/;error_log = php_errors.*/error_log = \/var\/log\/aplsimples.log/g' /etc/php/8.2/apache2/php.ini |
||||
|
||||
sed -i 's/^default_charset = .*/default_charset = "iso-8859-1"/g' /etc/php/8.2/cli/php.ini |
||||
sed -i 's/^default_charset = .*/default_charset = "iso-8859-1"/g' /etc/php/8.2/apache2/php.ini |
||||
|
||||
sed -i '745s/^;include_path = .*/include_path = \".:\/var\/www\/html\/include:\/var\/www\/html\/include\/core\"/g' /etc/php/8.2/cli/php.ini |
||||
sed -i '745 s/^;include_path = .*/include_path = \".:\/var\/www\/html\/include:\/var\/www\/html\/include\/core\"/g' /etc/php/8.2/apache2/php.ini |
||||
|
||||
sed -i 's/^;date.timezone =.*/date.timezone = "America\/Cuiaba"/g' /etc/php/8.2/cli/php.ini |
||||
sed -i 's/^;date.timezone =.*/date.timezone = "America\/Cuiaba"/g' /etc/php/8.2/apache2/php.ini |
||||
|
||||
sed -i 's/^export APACHE_RUN_USER=.*/export APACHE_RUN_USER=pbx/g' /etc/apache2/envvars |
||||
sed -i 's/^export APACHE_RUN_GROUP=.*/export APACHE_RUN_GROUP=pbx/g' /etc/apache2/envvars |
||||
|
||||
echo "export DB_HOST=${DB_HOST}" >> /etc/apache2/envvars |
||||
|
||||
cd /var/www/html/ |
||||
|
||||
exec rm -f /build-asterisk.sh |
@ -0,0 +1,20 @@
|
||||
#!/bin/bash |
||||
|
||||
echo "#Servicos Auxiliares" >> /etc/crontab |
||||
echo "0 1 * * * root /hdaux/utilitarios/scripts/hd.sh " >> /etc/crontab |
||||
echo "*/1 * * * * root /var/lib/asterisk/scripts/callcenter/queue_log.php" >> /etc/crontab |
||||
echo "*/1 * * * * root /var/lib/asterisk/scripts/callcenter/monitora_agentes.php" >> /etc/crontab |
||||
echo "*/1 * * * * root /var/lib/asterisk/scripts/manutencaoDB/importaBilhetes.php" >> /etc/crontab |
||||
echo "*/1 * * * * root /var/lib/asterisk/scripts/workflow/workflowSender.php" >> /etc/crontab |
||||
echo "0 2 * * * root /var/lib/asterisk/scripts/manutencaoDB/manutencaodb.php" >> /etc/crontab |
||||
echo "#Backup" >> /etc/crontab |
||||
echo "*/10 * * * * root /var/lib/asterisk/scripts/backup/backup.php" >> /etc/crontab |
||||
echo "#Backup - Shell" >> /etc/crontab |
||||
echo "0 1 * * * root /hdaux/utilitarios/scripts/backup.sh config,bd" >> /etc/crontab |
||||
echo "#VPN" >> /etc/crontab |
||||
echo "*/1 * * * * root /bin/sip_teste_vpn.sh" >> /etc/crontab |
||||
echo "#NTP" >> /etc/crontab |
||||
echo "*/15 * * * * root /hdaux/utilitarios/scripts/ntp.sh" >> /etc/crontab |
||||
echo "#Logrotate" >> /etc/crontab |
||||
echo "59 23 * * * root /hdaux/utilitarios/scripts/logrotate.sh --force" >> /etc/crontab |
||||
echo "57 23 * * * root /hdaux/utilitarios/scripts/temporizador_de_dados.sh" >> /etc/crontab |
@ -0,0 +1,31 @@
|
||||
#!/bin/sh |
||||
|
||||
# run as user asterisk by default |
||||
ASTERISK_USER=${ASTERISK_USER:-asterisk} |
||||
|
||||
if [ "$1" = "" ]; then |
||||
COMMAND="/usr/sbin/asterisk -T -W -U ${ASTERISK_USER} -p -vvvdddf" |
||||
else |
||||
COMMAND="$@" |
||||
fi |
||||
|
||||
if [ "${ASTERISK_UID}" != "" ] && [ "${ASTERISK_GID}" != "" ]; then |
||||
# recreate user and group for asterisk |
||||
# if they've sent as env variables (i.e. to macth with host user to fix permissions for mounted folders |
||||
|
||||
deluser asterisk && \ |
||||
adduser --gecos "" --no-create-home --uid ${ASTERISK_UID} --disabled-password ${ASTERISK_USER} \ |
||||
|| exit |
||||
fi |
||||
|
||||
mkdir -p /var/run/asterisk |
||||
|
||||
chown -R ${ASTERISK_USER}: /var/log/asterisk \ |
||||
/var/lib/asterisk \ |
||||
/var/run/asterisk \ |
||||
/var/spool/asterisk; \ |
||||
|
||||
cp /var/www/html/config-docker.php /var/www/html/aplicativo/ |
||||
/hdaux/utilitarios/scripts/permissoes_atualizacao.sh |
||||
|
||||
exec ${COMMAND} |
@ -0,0 +1,78 @@
|
||||
<VirtualHost *:80> |
||||
# The ServerName directive sets the request scheme, hostname and port that |
||||
# the server uses to identify itself. This is used when creating |
||||
# redirection URLs. In the context of virtual hosts, the ServerName |
||||
# specifies what hostname must appear in the request's Host: header to |
||||
# match this virtual host. For the default virtual host (this file) this |
||||
# value is not decisive as it is used as a last resort host regardless. |
||||
# However, you must set it for any further virtual host explicitly. |
||||
#ServerName www.example.com |
||||
|
||||
ServerAdmin webmaster@localhost |
||||
DocumentRoot /var/www/html/aplicativo |
||||
|
||||
Alias /gravacoes "/var/spool/asterisk/monitor" |
||||
<Directory "/var/spool/asterisk/monitor"> |
||||
Options Indexes MultiViews |
||||
AllowOverride None |
||||
Order allow,deny |
||||
Require all granted |
||||
Allow from 127.0.0.1 |
||||
</Directory> |
||||
|
||||
Alias /agenda "/var/www/html/agenda" |
||||
<Directory "/var/www/html/agenda/"> |
||||
Options Indexes MultiViews |
||||
AllowOverride None |
||||
Order allow,deny |
||||
Require all granted |
||||
Allow from all |
||||
</Directory> |
||||
|
||||
Alias /downloads "/hdaux/downloads" |
||||
<Directory "/hdaux/downloads/"> |
||||
Options Indexes MultiViews |
||||
AllowOverride None |
||||
Order allow,deny |
||||
Require all granted |
||||
Allow from all |
||||
</Directory> |
||||
|
||||
Alias /ferramentas "/hdaux/utilitarios/ferramentas" |
||||
<Directory "/hdaux/utilitarios/ferramentas/"> |
||||
Options Indexes MultiViews |
||||
AllowOverride None |
||||
Order allow,deny |
||||
Require all granted |
||||
Allow from all |
||||
</Directory> |
||||
|
||||
Alias /manuais "/hdaux/utilitarios/manuais" |
||||
<Directory "/hdaux/utilitarios/manuais/"> |
||||
Options Indexes MultiViews |
||||
AllowOverride None |
||||
Order allow,deny |
||||
Require all granted |
||||
Allow from all |
||||
</Directory> |
||||
|
||||
|
||||
|
||||
# Available loglevels: trace8, ..., trace1, debug, info, notice, warn, |
||||
# error, crit, alert, emerg. |
||||
# It is also possible to configure the loglevel for particular |
||||
# modules, e.g. |
||||
#LogLevel info ssl:warn |
||||
|
||||
ErrorLog ${APACHE_LOG_DIR}/error.log |
||||
CustomLog ${APACHE_LOG_DIR}/access.log combined |
||||
|
||||
# For most configuration files from conf-available/, which are |
||||
# enabled or disabled at a global level, it is possible to |
||||
# include a line for only one particular virtual host. For example the |
||||
# following line enables the CGI configuration for this host only |
||||
# after it has been globally disabled with "a2disconf". |
||||
#Include conf-available/serve-cgi-bin.conf |
||||
</VirtualHost> |
||||
|
||||
# vim: syntax=apache ts=4 sw=4 sts=4 sr noet |
@ -0,0 +1,88 @@
|
||||
#!/bin/bash |
||||
# |
||||
# /etc/init.d/Daemon |
||||
# |
||||
# Starts the at daemon |
||||
# |
||||
# chkconfig: 345 95 5 |
||||
# description: Runs the demonstration daemon. |
||||
# processname: Daemon |
||||
|
||||
|
||||
# Source function library. |
||||
. /etc/init.d/functions |
||||
|
||||
#startup values |
||||
log=/var/log/cnvrtd.log |
||||
|
||||
#verify that the executable exists |
||||
test -x /var/www/html/aplicativo/cnvrtd/cnvrtd.php || exit 0 |
||||
|
||||
# |
||||
# Set prog, proc and bin variables. |
||||
# |
||||
prog="cnvrtd" |
||||
proc=/var/lock/subsys/cnvrtd |
||||
bin=/var/www/html/aplicativo/cnvrtd/cnvrtd.php |
||||
|
||||
start() { |
||||
# Check if Daemon is already running |
||||
if [ ! -f $proc ]; then |
||||
echo -n $"Starting $prog: " |
||||
daemon $bin --log=$log |
||||
RETVAL=$? |
||||
[ $RETVAL -eq 0 ] && touch $proc |
||||
echo |
||||
fi |
||||
|
||||
return $RETVAL |
||||
} |
||||
|
||||
stop() { |
||||
echo -n $"Stopping $prog: " |
||||
killproc $bin |
||||
RETVAL=$? |
||||
[ $RETVAL -eq 0 ] && rm -f $proc |
||||
echo |
||||
return $RETVAL |
||||
} |
||||
|
||||
restart() { |
||||
stop |
||||
start |
||||
} |
||||
|
||||
reload() { |
||||
restart |
||||
} |
||||
|
||||
status_at() { |
||||
status $bin |
||||
} |
||||
|
||||
case "$1" in |
||||
start) |
||||
start |
||||
;; |
||||
stop) |
||||
stop |
||||
;; |
||||
reload|restart) |
||||
restart |
||||
;; |
||||
condrestart) |
||||
if [ -f $proc ]; then |
||||
restart |
||||
fi |
||||
;; |
||||
status) |
||||
status_at |
||||
;; |
||||
*) |
||||
|
||||
echo $"Usage: $0 {start|stop|restart|condrestart|status}" |
||||
exit 1 |
||||
esac |
||||
|
||||
exit $? |
||||
exit $RETVAL |
@ -0,0 +1,593 @@
|
||||
# -*-Shell-script-*- |
||||
# |
||||
# functions This file contains functions to be used by most or all |
||||
# shell scripts in the /etc/init.d directory. |
||||
# |
||||
|
||||
TEXTDOMAIN=initscripts |
||||
|
||||
# Make sure umask is sane |
||||
umask 022 |
||||
|
||||
# Set up a default search path. |
||||
PATH="/sbin:/usr/sbin:/bin:/usr/bin" |
||||
export PATH |
||||
|
||||
if [ $PPID -ne 1 -a -z "$SYSTEMCTL_SKIP_REDIRECT" ] && \ |
||||
( /bin/mountpoint -q /cgroup/systemd || /bin/mountpoint -q /sys/fs/cgroup/systemd ) ; then |
||||
case "$0" in |
||||
/etc/init.d/*|/etc/rc.d/init.d/*) |
||||
_use_systemctl=1 |
||||
;; |
||||
esac |
||||
fi |
||||
|
||||
systemctl_redirect () { |
||||
local s |
||||
local prog=${1##*/} |
||||
local command=$2 |
||||
local options="" |
||||
|
||||
case "$command" in |
||||
start) |
||||
s=$"Starting $prog (via systemctl): " |
||||
;; |
||||
stop) |
||||
s=$"Stopping $prog (via systemctl): " |
||||
;; |
||||
reload|try-reload) |
||||
s=$"Reloading $prog configuration (via systemctl): " |
||||
;; |
||||
restart|try-restart|condrestart) |
||||
s=$"Restarting $prog (via systemctl): " |
||||
;; |
||||
esac |
||||
|
||||
if [ -n "$SYSTEMCTL_IGNORE_DEPENDENCIES" ] ; then |
||||
options="--ignore-dependencies" |
||||
fi |
||||
|
||||
action "$s" /bin/systemctl $options $command "$prog.service" |
||||
} |
||||
|
||||
# Get a sane screen width |
||||
[ -z "${COLUMNS:-}" ] && COLUMNS=80 |
||||
|
||||
if [ -z "${CONSOLETYPE:-}" ]; then |
||||
if [ -c "/dev/stderr" -a -r "/dev/stderr" ]; then |
||||
CONSOLETYPE="$(/sbin/consoletype < /dev/stderr 2>/dev/null)" |
||||
else |
||||
CONSOLETYPE="serial" |
||||
fi |
||||
fi |
||||
|
||||
if [ -z "${NOLOCALE:-}" ] && [ -z "${LANGSH_SOURCED:-}" ] && [ -f /etc/sysconfig/i18n -o -f /etc/locale.conf ] ; then |
||||
. /etc/profile.d/lang.sh 2>/dev/null |
||||
# avoid propagating LANGSH_SOURCED any further |
||||
unset LANGSH_SOURCED |
||||
fi |
||||
|
||||
# Read in our configuration |
||||
if [ -z "${BOOTUP:-}" ]; then |
||||
if [ -f /etc/sysconfig/init ]; then |
||||
. /etc/sysconfig/init |
||||
else |
||||
# This all seem confusing? Look in /etc/sysconfig/init, |
||||
# or in /usr/share/doc/initscripts-*/sysconfig.txt |
||||
BOOTUP=color |
||||
RES_COL=60 |
||||
MOVE_TO_COL="echo -en \\033[${RES_COL}G" |
||||
SETCOLOR_SUCCESS="echo -en \\033[1;32m" |
||||
SETCOLOR_FAILURE="echo -en \\033[1;31m" |
||||
SETCOLOR_WARNING="echo -en \\033[1;33m" |
||||
SETCOLOR_NORMAL="echo -en \\033[0;39m" |
||||
LOGLEVEL=1 |
||||
fi |
||||
if [ "$CONSOLETYPE" = "serial" ]; then |
||||
BOOTUP=serial |
||||
MOVE_TO_COL= |
||||
SETCOLOR_SUCCESS= |
||||
SETCOLOR_FAILURE= |
||||
SETCOLOR_WARNING= |
||||
SETCOLOR_NORMAL= |
||||
fi |
||||
fi |
||||
|
||||
# Check if any of $pid (could be plural) are running |
||||
checkpid() { |
||||
local i |
||||
|
||||
for i in $* ; do |
||||
[ -d "/proc/$i" ] && return 0 |
||||
done |
||||
return 1 |
||||
} |
||||
|
||||
# __proc_pids {program} [pidfile] |
||||
# Set $pid to pids from /var/run* for {program}. $pid should be declared |
||||
# local in the caller. |
||||
# Returns LSB exit code for the 'status' action. |
||||
__pids_var_run() { |
||||
local base=${1##*/} |
||||
local pid_file=${2:-/var/run/$base.pid} |
||||
|
||||
pid= |
||||
if [ -f "$pid_file" ] ; then |
||||
local line p |
||||
|
||||
[ ! -r "$pid_file" ] && return 4 # "user had insufficient privilege" |
||||
while : ; do |
||||
read line |
||||
[ -z "$line" ] && break |
||||
for p in $line ; do |
||||
[ -z "${p//[0-9]/}" ] && [ -d "/proc/$p" ] && pid="$pid $p" |
||||
done |
||||
done < "$pid_file" |
||||
|
||||
if [ -n "$pid" ]; then |
||||
return 0 |
||||
fi |
||||
return 1 # "Program is dead and /var/run pid file exists" |
||||
fi |
||||
return 3 # "Program is not running" |
||||
} |
||||
|
||||
# Output PIDs of matching processes, found using pidof |
||||
__pids_pidof() { |
||||
pgrep -f "$1" |
||||
} |
||||
|
||||
|
||||
# A function to start a program. |
||||
daemon() { |
||||
# Test syntax. |
||||
local gotbase= force= nicelevel corelimit |
||||
local pid base= user= nice= bg= pid_file= |
||||
local cgroup= |
||||
nicelevel=0 |
||||
while [ "$1" != "${1##[-+]}" ]; do |
||||
case $1 in |
||||
'') echo $"$0: Usage: daemon [+/-nicelevel] {program}" |
||||
return 1;; |
||||
--check) |
||||
base=$2 |
||||
gotbase="yes" |
||||
shift 2 |
||||
;; |
||||
--check=?*) |
||||
base=${1#--check=} |
||||
gotbase="yes" |
||||
shift |
||||
;; |
||||
--user) |
||||
user=$2 |
||||
shift 2 |
||||
;; |
||||
--user=?*) |
||||
user=${1#--user=} |
||||
shift |
||||
;; |
||||
--pidfile) |
||||
pid_file=$2 |
||||
shift 2 |
||||
;; |
||||
--pidfile=?*) |
||||
pid_file=${1#--pidfile=} |
||||
shift |
||||
;; |
||||
--force) |
||||
force="force" |
||||
shift |
||||
;; |
||||
[-+][0-9]*) |
||||
nice="nice -n $1" |
||||
shift |
||||
;; |
||||
*) echo $"$0: Usage: daemon [+/-nicelevel] {program}" |
||||
return 1;; |
||||
esac |
||||
done |
||||
|
||||
# Save basename. |
||||
[ -z "$gotbase" ] && base=${1##*/} |
||||
|
||||
# See if it's already running. Look *only* at the pid file. |
||||
__pids_var_run "$base" "$pid_file" |
||||
|
||||
[ -n "$pid" -a -z "$force" ] && return |
||||
|
||||
# make sure it doesn't core dump anywhere unless requested |
||||
corelimit="ulimit -S -c ${DAEMON_COREFILE_LIMIT:-0}" |
||||
|
||||
# if they set NICELEVEL in /etc/sysconfig/foo, honor it |
||||
[ -n "${NICELEVEL:-}" ] && nice="nice -n $NICELEVEL" |
||||
|
||||
# if they set CGROUP_DAEMON in /etc/sysconfig/foo, honor it |
||||
if [ -n "${CGROUP_DAEMON}" ]; then |
||||
if [ ! -x /bin/cgexec ]; then |
||||
echo -n "Cgroups not installed"; warning |
||||
echo |
||||
else |
||||
cgroup="/bin/cgexec"; |
||||
for i in $CGROUP_DAEMON; do |
||||
cgroup="$cgroup -g $i"; |
||||
done |
||||
fi |
||||
fi |
||||
|
||||
# Echo daemon |
||||
[ "${BOOTUP:-}" = "verbose" -a -z "${LSB:-}" ] && echo -n " $base" |
||||
|
||||
# And start it up. |
||||
if [ -z "$user" ]; then |
||||
$cgroup $nice /bin/bash -c "$corelimit >/dev/null 2>&1 ; $*" |
||||
else |
||||
$cgroup $nice runuser -s /bin/bash $user -c "$corelimit >/dev/null 2>&1 ; $*" |
||||
fi |
||||
|
||||
[ "$?" -eq 0 ] && success $"$base startup" || failure $"$base startup" |
||||
} |
||||
|
||||
# A function to stop a program. |
||||
killproc() { |
||||
local RC killlevel= base pid pid_file= delay try |
||||
|
||||
RC=0; delay=3; try=0 |
||||
# Test syntax. |
||||
if [ "$#" -eq 0 ]; then |
||||
echo $"Usage: killproc [-p pidfile] [ -d delay] {program} [-signal]" |
||||
return 1 |
||||
fi |
||||
if [ "$1" = "-p" ]; then |
||||
pid_file=$2 |
||||
shift 2 |
||||
fi |
||||
if [ "$1" = "-d" ]; then |
||||
delay=$(echo $2 | awk -v RS=' ' -v IGNORECASE=1 '{if($1!~/^[0-9.]+[smhd]?$/) exit 1;d=$1~/s$|^[0-9.]*$/?1:$1~/m$/?60:$1~/h$/?60*60:$1~/d$/?24*60*60:-1;if(d==-1) exit 1;delay+=d*$1} END {printf("%d",delay+0.5)}') |
||||
if [ "$?" -eq 1 ]; then |
||||
echo $"Usage: killproc [-p pidfile] [ -d delay] {program} [-signal]" |
||||
return 1 |
||||
fi |
||||
shift 2 |
||||
fi |
||||
|
||||
|
||||
# check for second arg to be kill level |
||||
[ -n "${2:-}" ] && killlevel=$2 |
||||
|
||||
# Save basename. |
||||
base=${1##*/} |
||||
|
||||
# Find pid. |
||||
__pids_var_run "$1" "$pid_file" |
||||
RC=$? |
||||
if [ -z "$pid" ]; then |
||||
if [ -z "$pid_file" ]; then |
||||
pid="$(__pids_pidof "$1")" |
||||
else |
||||
[ "$RC" = "4" ] && { failure $"$base shutdown" ; return $RC ;} |
||||
fi |
||||
fi |
||||
|
||||
# Kill it. |
||||
if [ -n "$pid" ] ; then |
||||
[ "$BOOTUP" = "verbose" -a -z "${LSB:-}" ] && echo -n "$base " |
||||
if [ -z "$killlevel" ] ; then |
||||
if checkpid $pid 2>&1; then |
||||
# TERM first, then KILL if not dead |
||||
kill -TERM $pid >/dev/null 2>&1 |
||||
sleep 1 |
||||
if checkpid $pid ; then |
||||
try=0 |
||||
while [ $try -lt $delay ] ; do |
||||
checkpid $pid || break |
||||
sleep 1 |
||||
let try+=1 |
||||
done |
||||
if checkpid $pid ; then |
||||
kill -KILL $pid >/dev/null 2>&1 |
||||
sleep 1 |
||||
fi |
||||
fi |
||||
fi |
||||
checkpid $pid |
||||
RC=$? |
||||
[ "$RC" -eq 0 ] && failure $"$base shutdown" || success $"$base shutdown" |
||||
RC=$((! $RC)) |
||||
# use specified level only |
||||
else |
||||
if checkpid $pid; then |
||||
kill $killlevel $pid >/dev/null 2>&1 |
||||
RC=$? |
||||
[ "$RC" -eq 0 ] && success $"$base $killlevel" || failure $"$base $killlevel" |
||||
elif [ -n "${LSB:-}" ]; then |
||||
RC=7 # Program is not running |
||||
fi |
||||
fi |
||||
else |
||||
if [ -n "${LSB:-}" -a -n "$killlevel" ]; then |
||||
RC=7 # Program is not running |
||||
else |
||||
failure $"$base shutdown" |
||||
RC=0 |
||||
fi |
||||
fi |
||||
|
||||
# Remove pid file if any. |
||||
if [ -z "$killlevel" ]; then |
||||
rm -f "${pid_file:-/var/run/$base.pid}" |
||||
fi |
||||
return $RC |
||||
} |
||||
|
||||
# A function to find the pid of a program. Looks *only* at the pidfile |
||||
pidfileofproc() { |
||||
local pid |
||||
|
||||
# Test syntax. |
||||
if [ "$#" = 0 ] ; then |
||||
echo $"Usage: pidfileofproc {program}" |
||||
return 1 |
||||
fi |
||||
|
||||
__pids_var_run "$1" |
||||
[ -n "$pid" ] && echo $pid |
||||
return 0 |
||||
} |
||||
|
||||
# A function to find the pid of a program. |
||||
pidofproc() { |
||||
local RC pid pid_file= |
||||
|
||||
# Test syntax. |
||||
if [ "$#" = 0 ]; then |
||||
echo $"Usage: pidofproc [-p pidfile] {program}" |
||||
return 1 |
||||
fi |
||||
if [ "$1" = "-p" ]; then |
||||
pid_file=$2 |
||||
shift 2 |
||||
fi |
||||
fail_code=3 # "Program is not running" |
||||
|
||||
# First try "/var/run/*.pid" files |
||||
__pids_var_run "$1" "$pid_file" |
||||
RC=$? |
||||
if [ -n "$pid" ]; then |
||||
echo $pid |
||||
return 0 |
||||
fi |
||||
|
||||
[ -n "$pid_file" ] && return $RC |
||||
__pids_pidof "$1" || return $RC |
||||
} |
||||
|
||||
status() { |
||||
local base pid lock_file= pid_file= |
||||
|
||||
# Test syntax. |
||||
if [ "$#" = 0 ] ; then |
||||
echo $"Usage: status [-p pidfile] {program}" |
||||
return 1 |
||||
fi |
||||
if [ "$1" = "-p" ]; then |
||||
pid_file=$2 |
||||
shift 2 |
||||
fi |
||||
if [ "$1" = "-l" ]; then |
||||
lock_file=$2 |
||||
shift 2 |
||||
fi |
||||
base=${1##*/} |
||||
|
||||
if [ "$_use_systemctl" = "1" ]; then |
||||
systemctl status ${0##*/}.service |
||||
return $? |
||||
fi |
||||
|
||||
# First try "pidof" |
||||
__pids_var_run "$1" "$pid_file" |
||||
RC=$? |
||||
if [ -z "$pid_file" -a -z "$pid" ]; then |
||||
pid="$(__pids_pidof "$1")" |
||||
fi |
||||
if [ -n "$pid" ]; then |
||||
echo $"${base} (pid $pid) is running..." |
||||
return 0 |
||||
fi |
||||
|
||||
case "$RC" in |
||||
0) |
||||
echo $"${base} (pid $pid) is running..." |
||||
return 0 |
||||
;; |
||||
1) |
||||
echo $"${base} dead but pid file exists" |
||||
return 1 |
||||
;; |
||||
4) |
||||
echo $"${base} status unknown due to insufficient privileges." |
||||
return 4 |
||||
;; |
||||
esac |
||||
if [ -z "${lock_file}" ]; then |
||||
lock_file=${base} |
||||
fi |
||||
# See if /var/lock/subsys/${lock_file} exists |
||||
if [ -f /var/lock/subsys/${lock_file} ]; then |
||||
echo $"${base} dead but subsys locked" |
||||
return 2 |
||||
fi |
||||
echo $"${base} is stopped" |
||||
return 3 |
||||
} |
||||
|
||||
echo_success() { |
||||
[ "$BOOTUP" = "color" ] && $MOVE_TO_COL |
||||
echo -n "[" |
||||
[ "$BOOTUP" = "color" ] && $SETCOLOR_SUCCESS |
||||
echo -n $" OK " |
||||
[ "$BOOTUP" = "color" ] && $SETCOLOR_NORMAL |
||||
echo -n "]" |
||||
echo -ne "\r" |
||||
return 0 |
||||
} |
||||
|
||||
echo_failure() { |
||||
[ "$BOOTUP" = "color" ] && $MOVE_TO_COL |
||||
echo -n "[" |
||||
[ "$BOOTUP" = "color" ] && $SETCOLOR_FAILURE |
||||
echo -n $"FAILED" |
||||
[ "$BOOTUP" = "color" ] && $SETCOLOR_NORMAL |
||||
echo -n "]" |
||||
echo -ne "\r" |
||||
return 1 |
||||
} |
||||
|
||||
echo_passed() { |
||||
[ "$BOOTUP" = "color" ] && $MOVE_TO_COL |
||||
echo -n "[" |
||||
[ "$BOOTUP" = "color" ] && $SETCOLOR_WARNING |
||||
echo -n $"PASSED" |
||||
[ "$BOOTUP" = "color" ] && $SETCOLOR_NORMAL |
||||
echo -n "]" |
||||
echo -ne "\r" |
||||
return 1 |
||||
} |
||||
|
||||
echo_warning() { |
||||
[ "$BOOTUP" = "color" ] && $MOVE_TO_COL |
||||
echo -n "[" |
||||
[ "$BOOTUP" = "color" ] && $SETCOLOR_WARNING |
||||
echo -n $"WARNING" |
||||
[ "$BOOTUP" = "color" ] && $SETCOLOR_NORMAL |
||||
echo -n "]" |
||||
echo -ne "\r" |
||||
return 1 |
||||
} |
||||
|
||||
# Inform the graphical boot of our current state |
||||
update_boot_stage() { |
||||
if [ -x /bin/plymouth ]; then |
||||
/bin/plymouth --update="$1" |
||||
fi |
||||
return 0 |
||||
} |
||||
|
||||
# Log that something succeeded |
||||
success() { |
||||
[ "$BOOTUP" != "verbose" -a -z "${LSB:-}" ] && echo_success |
||||
return 0 |
||||
} |
||||
|
||||
# Log that something failed |
||||
failure() { |
||||
local rc=$? |
||||
[ "$BOOTUP" != "verbose" -a -z "${LSB:-}" ] && echo_failure |
||||
[ -x /bin/plymouth ] && /bin/plymouth --details |
||||
return $rc |
||||
} |
||||
|
||||
# Log that something passed, but may have had errors. Useful for fsck |
||||
passed() { |
||||
local rc=$? |
||||
[ "$BOOTUP" != "verbose" -a -z "${LSB:-}" ] && echo_passed |
||||
return $rc |
||||
} |
||||
|
||||
# Log a warning |
||||
warning() { |
||||
local rc=$? |
||||
[ "$BOOTUP" != "verbose" -a -z "${LSB:-}" ] && echo_warning |
||||
return $rc |
||||
} |
||||
|
||||
# Run some action. Log its output. |
||||
action() { |
||||
local STRING rc |
||||
|
||||
STRING=$1 |
||||
echo -n "$STRING " |
||||
shift |
||||
"$@" && success $"$STRING" || failure $"$STRING" |
||||
rc=$? |
||||
echo |
||||
return $rc |
||||
} |
||||
|
||||
# returns OK if $1 contains $2 |
||||
strstr() { |
||||
[ "${1#*$2*}" = "$1" ] && return 1 |
||||
return 0 |
||||
} |
||||
|
||||
# Check whether file $1 is a backup or rpm-generated file and should be ignored |
||||
is_ignored_file() { |
||||
case "$1" in |
||||
*~ | *.bak | *.orig | *.rpmnew | *.rpmorig | *.rpmsave) |
||||
return 0 |
||||
;; |
||||
esac |
||||
return 1 |
||||
} |
||||
|
||||
# Evaluate shvar-style booleans |
||||
is_true() { |
||||
case "$1" in |
||||
[tT] | [yY] | [yY][eE][sS] | [tT][rR][uU][eE]) |
||||
return 0 |
||||
;; |
||||
esac |
||||
return 1 |
||||
} |
||||
|
||||
# Evaluate shvar-style booleans |
||||
is_false() { |
||||
case "$1" in |
||||
[fF] | [nN] | [nN][oO] | [fF][aA][lL][sS][eE]) |
||||
return 0 |
||||
;; |
||||
esac |
||||
return 1 |
||||
} |
||||
|
||||
# Apply sysctl settings, including files in /etc/sysctl.d |
||||
apply_sysctl() { |
||||
if [ -x /lib/systemd/systemd-sysctl ]; then |
||||
/lib/systemd/systemd-sysctl |
||||
else |
||||
for file in /usr/lib/sysctl.d/*.conf ; do |
||||
is_ignored_file "$file" && continue |
||||
[ -f /run/sysctl.d/${file##*/} ] && continue |
||||
[ -f /etc/sysctl.d/${file##*/} ] && continue |
||||
test -f "$file" && sysctl -e -p "$file" >/dev/null 2>&1 |
||||
done |
||||
for file in /run/sysctl.d/*.conf ; do |
||||
is_ignored_file "$file" && continue |
||||
[ -f /etc/sysctl.d/${file##*/} ] && continue |
||||
test -f "$file" && sysctl -e -p "$file" >/dev/null 2>&1 |
||||
done |
||||
for file in /etc/sysctl.d/*.conf ; do |
||||
is_ignored_file "$file" && continue |
||||
test -f "$file" && sysctl -e -p "$file" >/dev/null 2>&1 |
||||
done |
||||
sysctl -e -p /etc/sysctl.conf >/dev/null 2>&1 |
||||
fi |
||||
} |
||||
|
||||
# A sed expression to filter out the files that is_ignored_file recognizes |
||||
__sed_discard_ignored_files='/\(~\|\.bak\|\.orig\|\.rpmnew\|\.rpmorig\|\.rpmsave\)$/d' |
||||
|
||||
if [ "$_use_systemctl" = "1" ]; then |
||||
if [ "x$1" = xstart -o \ |
||||
"x$1" = xstop -o \ |
||||
"x$1" = xrestart -o \ |
||||
"x$1" = xreload -o \ |
||||
"x$1" = xtry-restart -o \ |
||||
"x$1" = xforce-reload -o \ |
||||
"x$1" = xcondrestart ] ; then |
||||
|
||||
systemctl_redirect $0 $1 |
||||
exit $? |
||||
fi |
||||
fi |
@ -0,0 +1,25 @@
|
||||
[supervisord] |
||||
logfile=/var/log/supervisor/supervisord.log ; localização do arquivo de log do Supervisor |
||||
pidfile=/var/run/supervisord.pid ; localização do arquivo PID do Supervisor |
||||
user=root |
||||
|
||||
[program:apache2] |
||||
priority=100 |
||||
notdaemon=false |
||||
command=/usr/sbin/apachectl -D BACKGROUND |
||||
startsecs=0 |
||||
startretries=0 |
||||
|
||||
[program:cnvrtd] |
||||
priority=200 |
||||
notdaemon=false |
||||
command=/etc/init.d/cnvrtd start |
||||
startsecs=0 |
||||
startretries=0 |
||||
|
||||
[program:cron] |
||||
priority=150 |
||||
notdaemon=false |
||||
command=/usr/sbin/cron |
||||
startsecs=0 |
||||
startretries=0 |
@ -0,0 +1,12 @@
|
||||
# Imagem postgres 13:14 para monitor Simples IP |
||||
|
||||
Container ISO-8859-1 |
||||
|
||||
|
||||
1. **base.sh** |
||||
- responsável por criar usuários |
||||
- Restaurar o banco da versão desejada |
||||
- Acrescentar as querys extras em /base/add_sql. São incluídos por ordens alfabéticas |
||||
|
||||
2. **permission_pg_hba.sh** |
||||
- Acrescenta permissões de acesso externo |
@ -0,0 +1,22 @@
|
||||
#!/bin/bash |
||||
|
||||
# Criar usuarios do banco de dados |
||||
# Usuario contacte é criado por default pelo container |
||||
psql -c "CREATE USER root WITH PASSWORD '\$imple\$ip' SUPERUSER CREATEDB CREATEROLE" |
||||
psql -c "CREATE USER simplesip WITH PASSWORD 'smplsIP' SUPERUSER CREATEDB CREATEROLE" |
||||
psql -c "CREATE USER postgres WITH PASSWORD 'SIP\$\$'" |
||||
|
||||
# excluir schema antes de restaurar o banco de dados |
||||
psql -d "pbx" -c "DROP SCHEMA public CASCADE;" |
||||
|
||||
# Restaurar o banco dedados do monitor |
||||
/usr/bin/pg_restore -v -Fc --jobs="5" -d pbx /base/base-monitor.sql |
||||
|
||||
# Adiciona query nacessarias depois que restaura o banco |
||||
# Incluida por ordem alfabetica no diretório /base/add_sql |
||||
# /base/add_sql -> espelho do projeto/base/add_sql |
||||
for file $(find /base/add_sql/ | sort) |
||||
do |
||||
psql -f "$file" |
||||
done |
||||
|
@ -0,0 +1,5 @@
|
||||
#!/bin/sh |
||||
|
||||
echo "host all all 192.168.115.0/24 md5" >> /var/lib/postgresql/data/pg_hba.conf |
||||
echo "host all all 10.252.252.0/24 md5" >> /var/lib/postgresql/data/pg_hba.conf |
||||
echo "host all all 177.67.197.146/32 md5" >> /var/lib/postgresql/data/pg_hba.conf |
Loading…
Reference in new issue