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

com.microsoft.azure.management.network.PublicIPAddress Maven / Gradle / Ivy

/**
 * 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 com.microsoft.azure.management.apigeneration.Beta;
import com.microsoft.azure.management.apigeneration.Fluent;
import com.microsoft.azure.management.network.implementation.NetworkManager;
import com.microsoft.azure.management.network.implementation.PublicIPAddressInner;
import com.microsoft.azure.management.network.model.UpdatableWithTags;
import com.microsoft.azure.management.resources.fluentcore.arm.AvailabilityZoneId;
import com.microsoft.azure.management.resources.fluentcore.arm.models.GroupableResource;
import com.microsoft.azure.management.resources.fluentcore.arm.models.Resource;
import com.microsoft.azure.management.resources.fluentcore.model.Creatable;
import com.microsoft.azure.management.resources.fluentcore.model.Refreshable;
import com.microsoft.azure.management.resources.fluentcore.model.Updatable;
import com.microsoft.azure.management.resources.fluentcore.model.Appliable;

import java.util.List;
import java.util.Set;

/**
 * Public IP address.
 */
@Fluent()
public interface PublicIPAddress extends
        GroupableResource,
        Refreshable,
        Updatable,
        UpdatableWithTags {

    // Getters

    /**
     * @return the IP version of the public IP address
     */
    IPVersion version();

    /**
     * @return the assigned IP address
     */
    String ipAddress();

    /**
     * @return the assigned leaf domain label
     */
    String leafDomainLabel();

    /**
     * @return the assigned FQDN (fully qualified domain name)
     */
    String fqdn();

    /**
     * @return the assigned reverse FQDN, if any
     */
    String reverseFqdn();

    /**
     * @return the IP address allocation method (Static/Dynamic)
     */
    IPAllocationMethod ipAllocationMethod();

    /**
     * @return the idle connection timeout setting (in minutes)
     */
    int idleTimeoutInMinutes();

    /**
     * @return the load balancer public frontend that this public IP address is assigned to
     */
    LoadBalancerPublicFrontend getAssignedLoadBalancerFrontend();

    /**
     * @return true if this public IP address is assigned to a load balancer
     */
    boolean hasAssignedLoadBalancer();

    /**
     * @return the network interface IP configuration that this public IP address is assigned to
     */
    NicIPConfiguration getAssignedNetworkInterfaceIPConfiguration();

    /**
     * @return true if this public IP address is assigned to a network interface
     */
    boolean hasAssignedNetworkInterface();

    /**
     * @return the availability zones assigned to the public IP address
     */
    @Beta(Beta.SinceVersion.V1_3_0)
    Set availabilityZones();

    /**
     * @return public IP address sku.
     */
    @Beta(Beta.SinceVersion.V1_3_0)
    PublicIPSkuType sku();

    /**
     * @return read-only list of ipTags assosiated with public ip address
     */
    @Beta(Beta.SinceVersion.V1_10_0)
    List ipTags();

    /**
     * Container interface for all the definitions.
     */
    interface Definition extends
        DefinitionStages.Blank,
        DefinitionStages.WithGroup,
        DefinitionStages.WithCreate {
    }

    /**
     * Grouping of public IP address definition stages.
     */
    interface DefinitionStages {
        /**
         * The first stage of a public IP address definition.
         */
        interface Blank
            extends GroupableResource.DefinitionWithRegion {
        }

        /**
         * The stage of the public IP address definition allowing to specify the resource group.
         */
        interface WithGroup
            extends GroupableResource.DefinitionStages.WithGroup {
        }

        /**
         * A public IP address definition allowing to set the IP allocation method (static or dynamic).
         */
        interface WithIPAddress {
            /**
             * Enables static IP address allocation.
             * 

* Use {@link PublicIPAddress#ipAddress()} after the public IP address is created to obtain the * actual IP address allocated for this resource by Azure * * @return the next stage of the definition */ WithCreate withStaticIP(); /** * Enables dynamic IP address allocation. * * @return the next stage of the definition */ WithCreate withDynamicIP(); } /** * A public IP address definition allowing to specify the leaf domain label, if any. */ interface WithLeafDomainLabel { /** * Specifies the leaf domain label to associate with this public IP address. *

* The fully qualified domain name (FQDN) * will be constructed automatically by appending the rest of the domain to this label. * @param dnsName the leaf domain label to use. This must follow the required naming convention for leaf domain names. * @return the next stage of the definition */ WithCreate withLeafDomainLabel(String dnsName); /** * Ensures that no leaf domain label will be used. *

* This means that this public IP address will not be associated with a domain name. * @return the next stage of the definition */ WithCreate withoutLeafDomainLabel(); } /** * A public IP address definition allowing the reverse FQDN to be specified. */ interface WithReverseFQDN { /** * Specifies the reverse FQDN to assign to this public IP address. *

* * @param reverseFQDN the reverse FQDN to assign * @return the next stage of the definition */ WithCreate withReverseFqdn(String reverseFQDN); /** * Ensures that no reverse FQDN will be used. * @return the next stage of the definition */ WithCreate withoutReverseFqdn(); } /** * A public IP address definition allowing the idle timeout to be specified. */ interface WithIdleTimeout { /** * Specifies the timeout (in minutes) for an idle connection. * * @param minutes the length of the time out in minutes * @return the next stage of the definition */ WithCreate withIdleTimeoutInMinutes(int minutes); } /** * The stage of the IP address definition allowing to specify availability zone. */ @Beta(Beta.SinceVersion.V1_3_0) interface WithAvailabilityZone { /** * Specifies the availability zone for the IP address. * * @param zoneId the zone identifier. * @return the next stage of the definition */ @Beta(Beta.SinceVersion.V1_3_0) WithCreate withAvailabilityZone(AvailabilityZoneId zoneId); } /** * The stage of the IP address definition allowing to specify SKU. */ @Beta(Beta.SinceVersion.V1_3_0) interface WithSku { /** * Specifies the SKU for the IP address. * * @param skuType the SKU type * @return the next stage of the definition */ WithCreate withSku(PublicIPSkuType skuType); } /** * The stage of the definition allowing to specify ipTags associated with the public IP address. */ @Beta(Beta.SinceVersion.V1_10_0) interface WithIpTag { /** * Sets an ipTag associated with the public IP address. * @param tag ip tag value * @return the next stage of the definition */ WithCreate withIpTag(String tag); /** * Sets an ipTag associated with the public IP address. * @param tag ip tag value * @param ipTagType ipTagType * @return the next stage of the definition */ WithCreate withIpTag(String tag, String ipTagType); } /** * The stage of the public IP definition which contains all the minimum required inputs for * the resource to be created (via {@link WithCreate#create()}), but also allows * for any other optional settings to be specified. */ interface WithCreate extends Creatable, DefinitionStages.WithLeafDomainLabel, DefinitionStages.WithIPAddress, DefinitionStages.WithReverseFQDN, DefinitionStages.WithIdleTimeout, DefinitionStages.WithAvailabilityZone, DefinitionStages.WithSku, DefinitionStages.WithIpTag, Resource.DefinitionWithTags { } } /** * Container interface for all the updates. *

* Use {@link Update#apply()} to apply the changes to the resource in Azure. */ interface Update extends Appliable, UpdateStages.WithIPAddress, UpdateStages.WithLeafDomainLabel, UpdateStages.WithReverseFQDN, UpdateStages.WithIdleTimout, UpdateStages.WithIpTag, Resource.UpdateWithTags { } /** * Grouping of public IP address update stages. */ interface UpdateStages { /** * A public IP address update allowing to change the IP allocation method (static or dynamic). */ interface WithIPAddress { /** * Enables static IP address allocation. *

* Use {@link PublicIPAddress#ipAddress()} after the public IP address is updated to * obtain the actual IP address allocated for this resource by Azure * * @return the next stage of the resource update */ Update withStaticIP(); /** * Enables dynamic IP address allocation. * * @return the next stage of the resource update */ Update withDynamicIP(); } /** * A public IP address update allowing to change the leaf domain label, if any. */ interface WithLeafDomainLabel { /** * Specifies the leaf domain label to associate with this public IP address. *

* The fully qualified domain name (FQDN) * will be constructed automatically by appending the rest of the domain to this label. * @param dnsName the leaf domain label to use. This must follow the required naming convention for leaf domain names. * @return the next stage of the resource update */ Update withLeafDomainLabel(String dnsName); /** * Ensures that no leaf domain label will be used. *

* This means that this public IP address will not be associated with a domain name. * @return the next stage of the resource update */ Update withoutLeafDomainLabel(); } /** * A public IP address update allowing the reverse FQDN to be changed. */ interface WithReverseFQDN { /** * Specifies the reverse FQDN to assign to this public IP address. * * @param reverseFQDN the reverse FQDN to assign * @return the next stage of the resource update */ Update withReverseFqdn(String reverseFQDN); /** * Ensures that no reverse FQDN will be used. * * @return The next stage of the resource update */ Update withoutReverseFqdn(); } /** * A public IP address update allowing the idle timeout to be changed. */ interface WithIdleTimout { /** * Specifies the timeout (in minutes) for an idle connection. * * @param minutes the length of the time out in minutes * @return the next stage of the resource update */ Update withIdleTimeoutInMinutes(int minutes); } /** * The stage of the update allowing to specify ipTags associated with the public IP address. */ @Beta(Beta.SinceVersion.V1_10_0) interface WithIpTag { /** * Sets an ipTag associated with the public IP address. * @param tag ip tag value * @return the next stage of the update */ Update withIpTag(String tag); /** * Sets an ipTag associated with the public IP address. * @param tag ip tag value * @param ipTagType ipTagType * @return the next stage of the update */ Update withIpTag(String tag, String ipTagType); /** * Removes an ipTag associated with the public IP address. * @param tag ip tag value * @return the next stage of the update */ Update withoutIpTag(String tag); } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy