Package com.sun.enterprise.tools.admingui.handlers

Source Code of com.sun.enterprise.tools.admingui.handlers.JdbcHandlers

/*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
*
* Copyright 1997-2007 Sun Microsystems, Inc. All rights reserved.
*
* The contents of this file are subject to the terms of either the GNU
* General Public License Version 2 only ("GPL") or the Common Development
* and Distribution License("CDDL") (collectively, the "License").  You
* may not use this file except in compliance with the License. You can obtain
* a copy of the License at https://glassfish.dev.java.net/public/CDDL+GPL.html
* or glassfish/bootstrap/legal/LICENSE.txt.  See the License for the specific
* language governing permissions and limitations under the License.
*
* When distributing the software, include this License Header Notice in each
* file and include the License file at glassfish/bootstrap/legal/LICENSE.txt.
* Sun designates this particular file as subject to the "Classpath" exception
* as provided by Sun in the GPL Version 2 section of the License file that
* accompanied this code.  If applicable, add the following below the License
* Header, with the fields enclosed by brackets [] replaced by your own
* identifying information: "Portions Copyrighted [year]
* [name of copyright owner]"
*
* Contributor(s):
*
* If you wish your version of this file to be governed by only the CDDL or
* only the GPL Version 2, indicate your decision by adding "[Contributor]
* elects to include this software in this distribution under the [CDDL or GPL
* Version 2] license."  If you don't indicate a single choice of license, a
* recipient has the option to distribute your version of this file under
* either the CDDL, the GPL Version 2 or to extend the choice of license to
* its licensees as provided above.  However, if you add GPL Version 2 code
* and therefore, elected the GPL Version 2 license, then the option applies
* only if the new code is made subject to such option by the copyright
* holder.
*/

/*
* JdbcHandler.java
*
* Created on August 10, 2006, 2:32 PM
*
* To change this template, choose Tools | Template Manager
* and open the template in the editor.
*/

/**
*
* @author anilam
*/

package com.sun.enterprise.tools.admingui.handlers;

import com.sun.jsftemplating.annotation.Handler;
import com.sun.jsftemplating.annotation.HandlerInput;
import com.sun.jsftemplating.annotation.HandlerOutput;
import com.sun.jsftemplating.layout.descriptors.handler.HandlerContext;

import java.util.ArrayList;
import java.util.List;
import java.util.Set;
import java.util.Map;
import java.util.HashMap;
import java.util.Iterator;


import com.sun.enterprise.tools.admingui.util.AMXUtil;
import com.sun.enterprise.tools.admingui.util.JMXUtil;
import com.sun.enterprise.tools.admingui.util.GuiUtil;
import com.sun.enterprise.tools.admingui.util.TargetUtil;

import com.sun.appserv.management.config.JDBCConnectionPoolConfig;
import com.sun.appserv.management.config.JDBCResourceConfig;
import com.sun.enterprise.connectors.ConnectorRuntime;
import com.sun.enterprise.connectors.util.ConnectionDefinitionUtils;

import com.sun.webui.jsf.component.Field;

public class JdbcHandlers {
    /** Creates a new instance of JdbcHandler */
    public JdbcHandlers() {
    }
   
