From 895defda8edbe416b38e6acbc165ac0812d26389 Mon Sep 17 00:00:00 2001 From: Florian Hotze Date: Thu, 29 Dec 2022 21:01:22 +0100 Subject: [PATCH] [jsscripting] Use `application/javascript` as MIME type (#14096) Signed-off-by: Florian Hotze --- .../internal/GraalJSScriptEngineFactory.java | 30 ++++++++++--------- 1 file changed, 16 insertions(+), 14 deletions(-) diff --git a/bundles/org.openhab.automation.jsscripting/src/main/java/org/openhab/automation/jsscripting/internal/GraalJSScriptEngineFactory.java b/bundles/org.openhab.automation.jsscripting/src/main/java/org/openhab/automation/jsscripting/internal/GraalJSScriptEngineFactory.java index 9883dd4e9..769601056 100644 --- a/bundles/org.openhab.automation.jsscripting/src/main/java/org/openhab/automation/jsscripting/internal/GraalJSScriptEngineFactory.java +++ b/bundles/org.openhab.automation.jsscripting/src/main/java/org/openhab/automation/jsscripting/internal/GraalJSScriptEngineFactory.java @@ -14,6 +14,8 @@ package org.openhab.automation.jsscripting.internal; import java.util.List; import java.util.Map; +import java.util.stream.Collectors; +import java.util.stream.Stream; import javax.script.ScriptEngine; @@ -29,6 +31,8 @@ import org.osgi.service.component.annotations.Component; import org.osgi.service.component.annotations.Modified; import org.osgi.service.component.annotations.Reference; +import com.oracle.truffle.js.scriptengine.GraalJSEngineFactory; + /** * An implementation of {@link ScriptEngineFactory} with customizations for GraalJS ScriptEngines. * @@ -42,23 +46,21 @@ import org.osgi.service.component.annotations.Reference; public final class GraalJSScriptEngineFactory implements ScriptEngineFactory { private static final String CFG_INJECTION_ENABLED = "injectionEnabled"; private static final String INJECTION_CODE = "Object.assign(this, require('openhab'));"; - private boolean injectionEnabled = true; - /* - * Whilst we run in parallel with Nashorn, we use a custom mime-type to avoid - * disrupting Nashorn scripts. When Nashorn is removed, we take over the standard - * JS runtime. - */ + private static final GraalJSEngineFactory factory = new GraalJSEngineFactory(); - // GraalJSEngineFactory graalJSEngineFactory = new GraalJSEngineFactory(); - // - // scriptTypes.addAll(graalJSEngineFactory.getMimeTypes()); - // scriptTypes.addAll(graalJSEngineFactory.getExtensions()); - - public static final String MIME_TYPE = "application/javascript;version=ECMAScript-2021"; - private static final String ALT_MIME_TYPE = "text/javascript;version=ECMAScript-2021"; + public static final String MIME_TYPE = "application/javascript"; private static final String ALIAS = "graaljs"; - private static final List SCRIPT_TYPES = List.of(MIME_TYPE, ALT_MIME_TYPE, ALIAS); + private static final List SCRIPT_TYPES = createScriptTypes(); + + private static List createScriptTypes() { + // Add those for backward compatibility (existing scripts may rely on those MIME types) + List backwardCompat = List.of("application/javascript;version=ECMAScript-2021", ALIAS); + return Stream.of(factory.getMimeTypes(), factory.getExtensions(), backwardCompat).flatMap(List::stream) + .collect(Collectors.toUnmodifiableList()); + } + + private boolean injectionEnabled = true; private final JSScriptServiceUtil jsScriptServiceUtil; private final JSDependencyTracker jsDependencyTracker;