A free, open, self-hosted app platform (GNU AGPLv3): one-click app deploys, Traefik reverse proxy with automatic SSL, rootless Docker support, gluetun VPN routing, and a web dashboard to manage it all. Free & open forever to self-host; optional paid hosted services fund it. See PROMISE.md. Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com> Signed-off-by: librelad <librelad@digitalangels.vip>
111 lines
6.0 KiB
Bash
Executable File
111 lines
6.0 KiB
Bash
Executable File
#!/bin/bash
|
|
|
|
databaseCreateTables()
|
|
{
|
|
if command -v sqlite3 &> /dev/null; then
|
|
setup_table_name=path
|
|
if ! sqlite3 "$docker_dir/$db_file" ".tables" | grep -q "\b$setup_table_name\b"; then
|
|
# Table info here
|
|
local result=$(sqlite3 $docker_dir/$db_file "CREATE TABLE IF NOT EXISTS $setup_table_name (path TEXT);")
|
|
checkSuccess "Creating $setup_table_name table"
|
|
fi
|
|
|
|
setup_table_name=sysupdate
|
|
if ! sqlite3 "$docker_dir/$db_file" ".tables" | grep -q "\b$setup_table_name\b"; then
|
|
# Table info here
|
|
local result=$(sqlite3 $docker_dir/$db_file "CREATE TABLE IF NOT EXISTS $setup_table_name (date DATE, time TIME);")
|
|
checkSuccess "Creating $setup_table_name table"
|
|
fi
|
|
|
|
setup_table_name=options
|
|
if ! sqlite3 "$docker_dir/$db_file" ".tables" | grep -q "\b$setup_table_name\b"; then
|
|
# Table info here
|
|
local result=$(sqlite3 $docker_dir/$db_file "CREATE TABLE IF NOT EXISTS $setup_table_name (option TEXT UNIQUE, content TEXT);")
|
|
checkSuccess "Creating $setup_table_name table"
|
|
fi
|
|
|
|
setup_table_name=apps
|
|
if ! sqlite3 "$docker_dir/$db_file" ".tables" | grep -q "\b$setup_table_name\b"; then
|
|
# Table info here
|
|
# status = 1 = installed, 0 uninstalled
|
|
local result=$(sqlite3 $docker_dir/$db_file "CREATE TABLE IF NOT EXISTS $setup_table_name (name TEXT UNIQUE, status DATE, install_date DATE, install_time TIME, uninstall_date DATE, uninstall_time TIME);")
|
|
checkSuccess "Creating $setup_table_name table"
|
|
fi
|
|
|
|
setup_table_name=backups
|
|
if ! sqlite3 "$docker_dir/$db_file" ".tables" | grep -q "\b$setup_table_name\b"; then
|
|
# Table info here
|
|
local result=$(sqlite3 $docker_dir/$db_file "CREATE TABLE IF NOT EXISTS $setup_table_name (id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT, date DATE, time TIME);")
|
|
checkSuccess "Creating $setup_table_name table"
|
|
fi
|
|
|
|
setup_table_name=restores
|
|
if ! sqlite3 "$docker_dir/$db_file" ".tables" | grep -q "\b$setup_table_name\b"; then
|
|
# Table info here
|
|
local result=$(sqlite3 $docker_dir/$db_file "CREATE TABLE IF NOT EXISTS $setup_table_name (id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT, date DATE, time TIME);")
|
|
checkSuccess "Creating $setup_table_name table"
|
|
fi
|
|
|
|
setup_table_name=migrations
|
|
if ! sqlite3 "$docker_dir/$db_file" ".tables" | grep -q "\b$setup_table_name\b"; then
|
|
# Table info here
|
|
local result=$(sqlite3 $docker_dir/$db_file "CREATE TABLE IF NOT EXISTS $setup_table_name (id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT, date DATE, time TIME);")
|
|
checkSuccess "Creating $setup_table_name table"
|
|
fi
|
|
|
|
setup_table_name=ssh
|
|
if ! sqlite3 "$docker_dir/$db_file" ".tables" | grep -q "\b$setup_table_name\b"; then
|
|
# Table info here
|
|
local result=$(sqlite3 $docker_dir/$db_file "CREATE TABLE IF NOT EXISTS $setup_table_name (id INTEGER PRIMARY KEY AUTOINCREMENT, ip TEXT, date DATE, time TIME);")
|
|
checkSuccess "Creating $setup_table_name table"
|
|
fi
|
|
|
|
setup_table_name=ssh_keys
|
|
if ! sqlite3 "$docker_dir/$db_file" ".tables" | grep -q "\b$setup_table_name\b"; then
|
|
# Table info here
|
|
local result=$(sqlite3 $docker_dir/$db_file "CREATE TABLE IF NOT EXISTS $setup_table_name (name TEXT UNIQUE, hash TEXT, date DATE, time TIME);")
|
|
checkSuccess "Creating $setup_table_name table"
|
|
fi
|
|
|
|
setup_table_name=cron_jobs
|
|
if ! sqlite3 "$docker_dir/$db_file" ".tables" | grep -q "\b$setup_table_name\b"; then
|
|
# Table info here
|
|
local result=$(sqlite3 $docker_dir/$db_file "CREATE TABLE IF NOT EXISTS $setup_table_name (id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT UNIQUE, date DATE, time TIME);")
|
|
checkSuccess "Creating $setup_table_name table"
|
|
fi
|
|
|
|
setup_table_name=network_resources
|
|
if ! sqlite3 "$docker_dir/$db_file" ".tables" | grep -q "\b$setup_table_name\b"; then
|
|
# Simple unified network resources table - replaces all complex network tables
|
|
local result=$(sqlite3 $docker_dir/$db_file "CREATE TABLE IF NOT EXISTS $setup_table_name (
|
|
id INTEGER PRIMARY KEY AUTOINCREMENT,
|
|
app_name TEXT NOT NULL,
|
|
resource_type TEXT NOT NULL, -- 'ip' or 'port'
|
|
resource_value TEXT NOT NULL, -- '172.20.0.10' or '3001'
|
|
service_name TEXT DEFAULT 'main', -- service within app
|
|
parent_service TEXT DEFAULT NULL, -- parent Docker service for ports
|
|
status TEXT DEFAULT 'active',
|
|
created_date DATE DEFAULT CURRENT_DATE,
|
|
created_time TIME DEFAULT CURRENT_TIME,
|
|
UNIQUE(app_name, resource_type, service_name),
|
|
UNIQUE(resource_type, resource_value)
|
|
);")
|
|
checkSuccess "Creating unified network_resources table"
|
|
|
|
# Create simple indexes for performance
|
|
local result=$(sqlite3 "$docker_dir/$db_file" "CREATE INDEX IF NOT EXISTS idx_network_resources_app ON network_resources(app_name);")
|
|
checkSuccess "Creating network resources app index"
|
|
local result=$(sqlite3 "$docker_dir/$db_file" "CREATE INDEX IF NOT EXISTS idx_network_resources_type ON network_resources(resource_type);")
|
|
checkSuccess "Creating network resources type index"
|
|
local result=$(sqlite3 "$docker_dir/$db_file" "CREATE INDEX IF NOT EXISTS idx_network_resources_value ON network_resources(resource_value);")
|
|
checkSuccess "Creating network resources value index"
|
|
local result=$(sqlite3 "$docker_dir/$db_file" "CREATE INDEX IF NOT EXISTS idx_network_resources_status ON network_resources(status);")
|
|
checkSuccess "Creating network resources status index"
|
|
local result=$(sqlite3 "$docker_dir/$db_file" "CREATE INDEX IF NOT EXISTS idx_network_resources_parent_service ON network_resources(parent_service);")
|
|
checkSuccess "Creating network resources parent service index"
|
|
fi
|
|
else
|
|
echo "SQLite3 is not installed. Skipping table creation."
|
|
fi
|
|
}
|