diff options
author | James Moger <james.moger@gitblit.com> | 2015-05-22 11:25:37 -0400 |
---|---|---|
committer | James Moger <james.moger@gitblit.com> | 2015-05-22 11:25:37 -0400 |
commit | 08afff2282d1109f9e426f06d189e99ced2a2316 (patch) | |
tree | 90a819ad63a5524949ac26cc144aedf0bdc6fa41 /src/main/java/com/gitblit/utils | |
parent | c36bfeced34a34638e363461cea0804da6dbc5c3 (diff) | |
download | gitblit-08afff2282d1109f9e426f06d189e99ced2a2316.tar.gz gitblit-08afff2282d1109f9e426f06d189e99ced2a2316.zip |
Parse X509 DN with LdapName
Diffstat (limited to 'src/main/java/com/gitblit/utils')
-rw-r--r-- | src/main/java/com/gitblit/utils/X509Utils.java | 22 |
1 files changed, 12 insertions, 10 deletions
diff --git a/src/main/java/com/gitblit/utils/X509Utils.java b/src/main/java/com/gitblit/utils/X509Utils.java index fc0b797d..a2650be4 100644 --- a/src/main/java/com/gitblit/utils/X509Utils.java +++ b/src/main/java/com/gitblit/utils/X509Utils.java @@ -61,6 +61,7 @@ import java.util.zip.ZipEntry; import java.util.zip.ZipOutputStream;
import javax.crypto.Cipher;
+import javax.naming.ldap.LdapName;
import org.bouncycastle.asn1.ASN1ObjectIdentifier;
import org.bouncycastle.asn1.pkcs.PKCSObjectIdentifiers;
@@ -1117,17 +1118,18 @@ public class X509Utils { }
public static X509Metadata getMetadata(X509Certificate cert) {
- // manually split DN into OID components
- // this is instead of parsing with LdapName which:
- // (1) I don't trust the order of values
- // (2) it filters out values like EMAILADDRESS
- String dn = cert.getSubjectDN().getName();
Map<String, String> oids = new HashMap<String, String>();
- for (String kvp : dn.split(",")) {
- String [] val = kvp.trim().split("=");
- String oid = val[0].toUpperCase().trim();
- String data = val[1].trim();
- oids.put(oid, data);
+ try {
+ String dn = cert.getSubjectDN().getName();
+ LdapName ldapName = new LdapName(dn);
+ for (int i = 0; i < ldapName.size(); i++) {
+ String [] val = ldapName.get(i).trim().split("=", 2);
+ String oid = val[0].toUpperCase().trim();
+ String data = val[1].trim();
+ oids.put(oid, data);
+ }
+ } catch (Exception e) {
+ throw new RuntimeException(e);
}
X509Metadata metadata = new X509Metadata(oids.get("CN"), "whocares");
|