Files
fnx_web/webcontroller/file_viewer.go

155 lines
4.5 KiB
Go
Raw Normal View History

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"
2020-01-28 12:51:21 +01:00
"time"
2017-11-10 12:39:55 +01:00
"fornaxian.com/pixeldrain-web/pixelapi"
"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
}
2020-01-28 12:51:21 +01:00
func browserCompat(ua string) bool {
return strings.Contains(ua, "MSIE") || strings.Contains(ua, "Trident/7.0")
}
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
APIResponse interface{}
}
2017-11-10 12:39:55 +01:00
// ServeFileViewer controller for GET /u/:id
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" {
wc.serveFileViewerDemo(w, r) // Required for a-ads.com quality check
2017-11-10 12:39:55 +01:00
return
}
2020-01-28 12:51:21 +01:00
var ids = strings.Split(p.ByName("id"), ",")
2017-11-10 12:39:55 +01:00
2020-01-21 15:33:09 +01:00
templateData := wc.newTemplateData(w, r)
2020-01-28 12:51:21 +01:00
var finfo []pixelapi.ListFile
2017-11-10 12:39:55 +01:00
for _, id := range ids {
2020-01-21 15:43:09 +01:00
inf, err := templateData.PixelAPI.GetFileInfo(id)
if err != nil {
2017-11-10 12:39:55 +01:00
continue
}
2020-01-28 12:51:21 +01:00
finfo = append(finfo, pixelapi.ListFile{FileInfo: inf})
2017-11-10 12:39:55 +01:00
}
if len(finfo) == 0 {
w.WriteHeader(http.StatusNotFound)
wc.templates.Get().ExecuteTemplate(w, "file_not_found", templateData)
2017-11-10 12:39:55 +01:00
return
}
2020-01-28 12:51:21 +01:00
templateData.OGData = metadataFromFile(finfo[0].FileInfo)
if len(ids) > 1 {
2020-01-17 20:32:21 +01:00
templateData.Title = fmt.Sprintf("%d files on pixeldrain", len(finfo))
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),
2020-01-28 12:51:21 +01:00
APIResponse: pixelapi.List{
Success: true,
Title: "Multiple files",
DateCreated: time.Now(),
Files: finfo,
},
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)
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),
2020-01-28 12:51:21 +01:00
APIResponse: finfo[0].FileInfo,
}
2017-11-10 12:39:55 +01:00
}
2020-01-28 12:51:21 +01:00
var templateName = "file_viewer"
if browserCompat(r.UserAgent()) {
templateName = "file_viewer_compat"
}
err = wc.templates.Get().ExecuteTemplate(w, templateName, 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)
}
}
// 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.
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,
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",
},
}
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") {
log.Error("Error rendering demo file: %s", err)
}
}
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 templateData = wc.newTemplateData(w, r)
2020-01-28 12:51:21 +01:00
var list, err = templateData.PixelAPI.GetList(p.ByName("id"))
2020-01-21 15:33:09 +01:00
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)
2020-01-28 12:51:21 +01:00
templateData.OGData = metadataFromList(list)
2020-01-21 15:33:09 +01:00
templateData.Other = viewerData{
2020-01-28 12:51:21 +01:00
Type: "list",
CaptchaKey: wc.captchaSiteKey,
ViewToken: viewTokenOrBust(templateData.PixelAPI),
APIResponse: list,
2020-01-21 15:33:09 +01:00
}
2020-01-28 12:51:21 +01:00
var templateName = "file_viewer"
if browserCompat(r.UserAgent()) {
templateName = "file_viewer_compat"
}
err = wc.templates.Get().ExecuteTemplate(w, templateName, templateData)
2020-01-21 15:33:09 +01:00
if err != nil && !strings.Contains(err.Error(), "broken pipe") {
log.Error("Error executing template file_viewer: %s", err)
}
}