com.microsoft.azure.management.network.implementation.LoadBalancerFrontendImpl 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.implementation;
import java.util.ArrayList;
import java.util.Collections;
import java.util.HashSet;
import java.util.Map;
import java.util.Set;
import java.util.TreeMap;
import com.microsoft.azure.SubResource;
import com.microsoft.azure.management.apigeneration.LangDefinition;
import com.microsoft.azure.management.network.LoadBalancerFrontend;
import com.microsoft.azure.management.network.IPAllocationMethod;
import com.microsoft.azure.management.network.LoadBalancerInboundNatPool;
import com.microsoft.azure.management.network.LoadBalancerInboundNatRule;
import com.microsoft.azure.management.network.LoadBalancerPrivateFrontend;
import com.microsoft.azure.management.network.LoadBalancerPublicFrontend;
import com.microsoft.azure.management.network.LoadBalancer;
import com.microsoft.azure.management.network.LoadBalancingRule;
import com.microsoft.azure.management.network.Network;
import com.microsoft.azure.management.network.PublicIPAddress;
import com.microsoft.azure.management.network.Subnet;
import com.microsoft.azure.management.resources.fluentcore.arm.AvailabilityZoneId;
import com.microsoft.azure.management.resources.fluentcore.arm.ResourceUtils;
import com.microsoft.azure.management.resources.fluentcore.arm.models.implementation.ChildResourceImpl;
import com.microsoft.azure.management.resources.fluentcore.model.Creatable;
import com.microsoft.azure.management.resources.fluentcore.utils.SdkContext;
/**
* Implementation for LoadBalancerPublicFrontend.
*/
@LangDefinition
class LoadBalancerFrontendImpl
extends ChildResourceImpl
implements
LoadBalancerFrontend,
LoadBalancerPrivateFrontend,
LoadBalancerPrivateFrontend.Definition,
LoadBalancerPrivateFrontend.UpdateDefinition,
LoadBalancerPrivateFrontend.Update,
LoadBalancerPublicFrontend,
LoadBalancerPublicFrontend.Definition,
LoadBalancerPublicFrontend.UpdateDefinition,
LoadBalancerPublicFrontend.Update {
LoadBalancerFrontendImpl(FrontendIPConfigurationInner inner, LoadBalancerImpl parent) {
super(inner, parent);
}
// Getters
@Override
public String networkId() {
SubResource subnetRef = this.inner().subnet();
if (subnetRef != null) {
return ResourceUtils.parentResourceIdFromResourceId(subnetRef.id());
} else {
return null;
}
}
@Override
public String subnetName() {
SubResource subnetRef = this.inner().subnet();
if (subnetRef != null) {
return ResourceUtils.nameFromResourceId(subnetRef.id());
} else {
return null;
}
}
@Override
public String privateIPAddress() {
return this.inner().privateIPAddress();
}
@Override
public IPAllocationMethod privateIPAllocationMethod() {
return this.inner().privateIPAllocationMethod();
}
@Override
public String name() {
return this.inner().name();
}
@Override
public String publicIPAddressId() {
return this.inner().publicIPAddress().id();
}
@Override
public boolean isPublic() {
return (this.inner().publicIPAddress() != null);
}
@Override
public Map loadBalancingRules() {
final Map rules = new TreeMap<>();
if (this.inner().loadBalancingRules() != null) {
for (SubResource innerRef : this.inner().loadBalancingRules()) {
String name = ResourceUtils.nameFromResourceId(innerRef.id());
LoadBalancingRule rule = this.parent().loadBalancingRules().get(name);
if (rule != null) {
rules.put(name, rule);
}
}
}
return Collections.unmodifiableMap(rules);
}
@Override
public Map inboundNatPools() {
final Map pools = new TreeMap<>();
if (this.inner().inboundNatPools() != null) {
for (SubResource innerRef : this.inner().inboundNatPools()) {
String name = ResourceUtils.nameFromResourceId(innerRef.id());
LoadBalancerInboundNatPool pool = this.parent().inboundNatPools().get(name);
if (pool != null) {
pools.put(name, pool);
}
}
}
return Collections.unmodifiableMap(pools);
}
@Override
public Map inboundNatRules() {
final Map rules = new TreeMap<>();
if (this.inner().inboundNatRules() != null) {
for (SubResource innerRef : this.inner().inboundNatRules()) {
String name = ResourceUtils.nameFromResourceId(innerRef.id());
LoadBalancerInboundNatRule rule = this.parent().inboundNatRules().get(name);
if (rule != null) {
rules.put(name, rule);
}
}
}
return Collections.unmodifiableMap(rules);
}
// Fluent setters
@Override
public LoadBalancerFrontendImpl withExistingSubnet(Network network, String subnetName) {
return this.withExistingSubnet(network.id(), subnetName);
}
@Override
public LoadBalancerFrontendImpl withExistingSubnet(String parentNetworkResourceId, String subnetName) {
SubnetInner subnetRef = (SubnetInner) new SubnetInner()
.withId(parentNetworkResourceId + "/subnets/" + subnetName);
this.inner()
.withSubnet(subnetRef)
.withPublicIPAddress(null); // Ensure no conflicting public and private settings
return this;
}
@Override
public LoadBalancerFrontendImpl withAvailabilityZone(AvailabilityZoneId zoneId) {
// Note: Zone is not updatable as of now, so this is available only during definition time.
// Service return `ResourceAvailabilityZonesCannotBeModified` upon attempt to append a new
// zone or remove one. Trying to remove the last one means attempt to change resource from
// zonal to regional, which is not supported.
//
// Zone is supported only for internal load balancer, hence exposed only for PrivateFrontEnd
//
if (this.inner().zones() == null) {
this.inner().withZones(new ArrayList());
}
this.inner().zones().add(zoneId.toString());
return this;
}
@Override
public LoadBalancerFrontendImpl withExistingPublicIPAddress(PublicIPAddress pip) {
return this.withExistingPublicIPAddress(pip.id());
}
@Override
public LoadBalancerFrontendImpl withExistingPublicIPAddress(String resourceId) {
PublicIPAddressInner pipRef = new PublicIPAddressInner().withId(resourceId);
this.inner()
.withPublicIPAddress(pipRef)
// Ensure no conflicting public and private settings
.withSubnet(null)
.withPrivateIPAddress(null)
.withPrivateIPAllocationMethod(null);
return this;
}
@Override
public LoadBalancerFrontendImpl withoutPublicIPAddress() {
this.inner().withPublicIPAddress(null);
return this;
}
@Override
public LoadBalancerFrontendImpl withPrivateIPAddressDynamic() {
this.inner()
.withPrivateIPAddress(null)
.withPrivateIPAllocationMethod(IPAllocationMethod.DYNAMIC)
// Ensure no conflicting public and private settings
.withPublicIPAddress(null);
return this;
}
@Override
public LoadBalancerFrontendImpl withPrivateIPAddressStatic(String ipAddress) {
this.inner()
.withPrivateIPAddress(ipAddress)
.withPrivateIPAllocationMethod(IPAllocationMethod.STATIC)
// Ensure no conflicting public and private settings
.withPublicIPAddress(null);
return this;
}
@Override
public LoadBalancerFrontendImpl withNewPublicIPAddress(String leafDnsLabel) {
this.parent().withNewPublicIPAddress(leafDnsLabel, this.name());
return this;
}
@Override
public LoadBalancerFrontendImpl withNewPublicIPAddress(Creatable creatable) {
this.parent().withNewPublicIPAddress(creatable, this.name());
return this;
}
@Override
public LoadBalancerFrontendImpl withNewPublicIPAddress() {
String dnsLabel = SdkContext.randomResourceName("fe", 20);
return this.withNewPublicIPAddress(dnsLabel);
}
// Verbs
@Override
public LoadBalancerImpl attach() {
return this.parent().withFrontend(this);
}
@Override
public PublicIPAddress getPublicIPAddress() {
final String pipId = this.publicIPAddressId();
if (pipId == null) {
return null;
} else {
return this.parent().manager().publicIPAddresses().getById(pipId);
}
}
@Override
public Subnet getSubnet() {
return this.parent().manager().getAssociatedSubnet(this.inner().subnet());
}
@Override
public Set availabilityZones() {
Set zones = new HashSet<>();
if (this.inner().zones() != null) {
for (String zone : this.inner().zones()) {
zones.add(AvailabilityZoneId.fromString(zone));
}
}
return Collections.unmodifiableSet(zones);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy