fathom/pkg/datastore/sqlstore/config.go

68 lines
1.3 KiB
Go
Raw Normal View History

package sqlstore
2018-05-08 10:31:51 +00:00
import (
mysql "github.com/go-sql-driver/mysql"
2018-07-30 07:33:49 +00:00
"strings"
)
2018-05-08 10:31:51 +00:00
type Config struct {
2018-07-29 16:32:04 +00:00
URL string `default:""`
Driver string `default:"sqlite3"`
2018-05-08 10:31:51 +00:00
Host string `default:""`
User string `default:""`
Password string `default:""`
Name string `default:"fathom.db"`
SSLMode string `default:""`
2018-05-08 10:31:51 +00:00
}
func (c *Config) DSN() string {
var dsn string
// if FATHOM_DATABASE_URL was set, use that
// this relies on the user to set the appropriate parameters, eg ?parseTime=true when using MySQL
if c.URL != "" {
return c.URL
}
// otherwise, generate from individual fields
2018-05-08 10:31:51 +00:00
switch c.Driver {
case "postgres":
params := map[string]string{
"host": c.Host,
"dbname": c.Name,
"user": c.User,
"password": c.Password,
"sslmode": c.SSLMode,
}
2018-07-30 07:33:49 +00:00
for k, v := range params {
if v == "" {
continue
2018-07-29 16:32:04 +00:00
}
dsn = dsn + k + "=" + v + " "
2018-07-29 16:32:04 +00:00
}
dsn = strings.TrimSpace(dsn)
2018-05-08 10:31:51 +00:00
case "mysql":
mc := mysql.NewConfig()
mc.User = c.User
mc.Passwd = c.Password
mc.Addr = c.Host
mc.Net = "tcp"
mc.DBName = c.Name
mc.Params = map[string]string{
"parseTime": "true",
"loc": "Local",
}
if c.SSLMode != "" {
mc.Params["tls"] = c.SSLMode
}
dsn = mc.FormatDSN()
case "sqlite3":
dsn = c.Name + "?_loc=auto"
2018-05-08 10:31:51 +00:00
}
return dsn
}