Interface BackupSupport

All Known Implementing Classes:
AbstractConstraintCreationUpgradeTask, AbstractDeferredRunUpgradeTask, AbstractIndexContentUpgradeTask, AbstractPageTemplateMigrationUpgradeTask, AbstractUpgradeTask, AbstractUserMappingUpgradeTask, BandanaKeyUniqueConstraintUpgradeTask, BandanaTokenCleanupUpgradeTask, BandanaXStreamValueUpgradeTask, DatabaseValidationQueryMigrationUpgradeTask, DbTrueFalseTypeFixUpgradeTask, DecoratorLangMacroReplacementUpgradeTask, DeleteTemporaryAttachmentUploadsUpgradeTask, DenormalisedContentPermissionsTriggersUpgradeTask, DenormalisedContentPermissionsUpgradeTask, DenormalisedContentStatusUpgradeTask, DenormalisedPermissionsTriggersUpgradeTask, DenormalisedSpacePermissionsUpgradeTask, EmbeddedCrowdAddGroupExternalIdUpgradeTask, EmbeddedCrowdSchemaUpgradeTask, MigrateScheduledJobCacheUpgradeTask, MigrateTrashDateUpgradeTask, NoopSplitIndexUpgradeTask, NullModificationDateDraftUpgradeTask, RenameTempDirPropertyUpgradeTask, ReplaceC3p0ConnectionPoolWithHikariCPUpgradeTask, ResetJournalStateUpgradeTask, SplitIndexUpgradeTask, SplitJournalUpgradeTask, SynchronyPidFileRemovalUpgradeTask, TurnFastPermissionsOnByDefaultUpgradeTask, UserDirectoryPasswordEncryptionUpgradeTask, WikiToXhtmlMigrationUpgradeTask

public interface BackupSupport
Interface implemented by AbstractUpgradeTasks which provide information to the backup manager to manage backward and forward compatibility.

If you're unsure how to fill this information, please have a look at https://pug.jira-dev.com/wiki/display/CONFDEV/How+to+add+to+or+change+the+Confluence+Database

Also, please list your upgrade task in https://pug.jira-dev.com/wiki/display/CONFDEV/List+of+upgrade+tasks+in+Confluence

  • Method Summary

    Modifier and Type
    Method
    Description
    boolean
    Returns true if a new export can't be imported in an older instance.
    boolean
    Returns true if an older Space can't be imported in a new instance without running this task.
  • Method Details

    • runOnSpaceImport

      boolean runOnSpaceImport()
      Returns true if an older Space can't be imported in a new instance without running this task. For example:
      • A task updating macro names in the BodyContent table would be blocking.
      • Tasks which updates data related to the space would be blocking.
      • A task upgrading the user table wouldn't be blocking.
      • Adding a mandatory column on space-related content breaks space import

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

      Since:
      5.2
    • breaksBackwardCompatibility

      boolean breaksBackwardCompatibility()
      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:

      • A destructive operation (Some data is replaced by another) breaks backwards compatibility
      • Adding a optional column does NOT break backwards compatibility
      • Data is copied to another column doesn't breaks backwards compatibility
      • A build number incrementation doesn't breaks backwards compatibility
      The best way to test is whether a newer export can be imported (with fully working features) in an older instance.
      Since:
      5.2