mirror of
https://github.com/discourse/discourse-chat-integration.git
synced 2025-07-01 11:52:10 +00:00
* FEATURE: Add chat integration reference post This class works similar to a post but it is not a post. * DEV: change how `excerpt` method works * feature: Add `send_chat_integration_message` scriptable add `send_chat_integration_message` scriptable that uses the rules to send a message to the chat provider add locale strings for the new scriptable update `ChatIntegrationReferencePost` `excerpt` method add tests for `ChatIntegrationReferencePost` * DEV: Add `get_channel_by_name` to every provider This makes using `trigger_notification` easier with every provider as well. * DEV: Add `get_channel_name` to all providers This method gets the name of the channel based on how the provider identifies it. Updates channel_name in locales yaml Adds migrate_tag_added_filter_to_all_providers.rb to move all existing rules to use Automation * DEV: Add removal of old migration data Update small action locales with strings from core * DEV: solve review comments * DEV: update test locale strings * DEV: remove empty line to trigger lint * DEV: lint applied * DEV: Add tests for automation integration * DEV: add rails logger for when automatio error occurs * DEV: move migration to be SQL only Update provider helper to use hashes instead of dot notation * DEV: update migration with correct table names * DEV: Update migrate_tag_added_filter_to_all_providers to use smaller SQL queries Commented out migrate_tag_added_from_filter_to_automation.rb * DEV: update comments in migration file * DEV: update indentation in client.en.yml * DEV: update with review comments * Update spec/lib/discourse_chat_integration/chat_integration_reference_post_spec.rb Co-authored-by: Jarek Radosz <jradosz@gmail.com> * Update spec/lib/discourse_chat_integration/chat_integration_reference_post_spec.rb Co-authored-by: Jarek Radosz <jradosz@gmail.com> * Update spec/lib/discourse_chat_integration/chat_integration_reference_post_spec.rb Co-authored-by: Jarek Radosz <jradosz@gmail.com> * Update spec/integration/automation_spec.rb Co-authored-by: Jarek Radosz <jradosz@gmail.com> * Update lib/discourse_chat_integration/chat_integration_reference_post.rb Co-authored-by: Jarek Radosz <jradosz@gmail.com> * DEV: update specs with review comments * DEV: update typos in tests * DEV: inlined functions for getting channel name for provider in migration --------- Co-authored-by: Jarek Radosz <jradosz@gmail.com>
57 lines
1.9 KiB
Ruby
57 lines
1.9 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
module DiscourseChatIntegration
|
|
module Provider
|
|
module GitterProvider
|
|
PROVIDER_NAME = "gitter".freeze
|
|
PROVIDER_ENABLED_SETTING = :chat_integration_gitter_enabled
|
|
CHANNEL_IDENTIFIER_KEY = "name".freeze
|
|
CHANNEL_PARAMETERS = [
|
|
{ key: "name", regex: '^\S+$', unique: true },
|
|
{
|
|
key: "webhook_url",
|
|
regex: '^https://webhooks\.gitter\.im/e/\S+$',
|
|
unique: true,
|
|
hidden: true,
|
|
},
|
|
]
|
|
|
|
def self.trigger_notification(post, channel, rule)
|
|
message = gitter_message(post)
|
|
response = Net::HTTP.post_form(URI(channel.data["webhook_url"]), message: message)
|
|
unless response.kind_of? Net::HTTPSuccess
|
|
error_key = nil
|
|
raise ::DiscourseChatIntegration::ProviderError.new info: {
|
|
error_key: error_key,
|
|
message: message,
|
|
response_body: response.body,
|
|
}
|
|
end
|
|
end
|
|
|
|
def self.gitter_message(post)
|
|
display_name = post.user.username
|
|
topic = post.topic
|
|
parent_category = topic.category.try :parent_category
|
|
category_name =
|
|
(
|
|
if parent_category
|
|
"[#{parent_category.name}/#{topic.category.name}]"
|
|
else
|
|
"[#{topic.category.name}]"
|
|
end
|
|
)
|
|
|
|
"[__#{display_name}__ - #{topic.title} - #{category_name}](#{post.full_url})"
|
|
end
|
|
|
|
def self.get_channel_by_name(name)
|
|
DiscourseChatIntegration::Channel
|
|
.with_provider(PROVIDER_NAME)
|
|
.with_data_value(CHANNEL_IDENTIFIER_KEY, name)
|
|
.first
|
|
end
|
|
end
|
|
end
|
|
end
|