mirror of
https://github.com/gitbucket/gitbucket.git
synced 2025-11-02 11:36:05 +01:00
WikiUtil moved to WikiService and applied cake pattern to
WikiController.
This commit is contained in:
@@ -1,10 +1,14 @@
|
|||||||
package app
|
package app
|
||||||
|
|
||||||
import util.{WikiUtil, JGitUtil}
|
import service._
|
||||||
|
import util.JGitUtil
|
||||||
|
import util.Directory._
|
||||||
import jp.sf.amateras.scalatra.forms._
|
import jp.sf.amateras.scalatra.forms._
|
||||||
import org.eclipse.jgit.api.Git
|
import org.eclipse.jgit.api.Git
|
||||||
|
|
||||||
class WikiController extends ControllerBase {
|
class WikiController extends WikiControllerBase with WikiService
|
||||||
|
|
||||||
|
trait WikiControllerBase extends ControllerBase { self: WikiService =>
|
||||||
|
|
||||||
case class WikiPageEditForm(pageName: String, content: String, message: Option[String], currentPageName: String)
|
case class WikiPageEditForm(pageName: String, content: String, message: Option[String], currentPageName: String)
|
||||||
|
|
||||||
@@ -26,7 +30,7 @@ class WikiController extends ControllerBase {
|
|||||||
val owner = params("owner")
|
val owner = params("owner")
|
||||||
val repository = params("repository")
|
val repository = params("repository")
|
||||||
|
|
||||||
WikiUtil.getPage(owner, repository, "Home") match {
|
getWikiPage(owner, repository, "Home") match {
|
||||||
case Some(page) => wiki.html.wiki("Home", page,
|
case Some(page) => wiki.html.wiki("Home", page,
|
||||||
JGitUtil.getRepositoryInfo(owner, repository, servletContext))
|
JGitUtil.getRepositoryInfo(owner, repository, servletContext))
|
||||||
case None => wiki.html.wikiedit("Home", None,
|
case None => wiki.html.wikiedit("Home", None,
|
||||||
@@ -39,7 +43,7 @@ class WikiController extends ControllerBase {
|
|||||||
val repository = params("repository")
|
val repository = params("repository")
|
||||||
val pageName = params("page")
|
val pageName = params("page")
|
||||||
|
|
||||||
WikiUtil.getPage(owner, repository, pageName) match {
|
getWikiPage(owner, repository, pageName) match {
|
||||||
case Some(page) => wiki.html.wiki(pageName, page,
|
case Some(page) => wiki.html.wiki(pageName, page,
|
||||||
JGitUtil.getRepositoryInfo(owner, repository, servletContext))
|
JGitUtil.getRepositoryInfo(owner, repository, servletContext))
|
||||||
case None => wiki.html.wikiedit(pageName, None,
|
case None => wiki.html.wikiedit(pageName, None,
|
||||||
@@ -52,7 +56,7 @@ class WikiController extends ControllerBase {
|
|||||||
val repository = params("repository")
|
val repository = params("repository")
|
||||||
val page = params("page")
|
val page = params("page")
|
||||||
|
|
||||||
JGitUtil.withGit(WikiUtil.getWikiRepositoryDir(owner, repository)){ git =>
|
JGitUtil.withGit(getWikiRepositoryDir(owner, repository)){ git =>
|
||||||
wiki.html.wikihistory(Some(page),
|
wiki.html.wikihistory(Some(page),
|
||||||
JGitUtil.getCommitLog(git, "master", path = page + ".md")._1,
|
JGitUtil.getCommitLog(git, "master", path = page + ".md")._1,
|
||||||
JGitUtil.getRepositoryInfo(owner, repository, servletContext))
|
JGitUtil.getRepositoryInfo(owner, repository, servletContext))
|
||||||
@@ -65,9 +69,9 @@ class WikiController extends ControllerBase {
|
|||||||
val page = params("page")
|
val page = params("page")
|
||||||
val commitId = params("commitId").split("\\.\\.\\.")
|
val commitId = params("commitId").split("\\.\\.\\.")
|
||||||
|
|
||||||
JGitUtil.withGit(WikiUtil.getWikiRepositoryDir(owner, repository)){ git =>
|
JGitUtil.withGit(getWikiRepositoryDir(owner, repository)){ git =>
|
||||||
wiki.html.wikicompare(Some(page),
|
wiki.html.wikicompare(Some(page),
|
||||||
WikiUtil.getDiffs(git, commitId(0), commitId(1)),
|
getWikiDiffs(git, commitId(0), commitId(1)),
|
||||||
JGitUtil.getRepositoryInfo(owner, repository, servletContext))
|
JGitUtil.getRepositoryInfo(owner, repository, servletContext))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -77,9 +81,9 @@ class WikiController extends ControllerBase {
|
|||||||
val repository = params("repository")
|
val repository = params("repository")
|
||||||
val commitId = params("commitId").split("\\.\\.\\.")
|
val commitId = params("commitId").split("\\.\\.\\.")
|
||||||
|
|
||||||
JGitUtil.withGit(WikiUtil.getWikiRepositoryDir(owner, repository)){ git =>
|
JGitUtil.withGit(getWikiRepositoryDir(owner, repository)){ git =>
|
||||||
wiki.html.wikicompare(None,
|
wiki.html.wikicompare(None,
|
||||||
WikiUtil.getDiffs(git, commitId(0), commitId(1)),
|
getWikiDiffs(git, commitId(0), commitId(1)),
|
||||||
JGitUtil.getRepositoryInfo(owner, repository, servletContext))
|
JGitUtil.getRepositoryInfo(owner, repository, servletContext))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -90,7 +94,7 @@ class WikiController extends ControllerBase {
|
|||||||
val page = params("page")
|
val page = params("page")
|
||||||
|
|
||||||
wiki.html.wikiedit(page,
|
wiki.html.wikiedit(page,
|
||||||
WikiUtil.getPage(owner, repository, page),
|
getWikiPage(owner, repository, page),
|
||||||
JGitUtil.getRepositoryInfo(owner, repository, servletContext))
|
JGitUtil.getRepositoryInfo(owner, repository, servletContext))
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -98,7 +102,7 @@ class WikiController extends ControllerBase {
|
|||||||
val owner = params("owner")
|
val owner = params("owner")
|
||||||
val repository = params("repository")
|
val repository = params("repository")
|
||||||
|
|
||||||
WikiUtil.savePage(owner, repository, form.currentPageName, form.pageName,
|
saveWikiPage(owner, repository, form.currentPageName, form.pageName,
|
||||||
form.content, context.loginUser, form.message.getOrElse(""))
|
form.content, context.loginUser, form.message.getOrElse(""))
|
||||||
|
|
||||||
redirect("%s/%s/wiki/%s".format(owner, repository, form.pageName))
|
redirect("%s/%s/wiki/%s".format(owner, repository, form.pageName))
|
||||||
@@ -116,7 +120,7 @@ class WikiController extends ControllerBase {
|
|||||||
val owner = params("owner")
|
val owner = params("owner")
|
||||||
val repository = params("repository")
|
val repository = params("repository")
|
||||||
|
|
||||||
WikiUtil.savePage(owner, repository, form.currentPageName, form.pageName,
|
saveWikiPage(owner, repository, form.currentPageName, form.pageName,
|
||||||
form.content, context.loginUser, form.message.getOrElse(""))
|
form.content, context.loginUser, form.message.getOrElse(""))
|
||||||
|
|
||||||
redirect("%s/%s/wiki/%s".format(owner, repository, form.pageName))
|
redirect("%s/%s/wiki/%s".format(owner, repository, form.pageName))
|
||||||
@@ -127,7 +131,7 @@ class WikiController extends ControllerBase {
|
|||||||
val repository = params("repository")
|
val repository = params("repository")
|
||||||
val page = params("page")
|
val page = params("page")
|
||||||
|
|
||||||
WikiUtil.deletePage(owner, repository, page, context.loginUser, "Delete %s".format(page))
|
deleteWikiPage(owner, repository, page, context.loginUser, "Delete %s".format(page))
|
||||||
|
|
||||||
redirect("%s/%s/wiki".format(owner, repository))
|
redirect("%s/%s/wiki".format(owner, repository))
|
||||||
}
|
}
|
||||||
@@ -136,7 +140,7 @@ class WikiController extends ControllerBase {
|
|||||||
val owner = params("owner")
|
val owner = params("owner")
|
||||||
val repository = params("repository")
|
val repository = params("repository")
|
||||||
|
|
||||||
wiki.html.wikipages(WikiUtil.getPageList(owner, repository),
|
wiki.html.wikipages(getWikiPageList(owner, repository),
|
||||||
JGitUtil.getRepositoryInfo(owner, repository, servletContext))
|
JGitUtil.getRepositoryInfo(owner, repository, servletContext))
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -144,7 +148,7 @@ class WikiController extends ControllerBase {
|
|||||||
val owner = params("owner")
|
val owner = params("owner")
|
||||||
val repository = params("repository")
|
val repository = params("repository")
|
||||||
|
|
||||||
JGitUtil.withGit(WikiUtil.getWikiRepositoryDir(owner, repository)){ git =>
|
JGitUtil.withGit(getWikiRepositoryDir(owner, repository)){ git =>
|
||||||
wiki.html.wikihistory(None,
|
wiki.html.wikihistory(None,
|
||||||
JGitUtil.getCommitLog(git, "master")._1,
|
JGitUtil.getCommitLog(git, "master")._1,
|
||||||
JGitUtil.getRepositoryInfo(owner, repository, servletContext))
|
JGitUtil.getRepositoryInfo(owner, repository, servletContext))
|
||||||
@@ -174,7 +178,7 @@ class WikiController extends ControllerBase {
|
|||||||
|
|
||||||
def unique: Constraint = new Constraint(){
|
def unique: Constraint = new Constraint(){
|
||||||
def validate(name: String, value: String): Option[String] = {
|
def validate(name: String, value: String): Option[String] = {
|
||||||
if(WikiUtil.getPageList(params("owner"), params("repository")).contains(value)){
|
if(getWikiPageList(params("owner"), params("repository")).contains(value)){
|
||||||
Some("Page already exists.")
|
Some("Page already exists.")
|
||||||
} else {
|
} else {
|
||||||
None
|
None
|
||||||
|
|||||||
@@ -1,179 +1,191 @@
|
|||||||
package util
|
package service
|
||||||
|
|
||||||
import java.io.File
|
import java.io.File
|
||||||
import java.util.Date
|
import java.util.Date
|
||||||
import org.eclipse.jgit.api.Git
|
import org.eclipse.jgit.api.Git
|
||||||
import org.apache.commons.io.FileUtils
|
import org.apache.commons.io.FileUtils
|
||||||
import org.eclipse.jgit.lib.RepositoryBuilder
|
import app.DiffInfo
|
||||||
import app.DiffInfo
|
import util.{Directory, JGitUtil}
|
||||||
import org.eclipse.jgit.treewalk.CanonicalTreeParser
|
import org.eclipse.jgit.lib.RepositoryBuilder
|
||||||
import org.eclipse.jgit.revwalk.RevCommit
|
import org.eclipse.jgit.treewalk.CanonicalTreeParser
|
||||||
import org.eclipse.jgit.treewalk.TreeWalk
|
import org.eclipse.jgit.treewalk.TreeWalk
|
||||||
import org.eclipse.jgit.revwalk.RevWalk
|
import org.eclipse.jgit.revwalk.RevCommit
|
||||||
import org.eclipse.jgit.diff.DiffEntry.ChangeType
|
import org.eclipse.jgit.revwalk.RevWalk
|
||||||
|
import org.eclipse.jgit.diff.DiffEntry.ChangeType
|
||||||
object WikiUtil {
|
|
||||||
|
object WikiService {
|
||||||
/**
|
|
||||||
* The model for wiki page.
|
/**
|
||||||
*
|
* The model for wiki page.
|
||||||
* @param name the page name
|
*
|
||||||
* @param content the page content
|
* @param name the page name
|
||||||
* @param committer the last committer
|
* @param content the page content
|
||||||
* @param time the last modified time
|
* @param committer the last committer
|
||||||
*/
|
* @param time the last modified time
|
||||||
case class WikiPageInfo(name: String, content: String, committer: String, time: Date)
|
*/
|
||||||
|
case class WikiPageInfo(name: String, content: String, committer: String, time: Date)
|
||||||
/**
|
|
||||||
* The model for wiki page history.
|
/**
|
||||||
*
|
* The model for wiki page history.
|
||||||
* @param name the page name
|
*
|
||||||
* @param committer the committer the committer
|
* @param name the page name
|
||||||
* @param message the commit message
|
* @param committer the committer the committer
|
||||||
* @param date the commit date
|
* @param message the commit message
|
||||||
*/
|
* @param date the commit date
|
||||||
case class WikiPageHistoryInfo(name: String, committer: String, message: String, date: Date)
|
*/
|
||||||
|
case class WikiPageHistoryInfo(name: String, committer: String, message: String, date: Date)
|
||||||
/**
|
|
||||||
* Returns the directory of the wiki repository.
|
}
|
||||||
*/
|
|
||||||
def getWikiRepositoryDir(owner: String, repository: String): File =
|
trait WikiService {
|
||||||
new File("%s/%s/%s.wiki.git".format(Directory.RepositoryHome, owner, repository))
|
|
||||||
|
import WikiService._
|
||||||
/**
|
|
||||||
* Returns the directory of the wiki working directory which is cloned from the wiki repository.
|
// /**
|
||||||
*/
|
// * Returns the directory of the wiki repository.
|
||||||
def getWikiWorkDir(owner: String, repository: String): File =
|
// */
|
||||||
new File("%s/tmp/%s/%s.wiki".format(Directory.GitBucketHome, owner, repository))
|
// def getWikiRepositoryDir(owner: String, repository: String): File =
|
||||||
|
// new File("%s/%s/%s.wiki.git".format(Directory.RepositoryHome, owner, repository))
|
||||||
// TODO synchronized?
|
//
|
||||||
def createWikiRepository(owner: String, repository: String): Unit = {
|
// /**
|
||||||
val dir = getWikiRepositoryDir(owner, repository)
|
// * Returns the directory of the wiki working directory which is cloned from the wiki repository.
|
||||||
if(!dir.exists){
|
// */
|
||||||
val repo = new RepositoryBuilder().setGitDir(dir).setBare.build
|
// def getWikiWorkDir(owner: String, repository: String): File =
|
||||||
try {
|
// new File("%s/tmp/%s/%s.wiki".format(Directory.GitBucketHome, owner, repository))
|
||||||
repo.create
|
|
||||||
savePage(owner, repository, "Home", "Home", "Welcome to the %s wiki!!".format(repository), owner, "Initial Commit")
|
// TODO synchronized?
|
||||||
} finally {
|
def createWikiRepository(owner: String, repository: String): Unit = {
|
||||||
repo.close
|
val dir = Directory.getWikiRepositoryDir(owner, repository)
|
||||||
}
|
if(!dir.exists){
|
||||||
}
|
val repo = new RepositoryBuilder().setGitDir(dir).setBare.build
|
||||||
}
|
try {
|
||||||
|
repo.create
|
||||||
/**
|
saveWikiPage(owner, repository, "Home", "Home", "Welcome to the %s wiki!!".format(repository), owner, "Initial Commit")
|
||||||
* Returns the wiki page.
|
} finally {
|
||||||
*/
|
repo.close
|
||||||
def getPage(owner: String, repository: String, pageName: String): Option[WikiPageInfo] = {
|
}
|
||||||
// TODO create wiki repository in the repository setting changing.
|
}
|
||||||
createWikiRepository(owner, repository)
|
}
|
||||||
|
|
||||||
JGitUtil.withGit(getWikiRepositoryDir(owner, repository)){ git =>
|
/**
|
||||||
try {
|
* Returns the wiki page.
|
||||||
JGitUtil.getFileList(git, "master", ".").find(_.name == pageName + ".md").map { file =>
|
*/
|
||||||
WikiPageInfo(file.name, new String(git.getRepository.open(file.id).getBytes, "UTF-8"), file.committer, file.time)
|
def getWikiPage(owner: String, repository: String, pageName: String): Option[WikiPageInfo] = {
|
||||||
}
|
// TODO create wiki repository in the repository setting changing.
|
||||||
} catch {
|
createWikiRepository(owner, repository)
|
||||||
// TODO no commit, but it should not judge by exception.
|
|
||||||
case e: NullPointerException => None
|
JGitUtil.withGit(Directory.getWikiRepositoryDir(owner, repository)){ git =>
|
||||||
}
|
try {
|
||||||
}
|
JGitUtil.getFileList(git, "master", ".").find(_.name == pageName + ".md").map { file =>
|
||||||
}
|
WikiPageInfo(file.name, new String(git.getRepository.open(file.id).getBytes, "UTF-8"), file.committer, file.time)
|
||||||
|
}
|
||||||
def getPageList(owner: String, repository: String): List[String] = {
|
} catch {
|
||||||
JGitUtil.getFileList(Git.open(getWikiRepositoryDir(owner, repository)), "master", ".")
|
// TODO no commit, but it should not judge by exception.
|
||||||
.filter(_.name.endsWith(".md"))
|
case e: NullPointerException => None
|
||||||
.map(_.name.replaceFirst("\\.md$", ""))
|
}
|
||||||
.sortBy(x => x)
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO synchronized
|
def getWikiPageList(owner: String, repository: String): List[String] = {
|
||||||
/**
|
JGitUtil.getFileList(Git.open(Directory.getWikiRepositoryDir(owner, repository)), "master", ".")
|
||||||
* Save the wiki page.
|
.filter(_.name.endsWith(".md"))
|
||||||
*/
|
.map(_.name.replaceFirst("\\.md$", ""))
|
||||||
def savePage(owner: String, repository: String, currentPageName: String, newPageName: String,
|
.sortBy(x => x)
|
||||||
content: String, committer: String, message: String): Unit = {
|
}
|
||||||
|
|
||||||
// TODO create wiki repository in the repository setting changing.
|
// TODO synchronized
|
||||||
createWikiRepository(owner, repository)
|
/**
|
||||||
|
* Save the wiki page.
|
||||||
val workDir = getWikiWorkDir(owner, repository)
|
*/
|
||||||
|
def saveWikiPage(owner: String, repository: String, currentPageName: String, newPageName: String,
|
||||||
// clone
|
content: String, committer: String, message: String): Unit = {
|
||||||
if(!workDir.exists){
|
|
||||||
Git.cloneRepository.setURI(getWikiRepositoryDir(owner, repository).toURI.toString).setDirectory(workDir).call
|
// TODO create wiki repository in the repository setting changing.
|
||||||
}
|
createWikiRepository(owner, repository)
|
||||||
|
|
||||||
// write as file
|
val workDir = Directory.getWikiWorkDir(owner, repository)
|
||||||
JGitUtil.withGit(workDir){ git =>
|
|
||||||
val file = new File(workDir, newPageName + ".md")
|
// clone
|
||||||
val added = if(!file.exists || FileUtils.readFileToString(file, "UTF-8") != content){
|
if(!workDir.exists){
|
||||||
FileUtils.writeStringToFile(file, content, "UTF-8")
|
Git.cloneRepository
|
||||||
git.add.addFilepattern(file.getName).call
|
.setURI(Directory.getWikiRepositoryDir(owner, repository).toURI.toString)
|
||||||
true
|
.setDirectory(workDir)
|
||||||
} else {
|
.call
|
||||||
false
|
}
|
||||||
}
|
|
||||||
|
// write as file
|
||||||
// delete file
|
JGitUtil.withGit(workDir){ git =>
|
||||||
val deleted = if(currentPageName != "" && currentPageName != newPageName){
|
val file = new File(workDir, newPageName + ".md")
|
||||||
git.rm.addFilepattern(currentPageName + ".md").call
|
val added = if(!file.exists || FileUtils.readFileToString(file, "UTF-8") != content){
|
||||||
true
|
FileUtils.writeStringToFile(file, content, "UTF-8")
|
||||||
} else {
|
git.add.addFilepattern(file.getName).call
|
||||||
false
|
true
|
||||||
}
|
} else {
|
||||||
|
false
|
||||||
// commit and push
|
}
|
||||||
if(added || deleted){
|
|
||||||
// TODO committer's mail address
|
// delete file
|
||||||
git.commit.setAuthor(committer, committer + "@devnull").setMessage(message).call
|
val deleted = if(currentPageName != "" && currentPageName != newPageName){
|
||||||
git.push.call
|
git.rm.addFilepattern(currentPageName + ".md").call
|
||||||
}
|
true
|
||||||
}
|
} else {
|
||||||
}
|
false
|
||||||
|
}
|
||||||
/**
|
|
||||||
* Delete the wiki page.
|
// commit and push
|
||||||
*/
|
if(added || deleted){
|
||||||
def deletePage(owner: String, repository: String, pageName: String, committer: String, message: String): Unit = {
|
// TODO committer's mail address
|
||||||
// TODO create wiki repository in the repository setting changing.
|
git.commit.setAuthor(committer, committer + "@devnull").setMessage(message).call
|
||||||
createWikiRepository(owner, repository)
|
git.push.call
|
||||||
|
}
|
||||||
val workDir = getWikiWorkDir(owner, repository)
|
}
|
||||||
|
}
|
||||||
// clone
|
|
||||||
if(!workDir.exists){
|
/**
|
||||||
Git.cloneRepository.setURI(getWikiRepositoryDir(owner, repository).toURI.toString).setDirectory(workDir).call
|
* Delete the wiki page.
|
||||||
}
|
*/
|
||||||
|
def deleteWikiPage(owner: String, repository: String, pageName: String, committer: String, message: String): Unit = {
|
||||||
// delete file
|
// TODO create wiki repository in the repository setting changing.
|
||||||
new File(workDir, pageName + ".md").delete
|
createWikiRepository(owner, repository)
|
||||||
|
|
||||||
JGitUtil.withGit(workDir){ git =>
|
val workDir = Directory.getWikiWorkDir(owner, repository)
|
||||||
git.rm.addFilepattern(pageName + ".md").call
|
|
||||||
|
// clone
|
||||||
// commit and push
|
if(!workDir.exists){
|
||||||
// TODO committer's mail address
|
Git.cloneRepository
|
||||||
git.commit.setAuthor(committer, committer + "@devnull").setMessage(message).call
|
.setURI(Directory.getWikiRepositoryDir(owner, repository).toURI.toString)
|
||||||
git.push.call
|
.setDirectory(workDir)
|
||||||
}
|
.call
|
||||||
}
|
}
|
||||||
|
|
||||||
def getDiffs(git: Git, commitId1: String, commitId2: String): List[DiffInfo] = {
|
// delete file
|
||||||
// get diff between specified commit and its previous commit
|
new File(workDir, pageName + ".md").delete
|
||||||
val reader = git.getRepository.newObjectReader
|
|
||||||
|
JGitUtil.withGit(workDir){ git =>
|
||||||
val oldTreeIter = new CanonicalTreeParser
|
git.rm.addFilepattern(pageName + ".md").call
|
||||||
oldTreeIter.reset(reader, git.getRepository.resolve(commitId1 + "^{tree}"))
|
|
||||||
|
// commit and push
|
||||||
val newTreeIter = new CanonicalTreeParser
|
// TODO committer's mail address
|
||||||
newTreeIter.reset(reader, git.getRepository.resolve(commitId2 + "^{tree}"))
|
git.commit.setAuthor(committer, committer + "@devnull").setMessage(message).call
|
||||||
|
git.push.call
|
||||||
import scala.collection.JavaConverters._
|
}
|
||||||
git.diff.setNewTree(newTreeIter).setOldTree(oldTreeIter).call.asScala.map { diff =>
|
}
|
||||||
DiffInfo(diff.getChangeType, diff.getOldPath, diff.getNewPath,
|
|
||||||
JGitUtil.getContent(git, diff.getOldId.toObjectId, false).map(new String(_, "UTF-8")),
|
def getWikiDiffs(git: Git, commitId1: String, commitId2: String): List[DiffInfo] = {
|
||||||
JGitUtil.getContent(git, diff.getNewId.toObjectId, false).map(new String(_, "UTF-8")))
|
// get diff between specified commit and its previous commit
|
||||||
}.toList
|
val reader = git.getRepository.newObjectReader
|
||||||
}
|
|
||||||
|
val oldTreeIter = new CanonicalTreeParser
|
||||||
}
|
oldTreeIter.reset(reader, git.getRepository.resolve(commitId1 + "^{tree}"))
|
||||||
|
|
||||||
|
val newTreeIter = new CanonicalTreeParser
|
||||||
|
newTreeIter.reset(reader, git.getRepository.resolve(commitId2 + "^{tree}"))
|
||||||
|
|
||||||
|
import scala.collection.JavaConverters._
|
||||||
|
git.diff.setNewTree(newTreeIter).setOldTree(oldTreeIter).call.asScala.map { diff =>
|
||||||
|
DiffInfo(diff.getChangeType, diff.getOldPath, diff.getNewPath,
|
||||||
|
JGitUtil.getContent(git, diff.getOldId.toObjectId, false).map(new String(_, "UTF-8")),
|
||||||
|
JGitUtil.getContent(git, diff.getNewId.toObjectId, false).map(new String(_, "UTF-8")))
|
||||||
|
}.toList
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -47,4 +47,16 @@ object Directory {
|
|||||||
def getInitRepositoryDir(owner: String, repository: String): File =
|
def getInitRepositoryDir(owner: String, repository: String): File =
|
||||||
new File("%s/tmp/%s/init-%s".format(GitBucketHome, owner, repository))
|
new File("%s/tmp/%s/init-%s".format(GitBucketHome, owner, repository))
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Substance directory of the wiki repository.
|
||||||
|
*/
|
||||||
|
def getWikiRepositoryDir(owner: String, repository: String): File =
|
||||||
|
new File("%s/%s/%s.wiki.git".format(Directory.RepositoryHome, owner, repository))
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Wiki working directory which is cloned from the wiki repository.
|
||||||
|
*/
|
||||||
|
def getWikiWorkDir(owner: String, repository: String): File =
|
||||||
|
new File("%s/tmp/%s/%s.wiki".format(Directory.GitBucketHome, owner, repository))
|
||||||
|
|
||||||
}
|
}
|
||||||
@@ -1,4 +1,4 @@
|
|||||||
@(pageName: String, page: util.WikiUtil.WikiPageInfo, repository: app.RepositoryInfo)(implicit context: app.Context)
|
@(pageName: String, page: service.WikiService.WikiPageInfo, repository: app.RepositoryInfo)(implicit context: app.Context)
|
||||||
@import view.helpers
|
@import view.helpers
|
||||||
@import context._
|
@import context._
|
||||||
@html.main(pageName + " - " + repository.owner + "/" + repository.name){
|
@html.main(pageName + " - " + repository.owner + "/" + repository.name){
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
@(pageName: String, page: Option[util.WikiUtil.WikiPageInfo], repository: app.RepositoryInfo)(implicit context: app.Context)
|
@(pageName: String, page: Option[service.WikiService.WikiPageInfo], repository: app.RepositoryInfo)(implicit context: app.Context)
|
||||||
@import view.helpers
|
@import view.helpers
|
||||||
@import context._
|
@import context._
|
||||||
@html.main((if(pageName == "") "New Page" else pageName) + " - " + repository.owner + "/" + repository.name){
|
@html.main((if(pageName == "") "New Page" else pageName) + " - " + repository.owner + "/" + repository.name){
|
||||||
|
|||||||
Reference in New Issue
Block a user