Clean code

This commit is contained in:
Adria Navarro 2024-02-08 10:51:42 +01:00
parent 9d335b7fb1
commit 72c122105f
1 changed files with 34 additions and 16 deletions

View File

@ -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`)