githaven/routers/api/v1/miscellaneous.go

44 lines
1.1 KiB
Go
Raw Normal View History

2014-03-29 21:16:06 +08:00
// Copyright 2014 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.
2014-03-29 10:01:52 -04:00
package v1
2014-03-29 21:16:06 +08:00
2014-03-29 10:01:52 -04:00
import (
2014-05-05 13:08:01 -04:00
"io/ioutil"
"strings"
"github.com/gogits/gogs/modules/auth/apiv1"
2014-03-29 10:01:52 -04:00
"github.com/gogits/gogs/modules/base"
"github.com/gogits/gogs/modules/middleware"
2014-05-25 20:11:25 -04:00
"github.com/gogits/gogs/modules/setting"
2014-03-29 10:01:52 -04:00
)
2014-03-29 21:16:06 +08:00
2014-05-05 13:08:01 -04:00
const DOC_URL = "http://gogs.io/docs"
// Render an arbitrary Markdown document.
func Markdown(ctx *middleware.Context, form apiv1.MarkdownForm) {
if ctx.HasApiError() {
ctx.JSON(422, base.ApiJsonErr{ctx.GetErrMsg(), DOC_URL})
return
}
switch form.Mode {
case "gfm":
ctx.Write(base.RenderMarkdown([]byte(form.Text),
2014-05-25 20:11:25 -04:00
setting.AppUrl+strings.TrimPrefix(form.Context, "/")))
2014-05-05 13:08:01 -04:00
default:
ctx.Write(base.RenderRawMarkdown([]byte(form.Text), ""))
}
}
// Render a Markdown document in raw mode.
func MarkdownRaw(ctx *middleware.Context) {
body, err := ioutil.ReadAll(ctx.Req.Body)
if err != nil {
ctx.JSON(422, base.ApiJsonErr{err.Error(), DOC_URL})
return
}
ctx.Write(base.RenderRawMarkdown(body, ""))
2014-03-29 21:16:06 +08:00
}