Newer
Older
gitbucket_jkp / src / main / scala / service / ProjectService.scala
package service

import model._
import scala.slick.driver.H2Driver.simple._
import Database.threadLocalSession
import util.JGitUtil
import javax.servlet.ServletContext

trait ProjectService { self: AccountService =>
  import ProjectService._

  /**
   * Creates a new project.
   *
   * The project is created as public repository at first. Users can modify the project type at the repository settings
   * page after the project creation to configure the project as the private repository.
   *
   * @param projectName the project name
   * @param userName the user name of the project owner
   * @param description the project description
   * @return the created project id
   */
  def createProject(projectName: String, userName: String, description: Option[String]): Long = {
    // TODO create a git repository also here?

    val currentDate = new java.sql.Date(System.currentTimeMillis)

    Projects.ins returning Projects.projectId insert
      Project(
        projectId        = None,
        projectName      = projectName,
        userId           = getUserId(userName),
        projectType      = 0  /* 0:public, 1:private */,
        description      = description,
        defaultBranch    = "master",
        registeredDate   = currentDate,
        updatedDate      = currentDate,
        lastActivityDate = currentDate)
  }

  /**
   * Returns the specified user's project list.
   *
   * @param userName the user name
   * @return the project list which is sorted in descending order of lastActivityDate.
   */
  def getRepositories(userName: String, servletContext: ServletContext): List[RepositoryInfo] = {
    (Query(Projects) filter(_.userId is getUserId(userName).bind) sortBy(_.lastActivityDate desc) list) map { project =>
      val repositoryInfo = JGitUtil.getRepositoryInfo(userName, project.projectName, servletContext)
      RepositoryInfo(userName, project.projectName, repositoryInfo.url, project, repositoryInfo.branchList, repositoryInfo.tags)
    }
  }

  def getRepository(userName: String, projectName: String, servletContext: ServletContext): Option[RepositoryInfo] = {
    (Query(Projects) filter { project =>
      (project.userId is getUserId(userName).bind) && (project.projectName is projectName.bind)
    } firstOption) map { project =>
      val repositoryInfo = JGitUtil.getRepositoryInfo(userName, project.projectName, servletContext)
      RepositoryInfo(userName, project.projectName, repositoryInfo.url, project, repositoryInfo.branchList, repositoryInfo.tags)
    }
  }

  private def getUserId(userName: String): Long = getAccountByUserName(userName).get.userId.get

}

object ProjectService {
  case class RepositoryInfo(owner: String, name: String, url: String, project: Project, branchList: List[String], tags: List[util.JGitUtil.TagInfo])
}