    /**
     *  <p> This handler returns the values for all the attributes of the Jdbc Resource
     *  <p> Input  value: "name" -- Type: <code> java.lang.String</code></p>
     <p> Output value: "jndiName" -- Type: <code>java.lang.String</code></p>
     <p> Output value: "poolName" -- Type: <code>java.lang.String</code></p>
     <p> Output value: "description" -- Type: <code>java.lang.String</code></p>
     <p> Output value: "enbled" -- Type: <code>java.lang.Boolean</code></p>
     @param  context  The HandlerContext.
     */
    @Handler(id="getJdbcInfo",
        input={
            @HandlerInput(name="jndiName", type=String.class, required=true)},
        output={
            @HandlerOutput(name="poolName", type=String.class),
            @HandlerOutput(name="description", type=String.class),
            @HandlerOutput(name="enabledString", type=String.class),
            @HandlerOutput(name="enabled", type=Boolean.class)} )
    public static void getJdbcInfo(HandlerContext handlerCtx) {
       
        String jndiName = (String) handlerCtx.getInputValue("jndiName");

        if (GuiUtil.isEmpty(jndiName)){
            //for creating JDBC,this will be empty.
            handlerCtx.setOutputValue("enabled", Boolean.TRUE);
            return;
        }
  JDBCResourceConfig jdbc = AMXUtil.getDomainConfig().getJDBCResourceConfigMap().get(jndiName);
  if (jdbc == null){
      GuiUtil.handleError(handlerCtx, GuiUtil.getMessage("msg.NoSuchJDBCResource"));
  }else{
      handlerCtx.setOutputValue("poolName", jdbc.getPoolName());
      handlerCtx.setOutputValue("description", jdbc.getDescription());
            if(AMXUtil.isEE())
                handlerCtx.setOutputValue("enabledString", TargetUtil.getEnabledStatus(jdbc, false));
            else
                handlerCtx.setOutputValue("enabled", TargetUtil.isResourceEnabled(jdbc, "server" ));
  }

    }
   
   
    /**
     *  <p> This handler returns the values for all the attributes of the Jdbc Resource
     *  <p> Input  value: "name" -- Type: <code> java.lang.String</code></p>
     <p> Output value: "jndiName" -- Type: <code>java.lang.String</code></p>
     <p> Output value: "poolName" -- Type: <code>java.lang.String</code></p>
     <p> Output value: "description" -- Type: <code>java.lang.String</code></p>
     <p> Output value: "enbled" -- Type: <code>java.lang.Boolean</code></p>
     @param  context  The HandlerContext.
     */
    @Handler(id="saveJdbc",
        input={
            @HandlerInput(name="edit", type=Boolean.class, required=true),
            @HandlerInput(name="jndiName", type=String.class, required=true),
            @HandlerInput(name="poolName", type=String.class, required=true),
            @HandlerInput(name="description", type=String.class),
            @HandlerInput(name="enabled", type=Boolean.class),
            @HandlerInput(name="targets", type=String[].class )
        })
    public static void saveJdbc(HandlerContext handlerCtx) {
        String jndiName = (String) handlerCtx.getInputValue("jndiName");
        String poolName = (String) handlerCtx.getInputValue("poolName");
        Boolean edit = (Boolean) handlerCtx.getInputValue("edit");
       
        JDBCResourceConfig jdbc = null;
       
        try{
            if (edit){
                 jdbc = AMXUtil.getDomainConfig().getJDBCResourceConfigMap().get(jndiName);
                if (jdbc == null){
        GuiUtil.handleError(handlerCtx, GuiUtil.getMessage("msg.NoSuchJDBCResource"));
                    return;
                }
                jdbc.setPoolName(poolName);
                if(!AMXUtil.isEE()){
                    Boolean enabled = (Boolean) handlerCtx.getInputValue("enabled");
                    TargetUtil.setResourceEnabled(jdbc, "server", enabled);
                }
                GuiUtil.prepareSuccessful(handlerCtx);
            }else{
                 jdbc = AMXUtil.getDomainConfig().createJDBCResourceConfig(jndiName, poolName, null);
                 JavaMailHandlers.createNewTargets(handlerCtx,  jndiName);
            }
            jdbc.setDescription((String)handlerCtx.getInputValue("description"));
           
        }catch (Exception ex){
      GuiUtil.handleException(handlerCtx, ex);
        }
    }
   
   
    /**
     *  <p> This handler returns the list of JDBC Connection Pool
     *  <p> Output value: "connectionPoolNames" -- Type: <code>java.util.List</code></p>
     */
    @Handler(id="getJdbcConnectionPools",
        output={
            @HandlerOutput(name="jdbcConnectionPools", type=java.util.List.class)}
        )
    public static void getJdbcConnectionPools(HandlerContext handlerCtx) {
  Set keys = AMXUtil.getDomainConfig().getJDBCConnectionPoolConfigMap().keySet();
  handlerCtx.setOutputValue("jdbcConnectionPools", new ArrayList(keys));
    }


    /**
     *  <p> This handler returns the values for all the attributes of the Jdbc Connection Pool
     */
    @Handler(id="getJdbcConnectionPoolInfo",
        input={
            @HandlerInput(name="jndiName", type=String.class, required=true)},
        output={
            @HandlerOutput(name="jndiName", type=String.class),
            @HandlerOutput(name="datasourceClassname", type=String.class),
            @HandlerOutput(name="resType", type=String.class),
            @HandlerOutput(name="description", type=String.class),
            @HandlerOutput(name="steadyPoolSize", type=String.class),
            @HandlerOutput(name="maxPoolSize", type=String.class),
            @HandlerOutput(name="poolResizeQuantity", type=String.class),
            @HandlerOutput(name="idleTimeoutInSeconds", type=String.class),
            @HandlerOutput(name="maxWaitTimeInMillis", type=String.class),
            @HandlerOutput(name="isConnectionValidationRequired", type=Boolean.class),
            @HandlerOutput(name="connectionValidationMethod", type=String.class),
            @HandlerOutput(name="validationTableName", type=String.class),
            @HandlerOutput(name="failAllConnections", type=Boolean.class),
            @HandlerOutput(name="allowNonComponentCallers", type=Boolean.class),
            @HandlerOutput(name="nonTransactionalConnections", type=Boolean.class),
            @HandlerOutput(name="transactionIsolationLevel", type=String.class),
            @HandlerOutput(name="isIsolationLevelGuaranteed", type=Boolean.class)}
                )
        public static void getJdbcConnectionPoolInfo(HandlerContext handlerCtx) {
       
            String jndiName = (String) handlerCtx.getInputValue("jndiName");
            JDBCConnectionPoolConfig pool = AMXUtil.getDomainConfig().getJDBCConnectionPoolConfigMap().get(jndiName);
            if (pool == null){
    GuiUtil.handleError(handlerCtx, GuiUtil.getMessage("msg.noSuchJDBCConnectionPool"));
            }
            handlerCtx.setOutputValue("datasourceClassname", pool.getDatasourceClassname());
            handlerCtx.setOutputValue("resType", pool.getResType());
            handlerCtx.setOutputValue("description", pool.getDescription());
            handlerCtx.setOutputValue("steadyPoolSize", pool.getSteadyPoolSize());
            handlerCtx.setOutputValue("maxPoolSize", pool.getMaxPoolSize());
            handlerCtx.setOutputValue("poolResizeQuantity", pool.getPoolResizeQuantity());
            handlerCtx.setOutputValue("idleTimeoutInSeconds", pool.getIdleTimeoutInSeconds());
            handlerCtx.setOutputValue("maxWaitTimeInMillis", pool.getMaxWaitTimeInMillis());
            handlerCtx.setOutputValue("isConnectionValidationRequired", pool.getIsConnectionValidationRequired());
            handlerCtx.setOutputValue("connectionValidationMethod", pool.getConnectionValidationMethod());
            handlerCtx.setOutputValue("validationTableName", pool.getValidationTableName());
            handlerCtx.setOutputValue("failAllConnections", pool.getFailAllConnections());
            handlerCtx.setOutputValue("allowNonComponentCallers", pool.getAllowNonComponentCallers());
            handlerCtx.setOutputValue("nonTransactionalConnections", pool.getNonTransactionalConnections());
            handlerCtx.setOutputValue("transactionIsolationLevel", pool.getTransactionIsolationLevel());
            handlerCtx.setOutputValue("isIsolationLevelGuaranteed", pool.getIsIsolationLevelGuaranteed());
        }

   
    /**
     *  <p> This handler returns the properties of the Jdbc Connection Pool
     */
    @Handler(id="getJdbcConnectionPoolProperty",
        input={
            @HandlerInput(name="jndiName", type=String.class, required=true)},
        output={
            @HandlerOutput(name="properties",type=Map.class)}
                )
        public static void getJdbcConnectionPoolProperty(HandlerContext handlerCtx) {
       
            String jndiName = (String) handlerCtx.getInputValue("jndiName");
            JDBCConnectionPoolConfig pool = AMXUtil.getDomainConfig().getJDBCConnectionPoolConfigMap().get(jndiName);
            if (pool == null){
    GuiUtil.handleError(handlerCtx, GuiUtil.getMessage("msg.noSuchJDBCConnectionPool"));
            }
            Map<String, String> props = pool.getProperties();
            handlerCtx.setOutputValue("properties", props);
        }


