diff options
author | GitLab Bot <gitlab-bot@gitlab.com> | 2020-06-15 21:08:43 +0300 |
---|---|---|
committer | GitLab Bot <gitlab-bot@gitlab.com> | 2020-06-15 21:08:43 +0300 |
commit | 3caf5a8a007d8d9e9a86b7c847b5d9cfa6d41843 (patch) | |
tree | 6831279652bf5379c4650e2fd44c69663e1260c8 /lib/gitlab/jira_import.rb | |
parent | 4774fa00b74a9248b2d14fc424a8c2f1abb0a0de (diff) |
Add latest changes from gitlab-org/gitlab@master
Diffstat (limited to 'lib/gitlab/jira_import.rb')
-rw-r--r-- | lib/gitlab/jira_import.rb | 26 |
1 files changed, 22 insertions, 4 deletions
diff --git a/lib/gitlab/jira_import.rb b/lib/gitlab/jira_import.rb index c7b5317e67b..75d6fdc07b6 100644 --- a/lib/gitlab/jira_import.rb +++ b/lib/gitlab/jira_import.rb @@ -7,7 +7,8 @@ module Gitlab FAILED_ISSUES_COUNTER_KEY = 'jira-import/failed/%{project_id}/%{collection_type}' NEXT_ITEMS_START_AT_KEY = 'jira-import/paginator/%{project_id}/%{collection_type}' JIRA_IMPORT_LABEL = 'jira-import/import-label/%{project_id}' - ITEMS_MAPPER_CACHE_KEY = 'jira-import/items-mapper/%{project_id}/%{collection_type}/%{jira_isssue_id}' + ITEMS_MAPPER_CACHE_KEY = 'jira-import/items-mapper/%{project_id}/%{collection_type}/%{jira_item_id}' + USERS_MAPPER_KEY_PREFIX = 'jira-import/items-mapper/%{project_id}/users/' ALREADY_IMPORTED_ITEMS_CACHE_KEY = 'jira-importer/already-imported/%{project}/%{collection_type}' def self.validate_project_settings!(project, user: nil, configuration_check: true) @@ -24,8 +25,12 @@ module Gitlab raise Projects::ImportService::Error, _('Unable to connect to the Jira instance. Please check your Jira integration configuration.') unless jira_service&.valid_connection? end - def self.jira_issue_cache_key(project_id, jira_issue_id) - ITEMS_MAPPER_CACHE_KEY % { project_id: project_id, collection_type: :issues, jira_isssue_id: jira_issue_id } + def self.jira_item_cache_key(project_id, jira_item_id, collection_type) + ITEMS_MAPPER_CACHE_KEY % { project_id: project_id, collection_type: collection_type, jira_item_id: jira_item_id } + end + + def self.jira_user_key_prefix(project_id) + USERS_MAPPER_KEY_PREFIX % { project_id: project_id } end def self.already_imported_cache_key(collection_type, project_id) @@ -62,7 +67,7 @@ module Gitlab end def self.cache_issue_mapping(issue_id, jira_issue_id, project_id) - cache_key = JiraImport.jira_issue_cache_key(project_id, jira_issue_id) + cache_key = JiraImport.jira_item_cache_key(project_id, jira_issue_id, :issues) cache_class.write(cache_key, issue_id) end @@ -81,6 +86,19 @@ module Gitlab cache_class.expire(self.already_imported_cache_key(:issues, project_id), JIRA_IMPORT_CACHE_TIMEOUT) end + # Caches the mapping of jira_account_id -> gitlab user id + # project_id - id of a project + # mapping - hash in format of jira_account_id -> gitlab user id + def self.cache_users_mapping(project_id, mapping) + cache_class.write_multiple(mapping, key_prefix: jira_user_key_prefix(project_id)) + end + + def self.get_user_mapping(project_id, jira_account_id) + cache_key = JiraImport.jira_item_cache_key(project_id, jira_account_id, :users) + + cache_class.read(cache_key)&.to_i + end + def self.cache_class Gitlab::Cache::Import::Caching end |