Small clean-up (#98)

* Small clean-up

* Unifying enum casing

* Adding TODOs
This commit is contained in:
mkit 2017-11-14 09:44:48 +00:00 committed by GitHub
parent 1ec40ee983
commit 40cf4ad191
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
20 changed files with 4522 additions and 55 deletions

View File

@ -124,6 +124,7 @@ dependencies {
testCompile "com.nhaarman:mockito-kotlin:0.6.1" testCompile "com.nhaarman:mockito-kotlin:0.6.1"
testRuntime "net.corda:corda-rpc:$corda_dependency_version" testRuntime "net.corda:corda-rpc:$corda_dependency_version"
testCompile "com.spotify:docker-client:8.9.1" testCompile "com.spotify:docker-client:8.9.1"
integrationTestCompile "net.corda:corda-test-utils:$corda_dependency_version"
integrationTestRuntime "net.corda:corda-rpc:$corda_dependency_version" integrationTestRuntime "net.corda:corda-rpc:$corda_dependency_version"
compile('com.atlassian.jira:jira-rest-java-client-core:4.0.0') { compile('com.atlassian.jira:jira-rest-java-client-core:4.0.0') {

View File

@ -23,12 +23,12 @@ import java.util.*
*/ */
fun main(args: Array<String>) { fun main(args: Array<String>) {
run(Parameters( run(Parameters(
dataSourceProperties = makeTestDataSourceProperties("localhost"), dataSourceProperties = makeTestDataSourceProperties(),
databaseProperties = makeNotInitialisingTestDatabaseProperties() databaseProperties = makeNotInitialisingTestDatabaseProperties()
)) ))
} }
private fun makeTestDataSourceProperties(nodeName: String): Properties { private fun makeTestDataSourceProperties(): Properties {
val props = Properties() val props = Properties()
props.setProperty("dataSourceClassName", "org.h2.jdbcx.JdbcDataSource") props.setProperty("dataSourceClassName", "org.h2.jdbcx.JdbcDataSource")
props.setProperty("dataSource.url", "jdbc:h2:tcp://$HOST:$H2_TCP_PORT/mem:$DB_NAME;DB_CLOSE_DELAY=-1") props.setProperty("dataSource.url", "jdbc:h2:tcp://$HOST:$H2_TCP_PORT/mem:$DB_NAME;DB_CLOSE_DELAY=-1")

View File

@ -57,7 +57,7 @@ interface CertificationRequestStorage {
fun rejectRequest(requestId: String, rejectedBy: String, rejectReason: String) fun rejectRequest(requestId: String, rejectedBy: String, rejectReason: String)
/** /**
* Store certificate path with [requestId], this will store the encoded [CertPath] and transit request status to [RequestStatus.Signed]. * Store certificate path with [requestId], this will store the encoded [CertPath] and transit request status to [RequestStatus.SIGNED].
* @param requestId id of the certificate signing request * @param requestId id of the certificate signing request
* @param signedBy authority (its identifier) signing this request. * @param signedBy authority (its identifier) signing this request.
* @throws IllegalArgumentException if request is not found or not in Approved state. * @throws IllegalArgumentException if request is not found or not in Approved state.
@ -71,16 +71,10 @@ sealed class CertificateResponse {
data class Unauthorised(val message: String) : CertificateResponse() data class Unauthorised(val message: String) : CertificateResponse()
} }
/** enum class RequestStatus {
* Describes certificate status NEW, APPROVED, REJECTED, SIGNED
*/ }
enum class CertificateStatus { enum class CertificateStatus {
VALID, SUSPENDED, REVOKED VALID, SUSPENDED, REVOKED
} }
/**
* Describes entire certificate signing request status
*/
enum class RequestStatus {
New, Approved, Rejected, Signed
}

View File

@ -22,7 +22,7 @@ class PersistentCertificateRequestStorage(private val database: CordaPersistence
return database.transaction(Connection.TRANSACTION_SERIALIZABLE) { return database.transaction(Connection.TRANSACTION_SERIALIZABLE) {
val request = singleRequestWhere(CertificateSigningRequestEntity::class.java) { builder, path -> val request = singleRequestWhere(CertificateSigningRequestEntity::class.java) { builder, path ->
val requestIdEq = builder.equal(path.get<String>(CertificateSigningRequestEntity::requestId.name), requestId) val requestIdEq = builder.equal(path.get<String>(CertificateSigningRequestEntity::requestId.name), requestId)
val statusEq = builder.equal(path.get<String>(CertificateSigningRequestEntity::status.name), RequestStatus.Approved) val statusEq = builder.equal(path.get<String>(CertificateSigningRequestEntity::status.name), RequestStatus.APPROVED)
builder.and(requestIdEq, statusEq) builder.and(requestIdEq, statusEq)
} }
request ?: throw IllegalArgumentException("Cannot retrieve 'APPROVED' certificate signing request for request id: $requestId") request ?: throw IllegalArgumentException("Cannot retrieve 'APPROVED' certificate signing request for request id: $requestId")
@ -30,7 +30,7 @@ class PersistentCertificateRequestStorage(private val database: CordaPersistence
val certificateSigningRequest = request.copy( val certificateSigningRequest = request.copy(
modifiedBy = signedBy, modifiedBy = signedBy,
modifiedAt = Instant.now(), modifiedAt = Instant.now(),
status = RequestStatus.Signed) status = RequestStatus.SIGNED)
session.merge(certificateSigningRequest) session.merge(certificateSigningRequest)
val certificateDataEntity = CertificateDataEntity( val certificateDataEntity = CertificateDataEntity(
publicKeyHash = publicKeyHash, publicKeyHash = publicKeyHash,
@ -51,7 +51,7 @@ class PersistentCertificateRequestStorage(private val database: CordaPersistence
requestBytes = request.encoded, requestBytes = request.encoded,
remark = rejectReason, remark = rejectReason,
modifiedBy = emptyList(), modifiedBy = emptyList(),
status = if (rejectReason == null) RequestStatus.New else RequestStatus.Rejected status = if (rejectReason == null) RequestStatus.NEW else RequestStatus.REJECTED
)) ))
} }
return requestId return requestId
@ -61,13 +61,13 @@ class PersistentCertificateRequestStorage(private val database: CordaPersistence
return database.transaction(Connection.TRANSACTION_SERIALIZABLE) { return database.transaction(Connection.TRANSACTION_SERIALIZABLE) {
val request = singleRequestWhere(CertificateSigningRequestEntity::class.java) { builder, path -> val request = singleRequestWhere(CertificateSigningRequestEntity::class.java) { builder, path ->
builder.and(builder.equal(path.get<String>(CertificateSigningRequestEntity::requestId.name), requestId), builder.and(builder.equal(path.get<String>(CertificateSigningRequestEntity::requestId.name), requestId),
builder.equal(path.get<String>(CertificateSigningRequestEntity::status.name), RequestStatus.New)) builder.equal(path.get<String>(CertificateSigningRequestEntity::status.name), RequestStatus.NEW))
} }
request ?: throw IllegalArgumentException("Error when approving request with id: $requestId. Request does not exist or its status is not NEW.") request ?: throw IllegalArgumentException("Error when approving request with id: $requestId. Request does not exist or its status is not NEW.")
val update = request.copy( val update = request.copy(
modifiedBy = listOf(approvedBy), modifiedBy = listOf(approvedBy),
modifiedAt = Instant.now(), modifiedAt = Instant.now(),
status = RequestStatus.Approved) status = RequestStatus.APPROVED)
session.merge(update) session.merge(update)
} }
} }
@ -81,7 +81,7 @@ class PersistentCertificateRequestStorage(private val database: CordaPersistence
val update = request.copy( val update = request.copy(
modifiedBy = listOf(rejectedBy), modifiedBy = listOf(rejectedBy),
modifiedAt = Instant.now(), modifiedAt = Instant.now(),
status = RequestStatus.Rejected, status = RequestStatus.REJECTED,
remark = rejectReason remark = rejectReason
) )
session.merge(update) session.merge(update)
@ -121,7 +121,7 @@ class PersistentCertificateRequestStorage(private val database: CordaPersistence
} }
} }
val duplicates = session.createQuery(query).resultList.filter { val duplicates = session.createQuery(query).resultList.filter {
it.status == RequestStatus.New || it.status == RequestStatus.Approved || it.certificateData?.certificateStatus == CertificateStatus.VALID it.status == RequestStatus.NEW || it.status == RequestStatus.APPROVED || it.certificateData?.certificateStatus == CertificateStatus.VALID
} }
return if (duplicates.isEmpty()) { return if (duplicates.isEmpty()) {
Pair(legalName.x500Name, null) Pair(legalName.x500Name, null)

View File

@ -68,7 +68,7 @@ class PersistentNetworkMapStorage(private val database: CordaPersistence) : Netw
val networkMapEntity = getCurrentNetworkMapEntity(getNetworkMapWithNodeInfoAndCsrHint(session)) val networkMapEntity = getCurrentNetworkMapEntity(getNetworkMapWithNodeInfoAndCsrHint(session))
if (networkMapEntity != null) { if (networkMapEntity != null) {
networkMapEntity.nodeInfoList.filter({ networkMapEntity.nodeInfoList.filter({
certificateStatuses == null || certificateStatuses.isEmpty() || certificateStatuses.contains(it.certificateSigningRequest?.certificateData?.certificateStatus) certificateStatuses.isEmpty() || certificateStatuses.contains(it.certificateSigningRequest?.certificateData?.certificateStatus)
}).map { SecureHash.parse(it.nodeInfoHash) } }).map { SecureHash.parse(it.nodeInfoHash) }
} else { } else {
emptyList() emptyList()

View File

@ -25,7 +25,7 @@ class CertificateSigningRequestEntity(
@Audited @Audited
@Column(name = "status", nullable = false) @Column(name = "status", nullable = false)
@Enumerated(EnumType.STRING) @Enumerated(EnumType.STRING)
val status: RequestStatus = RequestStatus.New, val status: RequestStatus = RequestStatus.NEW,
@Audited @Audited
@Column(name = "modified_by", length = 512) @Column(name = "modified_by", length = 512)

View File

@ -35,7 +35,7 @@ class NetworkMapSigner(private val networkMapStorage: NetworkMapStorage,
val nodeInfoHashes = currentNetworkMapValidNodeInfo + detachedValidNodeInfo val nodeInfoHashes = currentNetworkMapValidNodeInfo + detachedValidNodeInfo
val networkParameters = networkMapStorage.getLatestNetworkParameters() val networkParameters = networkMapStorage.getLatestNetworkParameters()
val networkMap = NetworkMap(nodeInfoHashes.map { it.toString() }, networkParameters.serialize().hash.toString()) val networkMap = NetworkMap(nodeInfoHashes.map { it.toString() }, networkParameters.serialize().hash.toString())
if (currentSignedNetworkMap == null || networkMap != currentSignedNetworkMap.networkMap) { if (networkMap != currentSignedNetworkMap.networkMap) {
val digitalSignature = signer.sign(networkMap.serialize().bytes) val digitalSignature = signer.sign(networkMap.serialize().bytes)
require(digitalSignature != null) { "Error while signing network map." } require(digitalSignature != null) { "Error while signing network map." }
val signedHashedNetworkMap = SignedNetworkMap(networkMap, digitalSignature!!) val signedHashedNetworkMap = SignedNetworkMap(networkMap, digitalSignature!!)

View File

@ -15,7 +15,7 @@ interface CsrHandler {
class DefaultCsrHandler(private val storage: CertificationRequestStorage, private val signer: LocalSigner?) : CsrHandler { class DefaultCsrHandler(private val storage: CertificationRequestStorage, private val signer: LocalSigner?) : CsrHandler {
override fun processApprovedRequests() { override fun processApprovedRequests() {
storage.getRequests(RequestStatus.Approved) storage.getRequests(RequestStatus.APPROVED)
.forEach { processRequest(it.requestId, it.request) } .forEach { processRequest(it.requestId, it.request) }
} }
@ -35,9 +35,9 @@ class DefaultCsrHandler(private val storage: CertificationRequestStorage, privat
override fun getResponse(requestId: String): CertificateResponse { override fun getResponse(requestId: String): CertificateResponse {
val response = storage.getRequest(requestId) val response = storage.getRequest(requestId)
return when (response?.status) { return when (response?.status) {
RequestStatus.New, RequestStatus.Approved, null -> CertificateResponse.NotReady RequestStatus.NEW, RequestStatus.APPROVED, null -> CertificateResponse.NotReady
RequestStatus.Rejected -> CertificateResponse.Unauthorised(response.remark ?: "Unknown reason") RequestStatus.REJECTED -> CertificateResponse.Unauthorised(response.remark ?: "Unknown reason")
RequestStatus.Signed -> CertificateResponse.Ready(response.certData?.certPath?: throw IllegalArgumentException("Certificate should not be null.")) RequestStatus.SIGNED -> CertificateResponse.Ready(response.certData?.certPath ?: throw IllegalArgumentException("Certificate should not be null."))
} }
} }
} }
@ -55,7 +55,7 @@ class JiraCsrHandler(private val jiraClient: JiraClient, private val storage: Ce
override fun processApprovedRequests() { override fun processApprovedRequests() {
jiraClient.getApprovedRequests().forEach { (id, approvedBy) -> storage.approveRequest(id, approvedBy) } jiraClient.getApprovedRequests().forEach { (id, approvedBy) -> storage.approveRequest(id, approvedBy) }
delegate.processApprovedRequests() delegate.processApprovedRequests()
val signedRequests = storage.getRequests(RequestStatus.Signed).mapNotNull { val signedRequests = storage.getRequests(RequestStatus.SIGNED).mapNotNull {
it.certData?.certPath.let { certs -> it.requestId to certs!! } it.certData?.certPath.let { certs -> it.requestId to certs!! }
}.toMap() }.toMap()
jiraClient.updateSignedRequests(signedRequests) jiraClient.updateSignedRequests(signedRequests)

View File

@ -1,6 +1,6 @@
package com.r3.corda.networkmanage.hsm.authentication package com.r3.corda.networkmanage.hsm.authentication
/* /**
* Supported authentication modes * Supported authentication modes
*/ */
enum class AuthMode { enum class AuthMode {

View File

@ -8,6 +8,9 @@ import java.io.Console
import java.nio.file.Path import java.nio.file.Path
import kotlin.reflect.full.memberProperties import kotlin.reflect.full.memberProperties
/**
* Performs user authentication against the HSM
*/
class Authenticator(private val provider: CryptoServerProvider, class Authenticator(private val provider: CryptoServerProvider,
private val mode: AuthMode = AuthMode.PASSWORD, private val mode: AuthMode = AuthMode.PASSWORD,
private val autoUsername: String? = null, private val autoUsername: String? = null,

View File

@ -1,5 +1,9 @@
package com.r3.corda.networkmanage.hsm.menu package com.r3.corda.networkmanage.hsm.menu
/**
* Single menu item described by the selection [key], label associated with this item, action to be executed on response
* to the item selection and termination flag used to decide whether to loop after action completion.
*/
data class MenuItem(val key: String, val label: String, val action: () -> Unit, val isTerminating: Boolean = false) data class MenuItem(val key: String, val label: String, val action: () -> Unit, val isTerminating: Boolean = false)
/** /**

View File

@ -20,7 +20,7 @@ class DBSignedCertificateRequestStorage(database: CordaPersistence) : SignedCert
} }
override fun getApprovedRequests(): List<ApprovedCertificateRequestData> { override fun getApprovedRequests(): List<ApprovedCertificateRequestData> {
return storage.getRequests(RequestStatus.Approved).map { it.toRequestData() } return storage.getRequests(RequestStatus.APPROVED).map { it.toRequestData() }
} }
private fun CertificateSigningRequest.toRequestData() = ApprovedCertificateRequestData(requestId, request) private fun CertificateSigningRequest.toRequestData() = ApprovedCertificateRequestData(requestId, request)

View File

@ -7,6 +7,7 @@ import java.util.*
* CryptoServer error translator object. * CryptoServer error translator object.
* It holds mapping between CryptoServer error code to its human readable description. * It holds mapping between CryptoServer error code to its human readable description.
*/ */
// TODO this code (incl. the hsm_errors file) is duplicated with the SGX module
object HsmErrors { object HsmErrors {
val errors: Map<Int, String> by lazy(HsmErrors::load) val errors: Map<Int, String> by lazy(HsmErrors::load)

View File

@ -25,7 +25,7 @@ abstract class TestBase {
protected fun certificateSigningRequestEntity( protected fun certificateSigningRequestEntity(
requestId: String = SecureHash.randomSHA256().toString(), requestId: String = SecureHash.randomSHA256().toString(),
status: RequestStatus = RequestStatus.New, status: RequestStatus = RequestStatus.NEW,
legalName: String = "TestLegalName", legalName: String = "TestLegalName",
modifiedBy: List<String> = emptyList(), modifiedBy: List<String> = emptyList(),
modifiedAt: Instant = Instant.now(), modifiedAt: Instant = Instant.now(),
@ -47,7 +47,7 @@ abstract class TestBase {
protected fun certificateSigningRequest( protected fun certificateSigningRequest(
requestId: String = SecureHash.randomSHA256().toString(), requestId: String = SecureHash.randomSHA256().toString(),
status: RequestStatus = RequestStatus.New, status: RequestStatus = RequestStatus.NEW,
legalName: String = "TestLegalName", legalName: String = "TestLegalName",
remark: String = "Test remark", remark: String = "Test remark",
request: PKCS10CertificationRequest = mock(), request: PKCS10CertificationRequest = mock(),

View File

@ -46,7 +46,7 @@ class DBCertificateRequestStorageTest : TestBase() {
assertNotNull(storage.getRequest(requestId)).apply { assertNotNull(storage.getRequest(requestId)).apply {
assertEquals(request, this.request) assertEquals(request, this.request)
} }
assertThat(storage.getRequests(RequestStatus.New).map { it.requestId }).containsOnly(requestId) assertThat(storage.getRequests(RequestStatus.NEW).map { it.requestId }).containsOnly(requestId)
} }
@Test @Test
@ -55,7 +55,7 @@ class DBCertificateRequestStorageTest : TestBase() {
// Add request to DB. // Add request to DB.
val requestId = storage.saveRequest(request) val requestId = storage.saveRequest(request)
// Pending request should equals to 1. // Pending request should equals to 1.
assertEquals(1, storage.getRequests(RequestStatus.New).size) assertEquals(1, storage.getRequests(RequestStatus.NEW).size)
// Certificate should be empty. // Certificate should be empty.
assertNull(storage.getRequest(requestId)!!.certData) assertNull(storage.getRequest(requestId)!!.certData)
// Store certificate to DB. // Store certificate to DB.
@ -63,7 +63,7 @@ class DBCertificateRequestStorageTest : TestBase() {
// Check request is not ready yet. // Check request is not ready yet.
// assertTrue(storage.getResponse(requestId) is CertificateResponse.NotReady) // assertTrue(storage.getResponse(requestId) is CertificateResponse.NotReady)
// New request should be empty. // New request should be empty.
assertTrue(storage.getRequests(RequestStatus.New).isEmpty()) assertTrue(storage.getRequests(RequestStatus.NEW).isEmpty())
} }
@Test @Test
@ -91,15 +91,15 @@ class DBCertificateRequestStorageTest : TestBase() {
// Add request to DB. // Add request to DB.
val requestId = storage.saveRequest(csr) val requestId = storage.saveRequest(csr)
// New request should equals to 1. // New request should equals to 1.
assertEquals(1, storage.getRequests(RequestStatus.New).size) assertEquals(1, storage.getRequests(RequestStatus.NEW).size)
// Certificate should be empty. // Certificate should be empty.
assertNull(storage.getRequest(requestId)!!.certData) assertNull(storage.getRequest(requestId)!!.certData)
// Store certificate to DB. // Store certificate to DB.
storage.approveRequest(requestId, DOORMAN_SIGNATURE) storage.approveRequest(requestId, DOORMAN_SIGNATURE)
// Check request is not ready yet. // Check request is not ready yet.
assertEquals(RequestStatus.Approved, storage.getRequest(requestId)!!.status) assertEquals(RequestStatus.APPROVED, storage.getRequest(requestId)!!.status)
// New request should be empty. // New request should be empty.
assertTrue(storage.getRequests(RequestStatus.New).isEmpty()) assertTrue(storage.getRequests(RequestStatus.NEW).isEmpty())
// Sign certificate // Sign certificate
storage.putCertificatePath(requestId, JcaPKCS10CertificationRequest(csr).run { storage.putCertificatePath(requestId, JcaPKCS10CertificationRequest(csr).run {
val rootCAKey = Crypto.generateKeyPair(X509Utilities.DEFAULT_TLS_SIGNATURE_SCHEME) val rootCAKey = Crypto.generateKeyPair(X509Utilities.DEFAULT_TLS_SIGNATURE_SCHEME)
@ -146,21 +146,21 @@ class DBCertificateRequestStorageTest : TestBase() {
fun `reject request`() { fun `reject request`() {
val requestId = storage.saveRequest(createRequest("BankA").first) val requestId = storage.saveRequest(createRequest("BankA").first)
storage.rejectRequest(requestId, DOORMAN_SIGNATURE, "Because I said so!") storage.rejectRequest(requestId, DOORMAN_SIGNATURE, "Because I said so!")
assertThat(storage.getRequests(RequestStatus.New)).isEmpty() assertThat(storage.getRequests(RequestStatus.NEW)).isEmpty()
assertThat(storage.getRequest(requestId)!!.remark).isEqualTo("Because I said so!") assertThat(storage.getRequest(requestId)!!.remark).isEqualTo("Because I said so!")
} }
@Test @Test
fun `request with the same legal name as a pending request`() { fun `request with the same legal name as a pending request`() {
val requestId1 = storage.saveRequest(createRequest("BankA").first) val requestId1 = storage.saveRequest(createRequest("BankA").first)
assertThat(storage.getRequests(RequestStatus.New).map { it.requestId }).containsOnly(requestId1) assertThat(storage.getRequests(RequestStatus.NEW).map { it.requestId }).containsOnly(requestId1)
val requestId2 = storage.saveRequest(createRequest("BankA").first) val requestId2 = storage.saveRequest(createRequest("BankA").first)
assertThat(storage.getRequests(RequestStatus.New).map { it.requestId }).containsOnly(requestId1) assertThat(storage.getRequests(RequestStatus.NEW).map { it.requestId }).containsOnly(requestId1)
assertEquals(RequestStatus.Rejected, storage.getRequest(requestId2)!!.status) assertEquals(RequestStatus.REJECTED, storage.getRequest(requestId2)!!.status)
assertThat(storage.getRequest(requestId2)!!.remark).containsIgnoringCase("duplicate") assertThat(storage.getRequest(requestId2)!!.remark).containsIgnoringCase("duplicate")
// Make sure the first request is processed properly // Make sure the first request is processed properly
storage.approveRequest(requestId1, DOORMAN_SIGNATURE) storage.approveRequest(requestId1, DOORMAN_SIGNATURE)
assertThat(storage.getRequest(requestId1)!!.status).isEqualTo(RequestStatus.Approved) assertThat(storage.getRequest(requestId1)!!.status).isEqualTo(RequestStatus.APPROVED)
} }
@Test @Test
@ -176,9 +176,9 @@ class DBCertificateRequestStorageTest : TestBase() {
val requestId1 = storage.saveRequest(createRequest("BankA").first) val requestId1 = storage.saveRequest(createRequest("BankA").first)
storage.rejectRequest(requestId1, DOORMAN_SIGNATURE, "Because I said so!") storage.rejectRequest(requestId1, DOORMAN_SIGNATURE, "Because I said so!")
val requestId2 = storage.saveRequest(createRequest("BankA").first) val requestId2 = storage.saveRequest(createRequest("BankA").first)
assertThat(storage.getRequests(RequestStatus.New).map { it.requestId }).containsOnly(requestId2) assertThat(storage.getRequests(RequestStatus.NEW).map { it.requestId }).containsOnly(requestId2)
storage.approveRequest(requestId2, DOORMAN_SIGNATURE) storage.approveRequest(requestId2, DOORMAN_SIGNATURE)
assertThat(storage.getRequest(requestId2)!!.status).isEqualTo(RequestStatus.Approved) assertThat(storage.getRequest(requestId2)!!.status).isEqualTo(RequestStatus.APPROVED)
} }
@Test @Test
@ -194,10 +194,10 @@ class DBCertificateRequestStorageTest : TestBase() {
persistence.transaction { persistence.transaction {
val auditReader = AuditReaderFactory.get(persistence.entityManagerFactory.createEntityManager()) val auditReader = AuditReaderFactory.get(persistence.entityManagerFactory.createEntityManager())
val newRevision = auditReader.find(CertificateSigningRequestEntity::class.java, requestId, 1) val newRevision = auditReader.find(CertificateSigningRequestEntity::class.java, requestId, 1)
assertEquals(RequestStatus.New, newRevision.status) assertEquals(RequestStatus.NEW, newRevision.status)
assertTrue(newRevision.modifiedBy.isEmpty()) assertTrue(newRevision.modifiedBy.isEmpty())
val approvedRevision = auditReader.find(CertificateSigningRequestEntity::class.java, requestId, 2) val approvedRevision = auditReader.find(CertificateSigningRequestEntity::class.java, requestId, 2)
assertEquals(RequestStatus.Approved, approvedRevision.status) assertEquals(RequestStatus.APPROVED, approvedRevision.status)
assertEquals(approver, approvedRevision.modifiedBy.first()) assertEquals(approver, approvedRevision.modifiedBy.first())
} }
} }

View File

@ -68,7 +68,7 @@ class DBNetworkMapStorageTest : TestBase() {
nodeInfoStorage.signNodeInfo(nodeInfoHash, signature) nodeInfoStorage.signNodeInfo(nodeInfoHash, signature)
// Create network parameters // Create network parameters
val networkParametersHash = networkMapStorage.putNetworkParameters(testNetworkParameters(emptyList<NotaryInfo>())) val networkParametersHash = networkMapStorage.putNetworkParameters(testNetworkParameters(emptyList()))
val signatureData = SignatureAndCertPath(signature, certPath) val signatureData = SignatureAndCertPath(signature, certPath)
val signedNetworkMap = SignedNetworkMap(NetworkMap(listOf(nodeInfoHash.toString()), networkParametersHash.toString()), signatureData) val signedNetworkMap = SignedNetworkMap(NetworkMap(listOf(nodeInfoHash.toString()), networkParametersHash.toString()), signatureData)

View File

@ -29,6 +29,8 @@ class NetworkMapSignerTest : TestBase() {
val signedNodeInfoHashes = listOf(SecureHash.randomSHA256(), SecureHash.randomSHA256()) val signedNodeInfoHashes = listOf(SecureHash.randomSHA256(), SecureHash.randomSHA256())
val detachedNodeInfoHashes = listOf(SecureHash.randomSHA256()) val detachedNodeInfoHashes = listOf(SecureHash.randomSHA256())
val networkMapParameters = createNetworkParameters() val networkMapParameters = createNetworkParameters()
whenever(networkMapStorage.getCurrentNetworkMap())
.thenReturn(SignedNetworkMap(NetworkMap(signedNodeInfoHashes.map { it.toString() }, "Dummy"), mock()))
whenever(networkMapStorage.getCurrentNetworkMapNodeInfoHashes(any())).thenReturn(signedNodeInfoHashes) whenever(networkMapStorage.getCurrentNetworkMapNodeInfoHashes(any())).thenReturn(signedNodeInfoHashes)
whenever(networkMapStorage.getDetachedSignedAndValidNodeInfoHashes()).thenReturn(detachedNodeInfoHashes) whenever(networkMapStorage.getDetachedSignedAndValidNodeInfoHashes()).thenReturn(detachedNodeInfoHashes)
whenever(networkMapStorage.getLatestNetworkParameters()).thenReturn(networkMapParameters) whenever(networkMapStorage.getLatestNetworkParameters()).thenReturn(networkMapParameters)

View File

@ -27,8 +27,8 @@ class DefaultRequestProcessorTest : TestBase() {
val requestStorage: CertificationRequestStorage = mock { val requestStorage: CertificationRequestStorage = mock {
on { getRequest("New") }.thenReturn(certificateSigningRequest()) on { getRequest("New") }.thenReturn(certificateSigningRequest())
on { getRequest("Signed") }.thenReturn(certificateSigningRequest(status = RequestStatus.Signed, certData = certificateData("", CertificateStatus.VALID, buildCertPath(cert.toX509Certificate())))) on { getRequest("Signed") }.thenReturn(certificateSigningRequest(status = RequestStatus.SIGNED, certData = certificateData("", CertificateStatus.VALID, buildCertPath(cert.toX509Certificate()))))
on { getRequest("Rejected") }.thenReturn(certificateSigningRequest(status = RequestStatus.Rejected, remark = "Random reason")) on { getRequest("Rejected") }.thenReturn(certificateSigningRequest(status = RequestStatus.REJECTED, remark = "Random reason"))
} }
val signer: LocalSigner = mock() val signer: LocalSigner = mock()
val requestProcessor = DefaultCsrHandler(requestStorage, signer) val requestProcessor = DefaultCsrHandler(requestStorage, signer)
@ -46,10 +46,10 @@ class DefaultRequestProcessorTest : TestBase() {
val request3 = X509Utilities.createCertificateSigningRequest(CordaX500Name(locality = "London", organisation = "Test3", country = "GB"), "my@email.com", Crypto.generateKeyPair(X509Utilities.DEFAULT_TLS_SIGNATURE_SCHEME)) val request3 = X509Utilities.createCertificateSigningRequest(CordaX500Name(locality = "London", organisation = "Test3", country = "GB"), "my@email.com", Crypto.generateKeyPair(X509Utilities.DEFAULT_TLS_SIGNATURE_SCHEME))
val requestStorage: CertificationRequestStorage = mock { val requestStorage: CertificationRequestStorage = mock {
on { getRequests(RequestStatus.Approved) }.thenReturn(listOf( on { getRequests(RequestStatus.APPROVED) }.thenReturn(listOf(
certificateSigningRequest(requestId = "1", request = request1, status = RequestStatus.Approved), certificateSigningRequest(requestId = "1", request = request1, status = RequestStatus.APPROVED),
certificateSigningRequest(requestId = "2", request = request2, status = RequestStatus.Approved), certificateSigningRequest(requestId = "2", request = request2, status = RequestStatus.APPROVED),
certificateSigningRequest(requestId = "3", request = request3, status = RequestStatus.Approved) certificateSigningRequest(requestId = "3", request = request3, status = RequestStatus.APPROVED)
)) ))
} }
val signer: LocalSigner = mock() val signer: LocalSigner = mock()

View File

@ -2,7 +2,7 @@ package com.r3cev.sgx.utils
import java.util.* import java.util.*
// TODO this code (incl. the hsm_errors file) is duplicated with the Network-Management module
object HsmErrors { object HsmErrors {
val errors: Map<Int, String> by lazy(HsmErrors::load) val errors: Map<Int, String> by lazy(HsmErrors::load)