MQTTListener/models/db.go

35 lines
593 B
Go
Raw Normal View History

package models
import (
"database/sql"
_ "github.com/mattn/go-sqlite3"
)
type Datastore interface {
AllDevices() ([]*Device, error)
InsertDevice(*Device) error
}
type DB struct {
*sql.DB
}
func NewDB(dataSourceName string) (*DB, error) {
db, err := sql.Open("sqlite3", dataSourceName)
if err != nil {
return nil, err
}
if err = db.Ping(); err != nil {
return nil, err
}
sqlStmt := "CREATE TABLE IF NOT EXISTS devices (id TEXT not null primary key, mac TEXT, sn TEXT, lastMsg TEXT);"
_, err = db.Exec(sqlStmt)
if err != nil {
return nil, err
}
return &DB{db}, nil
}