(refs #32)Clone or pull plugin repository before displaying the available plugins page

This commit is contained in:
Naoki Takezoe
2014-06-15 18:07:34 +09:00
parent fd4a696303
commit 4bd6ef143a
2 changed files with 24 additions and 0 deletions

View File

@@ -99,6 +99,8 @@ trait SystemSettingsControllerBase extends ControllerBase {
})
get("/admin/plugins/available")(adminOnly {
// TODO Do periodical and asynchronous...?
PluginSystem.updateAllRepositories()
admin.plugins.html.available(getAvailablePlugins())
})

View File

@@ -7,6 +7,8 @@ import java.util.concurrent.atomic.AtomicBoolean
import util.Directory._
import util.ControlUtil._
import org.apache.commons.io.FileUtils
import util.JGitUtil
import org.eclipse.jgit.api.Git
/**
* 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 = {
val pluginDir = new java.io.File(PluginHome)
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 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
// addGlobalMenu("Google", "http://www.google.co.jp/", "")
// { context => context.loginAccount.isDefined }