com.atlassian.bamboo.plugins.hg
Class BitbucketRepository

java.lang.Object
  extended by com.atlassian.bamboo.v2.build.BaseBuildConfigurationAwarePlugin
      extended by com.atlassian.bamboo.v2.build.BaseConfigurablePlugin
          extended by com.atlassian.bamboo.repository.AbstractRepository
              extended by com.atlassian.bamboo.repository.AbstractStandaloneRepository
                  extended by com.atlassian.bamboo.plugins.hg.BitbucketRepository
All Implemented Interfaces:
ConvertibleFromConfig, InitablePluginModule, AdvancedConfigurationAwareRepository, BranchAwareRepository, BranchDetectionCapableRepository, BranchMergingAwareRepository, CachingAwareRepository, FilterChangesetAwareRepository, IncludeExcludeAwareRepository, PushCapableRepository, QuietPeriodAwareRepository, Repository, StandaloneRepository, DescriptionProvider, NameProvider, BambooPluginModule, BuildConfigurationAwarePlugin, ConfigurablePlugin, RenderableBuildConfiguration, CustomSourceDirectoryAwareRepository, RepositoryV2, RequirementsAwareRepository, java.io.Serializable

public class BitbucketRepository
extends AbstractStandaloneRepository
implements RequirementsAwareRepository, CustomSourceDirectoryAwareRepository, BranchDetectionCapableRepository, CachingAwareRepository, PushCapableRepository, BranchMergingAwareRepository

See Also:
Serialized Form

Nested Class Summary
 
Nested classes/interfaces inherited from interface com.atlassian.bamboo.repository.CachingAwareRepository
CachingAwareRepository.CachableOperation
 
Field Summary
static java.lang.String REPOSITORY_BITBUCKET_BRANCH
           
static java.lang.String REPOSITORY_BITBUCKET_COMMAND_TIMEOUT
           
static java.lang.String REPOSITORY_BITBUCKET_GIT_USE_SHALLOW_CLONES
           
static java.lang.String REPOSITORY_BITBUCKET_GIT_USE_SUBMODULES
           
static java.lang.String REPOSITORY_BITBUCKET_PASSWORD
           
static java.lang.String REPOSITORY_BITBUCKET_REPOSITORY
           
static java.lang.String REPOSITORY_BITBUCKET_SCM
           
static java.lang.String REPOSITORY_BITBUCKET_USERNAME
           
static java.lang.String REPOSITORY_BITBUCKET_VERBOSE_LOGS
           
 
Fields inherited from class com.atlassian.bamboo.repository.AbstractRepository
BUILD_TRIGGER_IP, buildDirectoryManager, buildLoggerManager, customVariableContext, featureManager, REPO_PREFIX, repositoryModuleDescriptor, templateRenderer, textProvider
 
Fields inherited from class com.atlassian.bamboo.v2.build.BaseBuildConfigurationAwarePlugin
moduleDescriptor
 
Fields inherited from interface com.atlassian.bamboo.repository.IncludeExcludeAwareRepository
FILTER_PATTERN_EXCLUDE, FILTER_PATTERN_INCLUDE, FILTER_PATTERN_OPTION, FILTER_PATTERN_REGEX
 
Fields inherited from interface com.atlassian.bamboo.repository.FilterChangesetAwareRepository
CHANGESET_FILTER_PATTERN_REGEX, MAVEN_RELEASE_PLUGIN_EXCLUSION_PATTERN
 
