2017-11-10 12:39:55 +01:00
|
|
|
package webcontroller
|
|
|
|
|
|
|
|
import (
|
2017-12-12 23:33:41 +01:00
|
|
|
"fmt"
|
2017-11-10 12:39:55 +01:00
|
|
|
"net/http"
|
|
|
|
"strings"
|
|
|
|
|
|
|
|
"fornaxian.com/pixeldrain-web/pixelapi"
|
2018-06-17 16:15:58 +02:00
|
|
|
"github.com/Fornaxian/log"
|
2017-11-10 12:39:55 +01:00
|
|
|
"github.com/julienschmidt/httprouter"
|
|
|
|
)
|
|
|
|
|
2020-01-21 15:33:09 +01:00
|
|
|
func viewTokenOrBust(api *pixelapi.PixelAPI) (t string) {
|
|
|
|
var err error
|
|
|
|
if t, err = api.GetMiscViewToken(); err != nil {
|
|
|
|
log.Error("Could not get viewtoken: %s", err)
|
|
|
|
}
|
|
|
|
return t
|
|
|
|
}
|
|
|
|
|
2019-02-19 23:10:04 +01:00
|
|
|
type viewerData struct {
|
|
|
|
Type string // file or list
|
2019-03-27 23:57:53 +01:00
|
|
|
CaptchaKey string
|
2020-01-21 15:33:09 +01:00
|
|
|
ViewToken string
|
2019-02-19 23:10:04 +01:00
|
|
|
APIResponse interface{}
|
|
|
|
}
|
|
|
|
|
2017-11-10 12:39:55 +01:00
|
|
|
// ServeFileViewer controller for GET /u/:id
|
2018-06-17 16:15:58 +02:00
|
|
|
func (wc *WebController) serveFileViewer(w http.ResponseWriter, r *http.Request, p httprouter.Params) {
|
2020-01-21 15:33:09 +01:00
|
|
|
var err error
|
2017-11-10 12:39:55 +01:00
|
|
|
if p.ByName("id") == "demo" {
|
2019-02-19 23:10:04 +01:00
|
|
|
wc.serveFileViewerDemo(w, r) // Required for a-ads.com quality check
|
2017-11-10 12:39:55 +01:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
var list = strings.Contains(p.ByName("id"), ",")
|
|
|
|
var ids []string
|
|
|
|
|
|
|
|
if list {
|
|
|
|
ids = strings.Split(p.ByName("id"), ",")
|
|
|
|
} else {
|
|
|
|
ids = append(ids, p.ByName("id"))
|
|
|
|
}
|
|
|
|
|
2020-01-21 15:33:09 +01:00
|
|
|
templateData := wc.newTemplateData(w, r)
|
|
|
|
|
2017-11-10 12:39:55 +01:00
|
|
|
var finfo []*pixelapi.FileInfo
|
|
|
|
for _, id := range ids {
|
2020-01-21 15:33:09 +01:00
|
|
|
inf, err := templateData.PixelAPI.GetFileInfo(id, "")
|
2018-06-20 23:47:47 +02:00
|
|
|
if err != nil {
|
2017-11-10 12:39:55 +01:00
|
|
|
continue
|
|
|
|
}
|
|
|
|
finfo = append(finfo, inf)
|
|
|
|
}
|
|
|
|
|
|
|
|
if len(finfo) == 0 {
|
2019-07-28 22:34:15 +02:00
|
|
|
w.WriteHeader(http.StatusNotFound)
|
|
|
|
wc.templates.Get().ExecuteTemplate(w, "file_not_found", templateData)
|
2017-11-10 12:39:55 +01:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2019-07-06 19:36:04 +02:00
|
|
|
templateData.OGData = metadataFromFile(*finfo[0])
|
2017-11-10 12:39:55 +01:00
|
|
|
if list {
|
2020-01-17 20:32:21 +01:00
|
|
|
templateData.Title = fmt.Sprintf("%d files on pixeldrain", len(finfo))
|
2019-02-19 23:10:04 +01:00
|
|
|
templateData.Other = viewerData{
|
2019-03-27 23:57:53 +01:00
|
|
|
Type: "list",
|
2019-03-28 10:47:27 +01:00
|
|
|
CaptchaKey: wc.captchaKey(),
|
2020-01-21 15:33:09 +01:00
|
|
|
ViewToken: viewTokenOrBust(templateData.PixelAPI),
|
2019-02-19 23:10:04 +01:00
|
|
|
APIResponse: map[string]interface{}{
|
|
|
|
"data": finfo,
|
|
|
|
"date_created": "now",
|
2019-07-28 22:34:15 +02:00
|
|
|
"title": "Multiple files",
|
2019-02-19 23:10:04 +01:00
|
|
|
"date_lastview": "now",
|
|
|
|
"views": 0,
|
|
|
|
},
|
2017-11-10 12:39:55 +01:00
|
|
|
}
|
|
|
|
} else {
|
2020-01-17 20:32:21 +01:00
|
|
|
templateData.Title = fmt.Sprintf("%s ~ pixeldrain", finfo[0].Name)
|
2019-02-19 23:10:04 +01:00
|
|
|
templateData.Other = viewerData{
|
|
|
|
Type: "file",
|
2019-03-28 10:47:27 +01:00
|
|
|
CaptchaKey: wc.captchaKey(),
|
2020-01-21 15:33:09 +01:00
|
|
|
ViewToken: viewTokenOrBust(templateData.PixelAPI),
|
2019-02-19 23:10:04 +01:00
|
|
|
APIResponse: finfo[0],
|
|
|
|
}
|
2017-11-10 12:39:55 +01:00
|
|
|
}
|
2019-02-19 23:10:04 +01:00
|
|
|
err = wc.templates.Get().ExecuteTemplate(w, "file_viewer", templateData)
|
2019-09-18 22:30:29 +02:00
|
|
|
if err != nil && !strings.Contains(err.Error(), "broken pipe") {
|
2017-11-10 12:39:55 +01:00
|
|
|
log.Error("Error executing template file_viewer: %s", err)
|
|
|
|
}
|
|
|
|
}
|
2018-06-17 16:15:58 +02:00
|
|
|
|
|
|
|
// ServeFileViewerDemo is a dummy API response that responds with info about a
|
|
|
|
// non-existent demo file. This is required by the a-ads ad network to allow for
|
|
|
|
// automatic checking of the presence of the ad unit on this page.
|
2019-02-19 23:10:04 +01:00
|
|
|
func (wc *WebController) serveFileViewerDemo(w http.ResponseWriter, r *http.Request) {
|
|
|
|
templateData := wc.newTemplateData(w, r)
|
|
|
|
templateData.Other = viewerData{
|
2019-03-27 23:57:53 +01:00
|
|
|
Type: "file",
|
|
|
|
CaptchaKey: wc.captchaSiteKey,
|
2019-02-19 23:10:04 +01:00
|
|
|
APIResponse: map[string]interface{}{
|
2019-03-26 20:53:19 +01:00
|
|
|
"id": "demo",
|
|
|
|
"name": "Demo file",
|
|
|
|
"date_upload": "2017-01-01 12:34:56",
|
|
|
|
"date_lastview": "2017-01-01 12:34:56",
|
|
|
|
"size": 123456789,
|
|
|
|
"views": 1,
|
|
|
|
"bandwidth_used": 123456789,
|
|
|
|
"mime_type": "text/demo",
|
|
|
|
"description": "A file to demonstrate the viewer page",
|
|
|
|
"mime_image": "/res/img/mime/text.png",
|
|
|
|
"thumbnail": "/res/img/mime/text.png",
|
2018-06-17 16:15:58 +02:00
|
|
|
},
|
2019-02-19 23:10:04 +01:00
|
|
|
}
|
|
|
|
err := wc.templates.Get().ExecuteTemplate(w, "file_viewer", templateData)
|
2019-09-18 22:30:29 +02:00
|
|
|
if err != nil && !strings.Contains(err.Error(), "broken pipe") {
|
2019-02-19 23:10:04 +01:00
|
|
|
log.Error("Error rendering demo file: %s", err)
|
|
|
|
}
|
2018-06-17 16:15:58 +02:00
|
|
|
}
|
2020-01-21 15:33:09 +01:00
|
|
|
|
|
|
|
// ServeListViewer controller for GET /l/:id
|
|
|
|
func (wc *WebController) serveListViewer(w http.ResponseWriter, r *http.Request, p httprouter.Params) {
|
|
|
|
var api = pixelapi.New(wc.apiURLInternal, "")
|
|
|
|
var list, err = api.GetList(p.ByName("id"))
|
|
|
|
var templateData = wc.newTemplateData(w, r)
|
|
|
|
if err != nil {
|
|
|
|
if err, ok := err.(pixelapi.Error); ok && err.ReqError {
|
|
|
|
log.Error("API request error occurred: %s", err.Value)
|
|
|
|
|
|
|
|
}
|
|
|
|
w.WriteHeader(http.StatusNotFound)
|
|
|
|
wc.templates.Get().ExecuteTemplate(w, "list_not_found", templateData)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
templateData.Title = fmt.Sprintf("%s ~ pixeldrain", list.Title)
|
|
|
|
templateData.OGData = metadataFromList(*list)
|
|
|
|
templateData.Other = viewerData{
|
|
|
|
Type: "list",
|
|
|
|
CaptchaKey: wc.captchaSiteKey,
|
|
|
|
ViewToken: viewTokenOrBust(templateData.PixelAPI),
|
|
|
|
APIResponse: map[string]interface{}{
|
|
|
|
"id": list.ID,
|
|
|
|
"data": list.Files,
|
|
|
|
"date_created": list.DateCreated,
|
|
|
|
"title": list.Title,
|
|
|
|
"views": 0,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
err = wc.templates.Get().ExecuteTemplate(w, "file_viewer", templateData)
|
|
|
|
if err != nil && !strings.Contains(err.Error(), "broken pipe") {
|
|
|
|
log.Error("Error executing template file_viewer: %s", err)
|
|
|
|
}
|
|
|
|
}
|