All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.glassfish.jca.admingui.handlers.ConnectorsHandlers Maven / Gradle / Ivy


/*
 * 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.
 */

/*
 * ConnectorHandlers.java
 *
 * Created on Sept 1, 2006, 8:32 AM
 *
 * To change this template, choose Tools | Template Manager
 * and open the template in the editor.
 */
/**
 *
 */
package org.glassfish.jca.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.List;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Map;
import java.util.HashMap;


import org.glassfish.admingui.common.util.GuiUtil;
import org.glassfish.admingui.common.util.V3AMX;


public class ConnectorsHandlers {

    /** Creates a new instance of ConnectorsHandler */
    public ConnectorsHandlers() {
    }


    /**
     *	

This handler creates a ConnectorConnection Pool to be used in the wizard */ @Handler(id = "getConnectorConnectionPoolWizard", input = { @HandlerInput(name = "fromStep2", type = Boolean.class), @HandlerInput(name = "fromStep1", type = Boolean.class), @HandlerInput(name = "attrMap", type = Map.class), @HandlerInput(name = "poolName", type = String.class), @HandlerInput(name = "resAdapter", type = String.class) }, output = { @HandlerOutput(name = "connectionDefinitions", type = List.class) }) public static void getConnectorConnectionPoolWizard(HandlerContext handlerCtx) { Boolean fromStep2 = (Boolean) handlerCtx.getInputValue("fromStep2"); Boolean fromStep1 = (Boolean) handlerCtx.getInputValue("fromStep1"); if ((fromStep2 != null) && fromStep2) { //valueMap is already in session map, we don't want to change anything. Map extra = (Map) handlerCtx.getFacesContext().getExternalContext().getSessionMap().get("wizardPoolExtra"); String resAdapter = (String) extra.get("ResourceAdapterName"); List defs = getConnectionDefinitions(resAdapter); handlerCtx.setOutputValue("connectionDefinitions", defs); } else if ((fromStep1 != null) && fromStep1) { //this is from Step 1 where the page is navigated when changing the dropdown of resource adapter. //since the dropdown is immediate, the wizardPoolExtra map is not updated yet, we need //to update it manually and also set the connection definition map according to this resource adapter. String resAdapter = (String) handlerCtx.getInputValue("resAdapter"); String poolName = (String) handlerCtx.getInputValue("poolName"); if (resAdapter == null || resAdapter.equals("")) { handlerCtx.setOutputValue("connectionDefinitions", new ArrayList()); } else { Map extra = (Map) handlerCtx.getFacesContext().getExternalContext().getSessionMap().get("wizardPoolExtra"); extra.put("ResourceAdapterName", resAdapter); extra.put("Name", poolName); List defs = getConnectionDefinitions(resAdapter); handlerCtx.setOutputValue("connectionDefinitions", defs); } } else { Map extra = new HashMap(); Map attrMap = (Map) handlerCtx.getInputValue("attrMap"); handlerCtx.getFacesContext().getExternalContext().getSessionMap().put("valueMap", attrMap); handlerCtx.getFacesContext().getExternalContext().getSessionMap().put("wizardPoolExtra", extra); } } /** *

updates the wizard map */ @Handler(id = "updateConnectorConnectionPoolWizard") public static void updateConnectorConnectionPoolWizard(HandlerContext handlerCtx) { Map extra = (Map) handlerCtx.getFacesContext().getExternalContext().getSessionMap().get("wizardPoolExtra"); String resAdapter = (String) extra.get("ResourceAdapterName"); String definition = (String) extra.get("ConnectionDefinitionName"); String previousDefinition = (String) extra.get("previousDefinition"); String previousResAdapter = (String) extra.get("previousResAdapter"); if (definition.equals(previousDefinition) && resAdapter.equals(previousResAdapter)) { //User didn't change defintion and adapter, keep the properties table content the same. } else { List propsList = new ArrayList(); if (!GuiUtil.isEmpty(definition) && !GuiUtil.isEmpty(resAdapter)) { Map result = (Map) V3AMX.getInstance().getConnectorRuntime().getMCFConfigProps(resAdapter, definition); Map props = (Map) result.get(MCF_CONFIG_PROPS_KEY); if(props != null){ handlerCtx.getFacesContext().getExternalContext().getSessionMap().put("wizardPoolProperties", GuiUtil.convertMapToListOfMap(props)); } else { handlerCtx.getFacesContext().getExternalContext().getSessionMap().put("wizardPoolProperties", propsList); } } extra.put("previousDefinition", definition); extra.put("previousResAdapter", resAdapter); } } /** *

updates the wizard map properties on step 2 */ @Handler(id = "updateConnectorConnectionPoolWizardStep2") public static void updateConnectorConnectionPoolWizardStep2(HandlerContext handlerCtx) { Map extra = (Map) handlerCtx.getFacesContext().getExternalContext().getSessionMap().get("wizardPoolExtra"); Map attrs = (Map) handlerCtx.getFacesContext().getExternalContext().getSessionMap().get("valueMap"); String resAdapter = (String) extra.get("ResourceAdapterName"); String definition = (String) extra.get("ConnectionDefinitionName"); String name = (String) extra.get("Name"); attrs.put("Name", name); attrs.put("ConnectionDefinitionName", definition); attrs.put("ResourceAdapterName", resAdapter); } /** *

Adds the list of pre-installed system resource-adapters */ @Handler(id = "addSystemConnectors", input = { @HandlerInput(name = "rarList", type = List.class)}, output = { @HandlerOutput(name = "result", type = List.class) }) public static void addSystemConnectors(HandlerContext handlerCtx) { List rarList = (List) handlerCtx.getInputValue("rarList"); if (rarList == null){ rarList = new ArrayList(); } Map entries = (Map)V3AMX.getInstance().getConnectorRuntime().attributesMap().get("SystemConnectorsAllowingPoolCreation"); String[] emap = (String[])entries.get(SYSTEM_CONNECTORS_KEY); if(emap != null) { rarList.addAll(Arrays.asList(emap)); } handlerCtx.setOutputValue("result", rarList); } /** *

This returns the connection definitions based on resource adapter */ @Handler(id = "getConnectionDefinitionsForRA", input = { @HandlerInput(name = "resourceAdapter", type = String.class)}, output = { @HandlerOutput(name = "result", type = List.class) }) public static void getConnectionDefinitionsForRA(HandlerContext handlerCtx) { String ra = (String) handlerCtx.getInputValue("resourceAdapter"); handlerCtx.setOutputValue("result", getConnectionDefinitions(ra)); } private static List getConnectionDefinitions(String resAdapter) { ArrayList defs = new ArrayList(); if (resAdapter == null || resAdapter.equals("")) { return defs; } else { Map result = (Map) V3AMX.getInstance().getConnectorRuntime().getConnectionDefinitionNames(resAdapter); String[] names = (String[]) result.get(CONNECTION_DEFINITION_NAMES_KEY); if (names != null) { return Arrays.asList(names); } else { return defs; } } } /** *

This handler determines whether usergroups or principals will be used and returns appropriate string array */ @Handler(id="convertSecurityMapPropsToStringArray", input={ @HandlerInput(name="usersOptions", type=String.class), @HandlerInput(name="edit", type=String.class), @HandlerInput(name="userGroups", type=String.class), @HandlerInput(name="principals", type=String.class) }, output = { @HandlerOutput(name = "principalsSA", type = String[].class), @HandlerOutput(name = "usersSA", type = String[].class) }) public static void convertSecurityMapPropsToStringArray(HandlerContext handlerCtx) { String option = (String) handlerCtx.getInputValue("usersOptions"); String edit = (String) handlerCtx.getInputValue("edit"); String userGroups = (String) handlerCtx.getInputValue("userGroups"); String principals = (String) handlerCtx.getInputValue("principals"); String value = null; String[] str = null; Object emptyVal = null; boolean usePrincipals = false; //Take either userGroups or Principals if(option != null){ value = userGroups; usePrincipals = false; } else { value = principals; usePrincipals = true; } if (value != null && value.indexOf(",") != -1) { str = GuiUtil.stringToArray(value, ","); } else { str = new String[1]; str[0] = value; } if(edit.equals("true")) emptyVal = new String[1]; handlerCtx.setOutputValue("principalsSA", (usePrincipals)? str : emptyVal); handlerCtx.setOutputValue("usersSA", (usePrincipals)? emptyVal : str); } public static final String CONNECTION_DEFINITION_NAMES_KEY = "ConnectionDefinitionNamesKey"; public static final String MCF_CONFIG_PROPS_KEY = "McfConfigPropsKey"; public static final String SYSTEM_CONNECTORS_KEY = "SystemConnectorsKey"; }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy