skip symlinks to directories when generating plugin manifest (#30721)

pull/30743/head
Dan Cech 5 years ago committed by GitHub
parent 52a8f2bf7e
commit 06061c8741
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
  1. 8
      packages/grafana-toolkit/src/plugins/manifest.ts

@ -13,7 +13,7 @@ async function* walk(dir: string, baseDir: string): AsyncGenerator<string, any,
} else if (d.isFile()) { } else if (d.isFile()) {
yield path.posix.relative(baseDir, entry); yield path.posix.relative(baseDir, entry);
} else if (d.isSymbolicLink()) { } else if (d.isSymbolicLink()) {
const realPath = fs.realpathSync(entry); const realPath = await (fs.promises as any).realpath(entry);
if (!realPath.startsWith(baseDir)) { if (!realPath.startsWith(baseDir)) {
throw new Error( throw new Error(
`symbolic link ${path.posix.relative( `symbolic link ${path.posix.relative(
@ -22,7 +22,11 @@ async function* walk(dir: string, baseDir: string): AsyncGenerator<string, any,
)} targets a file outside of the base directory: ${baseDir}` )} targets a file outside of the base directory: ${baseDir}`
); );
} }
yield path.posix.relative(baseDir, entry); // if resolved symlink target is a file include it in the manifest
const stats = await (fs.promises as any).stat(realPath);
if (stats.isFile()) {
yield path.posix.relative(baseDir, entry);
}
} }
} }
} }

Loading…
Cancel
Save