Constructor Summary
BitbucketRepository()
           
 
Method Summary
 void addDefaultValues(BuildConfiguration buildConfiguration)
          Extension point for adding default values to the form for RenderableBuildConfiguration.getEditHtml(com.atlassian.bamboo.ww2.actions.build.admin.create.BuildConfiguration, com.atlassian.bamboo.plan.Plan)
 BuildRepositoryChanges collectChangesSinceLastBuild(java.lang.String planKey, java.lang.String lastVcsRevisionKey)
          Collects the changes since the lastVcsRevisionKey.
 java.lang.String commit(java.io.File sourceDirectory, java.lang.String message)
          Perform a commit (dvcs commit).
 CacheId getCacheId(CachingAwareRepository.CachableOperation cachableOperation)
          Cache id has to fulfill the following: Given two Repository objects A and B, returning equal CacheId (in terms of equals()) and a cachable operation foo(), in the following sequence of calls made in a short time period: 1.
 CapabilityContext getCapabilityContext()
           
 java.lang.String getEncryptedPassword()
           
 CommitContext getFirstCommit()
          Retrieve the commit that created the Branch.
 java.lang.String getHost()
          What's the repository server host
 CommitContext getLastCommit()
          Retrieve last commit on the branch set on this Repository.
 java.lang.String getName()
          The display name for the repository type
 java.util.List<VcsBranch> getOpenBranches(java.lang.String context)
          Set of open branches that are discovered in the repository.
 java.lang.String getOptionDescription()
           
 java.lang.String getRealRepositoryUrl()
           
 java.util.Set<Requirement> getRequirements()
           
 java.lang.String getScm()
           
 java.lang.String getUsername()
           
 VcsBranch getVcsBranch()
           
 boolean isCachingSupportedFor(CachingAwareRepository.CachableOperation cachableOperation)
           
 boolean isMergingSupported()
           
 boolean isRepositoryDifferent(Repository repository)
          Checks if the current repo is the same as the given repository
 boolean isVerboseLogs()
           
 boolean mergeWorkspaceWith(BuildContext buildContext, java.io.File checkoutDirectory, java.lang.String targetRevision)
          Merges a workspace located in checkout directory with the target revision.
 void populateFromConfig(org.apache.commons.configuration.HierarchicalConfiguration config)
          Update the current object with data in the HierarchicalConfiguration
 void prepareConfigObject(BuildConfiguration buildConfiguration)
          Do any preprocessing work before validation occurs.
 void pushRevision(java.io.File sourceDirectory, java.lang.String vcsRevisionKey)
          Push the specified revision to the remote directory.
 java.lang.String retrieveSourceCode(BuildContext buildContext, java.lang.String vcsRevisionKey, java.io.File sourceDirectory)
          Checks out the latest source code from an appropriate repository to specified directory
 java.lang.String retrieveSourceCode(BuildContext buildContext, java.lang.String vcsRevisionKey, java.io.File sourceDirectory, int depth)
          Checks out the latest source code from an appropriate repository to specified directory
 void setBitbucketApiService(BitbucketApiService bitbucketApiService)
           
 void setCapabilityContext(CapabilityContext capabilityContext)
           
 void setEncryptionService(EncryptionService encryptionService)
           
 void setI18nResolver(com.atlassian.sal.api.message.I18nResolver i18nResolver)
           
 void setRepositoryHelperService(BitbucketRepositoryHelperService repositoryHelperService)
           
 void setRepositoryManager(RepositoryManager repositoryManager)
           
 void setVcsBranch(VcsBranch branch)
          Set and prepare the repository for using an arbitrary branch.
 org.apache.commons.configuration.HierarchicalConfiguration toConfiguration()
          Generate a HierarchicalConfiguration from the current state of the object
 ErrorCollection validate(BuildConfiguration buildConfiguration)
          Validates the properties in the BuildConfiguration object.
 
Methods inherited from class com.atlassian.bamboo.repository.AbstractStandaloneRepository
getAdvancedEditHtml, getAdvancedViewHtml, getEditHtml, getViewHtml
 
Methods inherited from class com.atlassian.bamboo.repository.AbstractRepository
checkConnection, customizeBuildRequirements, getAdvancedEditHtml, getAdvancedViewHtml, getBranchIntegrationEditHtml, getChangesetFilterPatternRegex, getDescription, getEditHtml, getFilterFilePatternOption, getFilterFilePatternRegex, getKey, getLocationIdentifier, getMavenPomCheckoutAccessEditHtml, getMaxRetries, getMinimalEditHtml, getQuietPeriod, getShortKey, getSourceCodeDirectory, getSystemWideExclusionPatterns, getViewHtml, getWorkingDirectory, init, isAdvancedOptionEnabled, isQuietPeriodEnabled, isWorkspaceEmpty, removeBuildRequirements, setBuildDirectoryManager, setBuildLoggerManager, setChangesetFilterPatternRegex, setCustomVariableContext, setFeatureManager, setFilterFilePatternOption, setFilterFilePatternRegex, setTemplateRenderer, setTextProvider, setWorkingDir, substituteString, toMergeCapableRepository
 
Methods inherited from class com.atlassian.bamboo.v2.build.BaseConfigurablePlugin
customizeBuildRequirements, removeBuildRequirements
 
