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