app/controllers/members_controller.rb
# frozen_string_literal: true
class MembersController < ApplicationController
load_and_authorize_resource except: %i(finish_signup unsubscribe view_follows view_followers show)
skip_authorize_resource only: %i(nearby unsubscribe finish_signup)
respond_to :html, :json, :rss
def index
@sort = params[:sort]
@members = members
respond_to do |format|
format.html # index.html.haml
format.json { render json: @members.to_json(only: member_json_fields) }
end
end
def show
@member = Member.confirmed.kept.find_by!(slug: params[:slug])
@twitter_auth = @member.auth('twitter')
@flickr_auth = @member.auth('flickr')
@posts = @member.posts
@activity = TimelineService.member_query(@member).limit(30)
@late = []
@super_late = []
@harvesting = []
@others = []
@member.plantings.active.annual.each do |planting|
if planting.finish_is_predicatable?
if planting.super_late?
@super_late << planting
elsif planting.late?
@late << planting
elsif planting.harvest_time?
@harvesting << planting
else
@others << planting
end
end
end
@harvests = Harvest.search(
where: { owner_id: @member.id },
boost_by: [:created_at],
limit: 16,
load: false
)
respond_to do |format|
format.html # show.html.haml
format.json { render json: @member.to_json(only: member_json_fields) }
format.rss do
render(
layout: false,
locals: { member: @member }
)
end
end
end
def unsubscribe
verifier = ActiveSupport::MessageVerifier.new(ENV.fetch('RAILS_SECRET_TOKEN', nil))
decrypted_message = verifier.verify(params[:message])
@member = Member.find(decrypted_message[:member_id])
@type = decrypted_message[:type]
@member.update(@type => false)
flash.now[:notice] = I18n.t('members.unsubscribed', email_type: EMAIL_TYPE_STRING[@type])
rescue ActiveSupport::MessageVerifier::InvalidSignature
flash.now[:alert] = I18n.t('members.unsubscribe.error')
end
def finish_signup
@member = current_member
return unless request.patch? && params[:member]
if @member.update(member_params)
@member.skip_reconfirmation!
bypass_sign_in(@member)
redirect_to root_path, notice: I18n.t('members.welcome')
else
flash[:alert] = I18n.t('members.signup.error')
@show_errors = true
end
end
private
EMAIL_TYPE_STRING = {
send_notification_email: "direct message notifications",
send_planting_reminder: "planting reminders"
}.freeze
def member_params
params.require(:member).permit(:login_name, :tos_agreement, :email, :newsletter)
end
def member_json_fields
%i(
id login_name
slug bio created_at
location latitude longitude
)
end
def members
if @sort == 'recently_joined'
Member.recently_joined
else
Member.order(:login_name)
end.kept.confirmed.paginate(page: params[:page])
end
end