Documentation ¶
Overview ¶
xtemplate extends Go's html/template to be capable enough to define an entire server-side application with a directory of Go templates.
Index ¶
- func AddBlueMondayPolicy(name string, policy *bluemonday.Policy)
- func AddMarkdownConifg(name string, md goldmark.Markdown)
- func FuncFailf(format string, args ...any) (string, error)
- func FuncHumanize(formatType, data string) (string, error)
- func FuncIdx(idx int, arr any) any
- func FuncMarkdown(input string, configName ...string) (template.HTML, error)
- func FuncReturn() (string, error)
- func FuncSanitizeHtml(policyName string, html string) (template.HTML, error)
- func FuncSplitFrontMatter(input string) (parsedMarkdownDoc, error)
- func FuncTrustAttr(s string) template.HTMLAttr
- func FuncTrustHtml(s string) template.HTML
- func FuncTrustJS(s string) template.JS
- func FuncTrustJSStr(s string) template.JSStr
- func FuncTrustSrcSet(s string) template.Srcset
- func FuncTry(fn any, args ...any) (*result, error)
- func GetLogger(ctx context.Context) *slog.Logger
- func GetRequestId(ctx context.Context) string
- func RegisterDot(r RegisteredDotProvider)
- type CleanupDotProvider
- type Config
- type DotConfig
- type DotFlush
- type DotProvider
- type DotReq
- type DotResp
- func (h *DotResp) AddHeader(field, val string) string
- func (h *DotResp) DelHeader(field string) string
- func (h *DotResp) ReturnStatus(status int) (string, error)
- func (d *DotResp) ServeContent(path_ string, modtime time.Time, content any) (string, error)
- func (h *DotResp) SetHeader(field, val string) string
- func (h *DotResp) SetStatus(status int) string
- type DotX
- type ErrorStatus
- type Instance
- type InstanceRoute
- type InstanceStats
- type Option
- type RegisteredDotProvider
- type Request
- type ReturnError
- type Server
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func AddBlueMondayPolicy ¶ added in v0.5.0
func AddBlueMondayPolicy(name string, policy *bluemonday.Policy)
AddBlueMondayPolicy adds a bluemonday policy to the global policy list available to all xtemplate instances.
func AddMarkdownConifg ¶ added in v0.5.0
AddMarkdownConifg adds a custom markdown configuration to xtemplate's markdown config map, available to all xtemplate instances.
func FuncHumanize ¶ added in v0.5.0
humanize transforms size and time inputs to a human readable format using the go-humanize library.
Call with two parameters: format type and value to format. Supported format types are:
"size" which turns an integer amount of bytes into a string like "2.3 MB", for example:
{{humanize "size" "2048000"}}
"time" which turns a time string into a relative time string like "2 weeks ago", for example:
{{humanize "time" "Fri, 05 May 2022 15:04:05 +0200"}}
func FuncIdx ¶ added in v0.5.0
idx gets an item from a list, similar to the built-in index, but with reversed args: index first, then array. This is useful to use index in a pipeline, for example:
{{generate-list | idx 5}}
func FuncMarkdown ¶ added in v0.5.0
markdown renders the given Markdown text as HTML and returns it. This uses the Goldmark library, which is CommonMark compliant. If an alternative markdown policy is not named, it uses the default policy which has these extensions enabled: Github Flavored Markdown, Footnote, and syntax highlighting provided by Chroma.
func FuncReturn ¶ added in v0.5.0
return causes the template to exit early with a success status.
func FuncSanitizeHtml ¶ added in v0.5.0
sanitizeHtml Uses the BlueMonday library to sanitize strings with html content. First parameter is the name of the chosen sanitization policy.
func FuncSplitFrontMatter ¶ added in v0.5.0
splitFrontMatter parses front matter out from the beginning of input, and returns the separated key-value pairs and the body/content. input must be a "stringy" value.
func FuncTrustAttr ¶ added in v0.5.0
trustAttr marks the string s as safe and does not escape its contents in html attribute context.
func FuncTrustHtml ¶ added in v0.5.0
trustHtml marks the string s as safe and does not escape its contents in html node context.
func FuncTrustJS ¶ added in v0.5.0
trustJS marks the string s as safe and does not escape its contents in script tag context.
func FuncTrustJSStr ¶ added in v0.5.0
trustJSStr marks the string s as safe and does not escape its contents in script expression context.
func FuncTrustSrcSet ¶ added in v0.5.0
trustSrcSet marks the string s as safe and does not escape its contents in script tag context.
func FuncTry ¶ added in v0.5.0
The try template func accepts a fallible function object and calls it with the provided args. If the function and args are valid, try returns the result wrapped in a result object that exposes the return value and error to templates. Useful if you want to call a function and handle its error in a template. If the function value is invalid or the args cannot be used to call it then try raises an error that stops template execution.
func GetRequestId ¶ added in v0.6.0
func RegisterDot ¶ added in v0.5.0
func RegisterDot(r RegisteredDotProvider)
Types ¶
type CleanupDotProvider ¶ added in v0.5.0
type CleanupDotProvider interface { DotProvider Cleanup(any, error) error }
type Config ¶ added in v0.3.0
type Config struct { // The path to the templates directory. Default `templates`. TemplatesDir string `json:"templates_dir,omitempty" arg:"-t,--template-dir" default:"templates"` // The FS to load templates from. Overrides TemplatesDir if not nil. TemplatesFS fs.FS `json:"-" arg:"-"` // File extension to search for to find template files. Default `.html`. TemplateExtension string `json:"template_extension,omitempty" arg:"--template-ext" default:".html"` // Left template action delimiter. Default `{{`. LDelim string `json:"left,omitempty" arg:"--ldelim" default:"{{"` // Right template action delimiter. Default `}}`. RDelim string `json:"right,omitempty" arg:"--rdelim" default:"}}"` // Whether html templates are minified at load time. Default `true`. Minify bool `json:"minify,omitempty" arg:"-m,--minify" default:"true"` // A list of additional custom fields to add to the template dot value // `{{.}}`. Dot []DotConfig `json:"dot" arg:"-d,--dot,separate"` // Additional functions to add to the template execution context. FuncMaps []template.FuncMap `json:"-" arg:"-"` // The instance context that is threaded through dot providers and can // cancel the server. Defaults to `context.Background()`. Ctx context.Context `json:"-" arg:"-"` // The default logger. Defaults to `slog.Default()`. Logger *slog.Logger `json:"-" arg:"-"` }
func (Config) Instance ¶ added in v0.4.0
func (config Config) Instance(cfgs ...Option) (*Instance, *InstanceStats, []InstanceRoute, error)
Instance creates a new *Instance from the given config
type DotConfig ¶ added in v0.5.0
type DotConfig struct { Name string `json:"name"` Type string `json:"type"` DotProvider `json:"-"` }
func (*DotConfig) MarshalJSON ¶ added in v0.5.0
func (*DotConfig) MarshalText ¶ added in v0.5.0
func (*DotConfig) UnmarshalJSON ¶ added in v0.5.0
func (*DotConfig) UnmarshalText ¶ added in v0.5.0
type DotFlush ¶ added in v0.5.0
type DotFlush struct {
// contains filtered or unexported fields
}
DotFlush is used as the .Flush field for flushing template handlers (SSE).
func (*DotFlush) Flush ¶ added in v0.5.0
Flush flushes any content waiting to written to the client.
func (*DotFlush) Repeat ¶ added in v0.5.0
Repeat generates numbers up to max, using math.MaxInt64 if no max is provided.
func (*DotFlush) SendSSE ¶ added in v0.6.0
SendSSE sends an sse message by formatting the provided args as an sse event:
Requires 1-4 args: event, data, id, retry
func (*DotFlush) WaitForServerStop ¶ added in v0.5.0
WaitForServerStop blocks execution until the request is canceled by the client or until the server closes.
type DotProvider ¶ added in v0.5.0
type DotReq ¶ added in v0.5.0
DotReq is used as the .Req field for template invocations with an associated request, and contains the current HTTP request struct which can be used to read request data. See http.Request for detailed documentation. Some notable methods and fields:
http.Request.Method, http.Request.PathValue, http.Request.URL, [http.Request.URL.Query], http.Request.Cookie, http.Request.Header, [http.Request.Header.Get].
Note that http.Request.ParseForm must be called before using http.Request.Form, http.Request.PostForm, and http.Request.PostValue.
type DotResp ¶ added in v0.5.0
DotResp is used as the .Resp field in buffered template invocations.
func (*DotResp) AddHeader ¶ added in v0.5.0
AddHeader adds a header field value, appending val to existing values for that field. It returns an empty string.
func (*DotResp) DelHeader ¶ added in v0.5.0
DelHeader deletes a header field. It returns an empty string.
func (*DotResp) ReturnStatus ¶ added in v0.5.0
ReturnStatus sets the HTTP response status and exits template rendering immediately.
func (*DotResp) ServeContent ¶ added in v0.5.0
ServeContent aborts execution of the template and instead responds to the request with content with any headers set by AddHeader and SetHeader so far but ignoring SetStatus.
type DotX ¶ added in v0.5.0
type DotX struct {
// contains filtered or unexported fields
}
DotX is used as the field at .X in all template invocations.
func (DotX) Func ¶ added in v0.5.0
Func returns a function by name to call manually. Can be used in combination with the call and try funcs.
func (DotX) StaticFileHash ¶ added in v0.5.0
StaticFileHash returns the sha-384 hash of the named asset file to be used for integrity or caching behavior.
type ErrorStatus ¶ added in v0.6.0
type ErrorStatus int
func (ErrorStatus) Error ¶ added in v0.6.0
func (e ErrorStatus) Error() string
type Instance ¶ added in v0.4.0
type Instance struct {
// contains filtered or unexported fields
}
Instance is a configured, immutable, xtemplate request handler ready to execute templates and serve static files in response to http requests.
The only way to create a valid Instance is to call the Config.Instance method. Configuration of an Instance is intended to be immutable. Instead of mutating a running Instance, build a new Instance from a modified Config and swap them.
See also Server which manages instances and enables reloading them.
type InstanceRoute ¶ added in v0.4.0
type InstanceStats ¶ added in v0.4.0
type Option ¶ added in v0.6.0
func WithFuncMaps ¶ added in v0.3.0
func WithLogger ¶ added in v0.3.0
func WithProvider ¶ added in v0.5.0
func WithProvider(name string, p DotProvider) Option
func WithTemplateFS ¶ added in v0.3.3
type RegisteredDotProvider ¶ added in v0.5.0
type RegisteredDotProvider interface { DotProvider Type() string New() DotProvider }
type ReturnError ¶
type ReturnError struct{}
ReturnError is a sentinel value that indicates a successful/normal exit but causes template execution to stop immediately. Used by funcs and dot field methods to perform custom actions.
func (ReturnError) Error ¶
func (ReturnError) Error() string
type Server ¶ added in v0.4.0
type Server struct {
// contains filtered or unexported fields
}
Server is a configured, *reloadable*, xtemplate request handler ready to execute templates and serve static files in response to http requests. It manages an Instance and allows you to reload template files with the same config by calling `server.Reload()`. If successful, Reload atomically swaps the old Instance with the new Instance so subsequent requests are handled by the new instance, and any outstanding requests still being served by the old Instance can continue to completion. The old instance's Config.Ctx is also cancelled.
The only way to create a valid *Server is to call Config.Server.
func (*Server) Handler ¶ added in v0.4.0
Handler returns a `http.Handler` that always routes new requests to the current Instance.
func (*Server) Instance ¶ added in v0.4.0
Instance returns the current Instance. After calling Reload, previous calls to Instance may be stale.
func (*Server) Reload ¶ added in v0.4.0
Reload creates a new Instance from the config and swaps it with the current instance if successful, otherwise returns the error.