0
0
Fork 0
mirror of https://github.com/renovatebot/renovate.git synced 2025-02-28 18:44:03 +00:00
renovatebot_renovate/lib/modules/manager/devbox/artifacts.ts
Will Brennan 62cb77064a
feat(manager): add devbox manager module (#33638)
Co-authored-by: Michael Kriese <michael.kriese@gmx.de>
2025-01-31 11:33:18 +00:00

82 lines
2.1 KiB
TypeScript

import is from '@sindresorhus/is';
import { logger } from '../../../logger';
import { exec } from '../../../util/exec';
import type { ExecOptions } from '../../../util/exec/types';
import { getSiblingFileName, readLocalFile } from '../../../util/fs';
import type { UpdateArtifact, UpdateArtifactsResult } from '../types';
export async function updateArtifacts(
updateConfig: UpdateArtifact,
): Promise<UpdateArtifactsResult[] | null> {
const lockFileName = getSiblingFileName(
updateConfig.packageFileName,
'devbox.lock',
);
const existingLockFileContent = await readLocalFile(lockFileName, 'utf8');
if (!existingLockFileContent) {
logger.debug('No devbox.lock found');
return null;
}
const execOptions: ExecOptions = {
cwdFile: updateConfig.packageFileName,
toolConstraints: [
{
toolName: 'devbox',
constraint: updateConfig.config.constraints?.devbox,
},
],
docker: {},
userConfiguredEnv: updateConfig.config.env,
};
let cmd = '';
if (
updateConfig.config.isLockFileMaintenance ||
updateConfig.config.updateType === 'lockFileMaintenance'
) {
cmd += 'devbox update';
} else if (is.nonEmptyArray(updateConfig.updatedDeps)) {
cmd += 'devbox install';
} else {
logger.trace('No updated devbox packages - returning null');
return null;
}
const oldLockFileContent = await readLocalFile(lockFileName);
if (!oldLockFileContent) {
logger.trace(`No ${lockFileName} found`);
return null;
}
try {
await exec(cmd, execOptions);
const newLockFileContent = await readLocalFile(lockFileName);
if (
!newLockFileContent ||
Buffer.compare(oldLockFileContent, newLockFileContent) === 0
) {
return null;
}
logger.trace('Returning updated devbox.lock');
return [
{
file: {
type: 'addition',
path: lockFileName,
contents: newLockFileContent,
},
},
];
} catch (err) {
logger.warn({ err }, 'Error updating devbox.lock');
return [
{
artifactError: {
lockFile: lockFileName,
stderr: err.message,
},
},
];
}
}