/* * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER. * * Copyright (c) 2011 Oracle and/or its affiliates. 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_1_1.html * or packager/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 packager/legal/LICENSE.txt. * * GPL Classpath Exception: * Oracle designates this particular file as subject to the "Classpath" * exception as provided by Oracle in the GPL Version 2 section of the License * file that accompanied this code. * * Modifications: * If applicable, add the following below the License Header, with the fields * enclosed by brackets [] replaced by your own identifying information: * "Portions Copyright [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. */ /* * RestUitlHandlers.java * * Created on July 1,2010 9:32 PM * * To change this template, choose Tools | Template Manager * and open the template in the editor. */ /** * * @author anilam */ package org.glassfish.admingui.common.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.HashMap; import java.util.Map; import java.util.List; import java.util.Locale; import org.glassfish.admingui.common.util.GuiUtil; import org.glassfish.admingui.common.util.RestUtil; public class RestUtilHandlers { public RestUtilHandlers() { } @Handler(id = "gf.callRestAndExtractMsgProps", input = { @HandlerInput(name="endpoint", type=String.class, required=true), @HandlerInput(name="attrs", type=Map.class, required=false), @HandlerInput(name="method", type=String.class, defaultValue="post"), @HandlerInput(name="index", type=Integer.class, defaultValue="0") }, output = { @HandlerOutput(name = "keyList", type = List.class), @HandlerOutput(name = "propsMap", type = Map.class), @HandlerOutput(name = "listEmpty", type = Boolean.class) }) public static void callRestAndExtractMsgProps(HandlerContext handlerCtx) { Map<String, Object> attrs = (Map<String, Object>) handlerCtx.getInputValue("attrs"); String endpoint = (String) handlerCtx.getInputValue("endpoint"); String method = ((String) handlerCtx.getInputValue("method")).toLowerCase(GuiUtil.guiLocale); int index = (Integer) handlerCtx.getInputValue("index"); try{ Map responseMap = RestUtil.restRequest( endpoint , attrs, method , handlerCtx, false); ArrayList messages = (ArrayList) responseMap.get("messages"); if (messages != null) { Map message = (Map) messages.get(index); List<Map<String, String>> props = (List<Map<String, String>>) message.get("properties"); processProps(props, handlerCtx); } }catch (Exception ex){ GuiUtil.getLogger().severe("Error in callRestAndExtratResponse ; \nendpoint = " + endpoint + "attrs=" + attrs + "method="+method); //we don't need to call GuiUtil.handleError() because thats taken care of in restRequest() when we pass in the handler. } } /* * This handler takes in the properties list of "message" which is from the RestResponse. * extrct the info from this list. */ @Handler(id = "gf.getMessageProps", input = { @HandlerInput(name = "messageListProps", type = List.class, required = true), @HandlerInput(name = "id", type = String.class) }, output = { @HandlerOutput(name = "keyList", type = List.class), @HandlerOutput(name = "propsMap", type = Map.class), @HandlerOutput(name = "listEmpty", type = Boolean.class) }) public static void getMessageProps(HandlerContext handlerCtx) { //If restRequest() change to output json, this needs to be changed. List<Map<String, String>> props = (List<Map<String, String>>) handlerCtx.getInputValue("messageListProps"); String id = (String) handlerCtx.getInputValue("id"); if (id == null) processProps(props, handlerCtx); else processProps(props, handlerCtx, id); } /* * This handler takes the format * [{properites={name="NAME1"}}, {properites={name="NAME2"}}] * It is used in list-instances */ @Handler(id = "gf.getPropertiesList", input = { @HandlerInput(name = "listProps", type = List.class, required = true) }, output = { @HandlerOutput(name = "keyList", type = List.class)}) public static void getPropertiesList(HandlerContext handlerCtx) { //If restRequest() change to output json, this needs to be changed. List<Map<String, Object>> props = (List<Map<String, Object>>) handlerCtx.getInputValue("listProps"); List<String> keyList = getListFromPropertiesList(props); handlerCtx.setOutputValue("keyList", keyList); } public static List<String> getListFromPropertiesList(List<Map<String, Object>> props) { List<String> keyList = new ArrayList<String>(); if (props != null) { for (Map<String, Object> map : props) { Map<String, String> oneProp = (Map<String, String>) map.get("properties"); keyList.add(oneProp.get("name")); } } return keyList; } public static void processProps(List<Map<String, String>>props, HandlerContext handlerCtx, String... ids){ List keyList = new ArrayList(); Map propsMap = new HashMap(); String id = "name"; if (ids != null) { id = ids.length > 0 ? ids[0] : "name"; } try{ for(Map<String, String> oneProp : props){ keyList.add(oneProp.get(id)); //Issue 12141 : map is returning in the form of name=val. //Once fixed, this condition will be removed. if (oneProp.get(id).contains("=")) { String key = oneProp.get(id); propsMap.put(key.substring(0, key.indexOf("=")), key.substring(key.indexOf("=") + 1)); } else { propsMap.put(oneProp.get(id), oneProp.get("value")); } } }catch(Exception ex){ //log error ? } handlerCtx.setOutputValue("keyList", keyList); handlerCtx.setOutputValue("propsMap", propsMap); handlerCtx.setOutputValue("listEmpty", keyList.isEmpty()); } public static List<String> getListFromMapKey(List<Map<String, String>> props, String... ids) { List<String> keyList = new ArrayList<String>(); String id = "name"; if (ids != null) { id = ids.length > 0 ? ids[0] : "name"; } if (props != null) { for (Map<String, String> oneProp : props) { keyList.add(oneProp.get(id)); } } return keyList; } public static Map<String, String> getMapFromMapKey(List<Map<String, String>> props, String... ids) { Map<String, String> propsMap = new HashMap<String, String>(); String id = "name"; if (ids != null) { id = ids.length > 0 ? ids[0] : "name"; } if (props != null) { for (Map<String, String> oneProp : props) { //Issue 12141 : map is returning in the form of name=val. //Once fixed, this condition will be removed. if (oneProp.get(id).contains("=")) { String key = oneProp.get(id); propsMap.put(key.substring(0, key.indexOf("=")), key.substring(key.indexOf("=") + 1)); } else { propsMap.put(oneProp.get(id), oneProp.get("value")); } } } return propsMap; } }