mirror of
https://github.com/renovatebot/renovate.git
synced 2025-01-25 14:06:27 +00:00
Improve schema, only update direct inputs
This commit is contained in:
parent
46609cab40
commit
31094498b3
2 changed files with 9 additions and 9 deletions
|
@ -24,11 +24,6 @@ export function extractPackageFile(
|
||||||
|
|
||||||
const flakeLock = flakeLockParsed.data;
|
const flakeLock = flakeLockParsed.data;
|
||||||
|
|
||||||
if (flakeLock.version !== 7) {
|
|
||||||
logger.debug({ packageFile }, 'Unsupported flake lock version');
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
for (const depName of Object.keys(flakeLock.nodes ?? {})) {
|
for (const depName of Object.keys(flakeLock.nodes ?? {})) {
|
||||||
// the root input is a magic string for the entrypoint and only references other flake inputs
|
// the root input is a magic string for the entrypoint and only references other flake inputs
|
||||||
if (depName === 'root') {
|
if (depName === 'root') {
|
||||||
|
@ -40,6 +35,11 @@ export function extractPackageFile(
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// skip all locked nodes which are not in the flake.nix and cannot be updated
|
||||||
|
if (!(depName in (flakeLock.nodes['root'].inputs ?? []))) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
const flakeInput = flakeLock.nodes[depName];
|
const flakeInput = flakeLock.nodes[depName];
|
||||||
const flakeLocked = flakeInput.locked;
|
const flakeLocked = flakeInput.locked;
|
||||||
const flakeOriginal = flakeInput.original;
|
const flakeOriginal = flakeInput.original;
|
||||||
|
@ -52,7 +52,7 @@ export function extractPackageFile(
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
// indirect inputs cannot be updated via normal means
|
// indirect inputs cannot be reliable updated because they depend on the flake registry
|
||||||
if (flakeOriginal.type === 'indirect') {
|
if (flakeOriginal.type === 'indirect') {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
|
@ -32,7 +32,7 @@ export const OriginalInput = z.object({
|
||||||
});
|
});
|
||||||
|
|
||||||
export const NixInput = z.object({
|
export const NixInput = z.object({
|
||||||
inputs: z.record(z.string(), z.string()).optional(),
|
inputs: z.record(z.string(), z.string().or(z.array(z.string()))).optional(),
|
||||||
locked: LockedInput.optional(),
|
locked: LockedInput.optional(),
|
||||||
original: OriginalInput.optional(),
|
original: OriginalInput.optional(),
|
||||||
});
|
});
|
||||||
|
@ -40,8 +40,8 @@ export const NixInput = z.object({
|
||||||
export const NixFlakeLock = Json.pipe(
|
export const NixFlakeLock = Json.pipe(
|
||||||
z.object({
|
z.object({
|
||||||
nodes: z.record(z.string(), NixInput).optional(),
|
nodes: z.record(z.string(), NixInput).optional(),
|
||||||
root: z.string(),
|
root: z.literal('root').optional(),
|
||||||
version: z.number(),
|
version: z.literal(7),
|
||||||
}),
|
}),
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue