From 58a10bb445f0e7963280519a3165bc1a3f0a6924 Mon Sep 17 00:00:00 2001 From: M66B Date: Fri, 3 Jun 2022 07:47:40 +0200 Subject: [PATCH] Added support for GeneralName.iPAddress --- .../eu/faircode/email/EntityCertificate.java | 16 ++++++++++++++-- 1 file changed, 14 insertions(+), 2 deletions(-) diff --git a/app/src/main/java/eu/faircode/email/EntityCertificate.java b/app/src/main/java/eu/faircode/email/EntityCertificate.java index 5af4987c1b..150fac0734 100644 --- a/app/src/main/java/eu/faircode/email/EntityCertificate.java +++ b/app/src/main/java/eu/faircode/email/EntityCertificate.java @@ -28,6 +28,7 @@ import androidx.room.Index; import androidx.room.PrimaryKey; import org.bouncycastle.asn1.ASN1Encodable; +import org.bouncycastle.asn1.DERApplicationSpecific; import org.bouncycastle.asn1.DEROctetString; import org.bouncycastle.asn1.x500.AttributeTypeAndValue; import org.bouncycastle.asn1.x500.RDN; @@ -222,8 +223,19 @@ public class EntityCertificate { return result; for (List altName : altNames) - if (altName.get(0).equals(GeneralName.dNSName)) - result.add((String) altName.get(1)); + try { + if (altName.get(0).equals(GeneralName.dNSName)) + result.add((String) altName.get(1)); + else if (altName.get(0).equals(GeneralName.iPAddress)) + if (altName.get(1) instanceof String) + result.add((String) altName.get(1)); + else { + Object val = altName.get(1); + Log.persist("GeneralName.iPAddress type=" + (val == null ? null : val.getClass())); + } + } catch (Throwable ex) { + Log.e(ex); + } return result; }