diff --git a/kernel/api/router.go b/kernel/api/router.go index dffd6c0ee..13b809899 100644 --- a/kernel/api/router.go +++ b/kernel/api/router.go @@ -263,6 +263,7 @@ func ServeAPI(ginServer *gin.Engine) { ginServer.Handle("POST", "/api/setting/setCustomCSS", model.CheckAuth, model.CheckReadonly, setCustomCSS) ginServer.Handle("POST", "/api/setting/setEmoji", model.CheckAuth, model.CheckReadonly, setEmoji) ginServer.Handle("POST", "/api/setting/setFlashcard", model.CheckAuth, model.CheckReadonly, setFlashcard) + ginServer.Handle("POST", "/api/setting/setAI", model.CheckAuth, model.CheckReadonly, setAI) ginServer.Handle("POST", "/api/graph/resetGraph", model.CheckAuth, model.CheckReadonly, resetGraph) ginServer.Handle("POST", "/api/graph/resetLocalGraph", model.CheckAuth, model.CheckReadonly, resetLocalGraph) diff --git a/kernel/api/setting.go b/kernel/api/setting.go index ce33153e1..fc0070e6a 100644 --- a/kernel/api/setting.go +++ b/kernel/api/setting.go @@ -29,6 +29,35 @@ import ( "github.com/siyuan-note/siyuan/kernel/util" ) +func setAI(c *gin.Context) { + ret := gulu.Ret.NewResult() + defer c.JSON(http.StatusOK, ret) + + arg, ok := util.JsonArg(c, ret) + if !ok { + return + } + + param, err := gulu.JSON.MarshalJSON(arg) + if nil != err { + ret.Code = -1 + ret.Msg = err.Error() + return + } + + ai := &conf.AI{} + if err = gulu.JSON.UnmarshalJSON(param, ai); nil != err { + ret.Code = -1 + ret.Msg = err.Error() + return + } + + model.Conf.AI = ai + model.Conf.Save() + + ret.Data = ai +} + func setFlashcard(c *gin.Context) { ret := gulu.Ret.NewResult() defer c.JSON(http.StatusOK, ret)