mirror of
https://github.com/neilalexander/yggmail.git
synced 2026-04-18 08:06:28 +03:00
41 lines
881 B
Go
41 lines
881 B
Go
package sqlite3
|
|
|
|
import (
|
|
"database/sql"
|
|
"fmt"
|
|
|
|
_ "github.com/mattn/go-sqlite3"
|
|
)
|
|
|
|
type SQLite3Storage struct {
|
|
*TableConfig
|
|
*TableMailboxes
|
|
*TableMails
|
|
*TableQueue
|
|
}
|
|
|
|
func NewSQLite3StorageStorage(filename string) (*SQLite3Storage, error) {
|
|
db, err := sql.Open("sqlite3", "file:"+filename+"?_foreign_keys=on")
|
|
if err != nil {
|
|
return nil, fmt.Errorf("sql.Open: %w", err)
|
|
}
|
|
s := &SQLite3Storage{}
|
|
s.TableConfig, err = NewTableConfig(db)
|
|
if err != nil {
|
|
return nil, fmt.Errorf("NewTableConfig: %w", err)
|
|
}
|
|
s.TableMailboxes, err = NewTableMailboxes(db)
|
|
if err != nil {
|
|
return nil, fmt.Errorf("NewTableMailboxes: %w", err)
|
|
}
|
|
s.TableMails, err = NewTableMails(db)
|
|
if err != nil {
|
|
return nil, fmt.Errorf("NewTableMails: %w", err)
|
|
}
|
|
s.TableQueue, err = NewTableQueue(db)
|
|
if err != nil {
|
|
return nil, fmt.Errorf("NewTableQueue: %w", err)
|
|
}
|
|
return s, nil
|
|
}
|