journalduhacker/app/controllers/invitations_controller.rb

101 lines
2.6 KiB
Ruby
Raw Normal View History

2012-07-01 20:31:31 +02:00
class InvitationsController < ApplicationController
before_filter :require_logged_in_user,
:except => [ :build, :create_by_request, :confirm_email ]
def build
@invitation_request = InvitationRequest.new
end
def index
@invitation_requests = InvitationRequest.where(:is_verified => true)
end
def confirm_email
if !(ir = InvitationRequest.where(:code => params[:code].to_s).first)
flash[:error] = "Invalid or expired invitation request"
return redirect_to "/invitations/request"
end
ir.is_verified = true
ir.save!
flash[:success] = "Your invitiation request has been validated and " <<
"will now be shown to other logged-in users."
return redirect_to "/invitations/request"
end
2012-07-01 20:31:31 +02:00
def create
i = Invitation.new
i.user_id = @user.id
i.email = params[:email]
i.memo = params[:memo]
begin
i.save!
i.send_email
flash[:success] = "Successfully e-mailed invitation to " <<
params[:email].to_s << "."
rescue
2012-07-01 20:31:31 +02:00
flash[:error] = "Could not send invitation, verify the e-mail " <<
"address is valid."
end
if params[:return_home]
return redirect_to "/"
else
return redirect_to "/settings"
end
2012-07-01 20:31:31 +02:00
end
def create_by_request
@invitation_request = InvitationRequest.new(
params.require(:invitation_request).permit(:name, :email, :memo))
@invitation_request.ip_address = request.remote_ip
if @invitation_request.save
flash[:success] = "You have been e-mailed a confirmation to " <<
params[:invitation_request][:email].to_s << "."
return redirect_to "/invitations/request"
else
render :action => :build
end
end
def send_for_request
if !(ir = InvitationRequest.where(:code => params[:code].to_s).first)
flash[:error] = "Invalid or expired invitation request"
return redirect_to "/invitations"
end
i = Invitation.new
i.user_id = @user.id
i.email = ir.email
i.save!
i.send_email
ir.destroy!
flash[:success] = "Successfully e-mailed invitation to " <<
ir.name.to_s << "."
return redirect_to "/invitations"
end
def delete_request
if !@user.is_moderator?
return redirect_to "/invitations"
end
if !(ir = InvitationRequest.where(:code => params[:code].to_s).first)
flash[:error] = "Invalid or expired invitation request"
return redirect_to "/invitations"
end
ir.destroy!
flash[:success] = "Successfully deleted invitation request from " <<
ir.name.to_s << "."
return redirect_to "/invitations"
end
2012-07-01 20:31:31 +02:00
end