mirror of
https://github.com/gitbucket/gitbucket.git
synced 2025-11-06 13:35:50 +01:00
(refs #32)Clone or pull plugin repository before displaying the available plugins page
This commit is contained in:
@@ -99,6 +99,8 @@ trait SystemSettingsControllerBase extends ControllerBase {
|
|||||||
})
|
})
|
||||||
|
|
||||||
get("/admin/plugins/available")(adminOnly {
|
get("/admin/plugins/available")(adminOnly {
|
||||||
|
// TODO Do periodical and asynchronous...?
|
||||||
|
PluginSystem.updateAllRepositories()
|
||||||
admin.plugins.html.available(getAvailablePlugins())
|
admin.plugins.html.available(getAvailablePlugins())
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|||||||
@@ -7,6 +7,8 @@ import java.util.concurrent.atomic.AtomicBoolean
|
|||||||
import util.Directory._
|
import util.Directory._
|
||||||
import util.ControlUtil._
|
import util.ControlUtil._
|
||||||
import org.apache.commons.io.FileUtils
|
import org.apache.commons.io.FileUtils
|
||||||
|
import util.JGitUtil
|
||||||
|
import org.eclipse.jgit.api.Git
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Provides extension points to plug-ins.
|
* Provides extension points to plug-ins.
|
||||||
@@ -48,6 +50,7 @@ object PluginSystem {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// TODO Method name seems to not so good.
|
||||||
def installPlugin(id: String): Unit = {
|
def installPlugin(id: String): Unit = {
|
||||||
val pluginDir = new java.io.File(PluginHome)
|
val pluginDir = new java.io.File(PluginHome)
|
||||||
val javaScriptFile = new java.io.File(pluginDir, id + "/plugin.js")
|
val javaScriptFile = new java.io.File(pluginDir, id + "/plugin.js")
|
||||||
@@ -84,6 +87,25 @@ object PluginSystem {
|
|||||||
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)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Clone or pull all plugin repositories
|
||||||
|
*
|
||||||
|
* TODO Support plugin repository access through the proxy server
|
||||||
|
*/
|
||||||
|
def updateAllRepositories(): Unit = {
|
||||||
|
repositories.foreach { repository =>
|
||||||
|
val dir = getPluginCacheDir()
|
||||||
|
val repo = new java.io.File(dir, repository.id)
|
||||||
|
if(repo.exists){
|
||||||
|
// pull if the repository is already cloned
|
||||||
|
Git.open(repo).pull().call()
|
||||||
|
} else {
|
||||||
|
// clone if the repository is not exist
|
||||||
|
Git.cloneRepository().setURI(repository.url).setDirectory(repo).call()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// 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 }
|
||||||
|
|||||||
Reference in New Issue
Block a user