Class DefaultProjectImportPersister
java.lang.Object
com.atlassian.jira.imports.project.DefaultProjectImportPersister
- All Implemented Interfaces:
ProjectImportPersister
- Since:
- v3.13
-
Constructor Summary
ConstructorsConstructorDescriptionDefaultProjectImportPersister(ExternalUtils externalUtils, IssueFactory issueFactory, OfBizDelegator ofBizDelegator, IssueIndexManager issueIndexManager, IssueManager issueManager, ProjectManager projectManager, VersionManager versionManager, NodeAssociationStore nodeAssociationStore, UserAssociationStore userAssociationStore, ProjectComponentManager projectComponentManager, AttachmentManager attachmentManager, ChangeHistoryManager changeHistoryManager, IssueLinkTypeManager issueLinkTypeManager, UserManager userManager, UserService userService, ApplicationProperties applicationProperties, UserPropertyManager userPropertyManager, OnboardingStore onboardingStore, ProjectPropertiesManager projectPropertiesManager) -
Method Summary
Modifier and TypeMethodDescriptionbooleancreateAssociation(ExternalNodeAssociation nodeAssociation) Creates a NodeAssocation which is used to link the issue to external values such as versions and components.createAttachment(ExternalAttachment externalAttachment) Creates an attachment specified by the ExternalAttachment.createChangeItemForIssueLinkIfNeeded(String issueId, String issueLinkTypeId, String linkedIssueKey, boolean isSource, ApplicationUser importAuthor) This will look at the issue specified by issueId and add a changeItem for the issue link if it needs to.createComponents(BackupProject backupProject, ProjectImportMapper projectImportMapper) Creates the components, specified byBackupProject.getProjectComponents()for the named backup project.createEntity(EntityRepresentation entityRepresentation) This will store the provided entity in the database.createIssue(ExternalIssue externalIssue, Date importDate, ApplicationUser importAuthor) Creates an issue based off of the provided ExternalIssue.createProject(ExternalProject project) Creates a project, with details based off of the ExternalProject.booleancreateUser(UserMapper userMapper, ExternalUser externalUser) Creates a User in JIRA from the given ExternalUser object.createVersions(BackupProject backupProject) Creates the versions, specified byBackupProject.getProjectVersions()for the named backup project.booleancreateVoter(ExternalVoter voter) Creates a UserAssociation which is used to link the user to the issue as a voter.booleancreateWatcher(ExternalWatcher watcher) Creates a UserAssociation which is used to link the user to the issue as a watcher.voidreIndexProject(ProjectImportMapper projectImportMapper, TaskProgressInterval taskProgressInterval, I18nHelper i18n) Re-indexes all the new Issues that have just been created in this Project Import.updateProjectDetails(ExternalProject externalProject) Updates the details of an existing Project in JIRA from the given ExternalProject object.voidupdateProjectIssueCounter(BackupProject backupProject, long counter) Updates a projects issue counter, which is used to determine the numeric portion of the issue key.
-
Constructor Details
-
DefaultProjectImportPersister
public DefaultProjectImportPersister(ExternalUtils externalUtils, IssueFactory issueFactory, OfBizDelegator ofBizDelegator, IssueIndexManager issueIndexManager, IssueManager issueManager, ProjectManager projectManager, VersionManager versionManager, NodeAssociationStore nodeAssociationStore, UserAssociationStore userAssociationStore, ProjectComponentManager projectComponentManager, AttachmentManager attachmentManager, ChangeHistoryManager changeHistoryManager, IssueLinkTypeManager issueLinkTypeManager, UserManager userManager, UserService userService, ApplicationProperties applicationProperties, UserPropertyManager userPropertyManager, OnboardingStore onboardingStore, ProjectPropertiesManager projectPropertiesManager)
-
-
Method Details
-
createIssue
public Issue createIssue(ExternalIssue externalIssue, Date importDate, ApplicationUser importAuthor) Description copied from interface:ProjectImportPersisterCreates an issue based off of the provided ExternalIssue. This method will store the issue and make sure that it is in the correct workflow state. This will preserve the key provided in the issue.NOTE: If you are using this method you will, at a later time, need to fix the projects pcounter to be correct in relation to the manually stored issue keys.
- Specified by:
createIssuein interfaceProjectImportPersister- Parameters:
externalIssue- contains the issue details that will be persisted and the project id that the issue will be persisted against.importDate- a date that will be used as the value of the marker change item that is added to the issue to indicate that the issue was created via a project import.importAuthor- the user who is performing the project import, this is used as the author of the change item marker for created issues- Returns:
- an Issue representation of the newly stored issue, null if there is a problem creating the issue.
-
createEntity
Description copied from interface:ProjectImportPersisterThis will store the provided entity in the database. No validation will be performed so it is up to the caller to make certain that the data has integrity. If a DataAccessException occurs during this operation, then we return anullid.- Specified by:
createEntityin interfaceProjectImportPersister- Parameters:
entityRepresentation- the data that will be persisted.- Returns:
- the id of the newly created entity, or
nullif the Entity could not be created.
-
createChangeItemForIssueLinkIfNeeded
public String createChangeItemForIssueLinkIfNeeded(String issueId, String issueLinkTypeId, String linkedIssueKey, boolean isSource, ApplicationUser importAuthor) Description copied from interface:ProjectImportPersisterThis will look at the issue specified by issueId and add a changeItem for the issue link if it needs to. If a change item is added then the issues updated date will also be updated. If the issue already has a change item then one will not be added. If the issue has one but also has a change item that says the link was deleted this method will add a new one. If the issue has no change item for this link then one will be added.Please note: this method will add the change item but it does not re-index the issue, this should be handled elsewhere.
- Specified by:
createChangeItemForIssueLinkIfNeededin interfaceProjectImportPersister- Parameters:
issueId- the id of the issue that should exist in JIRA. This is the issue that will have the change item added to it if it does not already have one.issueLinkTypeId- the id of the issue link type in JIRA, this must exist.linkedIssueKey- the issue key that is part of the created link.isSource- true if the issue specified by issueId is the source of the issue link, false if it is the destination.importAuthor- the user who is performing the project import, this is used as the author of the change item marker for created issues.- Returns:
- the issue id that was changed if a change item was created, null otherwise.
-
reIndexProject
public void reIndexProject(ProjectImportMapper projectImportMapper, TaskProgressInterval taskProgressInterval, I18nHelper i18n) throws IndexException Description copied from interface:ProjectImportPersisterRe-indexes all the new Issues that have just been created in this Project Import. The list of Issues to be indexed is taken from theProjectImportIdMapper.getAllMappedIds().- Specified by:
reIndexProjectin interfaceProjectImportPersister- Parameters:
projectImportMapper- ProjectImportMapper which is used to get the new Issue IDtaskProgressInterval- Used to provide progress feedback, can be null.i18n- used to i18n the task progress messages.- Throws:
IndexException- If an error occurs in the IndexManager.
-
createAssociation
Description copied from interface:ProjectImportPersisterCreates a NodeAssocation which is used to link the issue to external values such as versions and components.- Specified by:
createAssociationin interfaceProjectImportPersister- Parameters:
nodeAssociation- the externalObject that contains the correct values to be persisted to the datastore.- Returns:
- true if the association was created false otherwise
-
createVoter
Description copied from interface:ProjectImportPersisterCreates a UserAssociation which is used to link the user to the issue as a voter.- Specified by:
createVoterin interfaceProjectImportPersister- Parameters:
voter- contains the issue and user information- Returns:
- true if created, false otherwise.
-
createWatcher
Description copied from interface:ProjectImportPersisterCreates a UserAssociation which is used to link the user to the issue as a watcher.- Specified by:
createWatcherin interfaceProjectImportPersister- Parameters:
watcher- contains the issue and user information- Returns:
- true if created, false otherwise.
-
updateProjectDetails
Description copied from interface:ProjectImportPersisterUpdates the details of an existing Project in JIRA from the given ExternalProject object. This includes the following:- name
- description
- URL
- lead
- assignee type
- email sender
- Specified by:
updateProjectDetailsin interfaceProjectImportPersister- Parameters:
externalProject- ExternalProject containing the data to use to update.- Returns:
- a Project object representing the project we just updated
-
createProject
Description copied from interface:ProjectImportPersisterCreates a project, with details based off of the ExternalProject. The project will be associated with the default schemes.- Specified by:
createProjectin interfaceProjectImportPersister- Parameters:
project- holds the details the project will be created with.- Returns:
- a Project object representing the project we just created
- Throws:
ExternalException- if there is an error creating the project.
-
createVersions
Description copied from interface:ProjectImportPersisterCreates the versions, specified byBackupProject.getProjectVersions()for the named backup project.- Specified by:
createVersionsin interfaceProjectImportPersister- Parameters:
backupProject- specifies the name of the project to create the versions for and the versions to create- Returns:
- a map of
Version's that represent the newly created versions keyed by the old version id they were created from.
-
createComponents
public Map<String,ProjectComponent> createComponents(BackupProject backupProject, ProjectImportMapper projectImportMapper) Description copied from interface:ProjectImportPersisterCreates the components, specified byBackupProject.getProjectComponents()for the named backup project.- Specified by:
createComponentsin interfaceProjectImportPersister- Parameters:
backupProject- specifies the name of the project to create the components for and the components to createprojectImportMapper- ProjectImportMapper used to map the component leads user key- Returns:
- a map of
ProjectComponent's that represent the newly created components keyed by the old component id they were created from.
-
updateProjectIssueCounter
Description copied from interface:ProjectImportPersisterUpdates a projects issue counter, which is used to determine the numeric portion of the issue key.- Specified by:
updateProjectIssueCounterin interfaceProjectImportPersister- Parameters:
backupProject- contains theExternalProjectthat holds the detailscounter- this is a long that the value will be set to in the stored project.
-
createUser
Description copied from interface:ProjectImportPersisterCreates a User in JIRA from the given ExternalUser object. This includes the custom properties as well as the standard ones.- Specified by:
createUserin interfaceProjectImportPersister- Parameters:
userMapper- contains mapping between old and new user keysexternalUser- ExternalUser containing the data to use to create the new User.- Returns:
- True If the user was created else false.
-
createAttachment
Description copied from interface:ProjectImportPersisterCreates an attachment specified by the ExternalAttachment. This will create a database entry for the attachment and will copy the file from its current path, specified byExternalAttachment.getAttachedFile()to the Jira attachment directory.- Specified by:
createAttachmentin interfaceProjectImportPersister- Parameters:
externalAttachment- specifies the issue id and attachment details for the attachment to create.- Returns:
- a
ChangeItemBeanor null if the attachment was not created.
-