1
0
Fork 0
mirror of https://github.com/Eggbertx/gochan.git synced 2025-09-04 10:06:24 -07:00
gochan/cmd/gochan-migration/internal/gcupdate/updatemysql.go

186 lines
5.2 KiB
Go
Raw Normal View History

package gcupdate
import (
"context"
"database/sql"
"github.com/gochan-org/gochan/cmd/gochan-migration/internal/common"
"github.com/gochan-org/gochan/pkg/config"
"github.com/gochan-org/gochan/pkg/gcutil"
2024-10-13 20:30:38 -07:00
"github.com/rs/zerolog"
)
func updateMysqlDB(ctx context.Context, dbu *GCDatabaseUpdater, sqlConfig *config.SQLConfig, errEv *zerolog.Event) (err error) {
var query string
var dataType string
2024-10-13 20:30:38 -07:00
defer func() {
if a := recover(); a != nil {
errEv.Caller(4).Interface("panic", a).Send()
errEv.Discard()
} else if err != nil {
2024-10-13 20:30:38 -07:00
errEv.Err(err).Caller(1).Send()
errEv.Discard()
}
2024-10-13 20:30:38 -07:00
}()
dbName := sqlConfig.DBname
db := dbu.db
2024-10-13 20:30:38 -07:00
// fix default collation
query = `ALTER DATABASE ` + dbName + ` CHARACTER SET = utf8mb4 COLLATE = utf8mb4_unicode_ci`
2024-10-13 20:30:38 -07:00
if _, err = db.GetBaseDB().ExecContext(ctx, query); err != nil {
return err
}
2024-10-13 20:30:38 -07:00
var rows *sql.Rows
query = `SELECT TABLE_NAME FROM information_schema.TABLES WHERE TABLE_SCHEMA = ?`
2024-10-13 20:30:38 -07:00
rows, err = db.QueryContextSQL(ctx, nil, query, dbName)
if err != nil {
return err
}
defer func() {
rows.Close()
}()
var tableName string
for rows.Next() {
err = rows.Scan(&tableName)
if err != nil {
return err
}
query = `ALTER TABLE ` + tableName + ` CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci`
2024-10-13 20:30:38 -07:00
if _, err = db.ExecContextSQL(ctx, nil, query); err != nil {
return err
}
}
if err = rows.Close(); err != nil {
return err
}
2024-10-13 20:30:38 -07:00
dataType, err = common.ColumnType(ctx, db, nil, "ip", "DBPREFIXip_ban", sqlConfig)
if err != nil {
return err
}
if dataType != "" {
// add range_start and range_end columns
query = `ALTER TABLE DBPREFIXip_ban
ADD COLUMN IF NOT EXISTS range_start VARBINARY(16) NOT NULL,
ADD COLUMN IF NOT EXISTS range_end VARBINARY(16) NOT NULL`
2024-10-13 20:30:38 -07:00
if _, err = db.ExecContextSQL(ctx, nil, query); err != nil {
return err
}
2024-10-13 20:30:38 -07:00
// convert ban IP string to IP range
2024-10-13 20:30:38 -07:00
if rows, err = db.QueryContextSQL(ctx, nil, "SELECT id, ip FROM DBPREFIXip_ban"); err != nil {
return err
}
var rangeStart, rangeEnd string
for rows.Next() {
var id int
var ipOrCIDR string
if err = rows.Scan(&id, &ipOrCIDR); err != nil {
return err
}
if rangeStart, rangeEnd, err = gcutil.ParseIPRange(ipOrCIDR); err != nil {
return err
}
query = `UPDATE DBPREFIXip_ban
SET range_start = INET6_ATON(?), range_end = INET6_ATON(?) WHERE id = ?`
2024-10-13 20:30:38 -07:00
if _, err = db.ExecContextSQL(ctx, nil, query, rangeStart, rangeEnd, id); err != nil {
return err
}
query = `ALTER TABLE DBPREFIXip_ban DROP COLUMN IF EXISTS ip`
2024-10-13 20:30:38 -07:00
if _, err = db.ExecContextSQL(ctx, nil, query); err != nil {
return err
}
}
if err = rows.Close(); err != nil {
return err
}
}
// Convert DBPREFIXposts.ip to from varchar to varbinary
2024-10-13 20:30:38 -07:00
dataType, err = common.ColumnType(ctx, db, nil, "ip", "DBPREFIXposts", sqlConfig)
if err != nil {
return err
}
if common.IsStringType(dataType) {
// rename `ip` to a temporary column to then be removed
2024-10-13 20:30:38 -07:00
query = "ALTER TABLE DBPREFIXposts CHANGE ip ip_str varchar(45)"
if _, err = db.ExecContextSQL(ctx, nil, query); err != nil {
return err
}
query = `ALTER TABLE DBPREFIXposts
ADD COLUMN IF NOT EXISTS ip VARBINARY(16) NOT NULL`
2024-10-13 20:30:38 -07:00
if _, err = db.ExecContextSQL(ctx, nil, query); err != nil {
return err
}
// convert post IP VARCHAR(45) to VARBINARY(16)
query = `UPDATE DBPREFIXposts SET ip = INET6_ATON(ip_str)`
2024-10-13 20:30:38 -07:00
if _, err = db.ExecContextSQL(ctx, nil, query); err != nil {
return err
}
query = `ALTER TABLE DBPREFIXposts DROP COLUMN IF EXISTS ip_str`
2024-10-13 20:30:38 -07:00
if _, err = db.ExecContextSQL(ctx, nil, query); err != nil {
return err
}
}
// Convert DBPREFIXreports.ip to from varchar to varbinary
2024-10-13 20:30:38 -07:00
dataType, err = common.ColumnType(ctx, db, nil, "ip", "DBPREFIXreports", sqlConfig)
if err != nil {
return err
}
if common.IsStringType(dataType) {
// rename `ip` to a temporary column to then be removed
2024-10-13 20:30:38 -07:00
query = "ALTER TABLE DBPREFIXreports CHANGE ip ip_str varchar(45)"
if _, err = db.ExecContextSQL(ctx, nil, query); err != nil {
return err
}
query = `ALTER TABLE DBPREFIXreports
ADD COLUMN IF NOT EXISTS ip VARBINARY(16) NOT NULL`
2024-10-13 20:30:38 -07:00
if _, err = db.ExecContextSQL(ctx, nil, query); err != nil {
return err
}
// convert report IP VARCHAR(45) to VARBINARY(16)
query = `UPDATE DBPREFIXreports SET ip = INET6_ATON(ip_str)`
2024-10-13 20:30:38 -07:00
if _, err = db.ExecContextSQL(ctx, nil, query); err != nil {
return err
}
query = `ALTER TABLE DBPREFIXreports DROP COLUMN IF EXISTS ip_str`
2024-10-13 20:30:38 -07:00
if _, err = db.ExecContextSQL(ctx, nil, query); err != nil {
return err
}
}
// add flag column to DBPREFIXposts
2024-10-13 20:30:38 -07:00
dataType, err = common.ColumnType(ctx, db, nil, "flag", "DBPREFIXposts", sqlConfig)
if err != nil {
return err
}
if dataType == "" {
query = `ALTER TABLE DBPREFIXposts ADD COLUMN flag VARCHAR(45) NOT NULL DEFAULT ''`
2024-10-13 20:30:38 -07:00
if _, err = db.ExecContextSQL(ctx, nil, query); err != nil {
return err
}
}
// add country column to DBPREFIXposts
2024-10-13 20:30:38 -07:00
dataType, err = common.ColumnType(ctx, db, nil, "country", "DBPREFIXposts", sqlConfig)
if err != nil {
return err
}
if dataType == "" {
query = `ALTER TABLE DBPREFIXposts ADD COLUMN country VARCHAR(80) NOT NULL DEFAULT ''`
2024-10-13 20:30:38 -07:00
if _, err = db.ExecContextSQL(ctx, nil, query); err != nil {
return err
}
}
return nil
}