Methods inherited from class com.atlassian.bamboo.v2.build.BaseBuildConfigurationAwarePlugin
isConfigurationMissing, populateContextForEdit, populateContextForView
 
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 
Methods inherited from interface com.atlassian.bamboo.repository.BranchMergingAwareRepository
getBranchIntegrationEditHtml
 

Field Detail

REPOSITORY_BITBUCKET_USERNAME

public static final java.lang.String REPOSITORY_BITBUCKET_USERNAME
See Also:
Constant Field Values

REPOSITORY_BITBUCKET_PASSWORD

public static final java.lang.String REPOSITORY_BITBUCKET_PASSWORD
See Also:
Constant Field Values

REPOSITORY_BITBUCKET_REPOSITORY

public static final java.lang.String REPOSITORY_BITBUCKET_REPOSITORY
See Also:
Constant Field Values

REPOSITORY_BITBUCKET_SCM

public static final java.lang.String REPOSITORY_BITBUCKET_SCM
See Also:
Constant Field Values

REPOSITORY_BITBUCKET_BRANCH

public static final java.lang.String REPOSITORY_BITBUCKET_BRANCH
See Also:
Constant Field Values

REPOSITORY_BITBUCKET_COMMAND_TIMEOUT

public static final java.lang.String REPOSITORY_BITBUCKET_COMMAND_TIMEOUT
See Also:
Constant Field Values

REPOSITORY_BITBUCKET_VERBOSE_LOGS

public static final java.lang.String REPOSITORY_BITBUCKET_VERBOSE_LOGS
See Also:
Constant Field Values

REPOSITORY_BITBUCKET_GIT_USE_SHALLOW_CLONES

public static final java.lang.String REPOSITORY_BITBUCKET_GIT_USE_SHALLOW_CLONES
See Also:
Constant Field Values

REPOSITORY_BITBUCKET_GIT_USE_SUBMODULES

public static final java.lang.String REPOSITORY_BITBUCKET_GIT_USE_SUBMODULES
See Also:
Constant Field Values
Constructor Detail

BitbucketRepository

public BitbucketRepository()
Method Detail

getName

@NotNull
public java.lang.String getName()
Description copied from interface: Repository
The display name for the repository type

Specified by:
getName in interface Repository
Specified by:
getName in interface DescriptionProvider
Specified by:
getName in interface NameProvider

getScm

public java.lang.String getScm()

getHost

public java.lang.String getHost()
Description copied from interface: Repository
What's the repository server host

Specified by:
getHost in interface Repository
Returns:
The host!

isRepositoryDifferent

public boolean isRepositoryDifferent(@NotNull
                                     Repository repository)
Description copied from interface: RepositoryV2
Checks if the current repo is the same as the given repository

Specified by:
isRepositoryDifferent in interface RepositoryV2
Parameters:
repository - to compare against
Returns:
true of repositories are different, false if the same;

addDefaultValues

public void addDefaultValues(@NotNull
                             BuildConfiguration buildConfiguration)
Description copied from interface: BuildConfigurationAwarePlugin
Extension point for adding default values to the form for RenderableBuildConfiguration.getEditHtml(com.atlassian.bamboo.ww2.actions.build.admin.create.BuildConfiguration, com.atlassian.bamboo.plan.Plan)

Specified by:
addDefaultValues in interface BuildConfigurationAwarePlugin
Overrides:
addDefaultValues in class AbstractRepository
Parameters:
buildConfiguration - - @NotNull

prepareConfigObject

public void prepareConfigObject(@NotNull
                                BuildConfiguration buildConfiguration)
Description copied from interface: BuildConfigurationAwarePlugin
Do any preprocessing work before validation occurs. For repository, builder and web repository plugins this will only be called if the plugin is select by the user.

Specified by:
prepareConfigObject in interface BuildConfigurationAwarePlugin
Overrides:
prepareConfigObject in class BaseBuildConfigurationAwarePlugin
Parameters:
buildConfiguration - - @NotNull

populateFromConfig

public void populateFromConfig(@NotNull
                               org.apache.commons.configuration.HierarchicalConfiguration config)
Description copied from interface: ConvertibleFromConfig
Update the current object with data in the HierarchicalConfiguration

Specified by:
populateFromConfig in interface ConvertibleFromConfig
Overrides:
populateFromConfig in class AbstractRepository

toConfiguration

@NotNull
public org.apache.commons.configuration.HierarchicalConfiguration toConfiguration()
Description copied from interface: ConvertibleFromConfig
Generate a HierarchicalConfiguration from the current state of the object

