pages-server/server/database/xorm.go

123 lines
2.5 KiB
Go
Raw Normal View History

2023-02-09 15:19:16 +01:00
package database
import (
2023-02-09 17:52:30 +01:00
"errors"
2023-02-09 15:19:16 +01:00
"fmt"
2023-02-09 19:14:53 +01:00
"strings"
2023-02-09 15:19:16 +01:00
2023-02-09 17:52:30 +01:00
"github.com/rs/zerolog/log"
2023-02-09 15:19:16 +01:00
"github.com/go-acme/lego/v4/certificate"
"xorm.io/xorm"
// register sql driver
_ "github.com/go-sql-driver/mysql"
_ "github.com/lib/pq"
_ "github.com/mattn/go-sqlite3"
)
var _ CertDB = xDB{}
2023-02-09 17:52:30 +01:00
var ErrNotFound = errors.New("entry not found")
2023-02-09 15:19:16 +01:00
type xDB struct {
engine *xorm.Engine
}
func NewXormDB(dbType, dbConn string) (CertDB, error) {
if !supportedDriver(dbType) {
return nil, fmt.Errorf("not supported db type '%s'", dbType)
}
2023-02-09 19:14:53 +01:00
if dbConn == "" {
return nil, fmt.Errorf("no db connection provided")
}
2023-02-09 15:19:16 +01:00
e, err := xorm.NewEngine(dbType, dbConn)
if err != nil {
return nil, err
}
if err := e.Sync2(new(Cert)); err != nil {
return nil, fmt.Errorf("cound not sync db model :%w", err)
}
return &xDB{
engine: e,
}, nil
}
func (x xDB) Close() error {
return x.engine.Close()
}
2023-02-09 19:14:53 +01:00
func (x xDB) Put(domain string, cert *certificate.Resource) error {
log.Trace().Str("domain", cert.Domain).Msg("inserting cert to db")
c, err := toCert(domain, cert)
2023-02-09 17:52:30 +01:00
if err != nil {
return err
}
2023-02-09 19:14:53 +01:00
2023-02-09 17:52:30 +01:00
_, err = x.engine.Insert(c)
return err
2023-02-09 15:19:16 +01:00
}
2023-02-09 19:14:53 +01:00
func (x xDB) Get(domain string) (*certificate.Resource, error) {
// TODO: do we need this or can we just go with domain name for wildcard cert
domain = strings.TrimPrefix(domain, ".")
2023-02-09 17:52:30 +01:00
cert := new(Cert)
2023-02-09 19:14:53 +01:00
log.Trace().Str("domain", domain).Msg("get cert from db")
if _, err := x.engine.ID(domain).Get(&cert); err != nil {
2023-02-09 17:52:30 +01:00
return nil, err
}
if cert == nil {
2023-02-09 19:14:53 +01:00
return nil, fmt.Errorf("%w: name='%s'", ErrNotFound, domain)
2023-02-09 17:52:30 +01:00
}
return cert.Raw(), nil
2023-02-09 15:19:16 +01:00
}
2023-02-09 19:14:53 +01:00
func (x xDB) Delete(domain string) error {
log.Trace().Str("domain", domain).Msg("delete cert from db")
_, err := x.engine.ID(domain).Delete(new(Cert))
2023-02-09 17:52:30 +01:00
return err
2023-02-09 15:19:16 +01:00
}
func (x xDB) Compact() (string, error) {
2023-02-09 17:52:30 +01:00
// not needed
return "", nil
2023-02-09 15:19:16 +01:00
}
2023-02-09 17:52:30 +01:00
// Items return al certs from db, if pageSize is 0 it does not use limit
func (x xDB) Items(page, pageSize int) ([]*Cert, error) {
// paginated return
2023-02-09 21:27:47 +01:00
if pageSize > 0 {
2023-02-09 17:52:30 +01:00
certs := make([]*Cert, 0, pageSize)
if page >= 0 {
page = 1
}
err := x.engine.Limit(pageSize, (page-1)*pageSize).Find(&certs)
return certs, err
}
// return all
certs := make([]*Cert, 0, 64)
2023-02-09 19:14:53 +01:00
err := x.engine.Find(&certs)
return certs, err
2023-02-09 15:19:16 +01:00
}
// Supported database drivers
const (
DriverSqlite = "sqlite3"
DriverMysql = "mysql"
DriverPostgres = "postgres"
)
func supportedDriver(driver string) bool {
switch driver {
case DriverMysql, DriverPostgres, DriverSqlite:
return true
default:
return false
}
}