mirror of
https://github.com/gitbucket/gitbucket.git
synced 2025-11-08 14:35:52 +01:00
(refs #32)Improving plug-in API
This commit is contained in:
@@ -14,15 +14,36 @@ object PluginSystem {
|
|||||||
|
|
||||||
private val logger = LoggerFactory.getLogger(PluginSystem.getClass)
|
private val logger = LoggerFactory.getLogger(PluginSystem.getClass)
|
||||||
|
|
||||||
private val repositoryMenuList = ListBuffer[RepositoryMenu]()
|
private val plugins = scala.collection.mutable.Map[String, Plugin]()
|
||||||
private val globalMenuList = ListBuffer[GlobalMenu]()
|
|
||||||
private val repositoryActionList = ListBuffer[Action]()
|
|
||||||
private val globalActionList = ListBuffer[Action]()
|
|
||||||
|
|
||||||
|
def install(id: String, plugin: Plugin): Unit = {
|
||||||
|
plugins.put(id, plugin)
|
||||||
|
}
|
||||||
|
|
||||||
|
def uninstall(id: String): Unit = {
|
||||||
|
plugins.remove(id)
|
||||||
|
}
|
||||||
|
|
||||||
|
def repositoryMenus : List[RepositoryMenu] = plugins.values.flatMap(_.repositoryMenuList).toList
|
||||||
|
def globalMenus : List[GlobalMenu] = plugins.values.flatMap(_.globalMenuList).toList
|
||||||
|
def repositoryActions : List[Action] = plugins.values.flatMap(_.repositoryActionList).toList
|
||||||
|
def globalActions : List[Action] = plugins.values.flatMap(_.globalActionList).toList
|
||||||
|
|
||||||
|
// Case classes to hold plug-ins information internally in GitBucket
|
||||||
case class GlobalMenu(label: String, url: String, icon: String, condition: Context => Boolean)
|
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 RepositoryMenu(label: String, name: String, url: String, icon: String, condition: Context => Boolean)
|
||||||
case class Action(path: String, function: (HttpServletRequest, HttpServletResponse) => Any)
|
case class Action(path: String, function: (HttpServletRequest, HttpServletResponse) => Any)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This is a plug-in definition class.
|
||||||
|
*/
|
||||||
|
class Plugin {
|
||||||
|
|
||||||
|
private[PluginSystem] val repositoryMenuList = ListBuffer[RepositoryMenu]()
|
||||||
|
private[PluginSystem] val globalMenuList = ListBuffer[GlobalMenu]()
|
||||||
|
private[PluginSystem] val repositoryActionList = ListBuffer[Action]()
|
||||||
|
private[PluginSystem] val globalActionList = ListBuffer[Action]()
|
||||||
|
|
||||||
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)
|
repositoryMenuList += RepositoryMenu(label, name, url, icon, condition)
|
||||||
}
|
}
|
||||||
@@ -54,31 +75,29 @@ object PluginSystem {
|
|||||||
def addRepositoryAction(path: String, function: ScriptObjectMirror): Unit = {
|
def addRepositoryAction(path: String, function: ScriptObjectMirror): Unit = {
|
||||||
repositoryActionList += Action(path, (request, response) => function.call(this, request, response))
|
repositoryActionList += Action(path, (request, response) => function.call(this, request, response))
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
def evaluateJavaScript(script: String): Any = {
|
def evaluateJavaScript(script: String): Any = {
|
||||||
val engine = new ScriptEngineManager().getEngineByName("JavaScript")
|
val engine = new ScriptEngineManager().getEngineByName("JavaScript")
|
||||||
logger.debug("Script: " + script)
|
logger.debug("Script: " + script)
|
||||||
engine.put("PluginSystem", this)
|
engine.put("PluginSystem", this)
|
||||||
val result = engine.eval(script)
|
// TODO Support both of Nashorn and Rhino!
|
||||||
|
val result = engine.eval("var Plugin = Java.type(\"plugin.PluginSystem.Plugin\"); " + script)
|
||||||
logger.debug("Result: " + result)
|
logger.debug("Result: " + result)
|
||||||
result
|
result
|
||||||
}
|
}
|
||||||
|
|
||||||
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
|
// TODO This is a test
|
||||||
addGlobalMenu("Google", "http://www.google.co.jp/", "")
|
// addGlobalMenu("Google", "http://www.google.co.jp/", "")
|
||||||
{ context => context.loginAccount.isDefined }
|
// { context => context.loginAccount.isDefined }
|
||||||
|
//
|
||||||
addRepositoryMenu("Board", "board", "/board", "")
|
// addRepositoryMenu("Board", "board", "/board", "")
|
||||||
{ context => true}
|
// { context => true}
|
||||||
|
//
|
||||||
addGlobalAction("/hello"){ (request, response) =>
|
// addGlobalAction("/hello"){ (request, response) =>
|
||||||
"Hello World!"
|
// "Hello World!"
|
||||||
}
|
// }
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user