mirror of
https://github.com/matrix-org/dendrite.git
synced 2024-06-14 21:16:39 +00:00
38 lines
996 B
Go
38 lines
996 B
Go
|
package storage
|
||
|
|
||
|
import (
|
||
|
"database/sql"
|
||
|
// Import the postgres database driver.
|
||
|
_ "github.com/lib/pq"
|
||
|
"github.com/matrix-org/dendrite/roomserver/types"
|
||
|
)
|
||
|
|
||
|
// A Database is used to store room events and stream offsets.
|
||
|
type Database struct {
|
||
|
statements statements
|
||
|
db *sql.DB
|
||
|
}
|
||
|
|
||
|
// Open a postgres database.
|
||
|
func Open(dataSourceName string) (*Database, error) {
|
||
|
var d Database
|
||
|
var err error
|
||
|
if d.db, err = sql.Open("postgres", dataSourceName); err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
if err = d.statements.prepare(d.db); err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
return &d, nil
|
||
|
}
|
||
|
|
||
|
// PartitionOffsets implements input.ConsumerDatabase
|
||
|
func (d *Database) PartitionOffsets(topic string) ([]types.PartitionOffset, error) {
|
||
|
return d.statements.selectPartitionOffsets(topic)
|
||
|
}
|
||
|
|
||
|
// SetPartitionOffset implements input.ConsumerDatabase
|
||
|
func (d *Database) SetPartitionOffset(topic string, partition int32, offset int64) error {
|
||
|
return d.statements.upsertPartitionOffset(topic, partition, offset)
|
||
|
}
|