diff options
author | GitLab Bot <gitlab-bot@gitlab.com> | 2021-07-20 09:55:51 +0000 |
---|---|---|
committer | GitLab Bot <gitlab-bot@gitlab.com> | 2021-07-20 09:55:51 +0000 |
commit | e8d2c2579383897a1dd7f9debd359abe8ae8373d (patch) | |
tree | c42be41678c2586d49a75cabce89322082698334 /app/workers/jira_connect | |
parent | fc845b37ec3a90aaa719975f607740c22ba6a113 (diff) | |
download | gitlab-ce-e8d2c2579383897a1dd7f9debd359abe8ae8373d.tar.gz |
Add latest changes from gitlab-org/gitlab@14-1-stable-eev14.1.0-rc42
Diffstat (limited to 'app/workers/jira_connect')
7 files changed, 45 insertions, 18 deletions
diff --git a/app/workers/jira_connect/forward_event_worker.rb b/app/workers/jira_connect/forward_event_worker.rb new file mode 100644 index 00000000000..877ab46cfe5 --- /dev/null +++ b/app/workers/jira_connect/forward_event_worker.rb @@ -0,0 +1,25 @@ +# frozen_string_literal: true + +module JiraConnect + class ForwardEventWorker # rubocop:disable Scalability/IdempotentWorker + include ApplicationWorker + + queue_namespace :jira_connect + feature_category :integrations + worker_has_external_dependencies! + + def perform(installation_id, base_path, event_path) + installation = JiraConnectInstallation.find_by_id(installation_id) + + return if installation&.instance_url.nil? + + proxy_url = installation.instance_url + event_path + qsh = Atlassian::Jwt.create_query_string_hash(proxy_url, 'POST', installation.instance_url + base_path) + jwt = Atlassian::Jwt.encode({ iss: installation.client_key, qsh: qsh }, installation.shared_secret) + + Gitlab::HTTP.post(proxy_url, headers: { 'Authorization' => "JWT #{jwt}" }) + ensure + installation.destroy if installation + end + end +end diff --git a/app/workers/jira_connect/sync_branch_worker.rb b/app/workers/jira_connect/sync_branch_worker.rb index 4e8566d86c9..2723287b77b 100644 --- a/app/workers/jira_connect/sync_branch_worker.rb +++ b/app/workers/jira_connect/sync_branch_worker.rb @@ -1,16 +1,17 @@ # frozen_string_literal: true module JiraConnect - class SyncBranchWorker + class SyncBranchWorker # rubocop:disable Scalability/IdempotentWorker include ApplicationWorker sidekiq_options retry: 3 queue_namespace :jira_connect feature_category :integrations + data_consistency :delayed loggable_arguments 1, 2 + worker_has_external_dependencies! - idempotent! def perform(project_id, branch_name, commit_shas, update_sequence_id) project = Project.find_by_id(project_id) diff --git a/app/workers/jira_connect/sync_builds_worker.rb b/app/workers/jira_connect/sync_builds_worker.rb index 11a3b598035..4c4daba3314 100644 --- a/app/workers/jira_connect/sync_builds_worker.rb +++ b/app/workers/jira_connect/sync_builds_worker.rb @@ -1,18 +1,18 @@ # frozen_string_literal: true module JiraConnect - class SyncBuildsWorker + class SyncBuildsWorker # rubocop:disable Scalability/IdempotentWorker include ApplicationWorker sidekiq_options retry: 3 - idempotent! - worker_has_external_dependencies! - queue_namespace :jira_connect feature_category :integrations + data_consistency :delayed tags :exclude_from_kubernetes + worker_has_external_dependencies! + def perform(pipeline_id, sequence_id) pipeline = Ci::Pipeline.find_by_id(pipeline_id) diff --git a/app/workers/jira_connect/sync_deployments_worker.rb b/app/workers/jira_connect/sync_deployments_worker.rb index 9f75b1161f0..0dc34b5999f 100644 --- a/app/workers/jira_connect/sync_deployments_worker.rb +++ b/app/workers/jira_connect/sync_deployments_worker.rb @@ -1,18 +1,18 @@ # frozen_string_literal: true module JiraConnect - class SyncDeploymentsWorker + class SyncDeploymentsWorker # rubocop:disable Scalability/IdempotentWorker include ApplicationWorker sidekiq_options retry: 3 - idempotent! - worker_has_external_dependencies! - queue_namespace :jira_connect feature_category :integrations + data_consistency :delayed tags :exclude_from_kubernetes + worker_has_external_dependencies! + def perform(deployment_id, sequence_id) deployment = Deployment.find_by_id(deployment_id) diff --git a/app/workers/jira_connect/sync_feature_flags_worker.rb b/app/workers/jira_connect/sync_feature_flags_worker.rb index 0d8d3d3142e..c484cabbe6b 100644 --- a/app/workers/jira_connect/sync_feature_flags_worker.rb +++ b/app/workers/jira_connect/sync_feature_flags_worker.rb @@ -1,18 +1,18 @@ # frozen_string_literal: true module JiraConnect - class SyncFeatureFlagsWorker + class SyncFeatureFlagsWorker # rubocop:disable Scalability/IdempotentWorker include ApplicationWorker sidekiq_options retry: 3 - idempotent! - worker_has_external_dependencies! - queue_namespace :jira_connect feature_category :integrations + data_consistency :delayed tags :exclude_from_kubernetes + worker_has_external_dependencies! + def perform(feature_flag_id, sequence_id) feature_flag = ::Operations::FeatureFlag.find_by_id(feature_flag_id) diff --git a/app/workers/jira_connect/sync_merge_request_worker.rb b/app/workers/jira_connect/sync_merge_request_worker.rb index bf31df2271f..bb0d24667e9 100644 --- a/app/workers/jira_connect/sync_merge_request_worker.rb +++ b/app/workers/jira_connect/sync_merge_request_worker.rb @@ -1,14 +1,14 @@ # frozen_string_literal: true module JiraConnect - class SyncMergeRequestWorker + class SyncMergeRequestWorker # rubocop:disable Scalability/IdempotentWorker include ApplicationWorker sidekiq_options retry: 3 queue_namespace :jira_connect feature_category :integrations - idempotent! + data_consistency :delayed worker_has_external_dependencies! diff --git a/app/workers/jira_connect/sync_project_worker.rb b/app/workers/jira_connect/sync_project_worker.rb index dfff0c4b3b6..317bace89b4 100644 --- a/app/workers/jira_connect/sync_project_worker.rb +++ b/app/workers/jira_connect/sync_project_worker.rb @@ -1,15 +1,16 @@ # frozen_string_literal: true module JiraConnect - class SyncProjectWorker + class SyncProjectWorker # rubocop:disable Scalability/IdempotentWorker include ApplicationWorker sidekiq_options retry: 3 queue_namespace :jira_connect feature_category :integrations + data_consistency :delayed tags :exclude_from_kubernetes - idempotent! + worker_has_external_dependencies! MERGE_REQUEST_LIMIT = 400 |