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

io.cloudshiftdev.awscdk.services.ecs.AppMeshProxyConfigurationProps.kt Maven / Gradle / Ivy

The newest version!
@file:Suppress("RedundantVisibilityModifier","RedundantUnitReturnType","RemoveRedundantQualifierName","unused","UnusedImport","ClassName","REDUNDANT_PROJECTION","DEPRECATION")

package io.cloudshiftdev.awscdk.services.ecs

import io.cloudshiftdev.awscdk.common.CdkDslMarker
import io.cloudshiftdev.awscdk.common.CdkObject
import io.cloudshiftdev.awscdk.common.CdkObjectWrappers
import kotlin.Number
import kotlin.String
import kotlin.Unit
import kotlin.collections.List

/**
 * Interface for setting the properties of proxy configuration.
 *
 * Example:
 *
 * ```
 * // The code below shows an example of how to instantiate this type.
 * // The values are placeholders you should change.
 * import io.cloudshiftdev.awscdk.services.ecs.*;
 * AppMeshProxyConfigurationProps appMeshProxyConfigurationProps =
 * AppMeshProxyConfigurationProps.builder()
 * .appPorts(List.of(123))
 * .proxyEgressPort(123)
 * .proxyIngressPort(123)
 * // the properties below are optional
 * .egressIgnoredIPs(List.of("egressIgnoredIPs"))
 * .egressIgnoredPorts(List.of(123))
 * .ignoredGID(123)
 * .ignoredUID(123)
 * .build();
 * ```
 */
public interface AppMeshProxyConfigurationProps {
  /**
   * The list of ports that the application uses.
   *
   * Network traffic to these ports is forwarded to the ProxyIngressPort and ProxyEgressPort.
   */
  public fun appPorts(): List

  /**
   * The egress traffic going to these specified IP addresses is ignored and not redirected to the
   * ProxyEgressPort.
   *
   * It can be an empty list.
   */
  public fun egressIgnoredIPs(): List = unwrap(this).getEgressIgnoredIPs() ?: emptyList()

  /**
   * The egress traffic going to these specified ports is ignored and not redirected to the
   * ProxyEgressPort.
   *
   * It can be an empty list.
   */
  public fun egressIgnoredPorts(): List = unwrap(this).getEgressIgnoredPorts() ?:
      emptyList()

  /**
   * The group ID (GID) of the proxy container as defined by the user parameter in a container
   * definition.
   *
   * This is used to ensure the proxy ignores its own traffic. If IgnoredUID is specified, this
   * field can be empty.
   */
  public fun ignoredGID(): Number? = unwrap(this).getIgnoredGID()

  /**
   * The user ID (UID) of the proxy container as defined by the user parameter in a container
   * definition.
   *
   * This is used to ensure the proxy ignores its own traffic. If IgnoredGID is specified, this
   * field can be empty.
   */
  public fun ignoredUID(): Number? = unwrap(this).getIgnoredUID()

  /**
   * Specifies the port that outgoing traffic from the AppPorts is directed to.
   */
  public fun proxyEgressPort(): Number

  /**
   * Specifies the port that incoming traffic to the AppPorts is directed to.
   */
  public fun proxyIngressPort(): Number

  /**
   * A builder for [AppMeshProxyConfigurationProps]
   */
  @CdkDslMarker
  public interface Builder {
    /**
     * @param appPorts The list of ports that the application uses. 
     * Network traffic to these ports is forwarded to the ProxyIngressPort and ProxyEgressPort.
     */
    public fun appPorts(appPorts: List)

    /**
     * @param appPorts The list of ports that the application uses. 
     * Network traffic to these ports is forwarded to the ProxyIngressPort and ProxyEgressPort.
     */
    public fun appPorts(vararg appPorts: Number)

    /**
     * @param egressIgnoredIPs The egress traffic going to these specified IP addresses is ignored
     * and not redirected to the ProxyEgressPort.
     * It can be an empty list.
     */
    public fun egressIgnoredIPs(egressIgnoredIPs: List)

