com.azure.resourcemanager.dnsresolver.models.DnsResolverPolicy 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.SystemData;
import com.azure.core.util.Context;
import com.azure.resourcemanager.dnsresolver.fluent.models.DnsResolverPolicyInner;
import java.util.Map;
/**
* An immutable client-side representation of DnsResolverPolicy.
*/
public interface DnsResolverPolicy {
/**
* 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 policy.
*
* @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 provisioningState property: The current provisioning state of the DNS resolver policy. 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 policy 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.DnsResolverPolicyInner object.
*
* @return the inner object.
*/
DnsResolverPolicyInner innerModel();
/**
* The entirety of the DnsResolverPolicy definition.
*/
interface Definition extends DefinitionStages.Blank, DefinitionStages.WithLocation,
DefinitionStages.WithResourceGroup, DefinitionStages.WithCreate {
}
/**
* The DnsResolverPolicy definition stages.
*/
interface DefinitionStages {
/**
* The first stage of the DnsResolverPolicy definition.
*/
interface Blank extends WithLocation {
}
/**
* The stage of the DnsResolverPolicy 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 DnsResolverPolicy 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.
*/
WithCreate withExistingResourceGroup(String resourceGroupName);
}
/**
* The stage of the DnsResolverPolicy 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.
*/
DnsResolverPolicy create();
/**
* Executes the create request.
*
* @param context The context to associate with this operation.
* @return the created resource.
*/
DnsResolverPolicy create(Context context);
}
/**
* The stage of the DnsResolverPolicy 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 DnsResolverPolicy 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 DnsResolverPolicy 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 DnsResolverPolicy resource.
*
* @return the stage of resource update.
*/
DnsResolverPolicy.Update update();
/**
* The template for DnsResolverPolicy update.
*/
interface Update extends UpdateStages.WithTags, UpdateStages.WithIfMatch {
/**
* Executes the update request.
*
* @return the updated resource.
*/
DnsResolverPolicy apply();
/**
* Executes the update request.
*
* @param context The context to associate with this operation.
* @return the updated resource.
*/
DnsResolverPolicy apply(Context context);
}
/**
* The DnsResolverPolicy update stages.
*/
interface UpdateStages {
/**
* The stage of the DnsResolverPolicy update allowing to specify tags.
*/
interface WithTags {
/**
* Specifies the tags property: Tags for DNS resolver policy..
*
* @param tags Tags for DNS resolver policy.
* @return the next definition stage.
*/
Update withTags(Map tags);
}
/**
* The stage of the DnsResolverPolicy 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.
*/
DnsResolverPolicy refresh();
/**
* Refreshes the resource to sync with Azure.
*
* @param context The context to associate with this operation.
* @return the refreshed resource.
*/
DnsResolverPolicy refresh(Context context);
}