package app import service._ import util.StringUtil._ import jp.sf.amateras.scalatra.forms._ class SignInController extends SignInControllerBase with SystemSettingsService with AccountService trait SignInControllerBase extends ControllerBase { self: SystemSettingsService with AccountService => case class SignInForm(userName: String, password: String) val form = mapping( "userName" -> trim(label("Username", text(required))), "password" -> trim(label("Password", text(required))) )(SignInForm.apply) get("/signin"){ val redirect = params.get("redirect") if(redirect.isDefined && redirect.get.startsWith("/")){ session.setAttribute("REDIRECT", redirect.get) } html.signin(loadSystemSettings()) } post("/signin", form){ form => getAccountByUserName(form.userName).collect { case account if(!account.isGroupAccount && account.password == sha1(form.password)) => { session.setAttribute("LOGIN_ACCOUNT", account) updateLastLoginDate(account.userName) session.get("REDIRECT").map { redirectUrl => session.removeAttribute("REDIRECT") redirect(redirectUrl.asInstanceOf[String]) }.getOrElse { redirect("/") } } } getOrElse redirect("/signin") } get("/signout"){ session.invalidate redirect("/") } }