Function makeSwingsetController make Swingset Controller ( kernelStorage ? , deviceEndowments ? , runtimeOptions ? ) : Promise < { debug : { addDeviceHook : ( ( deviceName : any , hookName : any , hook : any ) => void ) ; } ; injectQueuedUpgradeEvents : ( ( ) => void ) ; slogDuration : ( < T , A > ( labels : readonly [ undefined | string , string ] , startProps : SlogDurationProps , fn : ( ( finish : ( ( extraProps ?: SlogDurationProps ) => void ) , ... args : A ) => T | Promise < T > ) , ... args : unknown [] & A ) => Promise < T > ) ; validateAndInstallBundle : ( ( bundle : EndoZipBase64Bundle , allegedBundleID ??: string ) => Promise < string > ) ; writeSlogObject : ( ( obj : SlogProps ) => void ) ; changeKernelOptions ( options : any ) : void ; deviceNameToID ( deviceName : any ) : undefined | string ; dump ( ) : { acceptanceQueue : any [] ; gcActions : any [] ; kernelTable : any [] ; log : string [] ; objects : ( undefined | string | number ) [] [] ; promises : ( { decider : undefined | string ; id : string ; policy : string ; queue : string [] ; refCount : number ; state : "unresolved" ; subscribers : string [] ; } | { data : SwingSetCapData ; id : string ; refCount : number ; state : "rejected" | "fulfilled" ; } ) [] ; reapQueue : any ; runQueue : any [] ; vatTables : { state : { transcript : [ number , TranscriptEntry ] [] ; } ; vatID : string ; } [] ; } ; dumpLog ( idx : any ) : string [] ; getActivityhash ( ) : string ; getStats ( ) : Record < string , number > ; getStatus ( ) : { activeVats : { id : string ; options : RecordedVatOptions ; } [] ; } ; kpRegisterInterest ( kpid : any ) : void ; kpResolution ( kpid : any , options : any ) : SwingSetCapData ; kpStatus ( kpid : any ) : | "rejected" | "fulfilled" | "unknown" | "unresolved" ; log ( str : any ) : void ; pinVatRoot ( vatName : any ) : string ; queueToVatObject ( target : any , method : string | symbol , args ?: unknown [] , resultPolicy ?: ResolutionPolicy ) : undefined | string ; queueToVatRoot ( vatName : string , method : string | symbol , args ?: unknown [] , resultPolicy ?: ResolutionPolicy ) : undefined | string ; reapAllVats ( previousVatPos : any ) : Record < string , number > ; run ( policy ?: RunPolicy ) : Promise < number > ; shutdown ( ) : Promise < void > ; snapshotAllVats ( ) : Promise < string [] > ; step ( ) : Promise < 0 | 1 > ; terminateVat ( vatID : string , reasonCD : SwingSetCapData ) : void ; upgradeStaticVat ( vatName : any , shouldPauseFirst : any , bundleID : any , options ?: {} ) : undefined | string ; vatNameToID ( vatName : any ) : string ; verboseDebugMode ( flag : any ) : void ; } > Parameters kernelStorage : SwingStoreKernelStorage = ... deviceEndowments : Record < string , unknown > = {} runtimeOptions : { bundleHandler ?: BundleHandler ; debugPrefix ?: string ; debugVats ?: string [] ; env ?: Record < string , undefined | string > ; kernelBundle ?: Bundle ; overrideVatManagerOptions ?: unknown ; profileVats ?: string [] ; slogCallbacks ?: unknown ; slogSender ?: SlogSender ; spawn ?: { ( command : string , options ?: SpawnOptionsWithoutStdio ) : ChildProcessWithoutNullStreams ; ( command : string , options : SpawnOptionsWithStdioTuple < StdioPipe , StdioPipe , StdioPipe > ) : ChildProcessByStdio < Writable , Readable , Readable > ; ( command : string , options : SpawnOptionsWithStdioTuple < StdioPipe , StdioPipe , StdioNull > ) : ChildProcessByStdio < Writable , Readable , null > ; ( command : string , options : SpawnOptionsWithStdioTuple < StdioPipe , StdioNull , StdioPipe > ) : ChildProcessByStdio < Writable , null , Readable > ; ( command : string , options : SpawnOptionsWithStdioTuple < StdioNull , StdioPipe , StdioPipe > ) : ChildProcessByStdio < null , Readable , Readable > ; ( command : string , options : SpawnOptionsWithStdioTuple < StdioPipe , StdioNull , StdioNull > ) : ChildProcessByStdio < Writable , null , null > ; ( command : string , options : SpawnOptionsWithStdioTuple < StdioNull , StdioPipe , StdioNull > ) : ChildProcessByStdio < null , Readable , null > ; ( command : string , options : SpawnOptionsWithStdioTuple < StdioNull , StdioNull , StdioPipe > ) : ChildProcessByStdio < null , null , Readable > ; ( command : string , options : SpawnOptionsWithStdioTuple < StdioNull , StdioNull , StdioNull > ) : ChildProcessByStdio < null , null , null > ; ( command : string , options : SpawnOptions ) : ChildProcess ; ( command : string , args ?: readonly string [] , options ?: SpawnOptionsWithoutStdio ) : ChildProcessWithoutNullStreams ; ( command : string , args : readonly string [] , options : SpawnOptionsWithStdioTuple < StdioPipe , StdioPipe , StdioPipe > ) : ChildProcessByStdio < Writable , Readable , Readable > ; ( command : string , args : readonly string [] , options : SpawnOptionsWithStdioTuple < StdioPipe , StdioPipe , StdioNull > ) : ChildProcessByStdio < Writable , Readable , null > ; ( command : string , args : readonly string [] , options : SpawnOptionsWithStdioTuple < StdioPipe , StdioNull , StdioPipe > ) : ChildProcessByStdio < Writable , null , Readable > ; ( command : string , args : readonly string [] , options : SpawnOptionsWithStdioTuple < StdioNull , StdioPipe , StdioPipe > ) : ChildProcessByStdio < null , Readable , Readable > ; ( command : string , args : readonly string [] , options : SpawnOptionsWithStdioTuple < StdioPipe , StdioNull , StdioNull > ) : ChildProcessByStdio < Writable , null , null > ; ( command : string , args : readonly string [] , options : SpawnOptionsWithStdioTuple < StdioNull , StdioPipe , StdioNull > ) : ChildProcessByStdio < null , Readable , null > ; ( command : string , args : readonly string [] , options : SpawnOptionsWithStdioTuple < StdioNull , StdioNull , StdioPipe > ) : ChildProcessByStdio < null , null , Readable > ; ( command : string , args : readonly string [] , options : SpawnOptionsWithStdioTuple < StdioNull , StdioNull , StdioNull > ) : ChildProcessByStdio < null , null , null > ; ( command : string , args : readonly string [] , options : SpawnOptions ) : ChildProcess ; } ; testTrackDecref ?: unknown ; verbose ?: boolean ; warehousePolicy ?: VatWarehousePolicy ; xsnapBundleData ?: { getLockdownBundle : ( ( ) => Promise < Bundle > ) ; getLockdownBundleSHA256 : ( ( ) => Promise < string > ) ; getSupervisorBundle : ( ( ) => Promise < Bundle > ) ; getSupervisorBundleSHA256 : ( ( ) => Promise < string > ) ; } ; } = {} Optionalbundle Handler ?: BundleHandler Optionaldebug Prefix ?: string Optionaldebug Vats ?: string [] Optionalenv ?: Record < string , undefined | string > Optionalkernel Bundle ?: Bundle Optionaloverride Vat Manager Options ?: unknown Optionalprofile Vats ?: string [] Optionalslog Callbacks ?: unknown Optionalslog Sender ?: SlogSender Optionalspawn ?: { ( command : string , options ?: SpawnOptionsWithoutStdio ) : ChildProcessWithoutNullStreams ; ( command : string , options : SpawnOptionsWithStdioTuple < StdioPipe , StdioPipe , StdioPipe > ) : ChildProcessByStdio < Writable , Readable , Readable > ; ( command : string , options : SpawnOptionsWithStdioTuple < StdioPipe , StdioPipe , StdioNull > ) : ChildProcessByStdio < Writable , Readable , null > ; ( command : string , options : SpawnOptionsWithStdioTuple < StdioPipe , StdioNull , StdioPipe > ) : ChildProcessByStdio < Writable , null , Readable > ; ( command : string , options : SpawnOptionsWithStdioTuple < StdioNull , StdioPipe , StdioPipe > ) : ChildProcessByStdio < null , Readable , Readable > ; ( command : string , options : SpawnOptionsWithStdioTuple < StdioPipe , StdioNull , StdioNull > ) : ChildProcessByStdio < Writable , null , null > ; ( command : string , options : SpawnOptionsWithStdioTuple < StdioNull , StdioPipe , StdioNull > ) : ChildProcessByStdio < null , Readable , null > ; ( command : string , options : SpawnOptionsWithStdioTuple < StdioNull , StdioNull , StdioPipe > ) : ChildProcessByStdio < null , null , Readable > ; ( command : string , options : SpawnOptionsWithStdioTuple < StdioNull , StdioNull , StdioNull > ) : ChildProcessByStdio < null , null , null > ; ( command : string , options : SpawnOptions ) : ChildProcess ; ( command : string , args ?: readonly string [] , options ?: SpawnOptionsWithoutStdio ) : ChildProcessWithoutNullStreams ; ( command : string , args : readonly string [] , options : SpawnOptionsWithStdioTuple < StdioPipe , StdioPipe , StdioPipe > ) : ChildProcessByStdio < Writable , Readable , Readable > ; ( command : string , args : readonly string [] , options : SpawnOptionsWithStdioTuple < StdioPipe , StdioPipe , StdioNull > ) : ChildProcessByStdio < Writable , Readable , null > ; ( command : string , args : readonly string [] , options : SpawnOptionsWithStdioTuple < StdioPipe , StdioNull , StdioPipe > ) : ChildProcessByStdio < Writable , null , Readable > ; ( command : string , args : readonly string [] , options : SpawnOptionsWithStdioTuple < StdioNull , StdioPipe , StdioPipe > ) : ChildProcessByStdio < null , Readable , Readable > ; ( command : string , args : readonly string [] , options : SpawnOptionsWithStdioTuple < StdioPipe , StdioNull , StdioNull > ) : ChildProcessByStdio < Writable , null , null > ; ( command : string , args : readonly string [] , options : SpawnOptionsWithStdioTuple < StdioNull , StdioPipe , StdioNull > ) : ChildProcessByStdio < null , Readable , null > ; ( command : string , args : readonly string [] , options : SpawnOptionsWithStdioTuple < StdioNull , StdioNull , StdioPipe > ) : ChildProcessByStdio < null , null , Readable > ; ( command : string , args : readonly string [] , options : SpawnOptionsWithStdioTuple < StdioNull , StdioNull , StdioNull > ) : ChildProcessByStdio < null , null , null > ; ( command : string , args : readonly string [] , options : SpawnOptions ) : ChildProcess ; } ( command , options ? ) : ChildProcessWithoutNullStreams Parameters command : string Optionaloptions : SpawnOptionsWithoutStdio Returns ChildProcessWithoutNullStreams ( command , options ) : ChildProcessByStdio < Writable , Readable , Readable > Parameters command : string options : SpawnOptionsWithStdioTuple < StdioPipe , StdioPipe , StdioPipe > Returns ChildProcessByStdio < Writable , Readable , Readable > ( command , options ) : ChildProcessByStdio < Writable , Readable , null > Parameters command : string options : SpawnOptionsWithStdioTuple < StdioPipe , StdioPipe , StdioNull > Returns ChildProcessByStdio < Writable , Readable , null > ( command , options ) : ChildProcessByStdio < Writable , null , Readable > Parameters command : string options : SpawnOptionsWithStdioTuple < StdioPipe , StdioNull , StdioPipe > Returns ChildProcessByStdio < Writable , null , Readable > ( command , options ) : ChildProcessByStdio < null , Readable , Readable > Parameters command : string options : SpawnOptionsWithStdioTuple < StdioNull , StdioPipe , StdioPipe > Returns ChildProcessByStdio < null , Readable , Readable > ( command , options ) : ChildProcessByStdio < Writable , null , null > Parameters command : string options : SpawnOptionsWithStdioTuple < StdioPipe , StdioNull , StdioNull > Returns ChildProcessByStdio < Writable , null , null > ( command , options ) : ChildProcessByStdio < null , Readable , null > Parameters command : string options : SpawnOptionsWithStdioTuple < StdioNull , StdioPipe , StdioNull > Returns ChildProcessByStdio < null , Readable , null > ( command , options ) : ChildProcessByStdio < null , null , Readable > Parameters command : string options : SpawnOptionsWithStdioTuple < StdioNull , StdioNull , StdioPipe > Returns ChildProcessByStdio < null , null , Readable > ( command , options ) : ChildProcessByStdio < null , null , null > Parameters command : string options : SpawnOptionsWithStdioTuple < StdioNull , StdioNull , StdioNull > Returns ChildProcessByStdio < null , null , null > ( command , options ) : ChildProcess Parameters command : string options : SpawnOptions Returns ChildProcess ( command , args ? , options ? ) : ChildProcessWithoutNullStreams Parameters command : string Optionalargs : readonly string [] Optionaloptions : SpawnOptionsWithoutStdio Returns ChildProcessWithoutNullStreams ( command , args , options ) : ChildProcessByStdio < Writable , Readable , Readable > Parameters command : string args : readonly string [] options : SpawnOptionsWithStdioTuple < StdioPipe , StdioPipe , StdioPipe > Returns ChildProcessByStdio < Writable , Readable , Readable > ( command , args , options ) : ChildProcessByStdio < Writable , Readable , null > Parameters command : string args : readonly string [] options : SpawnOptionsWithStdioTuple < StdioPipe , StdioPipe , StdioNull > Returns ChildProcessByStdio < Writable , Readable , null > ( command , args , options ) : ChildProcessByStdio < Writable , null , Readable > Parameters command : string args : readonly string [] options : SpawnOptionsWithStdioTuple < StdioPipe , StdioNull , StdioPipe > Returns ChildProcessByStdio < Writable , null , Readable > ( command , args , options ) : ChildProcessByStdio < null , Readable , Readable > Parameters command : string args : readonly string [] options : SpawnOptionsWithStdioTuple < StdioNull , StdioPipe , StdioPipe > Returns ChildProcessByStdio < null , Readable , Readable > ( command , args , options ) : ChildProcessByStdio < Writable , null , null > Parameters command : string args : readonly string [] options : SpawnOptionsWithStdioTuple < StdioPipe , StdioNull , StdioNull > Returns ChildProcessByStdio < Writable , null , null > ( command , args , options ) : ChildProcessByStdio < null , Readable , null > Parameters command : string args : readonly string [] options : SpawnOptionsWithStdioTuple < StdioNull , StdioPipe , StdioNull > Returns ChildProcessByStdio < null , Readable , null > ( command , args , options ) : ChildProcessByStdio < null , null , Readable > Parameters command : string args : readonly string [] options : SpawnOptionsWithStdioTuple < StdioNull , StdioNull , StdioPipe > Returns ChildProcessByStdio < null , null , Readable > ( command , args , options ) : ChildProcessByStdio < null , null , null > Parameters command : string args : readonly string [] options : SpawnOptionsWithStdioTuple < StdioNull , StdioNull , StdioNull > Returns ChildProcessByStdio < null , null , null > ( command , args , options ) : ChildProcess Parameters command : string args : readonly string [] options : SpawnOptions Returns ChildProcess Optionaltest Track Decref ?: unknown Optionalverbose ?: boolean Optionalxsnap Bundle Data ?: { getLockdownBundle : ( ( ) => Promise < Bundle > ) ; getLockdownBundleSHA256 : ( ( ) => Promise < string > ) ; getSupervisorBundle : ( ( ) => Promise < Bundle > ) ; getSupervisorBundleSHA256 : ( ( ) => Promise < string > ) ; } get Lockdown Bundle : ( ( ) => Promise < Bundle > ) ( ) : Promise < Bundle > Returns Promise < Bundle > get Lockdown BundleSHA256 : ( ( ) => Promise < string > ) ( ) : Promise < string > Returns Promise < string > get Supervisor Bundle : ( ( ) => Promise < Bundle > ) ( ) : Promise < Bundle > Returns Promise < Bundle > get Supervisor BundleSHA256 : ( ( ) => Promise < string > ) ( ) : Promise < string > Returns Promise < string > Returns Promise < { debug : { addDeviceHook : ( ( deviceName : any , hookName : any , hook : any ) => void ) ; } ; injectQueuedUpgradeEvents : ( ( ) => void ) ; slogDuration : ( < T , A > ( labels : readonly [ undefined | string , string ] , startProps : SlogDurationProps , fn : ( ( finish : ( ( extraProps ?: SlogDurationProps ) => void ) , ... args : A ) => T | Promise < T > ) , ... args : unknown [] & A ) => Promise < T > ) ; validateAndInstallBundle : ( ( bundle : EndoZipBase64Bundle , allegedBundleID ??: string ) => Promise < string > ) ; writeSlogObject : ( ( obj : SlogProps ) => void ) ; changeKernelOptions ( options : any ) : void ; deviceNameToID ( deviceName : any ) : undefined | string ; dump ( ) : { acceptanceQueue : any [] ; gcActions : any [] ; kernelTable : any [] ; log : string [] ; objects : ( undefined | string | number ) [] [] ; promises : ( { decider : undefined | string ; id : string ; policy : string ; queue : string [] ; refCount : number ; state : "unresolved" ; subscribers : string [] ; } | { data : SwingSetCapData ; id : string ; refCount : number ; state : "rejected" | "fulfilled" ; } ) [] ; reapQueue : any ; runQueue : any [] ; vatTables : { state : { transcript : [ number , TranscriptEntry ] [] ; } ; vatID : string ; } [] ; } ; dumpLog ( idx : any ) : string [] ; getActivityhash ( ) : string ; getStats ( ) : Record < string , number > ; getStatus ( ) : { activeVats : { id : string ; options : RecordedVatOptions ; } [] ; } ; kpRegisterInterest ( kpid : any ) : void ; kpResolution ( kpid : any , options : any ) : SwingSetCapData ; kpStatus ( kpid : any ) : | "rejected" | "fulfilled" | "unknown" | "unresolved" ; log ( str : any ) : void ; pinVatRoot ( vatName : any ) : string ; queueToVatObject ( target : any , method : string | symbol , args ?: unknown [] , resultPolicy ?: ResolutionPolicy ) : undefined | string ; queueToVatRoot ( vatName : string , method : string | symbol , args ?: unknown [] , resultPolicy ?: ResolutionPolicy ) : undefined | string ; reapAllVats ( previousVatPos : any ) : Record < string , number > ; run ( policy ?: RunPolicy ) : Promise < number > ; shutdown ( ) : Promise < void > ; snapshotAllVats ( ) : Promise < string [] > ; step ( ) : Promise < 0 | 1 > ; terminateVat ( vatID : string , reasonCD : SwingSetCapData ) : void ; upgradeStaticVat ( vatName : any , shouldPauseFirst : any , bundleID : any , options ?: {} ) : undefined | string ; vatNameToID ( vatName : any ) : string ; verboseDebugMode ( flag : any ) : void ; } >
The
child_process.spawn()method spawns a new process using the givencommand, with command-line arguments inargs. If omitted,argsdefaults to an empty array.If the
shelloption is enabled, do not pass unsanitized user input to this function. Any input containing shell metacharacters may be used to trigger arbitrary command execution.A third argument may be used to specify additional options, with these defaults:
Use
cwdto specify the working directory from which the process is spawned. If not given, the default is to inherit the current working directory. If given, but the path does not exist, the child process emits anENOENTerror and exits immediately.ENOENTis also emitted when the command does not exist.Use
envto specify environment variables that will be visible to the new process, the default isprocess.env.undefinedvalues inenvwill be ignored.Example of running
ls -lh /usr, capturingstdout,stderr, and the exit code:Example: A very elaborate way to run
ps ax | grep sshExample of checking for failed
spawn:Certain platforms (macOS, Linux) will use the value of
argv[0]for the process title while others (Windows, SunOS) will usecommand.Node.js overwrites
argv[0]withprocess.execPathon startup, soprocess.argv[0]in a Node.js child process will not match theargv0parameter passed tospawnfrom the parent. Retrieve it with theprocess.argv0property instead.If the
signaloption is enabled, calling.abort()on the correspondingAbortControlleris similar to calling.kill()on the child process except the error passed to the callback will be anAbortError: