2013-05-23 14:10:32 -04:00
|
|
|
# == Schema Information
|
|
|
|
#
|
|
|
|
# Table name: services
|
|
|
|
#
|
2015-03-04 17:14:00 -05:00
|
|
|
# id :integer not null, primary key
|
|
|
|
# type :string(255)
|
|
|
|
# title :string(255)
|
|
|
|
# project_id :integer
|
|
|
|
# created_at :datetime
|
|
|
|
# updated_at :datetime
|
|
|
|
# active :boolean default(FALSE), not null
|
|
|
|
# properties :text
|
|
|
|
# template :boolean default(FALSE)
|
|
|
|
# push_events :boolean default(TRUE)
|
|
|
|
# issues_events :boolean default(TRUE)
|
|
|
|
# merge_requests_events :boolean default(TRUE)
|
|
|
|
# tag_push_events :boolean default(TRUE)
|
2015-05-03 12:05:38 -04:00
|
|
|
# note_events :boolean default(TRUE), not null
|
2013-05-23 14:10:32 -04:00
|
|
|
#
|
|
|
|
|
|
|
|
class HipchatService < Service
|
2014-07-29 04:04:19 -04:00
|
|
|
MAX_COMMITS = 3
|
|
|
|
|
2015-01-23 19:29:02 -05:00
|
|
|
prop_accessor :token, :room, :server, :notify, :color, :api_version
|
2013-05-23 14:10:32 -04:00
|
|
|
validates :token, presence: true, if: :activated?
|
|
|
|
|
|
|
|
def title
|
2014-11-09 00:12:14 -05:00
|
|
|
'HipChat'
|
2013-05-23 14:10:32 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
def description
|
2013-11-20 07:05:42 -05:00
|
|
|
'Private group chat and IM'
|
2013-05-23 14:10:32 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
def to_param
|
|
|
|
'hipchat'
|
|
|
|
end
|
|
|
|
|
|
|
|
def fields
|
|
|
|
[
|
2015-01-15 17:35:32 -05:00
|
|
|
{ type: 'text', name: 'token', placeholder: 'Room token' },
|
|
|
|
{ type: 'text', name: 'room', placeholder: 'Room name or ID' },
|
2015-04-26 14:56:13 -04:00
|
|
|
{ type: 'checkbox', name: 'notify' },
|
|
|
|
{ type: 'select', name: 'color', choices: ['yellow', 'red', 'green', 'purple', 'gray', 'random'] },
|
2015-01-23 19:29:02 -05:00
|
|
|
{ type: 'text', name: 'api_version',
|
|
|
|
placeholder: 'Leave blank for default (v2)' },
|
2014-11-09 00:04:31 -05:00
|
|
|
{ type: 'text', name: 'server',
|
2014-12-29 15:20:22 -05:00
|
|
|
placeholder: 'Leave blank for default. https://hipchat.example.com' }
|
2013-05-23 14:10:32 -04:00
|
|
|
]
|
|
|
|
end
|
|
|
|
|
2015-02-28 11:33:18 -05:00
|
|
|
def supported_events
|
2015-03-06 11:31:49 -05:00
|
|
|
%w(push issue merge_request note tag_push)
|
2015-02-28 11:33:18 -05:00
|
|
|
end
|
|
|
|
|
2015-02-20 08:49:26 -05:00
|
|
|
def execute(data)
|
2015-02-28 11:33:18 -05:00
|
|
|
return unless supported_events.include?(data[:object_kind])
|
2015-03-30 18:54:30 -04:00
|
|
|
message = create_message(data)
|
|
|
|
return unless message.present?
|
2015-04-26 14:56:13 -04:00
|
|
|
gate[room].send('GitLab', message, message_options)
|
2013-05-23 14:10:32 -04:00
|
|
|
end
|
|
|
|
|
2015-08-12 03:40:54 -04:00
|
|
|
def test(data)
|
|
|
|
begin
|
|
|
|
result = execute(data)
|
|
|
|
rescue StandardError => error
|
|
|
|
return { success: false, result: error }
|
|
|
|
end
|
|
|
|
|
|
|
|
{ success: true, result: result }
|
|
|
|
end
|
|
|
|
|
2013-05-23 14:10:32 -04:00
|
|
|
private
|
|
|
|
|
|
|
|
def gate
|
2015-05-27 00:51:31 -04:00
|
|
|
options = { api_version: api_version.present? ? api_version : 'v2' }
|
2014-12-29 15:20:22 -05:00
|
|
|
options[:server_url] = server unless server.blank?
|
2014-11-09 00:12:14 -05:00
|
|
|
@gate ||= HipChat::Client.new(token, options)
|
2013-05-23 14:10:32 -04:00
|
|
|
end
|
|
|
|
|
2015-04-26 14:56:13 -04:00
|
|
|
def message_options
|
|
|
|
{ notify: notify.present? && notify == '1', color: color || 'yellow' }
|
|
|
|
end
|
|
|
|
|
2015-03-05 04:54:28 -05:00
|
|
|
def create_message(data)
|
|
|
|
object_kind = data[:object_kind]
|
|
|
|
|
2015-10-03 01:56:37 -04:00
|
|
|
case object_kind
|
|
|
|
when "push", "tag_push"
|
|
|
|
create_push_message(data)
|
|
|
|
when "issue"
|
|
|
|
create_issue_message(data) unless is_update?(data)
|
|
|
|
when "merge_request"
|
|
|
|
create_merge_request_message(data) unless is_update?(data)
|
|
|
|
when "note"
|
|
|
|
create_note_message(data)
|
|
|
|
end
|
2015-03-05 04:54:28 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
def create_push_message(push)
|
2015-03-10 06:51:36 -04:00
|
|
|
ref_type = Gitlab::Git.tag_ref?(push[:ref]) ? 'tag' : 'branch'
|
|
|
|
ref = Gitlab::Git.ref_name(push[:ref])
|
2015-03-06 11:31:49 -05:00
|
|
|
|
2013-05-23 14:10:32 -04:00
|
|
|
before = push[:before]
|
|
|
|
after = push[:after]
|
|
|
|
|
|
|
|
message = ""
|
|
|
|
message << "#{push[:user_name]} "
|
2015-03-10 06:51:36 -04:00
|
|
|
if Gitlab::Git.blank_ref?(before)
|
2015-03-06 11:31:49 -05:00
|
|
|
message << "pushed new #{ref_type} <a href=\""\
|
2015-03-05 04:54:28 -05:00
|
|
|
"#{project_url}/commits/#{URI.escape(ref)}\">#{ref}</a>"\
|
2015-03-06 11:31:49 -05:00
|
|
|
" to #{project_link}\n"
|
2015-03-10 06:51:36 -04:00
|
|
|
elsif Gitlab::Git.blank_ref?(after)
|
2015-03-06 11:31:49 -05:00
|
|
|
message << "removed #{ref_type} <b>#{ref}</b> from <a href=\"#{project.web_url}\">#{project_name}</a> \n"
|
2013-05-23 14:10:32 -04:00
|
|
|
else
|
2015-03-06 11:31:49 -05:00
|
|
|
message << "pushed to #{ref_type} <a href=\""\
|
2014-07-15 23:03:17 -04:00
|
|
|
"#{project.web_url}/commits/#{URI.escape(ref)}\">#{ref}</a> "
|
2013-05-23 14:10:32 -04:00
|
|
|
message << "of <a href=\"#{project.web_url}\">#{project.name_with_namespace.gsub!(/\s/,'')}</a> "
|
|
|
|
message << "(<a href=\"#{project.web_url}/compare/#{before}...#{after}\">Compare changes</a>)"
|
2014-07-29 04:04:19 -04:00
|
|
|
|
|
|
|
push[:commits].take(MAX_COMMITS).each do |commit|
|
|
|
|
message << "<br /> - #{commit[:message].lines.first} (<a href=\"#{commit[:url]}\">#{commit[:id][0..5]}</a>)"
|
|
|
|
end
|
|
|
|
|
|
|
|
if push[:commits].count > MAX_COMMITS
|
|
|
|
message << "<br />... #{push[:commits].count - MAX_COMMITS} more commits"
|
2013-05-23 14:10:32 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
message
|
|
|
|
end
|
2015-03-05 04:54:28 -05:00
|
|
|
|
2015-03-05 13:38:23 -05:00
|
|
|
def format_body(body)
|
|
|
|
if body
|
|
|
|
body = body.truncate(200, separator: ' ', omission: '...')
|
|
|
|
end
|
|
|
|
|
|
|
|
"<pre>#{body}</pre>"
|
|
|
|
end
|
|
|
|
|
2015-03-05 04:54:28 -05:00
|
|
|
def create_issue_message(data)
|
2015-03-06 11:31:49 -05:00
|
|
|
user_name = data[:user][:name]
|
2015-03-05 04:54:28 -05:00
|
|
|
|
|
|
|
obj_attr = data[:object_attributes]
|
|
|
|
obj_attr = HashWithIndifferentAccess.new(obj_attr)
|
|
|
|
title = obj_attr[:title]
|
|
|
|
state = obj_attr[:state]
|
|
|
|
issue_iid = obj_attr[:iid]
|
|
|
|
issue_url = obj_attr[:url]
|
|
|
|
description = obj_attr[:description]
|
|
|
|
|
2015-03-06 11:31:49 -05:00
|
|
|
issue_link = "<a href=\"#{issue_url}\">issue ##{issue_iid}</a>"
|
|
|
|
message = "#{user_name} #{state} #{issue_link} in #{project_link}: <b>#{title}</b>"
|
2015-03-05 04:54:28 -05:00
|
|
|
|
|
|
|
if description
|
2015-03-05 13:38:23 -05:00
|
|
|
description = format_body(description)
|
|
|
|
message << description
|
2015-03-05 04:54:28 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
message
|
|
|
|
end
|
|
|
|
|
|
|
|
def create_merge_request_message(data)
|
2015-03-06 11:31:49 -05:00
|
|
|
user_name = data[:user][:name]
|
2015-03-05 04:54:28 -05:00
|
|
|
|
|
|
|
obj_attr = data[:object_attributes]
|
|
|
|
obj_attr = HashWithIndifferentAccess.new(obj_attr)
|
|
|
|
merge_request_id = obj_attr[:iid]
|
|
|
|
state = obj_attr[:state]
|
|
|
|
description = obj_attr[:description]
|
|
|
|
title = obj_attr[:title]
|
|
|
|
|
|
|
|
merge_request_url = "#{project_url}/merge_requests/#{merge_request_id}"
|
2015-03-06 11:31:49 -05:00
|
|
|
merge_request_link = "<a href=\"#{merge_request_url}\">merge request ##{merge_request_id}</a>"
|
|
|
|
message = "#{user_name} #{state} #{merge_request_link} in " \
|
2015-03-05 04:54:28 -05:00
|
|
|
"#{project_link}: <b>#{title}</b>"
|
|
|
|
|
|
|
|
if description
|
2015-03-05 13:38:23 -05:00
|
|
|
description = format_body(description)
|
|
|
|
message << description
|
|
|
|
end
|
|
|
|
|
|
|
|
message
|
|
|
|
end
|
|
|
|
|
|
|
|
def format_title(title)
|
|
|
|
"<b>" + title.lines.first.chomp + "</b>"
|
|
|
|
end
|
|
|
|
|
|
|
|
def create_note_message(data)
|
|
|
|
data = HashWithIndifferentAccess.new(data)
|
2015-03-06 11:31:49 -05:00
|
|
|
user_name = data[:user][:name]
|
2015-03-05 13:38:23 -05:00
|
|
|
|
|
|
|
obj_attr = HashWithIndifferentAccess.new(data[:object_attributes])
|
|
|
|
note = obj_attr[:note]
|
|
|
|
note_url = obj_attr[:url]
|
|
|
|
noteable_type = obj_attr[:noteable_type]
|
|
|
|
|
|
|
|
case noteable_type
|
|
|
|
when "Commit"
|
|
|
|
commit_attr = HashWithIndifferentAccess.new(data[:commit])
|
|
|
|
subject_desc = commit_attr[:id]
|
|
|
|
subject_desc = Commit.truncate_sha(subject_desc)
|
|
|
|
subject_type = "commit"
|
|
|
|
title = format_title(commit_attr[:message])
|
|
|
|
when "Issue"
|
|
|
|
subj_attr = HashWithIndifferentAccess.new(data[:issue])
|
|
|
|
subject_id = subj_attr[:iid]
|
|
|
|
subject_desc = "##{subject_id}"
|
|
|
|
subject_type = "issue"
|
|
|
|
title = format_title(subj_attr[:title])
|
|
|
|
when "MergeRequest"
|
|
|
|
subj_attr = HashWithIndifferentAccess.new(data[:merge_request])
|
|
|
|
subject_id = subj_attr[:iid]
|
|
|
|
subject_desc = "##{subject_id}"
|
|
|
|
subject_type = "merge request"
|
|
|
|
title = format_title(subj_attr[:title])
|
|
|
|
when "Snippet"
|
|
|
|
subj_attr = HashWithIndifferentAccess.new(data[:snippet])
|
|
|
|
subject_id = subj_attr[:id]
|
|
|
|
subject_desc = "##{subject_id}"
|
|
|
|
subject_type = "snippet"
|
|
|
|
title = format_title(subj_attr[:title])
|
|
|
|
end
|
|
|
|
|
|
|
|
subject_html = "<a href=\"#{note_url}\">#{subject_type} #{subject_desc}</a>"
|
2015-03-06 11:31:49 -05:00
|
|
|
message = "#{user_name} commented on #{subject_html} in #{project_link}: "
|
2015-03-05 13:38:23 -05:00
|
|
|
message << title
|
|
|
|
|
|
|
|
if note
|
|
|
|
note = format_body(note)
|
|
|
|
message << note
|
2015-03-05 04:54:28 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
message
|
|
|
|
end
|
|
|
|
|
|
|
|
def project_name
|
|
|
|
project.name_with_namespace.gsub(/\s/, '')
|
|
|
|
end
|
|
|
|
|
|
|
|
def project_url
|
|
|
|
project.web_url
|
|
|
|
end
|
|
|
|
|
|
|
|
def project_link
|
|
|
|
"<a href=\"#{project_url}\">#{project_name}</a>"
|
|
|
|
end
|
|
|
|
|
|
|
|
def is_update?(data)
|
|
|
|
data[:object_attributes][:action] == 'update'
|
|
|
|
end
|
2013-06-19 08:40:33 -04:00
|
|
|
end
|