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

com.netflix.spinnaker.front50.config.S3Properties Maven / Gradle / Ivy

The newest version!
/*
 * Copyright 2016 Netflix, Inc.
 *
 * Licensed 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 com.netflix.spinnaker.front50.config;

import org.springframework.boot.context.properties.NestedConfigurationProperty;

public abstract class S3Properties extends S3BucketProperties {
  String rootFolder = "front50";

  @NestedConfigurationProperty S3FailoverProperties failover = new S3FailoverProperties();

  @NestedConfigurationProperty S3EventingProperties eventing = new S3EventingProperties();

  // Front50 retrieves objects in batches of this size. Some S3 compatible store enforce a maximum
  // number of keys
  private Integer maxKeys = 10000;

  public String getRootFolder() {
    return rootFolder;
  }

  public void setRootFolder(String rootFolder) {
    this.rootFolder = rootFolder;
  }

  public Integer getMaxKeys() {
    return maxKeys;
  }

  public void setMaxKeys(Integer maxKeys) {
    this.maxKeys = maxKeys;
  }

  public S3FailoverProperties getFailover() {
    return failover;
  }

  public void setFailover(S3FailoverProperties failover) {
    this.failover = failover;
  }

  public boolean isFailoverEnabled() {
    return failover != null && failover.enabled;
  }

  public S3EventingProperties getEventing() {
    return eventing;
  }

  public void setEventing(S3EventingProperties eventing) {
    this.eventing = eventing;
  }

  @Override
  public String getBucket() {
    if (isFailoverEnabled()) {
      return failover.getBucket();
    }
    return super.getBucket();
  }

  @Override
  public String getRegion() {
    if (isFailoverEnabled()) {
      return failover.getRegion();
    }
    return super.getRegion();
  }

  @Override
  public String getRegionOverride() {
    if (isFailoverEnabled()) {
      return failover.getRegionOverride();
    }

    return super.getRegionOverride();
  }

  @Override
  public String getEndpoint() {
    if (isFailoverEnabled()) {
      return failover.getEndpoint();
    }
    return super.getEndpoint();
  }

  @Override
  public String getProxyHost() {
    if (isFailoverEnabled()) {
      return failover.getProxyHost();
    }
    return super.getProxyHost();
  }

  @Override
  public String getProxyPort() {
    if (isFailoverEnabled()) {
      return failover.getProxyPort();
    }
    return super.getProxyPort();
  }

  @Override
  public String getProxyProtocol() {
    if (isFailoverEnabled()) {
      return failover.getProxyProtocol();
    }
    return super.getProxyProtocol();
  }

  @Override
  public Boolean getVersioning() {
    if (isFailoverEnabled()) {
      return failover.getVersioning();
    }

    return super.getVersioning();
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy