func Login(context *GoInk.Context) { if context.Method == "POST" { data := context.Input() user := model.GetUserByName(data["user"]) if user == nil { Json(context, false).End() return } if !user.CheckPassword(data["password"]) { Json(context, false).End() return } exp := 3600 * 24 * 3 expStr := strconv.Itoa(exp) s := model.CreateToken(user, context, int64(exp)) context.Cookie("token-user", strconv.Itoa(s.UserId), expStr) context.Cookie("token-value", s.Value, expStr) Json(context, true).End() return } if context.Cookie("token-value") != "" { context.Redirect("/admin/") return } context.Render("admin/login", nil) }
func Auth(context *GoInk.Context) { tokenValue := context.Cookie("token-value") token := model.GetTokenByValue(tokenValue) if token == nil { context.Redirect("/logout/") context.End() return } if !token.IsValid() { context.Redirect("/logout/") context.End() return } }
func TopPage(context *GoInk.Context) { slug := context.Param("slug") page := model.GetContentBySlug(slug) if page == nil || page.Status != "publish" { context.Redirect("/") return } if page.IsLinked && page.Type == "page" { Theme(context).Layout("home").Render("page", map[string]interface{}{ "Title": page.Title, "Page": page, }) page.Hits++ return } context.Redirect("/") }
func Article(context *GoInk.Context) { id, _ := strconv.Atoi(context.Param("id")) slug := context.Param("slug") article := model.GetContentById(id) if article == nil { context.Redirect("/") return } if article.Slug != slug || article.Type != "article" { context.Redirect("/") return } article.Hits++ Theme(context).Layout("home").Render("article", map[string]interface{}{ "Title": article.Title, "Article": article, "CommentHtml": CommentHtml(context, article), }) }
func PageEdit(context *GoInk.Context) { id, _ := strconv.Atoi(context.Param("id")) c := model.GetContentById(id) if c == nil { context.Redirect("/admin/pages/") return } if context.Method == "DELETE" { model.RemoveContent(c) Json(context, true).End() return } if context.Method == "POST" { data := context.Input() if !c.ChangeSlug(data["slug"]) { Json(context, false).Set("msg", "固定链接重复").End() return } c.Title = data["title"] c.Text = data["content"] //c.Tags = strings.Split(strings.Replace(data["tag"], ",", ",", -1), ",") c.IsComment = data["comment"] == "1" c.IsLinked = data["link"] == "1" //c.AuthorId, _ = strconv.Atoi(context.Cookie("token-user")) //c.Template = "blog.html" c.Status = data["status"] //c.Format = "markdown" model.SaveContent(c) Json(context, true).Set("content", c).End() context.Do("page_modified", c) //c.Type = "article" return } context.Layout("admin/admin") context.Render("admin/edit_page", map[string]interface{}{ "Title": "编辑文章", "Page": c, }) }
func PluginSetting(context *GoInk.Context) { key := context.Param("plugin_key") if key == "" { context.Redirect("/admin/plugins/") return } p := plugin.GetPluginByKey(key) if p == nil { context.Redirect("/admin/plugins/") return } if context.Method == "POST" { p.SetSetting(context.Input()) Json(context, true).End() context.Do("plugin_setting_saved", p) return } context.Layout("admin/admin") context.Render("admin/plugin_setting", map[string]interface{}{ "Title": "插件 - " + p.Name(), "Form": p.Form(), }) }
func Logout(context *GoInk.Context) { context.Cookie("token-user", "", "-3600") context.Cookie("token-value", "", "-3600") context.Redirect("/login/") }