All Downloads are FREE. Search and download functionalities are using the official Maven repository.

gitbucket.core.model.CommitStatus.scala Maven / Gradle / Ivy

The newest version!
package gitbucket.core.model

trait CommitStatusComponent extends TemplateComponent { self: Profile =>
  import profile.api._
  import self._

  implicit val commitStateColumnType: BaseColumnType[CommitState] =
    MappedColumnType.base[CommitState, String](b => b.name, i => CommitState(i))

  lazy val CommitStatuses = TableQuery[CommitStatuses]
  class CommitStatuses(tag: Tag) extends Table[CommitStatus](tag, "COMMIT_STATUS") with CommitTemplate {
    val commitStatusId = column[Int]("COMMIT_STATUS_ID", O AutoInc)
    val context = column[String]("CONTEXT")
    val state = column[CommitState]("STATE")
    val targetUrl = column[Option[String]]("TARGET_URL")
    val description = column[Option[String]]("DESCRIPTION")
    val creator = column[String]("CREATOR")
    val registeredDate = column[java.util.Date]("REGISTERED_DATE")
    val updatedDate = column[java.util.Date]("UPDATED_DATE")
    def * =
      (
        commitStatusId,
        userName,
        repositoryName,
        commitId,
        context,
        state,
        targetUrl,
        description,
        creator,
        registeredDate,
        updatedDate
      ).mapTo[CommitStatus]
    def byPrimaryKey(id: Int) = commitStatusId === id.bind
  }
}

case class CommitStatus(
  commitStatusId: Int = 0,
  userName: String,
  repositoryName: String,
  commitId: String,
  context: String,
  state: CommitState,
  targetUrl: Option[String],
  description: Option[String],
  creator: String,
  registeredDate: java.util.Date,
  updatedDate: java.util.Date
)
object CommitStatus {
  def pending(owner: String, repository: String, context: String) =
    CommitStatus(
      commitStatusId = 0,
      userName = owner,
      repositoryName = repository,
      commitId = "",
      context = context,
      state = CommitState.PENDING,
      targetUrl = None,
      description = Some("Waiting for status to be reported"),
      creator = "",
      registeredDate = new java.util.Date(),
      updatedDate = new java.util.Date()
    )
}

sealed abstract class CommitState(val name: String)

object CommitState {
  object ERROR extends CommitState("error")

  object FAILURE extends CommitState("failure")

  object PENDING extends CommitState("pending")

  object SUCCESS extends CommitState("success")

  val values: Vector[CommitState] = Vector(PENDING, SUCCESS, ERROR, FAILURE)

  private val map: Map[String, CommitState] = values.map(e => e.name -> e).toMap

  def apply(name: String): CommitState = map(name)

  def valueOf(name: String): Option[CommitState] = map.get(name)

  /**
   * failure if any of the contexts report as error or failure
   * pending if there are no statuses or a context is pending
   * success if the latest status for all contexts is success
   */
  def combine(statuses: Set[CommitState]): CommitState = {
    if (statuses.isEmpty) {
      PENDING
    } else if (statuses.contains(CommitState.ERROR) || statuses.contains(CommitState.FAILURE)) {
      FAILURE
    } else if (statuses.contains(CommitState.PENDING)) {
      PENDING
    } else {
      SUCCESS
    }
  }

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy