(refs #32)Add JavaScript API

This commit is contained in:
Naoki Takezoe
2014-06-08 00:37:01 +09:00
parent daf5fc434c
commit 378c2c39a8
3 changed files with 50 additions and 16 deletions

View File

@@ -3,40 +3,71 @@ package plugin
import app.Context
import javax.servlet.http.{HttpServletResponse, HttpServletRequest}
import javax.script.ScriptEngineManager
import scala.collection.mutable.ListBuffer
import org.slf4j.LoggerFactory
import jdk.nashorn.api.scripting.ScriptObjectMirror
/**
* Provides extension points to plug-ins.
*/
object PluginSystem {
private val repositoryMenuList = scala.collection.mutable.ListBuffer[RepositoryMenu]()
private val globalMenuList = scala.collection.mutable.ListBuffer[GlobalMenu]()
private val actionList = scala.collection.mutable.ListBuffer[Action]()
private val logger = LoggerFactory.getLogger(PluginSystem.getClass)
private val repositoryMenuList = ListBuffer[RepositoryMenu]()
private val globalMenuList = ListBuffer[GlobalMenu]()
private val repositoryActionList = ListBuffer[Action]()
private val globalActionList = ListBuffer[Action]()
case class GlobalMenu(label: String, url: String, icon: String, condition: Context => Boolean)
case class RepositoryMenu(label: String, name: String, url: String, icon: String, condition: Context => Boolean)
case class Action(path: String, function: (HttpServletRequest, HttpServletResponse) => Any)
def addRepositoryMenu(label: String, name: String, url: String, icon: String = "")(condition: Context => Boolean): Unit = {
def addRepositoryMenu(label: String, name: String, url: String, icon: String)(condition: Context => Boolean): Unit = {
repositoryMenuList += RepositoryMenu(label, name, url, icon, condition)
}
def addGlobalMenu(label: String, url: String, icon: String = "")(condition: Context => Boolean): Unit = {
def addRepositoryMenu(label: String, name: String, url: String, icon: String, condition: ScriptObjectMirror): Unit = {
repositoryMenuList += RepositoryMenu(label, name, url, icon, (context) => condition.call(this, context).asInstanceOf[Boolean])
}
def addGlobalMenu(label: String, url: String, icon: String)(condition: Context => Boolean): Unit = {
globalMenuList += GlobalMenu(label, url, icon, condition)
}
def addAction(path: String)(function: (HttpServletRequest, HttpServletResponse) => Any): Unit = {
actionList += Action(path, function)
def addGlobalMenu(label: String, url: String, icon: String, condition: ScriptObjectMirror): Unit = {
globalMenuList += GlobalMenu(label, url, icon, (context) => condition.call(this, context).asInstanceOf[Boolean])
}
def addGlobalAction(path: String)(function: (HttpServletRequest, HttpServletResponse) => Any): Unit = {
globalActionList += Action(path, function)
}
def addGlobalAction(path: String, function: ScriptObjectMirror): Unit = {
globalActionList += Action(path, (request, response) => function.call(this, request, response))
}
def addRepositoryAction(path: String)(function: (HttpServletRequest, HttpServletResponse) => Any): Unit = {
repositoryActionList += Action(path, function)
}
def addRepositoryAction(path: String, function: ScriptObjectMirror): Unit = {
repositoryActionList += Action(path, (request, response) => function.call(this, request, response))
}
def evaluateJavaScript(script: String): Any = {
val engine = new ScriptEngineManager().getEngineByName("JavaScript")
engine.eval(script)
logger.debug("Script: " + script)
engine.put("PluginSystem", this)
val result = engine.eval(script)
logger.debug("Result: " + result)
result
}
lazy val repositoryMenus: List[RepositoryMenu] = repositoryMenuList.toList
lazy val globalMenus: List[GlobalMenu] = globalMenuList.toList
lazy val actions: List[Action] = actionList.toList
def repositoryMenus: List[RepositoryMenu] = repositoryMenuList.toList
def globalMenus: List[GlobalMenu] = globalMenuList.toList
def repositoryActions: List[Action] = repositoryActionList.toList
def globalActions: List[Action] = globalActionList.toList
// TODO This is a test
addGlobalMenu("Google", "http://www.google.co.jp/", "")
@@ -45,7 +76,7 @@ object PluginSystem {
addRepositoryMenu("Board", "board", "/board", "")
{ context => true}
addAction("/hello"){ (request, response) =>
addGlobalAction("/hello"){ (request, response) =>
"Hello World!"
}

View File

@@ -18,7 +18,7 @@ class PluginActionInvokeFilter extends Filter with SystemSettingsService {
(req, res) match {
case (request: HttpServletRequest, response: HttpServletResponse) => {
val path = req.asInstanceOf[HttpServletRequest].getRequestURI
val action = plugin.PluginSystem.actions.find(_.path == path)
val action = plugin.PluginSystem.globalActions.find(_.path == path)
if(action.isDefined){
val result = action.get.function(request, response)

View File

@@ -3,7 +3,7 @@
@import view.helpers._
@html.main("JavaScript Console"){
@menu("script"){
<form action="@path/admin/script" method="POST">
<form method="POST">
<div class="box">
<div class="box-header">JavaScript Console</div>
<div class="box-content">
@@ -11,7 +11,7 @@
</div>
</div>
<fieldset>
<input type="submit" id="evaluate" class="btn btn-success" value="Evaluate"/>
<input type="button" id="evaluate" class="btn btn-success" value="Evaluate"/>
</fieldset>
</form>
}
@@ -21,12 +21,15 @@
$(function(){
var editor = ace.edit("editor");
editor.setTheme("ace/theme/monokai");
editor.getSession().setMode("ace/mode/javascript");
$('#evaluate').click(function(){
$.post('@path/admin/script', {
script: editor.getValue()
}, function(data){
console.log(data);
alert('Success: ' + data);
}).fail(function(error){
alert(error.statusText);
});
});
});