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

org.apache.shindig.gadgets.spec.Feature Maven / Gradle / Ivy

Go to download

Renders gadgets, provides the gadget metadata service, and serves all javascript required by the OpenSocial specification.

The newest version!
/*
 * 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.shindig.gadgets.spec;

import org.apache.commons.lang3.StringUtils;
import org.apache.shindig.common.xml.XmlUtil;
import org.w3c.dom.Element;
import org.w3c.dom.NodeList;

import java.util.Collection;
import java.util.Map;
import java.util.Set;

import com.google.common.base.Splitter;
import com.google.common.collect.ImmutableMultimap;
import com.google.common.collect.ImmutableSet;
import com.google.common.collect.Multimap;

/**
 * Represents a Require or Optional tag.
 * No substitutions on any fields.
 */
public class Feature {
  public static final Feature CORE_FEATURE = new Feature("core");
  public static final Feature SECURITY_TOKEN_FEATURE = new Feature("security-token");
  
  // Instantiable only by CORE_FEATURE.
  private Feature(String name) {
    this.params = ImmutableMultimap.of();
    this.required = true;
    this.name = name;
    this.views = ImmutableSet.of();
  }
  
  /**
   * Require@feature
   * Optional@feature
   */
  private final String name;
  public String getName() {
    return name;
  }

  /**
   * Require.Param
   * Optional.Param
   *
   * Flattened into a map where Param@name is the key and Param content is
   * the value.
   */
  private final Multimap params;
  public Multimap getParams() {
    return params;
  }
  
  /**
   * Returns the first value for any feature parameter, or null
   * if the parameter does not exist.
   */
  public String getParam(String key) {
    Collection values = params.get(key);
    if (values == null || values.isEmpty()) {
      return null;
    }
    
    return values.iterator().next();
  }

  /**
   * Returns the values for the key, or an empty collection.
   */
  public Collection getParamCollection(String key) {
    return params.get(key);
  }

  /**
   * Whether this is a Require or an Optional feature.
   */
  private final boolean required;
  public boolean getRequired() {
    return required;
  }
  
  /**
   * Require@views
   * Optional@views
   * 
   * Views associated with this feature
   */
  private final Set views;
  public Set getViews() {
    return views;
  }

  /**
   * Produces an xml representation of the feature.
   */
  @Override
  public String toString() {
    StringBuilder buf = new StringBuilder();
    buf.append(required ? "");
    for (Map.Entry> entry : params.asMap().entrySet()) {
      buf.append("\n")
         .append(entry.getValue())
         .append("");
    }
    buf.append(required ? "" : "");
    return buf.toString();
  }

  /**
   * Creates a new Feature from an xml node.
   *
   * @param feature The feature to create
   * @throws SpecParserException When the Require or Optional tag is not valid
   */
  public Feature(Element feature) throws SpecParserException {
    this.required = feature.getNodeName().equals("Require");
    String name = XmlUtil.getAttribute(feature, "feature");
    if (name == null) {
      throw new SpecParserException(
          (required ? "Require" : "Optional") +"@feature is required.");
    }
    this.name = name;
    NodeList children = feature.getElementsByTagName("Param");
    if (children.getLength() > 0) {
      ImmutableMultimap.Builder params = ImmutableMultimap.builder();

      for (int i = 0, j = children.getLength(); i < j; ++i) {
        Element param = (Element)children.item(i);
        String paramName = XmlUtil.getAttribute(param, "name");
        if (paramName == null) {
          throw new SpecParserException("Param@name is required");
        }
        params.put(paramName, param.getTextContent());
      }
      this.params = params.build();
    } else {
      this.params = ImmutableMultimap.of();
    }
    // Record all the associated views
    String viewNames = XmlUtil.getAttribute(feature, "views", "").trim();
    this.views = ImmutableSet.copyOf(Splitter.on(',').omitEmptyStrings().trimResults().split(viewNames));
  }

  
  /**
   * @param name feature name
   * @param params feature parameters
   * @param required true if feature is required, false otherwise
   * @param views views declared in the feature.
   */
  public Feature(String name, Multimap params,
      boolean required, Set views) {
    this.name = name;
    this.params = params;
    this.required = required;
    this.views = views;
  }
  
 
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy