mirror of
https://github.com/renovatebot/renovate.git
synced 2025-05-12 23:51:55 +00:00
88 lines
3 KiB
TypeScript
88 lines
3 KiB
TypeScript
import is from '@sindresorhus/is';
|
|
import { ExternalHostError } from '../../../types/errors/external-host-error';
|
|
import { cache } from '../../../util/cache/package/decorator';
|
|
import { isValidLocalPath, readLocalFile } from '../../../util/fs';
|
|
import { HttpError } from '../../../util/http';
|
|
import { joinUrlParts } from '../../../util/url';
|
|
import { id as bazelVersioningId } from '../../versioning/bazel-module';
|
|
import { BzlmodVersion } from '../../versioning/bazel-module/bzlmod-version';
|
|
import { Datasource } from '../datasource';
|
|
import type { GetReleasesConfig, Release, ReleaseResult } from '../types';
|
|
import { BazelModuleMetadata } from './schema';
|
|
|
|
export class BazelDatasource extends Datasource {
|
|
static readonly id = 'bazel';
|
|
|
|
static readonly bazelCentralRepoUrl =
|
|
'https://raw.githubusercontent.com/bazelbuild/bazel-central-registry/main';
|
|
|
|
override readonly defaultRegistryUrls = [BazelDatasource.bazelCentralRepoUrl];
|
|
override readonly registryStrategy = 'hunt';
|
|
override readonly customRegistrySupport = true;
|
|
override readonly caching = true;
|
|
override readonly defaultVersioning = bazelVersioningId;
|
|
|
|
static packageMetadataPath(packageName: string): string {
|
|
return `/modules/${packageName}/metadata.json`;
|
|
}
|
|
|
|
constructor() {
|
|
super(BazelDatasource.id);
|
|
}
|
|
|
|
@cache({
|
|
namespace: `datasource-${BazelDatasource.id}`,
|
|
key: ({ registryUrl, packageName }: GetReleasesConfig) =>
|
|
`${registryUrl!}:${packageName}`,
|
|
})
|
|
async getReleases({
|
|
registryUrl,
|
|
packageName,
|
|
}: GetReleasesConfig): Promise<ReleaseResult | null> {
|
|
const path = BazelDatasource.packageMetadataPath(packageName);
|
|
const url = joinUrlParts(registryUrl!, path);
|
|
const result: ReleaseResult = { releases: [] };
|
|
try {
|
|
let metadata: BazelModuleMetadata;
|
|
const FILE_PREFIX = 'file://';
|
|
if (url.startsWith(FILE_PREFIX)) {
|
|
const filePath = url.slice(FILE_PREFIX.length);
|
|
if (!isValidLocalPath(filePath)) {
|
|
return null;
|
|
}
|
|
const fileContent = await readLocalFile(filePath, 'utf8');
|
|
if (!fileContent) {
|
|
return null;
|
|
}
|
|
metadata = BazelModuleMetadata.parse(JSON.parse(fileContent));
|
|
} else {
|
|
const response = await this.http.getJson(url, BazelModuleMetadata);
|
|
metadata = response.body;
|
|
}
|
|
|
|
result.releases = metadata.versions
|
|
.map((v) => new BzlmodVersion(v))
|
|
.sort(BzlmodVersion.defaultCompare)
|
|
.map((bv) => {
|
|
const release: Release = { version: bv.original };
|
|
if (is.truthy(metadata.yanked_versions?.[bv.original])) {
|
|
release.isDeprecated = true;
|
|
}
|
|
return release;
|
|
});
|
|
if (metadata.homepage) {
|
|
result.homepage = metadata.homepage;
|
|
}
|
|
} catch (err) {
|
|
if (err instanceof HttpError) {
|
|
if (err.response?.statusCode === 404) {
|
|
return null;
|
|
}
|
|
throw new ExternalHostError(err);
|
|
}
|
|
this.handleGenericErrors(err);
|
|
}
|
|
|
|
return result.releases.length ? result : null;
|
|
}
|
|
}
|