services/rfq/guard/guarddb/connect/sql.go
// Package connect contains the database connection logic for the RFQ relayer.
// TODO: this is a dumb name for a package in a dumb place. Move it somewhere else.
package connect
import (
"context"
"errors"
"fmt"
"github.com/synapsecns/sanguine/core/dbcommon"
"github.com/synapsecns/sanguine/core/metrics"
"github.com/synapsecns/sanguine/services/rfq/guard/guarddb"
"github.com/synapsecns/sanguine/services/rfq/guard/guarddb/mysql"
"github.com/synapsecns/sanguine/services/rfq/guard/guarddb/sqlite"
)
// Connect connects to the database.
func Connect(ctx context.Context, dbType dbcommon.DBType, path string, metrics metrics.Handler) (guarddb.Service, error) {
switch dbType {
case dbcommon.Mysql:
store, err := mysql.NewMysqlStore(ctx, path, metrics)
if err != nil {
return nil, fmt.Errorf("could not create mysql store: %w", err)
}
return store, nil
case dbcommon.Sqlite:
store, err := sqlite.NewSqliteStore(ctx, path, metrics)
if err != nil {
return nil, fmt.Errorf("could not create sqlite store: %w", err)
}
return store, nil
case dbcommon.Clickhouse:
return nil, errors.New("driver not supported")
default:
return nil, fmt.Errorf("unsupported driver: %s", dbType)
}
}