71 lines
1.8 KiB
Ruby
71 lines
1.8 KiB
Ruby
# == Schema Information
|
|
#
|
|
# Table name: channel_facebook_pages
|
|
#
|
|
# id :integer not null, primary key
|
|
# page_access_token :string not null
|
|
# user_access_token :string not null
|
|
# created_at :datetime not null
|
|
# updated_at :datetime not null
|
|
# account_id :integer not null
|
|
# instagram_id :string
|
|
# page_id :string not null
|
|
#
|
|
# Indexes
|
|
#
|
|
# index_channel_facebook_pages_on_page_id (page_id)
|
|
# index_channel_facebook_pages_on_page_id_and_account_id (page_id,account_id) UNIQUE
|
|
#
|
|
|
|
class Channel::FacebookPage < ApplicationRecord
|
|
include Channelable
|
|
include Reauthorizable
|
|
|
|
self.table_name = 'channel_facebook_pages'
|
|
|
|
validates :page_id, uniqueness: { scope: :account_id }
|
|
|
|
after_create_commit :subscribe
|
|
before_destroy :unsubscribe
|
|
|
|
def name
|
|
'Facebook'
|
|
end
|
|
|
|
def has_24_hour_messaging_window?
|
|
true
|
|
end
|
|
|
|
def create_contact_inbox(instagram_id, name)
|
|
ActiveRecord::Base.transaction do
|
|
contact = inbox.account.contacts.create!(name: name)
|
|
::ContactInbox.create(
|
|
contact_id: contact.id,
|
|
inbox_id: inbox.id,
|
|
source_id: instagram_id
|
|
)
|
|
rescue StandardError => e
|
|
Rails.logger.info e
|
|
end
|
|
end
|
|
|
|
def subscribe
|
|
# ref https://developers.facebook.com/docs/messenger-platform/reference/webhook-events
|
|
response = Facebook::Messenger::Subscriptions.subscribe(
|
|
access_token: page_access_token,
|
|
subscribed_fields: %w[
|
|
messages message_deliveries message_echoes message_reads
|
|
]
|
|
)
|
|
rescue => e
|
|
Rails.logger.debug { "Rescued: #{e.inspect}" }
|
|
true
|
|
end
|
|
|
|
def unsubscribe
|
|
Facebook::Messenger::Subscriptions.unsubscribe(access_token: page_access_token)
|
|
rescue => e
|
|
Rails.logger.debug { "Rescued: #{e.inspect}" }
|
|
true
|
|
end
|
|
end
|