2023-08-25 12:58:35 +00:00
|
|
|
package db_config
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"database/sql"
|
|
|
|
)
|
|
|
|
|
|
|
|
type DatabaseConfiguration struct {
|
|
|
|
PruneDepth uint64
|
2023-08-25 22:41:57 +00:00
|
|
|
FullBlocks bool
|
2023-08-25 12:58:35 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
var DefaultDatabaseConfiguration = DatabaseConfiguration{
|
2023-09-01 13:29:17 +00:00
|
|
|
PruneDepth: 1000, // should be 1_000_000
|
2023-08-25 22:41:57 +00:00
|
|
|
FullBlocks: false,
|
2023-08-25 12:58:35 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func WriteConfigurationIfNotExist(ctx context.Context, tx *sql.Tx, cfg DatabaseConfiguration) error {
|
|
|
|
var count int
|
|
|
|
err := tx.QueryRow("SELECT COUNT(*) FROM data_config;").Scan(&count)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if count > 0 {
|
|
|
|
return nil
|
|
|
|
}
|
2023-08-25 22:41:57 +00:00
|
|
|
_, err = tx.ExecContext(ctx, "INSERT INTO data_config (prune_depth, full_blocks) VALUES (?, ?);", cfg.PruneDepth, cfg.FullBlocks)
|
2023-08-25 12:58:35 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func ReadConfiguration(ctx context.Context, tx *sql.Tx) (DatabaseConfiguration, error) {
|
2023-08-25 22:41:57 +00:00
|
|
|
var (
|
|
|
|
pruneDepth uint64
|
|
|
|
fullBlocks bool
|
|
|
|
)
|
|
|
|
|
|
|
|
err := tx.QueryRowContext(ctx, "SELECT prune_depth, full_blocks FROM data_config").Scan(&pruneDepth, &fullBlocks)
|
2023-08-25 12:58:35 +00:00
|
|
|
if err != nil {
|
|
|
|
return DatabaseConfiguration{}, err
|
|
|
|
}
|
2023-08-25 22:41:57 +00:00
|
|
|
return DatabaseConfiguration{PruneDepth: pruneDepth, FullBlocks: fullBlocks}, nil
|
2023-08-25 12:58:35 +00:00
|
|
|
}
|