com.azure.resourcemanager.dnsresolver.models.DnsResolver Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of azure-resourcemanager-dnsresolver Show documentation
Show all versions of azure-resourcemanager-dnsresolver Show documentation
This package contains Microsoft Azure SDK for DnsResolver Management SDK. For documentation on how to use this package, please see https://aka.ms/azsdk/java/mgmt. The DNS Resolver Management Client. Package tag package-2022-07.
// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License.
// Code generated by Microsoft (R) AutoRest Code Generator.
package com.azure.resourcemanager.dnsresolver.models;
import com.azure.core.management.Region;
import com.azure.core.management.SubResource;
import com.azure.core.management.SystemData;
import com.azure.core.util.Context;
import com.azure.resourcemanager.dnsresolver.fluent.models.DnsResolverInner;
import java.util.Map;
/**
* An immutable client-side representation of DnsResolver.
*/
public interface DnsResolver {
/**
* Gets the id property: Fully qualified resource Id for the resource.
*
* @return the id value.
*/
String id();
/**
* Gets the name property: The name of the resource.
*
* @return the name value.
*/
String name();
/**
* Gets the type property: The type of the resource.
*
* @return the type value.
*/
String type();
/**
* Gets the location property: The geo-location where the resource lives.
*
* @return the location value.
*/
String location();
/**
* Gets the tags property: Resource tags.
*
* @return the tags value.
*/
Map tags();
/**
* Gets the etag property: ETag of the DNS resolver.
*
* @return the etag value.
*/
String etag();
/**
* Gets the systemData property: Azure Resource Manager metadata containing createdBy and modifiedBy information.
*
* @return the systemData value.
*/
SystemData systemData();
/**
* Gets the virtualNetwork property: The reference to the virtual network. This cannot be changed after creation.
*
* @return the virtualNetwork value.
*/
SubResource virtualNetwork();
/**
* Gets the dnsResolverState property: The current status of the DNS resolver. This is a read-only property and any
* attempt to set this value will be ignored.
*
* @return the dnsResolverState value.
*/
DnsResolverState dnsResolverState();
/**
* Gets the provisioningState property: The current provisioning state of the DNS resolver. This is a read-only
* property and any attempt to set this value will be ignored.
*
* @return the provisioningState value.
*/
ProvisioningState provisioningState();
/**
* Gets the resourceGuid property: The resourceGuid property of the DNS resolver resource.
*
* @return the resourceGuid value.
*/
String resourceGuid();
/**
* Gets the region of the resource.
*
* @return the region of the resource.
*/
Region region();
/**
* Gets the name of the resource region.
*
* @return the name of the resource region.
*/
String regionName();
/**
* Gets the name of the resource group.
*
* @return the name of the resource group.
*/
String resourceGroupName();
/**
* Gets the inner com.azure.resourcemanager.dnsresolver.fluent.models.DnsResolverInner object.
*
* @return the inner object.
*/
DnsResolverInner innerModel();
/**
* The entirety of the DnsResolver definition.
*/
interface Definition extends DefinitionStages.Blank, DefinitionStages.WithLocation,
DefinitionStages.WithResourceGroup, DefinitionStages.WithVirtualNetwork, DefinitionStages.WithCreate {
}
/**
* The DnsResolver definition stages.
*/
interface DefinitionStages {
/**
* The first stage of the DnsResolver definition.
*/
interface Blank extends WithLocation {
}
/**
* The stage of the DnsResolver definition allowing to specify location.
*/
interface WithLocation {
/**
* Specifies the region for the resource.
*
* @param location The geo-location where the resource lives.
* @return the next definition stage.
*/
WithResourceGroup withRegion(Region location);
/**
* Specifies the region for the resource.
*
* @param location The geo-location where the resource lives.
* @return the next definition stage.
*/
WithResourceGroup withRegion(String location);
}
/**
* The stage of the DnsResolver definition allowing to specify parent resource.
*/
interface WithResourceGroup {
/**
* Specifies resourceGroupName.
*
* @param resourceGroupName The name of the resource group. The name is case insensitive.
* @return the next definition stage.
*/
WithVirtualNetwork withExistingResourceGroup(String resourceGroupName);
}
/**
* The stage of the DnsResolver definition allowing to specify virtualNetwork.
*/
interface WithVirtualNetwork {
/**
* Specifies the virtualNetwork property: The reference to the virtual network. This cannot be changed after
* creation..
*
* @param virtualNetwork The reference to the virtual network. This cannot be changed after creation.
* @return the next definition stage.
*/
WithCreate withVirtualNetwork(SubResource virtualNetwork);
}
/**
* The stage of the DnsResolver definition which contains all the minimum required properties for the resource
* to be created, but also allows for any other optional properties to be specified.
*/
interface WithCreate
extends DefinitionStages.WithTags, DefinitionStages.WithIfMatch, DefinitionStages.WithIfNoneMatch {
/**
* Executes the create request.
*
* @return the created resource.
*/
DnsResolver create();
/**
* Executes the create request.
*
* @param context The context to associate with this operation.
* @return the created resource.
*/
DnsResolver create(Context context);
}
/**
* The stage of the DnsResolver definition allowing to specify tags.
*/
interface WithTags {
/**
* Specifies the tags property: Resource tags..
*
* @param tags Resource tags.
* @return the next definition stage.
*/
WithCreate withTags(Map tags);
}
/**
* The stage of the DnsResolver definition allowing to specify ifMatch.
*/
interface WithIfMatch {
/**
* Specifies the ifMatch property: ETag of the resource. Omit this value to always overwrite the current
* resource. Specify the last-seen ETag value to prevent accidentally overwriting any concurrent changes..
*
* @param ifMatch ETag of the resource. Omit this value to always overwrite the current resource. Specify
* the last-seen ETag value to prevent accidentally overwriting any concurrent changes.
* @return the next definition stage.
*/
WithCreate withIfMatch(String ifMatch);
}
/**
* The stage of the DnsResolver definition allowing to specify ifNoneMatch.
*/
interface WithIfNoneMatch {
/**
* Specifies the ifNoneMatch property: Set to '*' to allow a new resource to be created, but to prevent
* updating an existing resource. Other values will be ignored..
*
* @param ifNoneMatch Set to '*' to allow a new resource to be created, but to prevent updating an existing
* resource. Other values will be ignored.
* @return the next definition stage.
*/
WithCreate withIfNoneMatch(String ifNoneMatch);
}
}
/**
* Begins update for the DnsResolver resource.
*
* @return the stage of resource update.
*/
DnsResolver.Update update();
/**
* The template for DnsResolver update.
*/
interface Update extends UpdateStages.WithTags, UpdateStages.WithIfMatch {
/**
* Executes the update request.
*
* @return the updated resource.
*/
DnsResolver apply();
/**
* Executes the update request.
*
* @param context The context to associate with this operation.
* @return the updated resource.
*/
DnsResolver apply(Context context);
}
/**
* The DnsResolver update stages.
*/
interface UpdateStages {
/**
* The stage of the DnsResolver update allowing to specify tags.
*/
interface WithTags {
/**
* Specifies the tags property: Tags for DNS Resolver..
*
* @param tags Tags for DNS Resolver.
* @return the next definition stage.
*/
Update withTags(Map tags);
}
/**
* The stage of the DnsResolver update allowing to specify ifMatch.
*/
interface WithIfMatch {
/**
* Specifies the ifMatch property: ETag of the resource. Omit this value to always overwrite the current
* resource. Specify the last-seen ETag value to prevent accidentally overwriting any concurrent changes..
*
* @param ifMatch ETag of the resource. Omit this value to always overwrite the current resource. Specify
* the last-seen ETag value to prevent accidentally overwriting any concurrent changes.
* @return the next definition stage.
*/
Update withIfMatch(String ifMatch);
}
}
/**
* Refreshes the resource to sync with Azure.
*
* @return the refreshed resource.
*/
DnsResolver refresh();
/**
* Refreshes the resource to sync with Azure.
*
* @param context The context to associate with this operation.
* @return the refreshed resource.
*/
DnsResolver refresh(Context context);
}