com.microsoft.azure.management.network.ApplicationGatewayRequestRoutingRule Maven / Gradle / Ivy
Show all versions of azure-mgmt-network Show documentation
/**
* Copyright (c) Microsoft Corporation. All rights reserved.
* Licensed under the MIT License. See License.txt in the project root for
* license information.
*/
package com.microsoft.azure.management.network;
import java.util.Collection;
import com.microsoft.azure.management.apigeneration.Fluent;
import com.microsoft.azure.management.apigeneration.Method;
import com.microsoft.azure.management.network.implementation.ApplicationGatewayRequestRoutingRuleInner;
import com.microsoft.azure.management.network.model.HasBackendPort;
import com.microsoft.azure.management.network.model.HasCookieBasedAffinity;
import com.microsoft.azure.management.network.model.HasFrontendPort;
import com.microsoft.azure.management.network.model.HasHostName;
import com.microsoft.azure.management.network.model.HasPublicIPAddress;
import com.microsoft.azure.management.network.model.HasServerNameIndication;
import com.microsoft.azure.management.network.model.HasSslCertificate;
import com.microsoft.azure.management.resources.fluentcore.arm.models.ChildResource;
import com.microsoft.azure.management.resources.fluentcore.model.Attachable;
import com.microsoft.azure.management.resources.fluentcore.model.Settable;
import com.microsoft.azure.management.resources.fluentcore.model.HasInner;
/**
* A client-side representation of an application gateway request routing rule.
*/
@Fluent()
public interface ApplicationGatewayRequestRoutingRule extends
HasInner,
ChildResource,
HasPublicIPAddress,
HasSslCertificate,
HasFrontendPort,
HasBackendPort,
HasHostName,
HasCookieBasedAffinity,
HasServerNameIndication {
/**
* @return the frontend protocol
*/
ApplicationGatewayProtocol frontendProtocol();
/**
* @return rule type
*/
ApplicationGatewayRequestRoutingRuleType ruleType();
/**
* @return the associated backend address pool
*/
ApplicationGatewayBackend backend();
/**
* @return the associated backend HTTP settings configuration
*/
ApplicationGatewayBackendHttpConfiguration backendHttpConfiguration();
/**
* @return the associated frontend HTTP listener
*/
ApplicationGatewayListener listener();
/**
* @return the addresses assigned to the associated backend
*/
Collection backendAddresses();
// TODO urlPathMap()
/**
* Grouping of application gateway request routing rule definition stages.
*/
interface DefinitionStages {
/**
* The first stage of an application gateway request routing rule definition.
* @param the stage of the application gateway definition to return to after attaching this definition
*/
interface Blank extends WithListenerOrFrontend {
}
/** The final stage of an application gateway request routing rule definition.
*
* At this stage, any remaining optional settings can be specified, or the definition
* can be attached to the parent application gateway definition.
* @param the stage of the application gateway definition to return to after attaching this definition
*/
interface WithAttach extends
Attachable.InDefinition,
WithHostName,
WithCookieBasedAffinity {
}
/**
* The stage of an application gateway request routing rule definition allowing to specify an existing listener to
* associate the routing rule with.
* @param the stage of the application gateway definition to return to after attaching this definition
*/
interface WithListener {
/**
* Associates the request routing rule with a frontend listener.
*
* If the listener with the specified name does not yet exist, it must be defined separately in the optional stages
* of the application gateway definition. This only adds a reference to the listener by its name.
*
* Also, note that a given listener can be used by no more than one request routing rule at a time.
* @param name the name of a listener to reference
* @return the next stage of the definition
*/
WithBackendHttpConfiguration fromListener(String name);
}
/**
* The stage of an application gateway request routing rule definition allowing to associate an existing listener
* with the rule, or create a new one implicitly by specifying the frontend to listen to.
* @param the stage of the application gateway definition to return to after attaching this definition
*/
interface WithListenerOrFrontend extends
WithListener,
WithFrontend {
}
/**
* The stage of an application gateway request routing rule definition allowing to specify the frontend for the rule to apply to.
* @param the stage of the application gateway definition to return to after attaching this definition
*/
interface WithFrontend {
/**
* Enables the rule to apply to the application gateway's public (Internet-facing) frontend.
*
* If the public frontend IP configuration does not yet exist, it will be created under an auto-generated name.
*
* If the application gateway does not have a public IP address specified for its public frontend, one will be created
* automatically, unless a specific public IP address is specified in the application gateway definition's optional settings.
* @return the next stage of the definition
*/
@Method
WithFrontendPort fromPublicFrontend();
/**
* Enables the rule to apply to the application gateway's private (internal) frontend.
*
* If the private frontend IP configuration does not yet exist, it will be created under an auto-generated name.
*
* If the application gateway does not have a subnet specified for its private frontend, one will be created automatically,
* unless a specific subnet is specified in the application gateway definition's optional settings.
* @return the next stage of the definition
*/
@Method
WithFrontendPort fromPrivateFrontend();
}
/**
* The stage of an application gateway request routing rule definition allowing to create an associate listener and frontend
* for a specific port number and protocol.
* @param the stage of the application gateway definition to return to after attaching this definition
*/
interface WithFrontendPort {
/**
* Associates a new listener for the specified port number and the HTTP protocol with this rule.
* @param portNumber the port number to listen to
* @return the next stage of the definition, or null if the specified port number is already used for a different protocol
*/
WithBackendHttpConfiguration fromFrontendHttpPort(int portNumber);
/**
* Associates a new listener for the specified port number and the HTTPS protocol with this rule.
* @param portNumber the port number to listen to
* @return the next stage of the definition, or null if the specified port number is already used for a different protocol
*/
WithSslCertificate fromFrontendHttpsPort(int portNumber);
}
/**
* The stage of an application gateway request routing rule allowing to specify an SSL certificate.
* @param the stage of the application gateway definition to return to after attaching this definition
*/
interface WithSslCertificate extends
HasSslCertificate.DefinitionStages.WithSslCertificate> {
}
/**
* The stage of an application gateway request routing rule allowing to specify an SSL certificate.
* @param the stage of the application gateway definition to return to after attaching this definition
*/
interface WithSslPassword extends HasSslCertificate.DefinitionStages.WithSslPassword {
}
/**
* The stage of an application gateway request routing rule allowing to enable cookie based affinity.
* @param the stage of the application gateway definition to return to after attaching this definition
*/
interface WithCookieBasedAffinity extends HasCookieBasedAffinity.DefinitionStages.WithCookieBasedAffinity> {
}
/**
* The stage of an application gateway request routing rule definition allowing to specify the backend to associate the routing rule with.
* @param the stage of the application gateway definition to return to after attaching this definition
*/
interface WithBackend {
/**
* Associates the request routing rule with a backend on this application gateway.
*
* If the backend does not yet exist, it must be defined in the optional part of the application gateway definition.
* The request routing rule references it only by name.
* @param name the name of an existing backend
* @return the next stage of the definition
*/
WithAttach toBackend(String name);
}
/**
* The stage of an application gateway request routing rule definition allowing to add an address to the backend used by this request routing rule.
*
* A new backend will be created if none is associated with this rule yet.
* @param the stage of the application gateway definition to return to after attaching this definition
*/
interface WithBackendAddress {
/**
* Adds an IP address to the backend associated with this rule.
*
* If no backend has been associated with this rule yet, a new one will be created with an auto-generated name.
*
* This call can be used in a sequence to add multiple IP addresses.
* @param ipAddress an IP address
* @return the next stage of the definition
*/
WithBackendAddressOrAttach toBackendIPAddress(String ipAddress);
/**
* Adds an FQDN (fully qualified domain name) to the backend associated with this rule.
*
* If no backend has been associated with this rule yet, a new one will be created with an auto-generated name.
*
* This call can be used in a sequence to add multiple FQDNs.
* @param fqdn a fully qualified domain name
* @return the next stage of the definition
*/
WithBackendAddressOrAttach toBackendFqdn(String fqdn);
}
/**
* The stage of an application gateway request routing rule definition allowing to add more backend addresses,
* start specifying optional settings, or finish the definition by attaching it to the parent application gateway.
* @param the stage of the application gateway definition to return to after attaching this definition
*/
interface WithBackendAddressOrAttach extends WithBackendAddress, WithAttach {
}
/**
* The stage of an application gateway request routing rule definition allowing to add an address to specify an existing
* backend to associate with this request routing rule or create a new backend with an auto-generated name and addresses to it.
* @param the stage of the application gateway definition to return to after attaching this definition
*/
interface WithBackendOrAddress extends WithBackend, WithBackendAddress {
}
/**
* The stage of an application gateway request routing rule definition allowing to require server name indication if the
* application gateway is serving multiple websites in its backends and SSL is required.
* @param the stage of the application gateway definition to return to after attaching this definition
*/
interface WithBackendHttpConfigurationOrSni extends
WithBackendHttpConfiguration,
HasServerNameIndication.DefinitionStages.WithServerNameIndication> {
}
/**
* The stage of an application gateway request routing rule definition allowing to specify the backend HTTP settings configuration
* to associate the routing rule with.
* @param the stage of the application gateway definition to return to after attaching this definition
*/
interface WithBackendHttpConfiguration {
/**
* Associates the specified backend HTTP settings configuration with this request routing rule.
*
* If the backend configuration does not exist yet, it must be defined in the optional part of the application gateway
* definition. The request routing rule references it only by name.
* @param name the name of a backend HTTP settings configuration
* @return the next stage of the definition
*/
WithBackendOrAddress toBackendHttpConfiguration(String name);
/**
* Creates a backend HTTP settings configuration for the specified backend port and the HTTP protocol, and associates it with this
* request routing rule.
*
* An auto-generated name will be used for this newly created configuration.
* @param portNumber the port number for a new backend HTTP settings configuration
* @return the next stage of the definition
*/
WithBackendOrAddress toBackendHttpPort(int portNumber);
// TODO: toBackendHttpsPort(int portNumber) ?
}
/**
* The stage of an application gateway request routing rule definition allowing to specify the host name of a backend website
* for the listener to receive traffic for.
* @param the stage of the application gateway definition to return to after attaching this definition
*/
interface WithHostName extends HasHostName.DefinitionStages.WithHostName> {
}
/**
* The stage of an application gateway request routing rule definition allowing to require server name indication.
* @param the stage of the application gateway definition to return to after attaching this definition
*/
interface WithServerNameIndication extends HasServerNameIndication.DefinitionStages.WithServerNameIndication> {
}
}
/**
* The entirety of an application gateway request routing rule definition.
* @param the stage of the application gateway definition to return to after attaching this definition
*/
interface Definition extends
DefinitionStages.Blank,
DefinitionStages.WithAttach,
DefinitionStages.WithFrontend,
DefinitionStages.WithListener,
DefinitionStages.WithFrontendPort,
DefinitionStages.WithListenerOrFrontend,
DefinitionStages.WithBackend,
DefinitionStages.WithBackendAddress,
DefinitionStages.WithBackendOrAddress,
DefinitionStages.WithBackendAddressOrAttach,
DefinitionStages.WithBackendHttpConfiguration,
DefinitionStages.WithBackendHttpConfigurationOrSni,
DefinitionStages.WithSslCertificate,
DefinitionStages.WithSslPassword> {
}
/**
* Grouping of application gateway request routing rule update stages.
*/
interface UpdateStages {
/**
* The stage of an application gateway request routing rule update allowing to specify an existing listener to
* associate the routing rule with.
*/
interface WithListener {
/**
* Associates the request routing rule with an existing frontend listener.
*
* Also, note that a given listener can be used by no more than one request routing rule at a time.
* @param name the name of a listener to reference
* @return the next stage of the update
*/
Update fromListener(String name);
}
/**
* The stage of an application gateway request routing rule update allowing to specify the backend to associate the routing rule with.
*/
interface WithBackend {
/**
* Associates the request routing rule with an existing backend on this application gateway.
* @param name the name of an existing backend
* @return the next stage of the update
*/
Update toBackend(String name);
}
/**
* The stage of an application gateway request routing rule update allowing to specify the backend HTTP settings configuration
* to associate the routing rule with.
*/
interface WithBackendHttpConfiguration {
/**
* Associates the specified backend HTTP settings configuration with this request routing rule.
* @param name the name of a backend HTTP settings configuration
* @return the next stage of the update
*/
Update toBackendHttpConfiguration(String name);
}
}
/**
* The entirety of an application gateway request routing rule update as part of an application gateway update.
*/
interface Update extends
Settable,
UpdateStages.WithListener,
UpdateStages.WithBackend,
UpdateStages.WithBackendHttpConfiguration {
}
/**
* Grouping of application gateway request routing rule definition stages applicable as part of an application gateway update.
*/
interface UpdateDefinitionStages {
/**
* The first stage of an application gateway request routing rule definition.
* @param the stage of the application gateway definition to return to after attaching this definition
*/
interface Blank extends WithListenerOrFrontend {
}
/** The final stage of an application gateway request routing rule definition.
*
* At this stage, any remaining optional settings can be specified, or the definition
* can be attached to the parent application gateway definition.
* @param the stage of the application gateway definition to return to after attaching this definition
*/
interface WithAttach extends
Attachable.InUpdate,
WithHostName,
WithCookieBasedAffinity {
}
/**
* The stage of an application gateway request routing rule definition allowing to specify an existing listener to
* associate the routing rule with.
* @param the stage of the application gateway definition to return to after attaching this definition
*/
interface WithListener {
/**
* Associates the request routing rule with a frontend listener.
*
* If the listener with the specified name does not yet exist, it must be defined separately in the optional part
* of the application gateway definition. This only adds a reference to the listener by its name.
*
* Also, note that a given listener can be used by no more than one request routing rule at a time.
* @param name the name of a listener to reference
* @return the next stage of the definition
*/
WithBackendHttpConfiguration fromListener(String name);
}
/**
* The stage of an application gateway request routing rule definition allowing to associate an existing listener
* with the rule, or create a new one implicitly by specifying the frontend to listen to.
* @param the stage of the application gateway definition to return to after attaching this definition
*/
interface WithListenerOrFrontend extends
WithListener,
WithFrontend {
}
/**
* The stage of an application gateway request routing rule definition allowing to specify the frontend for the rule to apply to.
* @param the stage of the application gateway definition to return to after attaching this definition
*/
interface WithFrontend {
/**
* Enables the rule to apply to the application gateway's public (Internet-facing) frontend.
*
* If the public frontend IP configuration does not yet exist, it will be created under an auto-generated name.
*
* If the application gateway does not have a public IP address specified for its public frontend, one will be created
* automatically, unless a specific public IP address is specified in the application gateway definition's optional settings.
* @return the next stage of the definition
*/
@Method
WithFrontendPort fromPublicFrontend();
/**
* Enables the rule to apply to the application gateway's private (internal) frontend.
*
* If the private frontend IP configuration does not yet exist, it will be created under an auto-generated name.
*
* If the application gateway does not have a subnet specified for its private frontend, one will be created automatically,
* unless a specific subnet is specified in the application gateway definition's optional settings.
* @return the next stage of the definition
*/
@Method
WithFrontendPort fromPrivateFrontend();
}
/**
* The stage of an application gateway request routing rule definition allowing to create an associate listener and frontend
* for a specific port number and protocol.
* @param the stage of the application gateway definition to return to after attaching this definition
*/
interface WithFrontendPort {
/**
* Associates a new listener for the specified port number and the HTTP protocol with this rule.
* @param portNumber the port number to listen to
* @return the next stage of the definition, or null if the specified port number is already used for a different protocol
*/
WithBackendHttpConfiguration fromFrontendHttpPort(int portNumber);
/**
* Associates a new listener for the specified port number and the HTTPS protocol with this rule.
* @param portNumber the port number to listen to
* @return the next stage of the definition, or null if the specified port number is already used for a different protocol
*/
WithSslCertificate fromFrontendHttpsPort(int portNumber);
}
/**
* The stage of an application gateway request routing rule allowing to specify an SSL certificate.
* @param the next stage of the definition
*/
interface WithSslCertificate extends
HasSslCertificate.UpdateDefinitionStages.WithSslCertificate> {
}
/**
* The stage of an application gateway request routing rule allowing to specify an SSL certificate.
* @param the next stage of the definition
*/
interface WithSslPassword extends HasSslCertificate.UpdateDefinitionStages.WithSslPassword {
}
/**
* The stage of an application gateway request routing rule allowing to enable cookie based affinity.
* @param the next stage of the definition
*/
interface WithCookieBasedAffinity extends HasCookieBasedAffinity.UpdateDefinitionStages.WithCookieBasedAffinity> {
}
/**
* The stage of an application gateway request routing rule definition allowing to specify the backend to associate the routing rule with.
* @param the stage of the application gateway definition to return to after attaching this definition
*/
interface WithBackend {
/**
* Associates the request routing rule with a backend on this application gateway.
*
* If the backend does not yet exist, it must be defined in the optional part of the application gateway definition.
* The request routing rule references it only by name.
* @param name the name of an existing backend
* @return the next stage of the definition
*/
WithAttach toBackend(String name);
}
/**
* The stage of an application gateway request routing rule definition allowing to add an address to the backend used by this request routing rule.
*
* A new backend will be created if none is associated with this rule yet.
* @param the stage of the application gateway definition to return to after attaching this definition
*/
interface WithBackendAddress {
/**
* Adds an IP address to the backend associated with this rule.
*
* If no backend has been associated with this rule yet, a new one will be created with an auto-generated name.
*
* This call can be used in a sequence to add multiple IP addresses.
* @param ipAddress an IP address
* @return the next stage of the definition
*/
WithBackendAddressOrAttach toBackendIPAddress(String ipAddress);
/**
* Adds an FQDN (fully qualified domain name) to the backend associated with this rule.
*
* If no backend has been associated with this rule yet, a new one will be created with an auto-generated name.
*
* This call can be used in a sequence to add multiple FQDNs.
* @param fqdn a fully qualified domain name
* @return the next stage of the definition
*/
WithBackendAddressOrAttach toBackendFqdn(String fqdn);
}
/**
* The stage of an application gateway request routing rule definition allowing to add more backend addresses,
* start specifying optional settings, or finish the definition by attaching it to the parent application gateway.
* @param the stage of the application gateway definition to return to after attaching this definition
*/
interface WithBackendAddressOrAttach extends WithBackendAddress, WithAttach {
}
/**
* The stage of an application gateway request routing rule definition allowing to add an address to specify an existing
* backend to associate with this request routing rule or create a new backend with an auto-generated name and addresses to it.
* @param the stage of the application gateway definition to return to after attaching this definition
*/
interface WithBackendOrAddress extends WithBackend, WithBackendAddress {
}
/**
* The stage of an application gateway request routing rule definition allowing to require server name indication if the
* application gateway is serving multiple websites in its backends and SSL is required.
* @param the stage of the application gateway definition to return to after attaching this definition
*/
interface WithBackendHttpConfigurationOrSni extends
WithBackendHttpConfiguration,
HasServerNameIndication.UpdateDefinitionStages.WithServerNameIndication> {
}
/**
* The stage of an application gateway request routing rule definition allowing to specify the backend HTTP settings configuration
* to associate the routing rule with.
* @param the stage of the application gateway definition to return to after attaching this definition
*/
interface WithBackendHttpConfiguration {
/**
* Associates the specified backend HTTP settings configuration with this request routing rule.
*
* If the backend configuration does not exist yet, it must be defined in the optional part of the application gateway
* definition. The request routing rule references it only by name.
* @param name the name of a backend HTTP settings configuration
* @return the next stage of the definition
*/
WithBackendOrAddress toBackendHttpConfiguration(String name);
/**
* Creates a backend HTTP settings configuration for the specified backend port and the HTTP protocol, and associates it with this
* request routing rule.
*
* An auto-generated name will be used for this newly created configuration.
* @param portNumber the port number for a new backend HTTP settings configuration
* @return the next stage of the definition
*/
WithBackendOrAddress toBackendHttpPort(int portNumber);
// TODO: toBackendHttpsPort(int portNumber) ?
}
/**
* The stage of an application gateway request routing rule definition allowing to specify the host name of a backend website
* for the listener to receive traffic for.
* @param the stage of the application gateway definition to return to after attaching this definition
*/
interface WithHostName extends HasHostName.UpdateDefinitionStages.WithHostName> {
}
/**
* The stage of an application gateway request routing rule definition allowing to require server name indication.
* @param the stage of the application gateway definition to return to after attaching this definition
*/
interface WithServerNameIndication extends HasServerNameIndication.UpdateDefinitionStages.WithServerNameIndication> {
}
}
/** The entirety of an application gateway request routing rule definition as part of an application gateway update.
* @param the stage of the application gateway definition to return to after attaching this definition
*/
interface UpdateDefinition extends
UpdateDefinitionStages.Blank,
UpdateDefinitionStages.WithAttach,
UpdateDefinitionStages.WithFrontend,
UpdateDefinitionStages.WithListener,
UpdateDefinitionStages.WithFrontendPort,
UpdateDefinitionStages.WithListenerOrFrontend,
UpdateDefinitionStages.WithBackend,
UpdateDefinitionStages.WithBackendAddress,
UpdateDefinitionStages.WithBackendOrAddress,
UpdateDefinitionStages.WithBackendAddressOrAttach,
UpdateDefinitionStages.WithBackendHttpConfiguration,
UpdateDefinitionStages.WithBackendHttpConfigurationOrSni,
UpdateDefinitionStages.WithSslCertificate,
UpdateDefinitionStages.WithSslPassword> {
}
}