    /**
     * @param egressIgnoredIPs The egress traffic going to these specified IP addresses is ignored
     * and not redirected to the ProxyEgressPort.
     * It can be an empty list.
     */
    public fun egressIgnoredIPs(vararg egressIgnoredIPs: String)

    /**
     * @param egressIgnoredPorts The egress traffic going to these specified ports is ignored and
     * not redirected to the ProxyEgressPort.
     * It can be an empty list.
     */
    public fun egressIgnoredPorts(egressIgnoredPorts: List)

    /**
     * @param egressIgnoredPorts The egress traffic going to these specified ports is ignored and
     * not redirected to the ProxyEgressPort.
     * It can be an empty list.
     */
    public fun egressIgnoredPorts(vararg egressIgnoredPorts: Number)

    /**
     * @param ignoredGid The group ID (GID) of the proxy container as defined by the user parameter
     * in a container definition.
     * This is used to ensure the proxy ignores its own traffic. If IgnoredUID is specified, this
     * field can be empty.
     */
    public fun ignoredGid(ignoredGid: Number)

    /**
     * @param ignoredUid The user ID (UID) of the proxy container as defined by the user parameter
     * in a container definition.
     * This is used to ensure the proxy ignores its own traffic. If IgnoredGID is specified, this
     * field can be empty.
     */
    public fun ignoredUid(ignoredUid: Number)

    /**
     * @param proxyEgressPort Specifies the port that outgoing traffic from the AppPorts is directed
     * to. 
     */
    public fun proxyEgressPort(proxyEgressPort: Number)

    /**
     * @param proxyIngressPort Specifies the port that incoming traffic to the AppPorts is directed
     * to. 
     */
    public fun proxyIngressPort(proxyIngressPort: Number)
  }

  private class BuilderImpl : Builder {
    private val cdkBuilder:
        software.amazon.awscdk.services.ecs.AppMeshProxyConfigurationProps.Builder =
        software.amazon.awscdk.services.ecs.AppMeshProxyConfigurationProps.builder()

    /**
     * @param appPorts The list of ports that the application uses. 
     * Network traffic to these ports is forwarded to the ProxyIngressPort and ProxyEgressPort.
     */
    override fun appPorts(appPorts: List) {
      cdkBuilder.appPorts(appPorts)
    }

    /**
     * @param appPorts The list of ports that the application uses. 
     * Network traffic to these ports is forwarded to the ProxyIngressPort and ProxyEgressPort.
     */
    override fun appPorts(vararg appPorts: Number): Unit = appPorts(appPorts.toList())

    /**
     * @param egressIgnoredIPs The egress traffic going to these specified IP addresses is ignored
     * and not redirected to the ProxyEgressPort.
     * It can be an empty list.
     */
    override fun egressIgnoredIPs(egressIgnoredIPs: List) {
      cdkBuilder.egressIgnoredIPs(egressIgnoredIPs)
    }

    /**
     * @param egressIgnoredIPs The egress traffic going to these specified IP addresses is ignored
     * and not redirected to the ProxyEgressPort.
     * It can be an empty list.
     */
    override fun egressIgnoredIPs(vararg egressIgnoredIPs: String): Unit =
        egressIgnoredIPs(egressIgnoredIPs.toList())

    /**
     * @param egressIgnoredPorts The egress traffic going to these specified ports is ignored and
     * not redirected to the ProxyEgressPort.
     * It can be an empty list.
     */
    override fun egressIgnoredPorts(egressIgnoredPorts: List) {
      cdkBuilder.egressIgnoredPorts(egressIgnoredPorts)
    }

    /**
     * @param egressIgnoredPorts The egress traffic going to these specified ports is ignored and
     * not redirected to the ProxyEgressPort.
     * It can be an empty list.
     */
    override fun egressIgnoredPorts(vararg egressIgnoredPorts: Number): Unit =
        egressIgnoredPorts(egressIgnoredPorts.toList())

    /**
     * @param ignoredGid The group ID (GID) of the proxy container as defined by the user parameter
     * in a container definition.
     * This is used to ensure the proxy ignores its own traffic. If IgnoredUID is specified, this
     * field can be empty.
     */
    override fun ignoredGid(ignoredGid: Number) {
      cdkBuilder.ignoredGid(ignoredGid)
    }

