2024-11-21 22:25:59 +01:00
#!/usr/bin/env bash
2025-01-01 13:37:29 +01:00
# Copyright (c) 2021-2025 community-scripts ORG
2024-11-21 22:25:59 +01:00
# Author: MickLesk
2025-03-04 17:54:20 +01:00
# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
# Source: https://www.kimai.org/
2024-11-21 22:25:59 +01:00
2025-03-24 14:20:56 +01:00
source /dev/stdin <<< " $FUNCTIONS_FILE_PATH "
2024-11-21 22:25:59 +01:00
color
verb_ip6
catch_errors
setting_up_container
network_check
update_os
msg_info "Installing Dependencies"
$STD apt-get install -y \
apt-transport-https \
apache2 \
git \
2025-10-29 05:06:03 -07:00
expect
2024-11-21 22:25:59 +01:00
msg_ok "Installed Dependencies"
2025-10-29 05:06:03 -07:00
setup_mariadb
PHP_VERSION = "8.4" PHP_MODULE = "gd,mysql,mbstring,bcmath,xml,curl,zip,intl" PHP_APACHE = "YES" setup_php
setup_composer
2025-01-20 14:00:33 +01:00
2024-11-21 22:25:59 +01:00
msg_info "Setting up database"
DB_NAME = kimai_db
DB_USER = kimai
DB_PASS = $( openssl rand -base64 18 | tr -dc 'a-zA-Z0-9' | head -c13)
2025-10-29 05:06:03 -07:00
MYSQL_VERSION = $( mariadb --version | grep -oE '[0-9]+\.[0-9]+\.[0-9]+' )
$STD mariadb -u root -e " CREATE DATABASE $DB_NAME ; "
$STD mariadb -u root -e " CREATE USER ' $DB_USER '@'localhost' IDENTIFIED BY ' $DB_PASS '; "
$STD mariadb -u root -e " GRANT ALL ON $DB_NAME .* TO ' $DB_USER '@'localhost'; FLUSH PRIVILEGES; "
2025-10-30 04:42:04 -07:00
$STD mariadb -u root -e "SET GLOBAL sql_mode='';"
2024-11-21 22:25:59 +01:00
{
2025-03-24 14:20:56 +01:00
echo "Kimai-Credentials"
echo " Kimai Database User: $DB_USER "
echo " Kimai Database Password: $DB_PASS "
echo " Kimai Database Name: $DB_NAME "
} >>~/kimai.creds
2024-11-21 22:25:59 +01:00
msg_ok "Set up database"
2025-10-29 14:00:16 -07:00
fetch_and_deploy_gh_release "kimai" "kimai/kimai"
2025-10-29 05:06:03 -07:00
msg_info "Installing Kimai"
2025-04-15 15:20:46 +02:00
cd /opt/kimai
2025-03-24 14:20:56 +01:00
echo "export COMPOSER_ALLOW_SUPERUSER=1" >>~/.bashrc
2024-11-21 22:25:59 +01:00
source ~/.bashrc
$STD composer install --no-dev --optimize-autoloader --no-interaction
cp .env.dist .env
2025-10-30 13:51:10 +01:00
sed -i " /^DATABASE_URL=/c\DATABASE_URL=mysql:// $DB_USER : $DB_PASS @127.0.0.1:3306/ $DB_NAME ?charset=utf8mb4&serverVersion=mariadb- $MYSQL_VERSION " /opt/kimai/.env
2024-11-21 22:25:59 +01:00
$STD bin/console kimai:install -n
$STD expect <<EOF
set timeout -1
log_user 0
spawn bin/console kimai:user:create admin admin@helper-scripts.com ROLE_SUPER_ADMIN
expect "Please enter the password:"
send "helper-scripts.com\r"
expect eof
EOF
2025-01-20 16:51:05 +01:00
$STD composer update --no-interaction
2025-02-26 13:16:11 +01:00
cat <<EOF >/opt/kimai/config/packages/local.yaml
kimai:
timesheet:
rounding:
default:
begin: 15
end: 15
admin_lte:
options:
default_avatar: build/apple-touch-icon.png
EOF
2024-11-21 22:25:59 +01:00
msg_ok "Installed Kimai"
msg_info "Creating Service"
cat <<EOF >/etc/apache2/sites-available/kimai.conf
<VirtualHost *:80>
ServerAdmin webmaster@localhost
DocumentRoot /opt/kimai/public/
<Directory /opt/kimai/public>
Options FollowSymLinks
AllowOverride All
Require all granted
</Directory>
ErrorLog /var/log/apache2/error.log
CustomLog /var/log/apache2/access.log combined
</VirtualHost>
EOF
$STD a2ensite kimai.conf
2025-03-24 14:20:56 +01:00
$STD a2dissite 000-default.conf
2024-11-21 22:25:59 +01:00
$STD systemctl reload apache2
msg_ok "Created Service"
2025-03-17 10:55:16 +01:00
msg_info "Setup Permissions"
chown -R :www-data /opt/*
chmod -R g+r /opt/*
chmod -R g+rw /opt/*
chown -R www-data:www-data /opt/*
chmod -R 777 /opt/*
msg_ok "Setup Permissions"
2024-11-21 22:25:59 +01:00
motd_ssh
customize
msg_info "Cleaning up"
2025-10-29 05:06:03 -07:00
$STD apt -y autoremove
$STD apt -y autoclean
$STD apt -y clean
2024-11-21 22:25:59 +01:00
msg_ok "Cleaned"