.. | ||
__snapshots__ | ||
adoptium-java | ||
artifactory | ||
aws-machine-image | ||
bitbucket-tags | ||
cdnjs | ||
clojure | ||
conan | ||
conda | ||
crate | ||
dart | ||
docker | ||
galaxy | ||
galaxy-collection | ||
git-refs | ||
git-tags | ||
github-releases | ||
github-tags | ||
gitlab-packages | ||
gitlab-releases | ||
gitlab-tags | ||
go | ||
golang-version | ||
gradle-version | ||
helm | ||
hex | ||
jenkins-plugins | ||
maven | ||
node | ||
npm | ||
nuget | ||
orb | ||
packagist | ||
pod | ||
pypi | ||
repology | ||
ruby-version | ||
rubygems | ||
sbt-package | ||
sbt-plugin | ||
terraform-module | ||
terraform-provider | ||
api.ts | ||
common.ts | ||
datasource.spec.ts | ||
datasource.ts | ||
index.spec.ts | ||
index.ts | ||
metadata-manual.ts | ||
metadata.spec.ts | ||
metadata.ts | ||
readme.md | ||
types.ts |
Datasources
Datasources are used in Renovate primarily to fetch released versions of packages.
Follow the class-based programming style
New datasources must follow the class-based programming style.
Use the adoptium-java
datasource as a reference.
Add the datasource to the API in api.ts
so that the new datasource is usable. If you encounter Pending mocks!
errors in the jest tests and your mocked URLs are correct, ensure the datasource is correctly registered.
getReleases
The minimum exported interface for a datasource is a function called getReleases
that takes a lookup config as input.
The config has:
packageName
: the package's full name including scope if present (e.g.@foo/bar
)registryUrls
: an array of registry Urls to try
getReleases
should return an object having:
releases
: an array of strings of matched versions. This is the only mandatory field.deprecationMessage
: a string description of the package's deprecation notice, if applicablesourceUrl
: a HTTP URL pointing to the source code (e.g. on GitHub)homepage
: a HTTP URL for the package's homepage. Ideally should be empty if the homepage and sourceUrl are the samechangelogUrl
: a URL pointing to the package's Changelog (could be a Markdown file, for example). If not present then Renovate will search thesourceUrl
for a changelog file.tags
: an object mapping tag -> version, e.g.tags: { latest: '3.0.0' }
. This is only used by thefollowTags
function.
getDigest
Datasources that support the concept of digests (e.g. Docker digests and Git commit hashes) also can export a getDigest
function.
The getDigest
function has two inputs:
config
: the Renovate config for the package being updated, has the same fields asgetReleases
newValue
: the version or value to retrieve the digest for
The getDigest
function returns a string output representing the digest value. If none is found then a return value of null
should be returned.