    /**
     *  <p> This handler saves the values for all the attributes of the Jdbc Connection Pool
     */

    @Handler(id="saveJdbcConnectionPool",
        input={
    @HandlerInput(name="jndiName", type=String.class, required=true),
    @HandlerInput(name="datasourceClassname", type=String.class, required=true),
    @HandlerInput(name="resType", type=String.class),
    @HandlerInput(name="description", type=String.class),
    @HandlerInput(name="steadyPoolSize", type=String.class),
    @HandlerInput(name="maxPoolSize", type=String.class),
    @HandlerInput(name="poolResizeQuantity", type=String.class),
    @HandlerInput(name="idleTimeoutInSeconds", type=String.class),
    @HandlerInput(name="maxWaitTimeInMillis", type=String.class),
    @HandlerInput(name="isConnectionValidationRequired", type=Boolean.class),
    @HandlerInput(name="connectionValidationMethod", type=String.class),
    @HandlerInput(name="validationTableName", type=String.class),
    @HandlerInput(name="failAllConnections", type=Boolean.class),
    @HandlerInput(name="allowNonComponentCallers", type=Boolean.class),
    @HandlerInput(name="nonTransactionalConnections", type=Boolean.class),
    @HandlerInput(name="transactionIsolationLevel", type=String.class),
    @HandlerInput(name="isIsolationLevelGuaranteed", type=Boolean.class)
        })
    public static void saveJdbcConnectionPool(HandlerContext handlerCtx) {

        try{
            String jndiName = (String) handlerCtx.getInputValue("jndiName");
            JDBCConnectionPoolConfig pool = AMXUtil.getDomainConfig().getJDBCConnectionPoolConfigMap().get(jndiName);
                if (pool == null){
        GuiUtil.handleError(handlerCtx, GuiUtil.getMessage("msg.noSuchJDBCConnectionPool"));
                    return;
                }
            pool.setDatasourceClassname ((String) handlerCtx.getInputValue("datasourceClassname"));
            pool.setResType ((String) handlerCtx.getInputValue("resType"));
            pool.setDescription((String) handlerCtx.getInputValue("description"));
            pool.setMaxPoolSize ((String) handlerCtx.getInputValue("maxPoolSize"));
            pool.setSteadyPoolSize ((String) handlerCtx.getInputValue("steadyPoolSize"));
            pool.setPoolResizeQuantity ((String) handlerCtx.getInputValue("poolResizeQuantity"));
            pool.setIdleTimeoutInSeconds ((String) handlerCtx.getInputValue("idleTimeoutInSeconds"));
            pool.setMaxWaitTimeInMillis ((String) handlerCtx.getInputValue("maxWaitTimeInMillis"));
            pool.setIsConnectionValidationRequired ((Boolean) handlerCtx.getInputValue("isConnectionValidationRequired"));
            String method = (String) handlerCtx.getInputValue("connectionValidationMethod");
            pool.setConnectionValidationMethod (method);
            if ("table".equals(method)){
                String table = (String) handlerCtx.getInputValue("validationTableName");
                if (! GuiUtil.isEmpty(table))
                    pool.setValidationTableName (table);
            }else{
                pool.setValidationTableName("");
            }
            pool.setFailAllConnections ((Boolean) handlerCtx.getInputValue("failAllConnections"));
            pool.setAllowNonComponentCallers ((Boolean) handlerCtx.getInputValue("allowNonComponentCallers"));
            pool.setNonTransactionalConnections ((Boolean) handlerCtx.getInputValue("nonTransactionalConnections"));
            pool.setTransactionIsolationLevel ((String) handlerCtx.getInputValue("transactionIsolationLevel"));
            pool.setIsIsolationLevelGuaranteed ((Boolean) handlerCtx.getInputValue("isIsolationLevelGuaranteed"));
            GuiUtil.prepareSuccessful(handlerCtx);
        }catch (Exception ex){
      GuiUtil.handleException(handlerCtx, ex);
        }
    }
   
   
    /**
     *  <p> This handler saves the values for all the attributes of the Jdbc Connection Pool
     */

