-
-
Notifications
You must be signed in to change notification settings - Fork 18
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Ignoring node_gyp_bins
directory is not working, causes signed & notarized apps not to pass gatekeeper
#1444
Comments
👋 Thanks for opening your first issue here! If you have a question about using Electron Packager, read the support docs. If you're reporting a 🐞 bug, please make sure you include steps to reproduce it. Development and issue triage is community-driven, so please be patient and we will get back to you as soon as we can. To help make it easier for us to investigate your issue, please follow the contributing guidelines. |
@samdesota Thank you for the clear issue report! In Forge, the Rebuild step happens in an I would hang onto that |
@samdesota Any chance you could document your |
@jagthedrummer Maybe this article can help ? |
I ended up working around it by pinning "resolutions": {
"**/**/fsevents": "^1.2.9",
"**/**/node-gyp": "^8.4.0"
} |
@jagthedrummer I appreciate your patience with this, I know you solved it in another way, but still posting in case is useful for somebody else. In module.exports = {
packagerConfig: {
},
plugins: [
],
makers: [
],
hooks: {
packageAfterPrune(config, buildPath) {
if (process.platform === 'darwin') {
const dirs = glob.sync(
path.join(buildPath, 'node_modules/**/node_gyp_bins'),
{
onlyDirectories: true,
}
);
for (const directory of dirs) {
fs.rmdirSync(directory, { recursive: true, force: true });
}
}
},
},
}; |
Has a year passed, and still there's no solution? |
Preflight Checklist
Issue Details
Electron Packager 17.1.1
Node v16.17.1
Host Operating system: darwin 21.6.0 (x64)
21.2.2
macOS 12.6 arm64
Expected Behavior
macOS's Gatekeeper /
spctl
doesn't like symlinks in app bundles with invalid destinations. Node-gyp creates such a sym link to the build machines python installation under node_modules, which gets bundled into your app if you're using a native module built with node-gyp.This issue was already addressed with #1391, however this solution is not working. Despite ignoring it,
node_gyp_bins
ends up in the output .app when using electron packager v17.1.1 (in my case, with electron forge v6.0.1). I also attempted to add the file / directory to theignore
option, but the file persists.So expected behavior is that
node_gyp_bins
is excluded from the outputActual Behavior
node_gyp_bins
directories with the troublemakerpython3
symlink is included in the output app bundle, therefore a signed & notarized app fails to pass gatekeeper.The only workaround I've found is to delete the directory manually in the
afterPrune
hook.To Reproduce
Minimal repro here: https://github.com/samdesota/electron-packager-symlink-issue
I used create-electron-app with default options to create this, and the issue persists. Used the dependency
node-mac-permissions
to demonstrate the issue.The text was updated successfully, but these errors were encountered: