Table of Contents
API Documentation: | IvyArtifactRepository |
---|
An artifact repository which uses an Ivy format to store artifacts and meta-data.
When used to resolve metadata and artifact files, all available patterns will be searched.
When used to upload metadata and artifact files, only a single, primary pattern will be used:
- If a URL is specified via
IvyArtifactRepository.setUrl(java.lang.Object)
then that URL will be used for upload, combined with the appliedIvyArtifactRepository.layout(java.lang.String)
. - If no URL has been specified but additional patterns have been added via
IvyArtifactRepository.artifactPattern(java.lang.String)
orIvyArtifactRepository.ivyPattern(java.lang.String)
, then the first defined pattern will be used.
Repositories of this type are created by the RepositoryHandler.ivy(org.gradle.api.Action)
group of methods.
Property | Description |
allowInsecureProtocol | Specifies whether it is acceptable to communicate with a repository over an insecure HTTP connection. |
authentication | The authentication schemes for this repository. |
credentials | The credentials of the specified type used to authenticate with this repository. |
name | The name for this repository. A name must be unique amongst a repository set. A default name is provided for the repository if none is provided. |
resolve | The meta-data provider used when resolving artifacts from this repository. The provider is responsible for locating and interpreting the meta-data for the modules and artifacts contained in this repository. Using this provider, you can fine tune how this resolution happens. |
url | The base URL of this repository. |
Method | Description |
artifactPattern(pattern) | Adds an independent pattern that will be used to locate artifact files in this repository. This pattern will be used to locate ivy files as well, unless a specific
ivy pattern is supplied via |
authentication(action) | Configures the authentication schemes for this repository. |
credentials(credentialsType) | Configures the credentials for this repository that will be provided by the build. |
credentials(credentialsType, action) | Configures the credentials for this repository using the supplied action. |
credentials(action) | Configures the username and password credentials for this repository using the supplied action. |
ivyPattern(pattern) | Adds an independent pattern that will be used to locate ivy files in this repository.
If this pattern is not a fully-qualified URL, it will be interpreted as a file relative to the project directory.
It is not interpreted relative the URL specified in |
layout(layoutName) | Specifies how the items of the repository are organized. |
metadataSources(configureAction) | Configures the metadata sources for this repository. This method will replace any previously configured sources of metadata. |
patternLayout(config) | Specifies how the items of the repository are organized. |
Specifies whether it is acceptable to communicate with a repository over an insecure HTTP connection.
For security purposes this intentionally requires a user to opt-in to using insecure protocols on case by case basis.
Gradle intentionally does not offer a global system/gradle property that allows a universal disable of this check.
Allowing communication over insecure protocols allows for a man-in-the-middle to impersonate the intended server, and gives an attacker the ability to serve malicious executable code onto the system.
See also: Want to take over the Java ecosystem? All you need is a MITM!
AuthenticationContainer
authentication
(read-only)
The authentication schemes for this repository.
The credentials of the specified type used to authenticate with this repository.
If no credentials have been assigned to this repository, an empty set of credentials of the specified type is assigned to this repository and returned.
String
name
The name for this repository. A name must be unique amongst a repository set. A default name is provided for the repository if none is provided.
The name is used in logging output and error reporting to point to information related to this repository.
The meta-data provider used when resolving artifacts from this repository. The provider is responsible for locating and interpreting the meta-data for the modules and artifacts contained in this repository. Using this provider, you can fine tune how this resolution happens.
URI
url
The base URL of this repository.
void
artifactPattern
(String
pattern)
Adds an independent pattern that will be used to locate artifact files in this repository. This pattern will be used to locate ivy files as well, unless a specific
ivy pattern is supplied via IvyArtifactRepository.ivyPattern(java.lang.String)
.
If this pattern is not a fully-qualified URL, it will be interpreted as a file relative to the project directory.
It is not interpreted relative the URL specified in IvyArtifactRepository.setUrl(java.lang.Object)
.
Patterns added in this way will be in addition to any layout-based patterns added via IvyArtifactRepository.setUrl(java.lang.Object)
.
void
authentication
(Action
<? super AuthenticationContainer
>
action)
Action
<? super AuthenticationContainer
>Configures the authentication schemes for this repository.
This method executes the given action against the AuthenticationContainer
for this project. The AuthenticationContainer
is passed to the closure as the closure's delegate.
If no authentication schemes have been assigned to this repository, a default set of authentication schemes are used based on the repository's transport scheme.
repositories {
maven {
url "${url}"
authentication {
basic(BasicAuthentication)
}
}
}
Supported authentication scheme types extend Authentication
.
void
credentials
(Class
<? extends Credentials
>
credentialsType)
Class
<? extends Credentials
>Configures the credentials for this repository that will be provided by the build.
Credentials will be provided from Gradle properties based on the repository name. If credentials for this repository can not be resolved and the repository will be used in the current build, then the build will fail to start and point to the missing configuration.
repositories {
maven {
url "${url}"
credentials(PasswordCredentials)
}
}
The following credential types are currently supported for the credentialsType
argument:
Configures the credentials for this repository using the supplied action.
If no credentials have been assigned to this repository, an empty set of credentials of the specified type will be assigned to this repository and given to the configuration action. If credentials have already been specified for this repository, they will be passed to the given configuration action.
repositories { maven { url "${url}" credentials(AwsCredentials) { accessKey "myAccessKey" secretKey "mySecret" } } }
The following credential types are currently supported for the credentialsType
argument:
void
credentials
(Action
<? super PasswordCredentials
>
action)
Action
<? super PasswordCredentials
>Configures the username and password credentials for this repository using the supplied action.
If no credentials have been assigned to this repository, an empty set of username and password credentials is assigned to this repository and passed to the action.
repositories { maven { url "${url}" credentials { username = 'joe' password = 'secret' } } }
void
ivyPattern
(String
pattern)
Adds an independent pattern that will be used to locate ivy files in this repository.
If this pattern is not a fully-qualified URL, it will be interpreted as a file relative to the project directory.
It is not interpreted relative the URL specified in IvyArtifactRepository.setUrl(java.lang.Object)
.
Patterns added in this way will be in addition to any layout-based patterns added via IvyArtifactRepository.setUrl(java.lang.Object)
.
void
layout
(String
layoutName)
Specifies how the items of the repository are organized.
Recognised values are as follows:
A Repository Layout that applies the following patterns:
- Artifacts:
$baseUri/
[organisation]/[module]/[revision]/[artifact]-[revision](-[classifier])(.[ext])
- Ivy:
$baseUri/
[organisation]/[module]/[revision]/ivy-[revision].xml
A Repository Layout that applies the following patterns:
- Artifacts:
$baseUri/
[organisation]/[module]/[revision]/[artifact]-[revision](-[classifier])(.[ext])
- Ivy:
$baseUri/
[organisation]/[module]/[revision]/ivy-[revision].xml
Following the Maven convention, the 'organisation' value is further processed by replacing '.' with '/'.
void
metadataSources
(Action
<? super MetadataSources
>
configureAction)
Action
<? super MetadataSources
>Configures the metadata sources for this repository. This method will replace any previously configured sources of metadata.
void
patternLayout
(Action
<? super IvyPatternRepositoryLayout
>
config)
Action
<? super IvyPatternRepositoryLayout
>Specifies how the items of the repository are organized.
The layout is configured with the supplied closure.
repositories { ivy { patternLayout { artifact '[module]/[revision]/[artifact](.[ext])' ivy '[module]/[revision]/ivy.xml' } } }
The available pattern tokens are listed as part of Ivy's Main Concepts documentation.