    @Handler(id="saveJdbcConnectionPoolProperty",
        input={
    @HandlerInput(name="jndiName", type=String.class, required=true),
                @HandlerInput(name="AddProps",    type=Map.class),
                @HandlerInput(name="RemoveProps", type=ArrayList.class)
        })
    public static void saveJdbcConnectionPoolProperty(HandlerContext handlerCtx) {
        try{
            String jndiName = (String) handlerCtx.getInputValue("jndiName");
            JDBCConnectionPoolConfig pool = AMXUtil.getDomainConfig().getJDBCConnectionPoolConfigMap().get(jndiName);
            if (pool == null){
                GuiUtil.handleError(handlerCtx, GuiUtil.getMessage("msg.noSuchJDBCConnectionPool"));
                return;
            }
            AMXUtil.editProperties(handlerCtx, pool);
            GuiUtil.prepareSuccessful(handlerCtx);
        }catch (Exception ex){
      GuiUtil.handleException(handlerCtx, ex);
        }
    }
   
    /**
     *  <p> This handler returns the values for all the attributes of the Jdbc Connection Pool
     */
    @Handler(id="getJdbcConnectionPoolDefaultInfo",
        input={
            @HandlerInput(name="jndiName", type=String.class, required=true)},
        output={
            @HandlerOutput(name="resType", type=String.class),
            @HandlerOutput(name="description", type=String.class),
            @HandlerOutput(name="steadyPoolSize", type=String.class),
            @HandlerOutput(name="maxPoolSize", type=String.class),
            @HandlerOutput(name="poolResizeQuantity", type=String.class),
            @HandlerOutput(name="idleTimeoutInSeconds", type=String.class),
            @HandlerOutput(name="maxWaitTimeInMillis", type=String.class),
            @HandlerOutput(name="isConnectionValidationRequired", type=Boolean.class),
            @HandlerOutput(name="connectionValidationMethod", type=String.class),
            @HandlerOutput(name="validationTableName", type=String.class),
            @HandlerOutput(name="failAllConnections", type=Boolean.class),
            @HandlerOutput(name="allowNonComponentCallers", type=Boolean.class),
            @HandlerOutput(name="nonTransactionalConnections", type=Boolean.class),
            @HandlerOutput(name="transactionIsolationLevel", type=String.class),
            @HandlerOutput(name="isIsolationLevelGuaranteed", type=Boolean.class)}
                )
        public static void getJdbcConnectionPoolDefaultInfo(HandlerContext handlerCtx) {
       
            String jndiName = (String) handlerCtx.getInputValue("jndiName");
            JDBCConnectionPoolConfig pool = AMXUtil.getDomainConfig().getJDBCConnectionPoolConfigMap().get(jndiName);
            if (pool == null){
    GuiUtil.handleError(handlerCtx, GuiUtil.getMessage("msg.noSuchJDBCConnectionPool"));
                return;
            }
            handlerCtx.setOutputValue("resType", pool.getDefaultValue("ResType"));
            handlerCtx.setOutputValue("description", pool.getDefaultValue("Description"));
            handlerCtx.setOutputValue("steadyPoolSize", pool.getDefaultValue("SteadyPoolSize"));
            handlerCtx.setOutputValue("maxPoolSize", pool.getDefaultValue("MaxPoolSize"));
            handlerCtx.setOutputValue("poolResizeQuantity", pool.getDefaultValue("PoolResizeQuantity"));
            handlerCtx.setOutputValue("idleTimeoutInSeconds", pool.getDefaultValue("IdleTimeoutInSeconds"));
            handlerCtx.setOutputValue("maxWaitTimeInMillis", pool.getDefaultValue("MaxWaitTimeInMillis"));
            handlerCtx.setOutputValue("isConnectionValidationRequired", pool.getDefaultValue("IsConnectionValidationRequired"));
            handlerCtx.setOutputValue("connectionValidationMethod", pool.getDefaultValue("ConnectionValidationMethod"));
            handlerCtx.setOutputValue("validationTableName", pool.getDefaultValue("ValidationTableName"));
            handlerCtx.setOutputValue("failAllConnections", pool.getDefaultValue("FailAllConnections"));
            handlerCtx.setOutputValue("allowNonComponentCallers", pool.getDefaultValue("AllowNonComponentCallers"));
            handlerCtx.setOutputValue("nonTransactionalConnections", pool.getDefaultValue("NonTransactionalConnections"));
            handlerCtx.setOutputValue("transactionIsolationLevel", pool.getDefaultValue("TransactionIsolationLevel"));
            handlerCtx.setOutputValue("isIsolationLevelGuaranteed", pool.getDefaultValue("IsIsolationLevelGuaranteed"));
        }
   
   
        /**
         *  <p> This handler returns the values for all the attributes of the Jdbc Connection Pool
         */
        @Handler(id="getPoolAdvanceInfo",
            input={
                @HandlerInput(name="jndiName", type=String.class, required=true)},
            output={
                @HandlerOutput(name="advance", type=Map.class)}
        )
        public static void getPoolAdvanceInfo(HandlerContext handlerCtx) {
       
            String jndiName = (String) handlerCtx.getInputValue("jndiName");
            JDBCConnectionPoolConfig pool = AMXUtil.getDomainConfig().getJDBCConnectionPoolConfigMap().get(jndiName);
            if (pool == null){
    GuiUtil.handleError(handlerCtx, GuiUtil.getMessage("msg.noSuchJDBCConnectionPool"));
                return;
            }
            Map advance = new HashMap();
            advance.put("wrapJDBCObjects",  StringToBoolean( pool.getWrapJDBCObjects()));
            advance.put("statementTimeoutInSeconds", pool.getStatementTimeoutInSeconds());
            advance.put("validateAtMostOncePeriodInSeconds", pool.getValidateAtMostOncePeriodInSeconds());
            advance.put("connectionLeakTimeoutInSeconds", pool.getConnectionLeakTimeoutInSeconds());
            advance.put("connectionLeakReclaim",  StringToBoolean( pool.getConnectionLeakReclaim()));
            advance.put("connectionCreationRetryAttempts",  pool.getConnectionCreationRetryAttempts());
            advance.put("connectionCreationRetryIntervalInSeconds", pool.getConnectionCreationRetryIntervalInSeconds());
            advance.put("lazyConnectionEnlistment",  StringToBoolean( pool.getLazyConnectionEnlistment()));
            advance.put("lazyConnectionAssociation",  StringToBoolean( pool.getLazyConnectionAssociation()));
            advance.put("associateWithThread", StringToBooleanpool.getAssociateWithThread()));
            advance.put("matchConnections",  StringToBoolean( pool.getMatchConnections()));
            advance.put("maxConnectionUsageCount", pool.getMaxConnectionUsageCount());
            handlerCtx.setOutputValue("advance", advance);
        }
       
        /**
         *  <p> This handler returns the default values for the advance attributes of the Jdbc Connection Pool
         */
        @Handler(id="getPoolAdvanceDefaultInfo",
            input={
                @HandlerInput(name="jndiName", type=String.class, required=true)},
            output={
                @HandlerOutput(name="advance", type=Map.class)}
        )
        public static void getPoolAdvanceDefaultInfo(HandlerContext handlerCtx) {
       
            String jndiName = (String) handlerCtx.getInputValue("jndiName");
            JDBCConnectionPoolConfig pool = AMXUtil.getDomainConfig().getJDBCConnectionPoolConfigMap().get(jndiName);
            if (pool == null){
    GuiUtil.handleError(handlerCtx, GuiUtil.getMessage("msg.noSuchJDBCConnectionPool"));
                return;
            }
            Map advance = new HashMap();
            Map defaultMap = AMXUtil.getDomainConfig().getDefaultAttributeValues(JDBCConnectionPoolConfig.J2EE_TYPE);
            advance.put("wrapJDBCObjects", StringToBoolean( defaultMap.get("wrap-jdbc-objects")));
            advance.put("statementTimeoutInSeconds", defaultMap.get("statement-timeout-in-seconds"));
            advance.put("validateAtMostOncePeriodInSeconds", defaultMap.get("validate-atmost-once-period-in-seconds"));
            advance.put("connectionLeakTimeoutInSeconds", defaultMap.get("connection-leak-timeout-in-seconds"));
            advance.put("connectionLeakReclaim",  StringToBoolean( defaultMap.get("connection-leak-timeout-in-seconds")));
            advance.put("connectionCreationRetryAttempts",  defaultMap.get("connection-creation-retry-attempts"));
            advance.put("connectionCreationRetryIntervalInSeconds", defaultMap.get("connection-creation-retry-interval-in-seconds"));
            advance.put("lazyConnectionEnlistment",  StringToBoolean( defaultMap.get("lazy-connection-enlistment")));
            advance.put("lazyConnectionAssociation",  StringToBoolean( defaultMap.get("lazy-connection-association")));
            advance.put("associateWithThread",  StringToBoolean( defaultMap.get("associate-with-thread")));
            advance.put("matchConnections",  StringToBoolean( defaultMap.get("match-connections")));
            advance.put("maxConnectionUsageCount", defaultMap.get("max-connection-usage-count"));
            handlerCtx.setOutputValue("advance", advance);
        }
   
       
    /**
     *  <p> This handler saves the advance attributes of the Jdbc Connection Pool
     */

    @Handler(id="savePoolAdvanceInfo",
        input={
    @HandlerInput(name="jndiName", type=String.class, required=true),
                @HandlerInput(name="advance", type=Map.class)}
      )
    public static void savePoolAdvanceInfo(HandlerContext handlerCtx) {
        try{
            String jndiName = (String) handlerCtx.getInputValue("jndiName");
            Map advance = (Map) handlerCtx.getInputValue("advance");
            JDBCConnectionPoolConfig pool = AMXUtil.getDomainConfig().getJDBCConnectionPoolConfigMap().get(jndiName);
                if (pool == null){
        GuiUtil.handleError(handlerCtx, GuiUtil.getMessage("msg.noSuchJDBCConnectionPool"));
                    return;
                }
    pool.setWrapJDBCObjects(BooleanToString (advance.get("wrapJDBCObjects")));
    pool.setStatementTimeoutInSeconds((String) advance.get("statementTimeoutInSeconds"));
                pool.setValidateAtMostOncePeriodInSeconds((String) advance.get("validateAtMostOncePeriodInSeconds"));
                pool.setConnectionLeakTimeoutInSeconds((String) advance.get("connectionLeakTimeoutInSeconds"));
                pool.setConnectionLeakReclaim( BooleanToString( advance.get("connectionLeakReclaim")));
                pool.setConnectionCreationRetryAttempts((String) advance.get("connectionCreationRetryAttempts"));
                pool.setConnectionCreationRetryIntervalInSeconds((String) advance.get("connectionCreationRetryIntervalInSeconds"));
                pool.setLazyConnectionEnlistment( BooleanToString( advance.get("lazyConnectionEnlistment")));
                pool.setLazyConnectionAssociation( BooleanToStringadvance.get("lazyConnectionAssociation")));
                pool.setAssociateWithThread(BooleanToStringadvance.get("associateWithThread")));
                pool.setMatchConnections(BooleanToStringadvance.get("matchConnections")));
                pool.setMaxConnectionUsageCount((String) advance.get("maxConnectionUsageCount"));
        }catch (Exception ex){
             GuiUtil.handleException(handlerCtx, ex);
        }
    }
           
             
    private static String BooleanToString(Object test){
        if (test == null) return Boolean.FALSE.toString();
        return test.toString();
    }
   
    private static Boolean StringToBoolean(Object test){
        if (test == null) return false;
        if (test instanceof String)
            return Boolean.valueOf( (String) test);
        else
        if (test instanceof Boolean)
            return (Boolean) test;
        return false;
    }
   
           
        /**
         *  <p> This handler pings the  Jdbc Connection Pool
         */
        @Handler(id="pingJdbcConnectionPool",
            input={
                @HandlerInput(name="jndiName", type=String.class, required=true)})
        public static void pingJdbcConnectionPool(HandlerContext handlerCtx) {
       
            String jndiName = (String) handlerCtx.getInputValue("jndiName");
            String[] params = {jndiName, null};
            String[] signatures = {"java.lang.String", "java.lang.String" };
            try{
                Object result = JMXUtil.invoke( "com.sun.appserv:type=resources,category=config",
                            "pingConnectionPool",
                            params,
                            signatures);
                if ( (result != null) && (Boolean)result){
                    GuiUtil.prepareAlert(handlerCtx,"success", GuiUtil.getMessage("msg.PingSucceed"), null);
                }else{
                    GuiUtil.prepareAlert(handlerCtx, "error", GuiUtil.getMessage("msg.Error"), "msg.PingError");
                }
            }catch(Exception ex){
    GuiUtil.handleException(handlerCtx, ex);
            }
        }
    
       
        /**
         *  <p> This handler creates a JDBCConnection Pool to be used in the wizard
         */
        @Handler(id="getJDBCPoolWizard",
        input={
                @HandlerInput(name="fromStep2", type=Boolean.class)},
        output={
            @HandlerOutput(name="ResTypeList", type=java.util.List.class),
            @HandlerOutput(name="DBVendorList", type=java.util.List.class)
            } )
        public static void getJDBCPoolWizard(HandlerContext handlerCtx){
            //We need to use 2 maps for JDBC Connection Pool creation because there are extra info we need to keep track in
            //the wizard, but cannot be passed to the creation API.
           
            Boolean fromStep2 = (Boolean) handlerCtx.getInputValue("fromStep2");
            if ((fromStep2!= null) && fromStep2){
                //wizardPool is already in session map
            }else{
                Map defaultMap = AMXUtil.getDomainConfig().getDefaultAttributeValues(JDBCConnectionPoolConfig.J2EE_TYPE);
                Map attrMap = new HashMap();
                attrMap.put("SteadyPoolSize", defaultMap.get("steady-pool-size"));
                attrMap.put("MaxPoolSize", defaultMap.get("max-pool-size"));
                attrMap.put("MaxWaitTimeInMillis", defaultMap.get("max-wait-time-in-millis"));
                attrMap.put("PoolResizeQuantity", defaultMap.get("pool-resize-quantity"));
                attrMap.put("IdleTimeoutInSeconds", defaultMap.get("idle-timeout-in-seconds"));
                attrMap.put("IsIsolationLevelGuaranteed", defaultMap.get("is-isolation-level-guaranteed"));
                attrMap.put("IsConnectionValidationRequired", defaultMap.get("is-connection-validation-required"));
                attrMap.put("ConnectionValidationMethod", defaultMap.get("connection-validation-method"));
                attrMap.put("FailAllConnections", defaultMap.get("fail-all-connections"));
                attrMap.put("NonTransactionalConnections", defaultMap.get("non-transactional-connections"));
                attrMap.put("AllowNonComponentCallers", defaultMap.get("allow-non-component-callers"));
                            
                Map sessionMap = handlerCtx.getFacesContext().getExternalContext().getSessionMap();
                sessionMap.put("wizardPool", attrMap);
                sessionMap.put("wizardPoolExtra", new HashMap());
                sessionMap.put("wizardPoolProperties", new HashMap());
            }
            handlerCtx.setOutputValue("ResTypeList", resTypeList);
            handlerCtx.setOutputValue("DBVendorList", dbVendorList);
        }
       
        /**
         *  <p> This handler creates a JDBCConnection Pool to be used in the wizard
         */
        @Handler(id="updateJDBCPoolWizard")
        public static void updateJDBCPoolWizard(HandlerContext handlerCtx){
                Map pool = (Map) handlerCtx.getFacesContext().getExternalContext().getSessionMap().get("wizardPool");
                Map extra = (Map) handlerCtx.getFacesContext().getExternalContext().getSessionMap().get("wizardPoolExtra");
               
                String resType = (String) pool.get("ResType");
                String dbVendor = (String) extra.get("DBVendor");
               
                String previousResType = (String) extra.get("PreviousResType");
                String previousDB = (String) extra.get("PreviousDB");
               
                if (resType.equals(previousResType) && dbVendor.equals(previousDB) &&
                        !GuiUtil.isEmpty((String) extra.get("DatasourceClassname")) ){
                    //User didn't change type and DB, keep the datasource classname as the same.
                }else{
                   
                    if (!GuiUtil.isEmpty(resType) && !GuiUtil.isEmpty(dbVendor)){
                        String datasourceClassName = "";
                        if (resType.equals(DATA_SOURCE))
                            datasourceClassName =  dataSourceMap.get(dbVendor);
                        else
                        if (resType.equals(XADATA_SOURCE))
                            datasourceClassName =  XADataSourceMap.get(dbVendor);
                        else
                        if (resType.equals(CCDATA_SOURCE))
                            datasourceClassName =  CCDataSourceMap.get(dbVendor);
                       
                        if (datasourceClassName==null)
                            datasourceClassName="";
                        extra.put("DatasourceClassname",  datasourceClassName);
                        Map propsMap = ConnectorRuntime.getConnectionDefinitionPropertiesAndDefaults(datasourceClassName);
                        handlerCtx.getFacesContext().getExternalContext().getSessionMap().put("wizardPoolProperties", propsMap);
                    }
                   
        extra.put("PreviousResType", resType);
                    extra.put("PreviousDB", dbVendor);
                   
                }
        }

    /**
     *  <p> This handler creates a JDBCConnection Pool in DomainConfig
     */
    @Handler(id="createJdbcConnectionPool")
   
    public static void createJdbcConnectionPool(HandlerContext handlerCtx){
        try{
            Map pool = (Map) handlerCtx.getFacesContext().getExternalContext().getSessionMap().get("wizardPool");
            Map extra = (Map) handlerCtx.getFacesContext().getExternalContext().getSessionMap().get("wizardPoolExtra");
            Map properties = (Map) handlerCtx.getFacesContext().getExternalContext().getSessionMap().get("wizardPoolProperties");
            String name = (String) extra.get("name");
            String datasourceClassname = (String) extra.get("DatasourceClassname");
           
            String method = (String) pool.get("ConnectionValidationMethod");
            if ("table".equals(method)){
                String table = (String) pool.get("ValidationTableName");
                if (! GuiUtil.isEmpty(table))
                    pool.put ("ValidationTableName", table);
            }else{
                pool.remove("ValidationTableName");
            }
           
            Map allOptions = new HashMap(pool);
            allOptions = AMXUtil.convertToPropertiesOptionMap(properties, allOptions);
           
            JDBCConnectionPoolConfig newPool = AMXUtil.getDomainConfig().createJDBCConnectionPoolConfig(name, datasourceClassname, allOptions);
            newPool.setDescription((String) extra.get("Description"));
        }catch (Exception ex){
      GuiUtil.handleException(handlerCtx, ex);
        }
    }
       
  /**
     *  <p> This handler returns the list of Connector Connection Pools
     *  <p> Output value: "result" -- Type: <code>java.util.List</code></p>
     */
    @Handler(id="getJDBCConnectionPoolMaps",
        input={
            @HandlerInput(name="selectedRows", type=List.class)},
        output={
            @HandlerOutput(name="result", type=java.util.List.class)}
        )
    public static void getJDBCConnectionPoolMaps(HandlerContext handlerCtx) {
        List<Map> selectedList = (List)handlerCtx.getInputValue("selectedRows");
        boolean hasOrig = (selectedList == null || selectedList.size()==0) ? false: true;
        List result = new ArrayList();
        try{
  Iterator iter = AMXUtil.getDomainConfig().getJDBCConnectionPoolConfigMap().values().iterator();
        if(iter != null ){
            while(iter.hasNext()){
                JDBCConnectionPoolConfig res = (JDBCConnectionPoolConfig)iter.next();
                HashMap oneRow = new HashMap();
                oneRow.put("name", res.getName());
                oneRow.put("selected", (hasOrig)? ConnectorsHandlers.isSelected(res.getName(), selectedList): false);
                oneRow.put("resInfo", ConnectorsHandlers.checkEmpty(res.getResType()));
                oneRow.put("extraInfo", res.getDatasourceClassname());
                oneRow.put("description", ConnectorsHandlers.checkEmpty(res.getDescription()));
                result.add(oneRow);
            }
        }
        }catch (Exception ex){
            ex.printStackTrace();
        }
        handlerCtx.setOutputValue("result", result);
       
    }
   
    /**
     *  <p> This handler enable or disable the table text field according to the method value.
     */
    @Handler(id="setDisableConnectionPoolTableField",
        input={
            @HandlerInput(name="tableField", type=com.sun.webui.jsf.component.Field.class),
            @HandlerInput(name="methodValue", type=String.class)}
        )
    public static void setDisableConnectionPoolTableField(HandlerContext handlerCtx) {
        String methodValue = (String)handlerCtx.getInputValue("methodValue");
        Field tableField = (Field)handlerCtx.getInputValue("tableField");
        if("table".equals(methodValue)){
            tableField.setDisabled(false);
        }else
            tableField.setDisabled(true);
    }
   

        static private final String DATA_SOURCE = "javax.sql.DataSource";
  static private final String XADATA_SOURCE = "javax.sql.XADataSource";
  static private final String CCDATA_SOURCE = "javax.sql.ConnectionPoolDataSource";

  static private final String JAVADB = "JavaDB";
  static private final String ORACLE = "Oracle";
  static private final String DERBY = "Derby";
  static private final String SYBASE = "Sybase";
  static private final String DB2 = "DB2";
  static private final String POINTBASE = "PointBase";
  static private final String POSTGRESQL = "PostgreSQL";
  static private final String INFORMIX = "Informix";
  static private final String CLOUDSCAPE = "Cloudscape";
  static private final String MSSQL = "Microsoft SQL Server";
  static private final String MYSQL = "MySQL";
        static private Map<String, String> dataSourceMap = new HashMap();
        static private Map<String,String>  XADataSourceMap = new HashMap();
        static private Map<String,String> CCDataSourceMap = new HashMap();
        static private List resTypeList = new ArrayList();
        static private List dbVendorList = new ArrayList();
       
    static {
 
        dataSourceMap.put(ORACLE, "oracle.jdbc.pool.OracleDataSource");
  dataSourceMap.put(DERBY , "org.apache.derby.jdbc.ClientDataSource");
  dataSourceMap.put(JAVADB, "org.apache.derby.jdbc.ClientDataSource");
  dataSourceMap.put(DB2 , "com.ibm.db2.jdbc.DB2DataSource");
  dataSourceMap.put(MSSQL , "com.ddtek.jdbcx.sqlserver.SQLServerDataSource");
  dataSourceMap.put(SYBASE , "com.sybase.jdbc2.jdbc.SybDataSource");
  dataSourceMap.put(POINTBASE , "com.pointbase.jdbc.jdbcDataSource");
  dataSourceMap.put(CLOUDSCAPE , "com.cloudscape.core.BasicDataSource");
  dataSourceMap.put(INFORMIX , "com.informix.jdbcx.IfxDataSource");
  dataSourceMap.put(MYSQL , "com.mysql.jdbc.jdbc2.optional.MysqlDataSource" );
  dataSourceMap.put(POSTGRESQL , "org.postgresql.ds.PGSimpleDataSource");

 
  XADataSourceMap.put(ORACLE,  "oracle.jdbc.xa.client.OracleXADataSource");
  XADataSourceMap.put(DERBY,  "org.apache.derby.jdbc.ClientXADataSource");
  XADataSourceMap.put(JAVADB,  "org.apache.derby.jdbc.ClientXADataSource");
  XADataSourceMap.put(DB2,  "com.ibm.db2.jdbc.DB2XADataSource");
  XADataSourceMap.put(MSSQL,  "com.ddtek.jdbcx.sqlserver.SQLServerDataSource");
  XADataSourceMap.put(SYBASE,  "com.sybase.jdbc2.jdbc.SybXADataSource");
  XADataSourceMap.put(POINTBASE,  "com.pointbase.xa.xaDataSource");
  XADataSourceMap.put(CLOUDSCAPE,  "com.cloudscape.core.XADataSource");
  XADataSourceMap.put(INFORMIX,  "com.informix.jdbcx.IfxXADataSource");
  XADataSourceMap.put(MYSQL,  "com.mysql.jdbc.jdbc2.optional.MysqlXADataSource" );
  XADataSourceMap.put(POSTGRESQL,  "org.postgresql.xa.PGXADataSource");
 
  CCDataSourceMap.put(ORACLE, "oracle.jdbc.pool.OracleConnectionPoolDataSource");
  CCDataSourceMap.put(DB2, "com.ibm.db2.jdbc.DB2ConnectionPoolDataSource");
  CCDataSourceMap.put(SYBASE, "com.sybase.jdbc2.jdbc.SybConnectionPoolDataSource");
  CCDataSourceMap.put(DERBY, "org.apache.derby.jdbc.ClientConnectionPoolDataSource");
  CCDataSourceMap.put(JAVADB, "org.apache.derby.jdbc.ClientConnectionPoolDataSource");
  CCDataSourceMap.put(POSTGRESQL, "org.postgresql.ds.PGConnectionPoolDataSource");
        CCDataSourceMap.put(MYSQL, "com.mysql.jdbc.jdbc2.optional.MysqlConnectionPoolDataSource");
       
        resTypeList.add("");
        resTypeList.add(DATA_SOURCE);
        resTypeList.add(XADATA_SOURCE);
        resTypeList.add(CCDATA_SOURCE);
       
        dbVendorList.add("");
        dbVendorList.add(JAVADB);
        dbVendorList.add(ORACLE);
        dbVendorList.add(DERBY);
        dbVendorList.add(SYBASE);
        dbVendorList.add(DB2);
        dbVendorList.add(POINTBASE);
        dbVendorList.add(POSTGRESQL);
        dbVendorList.add(INFORMIX);
        dbVendorList.add(CLOUDSCAPE);
        dbVendorList.add(MSSQL);
        dbVendorList.add(MYSQL);
    }

}
       
 
TOP

Related Classes of com.sun.enterprise.tools.admingui.handlers.JdbcHandlers

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.