Tweak renderer structure
This commit is contained in:
parent
331f43a8b4
commit
c7636e2bb0
@ -10,31 +10,31 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
type (
|
type (
|
||||||
genericTXT struct{}
|
genericText struct{}
|
||||||
genericTXTDriver struct{}
|
genericTextDriver struct{}
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
plainTextRegex = regexp.MustCompile("text(/)?.*")
|
plainTextRegex = regexp.MustCompile("text(/)?.*")
|
||||||
)
|
)
|
||||||
|
|
||||||
func newGenericTXT() driverFactory {
|
func newGenericText() driverFactory {
|
||||||
return &genericTXT{}
|
return &genericText{}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (d *genericTXT) CanRender(t types.DocumentType) bool {
|
func (d *genericText) CanRender(t types.DocumentType) bool {
|
||||||
return t == types.DocumentTypePlain || t == types.DocumentTypeHTML
|
return t == types.DocumentTypePlain || t == types.DocumentTypeHTML
|
||||||
}
|
}
|
||||||
|
|
||||||
func (d *genericTXT) CanProduce(t types.DocumentType) bool {
|
func (d *genericText) CanProduce(t types.DocumentType) bool {
|
||||||
return t == types.DocumentTypePlain
|
return t == types.DocumentTypePlain
|
||||||
}
|
}
|
||||||
|
|
||||||
func (d *genericTXT) Driver() driver {
|
func (d *genericText) Driver() driver {
|
||||||
return &genericTXTDriver{}
|
return &genericTextDriver{}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (d *genericTXTDriver) Render(ctx context.Context, pl *driverPayload) (io.ReadSeeker, error) {
|
func (d *genericTextDriver) Render(ctx context.Context, pl *driverPayload) (io.ReadSeeker, error) {
|
||||||
t, err := preprocPlainTemplate(pl.Template, pl.Partials)
|
t, err := preprocPlainTemplate(pl.Template, pl.Partials)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
75
system/renderer/html.go
Normal file
75
system/renderer/html.go
Normal file
@ -0,0 +1,75 @@
|
|||||||
|
package renderer
|
||||||
|
|
||||||
|
import (
|
||||||
|
"encoding/base64"
|
||||||
|
"html/template"
|
||||||
|
"io/ioutil"
|
||||||
|
"net/http"
|
||||||
|
|
||||||
|
"github.com/Masterminds/sprig"
|
||||||
|
)
|
||||||
|
|
||||||
|
func preprocHTMLTemplate(pl *driverPayload) (*template.Template, error) {
|
||||||
|
bb, err := ioutil.ReadAll(pl.Template)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
gtpl := template.New("text/html_render").
|
||||||
|
Funcs(sprig.FuncMap()).
|
||||||
|
Funcs(template.FuncMap{
|
||||||
|
// "attachDataURL": func(name string) template.URL {
|
||||||
|
// // Find the attachment
|
||||||
|
// att, has := pl.Attachments[name]
|
||||||
|
// if !has {
|
||||||
|
// return template.URL(fmt.Sprintf("error: attachment not found: %s", name))
|
||||||
|
// }
|
||||||
|
|
||||||
|
// // Process source
|
||||||
|
// bb, err := ioutil.ReadAll(att.Source)
|
||||||
|
// if err != nil {
|
||||||
|
// return template.URL(fmt.Sprintf("error: %s", err.Error()))
|
||||||
|
// }
|
||||||
|
|
||||||
|
// return template.URL("data:" + att.Mime + ";base64," + base64.RawStdEncoding.EncodeToString(bb))
|
||||||
|
// },
|
||||||
|
|
||||||
|
"inlineRemote": func(url string) (template.URL, error) {
|
||||||
|
rsp, err := http.Get(url)
|
||||||
|
if err != nil {
|
||||||
|
return "", err
|
||||||
|
}
|
||||||
|
|
||||||
|
defer rsp.Body.Close()
|
||||||
|
|
||||||
|
bb, err := ioutil.ReadAll(rsp.Body)
|
||||||
|
if err != nil {
|
||||||
|
return "", err
|
||||||
|
}
|
||||||
|
|
||||||
|
raw := base64.RawStdEncoding.EncodeToString(bb)
|
||||||
|
return template.URL("data:" + rsp.Header.Get("Content-Type") + ";base64," + raw), nil
|
||||||
|
},
|
||||||
|
})
|
||||||
|
|
||||||
|
// Prep the original template
|
||||||
|
t, err := gtpl.Parse(string(bb))
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
// Prep partials
|
||||||
|
for _, p := range pl.Partials {
|
||||||
|
bb, err = ioutil.ReadAll(p)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
t, err = gtpl.Parse(string(bb))
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return t, nil
|
||||||
|
}
|
||||||
@ -16,13 +16,13 @@ type (
|
|||||||
|
|
||||||
func Renderer(cfg options.TemplateOpt) *renderer {
|
func Renderer(cfg options.TemplateOpt) *renderer {
|
||||||
ff := make([]driverFactory, 0, 3)
|
ff := make([]driverFactory, 0, 3)
|
||||||
ff = append(ff, newGenericTXT(), newGenericHTML())
|
ff = append(ff, newGenericText(), newGenericHTML())
|
||||||
if cfg.RendererGotenbergEnabled {
|
if cfg.RendererGotenbergEnabled {
|
||||||
ff = append(ff, newGotenbergPDF(cfg.RendererGotenbergAddress))
|
ff = append(ff, newGotenbergPDF(cfg.RendererGotenbergAddress))
|
||||||
}
|
}
|
||||||
|
|
||||||
return &renderer{
|
return &renderer{
|
||||||
factories: []driverFactory{},
|
factories: ff,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
37
system/renderer/text.go
Normal file
37
system/renderer/text.go
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
package renderer
|
||||||
|
|
||||||
|
import (
|
||||||
|
"io"
|
||||||
|
"io/ioutil"
|
||||||
|
"text/template"
|
||||||
|
)
|
||||||
|
|
||||||
|
func preprocPlainTemplate(tpl io.Reader, pp map[string]io.Reader) (*template.Template, error) {
|
||||||
|
bb, err := ioutil.ReadAll(tpl)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
gtpl := template.New("text/plain_render")
|
||||||
|
|
||||||
|
// Prep the original template
|
||||||
|
t, err := gtpl.Parse(string(bb))
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
// Prep partials
|
||||||
|
for _, p := range pp {
|
||||||
|
bb, err = ioutil.ReadAll(p)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
t, err = gtpl.Parse(string(bb))
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return t, nil
|
||||||
|
}
|
||||||
@ -1,107 +0,0 @@
|
|||||||
package renderer
|
|
||||||
|
|
||||||
import (
|
|
||||||
"encoding/base64"
|
|
||||||
htpl "html/template"
|
|
||||||
ttpl "html/template"
|
|
||||||
"io"
|
|
||||||
"io/ioutil"
|
|
||||||
"net/http"
|
|
||||||
|
|
||||||
"github.com/Masterminds/sprig"
|
|
||||||
)
|
|
||||||
|
|
||||||
func preprocHTMLTemplate(pl *driverPayload) (*htpl.Template, error) {
|
|
||||||
bb, err := ioutil.ReadAll(pl.Template)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
gtpl := htpl.New("text/html_render").
|
|
||||||
Funcs(sprig.FuncMap()).
|
|
||||||
Funcs(htpl.FuncMap{
|
|
||||||
// "attachDataURL": func(name string) htpl.URL {
|
|
||||||
// // Find the attachment
|
|
||||||
// att, has := pl.Attachments[name]
|
|
||||||
// if !has {
|
|
||||||
// return htpl.URL(fmt.Sprintf("error: attachment not found: %s", name))
|
|
||||||
// }
|
|
||||||
|
|
||||||
// // Process source
|
|
||||||
// bb, err := ioutil.ReadAll(att.Source)
|
|
||||||
// if err != nil {
|
|
||||||
// return htpl.URL(fmt.Sprintf("error: %s", err.Error()))
|
|
||||||
// }
|
|
||||||
|
|
||||||
// return htpl.URL("data:" + att.Mime + ";base64," + base64.RawStdEncoding.EncodeToString(bb))
|
|
||||||
// },
|
|
||||||
|
|
||||||
"inlineRemote": func(url string) (htpl.URL, error) {
|
|
||||||
rsp, err := http.Get(url)
|
|
||||||
if err != nil {
|
|
||||||
return "", err
|
|
||||||
}
|
|
||||||
|
|
||||||
defer rsp.Body.Close()
|
|
||||||
|
|
||||||
bb, err := ioutil.ReadAll(rsp.Body)
|
|
||||||
if err != nil {
|
|
||||||
return "", err
|
|
||||||
}
|
|
||||||
|
|
||||||
raw := base64.RawStdEncoding.EncodeToString(bb)
|
|
||||||
return htpl.URL("data:" + rsp.Header.Get("Content-Type") + ";base64," + raw), nil
|
|
||||||
},
|
|
||||||
})
|
|
||||||
|
|
||||||
// Prep the original template
|
|
||||||
t, err := gtpl.Parse(string(bb))
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
// Prep partials
|
|
||||||
for _, p := range pl.Partials {
|
|
||||||
bb, err = ioutil.ReadAll(p)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
t, err = gtpl.Parse(string(bb))
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return t, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func preprocPlainTemplate(tpl io.Reader, pp map[string]io.Reader) (*ttpl.Template, error) {
|
|
||||||
bb, err := ioutil.ReadAll(tpl)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
gtpl := ttpl.New("text/plain_render")
|
|
||||||
|
|
||||||
// Prep the original template
|
|
||||||
t, err := gtpl.Parse(string(bb))
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
// Prep partials
|
|
||||||
for _, p := range pp {
|
|
||||||
bb, err = ioutil.ReadAll(p)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
t, err = gtpl.Parse(string(bb))
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return t, nil
|
|
||||||
}
|
|
||||||
Loading…
x
Reference in New Issue
Block a user