Chatwoot/app/controllers/twitter/callbacks_controller.rb

61 lines
1.6 KiB
Ruby

class Twitter::CallbacksController < Twitter::BaseController
include TwitterConcern
def show
return redirect_to twitter_app_redirect_url if permitted_params[:denied]
@response = ensure_access_token
return redirect_to twitter_app_redirect_url if @response.status != '200'
ActiveRecord::Base.transaction do
inbox = create_inbox
::Redis::Alfred.delete(permitted_params[:oauth_token])
::Twitter::WebhookSubscribeService.new(inbox_id: inbox.id).perform
redirect_to app_twitter_inbox_agents_url(account_id: account.id, inbox_id: inbox.id)
end
rescue StandardError => e
Rails.logger.error e
redirect_to twitter_app_redirect_url
end
private
def parsed_body
@parsed_body ||= Rack::Utils.parse_nested_query(@response.raw_response.body)
end
def account_id
::Redis::Alfred.get(permitted_params[:oauth_token])
end
def account
@account ||= Account.find(account_id)
end
def twitter_app_redirect_url
app_new_twitter_inbox_url(account_id: account.id)
end
def ensure_access_token
twitter_client.access_token(
oauth_token: permitted_params[:oauth_token],
oauth_verifier: permitted_params[:oauth_verifier]
)
end
def create_inbox
twitter_profile = account.twitter_profiles.create(
twitter_access_token: parsed_body['oauth_token'],
twitter_access_token_secret: parsed_body['oauth_token_secret'],
profile_id: parsed_body['user_id']
)
account.inboxes.create(
name: parsed_body['screen_name'],
channel: twitter_profile
)
end
def permitted_params
params.permit(:oauth_token, :oauth_verifier, :denied)
end
end