//MRELEASE-76
scmRepo.setPersistCheckout( false );
if ( repository.getProviderRepository() instanceof ScmProviderRepositoryWithHost )
{
ScmProviderRepositoryWithHost repositoryWithHost =
(ScmProviderRepositoryWithHost) repository.getProviderRepository();
String host = repositoryWithHost.getHost();
int port = repositoryWithHost.getPort();
if ( port > 0 )
{
host += ":" + port;
}
if ( settings != null )
{
// TODO: this is a bit dodgy - id is not host, but since we don't have a <host> field we make an assumption
Server server = settings.getServer( host );
if ( server != null )
{
if ( username == null )
{
username = server.getUsername();
}
if ( password == null )
{
password = decrypt( server.getPassword(), host );
}
if ( privateKey == null )
{
privateKey = server.getPrivateKey();
}
if ( passphrase == null )
{
passphrase = decrypt( server.getPassphrase(), host );
}
}
}
}
if ( !StringUtils.isEmpty( username ) )
{
scmRepo.setUser( username );
}
if ( !StringUtils.isEmpty( password ) )
{
scmRepo.setPassword( password );
}
if ( scmRepo instanceof ScmProviderRepositoryWithHost )
{
ScmProviderRepositoryWithHost repositoryWithHost = (ScmProviderRepositoryWithHost) scmRepo;
if ( !StringUtils.isEmpty( privateKey ) )
{
repositoryWithHost.setPrivateKey( privateKey );
}
if ( !StringUtils.isEmpty( passphrase ) )
{
repositoryWithHost.setPassphrase( passphrase );
}
}
if ( "svn".equals( repository.getProvider() ) )
{