Skip to content

Latest commit

 

History

History
76 lines (54 loc) · 2.05 KB

README.md

File metadata and controls

76 lines (54 loc) · 2.05 KB

GraalJS REST wrapper

The simple REST wrapper for GraalJS that allows running scripts in synchronous and asynchronous modes and stopping them before completion.

Requirements

  1. GraalVM
  2. GraalJS module

Running

Windows

cd "path/to/cloned/repository"
set "JAVA_HOME=path/to/graalvm"
mvnw package
"%JAVA_HOME%/bin/java.exe" -Dpolyglot.image-build-time.PreinitializeContexts=js -jar target/graaljs-rest-wrapper-0.0.1-SNAPSHOT.jar

Linux

cd "path/to/cloned/repository"
export JAVA_HOME="/path/to/graalvm"
mvnw package
$JAVA_HOME/bin/java -Dpolyglot.image-build-time.PreinitializeContexts=js -jar target/graaljs-rest-wrapper-0.0.1-SNAPSHOT.jar

You can also add --running-threads-number argument that points out the number of threads that can process scripts at once (default value is 3).

Example (Windows):

"%JAVA_HOME%/bin/java.exe" -Dpolyglot.image-build-time.PreinitializeContexts=js -jar target/graaljs-rest-wrapper-0.0.1-SNAPSHOT.jar --running-threads-number=4

Usage

  • Send a script for execution in async mode (send and forget)
curl -X POST localhost:8080/scripts -H "Content-Type: text/plain" -d @script.txt
  • Send a script for execution in sync (blocking) mode (realtime script's output streaming).
    It should be noted that response streaming doesn't work correctly in Postman.
curl -X POST localhost:8080/scripts?blocking -H "Content-Type: text/plain" -d @script.txt
  • Stop running or queuing script
curl -X POST localhost:8080/scripts/{id}
  • Get all scripts (request params are optional).
    Available status values: queued, executing, completed, failed, interrupted.
    Available orderBy values: id, schedTime, pubTime.
curl localhost:8080/scripts?status=interrupted&orderBy=schedTime
  • Get all information about a script (including script's output).
curl localhost:8080/scripts/{id}
  • Remove a finished script.
curl -X DELETE localhost:8080/scripts/{id}