diff options
| author | Andrew Wnuk <awnuk@redhat.com> | 2013-08-27 20:44:53 -0400 |
|---|---|---|
| committer | Andrew Wnuk <awnuk@redhat.com> | 2013-08-28 11:35:20 -0700 |
| commit | 8c635c6e1f8f1643b96a97ea42500090e9193193 (patch) | |
| tree | 279f181de7dbb079e38a50b131b132ad693c9b12 /base/java-tools/src | |
| parent | b60f6404379714e36903cd75f70d8724f2007107 (diff) | |
| download | pki-8c635c6e1f8f1643b96a97ea42500090e9193193.tar.gz pki-8c635c6e1f8f1643b96a97ea42500090e9193193.tar.xz pki-8c635c6e1f8f1643b96a97ea42500090e9193193.zip | |
CRMFPopClient update
This patch provides enhancement to CRMFPopClient allowing to control encoding for components of the subject name.
Ticket #676
Diffstat (limited to 'base/java-tools/src')
| -rw-r--r-- | base/java-tools/src/com/netscape/cmstools/CRMFPopClient.java | 94 |
1 files changed, 84 insertions, 10 deletions
diff --git a/base/java-tools/src/com/netscape/cmstools/CRMFPopClient.java b/base/java-tools/src/com/netscape/cmstools/CRMFPopClient.java index 241b759ed..016adb861 100644 --- a/base/java-tools/src/com/netscape/cmstools/CRMFPopClient.java +++ b/base/java-tools/src/com/netscape/cmstools/CRMFPopClient.java @@ -38,11 +38,15 @@ import netscape.security.x509.X500Name; import org.mozilla.jss.CryptoManager; import org.mozilla.jss.asn1.ASN1Util; import org.mozilla.jss.asn1.BIT_STRING; +import org.mozilla.jss.asn1.BMPString; import org.mozilla.jss.asn1.INTEGER; import org.mozilla.jss.asn1.OBJECT_IDENTIFIER; import org.mozilla.jss.asn1.OCTET_STRING; import org.mozilla.jss.asn1.PrintableString; import org.mozilla.jss.asn1.SEQUENCE; +import org.mozilla.jss.asn1.TeletexString; +import org.mozilla.jss.asn1.UTF8String; +import org.mozilla.jss.asn1.UniversalString; import org.mozilla.jss.crypto.AlreadyInitializedException; import org.mozilla.jss.crypto.CryptoToken; import org.mozilla.jss.crypto.IVParameterSpec; @@ -94,6 +98,7 @@ public class CRMFPopClient { System.out.println("Usage: CRMFPopClient -d <location of certdb> -p <token password> -h <tokenname> -o <output file which saves the base64 CRMF request> -n <subjectDN> -a <algorithm: 'rsa' or 'ec'> -l <rsa key length> -c <ec curve name> -m <hostname:port> -f <profile name; rsa default caEncUserCert; ec default caEncECUserCert> -u <user name> -r <requestor name> -q <POP_NONE, POP_SUCCESS, or POP_FAIL; default POP_SUCCESS> \n"); System.out.println(" Optionally, for ECC key generation per definition in JSS pkcs11.PK11KeyPairGenerator:\n"); + System.out.println(" -k <true for enabling encoding of attribute values; false for default encoding of attribute values; default is false>\n"); System.out.println(" -t <true for temporary(session); false for permanent(token); default is true>\n"); System.out.println(" -s <1 for sensitive; 0 for non-sensitive; -1 temporaryPairMode dependent; default is -1>\n"); System.out.println(" -e <1 for extractable; 0 for non-extractable; -1 token dependent; default is -1>\n"); @@ -160,6 +165,7 @@ public class CRMFPopClient { int RSA_keylen = 2048; /* default ECC key curve name */ String ECC_curve = "nistp256"; + boolean enable_encoding = false; /* enable encoding attribute values if true */ boolean ec_temporary = true; /* session if true; token if false */ int ec_sensitive = -1; /* -1, 0, or 1 */ int ec_extractable = -1; /* -1, 0, or 1 */ @@ -207,6 +213,12 @@ public class CRMFPopClient { ec_temporary = true; else ec_temporary = false; + } else if (name.equals("-k")) { + String temp = args[i+1]; + if (temp.equals("true")) + enable_encoding = true; + else + enable_encoding = false; } else if (name.equals("-s")) { String ec_sensitive_s = args[i+1]; ec_sensitive = Integer.parseInt(ec_sensitive_s); @@ -417,7 +429,7 @@ public class CRMFPopClient { CertTemplate certTemplate = new CertTemplate(); certTemplate.setVersion(new INTEGER(2)); - Name n1 = getJssName(SUBJ_DN); + Name n1 = getJssName(enable_encoding, SUBJ_DN); Name n = new Name(); @@ -619,7 +631,44 @@ public class CRMFPopClient { } } - static Name getJssName(String dn) { + static boolean isEncoded (String elementValue) { + boolean encoded = false; + + if (elementValue != null && ((elementValue.startsWith("UTF8String:")) || + (elementValue.startsWith("PrintableString:")) || + (elementValue.startsWith("BMPString:")) || + (elementValue.startsWith("TeletexString:")) || + (elementValue.startsWith("UniversalString:")))) { + encoded = true; + } + return encoded; + } + + static Name addNameElement (Name name, OBJECT_IDENTIFIER oid, int n, String elementValue) { + try { + String encodingType = (n > 0)? elementValue.substring(0, n): null; + String nameValue = (n > 0)? elementValue.substring(n+1): null; + if (encodingType != null && encodingType.length() > 0 && + nameValue != null && nameValue.length() > 0) { + if (encodingType.equals("UTF8String")) { + name.addElement( new AVA(oid, new UTF8String(nameValue))); + } else if (encodingType.equals("PrintableString")) { + name.addElement( new AVA(oid, new PrintableString(nameValue))); + } else if (encodingType.equals("BMPString")) { + name.addElement( new AVA(oid, new BMPString(nameValue))); + } else if (encodingType.equals("TeletexString")) { + name.addElement( new AVA(oid, new TeletexString(nameValue))); + } else if (encodingType.equals("UniversalString")) { + name.addElement( new AVA(oid, new UniversalString(nameValue))); + } + } + } catch (Exception e) { + System.out.println("CRMFPopClient: Error adding name element: " + elementValue + " Error: " + e.toString()); + } + return name; + } + + static Name getJssName(boolean enable_encoding, String dn) { X500Name x5Name = null; @@ -654,13 +703,18 @@ public class CRMFPopClient { if (split.length != 2) continue; + int n = split[1].indexOf(':'); try { if (split[0].equals("UID")) { - - ret.addElement(new AVA(new OBJECT_IDENTIFIER("0.9.2342.19200300.100.1.1"), new PrintableString( - split[1]))); + if (enable_encoding && isEncoded(split[1])) { + ret = addNameElement(ret, new OBJECT_IDENTIFIER("0.9.2342.19200300.100.1.1"), + n, split[1]); + } else { + ret.addElement(new AVA(new OBJECT_IDENTIFIER("0.9.2342.19200300.100.1.1"), + new PrintableString(split[1]))); + } // System.out.println("UID found : " + split[1]); } @@ -673,31 +727,51 @@ public class CRMFPopClient { } if (split[0].equals("CN")) { - ret.addCommonName(split[1]); + if (enable_encoding && isEncoded(split[1])) { + ret = addNameElement (ret, Name.commonName, n, split[1]); + } else { + ret.addCommonName(split[1]); + } // System.out.println("CN found : " + split[1]); continue; } if (split[0].equals("L")) { - ret.addLocalityName(split[1]); + if (enable_encoding && isEncoded(split[1])) { + ret = addNameElement (ret, Name.localityName, n, split[1]); + } else { + ret.addLocalityName(split[1]); + } // System.out.println("L found : " + split[1]); continue; } if (split[0].equals("O")) { - ret.addOrganizationName(split[1]); + if (enable_encoding && isEncoded(split[1])) { + ret = addNameElement (ret, Name.organizationName, n, split[1]); + } else { + ret.addOrganizationName(split[1]); + } // System.out.println("O found : " + split[1]); continue; } if (split[0].equals("ST")) { - ret.addStateOrProvinceName(split[1]); + if (enable_encoding && isEncoded(split[1])) { + ret = addNameElement (ret, Name.stateOrProvinceName, n, split[1]); + } else { + ret.addStateOrProvinceName(split[1]); + } // System.out.println("ST found : " + split[1]); continue; } if (split[0].equals("OU")) { - ret.addOrganizationalUnitName(split[1]); + if (enable_encoding && isEncoded(split[1])) { + ret = addNameElement (ret, Name.organizationalUnitName, n, split[1]); + } else { + ret.addOrganizationalUnitName(split[1]); + } // System.out.println("OU found : " + split[1]); continue; } |
