/**
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apache.geronimo.console.ca;
import java.io.IOException;
import java.security.PublicKey;
import java.security.cert.Certificate;
import java.security.interfaces.RSAPublicKey;
import java.util.HashMap;
import java.util.Map;
import javax.portlet.ActionRequest;
import javax.portlet.ActionResponse;
import javax.portlet.PortletException;
import javax.portlet.RenderRequest;
import javax.portlet.RenderResponse;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.apache.geronimo.console.MultiPageModel;
import org.apache.geronimo.management.geronimo.CertificationAuthority;
import org.apache.geronimo.util.CaUtils;
import org.apache.geronimo.util.CertificateUtil;
/**
* Handler for the CA details screen.
*
* @version $Rev: 476291 $ $Date: 2006-11-17 15:05:24 -0500 (Fri, 17 Nov 2006) $
*/
public class CADetailsHandler extends BaseCAHandler {
private final static Log log = LogFactory.getLog(CADetailsHandler.class);
public CADetailsHandler() {
super(CADETAILS_MODE, "/WEB-INF/view/ca/caDetails.jsp");
}
public String actionBeforeView(ActionRequest request, ActionResponse response, MultiPageModel model) throws PortletException, IOException {
String[] params = {ERROR_MSG, INFO_MSG};
for(int i = 0; i < params.length; ++i) {
String value = request.getParameter(params[i]);
if(value != null) response.setRenderParameter(params[i], value);
}
return getMode();
}
public void renderView(RenderRequest request, RenderResponse response, MultiPageModel model) throws PortletException, IOException {
String[] params = {ERROR_MSG, INFO_MSG};
for(int i = 0; i < params.length; ++i) {
String value = request.getParameter(params[i]);
if(value != null) request.setAttribute(params[i], value);
}
try {
CertificationAuthority ca = getCertificationAuthority(request);
if(ca == null) {
throw new Exception("CA is not running. CA may not have been initialized.");
}
if(ca.isLocked()) {
request.setAttribute("caLocked", Boolean.TRUE);
throw new Exception("CA is locked. Unlock CA to view details.");
}
// Get CA details
Certificate caCert = ca.getCertificate();
request.setAttribute("cert", caCert);
request.setAttribute("highestSerial", ca.getHighestSerialNumber());
request.setAttribute("certText", CaUtils.base64Certificate(caCert));
PublicKey publickey = caCert.getPublicKey();
String keySize = null;
if(publickey instanceof RSAPublicKey) {
keySize = ""+((RSAPublicKey)publickey).getModulus().bitLength();
request.setAttribute("keySize", keySize);
}
Map fingerPrints = new HashMap();
fingerPrints.put("MD5", CertificateUtil.generateFingerprint(caCert, "MD5"));
fingerPrints.put("SHA1", CertificateUtil.generateFingerprint(caCert, "SHA1"));
request.setAttribute("fingerPrints", fingerPrints);
} catch (Exception e) {
request.setAttribute(ERROR_MSG, e.toString());
log.error("Errors while trying to view CA Details.", e);
}
}
public String actionAfterView(ActionRequest request, ActionResponse response, MultiPageModel model) throws PortletException, IOException {
return getMode()+BEFORE_ACTION;
}
}