mirror of
https://github.com/Growstuff/growstuff.git
synced 2025-12-24 01:57:46 -05:00
This change removes the twitter authentication feature from the application. It removes the `omniauth-twitter` gem and all related code from controllers, views, and tests. It also removes the twitter icon and environment variable settings.
116 lines
3.0 KiB
Ruby
116 lines
3.0 KiB
Ruby
# 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])
|
|
@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
|