Specified by:
toConfiguration in interface ConvertibleFromConfig
Overrides:
toConfiguration in class AbstractRepository
Returns:
Always returns an HierarchicalConfiguration. Never null

validate

@NotNull
public ErrorCollection validate(@NotNull
                                        BuildConfiguration buildConfiguration)
Description copied from interface: BuildConfigurationAwarePlugin
Validates the properties in the BuildConfiguration object. The name of the properties match those passed in through the form fragments in RenderableBuildConfiguration.getEditHtml(com.atlassian.bamboo.ww2.actions.build.admin.create.BuildConfiguration, com.atlassian.bamboo.plan.Plan) template.

Specified by:
validate in interface BuildConfigurationAwarePlugin
Overrides:
validate in class AbstractRepository
Parameters:
buildConfiguration - - @NotNull
Returns:
ErrorCollection keyed by the field name. @NotNull

collectChangesSinceLastBuild

@NotNull
public BuildRepositoryChanges collectChangesSinceLastBuild(@NotNull
                                                                   java.lang.String planKey,
                                                                   @Nullable
                                                                   java.lang.String lastVcsRevisionKey)
                                                    throws RepositoryException
Description copied from interface: RepositoryV2
Collects the changes since the lastVcsRevisionKey. This method is called only on server side (never on agent).

Specified by:
collectChangesSinceLastBuild in interface RepositoryV2
lastVcsRevisionKey - can be null, if null you should ensure the correct vcsrevisionkey is returned in the BuildChanges object.
Returns:
A build changes object with the appropriate build changes
Throws:
RepositoryException - if something goes wrong

retrieveSourceCode

@NotNull
public java.lang.String retrieveSourceCode(@NotNull
                                                   BuildContext buildContext,
                                                   @Nullable
                                                   java.lang.String vcsRevisionKey,
                                                   @NotNull
                                                   java.io.File sourceDirectory)
                                    throws RepositoryException
Description copied from interface: CustomSourceDirectoryAwareRepository
Checks out the latest source code from an appropriate repository to specified directory

Specified by:
retrieveSourceCode in interface CustomSourceDirectoryAwareRepository
vcsRevisionKey - - may be null if you want latest code
sourceDirectory - - directory to checkout to
Returns:
vcsRevisionKey - the revision
Throws:
RepositoryException

retrieveSourceCode

@NotNull
public java.lang.String retrieveSourceCode(@NotNull
                                                   BuildContext buildContext,
                                                   @Nullable
                                                   java.lang.String vcsRevisionKey,
                                                   @NotNull
                                                   java.io.File sourceDirectory,
                                                   int depth)
                                    throws RepositoryException
Description copied from interface: BranchMergingAwareRepository
Checks out the latest source code from an appropriate repository to specified directory

Specified by:
retrieveSourceCode in interface BranchMergingAwareRepository
vcsRevisionKey - - may be null if you want latest code
sourceDirectory - - directory to checkout to
depth - - how many historical revisions we'd like to check out (-1 means all revisions)
Returns:
vcsRevisionKey - the revision
Throws:
RepositoryException

getRequirements

public java.util.Set<Requirement> getRequirements()
Specified by:
getRequirements in interface RequirementsAwareRepository

setBitbucketApiService

public void setBitbucketApiService(BitbucketApiService bitbucketApiService)

setRepositoryHelperService

public void setRepositoryHelperService(BitbucketRepositoryHelperService repositoryHelperService)

setI18nResolver

public void setI18nResolver(com.atlassian.sal.api.message.I18nResolver i18nResolver)

setRepositoryManager

public void setRepositoryManager(RepositoryManager repositoryManager)

setEncryptionService

public void setEncryptionService(EncryptionService encryptionService)

getCapabilityContext

public CapabilityContext getCapabilityContext()

setCapabilityContext

public void setCapabilityContext(CapabilityContext capabilityContext)

getRealRepositoryUrl

public java.lang.String getRealRepositoryUrl()

isVerboseLogs

public boolean isVerboseLogs()

getOptionDescription

public java.lang.String getOptionDescription()

getEncryptedPassword

@Nullable
public java.lang.String getEncryptedPassword()

getCacheId

public CacheId getCacheId(@NotNull
                          CachingAwareRepository.CachableOperation cachableOperation)
Description copied from interface: CachingAwareRepository
Cache id has to fulfill the following: Given two Repository objects A and B, returning equal CacheId (in terms of equals()) and a cachable operation foo(), in the following sequence of calls made in a short time period: 1. A::foo() 2. B::foo() 3. A::foo() the result of B::foo() should be the same as either the first or the second call to A::foo().

