<div dir="ltr">Hi all,<div><br></div><div>There has been some discussion about supporting JavaScript in Wildfly for a while now, and as a result I have come up with a simple proof of concept of the form I think this support could take. </div><div><br></div><div>At the moment this is actually not part of Wildfly at all, but rather a jar file that you can include in your apps and allows you to register JavaScript based handlers. These handlers can be mapped to URL&#39;s, and inject container resources such as CDI beans and JNDI data sources. It also provide some simple JavaScript wrappers to make some EE objects easier to use from scripts. </div><div><br></div><div>At the moment handlers are mainly useful as REST endpoints, although if there is interest I am planning on adding template engine support as well. </div><div><br></div><div>When combined with my external resources PR (<a href="https://github.com/wildfly/wildfly/pull/7299">https://github.com/wildfly/wildfly/pull/7299</a>) this allows for changes in your script files to be immediately visible, without even needing to copy to an exploded deployment. </div><div><br></div><div>I envisage the main use of this will not be creating node.js like apps that are pure javascript, but rather to allow simpler parts of the app to be written in JavaScript, and this avoiding the compile+redeploy cycle.</div><div><br></div><div>Full details are here: <a href="https://github.com/undertow-io/undertow.js">https://github.com/undertow-io/undertow.js</a></div><div><br></div><div>I have an example of the Kitchen Sink quickstart that has been re-done to use this here:</div><div><br></div><div><a href="https://github.com/wildfly/quickstart/compare/master...stuartwdouglas:js#diff-598449fd216b3768c251e297895211deR1">https://github.com/wildfly/quickstart/compare/master...stuartwdouglas:js#diff-598449fd216b3768c251e297895211deR1</a><br></div><div><br></div><div>At this stage I am really not sure how this will evolve, or if it will go anywhere, I am just putting it out there to get some feedback.</div><div><br></div><div>Stuart</div></div>