erigon-pulse/cl/persistence/sql_migrations/migrations.go

58 lines
1.6 KiB
Go
Raw Normal View History

package sql_migrations
import (
"context"
"database/sql"
"errors"
)
var migrations = []string{
`CREATE TABLE IF NOT EXISTS beacon_indicies (
beacon_block_root BLOB NOT NULL CHECK(length(beacon_block_root) = 32),
slot INTEGER NOT NULL,
proposer_index INTEGER NOT NULL,
state_root BLOB NOT NULL CHECK(length(state_root) = 32),
parent_block_root BLOB NOT NULL CHECK(length(parent_block_root) = 32),
canonical INTEGER NOT NULL DEFAULT 0, -- 0 for false, 1 for true
body_root BLOB NOT NULL CHECK(length(state_root) = 32),
signature BLOB NOT NULL CHECK(length(signature) = 96),
PRIMARY KEY (beacon_block_root)
);`,
`CREATE INDEX idx_slot ON beacon_indicies (slot);`,
`CREATE INDEX idx_state_root ON beacon_indicies (state_root);`,
`CREATE INDEX idx_parent_block_root ON beacon_indicies (parent_block_root);`,
`CREATE TABLE IF NOT EXISTS data_config (
prune_depth INTEGER NOT NULL
);`,
}
func ApplyMigrations(ctx context.Context, tx *sql.Tx) error {
if _, err := tx.ExecContext(ctx, "CREATE TABLE IF NOT EXISTS schema_version (version INTEGER NOT NULL);"); err != nil {
return err
}
// Get current schema version
var currentVersion int
err := tx.QueryRow("SELECT version FROM schema_version").Scan(&currentVersion)
if errors.Is(err, sql.ErrNoRows) {
currentVersion = -1
} else if err != nil {
return err
}
// Apply missing migrations
for i := currentVersion + 1; i < len(migrations); i++ {
_, err = tx.Exec(migrations[i])
if err != nil {
return err
}
// Update schema version
_, err = tx.Exec("UPDATE schema_version SET version = ?", i)
if err != nil {
return err
}
}
return nil
}