1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
|
package com.netscape.cmstools.cert;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.util.Arrays;
import java.util.Scanner;
import javax.xml.bind.JAXBException;
import org.apache.commons.cli.CommandLine;
import org.apache.commons.cli.Option;
import org.apache.commons.cli.ParseException;
import com.netscape.certsrv.ca.AuthorityID;
import com.netscape.certsrv.cert.CertEnrollmentRequest;
import com.netscape.certsrv.cert.CertRequestInfos;
import com.netscape.cmstools.cli.CLI;
import com.netscape.cmstools.cli.MainCLI;
import netscape.security.x509.X500Name;
public class CertRequestSubmitCLI extends CLI {
CertCLI certCLI;
public CertRequestSubmitCLI(CertCLI certCLI) {
super("request-submit", "Submit certificate request", certCLI);
this.certCLI = certCLI;
Option optAID = new Option(null, "issuer-id", true, "Authority ID (host authority if omitted)");
optAID.setArgName("id");
options.addOption(optAID);
Option optADN = new Option(null, "issuer-dn", true, "Authority DN (host authority if omitted)");
optADN.setArgName("dn");
options.addOption(optADN);
}
public void printHelp() {
formatter.printHelp(getFullName() + " <filename> [OPTIONS...]", options);
}
@Override
public void execute(String[] args) {
// Always check for "--help" prior to parsing
if (Arrays.asList(args).contains("--help")) {
// Display usage
printHelp();
System.exit(0);
}
CommandLine cmd = null;
try {
cmd = parser.parse(options, args);
} catch (ParseException e) {
System.err.println("Error: " + e.getMessage());
printHelp();
System.exit(-1);
}
String[] cmdArgs = cmd.getArgs();
if (cmdArgs.length < 1) {
System.err.println("Error: No filename specified.");
printHelp();
System.exit(-1);
}
AuthorityID aid = null;
if (cmd.hasOption("issuer-id")) {
String aidString = cmd.getOptionValue("issuer-id");
try {
aid = new AuthorityID(aidString);
} catch (IllegalArgumentException e) {
System.err.println("Bad AuthorityID: " + aidString);
printHelp();
System.exit(-1);
}
}
X500Name adn = null;
if (cmd.hasOption("issuer-dn")) {
String adnString = cmd.getOptionValue("issuer-dn");
try {
adn = new X500Name(adnString);
} catch (IOException e) {
System.err.println("Bad DN: " + adnString);
printHelp();
System.exit(-1);
}
}
if (aid != null && adn != null) {
System.err.println("--issuer-id and --issuer-dn options are mutually exclusive");
printHelp();
System.exit(-1);
}
try {
CertEnrollmentRequest erd = getEnrollmentRequest(cmdArgs[0]);
CertRequestInfos cri = certCLI.certClient.enrollRequest(erd, aid, adn);
MainCLI.printMessage("Submitted certificate request");
CertCLI.printCertRequestInfos(cri);
} catch (FileNotFoundException e) {
System.err.println("Error: " + e.getMessage());
System.exit(-1);
} catch (JAXBException e) {
System.err.println("Error: " + e.getMessage());
System.exit(-1);
}
}
private CertEnrollmentRequest getEnrollmentRequest(String fileName) throws JAXBException, FileNotFoundException {
try (Scanner scanner = new Scanner(new File(fileName))) {
String xml = scanner.useDelimiter("\\A").next();
return CertEnrollmentRequest.fromXML(xml);
}
}
}
|