mirror of
https://github.com/corda/corda.git
synced 2025-01-09 06:23:04 +00:00
37 lines
1.5 KiB
Kotlin
37 lines
1.5 KiB
Kotlin
|
import com.google.common.io.BaseEncoding
|
||
|
import java.security.MessageDigest
|
||
|
import java.security.PublicKey
|
||
|
|
||
|
// "sealed" here means there can't be any subclasses other than the ones defined here.
|
||
|
sealed class SecureHash(val bits: ByteArray) {
|
||
|
class SHA256(bits: ByteArray) : SecureHash(bits) {
|
||
|
init { require(bits.size == 32) }
|
||
|
}
|
||
|
|
||
|
// Like static methods in Java, except the 'companion' is a singleton that can have state.
|
||
|
companion object {
|
||
|
fun parse(str: String) = BaseEncoding.base16().decode(str.toLowerCase()).let {
|
||
|
when (it.size) {
|
||
|
32 -> SecureHash.SHA256(it)
|
||
|
else -> throw IllegalArgumentException("Provided string is not 32 bytes in base 16 (hex): $str")
|
||
|
}
|
||
|
}
|
||
|
|
||
|
fun sha256(bits: ByteArray) = SHA256(MessageDigest.getInstance("SHA-256").digest(bits))
|
||
|
fun sha256(str: String) = sha256(str.toByteArray())
|
||
|
}
|
||
|
|
||
|
// In future, maybe SHA3, truncated hashes etc.
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* A wrapper around a digital signature. The covering field is a generic tag usable by whatever is interpreting the
|
||
|
* signature.
|
||
|
*/
|
||
|
sealed class DigitalSignature(val bits: ByteArray, val covering: Int) {
|
||
|
/** A digital signature that identifies who the public key is owned by */
|
||
|
open class WithKey(val by: PublicKey, bits: ByteArray, covering: Int) : DigitalSignature(bits, covering)
|
||
|
class LegallyIdentifiable(val signer: Institution, bits: ByteArray, covering: Int) : WithKey(signer.owningKey, bits, covering)
|
||
|
}
|
||
|
|