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

com.azure.resourcemanager.network.models.NetworkSecurityGroup Maven / Gradle / Ivy

// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License.
package com.azure.resourcemanager.network.models;

import com.azure.core.annotation.Fluent;
import com.azure.resourcemanager.network.NetworkManager;
import com.azure.resourcemanager.network.fluent.models.NetworkSecurityGroupInner;
import com.azure.resourcemanager.resources.fluentcore.arm.models.GroupableResource;
import com.azure.resourcemanager.resources.fluentcore.arm.models.Resource;
import com.azure.resourcemanager.resources.fluentcore.model.Appliable;
import com.azure.resourcemanager.resources.fluentcore.model.Attachable;
import com.azure.resourcemanager.resources.fluentcore.model.Creatable;
import com.azure.resourcemanager.resources.fluentcore.model.Refreshable;
import com.azure.resourcemanager.resources.fluentcore.model.Updatable;
import java.util.Map;
import java.util.Set;

/** 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 { } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy