2020-06-07 08:28:05 +00:00
|
|
|
class Api::V1::Accounts::CallbacksController < Api::V1::Accounts::BaseController
|
2020-02-26 12:52:08 +00:00
|
|
|
before_action :inbox, only: [:reauthorize_page]
|
2019-08-14 09:48:44 +00:00
|
|
|
|
|
|
|
def register_facebook_page
|
|
|
|
user_access_token = params[:user_access_token]
|
|
|
|
page_access_token = params[:page_access_token]
|
|
|
|
page_id = params[:page_id]
|
|
|
|
inbox_name = params[:inbox_name]
|
2020-04-19 18:10:28 +00:00
|
|
|
ActiveRecord::Base.transaction do
|
2020-06-07 08:28:05 +00:00
|
|
|
facebook_channel = Current.account.facebook_pages.create!(
|
2020-04-19 18:10:28 +00:00
|
|
|
page_id: page_id, user_access_token: user_access_token,
|
|
|
|
page_access_token: page_access_token
|
|
|
|
)
|
2020-06-07 08:28:05 +00:00
|
|
|
@facebook_inbox = Current.account.inboxes.create!(name: inbox_name, channel: facebook_channel)
|
2020-04-19 18:10:28 +00:00
|
|
|
set_avatar(@facebook_inbox, page_id)
|
|
|
|
rescue StandardError => e
|
2020-05-14 17:21:07 +00:00
|
|
|
Rails.logger.info e
|
2020-04-19 18:10:28 +00:00
|
|
|
end
|
2019-08-14 09:48:44 +00:00
|
|
|
end
|
|
|
|
|
2020-03-09 17:57:10 +00:00
|
|
|
def facebook_pages
|
2019-10-20 08:47:26 +00:00
|
|
|
@page_details = mark_already_existing_facebook_pages(fb_object.get_connections('me', 'accounts'))
|
2019-08-14 09:48:44 +00:00
|
|
|
end
|
|
|
|
|
2020-06-07 08:28:05 +00:00
|
|
|
# get params[:inbox_id], current_account. params[:omniauth_token]
|
2019-12-12 21:12:16 +00:00
|
|
|
def reauthorize_page
|
2020-02-26 12:52:08 +00:00
|
|
|
if @inbox&.facebook?
|
2019-12-12 21:12:16 +00:00
|
|
|
fb_page_id = @inbox.channel.page_id
|
2019-10-20 08:47:26 +00:00
|
|
|
page_details = fb_object.get_connections('me', 'accounts')
|
2019-12-12 21:12:16 +00:00
|
|
|
|
2020-02-26 12:52:08 +00:00
|
|
|
if (page_detail = (page_details || []).detect { |page| fb_page_id == page['id'] })
|
|
|
|
update_fb_page(fb_page_id, page_detail['access_token'])
|
|
|
|
return head :ok
|
2019-08-14 09:48:44 +00:00
|
|
|
end
|
|
|
|
end
|
2019-12-12 21:12:16 +00:00
|
|
|
|
2019-08-14 09:48:44 +00:00
|
|
|
head :unprocessable_entity
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
2019-12-12 21:12:16 +00:00
|
|
|
def inbox
|
2020-06-07 08:28:05 +00:00
|
|
|
@inbox = Current.account.inboxes.find_by(id: params[:inbox_id])
|
2019-12-12 21:12:16 +00:00
|
|
|
end
|
|
|
|
|
2020-02-26 12:52:08 +00:00
|
|
|
def update_fb_page(fb_page_id, access_token)
|
2020-02-29 15:11:09 +00:00
|
|
|
get_fb_page(fb_page_id)&.update!(
|
2020-02-26 12:52:08 +00:00
|
|
|
user_access_token: @user_access_token, page_access_token: access_token
|
|
|
|
)
|
2019-12-12 21:12:16 +00:00
|
|
|
end
|
|
|
|
|
2020-02-26 12:52:08 +00:00
|
|
|
def get_fb_page(fb_page_id)
|
2020-06-07 08:28:05 +00:00
|
|
|
Current.account.facebook_pages.find_by(page_id: fb_page_id)
|
2019-12-12 21:12:16 +00:00
|
|
|
end
|
|
|
|
|
2019-08-14 09:48:44 +00:00
|
|
|
def fb_object
|
|
|
|
@user_access_token = long_lived_token(params[:omniauth_token])
|
|
|
|
Koala::Facebook::API.new(@user_access_token)
|
|
|
|
end
|
|
|
|
|
|
|
|
def long_lived_token(omniauth_token)
|
2019-11-23 19:57:39 +00:00
|
|
|
koala = Koala::Facebook::OAuth.new(ENV['FB_APP_ID'], ENV['FB_APP_SECRET'])
|
2020-02-26 12:52:08 +00:00
|
|
|
koala.exchange_access_token_info(omniauth_token)['access_token']
|
2020-03-28 06:13:02 +00:00
|
|
|
rescue StandardError => e
|
2020-05-14 17:21:07 +00:00
|
|
|
Rails.logger.info e
|
2019-08-14 09:48:44 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
def mark_already_existing_facebook_pages(data)
|
|
|
|
return [] if data.empty?
|
2019-10-20 08:47:26 +00:00
|
|
|
|
2019-08-14 09:48:44 +00:00
|
|
|
data.inject([]) do |result, page_detail|
|
2020-06-07 08:28:05 +00:00
|
|
|
page_detail[:exists] = Current.account.facebook_pages.exists?(page_id: page_detail['id']) ? true : false
|
2019-08-14 09:48:44 +00:00
|
|
|
result << page_detail
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2020-04-19 18:10:28 +00:00
|
|
|
def set_avatar(facebook_inbox, page_id)
|
2020-02-26 12:52:08 +00:00
|
|
|
uri = get_avatar_url(page_id)
|
|
|
|
|
|
|
|
return unless uri
|
|
|
|
|
|
|
|
avatar_resource = LocalResource.new(uri)
|
2020-04-19 18:10:28 +00:00
|
|
|
facebook_inbox.avatar.attach(io: avatar_resource.file, filename: avatar_resource.tmp_filename, content_type: avatar_resource.encoding)
|
2020-01-07 17:29:17 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
def get_avatar_url(page_id)
|
2019-08-14 09:48:44 +00:00
|
|
|
begin
|
2019-10-20 08:47:26 +00:00
|
|
|
url = 'http://graph.facebook.com/' << page_id << '/picture?type=large'
|
2019-08-14 09:48:44 +00:00
|
|
|
uri = URI.parse(url)
|
|
|
|
tries = 3
|
|
|
|
begin
|
|
|
|
response = uri.open(redirect: false)
|
2019-10-20 08:47:26 +00:00
|
|
|
rescue OpenURI::HTTPRedirect => e
|
|
|
|
uri = e.uri # assigned from the "Location" response header
|
2020-03-09 17:57:10 +00:00
|
|
|
retry if (tries -= 1).positive?
|
2019-08-14 09:48:44 +00:00
|
|
|
raise
|
|
|
|
end
|
|
|
|
pic_url = response.base_uri.to_s
|
2019-10-20 08:47:26 +00:00
|
|
|
rescue StandardError => e
|
2020-03-09 17:57:10 +00:00
|
|
|
Rails.logger.debug "Rescued: #{e.inspect}"
|
2019-08-14 09:48:44 +00:00
|
|
|
pic_url = nil
|
|
|
|
end
|
|
|
|
pic_url
|
|
|
|
end
|
|
|
|
end
|