Albirew/nyaa-pantsu
Archivé
1
0
Bifurcation 0

Replace homehandler with search handler

Cette révision appartient à :
pantsudev 2017-06-14 13:53:54 +10:00
Parent 056d579f82
révision 5186e65dfc
2 fichiers modifiés avec 1 ajouts et 85 suppressions

Voir le fichier

@ -1,84 +0,0 @@
package router
import (
"html"
"net/http"
"strconv"
"github.com/NyaaPantsu/nyaa/cache"
"github.com/NyaaPantsu/nyaa/common"
"github.com/NyaaPantsu/nyaa/model"
"github.com/NyaaPantsu/nyaa/service/torrent"
"github.com/NyaaPantsu/nyaa/util/log"
msg "github.com/NyaaPantsu/nyaa/util/messages"
"github.com/gorilla/mux"
)
// HomeHandler : Controller for Home page, can have some query arguments
func HomeHandler(w http.ResponseWriter, r *http.Request) {
vars := mux.Vars(r)
page := vars["page"]
messages := msg.GetMessages(r)
deleteVar := r.URL.Query()["deleted"]
defer r.Body.Close()
// db params url
var err error
maxPerPage := 50
maxString := r.URL.Query().Get("max")
if maxString != "" {
maxPerPage, err = strconv.Atoi(maxString)
if !log.CheckError(err) {
maxPerPage = 50 // default Value maxPerPage
}
}
if deleteVar != nil {
messages.AddInfoTf("infos", "torrent_deleted", "")
}
pagenum := 1
if page != "" {
pagenum, err = strconv.Atoi(html.EscapeString(page))
if !log.CheckError(err) {
http.Error(w, err.Error(), http.StatusInternalServerError)
return
}
if pagenum <= 0 {
NotFoundHandler(w, r)
return
}
}
search := common.SearchParam{
Max: uint(maxPerPage),
Page: pagenum,
}
torrents, nbTorrents, err := cache.Impl.Get(search, func() ([]model.Torrent, int, error) {
return torrentService.GetAllTorrents(maxPerPage, maxPerPage*(pagenum-1))
})
if !log.CheckError(err) {
http.Error(w, err.Error(), http.StatusInternalServerError)
return
}
navigationTorrents := navigation{
TotalItem: nbTorrents,
MaxItemPerPage: maxPerPage,
CurrentPage: pagenum,
Route: "search_page",
}
torrentsJSON := model.TorrentsToJSON(torrents)
common := newCommonVariables(r)
common.Navigation = navigationTorrents
htv := modelListVbs{
commonTemplateVariables: common,
Models: torrentsJSON,
Infos: messages.GetAllInfos(),
}
err = homeTemplate.ExecuteTemplate(w, "index.html", htv)
if err != nil {
log.Errorf("HomeHandler(): %s", err)
}
}

Voir le fichier

@ -26,7 +26,7 @@ func init() {
// TODO Use config from cli
// TODO Make sure the directory exists
gpgKeyHandler := http.FileServer(http.Dir(GPGPublicKeyPath))
gzipHomeHandler := http.HandlerFunc(HomeHandler)
gzipHomeHandler := http.HandlerFunc(SearchHandler)
gzipAPIHandler := http.HandlerFunc(APIHandler)
gzipAPIViewHandler := http.HandlerFunc(APIViewHandler)
gzipViewHandler := http.HandlerFunc(ViewHandler)