discourse/app/controllers/invites_controller.rb

42 lines
1.1 KiB
Ruby

class InvitesController < ApplicationController
skip_before_filter :check_xhr, :check_restricted_access
before_filter :ensure_logged_in, only: [:destroy]
def show
invite = Invite.where(invite_key: params[:id]).first
if invite.present?
user = invite.redeem
if user.present?
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
cookies.permanent['_access'] = SiteSetting.access_password if SiteSetting.access_password.present?
topic = invite.topics.first
if topic.present?
redirect_to "#{Discourse.base_uri}#{topic.relative_url}"
return
end
end
end
redirect_to root_path
end
def destroy
requires_parameter(:email)
invite = Invite.where(invited_by_id: current_user.id, email: params[:email]).first
raise Discourse::InvalidParameters.new(:email) if invite.blank?
invite.trash!
render nothing: true
end
end