com.microsoft.azure.management.network.NetworkSecurityGroup 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 java.util.Map;
import java.util.Set;
import com.microsoft.azure.management.apigeneration.Fluent;
import com.microsoft.azure.management.network.implementation.NetworkManager;
import com.microsoft.azure.management.network.implementation.NetworkSecurityGroupInner;
import com.microsoft.azure.management.network.model.HasAssociatedSubnets;
import com.microsoft.azure.management.network.model.UpdatableWithTags;
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.Appliable;
import com.microsoft.azure.management.resources.fluentcore.model.Attachable;
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;
/**
* Network security group.
*/
@Fluent()
public interface NetworkSecurityGroup extends
GroupableResource,
Refreshable,
Updatable,
UpdatableWithTags,
HasAssociatedSubnets {
// Getters
/**
* @return security rules associated with this network security group, indexed by their names
*/
Map securityRules();
/**
* @return default security rules associated with this network security group, indexed by their name
*/
Map defaultSecurityRules();
/**
* @return the IDs of the network interfaces associated with this network security group
*/
Set networkInterfaceIds();
// Fluent interfaces for creating NSGs
/**
* The entirety of the network security group definition.
*/
interface Definition extends
DefinitionStages.Blank,
DefinitionStages.WithGroup,
DefinitionStages.WithCreate {
}
/**
* Grouping of network security group definition stages.
*/
interface DefinitionStages {
/**
* The first stage of the definition.
*/
interface Blank
extends GroupableResource.DefinitionWithRegion {
}
/**
* The stage allowing to specify the resource group.
*/
interface WithGroup
extends GroupableResource.DefinitionStages.WithGroup {
}
/**
* The stage allowing to define a new security rule.
*
* When the security rule description is complete enough, use {@link Attachable#attach()} to attach it to
* this network security group.
*/
interface WithRule {
/**
* Starts the definition of a new security rule.
* @param name the name for the new security rule
* @return the first stage of the security rule definition
*/
NetworkSecurityRule.DefinitionStages.Blank defineRule(String name);
}
/**
* The stage of the 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,
Resource.DefinitionWithTags,
DefinitionStages.WithRule {
}
}
/**
* Grouping of network security group update stages.
*/
interface UpdateStages {
/**
* The stage of the resource definition allowing to add or remove security rules.
*/
interface WithRule {
/**
* Removes an existing security rule.
* @param name the name of the security rule to remove
* @return the next stage of the network security group description
*/
Update withoutRule(String name);
/**
* Begins the definition of a new security rule to be added to this network security group.
* @param name the name of the new security rule
* @return the first stage of the new security rule definition
*/
NetworkSecurityRule.UpdateDefinitionStages.Blank defineRule(String name);
/**
* Begins the description of an update of an existing security rule of this network security group.
* @param name the name of an existing security rule
* @return the first stage of the security rule update description
*/
NetworkSecurityRule.Update updateRule(String name);
}
}
/**
* The template for an update operation, containing all the settings that
* can be modified.
*
* Call {@link Update#apply()} to apply the changes to the resource in Azure.
*/
interface Update extends
Appliable,
Resource.UpdateWithTags,
UpdateStages.WithRule {
}
}