diff options
author | Kamil Trzciński <ayufan@ayufan.eu> | 2017-10-31 11:54:49 +0000 |
---|---|---|
committer | Kamil Trzciński <ayufan@ayufan.eu> | 2017-10-31 11:54:49 +0000 |
commit | e829d5a08455e608ba5f054ffa65a2af0fe0393c (patch) | |
tree | 635b600e2fa432a21a70786d3c64fe847d57fec7 /app | |
parent | a9446093b12a9dffef97541915e2b6872875ad3f (diff) | |
parent | c207122fd2b4439ff8303a1860c35de658d6bdfb (diff) | |
download | gitlab-ce-e829d5a08455e608ba5f054ffa65a2af0fe0393c.tar.gz |
Merge branch 'add-packagist-project-service' into 'master'
Add Packagist project service
See merge request gitlab-org/gitlab-ce!14493
Diffstat (limited to 'app')
-rw-r--r-- | app/models/project.rb | 1 | ||||
-rw-r--r-- | app/models/project_services/packagist_service.rb | 65 | ||||
-rw-r--r-- | app/models/service.rb | 1 |
3 files changed, 67 insertions, 0 deletions
diff --git a/app/models/project.rb b/app/models/project.rb index 7185b4d44fc..d849082de60 100644 --- a/app/models/project.rb +++ b/app/models/project.rb @@ -120,6 +120,7 @@ class Project < ActiveRecord::Base has_one :mock_deployment_service has_one :mock_monitoring_service has_one :microsoft_teams_service + has_one :packagist_service # TODO: replace these relations with the fork network versions has_one :forked_project_link, foreign_key: "forked_to_project_id" diff --git a/app/models/project_services/packagist_service.rb b/app/models/project_services/packagist_service.rb new file mode 100644 index 00000000000..f68a0c1a3c3 --- /dev/null +++ b/app/models/project_services/packagist_service.rb @@ -0,0 +1,65 @@ +class PackagistService < Service + include HTTParty + + prop_accessor :username, :token, :server + + validates :username, presence: true, if: :activated? + validates :token, presence: true, if: :activated? + + default_value_for :push_events, true + default_value_for :tag_push_events, true + + after_save :compose_service_hook, if: :activated? + + def title + 'Packagist' + end + + def description + 'Update your project on Packagist, the main Composer repository' + end + + def self.to_param + 'packagist' + end + + def fields + [ + { type: 'text', name: 'username', placeholder: '', required: true }, + { type: 'text', name: 'token', placeholder: '', required: true }, + { type: 'text', name: 'server', placeholder: 'https://packagist.org', required: false } + ] + end + + def self.supported_events + %w(push merge_request tag_push) + end + + def execute(data) + return unless supported_events.include?(data[:object_kind]) + + service_hook.execute(data) + end + + def test(data) + begin + result = execute(data) + return { success: false, result: result[:message] } if result[:http_status] != 202 + rescue StandardError => error + return { success: false, result: error } + end + + { success: true, result: result[:message] } + end + + def compose_service_hook + hook = service_hook || build_service_hook + hook.url = hook_url + hook.save + end + + def hook_url + base_url = server.present? ? server : 'https://packagist.org' + "#{base_url}/api/update-package?username=#{username}&apiToken=#{token}" + end +end diff --git a/app/models/service.rb b/app/models/service.rb index 6b64079215f..fdd2605e3e3 100644 --- a/app/models/service.rb +++ b/app/models/service.rb @@ -238,6 +238,7 @@ class Service < ActiveRecord::Base kubernetes mattermost_slash_commands mattermost + packagist pipelines_email pivotaltracker prometheus |