mirror of
https://github.com/renovatebot/renovate.git
synced 2025-01-27 05:09:37 +00:00
c3958c9bd6
Co-authored-by: Sebastian Poxhofer <secustor@users.noreply.github.com> Co-authored-by: Rhys Arkins <rhys@arkins.net> Co-authored-by: Michael Kriese <michael.kriese@visualon.de> Co-authored-by: Sergei Zharinov <zharinov@users.noreply.github.com> Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com> Co-authored-by: Aleksandr Mezin <mezin.alexander@gmail.com> Co-authored-by: Jasmin Müller <9011011+jazzlyn@users.noreply.github.com>
91 lines
2.8 KiB
TypeScript
91 lines
2.8 KiB
TypeScript
import { joinUrlParts } from '../../../util/url';
|
|
|
|
/**
|
|
* Extracts the base release URL from a package URL by removing the last two path segments.
|
|
*
|
|
* @param basePackageUrl - The base URL of the package.
|
|
* @returns The base release URL.
|
|
*
|
|
* @example
|
|
* // Returns 'https://deb.debian.org/debian/dists/bullseye'
|
|
* getBaseReleaseUrl('https://deb.debian.org/debian/dists/bullseye/main/binary-amd64');
|
|
*/
|
|
export function getBaseReleaseUrl(basePackageUrl: string): string {
|
|
const urlParts = basePackageUrl.split('/');
|
|
return urlParts.slice(0, urlParts.length - 2).join('/');
|
|
}
|
|
|
|
/**
|
|
* Constructs the component URLs from the given registry URL.
|
|
*
|
|
* @param registryUrl - The base URL of the registry.
|
|
* @returns An array of component URLs.
|
|
* @throws Will throw an error if required parameters are missing from the URL.
|
|
*/
|
|
export function constructComponentUrls(registryUrl: string): string[] {
|
|
const REQUIRED_PARAMS = ['components', 'binaryArch'];
|
|
const OPTIONAL_PARAMS = ['release', 'suite'];
|
|
|
|
try {
|
|
const url = new URL(registryUrl);
|
|
validateUrlAndParams(url, REQUIRED_PARAMS);
|
|
|
|
const release = getReleaseParam(url, OPTIONAL_PARAMS);
|
|
const binaryArch = url.searchParams.get('binaryArch');
|
|
const components = url.searchParams.get('components')!.split(',');
|
|
|
|
// Clean up URL search parameters for constructing new URLs
|
|
[...REQUIRED_PARAMS, ...OPTIONAL_PARAMS].forEach((param) =>
|
|
url.searchParams.delete(param),
|
|
);
|
|
|
|
return components.map((component) =>
|
|
joinUrlParts(
|
|
url.toString(),
|
|
`dists`,
|
|
release,
|
|
component,
|
|
`binary-${binaryArch}`,
|
|
),
|
|
);
|
|
} catch (error) {
|
|
throw new Error(
|
|
`Invalid deb repo URL: ${registryUrl} - see documentation: ${error.message}`,
|
|
);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Validates that the required parameters are present in the URL.
|
|
*
|
|
* @param url - The URL to validate.
|
|
* @param requiredParams - The list of required query parameters.
|
|
* @throws Will throw an error if a required parameter is missing.
|
|
*/
|
|
function validateUrlAndParams(url: URL, requiredParams: string[]): void {
|
|
requiredParams.forEach((param) => {
|
|
if (!url.searchParams.has(param)) {
|
|
throw new Error(`Missing required query parameter '${param}'`);
|
|
}
|
|
});
|
|
}
|
|
|
|
/**
|
|
* Retrieves the release parameter from the URL.
|
|
*
|
|
* @param url - The URL to retrieve the release parameter from.
|
|
* @param optionalParams - The list of optional query parameters.
|
|
* @returns The value of the release parameter.
|
|
* @throws Will throw an error if none of the optional parameters are found.
|
|
*/
|
|
function getReleaseParam(url: URL, optionalParams: string[]): string {
|
|
for (const param of optionalParams) {
|
|
const paramValue = url.searchParams.get(param);
|
|
if (paramValue !== null) {
|
|
return paramValue;
|
|
}
|
|
}
|
|
throw new Error(
|
|
`Missing one of ${optionalParams.join(', ')} query parameter`,
|
|
);
|
|
}
|