From 01a3143a08707f1fafd3f16fc29e3713e618165c Mon Sep 17 00:00:00 2001 From: akuma06 Date: Tue, 6 Jun 2017 00:06:04 +0200 Subject: [PATCH] fix uploaderid when torrent is hidden (#930) Added a new function template to generate a link for uploaders name In the view we have the actual uploaderID and uploaderName now --- model/torrent.go | 33 ++++++++++++++++----------------- router/template_functions.go | 13 +++++++++++++ templates/view.html | 2 +- 3 files changed, 30 insertions(+), 18 deletions(-) diff --git a/model/torrent.go b/model/torrent.go index e02b07d3..9daeb184 100644 --- a/model/torrent.go +++ b/model/torrent.go @@ -207,6 +207,7 @@ type TorrentJSON struct { ID uint `json:"id"` Name string `json:"name"` Status int `json:"status"` + Hidden bool `json:"-"` Hash string `json:"hash"` Date string `json:"date"` Filesize int64 `json:"filesize"` @@ -240,21 +241,21 @@ func (t *TorrentJSON) ToTorrent() Torrent { subCategory = 0 } // Need to add +00:00 at the end because ES doesn't store it by default - date, err := time.Parse(time.RFC3339, t.Date + "+00:00") + date, err := time.Parse(time.RFC3339, t.Date+"+00:00") if err != nil { // TODO: Not sure what I should do here date = time.Now() } torrent := Torrent{ - ID: t.ID, - Name: t.Name, - Hash: t.Hash, - Category: int(category), + ID: t.ID, + Name: t.Name, + Hash: t.Hash, + Category: int(category), SubCategory: int(subCategory), - Status: t.Status, - Date: date, - UploaderID: t.UploaderID, - Downloads: t.Downloads, + Status: t.Status, + Date: date, + UploaderID: t.UploaderID, + Downloads: t.Downloads, //Stardom: t.Stardom, Filesize: t.Filesize, //Description: t.Description, @@ -265,9 +266,9 @@ func (t *TorrentJSON) ToTorrent() Torrent { //OldUploader: t.OldUploader, //OldComments: TODO // Comments: TODO - Seeders: t.Seeders, - Leechers: t.Leechers, - Completed: t.Completed, + Seeders: t.Seeders, + Leechers: t.Leechers, + Completed: t.Completed, LastScrape: t.LastScrape, //FileList: TODO } @@ -313,12 +314,9 @@ func (t *Torrent) ToJSON() TorrentJSON { return strings.ToLower(fileListJSON[i].Path) < strings.ToLower(fileListJSON[j].Path) }) - uploader := "" + uploader := "れんちょん" // by default var uploaderID uint - if t.Hidden { - uploader = "れんちょん" - uploaderID = 0 - } else if t.Uploader != nil { + if t.Uploader != nil { uploader = t.Uploader.Username uploaderID = t.UploaderID } @@ -336,6 +334,7 @@ func (t *Torrent) ToJSON() TorrentJSON { ID: t.ID, Name: t.Name, Status: t.Status, + Hidden: t.Hidden, Hash: t.Hash, Date: t.Date.Format(time.RFC3339), Filesize: t.Filesize, diff --git a/router/template_functions.go b/router/template_functions.go index 3b433fcc..71bfa4f4 100644 --- a/router/template_functions.go +++ b/router/template_functions.go @@ -236,4 +236,17 @@ var FuncMap = template.FuncMap{ } return string(T(d)) }, + "genUploaderLink": func(uploaderID uint, uploaderName string, torrentHidden bool) template.HTML { + if torrentHidden { + return template.HTML("れんちょん") + } + if uploaderID == 0 { + return template.HTML("れんちょん") + } + url, err := Router.Get("user_profile").URL("id", strconv.Itoa(int(uploaderID)), "username", uploaderName) + if err != nil { + return "error" + } + return template.HTML("" + uploaderName + "") + }, } diff --git a/templates/view.html b/templates/view.html index b5f2f9f0..6314bebe 100644 --- a/templates/view.html +++ b/templates/view.html @@ -46,7 +46,7 @@ {{ call $.T "date" }}:{{.Date}} - {{ call $.T "uploaded_by" }}:{{.UploaderName}} + {{ call $.T "uploaded_by" }}:{{ genUploaderLink .UploaderID .UploaderName .Hidden }} {{call $.T "seeders"}}:{{if .LastScrape.IsZero}}{{call $.T "unknown"}}{{else}}{{.Seeders}}{{end}}