func SaveBlog(ctx *middleware.Context, blog model.Blog) { if blog.Title == "" || blog.Content == "" { ctx.AddError(Translate(ctx.S.Get("Lang").(string), "message.error.save.failed")) } else { tags := ctx.R.PostForm["tags"] blog.SetTags(tags) signedUser := ctx.S.Get("SignedUser").(model.User) blog.UpdateUser = signedUser.Username if blog.Version == 0 { blog.State = "DRAFT" blog.Priority = 5 blog.Author = signedUser blog.CreateUser = signedUser.Username err := blog.Insert() PanicIf(err) } else { err := blog.Update() PanicIf(err) } dbBlog, err := blog.GetBlogById() PanicIf(err) ctx.Set("Blog", dbBlog) ctx.AddMessage(Translate(ctx.S.Get("Lang").(string), "message.save.success")) } tags, err := blog.GetAllTags() PanicIf(err) ctx.Set("Tags", tags) ctx.HTML(200, "blog/edit", ctx) }
func LoginHandler(ctx *middleware.Context, formErr binding.Errors, loginUser model.UserLoginForm) { switch ctx.R.Method { case "POST": ctx.JoinFormErrors(formErr) password := Md5(loginUser.Password) user := &model.User{Username: loginUser.Username, Password: password} if !ctx.HasError() { if has, err := user.Exist(); has { PanicIf(err) if user.Locked { ctx.Set("User", user) ctx.AddError(Translate(ctx.S.Get("Lang").(string), "message.error.invalid.username.or.password")) ctx.HTML(200, "user/login", ctx) return } ctx.S.Set("SignedUser", user) Log.Info(user.Username, " login") ctx.Redirect("/admin/dashboard") } else { ctx.Set("User", user) ctx.AddError(Translate(ctx.S.Get("Lang").(string), "message.error.invalid.username.or.password")) ctx.HTML(200, "user/login", ctx) } } else { ctx.HTML(200, "user/login", ctx) } default: ctx.HTML(200, "user/login", ctx) } }
func PublishBlog(ctx *middleware.Context, blog model.Blog) { switch ctx.R.Method { case "POST": if blog.Title == "" || blog.Content == "" { ctx.AddError(Translate(ctx.S.Get("Lang").(string), "message.error.publish.failed")) } else { tags := ctx.R.PostForm["tags"] blog.SetTags(tags) signedUser := ctx.S.Get("SignedUser").(model.User) blog.State = "PUBLISHED" blog.PublishDate = time.Now() if blog.Version == 0 { blog.Priority = 5 blog.Author = signedUser blog.CreateUser = signedUser.Username err := blog.Insert() PanicIf(err) } else { err := blog.Update() PanicIf(err) } } ctx.Redirect("/blog/view/" + IntString(blog.Id)) default: tags, err := blog.GetAllTags() PanicIf(err) ctx.Set("Tags", tags) ctx.HTML(200, "blog/edit", ctx) } }
func PasswordHandler(ctx *middleware.Context, formErr binding.Errors, password model.Password) { switch ctx.R.Method { case "POST": ctx.JoinFormErrors(formErr) if !ctx.HasError() { if password.CurrentPassword == password.ConfirmPassword { ctx.AddError(Translate(ctx.S.Get("Lang").(string), "message.error.password.not.changed")) } else { user := &model.User{Id: password.Id} dbUser, err := user.GetUserById(user.Id) PanicIf(err) if dbUser.Password == Md5(password.CurrentPassword) { dbUser.Password = Md5(password.ConfirmPassword) err := dbUser.Update() PanicIf(err) ctx.AddMessage(Translate(ctx.S.Get("Lang").(string), "message.change.success")) } else { ctx.AddError(Translate(ctx.S.Get("Lang").(string), "message.error.wrong.password")) } } } default: } ctx.HTML(200, "profile/password", ctx) }