mirror of
https://github.com/corda/corda.git
synced 2025-01-01 02:36:44 +00:00
Merge branch 'enterprise' into mike-enterprise-merge-june-21st
This commit is contained in:
commit
ddad4e1ac4
@ -5,10 +5,12 @@ import net.corda.core.crypto.SecureHash
|
|||||||
import net.corda.core.crypto.commonName
|
import net.corda.core.crypto.commonName
|
||||||
import net.corda.node.utilities.instant
|
import net.corda.node.utilities.instant
|
||||||
import net.corda.node.utilities.transaction
|
import net.corda.node.utilities.transaction
|
||||||
|
import org.apache.commons.io.IOUtils
|
||||||
import org.bouncycastle.pkcs.PKCS10CertificationRequest
|
import org.bouncycastle.pkcs.PKCS10CertificationRequest
|
||||||
import org.jetbrains.exposed.sql.*
|
import org.jetbrains.exposed.sql.*
|
||||||
import java.security.cert.Certificate
|
import java.security.cert.Certificate
|
||||||
import java.time.Instant
|
import java.time.Instant
|
||||||
|
import javax.sql.rowset.serial.SerialBlob
|
||||||
|
|
||||||
// TODO Relax the uniqueness requirement to be on the entire X.500 subject rather than just the legal name
|
// TODO Relax the uniqueness requirement to be on the entire X.500 subject rather than just the legal name
|
||||||
class DBCertificateRequestStorage(private val database: Database) : CertificationRequestStorage {
|
class DBCertificateRequestStorage(private val database: Database) : CertificationRequestStorage {
|
||||||
@ -18,10 +20,10 @@ class DBCertificateRequestStorage(private val database: Database) : Certificatio
|
|||||||
val ipAddress = varchar("ip_address", 15)
|
val ipAddress = varchar("ip_address", 15)
|
||||||
val legalName = varchar("legal_name", 256)
|
val legalName = varchar("legal_name", 256)
|
||||||
// TODO : Do we need to store this in column? or is it ok with blob.
|
// TODO : Do we need to store this in column? or is it ok with blob.
|
||||||
val request = binary("request", 256)
|
val request = blob("request")
|
||||||
val requestTimestamp = instant("request_timestamp")
|
val requestTimestamp = instant("request_timestamp")
|
||||||
val processTimestamp = instant("process_timestamp").nullable()
|
val processTimestamp = instant("process_timestamp").nullable()
|
||||||
val certificate = binary("certificate", 1024).nullable()
|
val certificate = blob("certificate").nullable()
|
||||||
val rejectReason = varchar("reject_reason", 256).nullable()
|
val rejectReason = varchar("reject_reason", 256).nullable()
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -54,7 +56,7 @@ class DBCertificateRequestStorage(private val database: Database) : Certificatio
|
|||||||
it[hostName] = certificationData.hostName
|
it[hostName] = certificationData.hostName
|
||||||
it[ipAddress] = certificationData.ipAddress
|
it[ipAddress] = certificationData.ipAddress
|
||||||
it[this.legalName] = legalName
|
it[this.legalName] = legalName
|
||||||
it[request] = certificationData.request.encoded
|
it[request] = SerialBlob(certificationData.request.encoded)
|
||||||
it[requestTimestamp] = now
|
it[requestTimestamp] = now
|
||||||
if (rejectReason != null) {
|
if (rejectReason != null) {
|
||||||
it[this.rejectReason] = rejectReason
|
it[this.rejectReason] = rejectReason
|
||||||
@ -69,7 +71,7 @@ class DBCertificateRequestStorage(private val database: Database) : Certificatio
|
|||||||
return database.transaction {
|
return database.transaction {
|
||||||
val response = DataTable
|
val response = DataTable
|
||||||
.select { DataTable.requestId eq requestId and DataTable.processTimestamp.isNotNull() }
|
.select { DataTable.requestId eq requestId and DataTable.processTimestamp.isNotNull() }
|
||||||
.map { Pair(it[DataTable.certificate], it[DataTable.rejectReason]) }
|
.map { Pair(it[DataTable.certificate]?.let { IOUtils.toByteArray(it.binaryStream) }, it[DataTable.rejectReason]) }
|
||||||
.singleOrNull()
|
.singleOrNull()
|
||||||
if (response == null) {
|
if (response == null) {
|
||||||
CertificateResponse.NotReady
|
CertificateResponse.NotReady
|
||||||
@ -89,7 +91,7 @@ class DBCertificateRequestStorage(private val database: Database) : Certificatio
|
|||||||
val request = singleRequestWhere { DataTable.requestId eq requestId and DataTable.processTimestamp.isNull() }
|
val request = singleRequestWhere { DataTable.requestId eq requestId and DataTable.processTimestamp.isNull() }
|
||||||
if (request != null) {
|
if (request != null) {
|
||||||
DataTable.update({ DataTable.requestId eq requestId }) {
|
DataTable.update({ DataTable.requestId eq requestId }) {
|
||||||
it[certificate] = request.generateCertificate().encoded
|
it[certificate] = SerialBlob(request.generateCertificate().encoded)
|
||||||
it[processTimestamp] = Instant.now()
|
it[processTimestamp] = Instant.now()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -125,7 +127,7 @@ class DBCertificateRequestStorage(private val database: Database) : Certificatio
|
|||||||
private fun singleRequestWhere(where: SqlExpressionBuilder.() -> Op<Boolean>): CertificationRequestData? {
|
private fun singleRequestWhere(where: SqlExpressionBuilder.() -> Op<Boolean>): CertificationRequestData? {
|
||||||
return DataTable
|
return DataTable
|
||||||
.select(where)
|
.select(where)
|
||||||
.map { CertificationRequestData(it[DataTable.hostName], it[DataTable.ipAddress], PKCS10CertificationRequest(it[DataTable.request])) }
|
.map { CertificationRequestData(it[DataTable.hostName], it[DataTable.ipAddress], PKCS10CertificationRequest(IOUtils.toByteArray(it[DataTable.request].binaryStream))) }
|
||||||
.singleOrNull()
|
.singleOrNull()
|
||||||
}
|
}
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user