package dbimpl import ( "context" "database/sql" "github.com/grafana/grafana/pkg/storage/unified/sql/db" ) // NewDB converts a *sql.DB to a db.DB. func NewDB(d *sql.DB, driverName string) db.DB { ret := sqlDB{ DB: d, driverName: driverName, } ret.WithTxFunc = db.NewWithTxFunc(ret.BeginTx) return ret } type sqlDB struct { *sql.DB db.WithTxFunc driverName string } func (d sqlDB) DriverName() string { return d.driverName } func (d sqlDB) QueryContext(ctx context.Context, query string, args ...any) (db.Rows, error) { return d.DB.QueryContext(ctx, query, args...) } func (d sqlDB) QueryRowContext(ctx context.Context, query string, args ...any) db.Row { return d.DB.QueryRowContext(ctx, query, args...) } func (d sqlDB) BeginTx(ctx context.Context, opts *sql.TxOptions) (db.Tx, error) { tx, err := d.DB.BeginTx(ctx, opts) if err != nil { return nil, err } return sqlTx{tx}, err } type sqlTx struct { *sql.Tx } func (tx sqlTx) QueryContext(ctx context.Context, query string, args ...any) (db.Rows, error) { // // codeql-suppress go/sql-query-built-from-user-controlled-sources "The query comes from a safe template source // and the parameters are passed as arguments." return tx.Tx.QueryContext(ctx, query, args...) } func (tx sqlTx) QueryRowContext(ctx context.Context, query string, args ...any) db.Row { // // codeql-suppress go/sql-query-built-from-user-controlled-sources "The query comes from a safe template source // and the parameters are passed as arguments." return tx.Tx.QueryRowContext(ctx, query, args...) }