diff --git a/core/src/main/java/org/bouncycastle/pqc/crypto/util/PrivateKeyFactory.java b/core/src/main/java/org/bouncycastle/pqc/crypto/util/PrivateKeyFactory.java index 15070d405e..1c7c222d3b 100644 --- a/core/src/main/java/org/bouncycastle/pqc/crypto/util/PrivateKeyFactory.java +++ b/core/src/main/java/org/bouncycastle/pqc/crypto/util/PrivateKeyFactory.java @@ -322,6 +322,16 @@ else if (algOID.equals(NISTObjectIdentifiers.id_ml_dsa_44) null); } } + else if (keyObj instanceof DEROctetString) + { + byte[] data = ASN1OctetString.getInstance(keyObj).getOctets(); + if (keyInfo.getPublicKeyData() != null) + { + MLDSAPublicKeyParameters pubParams = PublicKeyFactory.MLDSAConverter.getPublicKeyParams(spParams, keyInfo.getPublicKeyData()); + return new MLDSAPrivateKeyParameters(spParams, data, pubParams); + } + return new MLDSAPrivateKeyParameters(spParams, data, null); + } else { throw new IOException("not supported");