    /**
     * @param ignoredUid The user ID (UID) of the proxy container as defined by the user parameter
     * in a container definition.
     * This is used to ensure the proxy ignores its own traffic. If IgnoredGID is specified, this
     * field can be empty.
     */
    override fun ignoredUid(ignoredUid: Number) {
      cdkBuilder.ignoredUid(ignoredUid)
    }

    /**
     * @param proxyEgressPort Specifies the port that outgoing traffic from the AppPorts is directed
     * to. 
     */
    override fun proxyEgressPort(proxyEgressPort: Number) {
      cdkBuilder.proxyEgressPort(proxyEgressPort)
    }

    /**
     * @param proxyIngressPort Specifies the port that incoming traffic to the AppPorts is directed
     * to. 
     */
    override fun proxyIngressPort(proxyIngressPort: Number) {
      cdkBuilder.proxyIngressPort(proxyIngressPort)
    }

    public fun build(): software.amazon.awscdk.services.ecs.AppMeshProxyConfigurationProps =
        cdkBuilder.build()
  }

  private class Wrapper(
    cdkObject: software.amazon.awscdk.services.ecs.AppMeshProxyConfigurationProps,
  ) : CdkObject(cdkObject),
      AppMeshProxyConfigurationProps {
    /**
     * The list of ports that the application uses.
     *
     * Network traffic to these ports is forwarded to the ProxyIngressPort and ProxyEgressPort.
     */
    override fun appPorts(): List = unwrap(this).getAppPorts()

    /**
     * The egress traffic going to these specified IP addresses is ignored and not redirected to the
     * ProxyEgressPort.
     *
     * It can be an empty list.
     */
    override fun egressIgnoredIPs(): List = unwrap(this).getEgressIgnoredIPs() ?:
        emptyList()

    /**
     * The egress traffic going to these specified ports is ignored and not redirected to the
     * ProxyEgressPort.
     *
     * It can be an empty list.
     */
    override fun egressIgnoredPorts(): List = unwrap(this).getEgressIgnoredPorts() ?:
        emptyList()

    /**
     * The group ID (GID) of the proxy container as defined by the user parameter in a container
     * definition.
     *
     * This is used to ensure the proxy ignores its own traffic. If IgnoredUID is specified, this
     * field can be empty.
     */
    override fun ignoredGID(): Number? = unwrap(this).getIgnoredGID()

    /**
     * The user ID (UID) of the proxy container as defined by the user parameter in a container
     * definition.
     *
     * This is used to ensure the proxy ignores its own traffic. If IgnoredGID is specified, this
     * field can be empty.
     */
    override fun ignoredUID(): Number? = unwrap(this).getIgnoredUID()

    /**
     * Specifies the port that outgoing traffic from the AppPorts is directed to.
     */
    override fun proxyEgressPort(): Number = unwrap(this).getProxyEgressPort()

    /**
     * Specifies the port that incoming traffic to the AppPorts is directed to.
     */
    override fun proxyIngressPort(): Number = unwrap(this).getProxyIngressPort()
  }

  public companion object {
    public operator fun invoke(block: Builder.() -> Unit = {}): AppMeshProxyConfigurationProps {
      val builderImpl = BuilderImpl()
      return Wrapper(builderImpl.apply(block).build())
    }

    internal
        fun wrap(cdkObject: software.amazon.awscdk.services.ecs.AppMeshProxyConfigurationProps):
        AppMeshProxyConfigurationProps = CdkObjectWrappers.wrap(cdkObject) as?
        AppMeshProxyConfigurationProps ?: Wrapper(cdkObject)

    internal fun unwrap(wrapped: AppMeshProxyConfigurationProps):
        software.amazon.awscdk.services.ecs.AppMeshProxyConfigurationProps = (wrapped as
        CdkObject).cdkObject as software.amazon.awscdk.services.ecs.AppMeshProxyConfigurationProps
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy