Compare commits

..

4 Commits

Author SHA1 Message Date
45910947e7 Merge branch 'devel' 2025-02-12 17:29:12 +01:00
a1a470712b Merge branch 'devel' 2025-02-12 17:28:07 +01:00
259a2088a8 Merge branch 'devel' 2025-02-10 21:09:59 +01:00
5afd6b771a Merge branch 'devel' 2025-02-10 20:35:52 +01:00

View File

@ -6,35 +6,16 @@ import (
"github.com/microcosm-cc/bluemonday" "github.com/microcosm-cc/bluemonday"
"github.com/yuin/goldmark" "github.com/yuin/goldmark"
"github.com/yuin/goldmark/extension"
"github.com/yuin/goldmark/parser"
"github.com/yuin/goldmark/renderer/html"
) )
func ConvertToHTML(md string) (string, error) { func ConvertToHTML(md string) (string, error) {
var buf bytes.Buffer var buf bytes.Buffer
// Goldmark-Instanz mit GFM und aktivierter Attribute-Unterstützung initialisieren. if err := goldmark.Convert([]byte(md), &buf); err != nil {
gm := goldmark.New(
goldmark.WithExtensions(
extension.GFM,
),
goldmark.WithParserOptions(
parser.WithAttribute(),
),
goldmark.WithRendererOptions(
html.WithUnsafe(), // Falls du HTML-Inhalte erlauben möchtest
),
)
// Markdown in HTML konvertieren.
if err := gm.Convert([]byte(md), &buf); err != nil {
return "", fmt.Errorf("error converting markdown to html: %v", err) return "", fmt.Errorf("error converting markdown to html: %v", err)
} }
// Bluemonday-Policy anpassen, sodass id-Attribute auf h1-h6 erlaubt sind.
p := bluemonday.UGCPolicy() p := bluemonday.UGCPolicy()
p.AllowAttrs("id").OnElements("h1", "h2", "h3", "h4", "h5", "h6")
html := p.Sanitize(buf.String()) html := p.Sanitize(buf.String())
return html, nil return html, nil