56 lines
1.7 KiB
Ruby
56 lines
1.7 KiB
Ruby
|
#######################################
|
||
|
# To create an external channel reply service
|
||
|
# - Inherit this as the base class.
|
||
|
# - Implement `channel_class` method in your child class.
|
||
|
# - Implement `perform_reply` method in your child class.
|
||
|
# - Implement additional custom logic for your `perform_reply` method.
|
||
|
# - When required override the validation_methods.
|
||
|
# - Use Childclass.new.perform.
|
||
|
######################################
|
||
|
class Base::SendOnChannelService
|
||
|
pattr_initialize [:message!]
|
||
|
|
||
|
def perform
|
||
|
validate_target_channel
|
||
|
return unless outgoing_message?
|
||
|
return if invalid_message?
|
||
|
|
||
|
perform_reply
|
||
|
end
|
||
|
|
||
|
private
|
||
|
|
||
|
delegate :conversation, to: :message
|
||
|
delegate :contact, :contact_inbox, :inbox, to: :conversation
|
||
|
delegate :channel, to: :inbox
|
||
|
|
||
|
def channel_class
|
||
|
raise 'Overwrite this method in child class'
|
||
|
end
|
||
|
|
||
|
def perform_reply
|
||
|
raise 'Overwrite this method in child class'
|
||
|
end
|
||
|
|
||
|
def outgoing_message_originated_from_channel?
|
||
|
# TODO: we need to refactor this logic as more integrations comes by
|
||
|
# chatwoot messages won't have source id at the moment
|
||
|
# outgoing messages may be created in slack which should be send to the channel
|
||
|
message.source_id.present? && !message.source_id.starts_with?('slack_')
|
||
|
end
|
||
|
|
||
|
def outgoing_message?
|
||
|
message.outgoing? || message.template?
|
||
|
end
|
||
|
|
||
|
def invalid_message?
|
||
|
# private notes aren't send to the channels
|
||
|
# we should also avoid the case of message loops, when outgoing messages are created from channel
|
||
|
message.private? || outgoing_message_originated_from_channel?
|
||
|
end
|
||
|
|
||
|
def validate_target_channel
|
||
|
raise 'Invalid channel service was called' if inbox.channel.class != channel_class
|
||
|
end
|
||
|
end
|