aboutsummaryrefslogtreecommitdiff
path: root/internal/app/api.go
diff options
context:
space:
mode:
Diffstat (limited to 'internal/app/api.go')
-rw-r--r--internal/app/api.go36
1 files changed, 36 insertions, 0 deletions
diff --git a/internal/app/api.go b/internal/app/api.go
new file mode 100644
index 00000000..c64e946e
--- /dev/null
+++ b/internal/app/api.go
@@ -0,0 +1,36 @@
+// Copyright 2020 The Gogs Authors. All rights reserved.
+// Use of this source code is governed by a MIT-style
+// license that can be found in the LICENSE file.
+
+package app
+
+import (
+ "net/http"
+
+ "github.com/microcosm-cc/bluemonday"
+ "gopkg.in/macaron.v1"
+
+ "gogs.io/gogs/internal/context"
+)
+
+func ipynbSanitizer() *bluemonday.Policy {
+ p := bluemonday.UGCPolicy()
+ p.AllowAttrs("class", "data-prompt-number").OnElements("div")
+ p.AllowAttrs("class").OnElements("img")
+ p.AllowURLSchemes("data")
+ return p
+}
+
+func SanitizeIpynb() macaron.Handler {
+ p := ipynbSanitizer()
+
+ return func(c *context.Context) {
+ html, err := c.Req.Body().String()
+ if err != nil {
+ c.Error(err, "read body")
+ return
+ }
+
+ c.PlainText(http.StatusOK, p.Sanitize(html))
+ }
+}