SSH Resolver

Tag

ssh

Handle latest

yes

Handle publish

yes

[since 1.4]

This resolver can be used when your Ivy repository is located on a server accessible via SSH. The secured nature of SSH and its widespread implementation on most *nix servers makes this resolver a very good candidate in an enterprise environment.

If your server supports SFTP, you can consider using the SFTP resolver.

Internally this resolver shares most of its behaviour with the SFTP resolver, so refer to its documentation for details.

Attributes

This resolver shares the common attributes of standard resolvers.

Attribute Description Required

user

The username to provide as credential

No, defaults to username given on the patterns, or prompt if none is set

userPassword

The password to provide as credential

No, defaults to password given on the patterns, or prompt if none is set

keyFile

Path to the keyfile to use for authentication

No, defaults to username/password authentication

keyFilePassword

the password used to protect the key file

No, will prompt for password if keyFile authentication is used and if it is password encrypted

host

The host to connect to

No, defaults to host given on the patterns, fail if none is set

port

The port to connect to

No, defaults to 22

sshConfig

Path to an OpenSSH-style config file containing additional configuration

No

publishPermissions

A four digit string (e.g., 0644, see "man chmod", "man open") specifying the permissions of the published files. (since 2.0)

No, defaults to scp standard behaviour

Child elements

Element Description Cardinality

ivy

Defines a pattern for Ivy files, using the pattern attribute.

0..n

artifact

Defines a pattern for artifacts, using the pattern attribute.

1..n

Example

<ssh user="myuser" host="myhost.com">
  <ivy pattern="/path/to/ivy/[module]/ivy.xml"/>
  <artifact pattern="/path/to/[organisation]/[module]/[artifact].[ext]"/>
</ssh>

Will connect to myhost.com using myuser and prompt for the password.


<ssh keyFile="path/to/key/file" keyFilePassword="${password}">
  <ivy pattern="ssh://user:geheim@yourserver.com:8022/path/to/repos/[module]/[revision]/ivy.xml"/>
  <artifact pattern="ssh://user:geheim@myserver.com:8022/path/to/my/repos/[artifact].[ext]"/>
</ssh>

Will connect to yourserver.com on port 8022 with user geheim and use path/to/key/file for keyFile and the value of password variable for keyFilePassword authentication for Ivy files, and to myserver.com on port 8022 using user geheim with the same keyFile/keyFilePassword pair for the artifacts.

<ssh host="myhost" sshConfig="/path/to/.ssh/config">
  <ivy pattern="/path/to/ivy/[module]/ivy.xml"/>
  <artifact pattern="/path/to/[organisation]/[module]/[artifact].[ext]"/>
</ssh>

Will connect to the host named by myhost according to the config file in /path/to/.ssh/config, using the hostname, username, and optionally IdentityFile specified in the config section "Host myhost". For example, if the corresponding Host section contains "Hostname yourserver.com" and "User myremoteusername", it will connect to yourserver.com using username myremoteusername.