From 6f1c25a4673fee28e2c064ad402811eb32920a74 Mon Sep 17 00:00:00 2001 From: Leo Singer Date: Sun, 26 Nov 2023 23:18:41 -0500 Subject: [PATCH] Fall back to Docker for sandbox mode --- install.ts | 3 ++- run.ts | 44 ++++++++++++++++++++++++++++++++++---------- 2 files changed, 36 insertions(+), 11 deletions(-) diff --git a/install.ts b/install.ts index 4c5f690..95327fb 100644 --- a/install.ts +++ b/install.ts @@ -30,9 +30,10 @@ export async function install(engine: SandboxEngine) { entry.engine === engine && entry.arch === arch && entry.type === type )?.url if (!url) { - throw new Error( + console.warn( `No ${engine} binary is available for your OS type (${type}) and architecture (${arch}).` ) + return } const archiveFilename = posix diff --git a/run.ts b/run.ts index 9c4733b..1cb98f8 100644 --- a/run.ts +++ b/run.ts @@ -57,24 +57,48 @@ export class LocalSearch { const logsDir = join(tempDir, 'logs') await Promise.all([dataDir, logsDir].map(mkdirP)) - const args: string[] = [ - `-Epath.data=${dataDir}`, - `-Epath.logs=${logsDir}`, - `-Ehttp.port=${port}`, - '-Ediscovery.type=single-node', + let command + let args = [] + const opts = [ + `http.port=${port}`, + 'discovery.type=single-node', engine === 'elasticsearch' - ? '-Expack.security.enabled=false' - : '-Eplugins.security.disabled=true', + ? 'xpack.security.enabled=false' + : 'plugins.security.disabled=true', ] - console.log('Spawning', bin, ...args) - child = await spawn(bin, args, { + if (bin) { + command = bin + opts.push(`path.data=${dataDir}`, `path.logs=${logsDir}`) + args = opts.map((opt) => `-E${opt}`) + } else { + command = 'docker' + opts.push('path.data=/docker.data', 'path.logs=/docker.logs') + args = [ + 'run', + '--rm', + '-i', + '-p', + `${port}:${port}`, + '-v', + `${dataDir}:/docker.data`, + '-v', + `${logsDir}:/docker.logs`, + ...opts.flatMap((opt) => ['-e', opt]), + engine === 'elasticsearch' + ? 'elastic/elasticsearch:8.6.2' + : 'opensearchproject/opensearch:2.11.0', + ] + } + + console.log('Spawning', command, ...args) + child = await spawn(command, args, { stdio: ['ignore', 'ignore', 'inherit'], }) try { await Promise.race([ - waitPort({ port }), + waitPort({ port, protocol: 'http' }), untilTerminatedUnexpectedly(child), ]) } catch (e) {