com.atlassian.confluence.upgrade.upgradetask
Class ReferencedUsersUserMappingUpgradeTask

java.lang.Object
  extended by com.atlassian.confluence.upgrade.AbstractUpgradeTask
      extended by com.atlassian.confluence.upgrade.upgradetask.AbstractUserMappingUpgradeTask
          extended by com.atlassian.confluence.upgrade.upgradetask.ReferencedUsersUserMappingUpgradeTask
All Implemented Interfaces:
BackupSupport, DatabaseUpgradeTask, UpgradeTask, UpgradeTaskInfo, org.springframework.beans.factory.BeanNameAware

public class ReferencedUsersUserMappingUpgradeTask
extends AbstractUserMappingUpgradeTask
implements DatabaseUpgradeTask

Upgrade task to ensure that for all the user names in Confluence a ConfluenceUser object exist. Various username related columns across all content table are considered. This is consistent with Confluence's behaviour of allowing content to be owned/created/modified/whatever by non-existent users. Note that various "post schema" upgrade tasks assume this task has already run and make the assumption that all content referenced users are populated in the user_mapping table (ConfluenceUser). e.g. UserIndexingUpgradeTask.


Field Summary
 
Fields inherited from interface com.atlassian.confluence.upgrade.UpgradeTask
log
 
Constructor Summary
ReferencedUsersUserMappingUpgradeTask(ConfluenceUserDao confluenceUserDao, net.sf.hibernate.SessionFactory sessionFactory, org.springframework.transaction.PlatformTransactionManager transactionManager, BatchOperationManager batchOperationManager, java.util.Map<java.lang.String,java.util.Set<java.lang.String>> userNameReferences, com.atlassian.config.db.HibernateConfig hibernateConfig)
           
 
Method Summary
 boolean breaksBackwardCompatibility()
          Returns true if a new export can't be imported in an older instance.
 java.lang.String getBuildNumber()
           
 java.lang.String getShortDescription()
          A short (<50 chars) description of the upgrade action
protected  java.util.Set<java.lang.String> getUsernamesMissingMapping()
           
 boolean runOnSpaceImport()
          Returns true if an older Space can't be imported in a new instance without running this task.
 
Methods inherited from class com.atlassian.confluence.upgrade.upgradetask.AbstractUserMappingUpgradeTask
doUpgrade
 
Methods inherited from class com.atlassian.confluence.upgrade.AbstractUpgradeTask
addAllErrors, addError, addError, getConstraint, getErrors, getName, isDatabaseUpgrade, setBeanName, setBuildNumber, validate
 
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 
Methods inherited from interface com.atlassian.confluence.upgrade.UpgradeTask
doUpgrade, getConstraint, getErrors, validate
 
Methods inherited from interface com.atlassian.confluence.upgrade.UpgradeTaskInfo
getName, isDatabaseUpgrade
 

Constructor Detail

ReferencedUsersUserMappingUpgradeTask

public ReferencedUsersUserMappingUpgradeTask(ConfluenceUserDao confluenceUserDao,
                                             net.sf.hibernate.SessionFactory sessionFactory,
                                             org.springframework.transaction.PlatformTransactionManager transactionManager,
                                             BatchOperationManager batchOperationManager,
                                             java.util.Map<java.lang.String,java.util.Set<java.lang.String>> userNameReferences,
                                             com.atlassian.config.db.HibernateConfig hibernateConfig)
Method Detail

getUsernamesMissingMapping

protected java.util.Set<java.lang.String> getUsernamesMissingMapping()
Specified by:
getUsernamesMissingMapping in class AbstractUserMappingUpgradeTask

runOnSpaceImport

public boolean runOnSpaceImport()
Description copied from interface: BackupSupport
Returns true if an older Space can't be imported in a new instance without running this task. For example:

Note that tasks don't run on space import yet, so we just reject the import in this case.

Specified by:
runOnSpaceImport in interface BackupSupport

breaksBackwardCompatibility

public boolean breaksBackwardCompatibility()
Description copied from interface: BackupSupport
Returns true if a new export can't be imported in an older instance. Breaking compatibility means a snapshot of the new version will not work at all with the previous version. For example: The best way to test is whether a newer export can be imported (with fully working features) in an older instance.

Specified by:
breaksBackwardCompatibility in interface BackupSupport

getBuildNumber

public java.lang.String getBuildNumber()
Specified by:
getBuildNumber in interface UpgradeTaskInfo
Overrides:
getBuildNumber in class AbstractUpgradeTask
Returns:
The build number that this upgrade is applicable to

getShortDescription

public java.lang.String getShortDescription()
Description copied from interface: UpgradeTaskInfo
A short (<50 chars) description of the upgrade action

Specified by:
getShortDescription in interface UpgradeTaskInfo
Overrides:
getShortDescription in class AbstractUpgradeTask


Copyright © 2003-2014 Atlassian. All Rights Reserved.