64 lines
2.1 KiB
PHP
64 lines
2.1 KiB
PHP
<?php
|
|
|
|
/*
|
|
* This migration adds tables to store the date about the new notification methods (telegram, webhooks and gotify)
|
|
* Existing values on the notifications table will be split and migrated to the new tables.
|
|
*/
|
|
|
|
/** @noinspection PhpUndefinedVariableInspection */
|
|
$db->exec('CREATE TABLE IF NOT EXISTS telegram_notifications (
|
|
enabled BOOLEAN DEFAULT 0,
|
|
bot_token TEXT DEFAULT "",
|
|
chat_id TEXT DEFAULT ""
|
|
)');
|
|
|
|
$db->exec('CREATE TABLE IF NOT EXISTS webhook_notifications (
|
|
enabled BOOLEAN DEFAULT 0,
|
|
headers TEXT DEFAULT "",
|
|
url TEXT DEFAULT "",
|
|
request_method TEXT DEFAULT "POST",
|
|
payload TEXT DEFAULT "",
|
|
iterator TEXT DEFAULT ""
|
|
)');
|
|
|
|
$db->exec('CREATE TABLE IF NOT EXISTS gotify_notifications (
|
|
enabled BOOLEAN DEFAULT 0,
|
|
url TEXT DEFAULT "",
|
|
token TEXT DEFAULT ""
|
|
)');
|
|
|
|
$db->exec('CREATE TABLE IF NOT EXISTS email_notifications (
|
|
enabled BOOLEAN DEFAULT 0,
|
|
smtp_address TEXT DEFAULT "",
|
|
smtp_port INTEGER DEFAULT 587,
|
|
smtp_username TEXT DEFAULT "",
|
|
smtp_password TEXT DEFAULT "",
|
|
from_email TEXT DEFAULT "",
|
|
encryption TEXT DEFAULT "tls"
|
|
)');
|
|
|
|
$db->exec('CREATE TABLE IF NOT EXISTS notification_settings (
|
|
days INTEGER DEFAULT 0
|
|
)');
|
|
|
|
// Check if old email notifications table has data and migrate it
|
|
$result = $db->query('SELECT COUNT(*) as count FROM notifications');
|
|
$row = $result->fetchArray(SQLITE3_ASSOC);
|
|
|
|
if ($row['count'] > 0) {
|
|
// Copy data from notifications to email_notifications
|
|
$db->exec('INSERT INTO email_notifications (enabled, smtp_address, smtp_port, smtp_username, smtp_password, from_email, encryption)
|
|
SELECT enabled, smtp_address, smtp_port, smtp_username, smtp_password, from_email, encryption FROM notifications');
|
|
|
|
// Copy data from notifications to notification_settings
|
|
$db->exec('INSERT INTO notification_settings (days)
|
|
SELECT days FROM notifications');
|
|
|
|
if ($db->changes() > 0) {
|
|
$db->exec('DROP TABLE IF EXISTS notifications');
|
|
}
|
|
} else {
|
|
$db->exec('DROP TABLE IF EXISTS notifications');
|
|
}
|
|
|
|
?>
|