memos/store/db.go

71 lines
1.3 KiB
Go
Raw Normal View History

2021-12-10 13:41:17 +08:00
package store
import (
"database/sql"
2021-12-15 10:55:17 +08:00
"errors"
2021-12-12 12:14:40 +08:00
"io/ioutil"
2021-12-10 13:41:17 +08:00
"os"
2021-12-12 12:14:40 +08:00
"path/filepath"
2021-12-10 13:41:17 +08:00
_ "github.com/mattn/go-sqlite3"
)
/*
* Use a global variable to save the db connection: Quick and easy to setup.
* Reference: https://techinscribed.com/different-approaches-to-pass-database-connection-into-controllers-in-golang/
*/
var DB *sql.DB
func InitDBConn() {
2021-12-12 12:52:58 +08:00
// mounting point in docker is "/usr/local/memos/data"
dbFilePath := "./data/memos.db"
2021-12-10 13:41:17 +08:00
if _, err := os.Stat(dbFilePath); err != nil {
dbFilePath = "./resources/memos.db"
println("use the default database")
} else {
println("use the custom database")
}
db, err := sql.Open("sqlite3", dbFilePath)
if err != nil {
2021-12-12 11:43:27 +08:00
panic("db connect failed")
2021-12-10 13:41:17 +08:00
} else {
DB = db
println("connect to sqlite succeed")
}
2021-12-12 12:14:40 +08:00
if dbFilePath == "./resources/memos.db" {
resetDataInDefaultDatabase()
}
2021-12-10 13:41:17 +08:00
}
func FormatDBError(err error) error {
if err == nil {
return nil
}
2021-12-15 10:55:17 +08:00
switch err {
case sql.ErrNoRows:
return errors.New("data not found")
2021-12-10 13:41:17 +08:00
default:
return err
}
}
func resetDataInDefaultDatabase() {
2021-12-12 12:14:40 +08:00
initialSQLFilePath := filepath.Join("resources", "initial_db.sql")
c, err := ioutil.ReadFile(initialSQLFilePath)
if err != nil {
// do nth
return
}
sql := string(c)
DB.Exec(sql)
println("Initial data succeed")
2021-12-10 13:41:17 +08:00
}