renovate/lib/modules/datasource
Sebastian Poxhofer 19259a0383 feat!: categories (#16534)
Closes #13953

Co-authored-by: Rhys Arkins <rhys@arkins.net>
Co-authored-by: Michael Kriese <michael.kriese@visualon.de>
Co-authored-by: HonkingGoose <34918129+HonkingGoose@users.noreply.github.com>

BREAKING CHANGE: languages are now called categories instead
2023-07-04 19:21:52 +02:00
..
__snapshots__ test: use jest v29 (#17151) 2022-08-16 14:22:29 +02:00
artifactory refactor(datasource): use packageName and not depName for datasource lookups (#20474) 2023-03-10 09:34:40 +01:00
aws-machine-image chore: migrate to structuredClone (#20885) 2023-04-27 05:06:22 +00:00
aws-rds chore: migrate to structuredClone (#20885) 2023-04-27 05:06:22 +00:00
azure-bicep-resource refactor(azure-bicep-resource): Refactor schema usage (#21402) 2023-04-11 14:41:41 +00:00
azure-pipelines-tasks feat(datasource/azure-pipeline-tasks): read tasks from cdn (#22864) 2023-06-21 05:42:10 +00:00
bazel feat: add bazel datasource (#21733) 2023-04-25 20:08:26 +00:00
bitbucket-tags refactor(bitbucket): use paginated api for tags (#22336) 2023-05-22 05:54:25 +00:00
cdnjs feat: Use klona library for deep clone (#22979) 2023-06-26 17:21:29 +00:00
clojure refactor(datasource): use packageName and not depName for datasource lookups (#20474) 2023-03-10 09:34:40 +01:00
conan feat(datasource/conan): add sourceUrl when artifactory is used (#22656) 2023-06-15 15:56:54 +00:00
conda refactor(datasource): use packageName and not depName for datasource lookups (#20474) 2023-03-10 09:34:40 +01:00
cpan fix(datasource/cpan): add module.authorized condition for querying releases (#22445) 2023-05-27 03:43:46 +00:00
crate feat(datasource/crate): add sparse registry support (#21187) 2023-04-05 12:30:35 +00:00
dart refactor(datasource): use packageName and not depName for datasource lookups (#20474) 2023-03-10 09:34:40 +01:00
dart-version refactor(datasource): use packageName and not depName for datasource lookups (#20474) 2023-03-10 09:34:40 +01:00
deno refactor(schema): Enhanced "loose" collections (#21541) 2023-04-21 08:25:48 +00:00
docker feat(datasource/conan): add sourceUrl when artifactory is used (#22656) 2023-06-15 15:56:54 +00:00
dotnet-version refactor(schema): Enhanced "loose" collections (#21541) 2023-04-21 08:25:48 +00:00
endoflife-date test(endoflife): Mock time (#22575) 2023-06-04 15:06:43 +00:00
flutter-version feat(datasource)!: default to the central default versioning (#23020) 2023-07-04 19:21:52 +02:00
galaxy refactor(datasource): use packageName and not depName for datasource lookups (#20474) 2023-03-10 09:34:40 +01:00
galaxy-collection feat: Use klona library for deep clone (#22979) 2023-06-26 17:21:29 +00:00
git-refs test(git-refs/git-tags): add types to mocked objects (#23096) 2023-07-03 19:20:06 +00:00
git-tags test(git-refs/git-tags): add types to mocked objects (#23096) 2023-07-03 19:20:06 +00:00
github-release-attachments feat(datasource/github-releases)!: digest computation use git tag, not file digest (#20178) 2023-03-10 09:34:40 +01:00
github-releases feat(datasource/github-releases)!: digest computation use git tag, not file digest (#20178) 2023-03-10 09:34:40 +01:00
github-tags feat(github-tags): enable datasource for registry hunting (#23041) 2023-06-29 15:29:57 +00:00
gitlab-packages refactor(datasource): use packageName and not depName for datasource lookups (#20474) 2023-03-10 09:34:40 +01:00
gitlab-releases feat(versioning)!: default to semver-coerced instead of semver (#20573) 2023-03-10 09:34:41 +01:00
gitlab-tags feat(versioning)!: default to semver-coerced instead of semver (#20573) 2023-03-10 09:34:41 +01:00
go feat!: categories (#16534) 2023-07-04 19:21:52 +02:00
golang-version refactor: exactOptionalPropertyTypes (#20761) 2023-03-19 16:09:46 +00:00
gradle-version refactor(datasource): use packageName and not depName for datasource lookups (#20474) 2023-03-10 09:34:40 +01:00
helm refactor: replace test.each with it.each (#21859) 2023-04-28 04:33:15 +00:00
hermit fix(regex): don’t escape forward slash in fileMatch (#19314) 2023-03-10 09:34:39 +01:00
hex refactor(datasource): use packageName and not depName for datasource lookups (#20474) 2023-03-10 09:34:40 +01:00
hexpm-bob feat(datasource)!: default to the central default versioning (#23020) 2023-07-04 19:21:52 +02:00
java-version refactor(datasource): use packageName and not depName for datasource lookups (#20474) 2023-03-10 09:34:40 +01:00
jenkins-plugins feat: Clone objects via wrapper (#22970) 2023-06-27 13:09:59 +00:00
kubernetes-api chore: migrate to structuredClone (#20885) 2023-04-27 05:06:22 +00:00
maven chore(docs/maven): document how to specify project homepage in pom.xml (#22889) 2023-06-20 09:40:21 +00:00
node-version feat(datasource): rename node -> node-version (#21149) 2023-04-12 13:43:59 +00:00
npm feat(npm): support constraintsFiltering=strict (#22447) 2023-07-04 19:21:52 +02:00
nuget refactor(datasource): use packageName and not depName for datasource lookups (#20474) 2023-03-10 09:34:40 +01:00
orb refactor(datasource): use packageName and not depName for datasource lookups (#20474) 2023-03-10 09:34:40 +01:00
packagist fix(datasource/packagist): Use serializable type for availablePackages (#23117) 2023-07-03 17:54:20 +00:00
pod chore: use node: protocol imports (#21181) 2023-03-28 21:05:36 +00:00
puppet-forge refactor(datasource): use packageName and not depName for datasource lookups (#20474) 2023-03-10 09:34:40 +01:00
pypi feat(manager/pep621): implement manager (#22082) 2023-05-15 07:51:05 +00:00
repology feat(versioning)!: default to semver-coerced instead of semver (#20573) 2023-03-10 09:34:41 +01:00
ruby-version refactor: Clear distinction between generic and HttpError handlers (#22576) 2023-06-05 03:39:27 +00:00
rubygems fix(rubygems): Return fallback result for metadata cache (#22907) 2023-06-21 09:47:06 +00:00
sbt-package refactor(datasource): use packageName and not depName for datasource lookups (#20474) 2023-03-10 09:34:40 +01:00
sbt-plugin refactor(datasource): use packageName and not depName for datasource lookups (#20474) 2023-03-10 09:34:40 +01:00
terraform-module refactor: Clear distinction between generic and HttpError handlers (#22576) 2023-06-05 03:39:27 +00:00
terraform-provider refactor(datasource): use packageName and not depName for datasource lookups (#20474) 2023-03-10 09:34:40 +01:00
api.ts feat(datasource/endoflife-date): add endoflife.date datasource (#21994) 2023-06-01 16:41:39 +00:00
common.spec.ts feat(datasource/conan): add sourceUrl when artifactory is used (#22656) 2023-06-15 15:56:54 +00:00
common.ts feat(datasource/conan): add sourceUrl when artifactory is used (#22656) 2023-06-15 15:56:54 +00:00
datasource.spec.ts test: add new wrapper for partial (#20618) 2023-02-25 06:46:32 +00:00
datasource.ts refactor: Clear distinction between generic and HttpError handlers (#22576) 2023-06-05 03:39:27 +00:00
index.spec.ts feat(datasource)!: default to the central default versioning (#23020) 2023-07-04 19:21:52 +02:00
index.ts feat(datasource)!: default to the central default versioning (#23020) 2023-07-04 19:21:52 +02:00
metadata-manual.ts fix: Add changelogUrl for gradle-semver-plugin (#20441) 2023-05-16 05:01:16 +00:00
metadata.spec.ts refactor: replace test.each with it.each (#21859) 2023-04-28 04:33:15 +00:00
metadata.ts feat(helm): improve subdirectory support (#19181) 2022-12-09 12:48:20 +01:00
readme.md fix(datasource): rename adoptium-java to java-version (#20245) 2023-02-13 07:54:20 +00:00
types.ts refactor(datasource): Use Result utility class for lookups (#23067) 2023-06-30 17:46:51 +00:00

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 java-version datasource as a reference.

Add the datasource to the API in api.ts so that the new datasource is usable. If you find 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 applicable
  • sourceUrl: 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 same
  • changelogUrl: a URL pointing to the package's Changelog (could be a Markdown file, for example). If not present then Renovate will search the sourceUrl for a changelog file.
  • tags: an object mapping tag -> version, e.g. tags: { latest: '3.0.0' }. This is only used by the followTags 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 as getReleases
  • 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.