Package org.apache.hadoop.gateway.deploy

Source Code of org.apache.hadoop.gateway.deploy.DeploymentContextImpl

/**
* 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.hadoop.gateway.deploy;

import org.apache.hadoop.gateway.config.GatewayConfig;
import org.apache.hadoop.gateway.descriptor.FilterParamDescriptor;
import org.apache.hadoop.gateway.descriptor.GatewayDescriptor;
import org.apache.hadoop.gateway.descriptor.ResourceDescriptor;
import org.apache.hadoop.gateway.topology.Provider;
import org.apache.hadoop.gateway.topology.Service;
import org.apache.hadoop.gateway.topology.Topology;
import org.jboss.shrinkwrap.api.spec.WebArchive;
import org.jboss.shrinkwrap.descriptor.api.webapp30.WebAppDescriptor;

import java.util.HashMap;
import java.util.List;
import java.util.Map;

public class DeploymentContextImpl implements DeploymentContext {

  private GatewayConfig gatewayConfig;
  private Topology topology;
  private GatewayDescriptor gatewayDescriptor;
  private WebArchive webArchive;
  private WebAppDescriptor webAppDescriptor;
  Map<String,List<ProviderDeploymentContributor>> providers;
  Map<String,List<ServiceDeploymentContributor>> services;
  private Map<String,Object> descriptors;

  public DeploymentContextImpl(
      GatewayConfig gatewayConfig,
      Topology topology,
      GatewayDescriptor gatewayDescriptor,
      WebArchive webArchive,
      WebAppDescriptor webAppDescriptor,
      Map<String,List<ProviderDeploymentContributor>> providers,
      Map<String,List<ServiceDeploymentContributor>> services ) {
    this.gatewayConfig = gatewayConfig;
    this.topology = topology;
    this.gatewayDescriptor = gatewayDescriptor;
    this.webArchive = webArchive;
    this.webAppDescriptor = webAppDescriptor;
    this.providers = providers;
    this.services = services;
    this.descriptors = new HashMap<String,Object>();
  }

//  @Override
//  public ServiceDeploymentContributor getServiceContributor( String role, String name ) {
//    ServiceDeploymentContributor contributor = null;
//    if( name == null ) {
//      List<ServiceDeploymentContributor> list = services.get( role );
//      if( !list.isEmpty() ) {
//        contributor = list.get( 0 );
//      }
//    } else {
//      contributor = DeploymentFactory.getServiceContributor( role, name );
//    }
//    return contributor;
//  }

//  @Override
//  public ResourceDescriptorFactory getResourceDescriptorFactory( Service service ) {
//    return GatewayDescriptorFactory.getResourceDescriptorFactory( service );
//  }
//
//  @Override
//  public FilterDescriptorFactory getFilterDescriptorFactory( String filterRole ) {
//    return GatewayDescriptorFactory.getFilterDescriptorFactory( filterRole );
//  }

  @Override
  public GatewayConfig getGatewayConfig() {
    return gatewayConfig;
  }

  @Override
  public Topology getTopology() {
    return topology;
  }

  @Override
  public WebArchive getWebArchive() {
    return webArchive;
  }

  @Override
  public WebAppDescriptor getWebAppDescriptor() {
    return webAppDescriptor;
  }

  @Override
  public GatewayDescriptor getGatewayDescriptor() {
    return gatewayDescriptor;
  }

  @Override
  public void contributeFilter(
      Service service,
      ResourceDescriptor resource,
      String role,
      String name,
      List<FilterParamDescriptor> params ) {
    ProviderDeploymentContributor contributor = DeploymentFactory.getProviderContributor( providers, role, name );
    Provider provider = getTopology().getProvider( role, name );
//    if( provider != null ) {
//      System.out.println("=================== provider found by name: " + name + " with actual name of: " + provider.getName());
//    }
    if( provider == null ) {
      provider = new Provider();
      provider.setRole( role );
      provider.setName( name );
      provider.setEnabled( true );
    }
    if( provider.isEnabled() ) {
      contributor.contributeFilter( this, provider, service, resource, params );
    }
  }

  @Override
  public void addDescriptor( String name, Object descriptor ) {
    descriptors.put( name, descriptor );
  }

  @Override
  @SuppressWarnings("unchecked")
  public <T> T getDescriptor( String name ) {
    return (T)descriptors.get( name );
  }

}
TOP

Related Classes of org.apache.hadoop.gateway.deploy.DeploymentContextImpl

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.