//@URL: /account @method: POST func (uc *UserController) Password() { restweb.Logger.Debug("User Password") valid := restweb.Validation{} uid := uc.Uid // valid.AppendError("uid", uid) oldPwd := uc.Input.Get("user[oldPassword]") newPwd := uc.Input.Get("user[newPassword]") confirmPwd := uc.Input.Get("user[confirmPassword]") userModel := model.UserModel{} ret, err := userModel.Login(uid, oldPwd) if err != nil { uc.Error(err.Error(), 500) return } if ret.Uid == "" { valid.AppendError("oldPassword", "Old Password is Incorrect.") } valid.MinSize(newPwd, 6, "newPassword") valid.Equal(newPwd, confirmPwd, "confirmPassword") if !valid.HasError { err := userModel.Password(uid, newPwd) if err != nil { uc.Error(err.Error(), 400) return } uc.W.WriteHeader(200) } else { uc.W.WriteHeader(400) } hint := valid.RenderErrMap() b, _ := json.Marshal(&hint) uc.W.Write(b) }
//@URL: /users @method:POST func (uc *UserController) Register() { restweb.Logger.Debug("User Register") var one model.User userModel := model.UserModel{} uid := uc.Input.Get("user[handle]") nick := uc.Input.Get("user[nick]") pwd := uc.Input.Get("user[password]") pwdConfirm := uc.Input.Get("user[confirmPassword]") one.Mail = uc.Input.Get("user[mail]") one.School = uc.Input.Get("user[school]") one.Motto = uc.Input.Get("user[motto]") valid := restweb.Validation{} valid.MinSize(uid, 4, "uid") valid.Match(uid, "\\w+", "uid") if !valid.HasError { _, err := userModel.Detail(uid) if err != nil && err != model.NotFoundErr { http.Error(uc.W, err.Error(), 500) return } else if err == nil { valid.AppendError("uid", "Handle is currently in use.") } } valid.Required(nick, "nick") valid.MinSize(pwd, 6, "pwd") valid.Equal(pwd, pwdConfirm, "pwdConfirm") valid.Mail(one.Mail, "mail") if !valid.HasError { one.Uid = uid one.Nick = nick one.Pwd = pwd one.Privilege = config.PrivilegePU err := userModel.Insert(one) if err != nil { uc.Error(err.Error(), 500) return } uc.W.Header().Add("Location", "/users/"+uid) uc.W.WriteHeader(201) } else { hint := valid.RenderErrMap() b, _ := json.Marshal(&hint) uc.W.WriteHeader(400) uc.W.Write(b) } }