discourse/app/controllers/session_controller.rb

77 lines
2.2 KiB
Ruby
Raw Normal View History

2013-02-06 03:16:51 +08:00
class SessionController < ApplicationController
skip_before_filter :redirect_to_login_if_required
2013-02-06 03:16:51 +08:00
def csrf
render json: {csrf: form_authenticity_token }
end
2013-02-06 03:16:51 +08:00
def create
params.require(:login)
params.require(:password)
2013-02-06 03:16:51 +08:00
login = params[:login].strip
password = params[:password]
login = login[1..-1] if login[0] == "@"
2013-02-06 03:16:51 +08:00
@user = User.find_by_username_or_email(login)
2013-02-06 03:16:51 +08:00
2013-02-07 23:45:24 +08:00
if @user.present?
2013-02-06 03:16:51 +08:00
# If the site requires user approval and the user is not approved yet
if SiteSetting.must_approve_users? && !@user.approved? && !@user.admin?
render json: {error: I18n.t("login.not_approved")}
2013-02-06 03:16:51 +08:00
return
end
# If their password is correct
if @user.confirm_password?(password)
if @user.suspended?
if reason = @user.suspend_reason
render json: { error: I18n.t("login.suspended_with_reason", {date: I18n.l(@user.suspended_till, format: :date_only), reason: reason}) }
else
render json: { error: I18n.t("login.suspended", {date: I18n.l(@user.suspended_till, format: :date_only)}) }
end
return
end
2013-02-12 00:18:26 +08:00
if @user.email_confirmed?
log_on_user(@user)
render_serialized(@user, UserSerializer)
return
else
render json: {
error: I18n.t("login.not_activated"),
reason: 'not_activated',
sent_to_email: @user.email_logs.where(email_type: 'signup').order('created_at DESC').first.try(:to_address) || @user.email,
current_email: @user.email
}
2013-02-12 00:18:26 +08:00
return
end
2013-02-06 03:16:51 +08:00
end
end
render json: {error: I18n.t("login.incorrect_username_email_or_password")}
2013-02-06 03:16:51 +08:00
end
def forgot_password
params.require(:login)
2013-02-06 03:16:51 +08:00
user = User.find_by_username_or_email(params[:login])
2013-02-06 03:16:51 +08:00
if user.present?
email_token = user.email_tokens.create(email: user.email)
Jobs.enqueue(:user_email, type: :forgot_password, user_id: user.id, email_token: email_token.token)
end
# always render of so we don't leak information
render json: {result: "ok"}
2013-02-06 03:16:51 +08:00
end
def destroy
reset_session
log_off_user
2013-02-06 03:16:51 +08:00
render nothing: true
end
end