2017-05-05 14:20:51 +02:00
package torrentService
2017-05-07 03:10:35 +02:00
2017-05-05 14:20:51 +02:00
import (
2017-05-07 03:10:35 +02:00
"errors"
2017-05-10 20:42:20 +02:00
"net/http"
2017-05-09 01:56:57 +02:00
"strconv"
"strings"
2017-05-07 03:10:35 +02:00
"github.com/ewhal/nyaa/config"
2017-05-05 14:20:51 +02:00
"github.com/ewhal/nyaa/db"
"github.com/ewhal/nyaa/model"
2017-05-10 20:42:20 +02:00
"github.com/ewhal/nyaa/service"
2017-05-07 03:10:35 +02:00
"github.com/ewhal/nyaa/util"
2017-05-05 14:20:51 +02:00
)
/ * Function to interact with Models
*
* Get the torrents with where clause
*
* /
// don't need raw SQL once we get MySQL
2017-05-09 19:23:21 +02:00
func GetFeeds ( ) ( result [ ] model . Feed , err error ) {
result = make ( [ ] model . Feed , 0 , 50 )
2017-05-05 14:20:51 +02:00
rows , err := db . ORM . DB ( ) .
Query (
2017-05-15 08:24:06 +02:00
"SELECT `torrent_id` AS `id`, `torrent_name` AS `name`, `torrent_hash` AS `hash`, `timestamp` FROM `" + config . TableName +
"` ORDER BY `timestamp` desc LIMIT 50" )
2017-05-09 19:23:21 +02:00
if err != nil {
return nil , err
}
defer rows . Close ( )
for rows . Next ( ) {
item := model . Feed { }
Consistency, formatting, error checking, cleanup, and a couple bug fixes (#245)
* Checkpoint: it builds
The config, db, model, network, os, and public packages have had some
fixes to glaringly obvious flaws, dead code removed, and stylistic
changes.
* Style changes and old code removal in router
Router needs a lot of work done to its (lack of) error handling.
* Dead code removal and style changes
Now up to util/email/email.go. After I'm finished with the initial sweep
I'll go back and fix error handling and security issues. Then I'll fix
the broken API. Then I'll go through to add documentation and fix code
visibility.
* Finish dead code removal and style changes
Vendored libraries not touched. Everything still needs security fixes
and documentation. There's also one case of broken functionality.
* Fix accidental find-and-replace
* Style, error checking, saftey, bug fix changes
* Redo error checking erased during merge
* Re-add merge-erased fix. Make Safe safe.
2017-05-10 04:34:40 +02:00
err = rows . Scan ( & item . ID , & item . Name , & item . Hash , & item . Timestamp )
2017-05-09 19:23:21 +02:00
if err != nil {
return
2017-05-05 14:20:51 +02:00
}
2017-05-09 19:23:21 +02:00
magnet := util . InfoHashToMagnet ( strings . TrimSpace ( item . Hash ) , item . Name , config . Trackers ... )
item . Magnet = magnet
Consistency, formatting, error checking, cleanup, and a couple bug fixes (#245)
* Checkpoint: it builds
The config, db, model, network, os, and public packages have had some
fixes to glaringly obvious flaws, dead code removed, and stylistic
changes.
* Style changes and old code removal in router
Router needs a lot of work done to its (lack of) error handling.
* Dead code removal and style changes
Now up to util/email/email.go. After I'm finished with the initial sweep
I'll go back and fix error handling and security issues. Then I'll fix
the broken API. Then I'll go through to add documentation and fix code
visibility.
* Finish dead code removal and style changes
Vendored libraries not touched. Everything still needs security fixes
and documentation. There's also one case of broken functionality.
* Fix accidental find-and-replace
* Style, error checking, saftey, bug fix changes
* Redo error checking erased during merge
* Re-add merge-erased fix. Make Safe safe.
2017-05-10 04:34:40 +02:00
// TODO: memory hog
2017-05-09 19:23:21 +02:00
result = append ( result , item )
2017-05-05 14:20:51 +02:00
}
2017-05-09 19:23:21 +02:00
err = rows . Err ( )
return
2017-05-05 14:20:51 +02:00
}
Consistency, formatting, error checking, cleanup, and a couple bug fixes (#245)
* Checkpoint: it builds
The config, db, model, network, os, and public packages have had some
fixes to glaringly obvious flaws, dead code removed, and stylistic
changes.
* Style changes and old code removal in router
Router needs a lot of work done to its (lack of) error handling.
* Dead code removal and style changes
Now up to util/email/email.go. After I'm finished with the initial sweep
I'll go back and fix error handling and security issues. Then I'll fix
the broken API. Then I'll go through to add documentation and fix code
visibility.
* Finish dead code removal and style changes
Vendored libraries not touched. Everything still needs security fixes
and documentation. There's also one case of broken functionality.
* Fix accidental find-and-replace
* Style, error checking, saftey, bug fix changes
* Redo error checking erased during merge
* Re-add merge-erased fix. Make Safe safe.
2017-05-10 04:34:40 +02:00
func GetTorrentById ( id string ) ( torrent model . Torrent , err error ) {
2017-05-10 02:30:41 +02:00
// Postgres DB integer size is 32-bit
2017-05-10 02:22:23 +02:00
id_int , err := strconv . ParseInt ( id , 10 , 32 )
2017-05-08 23:40:54 +02:00
if err != nil {
2017-05-09 19:23:21 +02:00
return
2017-05-08 23:40:54 +02:00
}
2017-05-05 14:20:51 +02:00
2017-05-15 08:24:06 +02:00
tmp := db . ORM . Table ( config . TableName ) . Where ( "torrent_id = ?" , id ) . Preload ( "Comments" ) . Preload ( "FileList" )
2017-05-09 19:23:21 +02:00
err = tmp . Error
if err != nil {
return
}
Consistency, formatting, error checking, cleanup, and a couple bug fixes (#245)
* Checkpoint: it builds
The config, db, model, network, os, and public packages have had some
fixes to glaringly obvious flaws, dead code removed, and stylistic
changes.
* Style changes and old code removal in router
Router needs a lot of work done to its (lack of) error handling.
* Dead code removal and style changes
Now up to util/email/email.go. After I'm finished with the initial sweep
I'll go back and fix error handling and security issues. Then I'll fix
the broken API. Then I'll go through to add documentation and fix code
visibility.
* Finish dead code removal and style changes
Vendored libraries not touched. Everything still needs security fixes
and documentation. There's also one case of broken functionality.
* Fix accidental find-and-replace
* Style, error checking, saftey, bug fix changes
* Redo error checking erased during merge
* Re-add merge-erased fix. Make Safe safe.
2017-05-10 04:34:40 +02:00
if id_int <= config . LastOldTorrentID {
2017-05-08 23:40:54 +02:00
// only preload old comments if they could actually exist
tmp = tmp . Preload ( "OldComments" )
}
if tmp . Find ( & torrent ) . RecordNotFound ( ) {
2017-05-09 19:23:21 +02:00
err = errors . New ( "Article is not found." )
return
2017-05-05 14:20:51 +02:00
}
2017-05-09 12:35:46 +02:00
// GORM relly likes not doing its job correctly
// (or maybe I'm just retarded)
torrent . Uploader = new ( model . User )
Consistency, formatting, error checking, cleanup, and a couple bug fixes (#245)
* Checkpoint: it builds
The config, db, model, network, os, and public packages have had some
fixes to glaringly obvious flaws, dead code removed, and stylistic
changes.
* Style changes and old code removal in router
Router needs a lot of work done to its (lack of) error handling.
* Dead code removal and style changes
Now up to util/email/email.go. After I'm finished with the initial sweep
I'll go back and fix error handling and security issues. Then I'll fix
the broken API. Then I'll go through to add documentation and fix code
visibility.
* Finish dead code removal and style changes
Vendored libraries not touched. Everything still needs security fixes
and documentation. There's also one case of broken functionality.
* Fix accidental find-and-replace
* Style, error checking, saftey, bug fix changes
* Redo error checking erased during merge
* Re-add merge-erased fix. Make Safe safe.
2017-05-10 04:34:40 +02:00
db . ORM . Where ( "user_id = ?" , torrent . UploaderID ) . Find ( torrent . Uploader )
2017-05-10 13:32:45 +02:00
torrent . OldUploader = ""
2017-05-13 17:30:29 +02:00
if torrent . ID <= config . LastOldTorrentID && torrent . UploaderID == 0 {
2017-05-10 13:32:45 +02:00
var tmp model . UserUploadsOld
if ! db . ORM . Where ( "torrent_id = ?" , torrent . ID ) . Find ( & tmp ) . RecordNotFound ( ) {
torrent . OldUploader = tmp . Username
}
}
2017-05-08 21:18:48 +02:00
for i := range torrent . Comments {
torrent . Comments [ i ] . User = new ( model . User )
Consistency, formatting, error checking, cleanup, and a couple bug fixes (#245)
* Checkpoint: it builds
The config, db, model, network, os, and public packages have had some
fixes to glaringly obvious flaws, dead code removed, and stylistic
changes.
* Style changes and old code removal in router
Router needs a lot of work done to its (lack of) error handling.
* Dead code removal and style changes
Now up to util/email/email.go. After I'm finished with the initial sweep
I'll go back and fix error handling and security issues. Then I'll fix
the broken API. Then I'll go through to add documentation and fix code
visibility.
* Finish dead code removal and style changes
Vendored libraries not touched. Everything still needs security fixes
and documentation. There's also one case of broken functionality.
* Fix accidental find-and-replace
* Style, error checking, saftey, bug fix changes
* Redo error checking erased during merge
* Re-add merge-erased fix. Make Safe safe.
2017-05-10 04:34:40 +02:00
err = db . ORM . Where ( "user_id = ?" , torrent . Comments [ i ] . UserID ) . Find ( torrent . Comments [ i ] . User ) . Error
2017-05-09 19:23:21 +02:00
if err != nil {
return
}
2017-05-08 21:18:48 +02:00
}
2017-05-05 14:20:51 +02:00
2017-05-09 19:23:21 +02:00
return
2017-05-05 14:20:51 +02:00
}
2017-05-13 17:29:21 +02:00
// won't fetch user or comments
func GetRawTorrentById ( id uint ) ( torrent model . Torrent , err error ) {
err = nil
2017-05-15 08:24:06 +02:00
if db . ORM . Table ( config . TableName ) . Table ( config . TableName ) . Where ( "torrent_id = ?" , id ) . Find ( & torrent ) . RecordNotFound ( ) {
2017-05-13 17:29:21 +02:00
err = errors . New ( "Article is not found." )
}
return
}
2017-05-10 20:42:20 +02:00
func GetTorrentsOrderByNoCount ( parameters * serviceBase . WhereParams , orderBy string , limit int , offset int ) ( torrents [ ] model . Torrent , err error ) {
2017-05-09 17:07:42 +02:00
torrents , _ , err = getTorrentsOrderBy ( parameters , orderBy , limit , offset , false )
return
}
2017-05-10 20:42:20 +02:00
func GetTorrentsOrderBy ( parameters * serviceBase . WhereParams , orderBy string , limit int , offset int ) ( torrents [ ] model . Torrent , count int , err error ) {
2017-05-09 17:07:42 +02:00
torrents , count , err = getTorrentsOrderBy ( parameters , orderBy , limit , offset , true )
return
}
2017-05-10 20:42:20 +02:00
func getTorrentsOrderBy ( parameters * serviceBase . WhereParams , orderBy string , limit int , offset int , countAll bool ) (
Consistency, formatting, error checking, cleanup, and a couple bug fixes (#245)
* Checkpoint: it builds
The config, db, model, network, os, and public packages have had some
fixes to glaringly obvious flaws, dead code removed, and stylistic
changes.
* Style changes and old code removal in router
Router needs a lot of work done to its (lack of) error handling.
* Dead code removal and style changes
Now up to util/email/email.go. After I'm finished with the initial sweep
I'll go back and fix error handling and security issues. Then I'll fix
the broken API. Then I'll go through to add documentation and fix code
visibility.
* Finish dead code removal and style changes
Vendored libraries not touched. Everything still needs security fixes
and documentation. There's also one case of broken functionality.
* Fix accidental find-and-replace
* Style, error checking, saftey, bug fix changes
* Redo error checking erased during merge
* Re-add merge-erased fix. Make Safe safe.
2017-05-10 04:34:40 +02:00
torrents [ ] model . Torrent , count int , err error ,
2017-05-09 19:23:21 +02:00
) {
2017-05-08 22:46:49 +02:00
var conditionArray [ ] string
2017-05-10 13:09:23 +02:00
conditionArray = append ( conditionArray , "deleted_at IS NULL" )
2017-05-05 14:20:51 +02:00
var params [ ] interface { }
if parameters != nil { // if there is where parameters
2017-05-08 16:53:15 +02:00
if len ( parameters . Conditions ) > 0 {
2017-05-08 22:46:49 +02:00
conditionArray = append ( conditionArray , parameters . Conditions )
2017-05-08 16:53:15 +02:00
}
2017-05-05 14:51:19 +02:00
params = parameters . Params
2017-05-05 14:20:51 +02:00
}
2017-05-08 22:46:49 +02:00
conditions := strings . Join ( conditionArray , " AND " )
2017-05-09 17:07:42 +02:00
if countAll {
2017-05-10 13:09:23 +02:00
// FIXME: `deleted_at IS NULL` is duplicate in here because GORM handles this for us
2017-05-15 08:24:06 +02:00
err = db . ORM . Model ( & torrents ) . Table ( config . TableName ) . Where ( conditions , params ... ) . Count ( & count ) . Error
2017-05-09 17:07:42 +02:00
if err != nil {
return
}
2017-05-09 13:31:58 +02:00
}
2017-05-10 13:09:23 +02:00
// TODO: Vulnerable to injections. Use query builder. (is it?)
2017-05-08 22:46:49 +02:00
// build custom db query for performance reasons
2017-05-15 08:24:06 +02:00
dbQuery := "SELECT * FROM " + config . TableName
2017-05-08 15:50:18 +02:00
if conditions != "" {
dbQuery = dbQuery + " WHERE " + conditions
}
2017-05-12 19:38:08 +02:00
/ * This makes all queries take roughly the same amount of time ( lots ) ...
2017-05-12 17:54:08 +02:00
if strings . Contains ( conditions , "torrent_name" ) && offset > 0 {
2017-05-08 15:50:18 +02:00
dbQuery = "WITH t AS (SELECT * FROM torrents WHERE " + conditions + ") SELECT * FROM t"
2017-05-12 19:38:08 +02:00
} * /
2017-05-05 14:20:51 +02:00
2017-05-07 21:04:21 +02:00
if orderBy == "" { // default OrderBy
2017-05-05 14:20:51 +02:00
orderBy = "torrent_id DESC"
2017-05-07 21:04:21 +02:00
}
2017-05-08 15:50:18 +02:00
dbQuery = dbQuery + " ORDER BY " + orderBy
2017-05-05 14:20:51 +02:00
if limit != 0 || offset != 0 { // if limits provided
2017-05-08 15:50:18 +02:00
dbQuery = dbQuery + " LIMIT " + strconv . Itoa ( limit ) + " OFFSET " + strconv . Itoa ( offset )
2017-05-05 14:20:51 +02:00
}
2017-05-17 00:05:16 +02:00
err = db . ORM . Preload ( "Comments" ) . Raw ( dbQuery , params ... ) . Find ( & torrents ) . Error
2017-05-09 13:31:58 +02:00
return
2017-05-05 14:20:51 +02:00
}
Consistency, formatting, error checking, cleanup, and a couple bug fixes (#245)
* Checkpoint: it builds
The config, db, model, network, os, and public packages have had some
fixes to glaringly obvious flaws, dead code removed, and stylistic
changes.
* Style changes and old code removal in router
Router needs a lot of work done to its (lack of) error handling.
* Dead code removal and style changes
Now up to util/email/email.go. After I'm finished with the initial sweep
I'll go back and fix error handling and security issues. Then I'll fix
the broken API. Then I'll go through to add documentation and fix code
visibility.
* Finish dead code removal and style changes
Vendored libraries not touched. Everything still needs security fixes
and documentation. There's also one case of broken functionality.
* Fix accidental find-and-replace
* Style, error checking, saftey, bug fix changes
* Redo error checking erased during merge
* Re-add merge-erased fix. Make Safe safe.
2017-05-10 04:34:40 +02:00
// GetTorrents obtain a list of torrents matching 'parameters' from the
// database. The list will be of length 'limit' and in default order.
// GetTorrents returns the first records found. Later records may be retrieved
// by providing a positive 'offset'
2017-05-10 20:42:20 +02:00
func GetTorrents ( parameters serviceBase . WhereParams , limit int , offset int ) ( [ ] model . Torrent , int , error ) {
2017-05-05 14:20:51 +02:00
return GetTorrentsOrderBy ( & parameters , "" , limit , offset )
}
Consistency, formatting, error checking, cleanup, and a couple bug fixes (#245)
* Checkpoint: it builds
The config, db, model, network, os, and public packages have had some
fixes to glaringly obvious flaws, dead code removed, and stylistic
changes.
* Style changes and old code removal in router
Router needs a lot of work done to its (lack of) error handling.
* Dead code removal and style changes
Now up to util/email/email.go. After I'm finished with the initial sweep
I'll go back and fix error handling and security issues. Then I'll fix
the broken API. Then I'll go through to add documentation and fix code
visibility.
* Finish dead code removal and style changes
Vendored libraries not touched. Everything still needs security fixes
and documentation. There's also one case of broken functionality.
* Fix accidental find-and-replace
* Style, error checking, saftey, bug fix changes
* Redo error checking erased during merge
* Re-add merge-erased fix. Make Safe safe.
2017-05-10 04:34:40 +02:00
// Get Torrents with where parameters but no limit and order by default (get all the torrents corresponding in the db)
2017-05-10 20:42:20 +02:00
func GetTorrentsDB ( parameters serviceBase . WhereParams ) ( [ ] model . Torrent , int , error ) {
2017-05-05 14:20:51 +02:00
return GetTorrentsOrderBy ( & parameters , "" , 0 , 0 )
}
Consistency, formatting, error checking, cleanup, and a couple bug fixes (#245)
* Checkpoint: it builds
The config, db, model, network, os, and public packages have had some
fixes to glaringly obvious flaws, dead code removed, and stylistic
changes.
* Style changes and old code removal in router
Router needs a lot of work done to its (lack of) error handling.
* Dead code removal and style changes
Now up to util/email/email.go. After I'm finished with the initial sweep
I'll go back and fix error handling and security issues. Then I'll fix
the broken API. Then I'll go through to add documentation and fix code
visibility.
* Finish dead code removal and style changes
Vendored libraries not touched. Everything still needs security fixes
and documentation. There's also one case of broken functionality.
* Fix accidental find-and-replace
* Style, error checking, saftey, bug fix changes
* Redo error checking erased during merge
* Re-add merge-erased fix. Make Safe safe.
2017-05-10 04:34:40 +02:00
func GetAllTorrentsOrderBy ( orderBy string , limit int , offset int ) ( [ ] model . Torrent , int , error ) {
2017-05-05 14:20:51 +02:00
return GetTorrentsOrderBy ( nil , orderBy , limit , offset )
}
Consistency, formatting, error checking, cleanup, and a couple bug fixes (#245)
* Checkpoint: it builds
The config, db, model, network, os, and public packages have had some
fixes to glaringly obvious flaws, dead code removed, and stylistic
changes.
* Style changes and old code removal in router
Router needs a lot of work done to its (lack of) error handling.
* Dead code removal and style changes
Now up to util/email/email.go. After I'm finished with the initial sweep
I'll go back and fix error handling and security issues. Then I'll fix
the broken API. Then I'll go through to add documentation and fix code
visibility.
* Finish dead code removal and style changes
Vendored libraries not touched. Everything still needs security fixes
and documentation. There's also one case of broken functionality.
* Fix accidental find-and-replace
* Style, error checking, saftey, bug fix changes
* Redo error checking erased during merge
* Re-add merge-erased fix. Make Safe safe.
2017-05-10 04:34:40 +02:00
func GetAllTorrents ( limit int , offset int ) ( [ ] model . Torrent , int , error ) {
2017-05-05 14:20:51 +02:00
return GetTorrentsOrderBy ( nil , "" , limit , offset )
}
Consistency, formatting, error checking, cleanup, and a couple bug fixes (#245)
* Checkpoint: it builds
The config, db, model, network, os, and public packages have had some
fixes to glaringly obvious flaws, dead code removed, and stylistic
changes.
* Style changes and old code removal in router
Router needs a lot of work done to its (lack of) error handling.
* Dead code removal and style changes
Now up to util/email/email.go. After I'm finished with the initial sweep
I'll go back and fix error handling and security issues. Then I'll fix
the broken API. Then I'll go through to add documentation and fix code
visibility.
* Finish dead code removal and style changes
Vendored libraries not touched. Everything still needs security fixes
and documentation. There's also one case of broken functionality.
* Fix accidental find-and-replace
* Style, error checking, saftey, bug fix changes
* Redo error checking erased during merge
* Re-add merge-erased fix. Make Safe safe.
2017-05-10 04:34:40 +02:00
func GetAllTorrentsDB ( ) ( [ ] model . Torrent , int , error ) {
2017-05-05 14:20:51 +02:00
return GetTorrentsOrderBy ( nil , "" , 0 , 0 )
}
2017-05-10 05:24:18 +02:00
func DeleteTorrent ( id string ) ( int , error ) {
2017-05-10 05:54:12 +02:00
var torrent model . Torrent
2017-05-15 08:24:06 +02:00
if db . ORM . Table ( config . TableName ) . First ( & torrent , id ) . RecordNotFound ( ) {
2017-05-10 04:03:25 +02:00
return http . StatusNotFound , errors . New ( "Torrent is not found." )
}
2017-05-15 08:24:06 +02:00
if db . ORM . Table ( config . TableName ) . Delete ( & torrent ) . Error != nil {
2017-05-10 04:03:25 +02:00
return http . StatusInternalServerError , errors . New ( "Torrent is not deleted." )
}
2017-05-10 05:24:18 +02:00
return http . StatusOK , nil
}
2017-05-10 05:54:12 +02:00
func UpdateTorrent ( torrent model . Torrent ) ( int , error ) {
2017-05-15 08:24:06 +02:00
if db . ORM . Table ( config . TableName ) . Save ( torrent ) . Error != nil {
2017-05-10 05:24:18 +02:00
return http . StatusInternalServerError , errors . New ( "Torrent is not updated." )
}
2017-05-10 04:03:25 +02:00
return http . StatusOK , nil
2017-05-10 05:40:47 +02:00
}