2021-09-04 01:27:46 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
module Integrations
|
|
|
|
class Pivotaltracker < Integration
|
|
|
|
API_ENDPOINT = 'https://www.pivotaltracker.com/services/v5/source_commits'
|
|
|
|
|
|
|
|
validates :token, presence: true, if: :activated?
|
|
|
|
|
2022-08-13 15:12:31 +05:30
|
|
|
field :token,
|
|
|
|
type: 'password',
|
|
|
|
help: -> { s_('PivotalTrackerService|Pivotal Tracker API token. User must have access to the story. All comments are attributed to this user.') },
|
|
|
|
non_empty_password_title: -> { s_('ProjectService|Enter new token') },
|
|
|
|
non_empty_password_help: -> { s_('ProjectService|Leave blank to use your current token.') },
|
|
|
|
required: true
|
|
|
|
|
|
|
|
field :restrict_to_branch,
|
|
|
|
title: -> { s_('Integrations|Restrict to branch (optional)') },
|
|
|
|
help: -> do
|
|
|
|
s_('PivotalTrackerService|Comma-separated list of branches to ' \
|
|
|
|
'automatically inspect. Leave blank to include all branches.')
|
|
|
|
end
|
|
|
|
|
2021-09-04 01:27:46 +05:30
|
|
|
def title
|
2021-09-30 23:02:18 +05:30
|
|
|
'Pivotal Tracker'
|
2021-09-04 01:27:46 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
def description
|
2021-09-30 23:02:18 +05:30
|
|
|
s_('PivotalTrackerService|Add commit messages as comments to Pivotal Tracker stories.')
|
|
|
|
end
|
|
|
|
|
|
|
|
def help
|
2022-05-07 20:08:51 +05:30
|
|
|
docs_link = ActionController::Base.helpers.link_to _('Learn more.'), Rails.application.routes.url_helpers.help_page_url('user/project/integrations/pivotal_tracker'), target: '_blank', rel: 'noopener noreferrer'
|
2021-09-30 23:02:18 +05:30
|
|
|
s_('Add commit messages as comments to Pivotal Tracker stories. %{docs_link}').html_safe % { docs_link: docs_link.html_safe }
|
2021-09-04 01:27:46 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
def self.to_param
|
|
|
|
'pivotaltracker'
|
|
|
|
end
|
|
|
|
|
|
|
|
def self.supported_events
|
|
|
|
%w(push)
|
|
|
|
end
|
|
|
|
|
|
|
|
def execute(data)
|
|
|
|
return unless supported_events.include?(data[:object_kind])
|
|
|
|
return unless allowed_branch?(data[:ref])
|
|
|
|
|
|
|
|
data[:commits].each do |commit|
|
|
|
|
message = {
|
|
|
|
'source_commit' => {
|
|
|
|
'commit_id' => commit[:id],
|
|
|
|
'author' => commit[:author][:name],
|
|
|
|
'url' => commit[:url],
|
|
|
|
'message' => commit[:message]
|
|
|
|
}
|
|
|
|
}
|
|
|
|
Gitlab::HTTP.post(
|
|
|
|
API_ENDPOINT,
|
2023-01-13 00:05:48 +05:30
|
|
|
body: Gitlab::Json.dump(message),
|
2021-09-04 01:27:46 +05:30
|
|
|
headers: {
|
|
|
|
'Content-Type' => 'application/json',
|
|
|
|
'X-TrackerToken' => token
|
|
|
|
}
|
|
|
|
)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def allowed_branch?(ref)
|
|
|
|
return true unless ref.present? && restrict_to_branch.present?
|
|
|
|
|
|
|
|
branch = Gitlab::Git.ref_name(ref)
|
|
|
|
allowed_branches = restrict_to_branch.split(',').map(&:strip)
|
|
|
|
|
|
|
|
branch.present? && allowed_branches.include?(branch)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|