2023-08-21 23:24:26 +00:00
|
|
|
package sql_migrations
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"database/sql"
|
|
|
|
"errors"
|
|
|
|
)
|
|
|
|
|
|
|
|
var migrations = []string{
|
|
|
|
`CREATE TABLE IF NOT EXISTS beacon_indicies (
|
2023-08-25 15:45:00 +00:00
|
|
|
beacon_block_root BLOB NOT NULL CHECK(length(beacon_block_root) = 32),
|
2023-08-21 23:24:26 +00:00
|
|
|
slot INTEGER NOT NULL,
|
2023-08-25 22:41:57 +00:00
|
|
|
proposer_index INTEGER NOT NULL,
|
2023-08-21 23:24:26 +00:00
|
|
|
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
|
2023-08-29 14:47:16 +00:00
|
|
|
body_root BLOB NOT NULL CHECK(length(state_root) = 32),
|
|
|
|
signature BLOB NOT NULL CHECK(length(signature) = 96),
|
2023-08-25 15:45:00 +00:00
|
|
|
PRIMARY KEY (beacon_block_root)
|
2023-08-21 23:24:26 +00:00
|
|
|
);`,
|
2023-08-25 15:45:00 +00:00
|
|
|
`CREATE INDEX idx_slot ON beacon_indicies (slot);`,
|
2023-08-29 14:47:16 +00:00
|
|
|
`CREATE INDEX idx_state_root ON beacon_indicies (state_root);`,
|
|
|
|
`CREATE INDEX idx_parent_block_root ON beacon_indicies (parent_block_root);`,
|
2023-08-25 22:41:57 +00:00
|
|
|
`CREATE TABLE IF NOT EXISTS data_config (
|
2023-09-14 20:14:05 +00:00
|
|
|
prune_depth INTEGER NOT NULL
|
2023-08-25 22:41:57 +00:00
|
|
|
);`,
|
2023-08-21 23:24:26 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
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(¤tVersion)
|
|
|
|
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
|
|
|
|
}
|