Class SvnRepository
- All Implemented Interfaces:
ConvertibleFromConfig
,InitablePluginModule
,AdvancedConfigurationAwareRepository
,BranchAwareRepository
,BranchDetectionCapableRepository
,BranchInformationProvider
,BranchingAwareRepository
,CachingAwareRepository
,CommitIsolationAwareRepository
,CustomRevisionDataAwareRepository
,CustomVariableProviderRepository
,DeploymentAwareRepository
,FilterChangesetAwareRepository
,IncludeExcludeAwareRepository
,InitialBuildAwareRepository
,MandatoryCleanCheckoutAwareRepository
,MavenPomAccessorCapableRepository
,OnceOffCapableRepository
,QuietPeriodAwareRepository
,Repository
,SelectableAuthenticationRepository
,StandaloneRepository
,TaggingAwareRepository
,TestConnectionAwareRepository
,DescriptionProvider
,NameProvider
,BambooPluginModule
,BuildConfigurationAwarePlugin
,ConfigurablePlugin
,RenderableBuildConfiguration
,CustomSourceDirectoryAwareRepository
,RepositoryEventAware
,RepositoryV2
,Serializable
public class SvnRepository
extends AbstractStandaloneRepository
implements SelectableAuthenticationRepository, InitialBuildAwareRepository, RepositoryEventAware, MavenPomAccessorCapableRepository, CommitIsolationAwareRepository, BranchingAwareRepository, TaggingAwareRepository, CustomSourceDirectoryAwareRepository, MandatoryCleanCheckoutAwareRepository, AdvancedConfigurationAwareRepository, CustomRevisionDataAwareRepository, CustomVariableProviderRepository, BranchInformationProvider, CachingAwareRepository, DeploymentAwareRepository, TestConnectionAwareRepository
This class provides a Subversion repository for Bamboo.
- See Also:
-
Nested Class Summary
Nested classes/interfaces inherited from interface com.atlassian.bamboo.repository.CachingAwareRepository
CachingAwareRepository.CachableOperation
-
Field Summary
Modifier and TypeFieldDescriptionstatic final String
static final String
static final String
static final String
static final String
static final org.tmatesoft.svn.core.wc.ISVNOptions
static final String
static final String
static final String
static final String
static final String
static final String
static final String
static final String
static final String
static final String
static final String
static final String
static final String
static final String
static final String
protected TrustedKeyHelper
static final String
static final String
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.CommitIsolationAwareRepository
COMMIT_ISOLATION_OPTION
Fields inherited from interface com.atlassian.bamboo.repository.FilterChangesetAwareRepository
CHANGESET_FILTER_PATTERN_REGEX, MAVEN_RELEASE_PLUGIN_EXCLUSION_PATTERN
Fields inherited from interface com.atlassian.bamboo.repository.IncludeExcludeAwareRepository
FILTER_PATTERN_EXCLUDE, FILTER_PATTERN_INCLUDE, FILTER_PATTERN_NONE, FILTER_PATTERN_OPTION, FILTER_PATTERN_REGEX
Fields inherited from interface com.atlassian.bamboo.repository.Repository
SELECTED_REPOSITORY, UNKNOWN_HOST
Fields inherited from interface com.atlassian.bamboo.repository.TestConnectionAwareRepository
HOST_KEY
-
Constructor Summary
-
Method Summary
Modifier and TypeMethodDescriptionvoid
addDefaultValues
(@NotNull BuildConfiguration buildConfiguration) Extension point for adding default values to the form forRenderableBuildConfiguration.getEditHtml(com.atlassian.bamboo.ww2.actions.build.admin.create.BuildConfiguration, com.atlassian.bamboo.plan.Plan)
long
checkout
(org.tmatesoft.svn.core.SVNURL url, org.tmatesoft.svn.core.wc.SVNRevision revision, File dstPath, boolean isRecursive) Checks out a working copy from a repository.@NotNull BuildRepositoryChanges
collectChangesForRevision
(@NotNull PlanKey planKey, @NotNull String targetRevision) Collects the changes for the targetRevision.@NotNull BuildRepositoryChanges
collectChangesSinceLastBuild
(@NotNull String planKey, @NotNull PlanVcsRevisionData revisionData) @NotNull BuildRepositoryChanges
collectChangesSinceLastBuild
(@NotNull String planKey, @Nullable String lastVcsRevisionKey) Collects the changes since the lastVcsRevisionKey.int
void
createBranch
(long repositoryId, @NotNull String branchName, @NotNull BuildContext buildContext) Creates branch in the repository.void
createTag
(long repositoryId, @NotNull String tagName, @NotNull BuildContext buildContext) Creates a tag in the repositoryboolean
long
export
(org.tmatesoft.svn.core.SVNURL url, org.tmatesoft.svn.core.wc.SVNRevision revision, File dstPath, boolean isRecursive) @NotNull List<NameValuePair>
List all authentication types supported by repository.org.tmatesoft.svn.core.SVNURL
getCacheId
(@NotNull 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.static String
Return a map containing name->value mapping of the variables.Retrieve the commit that created the Branch.getHost()
What's the repository server hostgetHost
(BuildContext buildContext) Retrieve last commit on the branch set on this Repository.@NotNull String
A string representing the location of the repository@NotNull SvnRepositoryMavenPomAccessor
@NotNull String
getName()
What's the name of the plugin - appears in the GUI dropdowngetOpenBranches
(@Nullable String context) Set
of open branches that are discovered in the repository.Return a map containing name->value mapping of the plan repository format variables.protected static String
Which repository URL are we using?Return repository URL with extrapolated Bamboo variablesprotected org.tmatesoft.svn.core.SVNURL
protected org.tmatesoft.svn.core.wc.SVNClientManager
SVNClientManager factory.protected String
protected String
getUrl()
Where is the documentation and help about using Subversion?What username are we using to access the repository?What password are we using to access the repository@NotNull VcsBranch
int
hashCode()
@NotNull org.tmatesoft.svn.core.wc.SVNInfo
info
(org.tmatesoft.svn.core.SVNURL url, org.tmatesoft.svn.core.wc.SVNRevision revision) Runs 'svn info' operation on a given URL.boolean
isAdvancedOptionEnabled
(@NotNull BuildConfiguration buildConfiguration) boolean
boolean
boolean
isCachingSupportedFor
(@NotNull CachingAwareRepository.CachableOperation cachableOperation) boolean
boolean
Whether or not commits will be broken up into individual builds@NotNull List<BuildRepositoryChanges>
isolateCommits
(@NotNull BuildRepositoryChanges buildChanges) Break the single build changes object into a list ofBuildRepositoryChanges
.protected boolean
isRecoverableException
(@NotNull org.tmatesoft.svn.core.SVNException e) Check if provided exception object identifies recoverable exception.boolean
isRepositoryDifferent
(@NotNull Repository repository) Checks if the current repo is the same as the given repositoryboolean
boolean
void
onInitialBuild
(BuildContext buildContext) Allows theRepository
to perform custom actions when an initial build is triggered.void
populateFromConfig
(@NotNull org.apache.commons.configuration.HierarchicalConfiguration config) Update the current object with data in theHierarchicalConfiguration
void
postRetrieveSourceCode
(@NotNull BuildContext buildContext, @NotNull File sourceDirectory) postRetrieveSourceCode will run after the retrieveSourceCode method is called.void
prepareConfigObject
(@NotNull BuildConfiguration buildConfiguration) Do any preprocessing work before validation occurs.void
preRetrieveSourceCode
(@NotNull BuildContext buildContext, @NotNull File sourceDirectory) Checks if the SVN URL has changed@NotNull String
retrieveSourceCode
(@NotNull BuildContext buildContext, @Nullable String vcsRevisionKey, @NotNull File sourceDirectory) Checks out the latest source code from an appropriate repository to specified directoryvoid
setAdministrationConfigurationAccessor
(AdministrationConfigurationAccessor administrationConfigurationAccessor) void
setAuthType
(String authType) void
setAutodetectBranchRoot
(boolean autodetectBranchRoot) void
setCommitIsolationEnabled
(boolean commitIsolationEnabled) void
setEncryptedPassphrase
(String encryptedPassphrase) void
setEncryptedPassword
(String encryptedPassword) void
setKeyFile
(String myKeyFile) void
setManualBranchRootUrl
(String branchRoot) void
setPassphrase
(String passphrase) void
setRepositoryUrl
(String repositoryUrl) Specify the subversion repository we are usingvoid
setSvnClientManagerFactory
(SVNClientManagerFactory svnClientManagerFactory) void
setTrustedKeyHelper
(TrustedKeyHelper trustedKeyHelper) void
setUseExport
(boolean useExport) void
setUseExternals
(boolean useExternals) void
setUsername
(String username) What's the username (if any) we are using to acces the repository?void
setUserPassword
(String password) Specify the password required to access the resposotoryvoid
setVcsBranch
(@NotNull VcsBranch branch) Set and prepare the repository for using an arbitrary branch.void
setVcsBranch
(@NotNull VcsBranch branch, @NotNull org.apache.commons.configuration.HierarchicalConfiguration customConfiguration) @NotNull ErrorCollection
testConnection
(long timeout, @NotNull TimeUnit unit) Test connection to the repository within the given timeout.@NotNull org.apache.commons.configuration.HierarchicalConfiguration
Store SvnRepository data into configuration object.boolean
If Bamboo generic detection polling should be used for this repository@NotNull ErrorCollection
validate
(@NotNull BuildConfiguration buildConfiguration) Validates the properties in theBuildConfiguration
object.Methods inherited from class com.atlassian.bamboo.repository.AbstractStandaloneRepository
getAdvancedEditHtml, getAdvancedViewHtml, getEditHtml, getViewHtml, getViewHtml
Methods inherited from class com.atlassian.bamboo.repository.AbstractRepository
checkConnection, customizeBuildRequirements, getAdvancedEditHtml, getAdvancedViewHtml, getBranchIntegrationEditHtml, getChangesetFilterPatternRegex, getDefaultTriggerModule, getDescription, getEditHtml, getFilterFilePatternOption, getFilterFilePatternRegex, getKey, getMavenPomCheckoutAccessEditHtml, getMaxCommitsToReturn, getMaxRetries, getMinimalEditHtml, getPollingTriggerModule, getQuietPeriod, getShortKey, getSourceCodeDirectory, getSystemWideExclusionPatterns, getViewHtml, getWorkingDirectory, init, isQuietPeriodEnabled, isWorkspaceEmpty, removeBuildRequirements, setBuildDirectoryManager, setBuildLoggerManager, setChangesetFilterPatternRegex, setCustomVariableContext, setFeatureManager, setFilterFilePatternOption, setFilterFilePatternRegex, setTemplateRenderer, setTextProvider, setWorkingDir, substituteString, toMergeCapableRepository
Methods inherited from class com.atlassian.bamboo.v2.build.BaseBuildConfigurationAwarePlugin
getTemplateRenderer, populateContextForEdit, populateContextForView
Methods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, toString, wait, wait, wait
Methods inherited from interface com.atlassian.bamboo.repository.AdvancedConfigurationAwareRepository
getAdvancedEditHtml, getAdvancedViewHtml
Methods inherited from interface com.atlassian.bamboo.v2.build.BuildConfigurationAwarePlugin
isConfigurationMissing
Methods inherited from interface com.atlassian.bamboo.v2.build.ConfigurablePlugin
customizeBuildRequirements, removeBuildRequirements
Methods inherited from interface com.atlassian.bamboo.utils.DescriptionProvider
getDescription
Methods inherited from interface com.atlassian.bamboo.plugin.InitablePluginModule
init
Methods inherited from interface com.atlassian.bamboo.v2.build.RenderableBuildConfiguration
getEditHtml, getViewHtml
Methods inherited from interface com.atlassian.bamboo.repository.Repository
checkConnection, getKey, getMinimalEditHtml, getShortKey
Methods inherited from interface com.atlassian.bamboo.v2.build.repository.RepositoryV2
getSourceCodeDirectory
Methods inherited from interface com.atlassian.bamboo.repository.TestConnectionAwareRepository
validateForConnectionTesting
-
Field Details
-
NAME
- See Also:
-
KEY
- See Also:
-
COMPLETE_PLUGIN_KEY
- See Also:
-
SVN_REPO_PREFIX
- See Also:
-
SVN_REPO_URL
- See Also:
-
SVN_USERNAME
- See Also:
-
SVN_AUTH_TYPE
- See Also:
-
SVN_PASSWORD
- See Also:
-
SVN_KEYFILE
- See Also:
-
SVN_PASSPHRASE
- See Also:
-
SVN_SSL_KEYFILE
- See Also:
-
SVN_SSL_PASSPHRASE
- See Also:
-
USE_EXTERNALS
- See Also:
-
USE_EXPORT
- See Also:
-
TEMPORARY_SVN_REPO_PREFIX
- See Also:
-
TEMPORARY_SVN_PASSWORD
- See Also:
-
BRANCH_AUTODETECT_ROOT
- See Also:
-
BRANCH_MANUAL_ROOT
- See Also:
-
TAG_AUTODETECT_ROOT
- See Also:
-
TAG_MANUAL_ROOT
- See Also:
-
BRANCHES_DETECTION_BRANCHES_ROOT
- See Also:
-
BRANCHES_DETECTION_BRANCHES_ROOT_OVERRIDDEN
- See Also:
-
DEFAULT_SVN_OPTIONS
public static final org.tmatesoft.svn.core.wc.ISVNOptions DEFAULT_SVN_OPTIONS -
trustedKeyHelper
-
-
Constructor Details
-
SvnRepository
public SvnRepository()
-
-
Method Details
-
collectChangesSinceLastBuild
@NotNull public @NotNull BuildRepositoryChanges collectChangesSinceLastBuild(@NotNull @NotNull String planKey, @NotNull @NotNull PlanVcsRevisionData revisionData) throws RepositoryException - Specified by:
collectChangesSinceLastBuild
in interfaceCustomRevisionDataAwareRepository
- Throws:
RepositoryException
-
collectChangesForRevision
@NotNull public @NotNull BuildRepositoryChanges collectChangesForRevision(@NotNull @NotNull PlanKey planKey, @NotNull @NotNull String targetRevision) throws RepositoryException Description copied from interface:OnceOffCapableRepository
Collects the changes for the targetRevision. This method is called only on server side (never on agent).- Specified by:
collectChangesForRevision
in interfaceOnceOffCapableRepository
- Overrides:
collectChangesForRevision
in classAbstractRepository
- Returns:
- A build changes object with the appropriate build changes (that is - with the single commit data relevant for targetRevision)
- Throws:
RepositoryException
- if something goes wrong
-
collectChangesSinceLastBuild
@NotNull public @NotNull BuildRepositoryChanges collectChangesSinceLastBuild(@NotNull @NotNull String planKey, @Nullable @Nullable 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 interfaceRepositoryV2
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
-
usePollingForBranchDetection
public boolean usePollingForBranchDetection()Description copied from interface:BranchInformationProvider
If Bamboo generic detection polling should be used for this repository- Specified by:
usePollingForBranchDetection
in interfaceBranchInformationProvider
- Returns:
-
retrieveSourceCode
@NotNull public @NotNull String retrieveSourceCode(@NotNull @NotNull BuildContext buildContext, @Nullable @Nullable String vcsRevisionKey, @NotNull @NotNull 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 interfaceCustomSourceDirectoryAwareRepository
vcsRevisionKey
- - may be null if you want latest codesourceDirectory
- - directory to checkout to- Returns:
- vcsRevisionKey - the revision
- Throws:
RepositoryException
-
preRetrieveSourceCode
public void preRetrieveSourceCode(@NotNull @NotNull BuildContext buildContext, @NotNull @NotNull File sourceDirectory) Checks if the SVN URL has changed- Specified by:
preRetrieveSourceCode
in interfaceRepositoryEventAware
- Parameters:
buildContext
-
-
postRetrieveSourceCode
public void postRetrieveSourceCode(@NotNull @NotNull BuildContext buildContext, @NotNull @NotNull File sourceDirectory) Description copied from interface:RepositoryEventAware
postRetrieveSourceCode will run after the retrieveSourceCode method is called. The extension point allows you to easily set custom data, do any post checkout collection of data.- Specified by:
postRetrieveSourceCode
in interfaceRepositoryEventAware
-
isRecoverableException
protected boolean isRecoverableException(@NotNull @NotNull org.tmatesoft.svn.core.SVNException e) Check if provided exception object identifies recoverable exception.- Parameters:
e
- Exception to be analyzed.- Returns:
- True if exception is recognized as the one we can recover from.
-
getSvnClientManager
protected org.tmatesoft.svn.core.wc.SVNClientManager getSvnClientManager()SVNClientManager factory.- Returns:
- SVNClientManager appropriate for authorization mode
-
validate
@NotNull public @NotNull ErrorCollection validate(@NotNull @NotNull BuildConfiguration buildConfiguration) Description copied from interface:BuildConfigurationAwarePlugin
Validates the properties in theBuildConfiguration
object. The name of the properties match those passed in through the form fragments inRenderableBuildConfiguration.getEditHtml(com.atlassian.bamboo.ww2.actions.build.admin.create.BuildConfiguration, com.atlassian.bamboo.plan.Plan)
template.- Specified by:
validate
in interfaceBuildConfigurationAwarePlugin
- Overrides:
validate
in classAbstractRepository
- Parameters:
buildConfiguration
- -- Returns:
ErrorCollection
keyed by the field name.
-
isRepositoryDifferent
Description copied from interface:RepositoryV2
Checks if the current repo is the same as the given repository- Specified by:
isRepositoryDifferent
in interfaceRepositoryV2
- Parameters:
repository
- to compare against- Returns:
- true of repositories are different, false if the same;
-
prepareConfigObject
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 interfaceBuildConfigurationAwarePlugin
- Overrides:
prepareConfigObject
in classBaseBuildConfigurationAwarePlugin
- Parameters:
buildConfiguration
- -
-
checkout
public long checkout(org.tmatesoft.svn.core.SVNURL url, org.tmatesoft.svn.core.wc.SVNRevision revision, File dstPath, boolean isRecursive) throws RepositoryException Checks out a working copy from a repository. Like 'svn checkout URL[@REV] PATH (-r..)' command; It's done by invoking- Parameters:
url
- repository location where a working copy is to be checked out from;revision
- a revision at which a working copy being checked out is to be;dstPath
- a local path where the working copy will be fetched into;isRecursive
- if true and url corresponds to a directory then doCheckout(..) recursively- Returns:
- the number of the revision at which the working copy is
- Throws:
RepositoryException
- Failed!
-
export
public long export(org.tmatesoft.svn.core.SVNURL url, org.tmatesoft.svn.core.wc.SVNRevision revision, File dstPath, boolean isRecursive) throws RepositoryException - Throws:
RepositoryException
-
getMavenPomAccessor
- Specified by:
getMavenPomAccessor
in interfaceMavenPomAccessorCapableRepository
-
info
@NotNull public @NotNull org.tmatesoft.svn.core.wc.SVNInfo info(org.tmatesoft.svn.core.SVNURL url, org.tmatesoft.svn.core.wc.SVNRevision revision) throws RepositoryException Runs 'svn info' operation on a given URL.- Parameters:
url
- repository location which shall be queriedrevision
- a revision of repository location which shall be queried- Returns:
- SVNInfo object holding data
- Throws:
RepositoryException
- Failed!
-
addDefaultValues
Description copied from interface:BuildConfigurationAwarePlugin
Extension point for adding default values to the form forRenderableBuildConfiguration.getEditHtml(com.atlassian.bamboo.ww2.actions.build.admin.create.BuildConfiguration, com.atlassian.bamboo.plan.Plan)
- Specified by:
addDefaultValues
in interfaceBuildConfigurationAwarePlugin
- Overrides:
addDefaultValues
in classAbstractRepository
- Parameters:
buildConfiguration
- -
-
populateFromConfig
public void populateFromConfig(@NotNull @NotNull org.apache.commons.configuration.HierarchicalConfiguration config) Description copied from interface:ConvertibleFromConfig
Update the current object with data in theHierarchicalConfiguration
- Specified by:
populateFromConfig
in interfaceConvertibleFromConfig
- Overrides:
populateFromConfig
in classAbstractRepository
-
toConfiguration
@NotNull public @NotNull org.apache.commons.configuration.HierarchicalConfiguration toConfiguration()Store SvnRepository data into configuration object.- Specified by:
toConfiguration
in interfaceConvertibleFromConfig
- Overrides:
toConfiguration
in classAbstractRepository
- Returns:
-
onInitialBuild
Description copied from interface:InitialBuildAwareRepository
Allows theRepository
to perform custom actions when an initial build is triggered.- Specified by:
onInitialBuild
in interfaceInitialBuildAwareRepository
-
isAdvancedOptionEnabled
- Overrides:
isAdvancedOptionEnabled
in classAbstractRepository
-
getName
What's the name of the plugin - appears in the GUI dropdown- Specified by:
getName
in interfaceDescriptionProvider
- Specified by:
getName
in interfaceNameProvider
- Specified by:
getName
in interfaceRepository
- Returns:
- The name
-
getPassphrase
-
setPassphrase
-
getEncryptedPassphrase
-
setEncryptedPassphrase
-
getKeyFile
-
getSubstitutedKeyFile
-
setKeyFile
-
getAuthType
- Specified by:
getAuthType
in interfaceSelectableAuthenticationRepository
- Returns:
- the authentication type for this repository configuration
-
setAuthType
-
getUrl
Where is the documentation and help about using Subversion?- Returns:
- The web url
-
setRepositoryUrl
Specify the subversion repository we are using- Parameters:
repositoryUrl
- The subversion repository
-
getRepositoryUrl
Which repository URL are we using?- Returns:
- The subversion repository
-
getSubstitutedRepositoryUrl
Return repository URL with extrapolated Bamboo variables- Returns:
- Repository URL with extrapolated Bamboo variables
-
setUsername
What's the username (if any) we are using to acces the repository?- Parameters:
username
- The user name, null if there is no user
-
getUsername
What username are we using to access the repository?- Returns:
- The username, null if we are not using user authentication
-
setUserPassword
Specify the password required to access the resposotory- Parameters:
password
- The password (null if we are not using user authentication)
-
getUserPassword
What password are we using to access the repository- Returns:
- The password (null if we are not using user authentication)
-
getEncryptedPassword
-
setEncryptedPassword
-
getSubstitutedSvnUrl
protected org.tmatesoft.svn.core.SVNURL getSubstitutedSvnUrl() throws org.tmatesoft.svn.core.SVNException- Throws:
org.tmatesoft.svn.core.SVNException
-
getHost
Description copied from interface:Repository
What's the repository server host- Specified by:
getHost
in interfaceRepository
- Returns:
- The host!
-
getHost
-
getLocationIdentifier
Description copied from interface:Repository
A string representing the location of the repository- Specified by:
getLocationIdentifier
in interfaceRepository
- Overrides:
getLocationIdentifier
in classAbstractRepository
- Returns:
-
isUseExternals
public boolean isUseExternals() -
setUseExternals
public void setUseExternals(boolean useExternals) -
isUseExport
public boolean isUseExport() -
setUseExport
public void setUseExport(boolean useExport) -
isCleanCheckoutRequired
public boolean isCleanCheckoutRequired()- Specified by:
isCleanCheckoutRequired
in interfaceMandatoryCleanCheckoutAwareRepository
-
setSvnClientManagerFactory
-
hashCode
public int hashCode() -
equals
-
compareTo
-
getAuthenticationTypes
Description copied from interface:SelectableAuthenticationRepository
List all authentication types supported by repository.- Specified by:
getAuthenticationTypes
in interfaceSelectableAuthenticationRepository
- Returns:
- List of authentication types supported by repository
-
isCommitIsolationEnabled
public boolean isCommitIsolationEnabled()Description copied from interface:CommitIsolationAwareRepository
Whether or not commits will be broken up into individual builds- Specified by:
isCommitIsolationEnabled
in interfaceCommitIsolationAwareRepository
- Returns:
-
setCommitIsolationEnabled
public void setCommitIsolationEnabled(boolean commitIsolationEnabled) -
isAutodetectBranchRootUrl
public boolean isAutodetectBranchRootUrl() -
setAutodetectBranchRoot
public void setAutodetectBranchRoot(boolean autodetectBranchRoot) -
isAutodetectTagRootUrl
public boolean isAutodetectTagRootUrl() -
getManualBranchRootUrl
-
setManualBranchRootUrl
-
getManualTagRootUrl
-
setTrustedKeyHelper
-
setAdministrationConfigurationAccessor
public void setAdministrationConfigurationAccessor(AdministrationConfigurationAccessor administrationConfigurationAccessor) - Overrides:
setAdministrationConfigurationAccessor
in classAbstractRepository
-
isolateCommits
@NotNull public @NotNull List<BuildRepositoryChanges> isolateCommits(@NotNull @NotNull BuildRepositoryChanges buildChanges) Description copied from interface:CommitIsolationAwareRepository
Break the single build changes object into a list ofBuildRepositoryChanges
. Must not be null. May return an empty list but that doesn't actually make any sense.
The order here matters. The first of theBuildRepositoryChanges
will be more likely to be built than lower changes, which may be discarded.- Specified by:
isolateCommits
in interfaceCommitIsolationAwareRepository
- Returns:
-
createBranch
public void createBranch(long repositoryId, @NotNull @NotNull String branchName, @NotNull @NotNull BuildContext buildContext) throws RepositoryException Description copied from interface:BranchingAwareRepository
Creates branch in the repository.- Specified by:
createBranch
in interfaceBranchingAwareRepository
branchName
- name of new branchbuildContext
- build context- Throws:
RepositoryException
-
createTag
public void createTag(long repositoryId, @NotNull @NotNull String tagName, @NotNull @NotNull BuildContext buildContext) throws RepositoryException Description copied from interface:TaggingAwareRepository
Creates a tag in the repository- Specified by:
createTag
in interfaceTaggingAwareRepository
tagName
- - name of the tagbuildContext
- - build context- Throws:
RepositoryException
-
getCustomVariables
Description copied from interface:CustomVariableProviderRepository
Return a map containing name->value mapping of the variables.Null values will be filtered out so it's safe to put them in the map.
- Specified by:
getCustomVariables
in interfaceCustomVariableProviderRepository
- Returns:
- Map with variable substitutions
-
getPlanRepositoryVariables
Description copied from interface:CustomVariableProviderRepository
Return a map containing name->value mapping of the plan repository format variables.Null values will be filtered out so it's safe to put them in the map.
- Specified by:
getPlanRepositoryVariables
in interfaceCustomVariableProviderRepository
- Returns:
- Map with variable substitutions
-
getBranchRootUrl
public org.tmatesoft.svn.core.SVNURL getBranchRootUrl() throws org.tmatesoft.svn.core.SVNException- Throws:
org.tmatesoft.svn.core.SVNException
-
getOpenBranches
@NotNull public @NotNull List<VcsBranch> getOpenBranches(@Nullable @Nullable 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 interfaceBranchDetectionCapableRepository
- Returns:
List
of branch names. May be empty.- Throws:
RepositoryException
-
getLastCommit
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 interfaceBranchDetectionCapableRepository
- Returns:
- the last commit or null if N/A
- Throws:
RepositoryException
-
getFirstCommit
Description copied from interface:BranchDetectionCapableRepository
Retrieve the commit that created the Branch.- Specified by:
getFirstCommit
in interfaceBranchDetectionCapableRepository
- Returns:
- the first commit to the branch
- Throws:
RepositoryException
-
getVcsBranch
- Specified by:
getVcsBranch
in interfaceBranchAwareRepository
- Returns:
- the branch being used currently by this repository.
-
setVcsBranch
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 interfaceBranchAwareRepository
-
setVcsBranch
public void setVcsBranch(@NotNull @NotNull VcsBranch branch, @NotNull @NotNull org.apache.commons.configuration.HierarchicalConfiguration customConfiguration) -
getCacheId
public CacheId getCacheId(@NotNull @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 interfaceCachingAwareRepository
- Returns:
- the cache id of repository, null if the supplied operation cannot be cached
-
testConnection
@NotNull public @NotNull ErrorCollection testConnection(long timeout, @NotNull @NotNull TimeUnit unit) Description copied from interface:TestConnectionAwareRepository
Test connection to the repository within the given timeout. The method should stop executing after the given time elapses.- Specified by:
testConnection
in interfaceTestConnectionAwareRepository
- Parameters:
timeout
- the maximum time to waitunit
- the time unit of the timeout argument- Returns:
- Errors discovered during testing connection. Empty error collection should be returned if connection was successful. The errors should be translated to error messages, rather than field errors. Field errors are used by Bamboo to handle special cases.
-
isCachingSupportedFor
public boolean isCachingSupportedFor(@NotNull @NotNull CachingAwareRepository.CachableOperation cachableOperation) - Specified by:
isCachingSupportedFor
in interfaceCachingAwareRepository
- Returns:
- true if the repository supports generation of CacheIds for a given operation
-
getRepoPrefix
-
getTemporaryPrefix
-
getConfigConstant
-
getTemporaryConstant
-