mirror of
https://github.com/pgpainless/pgpainless.git
synced 2025-09-09 18:29:39 +02:00
Implement SOPs validate-userid command
This commit is contained in:
parent
2d1c2d2737
commit
3080e8bdd3
2 changed files with 39 additions and 1 deletions
|
@ -68,7 +68,7 @@ class SOPImpl(
|
||||||
|
|
||||||
override fun updateKey(): UpdateKey? = null
|
override fun updateKey(): UpdateKey? = null
|
||||||
|
|
||||||
override fun validateUserId(): ValidateUserId? = null
|
override fun validateUserId(): ValidateUserId = ValidateUserIdImpl(api)
|
||||||
|
|
||||||
override fun version(): Version = sopv.version()!!
|
override fun version(): Version = sopv.version()!!
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,38 @@
|
||||||
|
// SPDX-FileCopyrightText: 2025 Paul Schaub <vanitasvitae@fsfe.org>
|
||||||
|
//
|
||||||
|
// SPDX-License-Identifier: Apache-2.0
|
||||||
|
|
||||||
|
package org.pgpainless.sop
|
||||||
|
|
||||||
|
import java.io.InputStream
|
||||||
|
import java.util.*
|
||||||
|
import org.bouncycastle.openpgp.api.OpenPGPCertificate
|
||||||
|
import org.pgpainless.PGPainless
|
||||||
|
import sop.operation.ValidateUserId
|
||||||
|
|
||||||
|
class ValidateUserIdImpl(private val api: PGPainless) : ValidateUserId {
|
||||||
|
|
||||||
|
private var addSpecOnly = false
|
||||||
|
private var userId: String? = null
|
||||||
|
private val authorities: MutableList<OpenPGPCertificate> = mutableListOf()
|
||||||
|
private var validateAt: Date = Date()
|
||||||
|
|
||||||
|
override fun addrSpecOnly(): ValidateUserId = apply { addSpecOnly = true }
|
||||||
|
|
||||||
|
override fun authorities(certs: InputStream): ValidateUserId = apply {
|
||||||
|
authorities.addAll(api.readKey().parseCertificates(certs))
|
||||||
|
}
|
||||||
|
|
||||||
|
override fun subjects(certs: InputStream): Boolean {
|
||||||
|
requireNotNull(userId) { "Missing parameter USERID" }
|
||||||
|
return api.readKey().parseCertificates(certs).all { cert ->
|
||||||
|
authorities.all { authority ->
|
||||||
|
cert.getUserId(userId)?.getCertificationBy(authority, validateAt)?.isValid == true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
override fun userId(userId: String): ValidateUserId = apply { this.userId = userId }
|
||||||
|
|
||||||
|
override fun validateAt(date: Date): ValidateUserId = apply { validateAt = date }
|
||||||
|
}
|
Loading…
Add table
Add a link
Reference in a new issue