2021-12-18 18:08:42 +08:00
|
|
|
package migrations
|
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/jmoiron/sqlx"
|
|
|
|
"github.com/knadh/koanf"
|
|
|
|
"github.com/knadh/stuffbin"
|
|
|
|
)
|
|
|
|
|
|
|
|
// V2_1_0 performs the DB migrations for v.2.1.0.
|
|
|
|
func V2_1_0(db *sqlx.DB, fs stuffbin.FileSystem, ko *koanf.Koanf) error {
|
2022-01-05 00:46:21 +08:00
|
|
|
// Insert appearance related settings.
|
2021-12-18 18:08:42 +08:00
|
|
|
if _, err := db.Exec(`
|
|
|
|
INSERT INTO settings (key, value) VALUES
|
|
|
|
('appearance.admin.custom_css', '""'),
|
|
|
|
('appearance.admin.custom_js', '""'),
|
|
|
|
('appearance.public.custom_css', '""'),
|
2022-01-15 23:50:32 +08:00
|
|
|
('appearance.public.custom_js', '""'),
|
|
|
|
('upload.s3.public_url', '""')
|
2021-12-18 18:08:42 +08:00
|
|
|
ON CONFLICT DO NOTHING;
|
|
|
|
`); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2022-01-03 21:58:36 +08:00
|
|
|
// Replace all `tls_enabled: true/false` keys in the `smtp` settings JSON array
|
|
|
|
// with the new field `tls_type: STARTTLS|TLS|none`.
|
|
|
|
// The `tls_enabled` key is removed.
|
|
|
|
if _, err := db.Exec(`
|
|
|
|
UPDATE settings SET value = s.updated
|
|
|
|
FROM (
|
|
|
|
SELECT JSONB_AGG(
|
|
|
|
JSONB_SET(v - 'tls_enabled', '{tls_type}', (CASE WHEN v->>'tls_enabled' = 'true' THEN '"STARTTLS"' ELSE '"none"' END)::JSONB)
|
|
|
|
) AS updated FROM settings, JSONB_ARRAY_ELEMENTS(value) v WHERE key = 'smtp'
|
2022-01-05 01:00:43 +08:00
|
|
|
) s WHERE key = 'smtp' AND value::TEXT LIKE '%tls_enabled%';
|
2022-01-03 21:58:36 +08:00
|
|
|
`); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2022-01-05 00:46:21 +08:00
|
|
|
if _, err := db.Exec(`ALTER TABLE campaigns ADD COLUMN IF NOT EXISTS headers JSONB NOT NULL DEFAULT '[]';`); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2021-12-18 18:08:42 +08:00
|
|
|
return nil
|
|
|
|
}
|