summaryrefslogtreecommitdiff
path: root/lib/gitlab/chat_commands/presenters
diff options
context:
space:
mode:
Diffstat (limited to 'lib/gitlab/chat_commands/presenters')
-rw-r--r--lib/gitlab/chat_commands/presenters/access.rb40
-rw-r--r--lib/gitlab/chat_commands/presenters/base.rb77
-rw-r--r--lib/gitlab/chat_commands/presenters/deploy.rb21
-rw-r--r--lib/gitlab/chat_commands/presenters/help.rb27
-rw-r--r--lib/gitlab/chat_commands/presenters/issue_base.rb43
-rw-r--r--lib/gitlab/chat_commands/presenters/issue_new.rb50
-rw-r--r--lib/gitlab/chat_commands/presenters/issue_search.rb47
-rw-r--r--lib/gitlab/chat_commands/presenters/issue_show.rb61
8 files changed, 0 insertions, 366 deletions
diff --git a/lib/gitlab/chat_commands/presenters/access.rb b/lib/gitlab/chat_commands/presenters/access.rb
deleted file mode 100644
index 92f4fa17f78..00000000000
--- a/lib/gitlab/chat_commands/presenters/access.rb
+++ /dev/null
@@ -1,40 +0,0 @@
-module Gitlab
- module ChatCommands
- module Presenters
- class Access < Presenters::Base
- def access_denied
- ephemeral_response(text: "Whoops! This action is not allowed. This incident will be [reported](https://xkcd.com/838/).")
- end
-
- def not_found
- ephemeral_response(text: "404 not found! GitLab couldn't find what you were looking for! :boom:")
- end
-
- def authorize
- message =
- if @resource
- ":wave: Hi there! Before I do anything for you, please [connect your GitLab account](#{@resource})."
- else
- ":sweat_smile: Couldn't identify you, nor can I autorize you!"
- end
-
- ephemeral_response(text: message)
- end
-
- def unknown_command(commands)
- ephemeral_response(text: help_message(trigger))
- end
-
- private
-
- def help_message(trigger)
- header_with_list("Command not found, these are the commands you can use", full_commands(trigger))
- end
-
- def full_commands(trigger)
- @resource.map { |command| "#{trigger} #{command.help_message}" }
- end
- end
- end
- end
-end
diff --git a/lib/gitlab/chat_commands/presenters/base.rb b/lib/gitlab/chat_commands/presenters/base.rb
deleted file mode 100644
index 05994bee79d..00000000000
--- a/lib/gitlab/chat_commands/presenters/base.rb
+++ /dev/null
@@ -1,77 +0,0 @@
-module Gitlab
- module ChatCommands
- module Presenters
- class Base
- include Gitlab::Routing.url_helpers
-
- def initialize(resource = nil)
- @resource = resource
- end
-
- def display_errors
- message = header_with_list("The action was not successful, because:", @resource.errors.full_messages)
-
- ephemeral_response(text: message)
- end
-
- private
-
- def header_with_list(header, items)
- message = [header]
-
- items.each do |item|
- message << "- #{item}"
- end
-
- message.join("\n")
- end
-
- def ephemeral_response(message)
- response = {
- response_type: :ephemeral,
- status: 200
- }.merge(message)
-
- format_response(response)
- end
-
- def in_channel_response(message)
- response = {
- response_type: :in_channel,
- status: 200
- }.merge(message)
-
- format_response(response)
- end
-
- def format_response(response)
- response[:text] = format(response[:text]) if response.key?(:text)
-
- if response.key?(:attachments)
- response[:attachments].each do |attachment|
- attachment[:pretext] = format(attachment[:pretext]) if attachment[:pretext]
- attachment[:text] = format(attachment[:text]) if attachment[:text]
- end
- end
-
- response
- end
-
- # Convert Markdown to slacks format
- def format(string)
- Slack::Notifier::LinkFormatter.format(string)
- end
-
- def resource_url
- url_for(
- [
- @resource.project.namespace.becomes(Namespace),
- @resource.project,
- @resource
- ]
- )
- end
- end
- end
- end
-end
diff --git a/lib/gitlab/chat_commands/presenters/deploy.rb b/lib/gitlab/chat_commands/presenters/deploy.rb
deleted file mode 100644
index 863d0bf99ca..00000000000
--- a/lib/gitlab/chat_commands/presenters/deploy.rb
+++ /dev/null
@@ -1,21 +0,0 @@
-module Gitlab
- module ChatCommands
- module Presenters
- class Deploy < Presenters::Base
- def present(from, to)
- message = "Deployment started from #{from} to #{to}. [Follow its progress](#{resource_url})."
-
- in_channel_response(text: message)
- end
-
- def no_actions
- ephemeral_response(text: "No action found to be executed")
- end
-
- def too_many_actions
- ephemeral_response(text: "Too many actions defined")
- end
- end
- end
- end
-end
diff --git a/lib/gitlab/chat_commands/presenters/help.rb b/lib/gitlab/chat_commands/presenters/help.rb
deleted file mode 100644
index cd47b7f4c6a..00000000000
--- a/lib/gitlab/chat_commands/presenters/help.rb
+++ /dev/null
@@ -1,27 +0,0 @@
-module Gitlab
- module ChatCommands
- module Presenters
- class Help < Presenters::Base
- def present(trigger, text)
- ephemeral_response(text: help_message(trigger, text))
- end
-
- private
-
- def help_message(trigger, text)
- return "No commands available :thinking_face:" unless @resource.present?
-
- if text.start_with?('help')
- header_with_list("Available commands", full_commands(trigger))
- else
- header_with_list("Unknown command, these commands are available", full_commands(trigger))
- end
- end
-
- def full_commands(trigger)
- @resource.map { |command| "#{trigger} #{command.help_message}" }
- end
- end
- end
- end
-end
diff --git a/lib/gitlab/chat_commands/presenters/issue_base.rb b/lib/gitlab/chat_commands/presenters/issue_base.rb
deleted file mode 100644
index 25bc82994ba..00000000000
--- a/lib/gitlab/chat_commands/presenters/issue_base.rb
+++ /dev/null
@@ -1,43 +0,0 @@
-module Gitlab
- module ChatCommands
- module Presenters
- module IssueBase
- def color(issuable)
- issuable.open? ? '#38ae67' : '#d22852'
- end
-
- def status_text(issuable)
- issuable.open? ? 'Open' : 'Closed'
- end
-
- def project
- @resource.project
- end
-
- def author
- @resource.author
- end
-
- def fields
- [
- {
- title: "Assignee",
- value: @resource.assignees.any? ? @resource.assignees.first.name : "_None_",
- short: true
- },
- {
- title: "Milestone",
- value: @resource.milestone ? @resource.milestone.title : "_None_",
- short: true
- },
- {
- title: "Labels",
- value: @resource.labels.any? ? @resource.label_names.join(', ') : "_None_",
- short: true
- }
- ]
- end
- end
- end
- end
-end
diff --git a/lib/gitlab/chat_commands/presenters/issue_new.rb b/lib/gitlab/chat_commands/presenters/issue_new.rb
deleted file mode 100644
index 3674ba25641..00000000000
--- a/lib/gitlab/chat_commands/presenters/issue_new.rb
+++ /dev/null
@@ -1,50 +0,0 @@
-module Gitlab
- module ChatCommands
- module Presenters
- class IssueNew < Presenters::Base
- include Presenters::IssueBase
-
- def present
- in_channel_response(new_issue)
- end
-
- private
-
- def new_issue
- {
- attachments: [
- {
- title: "#{@resource.title} · #{@resource.to_reference}",
- title_link: resource_url,
- author_name: author.name,
- author_icon: author.avatar_url,
- fallback: "New issue #{@resource.to_reference}: #{@resource.title}",
- pretext: pretext,
- color: color(@resource),
- fields: fields,
- mrkdwn_in: [
- :title,
- :pretext,
- :text,
- :fields
- ]
- }
- ]
- }
- end
-
- def pretext
- "I created an issue on #{author_profile_link}'s behalf: **#{@resource.to_reference}** in #{project_link}"
- end
-
- def project_link
- "[#{project.name_with_namespace}](#{project.web_url})"
- end
-
- def author_profile_link
- "[#{author.to_reference}](#{url_for(author)})"
- end
- end
- end
- end
-end
diff --git a/lib/gitlab/chat_commands/presenters/issue_search.rb b/lib/gitlab/chat_commands/presenters/issue_search.rb
deleted file mode 100644
index 73788cf9662..00000000000
--- a/lib/gitlab/chat_commands/presenters/issue_search.rb
+++ /dev/null
@@ -1,47 +0,0 @@
-module Gitlab
- module ChatCommands
- module Presenters
- class IssueSearch < Presenters::Base
- include Presenters::IssueBase
-
- def present
- text = if @resource.count >= 5
- "Here are the first 5 issues I found:"
- elsif @resource.one?
- "Here is the only issue I found:"
- else
- "Here are the #{@resource.count} issues I found:"
- end
-
- ephemeral_response(text: text, attachments: attachments)
- end
-
- private
-
- def attachments
- @resource.map do |issue|
- url = "[#{issue.to_reference}](#{url_for([namespace, project, issue])})"
-
- {
- color: color(issue),
- fallback: "#{issue.to_reference} #{issue.title}",
- text: "#{url} · #{issue.title} (#{status_text(issue)})",
-
- mrkdwn_in: [
- :text
- ]
- }
- end
- end
-
- def project
- @project ||= @resource.first.project
- end
-
- def namespace
- @namespace ||= project.namespace.becomes(Namespace)
- end
- end
- end
- end
-end
diff --git a/lib/gitlab/chat_commands/presenters/issue_show.rb b/lib/gitlab/chat_commands/presenters/issue_show.rb
deleted file mode 100644
index bd784ad241e..00000000000
--- a/lib/gitlab/chat_commands/presenters/issue_show.rb
+++ /dev/null
@@ -1,61 +0,0 @@
-module Gitlab
- module ChatCommands
- module Presenters
- class IssueShow < Presenters::Base
- include Presenters::IssueBase
-
- def present
- if @resource.confidential?
- ephemeral_response(show_issue)
- else
- in_channel_response(show_issue)
- end
- end
-
- private
-
- def show_issue
- {
- attachments: [
- {
- title: "#{@resource.title} · #{@resource.to_reference}",
- title_link: resource_url,
- author_name: author.name,
- author_icon: author.avatar_url,
- fallback: "Issue #{@resource.to_reference}: #{@resource.title}",
- pretext: pretext,
- text: text,
- color: color(@resource),
- fields: fields,
- mrkdwn_in: [
- :pretext,
- :text,
- :fields
- ]
- }
- ]
- }
- end
-
- def text
- message = "**#{status_text(@resource)}**"
-
- if @resource.upvotes.zero? && @resource.downvotes.zero? && @resource.user_notes_count.zero?
- return message
- end
-
- message << " · "
- message << ":+1: #{@resource.upvotes} " unless @resource.upvotes.zero?
- message << ":-1: #{@resource.downvotes} " unless @resource.downvotes.zero?
- message << ":speech_balloon: #{@resource.user_notes_count}" unless @resource.user_notes_count.zero?
-
- message
- end
-
- def pretext
- "Issue *#{@resource.to_reference}* from #{project.name_with_namespace}"
- end
- end
- end
- end
-end