2018-02-05 00:45:07 +01:00
|
|
|
// Copyright 2018 Frédéric Guillot. All rights reserved.
|
|
|
|
// Use of this source code is governed by the Apache 2.0
|
|
|
|
// license that can be found in the LICENSE file.
|
|
|
|
|
|
|
|
package template
|
|
|
|
|
|
|
|
import (
|
2018-07-18 03:48:28 +02:00
|
|
|
"bytes"
|
2018-02-05 00:45:07 +01:00
|
|
|
"html/template"
|
|
|
|
"net/mail"
|
|
|
|
"strings"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/gorilla/mux"
|
|
|
|
"github.com/miniflux/miniflux/config"
|
|
|
|
"github.com/miniflux/miniflux/filter"
|
|
|
|
"github.com/miniflux/miniflux/http/route"
|
|
|
|
"github.com/miniflux/miniflux/url"
|
|
|
|
)
|
|
|
|
|
|
|
|
type funcMap struct {
|
2018-04-28 07:07:46 +02:00
|
|
|
cfg *config.Config
|
|
|
|
router *mux.Router
|
2018-02-05 00:45:07 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
func (f *funcMap) Map() template.FuncMap {
|
|
|
|
return template.FuncMap{
|
|
|
|
"baseURL": func() string {
|
|
|
|
return f.cfg.BaseURL()
|
|
|
|
},
|
|
|
|
"rootURL": func() string {
|
|
|
|
return f.cfg.RootURL()
|
|
|
|
},
|
|
|
|
"hasOAuth2Provider": func(provider string) bool {
|
|
|
|
return f.cfg.OAuth2Provider() == provider
|
|
|
|
},
|
|
|
|
"hasKey": func(dict map[string]string, key string) bool {
|
|
|
|
if value, found := dict[key]; found {
|
|
|
|
return value != ""
|
|
|
|
}
|
|
|
|
return false
|
|
|
|
},
|
|
|
|
"route": func(name string, args ...interface{}) string {
|
|
|
|
return route.Path(f.router, name, args...)
|
|
|
|
},
|
|
|
|
"noescape": func(str string) template.HTML {
|
|
|
|
return template.HTML(str)
|
|
|
|
},
|
|
|
|
"proxyFilter": func(data string) string {
|
2018-07-13 02:41:09 +02:00
|
|
|
return filter.ImageProxyFilter(f.router, f.cfg, data)
|
2018-02-05 00:45:07 +01:00
|
|
|
},
|
|
|
|
"proxyURL": func(link string) string {
|
2018-07-13 02:41:09 +02:00
|
|
|
proxyImages := f.cfg.ProxyImages()
|
|
|
|
|
|
|
|
if proxyImages == "all" || (proxyImages != "none" && !url.IsHTTPS(link)) {
|
|
|
|
return filter.Proxify(f.router, link)
|
2018-02-05 00:45:07 +01:00
|
|
|
}
|
|
|
|
|
2018-07-13 02:41:09 +02:00
|
|
|
return link
|
2018-02-05 00:45:07 +01:00
|
|
|
},
|
|
|
|
"domain": func(websiteURL string) string {
|
|
|
|
return url.Domain(websiteURL)
|
|
|
|
},
|
|
|
|
"isEmail": func(str string) bool {
|
|
|
|
_, err := mail.ParseAddress(str)
|
|
|
|
if err != nil {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
return true
|
|
|
|
},
|
|
|
|
"hasPrefix": func(str, prefix string) bool {
|
|
|
|
return strings.HasPrefix(str, prefix)
|
|
|
|
},
|
|
|
|
"contains": func(str, substr string) bool {
|
|
|
|
return strings.Contains(str, substr)
|
|
|
|
},
|
|
|
|
"isodate": func(ts time.Time) string {
|
|
|
|
return ts.Format("2006-01-02 15:04:05")
|
|
|
|
},
|
2018-04-28 07:07:46 +02:00
|
|
|
"dict": dict,
|
2018-07-18 03:48:28 +02:00
|
|
|
"truncate": func(str string, max int) string {
|
|
|
|
if len(str) > max {
|
|
|
|
var buffer bytes.Buffer
|
|
|
|
|
|
|
|
buffer.WriteString(str[:max-1])
|
|
|
|
buffer.WriteString("…")
|
|
|
|
|
|
|
|
return buffer.String()
|
|
|
|
}
|
|
|
|
|
|
|
|
return str
|
|
|
|
},
|
2018-04-28 07:07:46 +02:00
|
|
|
|
|
|
|
// These functions are overrided at runtime after the parsing.
|
2018-02-05 00:45:07 +01:00
|
|
|
"elapsed": func(timezone string, t time.Time) string {
|
2018-04-28 07:07:46 +02:00
|
|
|
return ""
|
2018-02-05 00:45:07 +01:00
|
|
|
},
|
|
|
|
"t": func(key interface{}, args ...interface{}) string {
|
2018-04-28 07:07:46 +02:00
|
|
|
return ""
|
2018-02-05 00:45:07 +01:00
|
|
|
},
|
|
|
|
"plural": func(key string, n int, args ...interface{}) string {
|
2018-04-28 07:07:46 +02:00
|
|
|
return ""
|
2018-02-05 00:45:07 +01:00
|
|
|
},
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-04-28 07:07:46 +02:00
|
|
|
func newFuncMap(cfg *config.Config, router *mux.Router) *funcMap {
|
|
|
|
return &funcMap{cfg, router}
|
2018-02-05 00:45:07 +01:00
|
|
|
}
|