2017-05-15 01:31:17 +02:00
package database
import (
2017-05-17 07:58:40 +02:00
"github.com/NyaaPantsu/nyaa/common"
"github.com/NyaaPantsu/nyaa/config"
"github.com/NyaaPantsu/nyaa/database/postgres"
//"github.com/NyaaPantsu/nyaa/db/sqlite"
"github.com/NyaaPantsu/nyaa/model"
"github.com/NyaaPantsu/nyaa/util/log"
2017-05-15 01:31:17 +02:00
"errors"
)
// Database obstraction layer
type Database interface {
// Initialize internal state
Init ( ) error
// return true if we need to call MigrateNext again
NeedsMigrate ( ) ( bool , error )
// migrate to next database revision
MigrateNext ( ) error
// get torrents given parameters
GetTorrentsWhere ( param * common . TorrentParam ) ( [ ] model . Torrent , error )
// insert new comment
InsertComment ( comment * model . Comment ) error
// new torrent report
InsertTorrentReport ( report * model . TorrentReport ) error
// check if user A follows B (by id)
UserFollows ( a , b uint32 ) ( bool , error )
// delete reports given params
DeleteTorrentReportsWhere ( param * common . ReportParam ) ( uint32 , error )
// get reports given params
GetTorrentReportsWhere ( param * common . ReportParam ) ( [ ] model . TorrentReport , error )
// bulk record scrape events in 1 transaction
RecordScrapes ( scrapes [ ] common . ScrapeResult ) error
// insert new user
InsertUser ( u * model . User ) error
// update existing user info
UpdateUser ( u * model . User ) error
// get users given paramteters
GetUsersWhere ( param * common . UserParam ) ( [ ] model . User , error )
// delete many users given parameters
DeleteUsersWhere ( param * common . UserParam ) ( uint32 , error )
// get comments by given parameters
GetCommentsWhere ( param * common . CommentParam ) ( [ ] model . Comment , error )
// delete comment by given parameters
DeleteCommentsWhere ( param * common . CommentParam ) ( uint32 , error )
// add user A following B
AddUserFollowing ( a , b uint32 ) error
// delete user A following B
DeleteUserFollowing ( a , b uint32 ) ( bool , error )
// insert/update torrent
UpsertTorrent ( t * model . Torrent ) error
2017-05-15 01:46:33 +02:00
// XXX: add more as needed
2017-05-15 01:31:17 +02:00
}
2017-05-26 12:12:52 +02:00
var errInvalidDatabaseDialect = errors . New ( "invalid database dialect" )
var errSqliteSucksAss = errors . New ( "sqlite3 sucks ass so it's not supported yet" )
2017-05-15 01:31:17 +02:00
2017-05-26 12:12:52 +02:00
// Impl : Database variable
2017-05-15 01:31:17 +02:00
var Impl Database
2017-05-26 12:12:52 +02:00
// Configure : Configure Database
2017-05-15 01:31:17 +02:00
func Configure ( conf * config . Config ) ( err error ) {
switch conf . DBType {
case "postgres" :
Impl , err = postgres . New ( conf . DBParams )
break
case "sqlite3" :
2017-05-26 12:12:52 +02:00
err = errSqliteSucksAss
2017-05-15 01:31:17 +02:00
// Impl, err = sqlite.New(conf.DBParams)
break
default :
2017-05-26 12:12:52 +02:00
err = errInvalidDatabaseDialect
2017-05-15 01:31:17 +02:00
}
if err == nil {
log . Infof ( "Init %s database" , conf . DBType )
err = Impl . Init ( )
}
return
}
// Migrate migrates the database to latest revision, call after Configure
func Migrate ( ) ( err error ) {
next := true
for err == nil && next {
next , err = Impl . NeedsMigrate ( )
if next {
err = Impl . MigrateNext ( )
}
}
return
}