Welcome to mirror list, hosted at ThFree Co, Russian Federation.

HmacSha1.scala « util « rorschach « getbootstrap « com « scala « main « src - github.com/twbs/rorschach.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: 2856feaa3f1254c71e61ac3833a2a53e2653f585 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
package com.chrisrebert.lmvtfy.util

import javax.crypto.Mac
import javax.crypto.spec.SecretKeySpec
import java.security.{NoSuchAlgorithmException, InvalidKeyException, SignatureException}
import java.security.MessageDigest

object HmacSha1 {
  private val HmacSha1Algorithm = "HmacSHA1"

  implicit class HexByteArray(array: Array[Byte]) {
    import javax.xml.bind.DatatypeConverter
    def asHexBytes: String = DatatypeConverter.printHexBinary(array).toLowerCase
  }
}

case class HmacSha1(mac: Array[Byte], secretKey: Array[Byte], data: Array[Byte]) {
  import HmacSha1.HmacSha1Algorithm
  import HmacSha1.HexByteArray

  @throws[NoSuchAlgorithmException]("if HMAC-SHA1 is not supported")
  @throws[InvalidKeyException]("if the secret key is malformed")
  @throws[SignatureException]("under unknown circumstances")
  private lazy val correct: Array[Byte] = {
    val key = new SecretKeySpec(secretKey, HmacSha1Algorithm)
    val mac = Mac.getInstance(HmacSha1Algorithm)
    mac.init(key)
    mac.doFinal(data)
  }

  lazy val isValid: Boolean = MessageDigest.isEqual(mac, correct)

  def givenHex = mac.asHexBytes
  def correctHex = correct.asHexBytes
}