2013-02-06 03:16:51 +08:00
|
|
|
class InvitesController < ApplicationController
|
|
|
|
|
|
|
|
skip_before_filter :check_xhr, :check_restricted_access
|
2013-06-06 02:12:37 +08:00
|
|
|
skip_before_filter :redirect_to_login_if_required
|
|
|
|
|
2013-02-06 03:16:51 +08:00
|
|
|
before_filter :ensure_logged_in, only: [:destroy]
|
|
|
|
|
|
|
|
def show
|
|
|
|
invite = Invite.where(invite_key: params[:id]).first
|
|
|
|
|
|
|
|
if invite.present?
|
|
|
|
user = invite.redeem
|
2013-02-07 23:45:24 +08:00
|
|
|
if user.present?
|
2013-02-06 03:16:51 +08:00
|
|
|
log_on_user(user)
|
|
|
|
|
|
|
|
# Send a welcome message if required
|
|
|
|
user.enqueue_welcome_message('welcome_invite') if user.send_welcome_message
|
|
|
|
|
|
|
|
# We skip the access password if we come in via an invite link
|
2013-03-02 01:45:25 +08:00
|
|
|
cookies.permanent['_access'] = SiteSetting.access_password if SiteSetting.access_password.present?
|
2013-02-06 03:16:51 +08:00
|
|
|
|
|
|
|
topic = invite.topics.first
|
|
|
|
if topic.present?
|
2013-03-14 20:01:52 +08:00
|
|
|
redirect_to "#{Discourse.base_uri}#{topic.relative_url}"
|
2013-02-06 03:16:51 +08:00
|
|
|
return
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
redirect_to root_path
|
|
|
|
end
|
|
|
|
|
|
|
|
def destroy
|
2013-06-05 15:04:03 +08:00
|
|
|
params.require(:email)
|
2013-02-06 03:16:51 +08:00
|
|
|
|
2013-02-07 23:45:24 +08:00
|
|
|
invite = Invite.where(invited_by_id: current_user.id, email: params[:email]).first
|
2013-02-06 03:16:51 +08:00
|
|
|
raise Discourse::InvalidParameters.new(:email) if invite.blank?
|
2013-05-07 12:39:01 +08:00
|
|
|
invite.trash!
|
2013-02-06 03:16:51 +08:00
|
|
|
|
|
|
|
render nothing: true
|
|
|
|
end
|
|
|
|
|
|
|
|
end
|