summaryrefslogtreecommitdiffstats
path: root/base/java-tools/src/com/netscape/cmstools/cert/CertRequestReviewCLI.java
diff options
context:
space:
mode:
Diffstat (limited to 'base/java-tools/src/com/netscape/cmstools/cert/CertRequestReviewCLI.java')
-rw-r--r--base/java-tools/src/com/netscape/cmstools/cert/CertRequestReviewCLI.java138
1 files changed, 102 insertions, 36 deletions
diff --git a/base/java-tools/src/com/netscape/cmstools/cert/CertRequestReviewCLI.java b/base/java-tools/src/com/netscape/cmstools/cert/CertRequestReviewCLI.java
index 682314b25..3891508bd 100644
--- a/base/java-tools/src/com/netscape/cmstools/cert/CertRequestReviewCLI.java
+++ b/base/java-tools/src/com/netscape/cmstools/cert/CertRequestReviewCLI.java
@@ -1,15 +1,20 @@
package com.netscape.cmstools.cert;
-import java.io.FileNotFoundException;
+import java.io.BufferedReader;
+import java.io.FileInputStream;
import java.io.FileOutputStream;
+import java.io.InputStreamReader;
+import java.util.Arrays;
+import java.util.List;
import javax.xml.bind.JAXBContext;
-import javax.xml.bind.JAXBException;
import javax.xml.bind.Marshaller;
+import javax.xml.bind.Unmarshaller;
import org.apache.commons.cli.CommandLine;
import org.apache.commons.cli.Option;
import org.apache.commons.cli.ParseException;
+import org.apache.commons.lang.StringUtils;
import com.netscape.certsrv.base.PKIException;
import com.netscape.certsrv.cert.CertReviewResponse;
@@ -20,6 +25,9 @@ import com.netscape.cmstools.cli.MainCLI;
public class CertRequestReviewCLI extends CLI {
CertCLI parent;
+ List<String> actions = Arrays.asList(
+ "approve", "reject", "cancel", "update", "validate", "assign", "unassign"
+ );
public CertRequestReviewCLI(CertCLI parent) {
super("request-review", "Review certificate request");
@@ -27,11 +35,21 @@ public class CertRequestReviewCLI extends CLI {
}
@Override
- public void execute(String[] args) {
+ public void printHelp() {
+ formatter.printHelp(parent.name + "-" + name + " <Request ID> [OPTIONS...]", options);
+ }
+
+ @Override
+ public void execute(String[] args) throws Exception {
CommandLine cmd = null;
- Option output = new Option(null, "output", true, "Output Filename");
- options.addOption(output);
+ Option option = new Option(null, "action", true, "Action: " + StringUtils.join(actions, ", "));
+ option.setArgName("action");
+ options.addOption(option);
+
+ option = new Option(null, "output", true, "Output filename");
+ option.setArgName("filename");
+ options.addOption(option);
try {
cmd = parser.parse(options, args);
@@ -42,62 +60,110 @@ public class CertRequestReviewCLI extends CLI {
}
String[] cLineArgs = cmd.getArgs();
-
if (cLineArgs.length < 1) {
- System.err.println("Error: No request id specified.");
- printHelp();
- System.exit(-1);
- }
- String filename = null;
- if (cmd.hasOption("output")) {
- filename = cmd.getOptionValue("output");
- } else {
- System.err.println("No output option specified.");
- printHelp();
- System.exit(-1);
- }
-
- if (filename == null || filename.trim().length() == 0) {
- System.err.println("Specify the filename to write the request information");
+ System.err.println("Error: Missing certificate request ID.");
printHelp();
System.exit(-1);
}
- RequestId reqId = null;
+ RequestId requestId = null;
try {
- reqId = new RequestId(cLineArgs[0]);
+ requestId = new RequestId(cLineArgs[0]);
} catch (NumberFormatException e) {
- System.err.println("Error: Invalid RequestID: " + cLineArgs[0]);
+ System.err.println("Error: Invalid certificate request ID " + cLineArgs[0] + ".");
System.exit(-1);
}
+ String action = cmd.getOptionValue("action");
+ String filename = null;
+
+ if (action == null) {
+ if (cmd.hasOption("output")) {
+ filename = cmd.getOptionValue("output");
+ } else {
+ System.err.println("Error: Missing output file name.");
+ printHelp();
+ System.exit(-1);
+ }
+
+ if (filename == null || filename.trim().length() == 0) {
+ System.err.println("Error: Missing output file name.");
+ printHelp();
+ System.exit(-1);
+ }
+ }
+
+ // Retrieve certificate request.
CertReviewResponse reviewInfo = null;
try {
- reviewInfo = parent.client.reviewRequest(reqId);
+ reviewInfo = parent.client.reviewRequest(requestId);
} catch (PKIException e) {
System.err.println(e.getMessage());
System.exit(-1);
}
- try {
+ if (action == null) {
+ // Store certificate request in a file.
JAXBContext context = JAXBContext.newInstance(CertReviewResponse.class);
Marshaller marshaller = context.createMarshaller();
marshaller.setProperty(Marshaller.JAXB_FORMATTED_OUTPUT, true);
FileOutputStream stream = new FileOutputStream(filename);
-
marshaller.marshal(reviewInfo, stream);
- MainCLI.printMessage("Downloaded certificate request " + cLineArgs[0]);
- } catch (JAXBException e) {
- System.err.println("Cannot write to the file. " + e);
- } catch (FileNotFoundException e) {
- System.err.println("File not found at " + filename);
+
+ MainCLI.printMessage("Retrieved certificate request " + requestId);
+ CertCLI.printCertReviewResponse(reviewInfo);
+ System.out.println(" Filename: " + filename);
+ if (verbose) System.out.println(" Nonce: " + reviewInfo.getNonce());
+ System.out.println();
+
+ while (true) {
+ // Prompt for action.
+ System.out.print("Action (" + StringUtils.join(actions, "/") + "): ");
+ System.out.flush();
+
+ BufferedReader reader = new BufferedReader(new InputStreamReader(System.in));
+ action = reader.readLine().trim().toLowerCase();
+
+ if (actions.contains(action)) break;
+ }
+
+ // Read certificate request file.
+ Unmarshaller unmarshaller = context.createUnmarshaller();
+ FileInputStream fis = new FileInputStream(filename);
+ reviewInfo = (CertReviewResponse) unmarshaller.unmarshal(fis);
}
- }
+ if (action.equalsIgnoreCase("approve")) {
+ parent.client.approveRequest(reviewInfo.getRequestId(), reviewInfo);
+ MainCLI.printMessage("Approved certificate request " + requestId);
- @Override
- public void printHelp() {
- formatter.printHelp(parent.name + "-" + name + " <request id>", options);
+ } else if (action.equalsIgnoreCase("reject")) {
+ parent.client.rejectRequest(reviewInfo.getRequestId(), reviewInfo);
+ MainCLI.printMessage("Rejected certificate request " + requestId);
+
+ } else if (action.equalsIgnoreCase("cancel")) {
+ parent.client.cancelRequest(reviewInfo.getRequestId(), reviewInfo);
+ MainCLI.printMessage("Canceled certificate request " + requestId);
+
+ } else if (action.equalsIgnoreCase("update")) {
+ parent.client.updateRequest(reviewInfo.getRequestId(), reviewInfo);
+ MainCLI.printMessage("Updated certificate request " + requestId);
+
+ } else if (action.equalsIgnoreCase("validate")) {
+ parent.client.validateRequest(reviewInfo.getRequestId(), reviewInfo);
+ MainCLI.printMessage("Validated certificate request " + requestId);
+
+ } else if (action.equalsIgnoreCase("assign")) {
+ parent.client.assignRequest(reviewInfo.getRequestId(), reviewInfo);
+ MainCLI.printMessage("Assigned certificate request " + requestId);
+
+ } else if (action.equalsIgnoreCase("unassign")) {
+ parent.client.unassignRequest(reviewInfo.getRequestId(), reviewInfo);
+ MainCLI.printMessage("Unassigned certificate request " + requestId);
+
+ } else {
+ throw new Error("Invalid action: " + action);
+ }
}
}