Newer
Older
GitBucket / src / main / scala / gitbucket / core / service / GpgKeyService.scala
@Yuusuke KOUNOIKE Yuusuke KOUNOIKE on 16 Mar 2019 1 KB Verify gpg sign (#2264)
package gitbucket.core.service

import java.io.ByteArrayInputStream

import gitbucket.core.model.GpgKey

import collection.JavaConverters._
import gitbucket.core.model.Profile._
import gitbucket.core.model.Profile.profile.blockingApi._
import org.bouncycastle.bcpg.ArmoredInputStream
import org.bouncycastle.openpgp.PGPPublicKeyRing
import org.bouncycastle.openpgp.bc.BcPGPObjectFactory

trait GpgKeyService {
  def getGpgPublicKeys(userName: String)(implicit s: Session): List[GpgKey] =
    GpgKeys.filter(_.userName === userName.bind).sortBy(_.gpgKeyId).list

  def addGpgPublicKey(userName: String, title: String, publicKey: String)(implicit s: Session): Unit = {
    val pubKeyOf = new BcPGPObjectFactory(new ArmoredInputStream(new ByteArrayInputStream(publicKey.getBytes)))
    pubKeyOf.iterator().asScala.foreach {
      case keyRing: PGPPublicKeyRing =>
        val key = keyRing.getPublicKey()
        GpgKeys.insert(GpgKey(userName = userName, gpgKeyId = key.getKeyID, title = title, publicKey = publicKey))
    }
  }

  def deleteGpgPublicKey(userName: String, keyId: Int)(implicit s: Session): Unit =
    GpgKeys.filter(_.byPrimaryKey(userName, keyId)).delete
}