Clean code
This commit is contained in:
parent
9d335b7fb1
commit
72c122105f
|
@ -14,6 +14,35 @@ class ExecutionTimeoutError extends Error {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
class ModuleHandler {
|
||||||
|
#modules: {
|
||||||
|
import: string
|
||||||
|
moduleKey: string
|
||||||
|
module: ivm.Module
|
||||||
|
}[] = []
|
||||||
|
|
||||||
|
#generateRandomKey = () => `i${crypto.randomUUID().replace(/-/g, "")}`
|
||||||
|
|
||||||
|
registerModule(module: ivm.Module, imports: string) {
|
||||||
|
this.#modules.push({
|
||||||
|
moduleKey: this.#generateRandomKey(),
|
||||||
|
import: imports,
|
||||||
|
module: module,
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
generateImports() {
|
||||||
|
return this.#modules
|
||||||
|
.map(m => `import ${m.import} from "${m.moduleKey}"`)
|
||||||
|
.join(";")
|
||||||
|
}
|
||||||
|
|
||||||
|
getModule(key: string) {
|
||||||
|
const module = this.#modules.find(m => m.moduleKey === key)
|
||||||
|
return module?.module
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
export class IsolatedVM implements VM {
|
export class IsolatedVM implements VM {
|
||||||
#isolate: ivm.Isolate
|
#isolate: ivm.Isolate
|
||||||
#vm: ivm.Context
|
#vm: ivm.Context
|
||||||
|
@ -21,11 +50,7 @@ export class IsolatedVM implements VM {
|
||||||
#timeout: number
|
#timeout: number
|
||||||
#perRequestLimit?: number
|
#perRequestLimit?: number
|
||||||
|
|
||||||
#modules: {
|
#moduleHandler = new ModuleHandler()
|
||||||
import: string
|
|
||||||
moduleKey: string
|
|
||||||
module: ivm.Module
|
|
||||||
}[] = []
|
|
||||||
|
|
||||||
readonly #resultKey = "results"
|
readonly #resultKey = "results"
|
||||||
|
|
||||||
|
@ -96,11 +121,7 @@ export class IsolatedVM implements VM {
|
||||||
throw new Error(`No imports allowed. Required: ${specifier}`)
|
throw new Error(`No imports allowed. Required: ${specifier}`)
|
||||||
})
|
})
|
||||||
|
|
||||||
this.#modules.push({
|
this.#moduleHandler.registerModule(helpersModule, "helpers")
|
||||||
import: "helpers",
|
|
||||||
moduleKey: `i${crypto.randomUUID().replace(/-/g, "")}`,
|
|
||||||
module: helpersModule,
|
|
||||||
})
|
|
||||||
return this
|
return this
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -121,17 +142,14 @@ export class IsolatedVM implements VM {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
code = [
|
code = `${this.#moduleHandler.generateImports()};results.out=${code};`
|
||||||
...this.#modules.map(m => `import ${m.import} from "${m.moduleKey}"`),
|
|
||||||
`results.out=${code};`,
|
|
||||||
].join(";")
|
|
||||||
|
|
||||||
const script = this.#isolate.compileModuleSync(code)
|
const script = this.#isolate.compileModuleSync(code)
|
||||||
|
|
||||||
script.instantiateSync(this.#vm, specifier => {
|
script.instantiateSync(this.#vm, specifier => {
|
||||||
const module = this.#modules.find(m => m.moduleKey === specifier)
|
const module = this.#moduleHandler.getModule(specifier)
|
||||||
if (module) {
|
if (module) {
|
||||||
return module.module
|
return module
|
||||||
}
|
}
|
||||||
|
|
||||||
throw new Error(`"${specifier}" import not allowed`)
|
throw new Error(`"${specifier}" import not allowed`)
|
||||||
|
|
Loading…
Reference in New Issue