From 5bb7933dd00f11ec87237d3bad7756989abb59ee Mon Sep 17 00:00:00 2001 From: Endi Sukma Dewata Date: Thu, 6 Sep 2012 16:33:48 -0500 Subject: Added REST interface to get domain info. The REST interface for security domain has been updated to provide a method to get the domain info. A CLI has been provided to access this method. Ticket #309 --- .../cmstools/system/SecurityDomainCLI.java | 27 +++++++++ .../cmstools/system/SecurityDomainShowCLI.java | 66 ++++++++++++++++++++++ 2 files changed, 93 insertions(+) create mode 100644 base/java-tools/src/com/netscape/cmstools/system/SecurityDomainShowCLI.java (limited to 'base/java-tools/src') diff --git a/base/java-tools/src/com/netscape/cmstools/system/SecurityDomainCLI.java b/base/java-tools/src/com/netscape/cmstools/system/SecurityDomainCLI.java index a6441e2fc..ed107f831 100644 --- a/base/java-tools/src/com/netscape/cmstools/system/SecurityDomainCLI.java +++ b/base/java-tools/src/com/netscape/cmstools/system/SecurityDomainCLI.java @@ -22,7 +22,10 @@ import java.util.Arrays; import org.apache.commons.lang.StringUtils; +import com.netscape.certsrv.system.DomainInfo; import com.netscape.certsrv.system.SecurityDomainClient; +import com.netscape.certsrv.system.SecurityDomainHost; +import com.netscape.certsrv.system.SecurityDomainSubsystem; import com.netscape.cmstools.cli.CLI; import com.netscape.cmstools.cli.MainCLI; @@ -39,6 +42,7 @@ public class SecurityDomainCLI extends CLI { this.parent = parent; addModule(new SecurityDomainGetInstallTokenCLI(this)); + addModule(new SecurityDomainShowCLI(this)); } public void printHelp() { @@ -89,4 +93,27 @@ public class SecurityDomainCLI extends CLI { System.exit(1); } } + + public static void printSecurityDomain(DomainInfo domain) { + System.out.println(" Domain: " + domain.getName()); + System.out.println(); + + for (SecurityDomainSubsystem subsystem : domain.getSubsystems()) { + + SecurityDomainHost[] hosts = subsystem.getHosts(); + if (hosts.length == 0) continue; + + System.out.println(" " + subsystem.getName() + " Subsystem:"); + System.out.println(); + + for (SecurityDomainHost host : hosts) { + System.out.println(" Host ID: " + host.getId()); + System.out.println(" Hostname: " + host.getHostname()); + System.out.println(" Port: " + host.getPort()); + System.out.println(" Secure Port: " + host.getSecurePort()); + if (host.getDomainManager() != null) System.out.println(" Domain Manager: " + host.getDomainManager()); + System.out.println(); + } + } + } } diff --git a/base/java-tools/src/com/netscape/cmstools/system/SecurityDomainShowCLI.java b/base/java-tools/src/com/netscape/cmstools/system/SecurityDomainShowCLI.java new file mode 100644 index 000000000..14664dbcf --- /dev/null +++ b/base/java-tools/src/com/netscape/cmstools/system/SecurityDomainShowCLI.java @@ -0,0 +1,66 @@ +// --- BEGIN COPYRIGHT BLOCK --- +// This program is free software; you can redistribute it and/or modify +// it under the terms of the GNU General Public License as published by +// the Free Software Foundation; version 2 of the License. +// +// This program is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +// GNU General Public License for more details. +// +// You should have received a copy of the GNU General Public License along +// with this program; if not, write to the Free Software Foundation, Inc., +// 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. +// +// (C) 2012 Red Hat, Inc. +// All rights reserved. +// --- END COPYRIGHT BLOCK --- + +package com.netscape.cmstools.system; + +import org.apache.commons.cli.CommandLine; + +import com.netscape.certsrv.system.DomainInfo; +import com.netscape.cmstools.cli.CLI; + +/** + * @author Endi S. Dewata + */ +public class SecurityDomainShowCLI extends CLI { + + public SecurityDomainCLI parent; + + public SecurityDomainShowCLI(SecurityDomainCLI parent) { + super("show", "Show domain info"); + this.parent = parent; + } + + public void printHelp() { + formatter.printHelp(parent.name + "-" + name, options); + } + + public void execute(String[] args) throws Exception { + + CommandLine cmd = null; + + try { + cmd = parser.parse(options, args); + + } catch (Exception e) { + System.err.println("Error: " + e.getMessage()); + printHelp(); + System.exit(1); + } + + String[] cmdArgs = cmd.getArgs(); + + if (cmdArgs.length != 0) { + printHelp(); + System.exit(1); + } + + DomainInfo domain = parent.client.getDomainInfo(); + + SecurityDomainCLI.printSecurityDomain(domain); + } +} -- cgit