2022-07-06 23:19:05 +02:00
|
|
|
//go:build !cgo
|
|
|
|
|
|
|
|
package core
|
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/pocketbase/dbx"
|
|
|
|
_ "modernc.org/sqlite"
|
|
|
|
)
|
|
|
|
|
|
|
|
func connectDB(dbPath string) (*dbx.DB, error) {
|
2023-05-27 08:04:01 +02:00
|
|
|
// Note: the busy_timeout pragma must be first because
|
|
|
|
// the connection needs to be set to block on busy before WAL mode
|
|
|
|
// is set in case it hasn't been already set by another connection.
|
2023-07-24 09:35:42 +02:00
|
|
|
pragmas := "?_pragma=busy_timeout(10000)&_pragma=journal_mode(WAL)&_pragma=journal_size_limit(200000000)&_pragma=synchronous(NORMAL)&_pragma=foreign_keys(ON)&_pragma=temp_store(MEMORY)&_pragma=cache_size(-16000)"
|
2022-11-01 20:29:07 +02:00
|
|
|
|
2023-05-27 08:04:01 +02:00
|
|
|
db, err := dbx.Open("sqlite", dbPath+pragmas)
|
|
|
|
if err != nil {
|
2022-12-15 16:42:35 +02:00
|
|
|
return nil, err
|
|
|
|
}
|
2022-11-01 20:29:07 +02:00
|
|
|
|
|
|
|
return db, nil
|
2022-07-06 23:19:05 +02:00
|
|
|
}
|