Newer
Older
# Copyright (c) 2010-2011, Diaspora Inc. This file is
# licensed under the Affero General Public License version 3 or later. See
# the COPYRIGHT file.
class InvitationsController < ApplicationController
before_action :authenticate_user!, :only => [:new, :create]
@invite_code = current_user.invitation_code
@invalid_emails = html_safe_string_from_session_array(:invalid_email_invites)
@valid_emails = html_safe_string_from_session_array(:valid_email_invites)
respond_to do |format|
format.html do
render 'invitations/new', layout: false
end
end
# this is for legacy invites. We try to look the person who sent them the
# invite, and use their new invite code
Maxwell Salzberg
a validé
# owe will be removing this eventually
# @depreciated
def edit
user = User.find_by_invitation_token(params[:invitation_token])
invitation_code = user.ugly_accept_invitation_code
redirect_to invite_code_path(invitation_code)
@invitation_code =
if params[:invitation_token]
# this is for legacy invites.
user = User.find_by_invitation_token(params[:invitation_token])
user.ugly_accept_invitation_code if user
else
params[:invitation_code]
end
@inviter = user || InvitationCode.where(id: params[:invitation_code]).first.try(:user)
if @invitation_code.present?
render 'notifier/invite', :layout => false
flash[:error] = t('invitations.check_token.not_found')
redirect_to root_url
Ilyaaaaaaaaaaaaa Zhitomirskiy
a validé
emails = inviter_params[:emails].split(',').map(&:strip).uniq
valid_emails, invalid_emails = emails.partition { |email| valid_email?(email) }
session[:valid_email_invites] = valid_emails
session[:invalid_email_invites] = invalid_emails
Workers::Mail::InviteEmail.perform_async(valid_emails.join(','),
current_user.id,
end
if emails.empty?
flash[:error] = t('invitations.create.empty')
elsif invalid_emails.empty?
flash[:notice] = t('invitations.create.sent', :emails => valid_emails.join(', '))
elsif valid_emails.empty?
flash[:error] = t('invitations.create.rejected') + invalid_emails.join(', ')
else
flash[:error] = t('invitations.create.sent', :emails => valid_emails.join(', '))
flash[:error] << '. '
flash[:error] << t('invitations.create.rejected') + invalid_emails.join(', ')
end
redirect_to :back
danielgrippi
a validé
def check_if_invites_open
danielgrippi
a validé
flash[:error] = I18n.t 'invitations.create.no_more'
danielgrippi
a validé
redirect_to :back
end
end
private
def valid_email?(email)
User.email_regexp.match(email).present?
end
def html_safe_string_from_session_array(key)
return "" unless session[key].present?
return "" unless session[key].respond_to?(:join)
value = session[key].join(', ').html_safe
session[key] = nil
return value
end
def inviter_params
params.require(:email_inviter).permit(:message, :locale, :emails)
end