Specified by:
getCacheId in interface CachingAwareRepository
Returns:
the cache id of repository, null if the supplied operation cannot be cached

isCachingSupportedFor

public boolean isCachingSupportedFor(@NotNull
                                     CachingAwareRepository.CachableOperation cachableOperation)
Specified by:
isCachingSupportedFor in interface CachingAwareRepository
Returns:
true if the repository supports generation of CacheIds for a given operation

getOpenBranches

@NotNull
public java.util.List<VcsBranch> getOpenBranches(@Nullable
                                                         java.lang.String context)
                                          throws RepositoryException
Description copied from interface: BranchDetectionCapableRepository
Set of open branches that are discovered in the repository. Returns empty collection if no branches at all (can that happen?). Used for monitoring repositories for new branches. An open branch is a branch that is considered 'open' by underlying VCS - it has nothing to do with the actual development on that branch (recent commits or so).

Specified by:
getOpenBranches in interface BranchDetectionCapableRepository
Returns:
List of branch names. May be empty.
Throws:
RepositoryException

getUsername

@Nullable
public java.lang.String getUsername()

getVcsBranch

@NotNull
public VcsBranch getVcsBranch()
Specified by:
getVcsBranch in interface BranchAwareRepository
Returns:
the branch being used currently by this repository.

setVcsBranch

public void setVcsBranch(@NotNull
                         VcsBranch branch)
Description copied from interface: BranchAwareRepository
Set and prepare the repository for using an arbitrary branch. Generally the subsequent getVcsBranch should return the same branch name.

Specified by:
setVcsBranch in interface BranchAwareRepository

getFirstCommit

public CommitContext getFirstCommit()
                             throws RepositoryException
Description copied from interface: BranchDetectionCapableRepository
Retrieve the commit that created the Branch.

Specified by:
getFirstCommit in interface BranchDetectionCapableRepository
Returns:
the first commit to the branch
Throws:
RepositoryException

getLastCommit

public CommitContext getLastCommit()
                            throws RepositoryException
Description copied from interface: BranchDetectionCapableRepository
Retrieve last commit on the branch set on this Repository. Method is used by Chain Branch automatic expiry. If this method returns null Chain Branch is not expired.

Specified by:
getLastCommit in interface BranchDetectionCapableRepository
Returns:
the last commit or null if N/A
Throws:
RepositoryException

mergeWorkspaceWith

public boolean mergeWorkspaceWith(@NotNull
                                  BuildContext buildContext,
                                  @NotNull
                                  java.io.File checkoutDirectory,
                                  @NotNull
                                  java.lang.String targetRevision)
                           throws RepositoryException
Description copied from interface: BranchMergingAwareRepository
Merges a workspace located in checkout directory with the target revision.

Specified by:
mergeWorkspaceWith in interface BranchMergingAwareRepository
Parameters:
buildContext - the build context of build doing the merge
checkoutDirectory - the workspace to use for merge
targetRevision - the revision to merge with
Returns:
true if the result of the merge would result in a non-empty commit
Throws:
RepositoryException

isMergingSupported

public boolean isMergingSupported()
Specified by:
isMergingSupported in interface BranchMergingAwareRepository

pushRevision

public void pushRevision(@NotNull
                         java.io.File sourceDirectory,
                         @Nullable
                         java.lang.String vcsRevisionKey)
                  throws RepositoryException
Description copied from interface: PushCapableRepository
Push the specified revision to the remote directory. Throws RepositoryException when failed due to connection problems or similar.

Specified by:
pushRevision in interface PushCapableRepository
Parameters:
sourceDirectory - - the working directory of the repository we want to push from
vcsRevisionKey - - the revisionKey (usually a branch name) to push
Throws:
RepositoryException - - when something goes wrong

commit

@NotNull
public java.lang.String commit(@NotNull
                                       java.io.File sourceDirectory,
                                       @NotNull
                                       java.lang.String message)
                        throws RepositoryException
Description copied from interface: PushCapableRepository
Perform a commit (dvcs commit).

Specified by:
commit in interface PushCapableRepository
Parameters:
sourceDirectory - - which workspace directory to perform the commit
message - - what message use for commit
Returns:
Created commit revision key
Throws:
RepositoryException - - when something goes wrong


Copyright © 2012 Atlassian. All Rights Reserved.