add a way to disable sandbox if we cannot use it without crashing
parent
8d45ea2742
commit
3e020d4a91
@ -0,0 +1,43 @@
|
||||
const path = require('path');
|
||||
const fs = require('fs');
|
||||
const util = require('util');
|
||||
|
||||
const renameAsync = util.promisify(fs.rename);
|
||||
const unlinkAsync = util.promisify(fs.unlink);
|
||||
|
||||
module.exports = async function (context) {
|
||||
// Replace the app launcher on linux only.
|
||||
if (process.platform !== 'linux') {
|
||||
return;
|
||||
}
|
||||
const isAppImage = context.targets.find(target => target.name === 'appImage')
|
||||
if (!isAppImage) {
|
||||
return
|
||||
}
|
||||
// eslint-disable-next-line no-console
|
||||
console.log('afterPack hook triggered', context);
|
||||
|
||||
const executableName = context.packager.executableName;
|
||||
const sourceExecutable = path.join(context.appOutDir, executableName);
|
||||
const targetExecutable = path.join(
|
||||
context.appOutDir,
|
||||
`${executableName}-bin`
|
||||
);
|
||||
const launcherScript = path.join(
|
||||
context.appOutDir,
|
||||
'resources',
|
||||
'launcher-script.sh'
|
||||
);
|
||||
const chromeSandbox = path.join(context.appOutDir, 'chrome-sandbox');
|
||||
|
||||
return Promise.all([
|
||||
// rename session-desktop to session-desktop-bin
|
||||
renameAsync(sourceExecutable, targetExecutable),
|
||||
|
||||
// rename launcher script to session-desktop
|
||||
renameAsync(launcherScript, sourceExecutable),
|
||||
|
||||
// remove the chrome-sandbox file since we explicitly disable it
|
||||
unlinkAsync(chromeSandbox),
|
||||
]);
|
||||
};
|
@ -0,0 +1,6 @@
|
||||
#!/usr/bin/env bash
|
||||
set -ex
|
||||
|
||||
UNPRIVILEGED_USERNS_ENABLED=$(cat /proc/sys/kernel/unprivileged_userns_clone 2>/dev/null)
|
||||
SCRIPT_DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
|
||||
exec "$SCRIPT_DIR/session-desktop-bin" "$([[ $UNPRIVILEGED_USERNS_ENABLED == 0 ]] && echo '--no-sandbox')" "$@"
|
Loading…
Reference in New Issue