diff --git a/src/main/scala/app/SystemSettingsController.scala b/src/main/scala/app/SystemSettingsController.scala index 076da08..42e52d7 100644 --- a/src/main/scala/app/SystemSettingsController.scala +++ b/src/main/scala/app/SystemSettingsController.scala @@ -99,6 +99,8 @@ }) get("/admin/plugins/available")(adminOnly { + // TODO Do periodical and asynchronous...? + PluginSystem.updateAllRepositories() admin.plugins.html.available(getAvailablePlugins()) }) diff --git a/src/main/scala/plugin/PluginSystem.scala b/src/main/scala/plugin/PluginSystem.scala index 539c992..df00943 100644 --- a/src/main/scala/plugin/PluginSystem.scala +++ b/src/main/scala/plugin/PluginSystem.scala @@ -7,6 +7,8 @@ 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 @@ } } + // 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 @@ 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 }