mirror of
https://github.com/caddyserver/caddy.git
synced 2025-01-22 18:43:17 +08:00
87 lines
2.3 KiB
Go
87 lines
2.3 KiB
Go
package markdown
|
|
|
|
import (
|
|
"bytes"
|
|
"path/filepath"
|
|
|
|
"github.com/mholt/caddy/middleware"
|
|
"github.com/russross/blackfriday"
|
|
)
|
|
|
|
// Data represents a markdown document.
|
|
type Data struct {
|
|
middleware.Context
|
|
Doc map[string]string
|
|
DocFlags map[string]bool
|
|
Styles []string
|
|
Scripts []string
|
|
}
|
|
|
|
// Include "overrides" the embedded middleware.Context's Include()
|
|
// method so that included files have access to d's fields.
|
|
func (d Data) Include(filename string) (string, error) {
|
|
return middleware.ContextInclude(filename, d, d.Root)
|
|
}
|
|
|
|
// Process processes the contents of a page in b. It parses the metadata
|
|
// (if any) and uses the template (if found).
|
|
func (md Markdown) Process(c *Config, requestPath string, b []byte, ctx middleware.Context) ([]byte, error) {
|
|
var metadata = newMetadata()
|
|
var markdown []byte
|
|
var err error
|
|
|
|
// find parser compatible with page contents
|
|
parser := findParser(b)
|
|
|
|
if parser == nil {
|
|
// if not found, assume whole file is markdown (no front matter)
|
|
markdown = b
|
|
} else {
|
|
// if found, assume metadata present and parse.
|
|
markdown, err = parser.Parse(b)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
metadata = parser.Metadata()
|
|
}
|
|
|
|
// process markdown
|
|
extns := 0
|
|
extns |= blackfriday.EXTENSION_TABLES
|
|
extns |= blackfriday.EXTENSION_FENCED_CODE
|
|
extns |= blackfriday.EXTENSION_STRIKETHROUGH
|
|
extns |= blackfriday.EXTENSION_DEFINITION_LISTS
|
|
markdown = blackfriday.Markdown(markdown, c.Renderer, extns)
|
|
|
|
// set it as body for template
|
|
metadata.Variables["body"] = string(markdown)
|
|
title := metadata.Title
|
|
if title == "" {
|
|
title = filepath.Base(requestPath)
|
|
var extension = filepath.Ext(requestPath)
|
|
title = title[0 : len(title)-len(extension)]
|
|
}
|
|
metadata.Variables["title"] = title
|
|
|
|
// return md.processTemplate(c, requestPath, metadata, ctx)
|
|
return md.doTemplate(c, requestPath, metadata, ctx)
|
|
}
|
|
|
|
// doTemplate executes a template given a requestPath, template, and metadata
|
|
func (md Markdown) doTemplate(c *Config, reqPath string, metadata Metadata, ctx middleware.Context) ([]byte, error) {
|
|
mdData := Data{
|
|
Context: ctx,
|
|
Doc: metadata.Variables,
|
|
DocFlags: metadata.Flags,
|
|
Styles: c.Styles,
|
|
Scripts: c.Scripts,
|
|
}
|
|
|
|
b := new(bytes.Buffer)
|
|
if err := c.Template.ExecuteTemplate(b, metadata.Template, mdData); err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return b.Bytes(), nil
|
|
}
|