From 35b521c31507db4cdffd2df689776e8b0ce89e7d Mon Sep 17 00:00:00 2001 From: Dante Date: Thu, 4 Jul 2024 06:25:43 -0400 Subject: [PATCH] Deployment stacks sdk introduction (#44405) --- .../Azure.ResourceManager.Resources.sln | 14 - .../CHANGELOG.md | 12 +- ...esourceManager.Resources.netstandard2.0.cs | 406 ++++++ .../assets.json | 2 +- .../Samples/Sample_ArmDeploymentCollection.cs | 2 +- .../Samples/Sample_ArmDeploymentResource.cs | 12 +- .../Azure.ResourceManager.Resources.csproj | 2 +- .../src/Custom/DeploymentStackData.cs | 17 + .../src/Generated/ArmDeploymentCollection.cs | 20 +- .../src/Generated/ArmDeploymentResource.cs | 64 +- .../src/Generated/ArmResourcesModelFactory.cs | 123 ++ .../Generated/DeploymentStackCollection.cs | 484 ++++++++ .../DeploymentStackData.Serialization.cs | 1100 +++++++++++++++++ .../src/Generated/DeploymentStackData.cs | 257 ++++ .../DeploymentStackResource.Serialization.cs | 26 + .../src/Generated/DeploymentStackResource.cs | 860 +++++++++++++ .../Extensions/MockableResourcesArmClient.cs | 12 + ...ockableResourcesManagementGroupResource.cs | 73 +- .../MockableResourcesResourceGroupResource.cs | 73 +- .../MockableResourcesSubscriptionResource.cs | 73 +- .../MockableResourcesTenantResource.cs | 8 +- .../Extensions/ResourcesExtensions.cs | 318 ++++- .../DeploymentStackOperationSource.cs | 38 + ...ymentStackValidateResultOperationSource.cs | 30 + .../Models/ActionOnUnmanage.Serialization.cs | 209 ++++ .../src/Generated/Models/ActionOnUnmanage.cs | 83 ++ .../Models/DenySettings.Serialization.cs | 303 +++++ .../src/Generated/Models/DenySettings.cs | 90 ++ .../src/Generated/Models/DenySettingsMode.cs | 54 + .../src/Generated/Models/DenyStatusMode.cs | 63 + .../DeploymentParameter.Serialization.cs | 230 ++++ .../Generated/Models/DeploymentParameter.cs | 105 ++ ...DeploymentStackListResult.Serialization.cs | 212 ++++ .../Models/DeploymentStackListResult.cs | 70 ++ .../DeploymentStackProvisioningState.cs | 78 ++ ...ntStackTemplateDefinition.Serialization.cs | 196 +++ .../DeploymentStackTemplateDefinition.cs | 100 ++ ...ntStackValidateProperties.Serialization.cs | 429 +++++++ .../DeploymentStackValidateProperties.cs | 103 ++ ...oymentStackValidateResult.Serialization.cs | 298 +++++ .../Models/DeploymentStackValidateResult.cs | 77 ++ ...loymentStacksDebugSetting.Serialization.cs | 163 +++ .../Models/DeploymentStacksDebugSetting.cs | 66 + .../DeploymentStacksDeleteDetachEnum.cs | 51 + ...ymentStacksParametersLink.Serialization.cs | 186 +++ .../Models/DeploymentStacksParametersLink.cs | 81 ++ ...loymentStacksTemplateLink.Serialization.cs | 301 +++++ .../Models/DeploymentStacksTemplateLink.cs | 86 ++ ...eyVaultParameterReference.Serialization.cs | 220 ++++ .../Models/KeyVaultParameterReference.cs | 102 ++ .../ManagedResourceReference.Serialization.cs | 223 ++++ .../Models/ManagedResourceReference.cs | 39 + ...rceReferenceAutoGenerated.Serialization.cs | 163 +++ .../Models/ResourceReferenceAutoGenerated.cs | 66 + ...ResourceReferenceExtended.Serialization.cs | 193 +++ .../Models/ResourceReferenceExtended.cs | 34 + .../Generated/Models/ResourceStatusMode.cs | 54 + .../UnmanageActionManagementGroupMode.cs | 51 + .../Models/UnmanageActionResourceGroupMode.cs | 51 + .../Models/UnmanageActionResourceMode.cs | 51 + .../DeploymentRestOperations.cs | 2 +- .../DeploymentStacksRestOperations.cs | 653 ++++++++++ .../DeploymentsRestOperations.cs | 2 +- .../src/autorest.md | 328 ++++- .../tests/ResourcesTestBase.cs | 82 +- .../DeploymentStackCollectionTests.cs | 220 ++++ .../DeploymentStackOperationsTests.cs | 187 +++ .../mg-stack-template.json | 16 + .../rg-stack-template.json | 24 + .../sub-stack-template.json | 22 + 70 files changed, 10342 insertions(+), 101 deletions(-) create mode 100644 sdk/resources/Azure.ResourceManager.Resources/src/Custom/DeploymentStackData.cs create mode 100644 sdk/resources/Azure.ResourceManager.Resources/src/Generated/DeploymentStackCollection.cs create mode 100644 sdk/resources/Azure.ResourceManager.Resources/src/Generated/DeploymentStackData.Serialization.cs create mode 100644 sdk/resources/Azure.ResourceManager.Resources/src/Generated/DeploymentStackData.cs create mode 100644 sdk/resources/Azure.ResourceManager.Resources/src/Generated/DeploymentStackResource.Serialization.cs create mode 100644 sdk/resources/Azure.ResourceManager.Resources/src/Generated/DeploymentStackResource.cs create mode 100644 sdk/resources/Azure.ResourceManager.Resources/src/Generated/LongRunningOperation/DeploymentStackOperationSource.cs create mode 100644 sdk/resources/Azure.ResourceManager.Resources/src/Generated/LongRunningOperation/DeploymentStackValidateResultOperationSource.cs create mode 100644 sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/ActionOnUnmanage.Serialization.cs create mode 100644 sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/ActionOnUnmanage.cs create mode 100644 sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DenySettings.Serialization.cs create mode 100644 sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DenySettings.cs create mode 100644 sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DenySettingsMode.cs create mode 100644 sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DenyStatusMode.cs create mode 100644 sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentParameter.Serialization.cs create mode 100644 sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentParameter.cs create mode 100644 sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStackListResult.Serialization.cs create mode 100644 sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStackListResult.cs create mode 100644 sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStackProvisioningState.cs create mode 100644 sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStackTemplateDefinition.Serialization.cs create mode 100644 sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStackTemplateDefinition.cs create mode 100644 sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStackValidateProperties.Serialization.cs create mode 100644 sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStackValidateProperties.cs create mode 100644 sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStackValidateResult.Serialization.cs create mode 100644 sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStackValidateResult.cs create mode 100644 sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStacksDebugSetting.Serialization.cs create mode 100644 sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStacksDebugSetting.cs create mode 100644 sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStacksDeleteDetachEnum.cs create mode 100644 sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStacksParametersLink.Serialization.cs create mode 100644 sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStacksParametersLink.cs create mode 100644 sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStacksTemplateLink.Serialization.cs create mode 100644 sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStacksTemplateLink.cs create mode 100644 sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/KeyVaultParameterReference.Serialization.cs create mode 100644 sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/KeyVaultParameterReference.cs create mode 100644 sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/ManagedResourceReference.Serialization.cs create mode 100644 sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/ManagedResourceReference.cs create mode 100644 sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/ResourceReferenceAutoGenerated.Serialization.cs create mode 100644 sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/ResourceReferenceAutoGenerated.cs create mode 100644 sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/ResourceReferenceExtended.Serialization.cs create mode 100644 sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/ResourceReferenceExtended.cs create mode 100644 sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/ResourceStatusMode.cs create mode 100644 sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/UnmanageActionManagementGroupMode.cs create mode 100644 sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/UnmanageActionResourceGroupMode.cs create mode 100644 sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/UnmanageActionResourceMode.cs create mode 100644 sdk/resources/Azure.ResourceManager.Resources/src/Generated/RestOperations/DeploymentStacksRestOperations.cs create mode 100644 sdk/resources/Azure.ResourceManager.Resources/tests/Scenario/DeploymentStackCollectionTests.cs create mode 100644 sdk/resources/Azure.ResourceManager.Resources/tests/Scenario/DeploymentStackOperationsTests.cs create mode 100644 sdk/resources/Azure.ResourceManager.Resources/tests/Scenario/DeploymentTemplates/mg-stack-template.json create mode 100644 sdk/resources/Azure.ResourceManager.Resources/tests/Scenario/DeploymentTemplates/rg-stack-template.json create mode 100644 sdk/resources/Azure.ResourceManager.Resources/tests/Scenario/DeploymentTemplates/sub-stack-template.json diff --git a/sdk/resources/Azure.ResourceManager.Resources/Azure.ResourceManager.Resources.sln b/sdk/resources/Azure.ResourceManager.Resources/Azure.ResourceManager.Resources.sln index 9ac6f4b080a33..89158324f5ae9 100644 --- a/sdk/resources/Azure.ResourceManager.Resources/Azure.ResourceManager.Resources.sln +++ b/sdk/resources/Azure.ResourceManager.Resources/Azure.ResourceManager.Resources.sln @@ -2,8 +2,6 @@ Microsoft Visual Studio Solution File, Format Version 12.00 # Visual Studio Version 17 VisualStudioVersion = 17.6.33829.357 MinimumVisualStudioVersion = 15.0.26124.0 -Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "Azure.Core.TestFramework", "..\..\core\Azure.Core.TestFramework\src\Azure.Core.TestFramework.csproj", "{62AF7C88-CE3F-416E-B18E-BC6F884C89E2}" -EndProject Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "Azure.ResourceManager.Resources", "src\Azure.ResourceManager.Resources.csproj", "{DEFF4395-FBD0-4205-95DE-7992E79015FA}" EndProject Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "Azure.ResourceManager.Resources.Tests", "tests\Azure.ResourceManager.Resources.Tests.csproj", "{9D842058-41AB-42DD-82C8-F3DF49E25297}" @@ -20,18 +18,6 @@ Global Release|x86 = Release|x86 EndGlobalSection GlobalSection(ProjectConfigurationPlatforms) = postSolution - {62AF7C88-CE3F-416E-B18E-BC6F884C89E2}.Debug|Any CPU.ActiveCfg = Debug|Any CPU - {62AF7C88-CE3F-416E-B18E-BC6F884C89E2}.Debug|Any CPU.Build.0 = Debug|Any CPU - {62AF7C88-CE3F-416E-B18E-BC6F884C89E2}.Debug|x64.ActiveCfg = Debug|Any CPU - {62AF7C88-CE3F-416E-B18E-BC6F884C89E2}.Debug|x64.Build.0 = Debug|Any CPU - {62AF7C88-CE3F-416E-B18E-BC6F884C89E2}.Debug|x86.ActiveCfg = Debug|Any CPU - {62AF7C88-CE3F-416E-B18E-BC6F884C89E2}.Debug|x86.Build.0 = Debug|Any CPU - {62AF7C88-CE3F-416E-B18E-BC6F884C89E2}.Release|Any CPU.ActiveCfg = Release|Any CPU - {62AF7C88-CE3F-416E-B18E-BC6F884C89E2}.Release|Any CPU.Build.0 = Release|Any CPU - {62AF7C88-CE3F-416E-B18E-BC6F884C89E2}.Release|x64.ActiveCfg = Release|Any CPU - {62AF7C88-CE3F-416E-B18E-BC6F884C89E2}.Release|x64.Build.0 = Release|Any CPU - {62AF7C88-CE3F-416E-B18E-BC6F884C89E2}.Release|x86.ActiveCfg = Release|Any CPU - {62AF7C88-CE3F-416E-B18E-BC6F884C89E2}.Release|x86.Build.0 = Release|Any CPU {DEFF4395-FBD0-4205-95DE-7992E79015FA}.Debug|Any CPU.ActiveCfg = Debug|Any CPU {DEFF4395-FBD0-4205-95DE-7992E79015FA}.Debug|Any CPU.Build.0 = Debug|Any CPU {DEFF4395-FBD0-4205-95DE-7992E79015FA}.Debug|x64.ActiveCfg = Debug|Any CPU diff --git a/sdk/resources/Azure.ResourceManager.Resources/CHANGELOG.md b/sdk/resources/Azure.ResourceManager.Resources/CHANGELOG.md index 34bdde9a80702..b2c841f96290b 100644 --- a/sdk/resources/Azure.ResourceManager.Resources/CHANGELOG.md +++ b/sdk/resources/Azure.ResourceManager.Resources/CHANGELOG.md @@ -1,14 +1,10 @@ # Release History -## 1.8.0-beta.1 (Unreleased) +## 1.8.0 (2024-07-04) ### Features Added -### Breaking Changes - -### Bugs Fixed - -### Other Changes +- Added `DeploymentStack` support. ## 1.7.3 (2024-05-07) @@ -20,13 +16,13 @@ ### Features Added -- Add `ArmOperation.Rehydrate` and `ArmOperation.Rehydrate` static methods to rehydrate a long-running operation. +- Added `ArmOperation.Rehydrate` and `ArmOperation.Rehydrate` static methods to rehydrate a long-running operation. ## 1.7.1 (2024-03-23) ### Features Added -- Enable the new model serialization by using the System.ClientModel, refer this [document](https://aka.ms/azsdk/net/mrw) for more details. +- Enabled the new model serialization by using the System.ClientModel, refer this [document](https://aka.ms/azsdk/net/mrw) for more details. - Added experimental Bicep serialization. ## 1.7.0 (2023-11-16) diff --git a/sdk/resources/Azure.ResourceManager.Resources/api/Azure.ResourceManager.Resources.netstandard2.0.cs b/sdk/resources/Azure.ResourceManager.Resources/api/Azure.ResourceManager.Resources.netstandard2.0.cs index e15be5aca25e6..77e6f826a2c1e 100644 --- a/sdk/resources/Azure.ResourceManager.Resources/api/Azure.ResourceManager.Resources.netstandard2.0.cs +++ b/sdk/resources/Azure.ResourceManager.Resources/api/Azure.ResourceManager.Resources.netstandard2.0.cs @@ -264,6 +264,83 @@ protected ArmDeploymentScriptResource() { } public virtual Azure.Response Update(Azure.ResourceManager.Resources.Models.ArmDeploymentScriptPatch patch, System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } public virtual System.Threading.Tasks.Task> UpdateAsync(Azure.ResourceManager.Resources.Models.ArmDeploymentScriptPatch patch, System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } } + public partial class DeploymentStackCollection : Azure.ResourceManager.ArmCollection, System.Collections.Generic.IAsyncEnumerable, System.Collections.Generic.IEnumerable, System.Collections.IEnumerable + { + protected DeploymentStackCollection() { } + public virtual Azure.ResourceManager.ArmOperation CreateOrUpdate(Azure.WaitUntil waitUntil, string deploymentStackName, Azure.ResourceManager.Resources.DeploymentStackData data, System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } + public virtual System.Threading.Tasks.Task> CreateOrUpdateAsync(Azure.WaitUntil waitUntil, string deploymentStackName, Azure.ResourceManager.Resources.DeploymentStackData data, System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } + public virtual Azure.Response Exists(string deploymentStackName, System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } + public virtual System.Threading.Tasks.Task> ExistsAsync(string deploymentStackName, System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } + public virtual Azure.Response Get(string deploymentStackName, System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } + public virtual Azure.Pageable GetAll(System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } + public virtual Azure.AsyncPageable GetAllAsync(System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } + public virtual System.Threading.Tasks.Task> GetAsync(string deploymentStackName, System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } + public virtual Azure.NullableResponse GetIfExists(string deploymentStackName, System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } + public virtual System.Threading.Tasks.Task> GetIfExistsAsync(string deploymentStackName, System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } + System.Collections.Generic.IAsyncEnumerator System.Collections.Generic.IAsyncEnumerable.GetAsyncEnumerator(System.Threading.CancellationToken cancellationToken) { throw null; } + System.Collections.Generic.IEnumerator System.Collections.Generic.IEnumerable.GetEnumerator() { throw null; } + System.Collections.IEnumerator System.Collections.IEnumerable.GetEnumerator() { throw null; } + } + public partial class DeploymentStackData : Azure.ResourceManager.Models.ResourceData, System.ClientModel.Primitives.IJsonModel, System.ClientModel.Primitives.IPersistableModel + { + public DeploymentStackData() { } + public Azure.ResourceManager.Resources.Models.ActionOnUnmanage ActionOnUnmanage { get { throw null; } set { } } + public bool? BypassStackOutOfSyncError { get { throw null; } set { } } + public string CorrelationId { get { throw null; } } + public string DebugSettingDetailLevel { get { throw null; } set { } } + public System.Collections.Generic.IReadOnlyList DeletedResources { get { throw null; } } + public Azure.ResourceManager.Resources.Models.DenySettings DenySettings { get { throw null; } set { } } + public string DeploymentId { get { throw null; } } + public string DeploymentScope { get { throw null; } set { } } + public string Description { get { throw null; } set { } } + public System.Collections.Generic.IReadOnlyList DetachedResources { get { throw null; } } + public System.TimeSpan? Duration { get { throw null; } } + public Azure.ResponseError Error { get { throw null; } set { } } + public System.Collections.Generic.IReadOnlyList FailedResources { get { throw null; } } + public Azure.Core.AzureLocation? Location { get { throw null; } set { } } + public System.BinaryData Outputs { get { throw null; } } + public System.Collections.Generic.IDictionary Parameters { get { throw null; } } + public Azure.ResourceManager.Resources.Models.DeploymentStacksParametersLink ParametersLink { get { throw null; } set { } } + public Azure.ResourceManager.Resources.Models.DeploymentStackProvisioningState? ProvisioningState { get { throw null; } } + public System.Collections.Generic.IReadOnlyList Resources { get { throw null; } } + public System.Collections.Generic.IDictionary Tags { get { throw null; } } + public System.BinaryData Template { get { throw null; } set { } } + public Azure.ResourceManager.Resources.Models.DeploymentStacksTemplateLink TemplateLink { get { throw null; } set { } } + Azure.ResourceManager.Resources.DeploymentStackData System.ClientModel.Primitives.IJsonModel.Create(ref System.Text.Json.Utf8JsonReader reader, System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + void System.ClientModel.Primitives.IJsonModel.Write(System.Text.Json.Utf8JsonWriter writer, System.ClientModel.Primitives.ModelReaderWriterOptions options) { } + Azure.ResourceManager.Resources.DeploymentStackData System.ClientModel.Primitives.IPersistableModel.Create(System.BinaryData data, System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + string System.ClientModel.Primitives.IPersistableModel.GetFormatFromOptions(System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + System.BinaryData System.ClientModel.Primitives.IPersistableModel.Write(System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + } + public partial class DeploymentStackResource : Azure.ResourceManager.ArmResource, System.ClientModel.Primitives.IJsonModel, System.ClientModel.Primitives.IPersistableModel + { + public static readonly Azure.Core.ResourceType ResourceType; + protected DeploymentStackResource() { } + public virtual Azure.ResourceManager.Resources.DeploymentStackData Data { get { throw null; } } + public virtual bool HasData { get { throw null; } } + public virtual Azure.Response AddTag(string key, string value, System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } + public virtual System.Threading.Tasks.Task> AddTagAsync(string key, string value, System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } + public static Azure.Core.ResourceIdentifier CreateResourceIdentifier(string scope, string deploymentStackName) { throw null; } + public virtual Azure.ResourceManager.ArmOperation Delete(Azure.WaitUntil waitUntil, Azure.ResourceManager.Resources.Models.UnmanageActionResourceMode? unmanageActionResources = default(Azure.ResourceManager.Resources.Models.UnmanageActionResourceMode?), Azure.ResourceManager.Resources.Models.UnmanageActionResourceGroupMode? unmanageActionResourceGroups = default(Azure.ResourceManager.Resources.Models.UnmanageActionResourceGroupMode?), Azure.ResourceManager.Resources.Models.UnmanageActionManagementGroupMode? unmanageActionManagementGroups = default(Azure.ResourceManager.Resources.Models.UnmanageActionManagementGroupMode?), bool? bypassStackOutOfSyncError = default(bool?), System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } + public virtual System.Threading.Tasks.Task DeleteAsync(Azure.WaitUntil waitUntil, Azure.ResourceManager.Resources.Models.UnmanageActionResourceMode? unmanageActionResources = default(Azure.ResourceManager.Resources.Models.UnmanageActionResourceMode?), Azure.ResourceManager.Resources.Models.UnmanageActionResourceGroupMode? unmanageActionResourceGroups = default(Azure.ResourceManager.Resources.Models.UnmanageActionResourceGroupMode?), Azure.ResourceManager.Resources.Models.UnmanageActionManagementGroupMode? unmanageActionManagementGroups = default(Azure.ResourceManager.Resources.Models.UnmanageActionManagementGroupMode?), bool? bypassStackOutOfSyncError = default(bool?), System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } + public virtual Azure.Response ExportTemplate(System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } + public virtual System.Threading.Tasks.Task> ExportTemplateAsync(System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } + public virtual Azure.Response Get(System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } + public virtual System.Threading.Tasks.Task> GetAsync(System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } + public virtual Azure.Response RemoveTag(string key, System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } + public virtual System.Threading.Tasks.Task> RemoveTagAsync(string key, System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } + public virtual Azure.Response SetTags(System.Collections.Generic.IDictionary tags, System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } + public virtual System.Threading.Tasks.Task> SetTagsAsync(System.Collections.Generic.IDictionary tags, System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } + Azure.ResourceManager.Resources.DeploymentStackData System.ClientModel.Primitives.IJsonModel.Create(ref System.Text.Json.Utf8JsonReader reader, System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + void System.ClientModel.Primitives.IJsonModel.Write(System.Text.Json.Utf8JsonWriter writer, System.ClientModel.Primitives.ModelReaderWriterOptions options) { } + Azure.ResourceManager.Resources.DeploymentStackData System.ClientModel.Primitives.IPersistableModel.Create(System.BinaryData data, System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + string System.ClientModel.Primitives.IPersistableModel.GetFormatFromOptions(System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + System.BinaryData System.ClientModel.Primitives.IPersistableModel.Write(System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + public virtual Azure.ResourceManager.ArmOperation Update(Azure.WaitUntil waitUntil, Azure.ResourceManager.Resources.DeploymentStackData data, System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } + public virtual System.Threading.Tasks.Task> UpdateAsync(Azure.WaitUntil waitUntil, Azure.ResourceManager.Resources.DeploymentStackData data, System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } + public virtual Azure.ResourceManager.ArmOperation ValidateStack(Azure.WaitUntil waitUntil, Azure.ResourceManager.Resources.DeploymentStackData data, System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } + public virtual System.Threading.Tasks.Task> ValidateStackAsync(Azure.WaitUntil waitUntil, Azure.ResourceManager.Resources.DeploymentStackData data, System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } + } public partial class JitRequestCollection : Azure.ResourceManager.ArmCollection, System.Collections.Generic.IAsyncEnumerable, System.Collections.Generic.IEnumerable, System.Collections.IEnumerable { protected JitRequestCollection() { } @@ -358,6 +435,16 @@ public static partial class ResourcesExtensions public static Azure.ResourceManager.Resources.ArmDeploymentScriptCollection GetArmDeploymentScripts(this Azure.ResourceManager.Resources.ResourceGroupResource resourceGroupResource) { throw null; } public static Azure.Pageable GetArmDeploymentScripts(this Azure.ResourceManager.Resources.SubscriptionResource subscriptionResource, System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } public static Azure.AsyncPageable GetArmDeploymentScriptsAsync(this Azure.ResourceManager.Resources.SubscriptionResource subscriptionResource, System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } + public static Azure.Response GetDeploymentStack(this Azure.ResourceManager.ManagementGroups.ManagementGroupResource managementGroupResource, string deploymentStackName, System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } + public static Azure.Response GetDeploymentStack(this Azure.ResourceManager.Resources.ResourceGroupResource resourceGroupResource, string deploymentStackName, System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } + public static Azure.Response GetDeploymentStack(this Azure.ResourceManager.Resources.SubscriptionResource subscriptionResource, string deploymentStackName, System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } + public static System.Threading.Tasks.Task> GetDeploymentStackAsync(this Azure.ResourceManager.ManagementGroups.ManagementGroupResource managementGroupResource, string deploymentStackName, System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } + public static System.Threading.Tasks.Task> GetDeploymentStackAsync(this Azure.ResourceManager.Resources.ResourceGroupResource resourceGroupResource, string deploymentStackName, System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } + public static System.Threading.Tasks.Task> GetDeploymentStackAsync(this Azure.ResourceManager.Resources.SubscriptionResource subscriptionResource, string deploymentStackName, System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } + public static Azure.ResourceManager.Resources.DeploymentStackResource GetDeploymentStackResource(this Azure.ResourceManager.ArmClient client, Azure.Core.ResourceIdentifier id) { throw null; } + public static Azure.ResourceManager.Resources.DeploymentStackCollection GetDeploymentStacks(this Azure.ResourceManager.ManagementGroups.ManagementGroupResource managementGroupResource) { throw null; } + public static Azure.ResourceManager.Resources.DeploymentStackCollection GetDeploymentStacks(this Azure.ResourceManager.Resources.ResourceGroupResource resourceGroupResource) { throw null; } + public static Azure.ResourceManager.Resources.DeploymentStackCollection GetDeploymentStacks(this Azure.ResourceManager.Resources.SubscriptionResource subscriptionResource) { throw null; } public static Azure.Response GetJitRequest(this Azure.ResourceManager.Resources.ResourceGroupResource resourceGroupResource, string jitRequestName, System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } public static System.Threading.Tasks.Task> GetJitRequestAsync(this Azure.ResourceManager.Resources.ResourceGroupResource resourceGroupResource, string jitRequestName, System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } public static Azure.Pageable GetJitRequestDefinitions(this Azure.ResourceManager.Resources.SubscriptionResource subscriptionResource, System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } @@ -526,6 +613,7 @@ protected MockableResourcesArmClient() { } public virtual Azure.ResourceManager.Resources.ArmApplicationResource GetArmApplicationResource(Azure.Core.ResourceIdentifier id) { throw null; } public virtual Azure.ResourceManager.Resources.ArmDeploymentResource GetArmDeploymentResource(Azure.Core.ResourceIdentifier id) { throw null; } public virtual Azure.ResourceManager.Resources.ArmDeploymentScriptResource GetArmDeploymentScriptResource(Azure.Core.ResourceIdentifier id) { throw null; } + public virtual Azure.ResourceManager.Resources.DeploymentStackResource GetDeploymentStackResource(Azure.Core.ResourceIdentifier id) { throw null; } public virtual Azure.ResourceManager.Resources.JitRequestResource GetJitRequestResource(Azure.Core.ResourceIdentifier id) { throw null; } public virtual Azure.ResourceManager.Resources.ScriptLogResource GetScriptLogResource(Azure.Core.ResourceIdentifier id) { throw null; } public virtual Azure.ResourceManager.Resources.TemplateSpecResource GetTemplateSpecResource(Azure.Core.ResourceIdentifier id) { throw null; } @@ -537,6 +625,9 @@ protected MockableResourcesManagementGroupResource() { } public virtual Azure.Response GetArmDeployment(string deploymentName, System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } public virtual System.Threading.Tasks.Task> GetArmDeploymentAsync(string deploymentName, System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } public virtual Azure.ResourceManager.Resources.ArmDeploymentCollection GetArmDeployments() { throw null; } + public virtual Azure.Response GetDeploymentStack(string deploymentStackName, System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } + public virtual System.Threading.Tasks.Task> GetDeploymentStackAsync(string deploymentStackName, System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } + public virtual Azure.ResourceManager.Resources.DeploymentStackCollection GetDeploymentStacks() { throw null; } } public partial class MockableResourcesResourceGroupResource : Azure.ResourceManager.ArmResource { @@ -553,6 +644,9 @@ protected MockableResourcesResourceGroupResource() { } public virtual Azure.Response GetArmDeploymentScript(string scriptName, System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } public virtual System.Threading.Tasks.Task> GetArmDeploymentScriptAsync(string scriptName, System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } public virtual Azure.ResourceManager.Resources.ArmDeploymentScriptCollection GetArmDeploymentScripts() { throw null; } + public virtual Azure.Response GetDeploymentStack(string deploymentStackName, System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } + public virtual System.Threading.Tasks.Task> GetDeploymentStackAsync(string deploymentStackName, System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } + public virtual Azure.ResourceManager.Resources.DeploymentStackCollection GetDeploymentStacks() { throw null; } public virtual Azure.Response GetJitRequest(string jitRequestName, System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } public virtual System.Threading.Tasks.Task> GetJitRequestAsync(string jitRequestName, System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } public virtual Azure.ResourceManager.Resources.JitRequestCollection GetJitRequests() { throw null; } @@ -572,6 +666,9 @@ protected MockableResourcesSubscriptionResource() { } public virtual Azure.ResourceManager.Resources.ArmDeploymentCollection GetArmDeployments() { throw null; } public virtual Azure.Pageable GetArmDeploymentScripts(System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } public virtual Azure.AsyncPageable GetArmDeploymentScriptsAsync(System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } + public virtual Azure.Response GetDeploymentStack(string deploymentStackName, System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } + public virtual System.Threading.Tasks.Task> GetDeploymentStackAsync(string deploymentStackName, System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } + public virtual Azure.ResourceManager.Resources.DeploymentStackCollection GetDeploymentStacks() { throw null; } public virtual Azure.Pageable GetJitRequestDefinitions(System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } public virtual Azure.AsyncPageable GetJitRequestDefinitionsAsync(System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } public virtual Azure.Pageable GetTemplateSpecs(Azure.ResourceManager.Resources.Models.TemplateSpecExpandKind? expand = default(Azure.ResourceManager.Resources.Models.TemplateSpecExpandKind?), System.Threading.CancellationToken cancellationToken = default(System.Threading.CancellationToken)) { throw null; } @@ -589,6 +686,18 @@ protected MockableResourcesTenantResource() { } } namespace Azure.ResourceManager.Resources.Models { + public partial class ActionOnUnmanage : System.ClientModel.Primitives.IJsonModel, System.ClientModel.Primitives.IPersistableModel + { + public ActionOnUnmanage(Azure.ResourceManager.Resources.Models.DeploymentStacksDeleteDetachEnum resources) { } + public Azure.ResourceManager.Resources.Models.DeploymentStacksDeleteDetachEnum? ManagementGroups { get { throw null; } set { } } + public Azure.ResourceManager.Resources.Models.DeploymentStacksDeleteDetachEnum? ResourceGroups { get { throw null; } set { } } + public Azure.ResourceManager.Resources.Models.DeploymentStacksDeleteDetachEnum Resources { get { throw null; } set { } } + Azure.ResourceManager.Resources.Models.ActionOnUnmanage System.ClientModel.Primitives.IJsonModel.Create(ref System.Text.Json.Utf8JsonReader reader, System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + void System.ClientModel.Primitives.IJsonModel.Write(System.Text.Json.Utf8JsonWriter writer, System.ClientModel.Primitives.ModelReaderWriterOptions options) { } + Azure.ResourceManager.Resources.Models.ActionOnUnmanage System.ClientModel.Primitives.IPersistableModel.Create(System.BinaryData data, System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + string System.ClientModel.Primitives.IPersistableModel.GetFormatFromOptions(System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + System.BinaryData System.ClientModel.Primitives.IPersistableModel.Write(System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + } public partial class ArmApplicationArtifact : System.ClientModel.Primitives.IJsonModel, System.ClientModel.Primitives.IPersistableModel { internal ArmApplicationArtifact() { } @@ -1120,8 +1229,14 @@ public static partial class ArmResourcesModelFactory public static Azure.ResourceManager.Resources.Models.BasicArmDependency BasicArmDependency(string id = null, Azure.Core.ResourceType? resourceType = default(Azure.Core.ResourceType?), string resourceName = null) { throw null; } public static Azure.ResourceManager.Resources.Models.DecompiledFileDefinition DecompiledFileDefinition(string path = null, string contents = null) { throw null; } public static Azure.ResourceManager.Resources.Models.DecompileOperationSuccessResult DecompileOperationSuccessResult(System.Collections.Generic.IEnumerable files = null, string entryPoint = null) { throw null; } + public static Azure.ResourceManager.Resources.DeploymentStackData DeploymentStackData(Azure.Core.ResourceIdentifier id = null, string name = null, Azure.Core.ResourceType resourceType = default(Azure.Core.ResourceType), Azure.ResourceManager.Models.SystemData systemData = null, Azure.Core.AzureLocation? location = default(Azure.Core.AzureLocation?), System.Collections.Generic.IDictionary tags = null, Azure.ResponseError error = null, System.BinaryData template = null, Azure.ResourceManager.Resources.Models.DeploymentStacksTemplateLink templateLink = null, System.Collections.Generic.IDictionary parameters = null, Azure.ResourceManager.Resources.Models.DeploymentStacksParametersLink parametersLink = null, Azure.ResourceManager.Resources.Models.ActionOnUnmanage actionOnUnmanage = null, string debugSettingDetailLevel = null, bool? bypassStackOutOfSyncError = default(bool?), string deploymentScope = null, string description = null, Azure.ResourceManager.Resources.Models.DenySettings denySettings = null, Azure.ResourceManager.Resources.Models.DeploymentStackProvisioningState? provisioningState = default(Azure.ResourceManager.Resources.Models.DeploymentStackProvisioningState?), string correlationId = null, System.Collections.Generic.IEnumerable detachedResources = null, System.Collections.Generic.IEnumerable deletedResources = null, System.Collections.Generic.IEnumerable failedResources = null, System.Collections.Generic.IEnumerable resources = null, string deploymentId = null, System.BinaryData outputs = null, System.TimeSpan? duration = default(System.TimeSpan?)) { throw null; } + public static Azure.ResourceManager.Resources.Models.DeploymentStackTemplateDefinition DeploymentStackTemplateDefinition(System.BinaryData template = null, Azure.ResourceManager.Resources.Models.DeploymentStacksTemplateLink templateLink = null) { throw null; } + public static Azure.ResourceManager.Resources.Models.DeploymentStackValidateResult DeploymentStackValidateResult(Azure.Core.ResourceIdentifier id = null, string name = null, Azure.Core.ResourceType resourceType = default(Azure.Core.ResourceType), Azure.ResourceManager.Models.SystemData systemData = null, Azure.ResourceManager.Resources.Models.DeploymentStackValidateProperties properties = null, Azure.ResponseError error = null) { throw null; } public static Azure.ResourceManager.Resources.Models.ErrorDeploymentExtended ErrorDeploymentExtended(string provisioningState = null, Azure.ResourceManager.Resources.Models.ErrorDeploymentType? deploymentType = default(Azure.ResourceManager.Resources.Models.ErrorDeploymentType?), string deploymentName = null) { throw null; } public static Azure.ResourceManager.Resources.JitRequestData JitRequestData(Azure.Core.ResourceIdentifier id = null, string name = null, Azure.Core.ResourceType resourceType = default(Azure.Core.ResourceType), Azure.ResourceManager.Models.SystemData systemData = null, System.Collections.Generic.IDictionary tags = null, Azure.Core.AzureLocation location = default(Azure.Core.AzureLocation), string applicationResourceId = null, System.Guid? publisherTenantId = default(System.Guid?), System.Collections.Generic.IEnumerable jitAuthorizationPolicies = null, Azure.ResourceManager.Resources.Models.JitSchedulingPolicy jitSchedulingPolicy = null, Azure.ResourceManager.Resources.Models.ResourcesProvisioningState? provisioningState = default(Azure.ResourceManager.Resources.Models.ResourcesProvisioningState?), Azure.ResourceManager.Resources.Models.JitRequestState? jitRequestState = default(Azure.ResourceManager.Resources.Models.JitRequestState?), Azure.ResourceManager.Resources.Models.ArmApplicationDetails createdBy = null, Azure.ResourceManager.Resources.Models.ArmApplicationDetails updatedBy = null) { throw null; } + public static Azure.ResourceManager.Resources.Models.ManagedResourceReference ManagedResourceReference(string id = null, Azure.ResourceManager.Resources.Models.ResourceStatusMode? status = default(Azure.ResourceManager.Resources.Models.ResourceStatusMode?), Azure.ResourceManager.Resources.Models.DenyStatusMode? denyStatus = default(Azure.ResourceManager.Resources.Models.DenyStatusMode?)) { throw null; } + public static Azure.ResourceManager.Resources.Models.ResourceReferenceAutoGenerated ResourceReferenceAutoGenerated(string id = null) { throw null; } + public static Azure.ResourceManager.Resources.Models.ResourceReferenceExtended ResourceReferenceExtended(string id = null, Azure.ResponseError error = null) { throw null; } public static Azure.ResourceManager.Resources.ScriptLogData ScriptLogData(Azure.Core.ResourceIdentifier id = null, string name = null, Azure.Core.ResourceType resourceType = default(Azure.Core.ResourceType), Azure.ResourceManager.Models.SystemData systemData = null, string log = null) { throw null; } public static Azure.ResourceManager.Resources.Models.ScriptStatus ScriptStatus(string containerInstanceId = null, string storageAccountId = null, System.DateTimeOffset? startOn = default(System.DateTimeOffset?), System.DateTimeOffset? endOn = default(System.DateTimeOffset?), System.DateTimeOffset? expireOn = default(System.DateTimeOffset?), Azure.ResponseError error = null) { throw null; } public static Azure.ResourceManager.Resources.Models.StatusMessage StatusMessage(string status = null, Azure.ResponseError error = null) { throw null; } @@ -1228,6 +1343,181 @@ internal DecompileOperationSuccessResult() { } string System.ClientModel.Primitives.IPersistableModel.GetFormatFromOptions(System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } System.BinaryData System.ClientModel.Primitives.IPersistableModel.Write(System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } } + public partial class DenySettings : System.ClientModel.Primitives.IJsonModel, System.ClientModel.Primitives.IPersistableModel + { + public DenySettings(Azure.ResourceManager.Resources.Models.DenySettingsMode mode) { } + public bool? ApplyToChildScopes { get { throw null; } set { } } + public System.Collections.Generic.IList ExcludedActions { get { throw null; } } + public System.Collections.Generic.IList ExcludedPrincipals { get { throw null; } } + public Azure.ResourceManager.Resources.Models.DenySettingsMode Mode { get { throw null; } set { } } + Azure.ResourceManager.Resources.Models.DenySettings System.ClientModel.Primitives.IJsonModel.Create(ref System.Text.Json.Utf8JsonReader reader, System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + void System.ClientModel.Primitives.IJsonModel.Write(System.Text.Json.Utf8JsonWriter writer, System.ClientModel.Primitives.ModelReaderWriterOptions options) { } + Azure.ResourceManager.Resources.Models.DenySettings System.ClientModel.Primitives.IPersistableModel.Create(System.BinaryData data, System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + string System.ClientModel.Primitives.IPersistableModel.GetFormatFromOptions(System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + System.BinaryData System.ClientModel.Primitives.IPersistableModel.Write(System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + } + [System.Runtime.InteropServices.StructLayoutAttribute(System.Runtime.InteropServices.LayoutKind.Sequential)] + public readonly partial struct DenySettingsMode : System.IEquatable + { + private readonly object _dummy; + private readonly int _dummyPrimitive; + public DenySettingsMode(string value) { throw null; } + public static Azure.ResourceManager.Resources.Models.DenySettingsMode DenyDelete { get { throw null; } } + public static Azure.ResourceManager.Resources.Models.DenySettingsMode DenyWriteAndDelete { get { throw null; } } + public static Azure.ResourceManager.Resources.Models.DenySettingsMode None { get { throw null; } } + public bool Equals(Azure.ResourceManager.Resources.Models.DenySettingsMode other) { throw null; } + [System.ComponentModel.EditorBrowsableAttribute(System.ComponentModel.EditorBrowsableState.Never)] + public override bool Equals(object obj) { throw null; } + [System.ComponentModel.EditorBrowsableAttribute(System.ComponentModel.EditorBrowsableState.Never)] + public override int GetHashCode() { throw null; } + public static bool operator ==(Azure.ResourceManager.Resources.Models.DenySettingsMode left, Azure.ResourceManager.Resources.Models.DenySettingsMode right) { throw null; } + public static implicit operator Azure.ResourceManager.Resources.Models.DenySettingsMode (string value) { throw null; } + public static bool operator !=(Azure.ResourceManager.Resources.Models.DenySettingsMode left, Azure.ResourceManager.Resources.Models.DenySettingsMode right) { throw null; } + public override string ToString() { throw null; } + } + [System.Runtime.InteropServices.StructLayoutAttribute(System.Runtime.InteropServices.LayoutKind.Sequential)] + public readonly partial struct DenyStatusMode : System.IEquatable + { + private readonly object _dummy; + private readonly int _dummyPrimitive; + public DenyStatusMode(string value) { throw null; } + public static Azure.ResourceManager.Resources.Models.DenyStatusMode DenyDelete { get { throw null; } } + public static Azure.ResourceManager.Resources.Models.DenyStatusMode DenyWriteAndDelete { get { throw null; } } + public static Azure.ResourceManager.Resources.Models.DenyStatusMode Inapplicable { get { throw null; } } + public static Azure.ResourceManager.Resources.Models.DenyStatusMode None { get { throw null; } } + public static Azure.ResourceManager.Resources.Models.DenyStatusMode NotSupported { get { throw null; } } + public static Azure.ResourceManager.Resources.Models.DenyStatusMode RemovedBySystem { get { throw null; } } + public bool Equals(Azure.ResourceManager.Resources.Models.DenyStatusMode other) { throw null; } + [System.ComponentModel.EditorBrowsableAttribute(System.ComponentModel.EditorBrowsableState.Never)] + public override bool Equals(object obj) { throw null; } + [System.ComponentModel.EditorBrowsableAttribute(System.ComponentModel.EditorBrowsableState.Never)] + public override int GetHashCode() { throw null; } + public static bool operator ==(Azure.ResourceManager.Resources.Models.DenyStatusMode left, Azure.ResourceManager.Resources.Models.DenyStatusMode right) { throw null; } + public static implicit operator Azure.ResourceManager.Resources.Models.DenyStatusMode (string value) { throw null; } + public static bool operator !=(Azure.ResourceManager.Resources.Models.DenyStatusMode left, Azure.ResourceManager.Resources.Models.DenyStatusMode right) { throw null; } + public override string ToString() { throw null; } + } + public partial class DeploymentParameter : System.ClientModel.Primitives.IJsonModel, System.ClientModel.Primitives.IPersistableModel + { + public DeploymentParameter() { } + public string DeploymentParameterType { get { throw null; } set { } } + public Azure.ResourceManager.Resources.Models.KeyVaultParameterReference Reference { get { throw null; } set { } } + public System.BinaryData Value { get { throw null; } set { } } + Azure.ResourceManager.Resources.Models.DeploymentParameter System.ClientModel.Primitives.IJsonModel.Create(ref System.Text.Json.Utf8JsonReader reader, System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + void System.ClientModel.Primitives.IJsonModel.Write(System.Text.Json.Utf8JsonWriter writer, System.ClientModel.Primitives.ModelReaderWriterOptions options) { } + Azure.ResourceManager.Resources.Models.DeploymentParameter System.ClientModel.Primitives.IPersistableModel.Create(System.BinaryData data, System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + string System.ClientModel.Primitives.IPersistableModel.GetFormatFromOptions(System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + System.BinaryData System.ClientModel.Primitives.IPersistableModel.Write(System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + } + [System.Runtime.InteropServices.StructLayoutAttribute(System.Runtime.InteropServices.LayoutKind.Sequential)] + public readonly partial struct DeploymentStackProvisioningState : System.IEquatable + { + private readonly object _dummy; + private readonly int _dummyPrimitive; + public DeploymentStackProvisioningState(string value) { throw null; } + public static Azure.ResourceManager.Resources.Models.DeploymentStackProvisioningState Canceled { get { throw null; } } + public static Azure.ResourceManager.Resources.Models.DeploymentStackProvisioningState Canceling { get { throw null; } } + public static Azure.ResourceManager.Resources.Models.DeploymentStackProvisioningState Creating { get { throw null; } } + public static Azure.ResourceManager.Resources.Models.DeploymentStackProvisioningState Deleting { get { throw null; } } + public static Azure.ResourceManager.Resources.Models.DeploymentStackProvisioningState DeletingResources { get { throw null; } } + public static Azure.ResourceManager.Resources.Models.DeploymentStackProvisioningState Deploying { get { throw null; } } + public static Azure.ResourceManager.Resources.Models.DeploymentStackProvisioningState Failed { get { throw null; } } + public static Azure.ResourceManager.Resources.Models.DeploymentStackProvisioningState Succeeded { get { throw null; } } + public static Azure.ResourceManager.Resources.Models.DeploymentStackProvisioningState UpdatingDenyAssignments { get { throw null; } } + public static Azure.ResourceManager.Resources.Models.DeploymentStackProvisioningState Validating { get { throw null; } } + public static Azure.ResourceManager.Resources.Models.DeploymentStackProvisioningState Waiting { get { throw null; } } + public bool Equals(Azure.ResourceManager.Resources.Models.DeploymentStackProvisioningState other) { throw null; } + [System.ComponentModel.EditorBrowsableAttribute(System.ComponentModel.EditorBrowsableState.Never)] + public override bool Equals(object obj) { throw null; } + [System.ComponentModel.EditorBrowsableAttribute(System.ComponentModel.EditorBrowsableState.Never)] + public override int GetHashCode() { throw null; } + public static bool operator ==(Azure.ResourceManager.Resources.Models.DeploymentStackProvisioningState left, Azure.ResourceManager.Resources.Models.DeploymentStackProvisioningState right) { throw null; } + public static implicit operator Azure.ResourceManager.Resources.Models.DeploymentStackProvisioningState (string value) { throw null; } + public static bool operator !=(Azure.ResourceManager.Resources.Models.DeploymentStackProvisioningState left, Azure.ResourceManager.Resources.Models.DeploymentStackProvisioningState right) { throw null; } + public override string ToString() { throw null; } + } + [System.Runtime.InteropServices.StructLayoutAttribute(System.Runtime.InteropServices.LayoutKind.Sequential)] + public readonly partial struct DeploymentStacksDeleteDetachEnum : System.IEquatable + { + private readonly object _dummy; + private readonly int _dummyPrimitive; + public DeploymentStacksDeleteDetachEnum(string value) { throw null; } + public static Azure.ResourceManager.Resources.Models.DeploymentStacksDeleteDetachEnum Delete { get { throw null; } } + public static Azure.ResourceManager.Resources.Models.DeploymentStacksDeleteDetachEnum Detach { get { throw null; } } + public bool Equals(Azure.ResourceManager.Resources.Models.DeploymentStacksDeleteDetachEnum other) { throw null; } + [System.ComponentModel.EditorBrowsableAttribute(System.ComponentModel.EditorBrowsableState.Never)] + public override bool Equals(object obj) { throw null; } + [System.ComponentModel.EditorBrowsableAttribute(System.ComponentModel.EditorBrowsableState.Never)] + public override int GetHashCode() { throw null; } + public static bool operator ==(Azure.ResourceManager.Resources.Models.DeploymentStacksDeleteDetachEnum left, Azure.ResourceManager.Resources.Models.DeploymentStacksDeleteDetachEnum right) { throw null; } + public static implicit operator Azure.ResourceManager.Resources.Models.DeploymentStacksDeleteDetachEnum (string value) { throw null; } + public static bool operator !=(Azure.ResourceManager.Resources.Models.DeploymentStacksDeleteDetachEnum left, Azure.ResourceManager.Resources.Models.DeploymentStacksDeleteDetachEnum right) { throw null; } + public override string ToString() { throw null; } + } + public partial class DeploymentStacksParametersLink : System.ClientModel.Primitives.IJsonModel, System.ClientModel.Primitives.IPersistableModel + { + public DeploymentStacksParametersLink(System.Uri uri) { } + public string ContentVersion { get { throw null; } set { } } + public System.Uri Uri { get { throw null; } set { } } + Azure.ResourceManager.Resources.Models.DeploymentStacksParametersLink System.ClientModel.Primitives.IJsonModel.Create(ref System.Text.Json.Utf8JsonReader reader, System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + void System.ClientModel.Primitives.IJsonModel.Write(System.Text.Json.Utf8JsonWriter writer, System.ClientModel.Primitives.ModelReaderWriterOptions options) { } + Azure.ResourceManager.Resources.Models.DeploymentStacksParametersLink System.ClientModel.Primitives.IPersistableModel.Create(System.BinaryData data, System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + string System.ClientModel.Primitives.IPersistableModel.GetFormatFromOptions(System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + System.BinaryData System.ClientModel.Primitives.IPersistableModel.Write(System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + } + public partial class DeploymentStacksTemplateLink : System.ClientModel.Primitives.IJsonModel, System.ClientModel.Primitives.IPersistableModel + { + public DeploymentStacksTemplateLink() { } + public string ContentVersion { get { throw null; } set { } } + public string Id { get { throw null; } set { } } + public string QueryString { get { throw null; } set { } } + public string RelativePath { get { throw null; } set { } } + public System.Uri Uri { get { throw null; } set { } } + Azure.ResourceManager.Resources.Models.DeploymentStacksTemplateLink System.ClientModel.Primitives.IJsonModel.Create(ref System.Text.Json.Utf8JsonReader reader, System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + void System.ClientModel.Primitives.IJsonModel.Write(System.Text.Json.Utf8JsonWriter writer, System.ClientModel.Primitives.ModelReaderWriterOptions options) { } + Azure.ResourceManager.Resources.Models.DeploymentStacksTemplateLink System.ClientModel.Primitives.IPersistableModel.Create(System.BinaryData data, System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + string System.ClientModel.Primitives.IPersistableModel.GetFormatFromOptions(System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + System.BinaryData System.ClientModel.Primitives.IPersistableModel.Write(System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + } + public partial class DeploymentStackTemplateDefinition : System.ClientModel.Primitives.IJsonModel, System.ClientModel.Primitives.IPersistableModel + { + internal DeploymentStackTemplateDefinition() { } + public System.BinaryData Template { get { throw null; } } + public Azure.ResourceManager.Resources.Models.DeploymentStacksTemplateLink TemplateLink { get { throw null; } } + Azure.ResourceManager.Resources.Models.DeploymentStackTemplateDefinition System.ClientModel.Primitives.IJsonModel.Create(ref System.Text.Json.Utf8JsonReader reader, System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + void System.ClientModel.Primitives.IJsonModel.Write(System.Text.Json.Utf8JsonWriter writer, System.ClientModel.Primitives.ModelReaderWriterOptions options) { } + Azure.ResourceManager.Resources.Models.DeploymentStackTemplateDefinition System.ClientModel.Primitives.IPersistableModel.Create(System.BinaryData data, System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + string System.ClientModel.Primitives.IPersistableModel.GetFormatFromOptions(System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + System.BinaryData System.ClientModel.Primitives.IPersistableModel.Write(System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + } + public partial class DeploymentStackValidateProperties : System.ClientModel.Primitives.IJsonModel, System.ClientModel.Primitives.IPersistableModel + { + public DeploymentStackValidateProperties() { } + public Azure.ResourceManager.Resources.Models.ActionOnUnmanage ActionOnUnmanage { get { throw null; } set { } } + public string CorrelationId { get { throw null; } set { } } + public Azure.ResourceManager.Resources.Models.DenySettings DenySettings { get { throw null; } set { } } + public string DeploymentScope { get { throw null; } set { } } + public string Description { get { throw null; } set { } } + public System.Collections.Generic.IDictionary Parameters { get { throw null; } } + public Azure.ResourceManager.Resources.Models.DeploymentStacksTemplateLink TemplateLink { get { throw null; } set { } } + public System.Collections.Generic.IList ValidatedResources { get { throw null; } } + Azure.ResourceManager.Resources.Models.DeploymentStackValidateProperties System.ClientModel.Primitives.IJsonModel.Create(ref System.Text.Json.Utf8JsonReader reader, System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + void System.ClientModel.Primitives.IJsonModel.Write(System.Text.Json.Utf8JsonWriter writer, System.ClientModel.Primitives.ModelReaderWriterOptions options) { } + Azure.ResourceManager.Resources.Models.DeploymentStackValidateProperties System.ClientModel.Primitives.IPersistableModel.Create(System.BinaryData data, System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + string System.ClientModel.Primitives.IPersistableModel.GetFormatFromOptions(System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + System.BinaryData System.ClientModel.Primitives.IPersistableModel.Write(System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + } + public partial class DeploymentStackValidateResult : Azure.ResourceManager.Models.ResourceData, System.ClientModel.Primitives.IJsonModel, System.ClientModel.Primitives.IPersistableModel + { + public DeploymentStackValidateResult() { } + public Azure.ResponseError Error { get { throw null; } set { } } + public Azure.ResourceManager.Resources.Models.DeploymentStackValidateProperties Properties { get { throw null; } set { } } + Azure.ResourceManager.Resources.Models.DeploymentStackValidateResult System.ClientModel.Primitives.IJsonModel.Create(ref System.Text.Json.Utf8JsonReader reader, System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + void System.ClientModel.Primitives.IJsonModel.Write(System.Text.Json.Utf8JsonWriter writer, System.ClientModel.Primitives.ModelReaderWriterOptions options) { } + Azure.ResourceManager.Resources.Models.DeploymentStackValidateResult System.ClientModel.Primitives.IPersistableModel.Create(System.BinaryData data, System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + string System.ClientModel.Primitives.IPersistableModel.GetFormatFromOptions(System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + System.BinaryData System.ClientModel.Primitives.IPersistableModel.Write(System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + } public partial class ErrorDeployment : System.ClientModel.Primitives.IJsonModel, System.ClientModel.Primitives.IPersistableModel { public ErrorDeployment() { } @@ -1400,6 +1690,18 @@ public JitSchedulingPolicy(Azure.ResourceManager.Resources.Models.JitSchedulingT public static bool operator !=(Azure.ResourceManager.Resources.Models.JitSchedulingType left, Azure.ResourceManager.Resources.Models.JitSchedulingType right) { throw null; } public override string ToString() { throw null; } } + public partial class KeyVaultParameterReference : System.ClientModel.Primitives.IJsonModel, System.ClientModel.Primitives.IPersistableModel + { + public KeyVaultParameterReference(Azure.ResourceManager.Resources.Models.WritableSubResource keyVault, string secretName) { } + public Azure.Core.ResourceIdentifier KeyVaultId { get { throw null; } set { } } + public string SecretName { get { throw null; } set { } } + public string SecretVersion { get { throw null; } set { } } + Azure.ResourceManager.Resources.Models.KeyVaultParameterReference System.ClientModel.Primitives.IJsonModel.Create(ref System.Text.Json.Utf8JsonReader reader, System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + void System.ClientModel.Primitives.IJsonModel.Write(System.Text.Json.Utf8JsonWriter writer, System.ClientModel.Primitives.ModelReaderWriterOptions options) { } + Azure.ResourceManager.Resources.Models.KeyVaultParameterReference System.ClientModel.Primitives.IPersistableModel.Create(System.BinaryData data, System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + string System.ClientModel.Primitives.IPersistableModel.GetFormatFromOptions(System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + System.BinaryData System.ClientModel.Primitives.IPersistableModel.Write(System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + } public partial class LinkedTemplateArtifact : System.ClientModel.Primitives.IJsonModel, System.ClientModel.Primitives.IPersistableModel { public LinkedTemplateArtifact(string path, System.BinaryData template) { } @@ -1411,6 +1713,17 @@ public LinkedTemplateArtifact(string path, System.BinaryData template) { } string System.ClientModel.Primitives.IPersistableModel.GetFormatFromOptions(System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } System.BinaryData System.ClientModel.Primitives.IPersistableModel.Write(System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } } + public partial class ManagedResourceReference : Azure.ResourceManager.Resources.Models.ResourceReferenceAutoGenerated, System.ClientModel.Primitives.IJsonModel, System.ClientModel.Primitives.IPersistableModel + { + public ManagedResourceReference() { } + public Azure.ResourceManager.Resources.Models.DenyStatusMode? DenyStatus { get { throw null; } set { } } + public Azure.ResourceManager.Resources.Models.ResourceStatusMode? Status { get { throw null; } set { } } + Azure.ResourceManager.Resources.Models.ManagedResourceReference System.ClientModel.Primitives.IJsonModel.Create(ref System.Text.Json.Utf8JsonReader reader, System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + void System.ClientModel.Primitives.IJsonModel.Write(System.Text.Json.Utf8JsonWriter writer, System.ClientModel.Primitives.ModelReaderWriterOptions options) { } + Azure.ResourceManager.Resources.Models.ManagedResourceReference System.ClientModel.Primitives.IPersistableModel.Create(System.BinaryData data, System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + string System.ClientModel.Primitives.IPersistableModel.GetFormatFromOptions(System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + System.BinaryData System.ClientModel.Primitives.IPersistableModel.Write(System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + } public enum ProvisioningOperationKind { NotSpecified = 0, @@ -1424,6 +1737,26 @@ public enum ProvisioningOperationKind EvaluateDeploymentOutput = 8, DeploymentCleanup = 9, } + public partial class ResourceReferenceAutoGenerated : System.ClientModel.Primitives.IJsonModel, System.ClientModel.Primitives.IPersistableModel + { + public ResourceReferenceAutoGenerated() { } + public string Id { get { throw null; } } + Azure.ResourceManager.Resources.Models.ResourceReferenceAutoGenerated System.ClientModel.Primitives.IJsonModel.Create(ref System.Text.Json.Utf8JsonReader reader, System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + void System.ClientModel.Primitives.IJsonModel.Write(System.Text.Json.Utf8JsonWriter writer, System.ClientModel.Primitives.ModelReaderWriterOptions options) { } + Azure.ResourceManager.Resources.Models.ResourceReferenceAutoGenerated System.ClientModel.Primitives.IPersistableModel.Create(System.BinaryData data, System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + string System.ClientModel.Primitives.IPersistableModel.GetFormatFromOptions(System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + System.BinaryData System.ClientModel.Primitives.IPersistableModel.Write(System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + } + public partial class ResourceReferenceExtended : Azure.ResourceManager.Resources.Models.ResourceReferenceAutoGenerated, System.ClientModel.Primitives.IJsonModel, System.ClientModel.Primitives.IPersistableModel + { + public ResourceReferenceExtended() { } + public Azure.ResponseError Error { get { throw null; } set { } } + Azure.ResourceManager.Resources.Models.ResourceReferenceExtended System.ClientModel.Primitives.IJsonModel.Create(ref System.Text.Json.Utf8JsonReader reader, System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + void System.ClientModel.Primitives.IJsonModel.Write(System.Text.Json.Utf8JsonWriter writer, System.ClientModel.Primitives.ModelReaderWriterOptions options) { } + Azure.ResourceManager.Resources.Models.ResourceReferenceExtended System.ClientModel.Primitives.IPersistableModel.Create(System.BinaryData data, System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + string System.ClientModel.Primitives.IPersistableModel.GetFormatFromOptions(System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + System.BinaryData System.ClientModel.Primitives.IPersistableModel.Write(System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } + } [System.Runtime.InteropServices.StructLayoutAttribute(System.Runtime.InteropServices.LayoutKind.Sequential)] public readonly partial struct ResourcesProvisioningState : System.IEquatable { @@ -1453,6 +1786,25 @@ public enum ProvisioningOperationKind public override string ToString() { throw null; } } [System.Runtime.InteropServices.StructLayoutAttribute(System.Runtime.InteropServices.LayoutKind.Sequential)] + public readonly partial struct ResourceStatusMode : System.IEquatable + { + private readonly object _dummy; + private readonly int _dummyPrimitive; + public ResourceStatusMode(string value) { throw null; } + public static Azure.ResourceManager.Resources.Models.ResourceStatusMode DeleteFailed { get { throw null; } } + public static Azure.ResourceManager.Resources.Models.ResourceStatusMode Managed { get { throw null; } } + public static Azure.ResourceManager.Resources.Models.ResourceStatusMode RemoveDenyFailed { get { throw null; } } + public bool Equals(Azure.ResourceManager.Resources.Models.ResourceStatusMode other) { throw null; } + [System.ComponentModel.EditorBrowsableAttribute(System.ComponentModel.EditorBrowsableState.Never)] + public override bool Equals(object obj) { throw null; } + [System.ComponentModel.EditorBrowsableAttribute(System.ComponentModel.EditorBrowsableState.Never)] + public override int GetHashCode() { throw null; } + public static bool operator ==(Azure.ResourceManager.Resources.Models.ResourceStatusMode left, Azure.ResourceManager.Resources.Models.ResourceStatusMode right) { throw null; } + public static implicit operator Azure.ResourceManager.Resources.Models.ResourceStatusMode (string value) { throw null; } + public static bool operator !=(Azure.ResourceManager.Resources.Models.ResourceStatusMode left, Azure.ResourceManager.Resources.Models.ResourceStatusMode right) { throw null; } + public override string ToString() { throw null; } + } + [System.Runtime.InteropServices.StructLayoutAttribute(System.Runtime.InteropServices.LayoutKind.Sequential)] public readonly partial struct ScriptCleanupOptions : System.IEquatable { private readonly object _dummy; @@ -1616,6 +1968,60 @@ public TemplateSpecVersionPatch() { } string System.ClientModel.Primitives.IPersistableModel.GetFormatFromOptions(System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } System.BinaryData System.ClientModel.Primitives.IPersistableModel.Write(System.ClientModel.Primitives.ModelReaderWriterOptions options) { throw null; } } + [System.Runtime.InteropServices.StructLayoutAttribute(System.Runtime.InteropServices.LayoutKind.Sequential)] + public readonly partial struct UnmanageActionManagementGroupMode : System.IEquatable + { + private readonly object _dummy; + private readonly int _dummyPrimitive; + public UnmanageActionManagementGroupMode(string value) { throw null; } + public static Azure.ResourceManager.Resources.Models.UnmanageActionManagementGroupMode Delete { get { throw null; } } + public static Azure.ResourceManager.Resources.Models.UnmanageActionManagementGroupMode Detach { get { throw null; } } + public bool Equals(Azure.ResourceManager.Resources.Models.UnmanageActionManagementGroupMode other) { throw null; } + [System.ComponentModel.EditorBrowsableAttribute(System.ComponentModel.EditorBrowsableState.Never)] + public override bool Equals(object obj) { throw null; } + [System.ComponentModel.EditorBrowsableAttribute(System.ComponentModel.EditorBrowsableState.Never)] + public override int GetHashCode() { throw null; } + public static bool operator ==(Azure.ResourceManager.Resources.Models.UnmanageActionManagementGroupMode left, Azure.ResourceManager.Resources.Models.UnmanageActionManagementGroupMode right) { throw null; } + public static implicit operator Azure.ResourceManager.Resources.Models.UnmanageActionManagementGroupMode (string value) { throw null; } + public static bool operator !=(Azure.ResourceManager.Resources.Models.UnmanageActionManagementGroupMode left, Azure.ResourceManager.Resources.Models.UnmanageActionManagementGroupMode right) { throw null; } + public override string ToString() { throw null; } + } + [System.Runtime.InteropServices.StructLayoutAttribute(System.Runtime.InteropServices.LayoutKind.Sequential)] + public readonly partial struct UnmanageActionResourceGroupMode : System.IEquatable + { + private readonly object _dummy; + private readonly int _dummyPrimitive; + public UnmanageActionResourceGroupMode(string value) { throw null; } + public static Azure.ResourceManager.Resources.Models.UnmanageActionResourceGroupMode Delete { get { throw null; } } + public static Azure.ResourceManager.Resources.Models.UnmanageActionResourceGroupMode Detach { get { throw null; } } + public bool Equals(Azure.ResourceManager.Resources.Models.UnmanageActionResourceGroupMode other) { throw null; } + [System.ComponentModel.EditorBrowsableAttribute(System.ComponentModel.EditorBrowsableState.Never)] + public override bool Equals(object obj) { throw null; } + [System.ComponentModel.EditorBrowsableAttribute(System.ComponentModel.EditorBrowsableState.Never)] + public override int GetHashCode() { throw null; } + public static bool operator ==(Azure.ResourceManager.Resources.Models.UnmanageActionResourceGroupMode left, Azure.ResourceManager.Resources.Models.UnmanageActionResourceGroupMode right) { throw null; } + public static implicit operator Azure.ResourceManager.Resources.Models.UnmanageActionResourceGroupMode (string value) { throw null; } + public static bool operator !=(Azure.ResourceManager.Resources.Models.UnmanageActionResourceGroupMode left, Azure.ResourceManager.Resources.Models.UnmanageActionResourceGroupMode right) { throw null; } + public override string ToString() { throw null; } + } + [System.Runtime.InteropServices.StructLayoutAttribute(System.Runtime.InteropServices.LayoutKind.Sequential)] + public readonly partial struct UnmanageActionResourceMode : System.IEquatable + { + private readonly object _dummy; + private readonly int _dummyPrimitive; + public UnmanageActionResourceMode(string value) { throw null; } + public static Azure.ResourceManager.Resources.Models.UnmanageActionResourceMode Delete { get { throw null; } } + public static Azure.ResourceManager.Resources.Models.UnmanageActionResourceMode Detach { get { throw null; } } + public bool Equals(Azure.ResourceManager.Resources.Models.UnmanageActionResourceMode other) { throw null; } + [System.ComponentModel.EditorBrowsableAttribute(System.ComponentModel.EditorBrowsableState.Never)] + public override bool Equals(object obj) { throw null; } + [System.ComponentModel.EditorBrowsableAttribute(System.ComponentModel.EditorBrowsableState.Never)] + public override int GetHashCode() { throw null; } + public static bool operator ==(Azure.ResourceManager.Resources.Models.UnmanageActionResourceMode left, Azure.ResourceManager.Resources.Models.UnmanageActionResourceMode right) { throw null; } + public static implicit operator Azure.ResourceManager.Resources.Models.UnmanageActionResourceMode (string value) { throw null; } + public static bool operator !=(Azure.ResourceManager.Resources.Models.UnmanageActionResourceMode left, Azure.ResourceManager.Resources.Models.UnmanageActionResourceMode right) { throw null; } + public override string ToString() { throw null; } + } public partial class WhatIfChange : System.ClientModel.Primitives.IJsonModel, System.ClientModel.Primitives.IPersistableModel { internal WhatIfChange() { } diff --git a/sdk/resources/Azure.ResourceManager.Resources/assets.json b/sdk/resources/Azure.ResourceManager.Resources/assets.json index 3b0250ff92d65..a5a3e921d094b 100644 --- a/sdk/resources/Azure.ResourceManager.Resources/assets.json +++ b/sdk/resources/Azure.ResourceManager.Resources/assets.json @@ -2,5 +2,5 @@ "AssetsRepo": "Azure/azure-sdk-assets", "AssetsRepoPrefixPath": "net", "TagPrefix": "net/resources/Azure.ResourceManager.Resources", - "Tag": "net/resources/Azure.ResourceManager.Resources_fefa73f2c4" + "Tag": "net/resources/Azure.ResourceManager.Resources_b91d977a7f" } diff --git a/sdk/resources/Azure.ResourceManager.Resources/samples/Generated/Samples/Sample_ArmDeploymentCollection.cs b/sdk/resources/Azure.ResourceManager.Resources/samples/Generated/Samples/Sample_ArmDeploymentCollection.cs index ce51954e5df6c..7825e52a8fa33 100644 --- a/sdk/resources/Azure.ResourceManager.Resources/samples/Generated/Samples/Sample_ArmDeploymentCollection.cs +++ b/sdk/resources/Azure.ResourceManager.Resources/samples/Generated/Samples/Sample_ArmDeploymentCollection.cs @@ -21,7 +21,7 @@ public partial class Sample_ArmDeploymentCollection [NUnit.Framework.Ignore("Only verifying that the sample builds")] public async Task CreateOrUpdate_CreateDeploymentAtAGivenScope() { - // Generated from example definition: specification/resources/resource-manager/Microsoft.Resources/stable/2022-09-01/examples/PutDeploymentAtScope.json + // Generated from example definition: specification/resources/resource-manager/Microsoft.Resources/stable/2024-03-01/examples/PutDeploymentAtScope.json // this example is just showing the usage of "Deployments_CreateOrUpdateAtScope" operation, for the dependent resources, they will have to be created separately. // get your azure access token, for more details of how Azure SDK get your access token, please refer to https://learn.microsoft.com/en-us/dotnet/azure/sdk/authentication?tabs=command-line diff --git a/sdk/resources/Azure.ResourceManager.Resources/samples/Generated/Samples/Sample_ArmDeploymentResource.cs b/sdk/resources/Azure.ResourceManager.Resources/samples/Generated/Samples/Sample_ArmDeploymentResource.cs index f31af4caffde5..c98a85fb53476 100644 --- a/sdk/resources/Azure.ResourceManager.Resources/samples/Generated/Samples/Sample_ArmDeploymentResource.cs +++ b/sdk/resources/Azure.ResourceManager.Resources/samples/Generated/Samples/Sample_ArmDeploymentResource.cs @@ -21,7 +21,7 @@ public partial class Sample_ArmDeploymentResource [NUnit.Framework.Ignore("Only verifying that the sample builds")] public async Task Update_CreateDeploymentAtAGivenScope() { - // Generated from example definition: specification/resources/resource-manager/Microsoft.Resources/stable/2022-09-01/examples/PutDeploymentAtScope.json + // Generated from example definition: specification/resources/resource-manager/Microsoft.Resources/stable/2024-03-01/examples/PutDeploymentAtScope.json // this example is just showing the usage of "Deployments_CreateOrUpdateAtScope" operation, for the dependent resources, they will have to be created separately. // get your azure access token, for more details of how Azure SDK get your access token, please refer to https://learn.microsoft.com/en-us/dotnet/azure/sdk/authentication?tabs=command-line @@ -70,7 +70,7 @@ public async Task Update_CreateDeploymentAtAGivenScope() [NUnit.Framework.Ignore("Only verifying that the sample builds")] public async Task WhatIf_PredictTemplateChangesAtManagementGroupScope() { - // Generated from example definition: specification/resources/resource-manager/Microsoft.Resources/stable/2022-09-01/examples/PostDeploymentWhatIfOnTenant.json + // Generated from example definition: specification/resources/resource-manager/Microsoft.Resources/stable/2024-03-01/examples/PostDeploymentWhatIfOnTenant.json // this example is just showing the usage of "Deployments_WhatIfAtTenantScope" operation, for the dependent resources, they will have to be created separately. // get your azure access token, for more details of how Azure SDK get your access token, please refer to https://learn.microsoft.com/en-us/dotnet/azure/sdk/authentication?tabs=command-line @@ -110,7 +110,7 @@ public async Task WhatIf_PredictTemplateChangesAtManagementGroupScope() [NUnit.Framework.Ignore("Only verifying that the sample builds")] public async Task WhatIf_PredictTemplateChangesAtManagementGroupScope1() { - // Generated from example definition: specification/resources/resource-manager/Microsoft.Resources/stable/2022-09-01/examples/PostDeploymentWhatIfOnManagementGroup.json + // Generated from example definition: specification/resources/resource-manager/Microsoft.Resources/stable/2024-03-01/examples/PostDeploymentWhatIfOnManagementGroup.json // this example is just showing the usage of "Deployments_WhatIfAtManagementGroupScope" operation, for the dependent resources, they will have to be created separately. // get your azure access token, for more details of how Azure SDK get your access token, please refer to https://learn.microsoft.com/en-us/dotnet/azure/sdk/authentication?tabs=command-line @@ -151,7 +151,7 @@ public async Task WhatIf_PredictTemplateChangesAtManagementGroupScope1() [NUnit.Framework.Ignore("Only verifying that the sample builds")] public async Task WhatIf_PredictTemplateChangesAtSubscriptionScope() { - // Generated from example definition: specification/resources/resource-manager/Microsoft.Resources/stable/2022-09-01/examples/PostDeploymentWhatIfOnSubscription.json + // Generated from example definition: specification/resources/resource-manager/Microsoft.Resources/stable/2024-03-01/examples/PostDeploymentWhatIfOnSubscription.json // this example is just showing the usage of "Deployments_WhatIfAtSubscriptionScope" operation, for the dependent resources, they will have to be created separately. // get your azure access token, for more details of how Azure SDK get your access token, please refer to https://learn.microsoft.com/en-us/dotnet/azure/sdk/authentication?tabs=command-line @@ -192,7 +192,7 @@ public async Task WhatIf_PredictTemplateChangesAtSubscriptionScope() [NUnit.Framework.Ignore("Only verifying that the sample builds")] public async Task WhatIf_PredictTemplateChangesAtResourceGroupScope() { - // Generated from example definition: specification/resources/resource-manager/Microsoft.Resources/stable/2022-09-01/examples/PostDeploymentWhatIfOnResourceGroup.json + // Generated from example definition: specification/resources/resource-manager/Microsoft.Resources/stable/2024-03-01/examples/PostDeploymentWhatIfOnResourceGroup.json // this example is just showing the usage of "Deployments_WhatIf" operation, for the dependent resources, they will have to be created separately. // get your azure access token, for more details of how Azure SDK get your access token, please refer to https://learn.microsoft.com/en-us/dotnet/azure/sdk/authentication?tabs=command-line @@ -231,7 +231,7 @@ public async Task WhatIf_PredictTemplateChangesAtResourceGroupScope() [NUnit.Framework.Ignore("Only verifying that the sample builds")] public async Task CalculateDeploymentTemplateHash_CalculateTemplateHash() { - // Generated from example definition: specification/resources/resource-manager/Microsoft.Resources/stable/2022-09-01/examples/CalculateTemplateHash.json + // Generated from example definition: specification/resources/resource-manager/Microsoft.Resources/stable/2024-03-01/examples/CalculateTemplateHash.json // this example is just showing the usage of "Deployments_CalculateTemplateHash" operation, for the dependent resources, they will have to be created separately. // get your azure access token, for more details of how Azure SDK get your access token, please refer to https://learn.microsoft.com/en-us/dotnet/azure/sdk/authentication?tabs=command-line diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Azure.ResourceManager.Resources.csproj b/sdk/resources/Azure.ResourceManager.Resources/src/Azure.ResourceManager.Resources.csproj index 8820e5463fc9b..b69250ae1cbf5 100644 --- a/sdk/resources/Azure.ResourceManager.Resources/src/Azure.ResourceManager.Resources.csproj +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Azure.ResourceManager.Resources.csproj @@ -1,6 +1,6 @@ - 1.8.0-beta.1 + 1.8.0 1.7.3 Azure.ResourceManager.Resources diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Custom/DeploymentStackData.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Custom/DeploymentStackData.cs new file mode 100644 index 0000000000000..9bad31a6e1884 --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Custom/DeploymentStackData.cs @@ -0,0 +1,17 @@ +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. + +#nullable disable + +using Azure.ResourceManager.Models; + +namespace Azure.ResourceManager.Resources +{ + /// + /// A class representing the ArmDeploymentStack data model. + /// Deployment stack object. + /// + public partial class DeploymentStackData : ResourceData + { + } +} diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/ArmDeploymentCollection.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/ArmDeploymentCollection.cs index 6ba954164fc38..a52edf8589293 100644 --- a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/ArmDeploymentCollection.cs +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/ArmDeploymentCollection.cs @@ -56,7 +56,7 @@ internal ArmDeploymentCollection(ArmClient client, ResourceIdentifier id) : base /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -105,7 +105,7 @@ public virtual async Task> CreateOrUpdateAsy /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -154,7 +154,7 @@ public virtual ArmOperation CreateOrUpdate(WaitUntil wait /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -199,7 +199,7 @@ public virtual async Task> GetAsync(string deplo /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -244,7 +244,7 @@ public virtual Response Get(string deploymentName, Cancel /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -276,7 +276,7 @@ public virtual AsyncPageable GetAllAsync(string filter = /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -308,7 +308,7 @@ public virtual Pageable GetAll(string filter = null, int? /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -351,7 +351,7 @@ public virtual async Task> ExistsAsync(string deploymentName, Can /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -394,7 +394,7 @@ public virtual Response Exists(string deploymentName, CancellationToken ca /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -439,7 +439,7 @@ public virtual async Task> GetIfExistsAs /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/ArmDeploymentResource.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/ArmDeploymentResource.cs index 93954d0884de5..d9a707ff1fd5f 100644 --- a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/ArmDeploymentResource.cs +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/ArmDeploymentResource.cs @@ -107,7 +107,7 @@ internal static void ValidateResourceId(ResourceIdentifier id) /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -147,7 +147,7 @@ public virtual async Task> GetAsync(Cancellation /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -187,7 +187,7 @@ public virtual Response Get(CancellationToken cancellatio /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -229,7 +229,7 @@ public virtual async Task DeleteAsync(WaitUntil waitUntil, Cancell /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -271,7 +271,7 @@ public virtual ArmOperation Delete(WaitUntil waitUntil, CancellationToken cancel /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -317,7 +317,7 @@ public virtual async Task> UpdateAsync(WaitU /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -363,7 +363,7 @@ public virtual ArmOperation Update(WaitUntil waitUntil, A /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -401,7 +401,7 @@ public virtual async Task CancelAsync(CancellationToken cancellationTo /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -439,7 +439,7 @@ public virtual Response Cancel(CancellationToken cancellationToken = default) /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -485,7 +485,7 @@ public virtual async Task> ValidateAsy /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -531,7 +531,7 @@ public virtual ArmOperation Validate(WaitUntil wait /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -569,7 +569,7 @@ public virtual async Task> ExportTemplateAsy /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -607,7 +607,7 @@ public virtual Response ExportTemplate(CancellationTo /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -623,7 +623,7 @@ public virtual Response ExportTemplate(CancellationTo /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -639,7 +639,7 @@ public virtual Response ExportTemplate(CancellationTo /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -655,7 +655,7 @@ public virtual Response ExportTemplate(CancellationTo /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -732,7 +732,7 @@ public virtual async Task> WhatIfAsync(WaitU /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -748,7 +748,7 @@ public virtual async Task> WhatIfAsync(WaitU /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -764,7 +764,7 @@ public virtual async Task> WhatIfAsync(WaitU /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -780,7 +780,7 @@ public virtual async Task> WhatIfAsync(WaitU /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -857,7 +857,7 @@ public virtual ArmOperation WhatIf(WaitUntil waitUntil, A /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// @@ -896,7 +896,7 @@ public virtual async Task> GetDeploymentOperati /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// @@ -935,7 +935,7 @@ public virtual Response GetDeploymentOperation(string op /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// @@ -962,7 +962,7 @@ public virtual AsyncPageable GetDeploymentOperationsAsyn /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// @@ -989,7 +989,7 @@ public virtual Pageable GetDeploymentOperations(int? top /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -1027,7 +1027,7 @@ public virtual async Task CheckExistenceAsync(CancellationToken cancel /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -1065,7 +1065,7 @@ public virtual Response CheckExistence(CancellationToken cancellationToken = def /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -1127,7 +1127,7 @@ public virtual async Task> AddTagAsync(string ke /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -1189,7 +1189,7 @@ public virtual Response AddTag(string key, string value, /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -1246,7 +1246,7 @@ public virtual async Task> SetTagsAsync(IDiction /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -1303,7 +1303,7 @@ public virtual Response SetTags(IDictionary /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -1363,7 +1363,7 @@ public virtual async Task> RemoveTagAsync(string /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/ArmResourcesModelFactory.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/ArmResourcesModelFactory.cs index c65c277dbfe9a..67a07cb580496 100644 --- a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/ArmResourcesModelFactory.cs +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/ArmResourcesModelFactory.cs @@ -850,6 +850,129 @@ public static DecompiledFileDefinition DecompiledFileDefinition(string path = nu return new DecompiledFileDefinition(path, contents, serializedAdditionalRawData: null); } + /// Initializes a new instance of . + /// The template content. Use this element to pass the template syntax directly in the request rather than link to an existing template. It can be a JObject or well-formed JSON string. Use either the templateLink property or the template property, but not both. + /// The URI of the template. Use either the templateLink property or the template property, but not both. + /// A new instance for mocking. + public static DeploymentStackTemplateDefinition DeploymentStackTemplateDefinition(BinaryData template = null, DeploymentStacksTemplateLink templateLink = null) + { + return new DeploymentStackTemplateDefinition(template, templateLink, serializedAdditionalRawData: null); + } + + /// Initializes a new instance of . + /// The id. + /// The name. + /// The resourceType. + /// The systemData. + /// The location of the Deployment stack. It cannot be changed after creation. It must be one of the supported Azure locations. + /// Deployment stack resource tags. + /// The error detail. + /// The template content. You use this element when you want to pass the template syntax directly in the request rather than link to an existing template. It can be a JObject or well-formed JSON string. Use either the templateLink property or the template property, but not both. + /// The URI of the template. Use either the templateLink property or the template property, but not both. + /// Name and value pairs that define the deployment parameters for the template. Use this element when providing the parameter values directly in the request, rather than linking to an existing parameter file. Use either the parametersLink property or the parameters property, but not both. + /// The URI of parameters file. Use this element to link to an existing parameters file. Use either the parametersLink property or the parameters property, but not both. + /// Defines the behavior of resources that are no longer managed after the Deployment stack is updated or deleted. + /// The debug setting of the deployment. + /// Flag to bypass service errors that indicate the stack resource list is not correctly synchronized. + /// The scope at which the initial deployment should be created. If a scope is not specified, it will default to the scope of the deployment stack. Valid scopes are: management group (format: '/providers/Microsoft.Management/managementGroups/{managementGroupId}'), subscription (format: '/subscriptions/{subscriptionId}'), resource group (format: '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}'). + /// Deployment stack description. Max length of 4096 characters. + /// Defines how resources deployed by the stack are locked. + /// State of the deployment stack. + /// The correlation id of the last Deployment stack upsert or delete operation. It is in GUID format and is used for tracing. + /// An array of resources that were detached during the most recent Deployment stack update. Detached means that the resource was removed from the template, but no relevant deletion operations were specified. So, the resource still exists while no longer being associated with the stack. + /// An array of resources that were deleted during the most recent Deployment stack update. Deleted means that the resource was removed from the template and relevant deletion operations were specified. + /// An array of resources that failed to reach goal state during the most recent update. Each resourceId is accompanied by an error message. + /// An array of resources currently managed by the deployment stack. + /// The resourceId of the deployment resource created by the deployment stack. + /// The outputs of the deployment resource created by the deployment stack. + /// The duration of the last successful Deployment stack update. + /// A new instance for mocking. + public static DeploymentStackData DeploymentStackData(ResourceIdentifier id = null, string name = null, ResourceType resourceType = default, SystemData systemData = null, AzureLocation? location = null, IDictionary tags = null, ResponseError error = null, BinaryData template = null, DeploymentStacksTemplateLink templateLink = null, IDictionary parameters = null, DeploymentStacksParametersLink parametersLink = null, ActionOnUnmanage actionOnUnmanage = null, string debugSettingDetailLevel = null, bool? bypassStackOutOfSyncError = null, string deploymentScope = null, string description = null, DenySettings denySettings = null, DeploymentStackProvisioningState? provisioningState = null, string correlationId = null, IEnumerable detachedResources = null, IEnumerable deletedResources = null, IEnumerable failedResources = null, IEnumerable resources = null, string deploymentId = null, BinaryData outputs = null, TimeSpan? duration = null) + { + tags ??= new Dictionary(); + parameters ??= new Dictionary(); + detachedResources ??= new List(); + deletedResources ??= new List(); + failedResources ??= new List(); + resources ??= new List(); + + return new DeploymentStackData( + id, + name, + resourceType, + systemData, + location, + tags, + error, + template, + templateLink, + parameters, + parametersLink, + actionOnUnmanage, + debugSettingDetailLevel != null ? new DeploymentStacksDebugSetting(debugSettingDetailLevel, serializedAdditionalRawData: null) : null, + bypassStackOutOfSyncError, + deploymentScope, + description, + denySettings, + provisioningState, + correlationId, + detachedResources?.ToList(), + deletedResources?.ToList(), + failedResources?.ToList(), + resources?.ToList(), + deploymentId, + outputs, + duration, + serializedAdditionalRawData: null); + } + + /// Initializes a new instance of . + /// The resourceId of a resource managed by the deployment stack. + /// A new instance for mocking. + public static ResourceReferenceAutoGenerated ResourceReferenceAutoGenerated(string id = null) + { + return new ResourceReferenceAutoGenerated(id, serializedAdditionalRawData: null); + } + + /// Initializes a new instance of . + /// The resourceId of a resource managed by the deployment stack. + /// The error detail. + /// A new instance for mocking. + public static ResourceReferenceExtended ResourceReferenceExtended(string id = null, ResponseError error = null) + { + return new ResourceReferenceExtended(id, serializedAdditionalRawData: null, error); + } + + /// Initializes a new instance of . + /// The resourceId of a resource managed by the deployment stack. + /// Current management state of the resource in the deployment stack. + /// denyAssignment settings applied to the resource. + /// A new instance for mocking. + public static ManagedResourceReference ManagedResourceReference(string id = null, ResourceStatusMode? status = null, DenyStatusMode? denyStatus = null) + { + return new ManagedResourceReference(id, serializedAdditionalRawData: null, status, denyStatus); + } + + /// Initializes a new instance of . + /// The id. + /// The name. + /// The resourceType. + /// The systemData. + /// The validation result details. + /// The error detail. + /// A new instance for mocking. + public static DeploymentStackValidateResult DeploymentStackValidateResult(ResourceIdentifier id = null, string name = null, ResourceType resourceType = default, SystemData systemData = null, DeploymentStackValidateProperties properties = null, ResponseError error = null) + { + return new DeploymentStackValidateResult( + id, + name, + resourceType, + systemData, + properties, + error, + serializedAdditionalRawData: null); + } + /// Initializes a new instance of . /// The id. /// The name. diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/DeploymentStackCollection.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/DeploymentStackCollection.cs new file mode 100644 index 0000000000000..df33115caa974 --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/DeploymentStackCollection.cs @@ -0,0 +1,484 @@ +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. + +// + +#nullable disable + +using System; +using System.Collections; +using System.Collections.Generic; +using System.Threading; +using System.Threading.Tasks; +using Autorest.CSharp.Core; +using Azure.Core; +using Azure.Core.Pipeline; +using Azure.ResourceManager.ManagementGroups; + +namespace Azure.ResourceManager.Resources +{ + /// + /// A class representing a collection of and their operations. + /// Each in the collection will belong to the same instance of , or . + /// To get a instance call the GetDeploymentStacks method from an instance of , or . + /// + public partial class DeploymentStackCollection : ArmCollection, IEnumerable, IAsyncEnumerable + { + private readonly ClientDiagnostics _deploymentStackClientDiagnostics; + private readonly DeploymentStacksRestOperations _deploymentStackRestClient; + + /// Initializes a new instance of the class for mocking. + protected DeploymentStackCollection() + { + } + + /// Initializes a new instance of the class. + /// The client parameters to use in these operations. + /// The identifier of the parent resource that is the target of operations. + internal DeploymentStackCollection(ArmClient client, ResourceIdentifier id) : base(client, id) + { + _deploymentStackClientDiagnostics = new ClientDiagnostics("Azure.ResourceManager.Resources", DeploymentStackResource.ResourceType.Namespace, Diagnostics); + TryGetApiVersion(DeploymentStackResource.ResourceType, out string deploymentStackApiVersion); + _deploymentStackRestClient = new DeploymentStacksRestOperations(Pipeline, Diagnostics.ApplicationId, Endpoint, deploymentStackApiVersion); + } + + /// + /// Creates or updates a Deployment stack at specific scope. + /// + /// + /// Request Path + /// /{scope}/providers/Microsoft.Resources/deploymentStacks/{deploymentStackName} + /// + /// + /// Operation Id + /// DeploymentStacks_CreateOrUpdateAtScope + /// + /// + /// Default Api Version + /// 2024-03-01 + /// + /// + /// Resource + /// + /// + /// + /// + /// if the method should wait to return until the long-running operation has completed on the service; if it should return after starting the operation. For more information on long-running operations, please see Azure.Core Long-Running Operation samples. + /// Name of the deployment stack. + /// Deployment stack supplied to the operation. + /// The cancellation token to use. + /// is an empty string, and was expected to be non-empty. + /// or is null. + public virtual async Task> CreateOrUpdateAsync(WaitUntil waitUntil, string deploymentStackName, DeploymentStackData data, CancellationToken cancellationToken = default) + { + Argument.AssertNotNullOrEmpty(deploymentStackName, nameof(deploymentStackName)); + Argument.AssertNotNull(data, nameof(data)); + + using var scope = _deploymentStackClientDiagnostics.CreateScope("DeploymentStackCollection.CreateOrUpdate"); + scope.Start(); + try + { + var response = await _deploymentStackRestClient.CreateOrUpdateAtScopeAsync(Id, deploymentStackName, data, cancellationToken).ConfigureAwait(false); + var operation = new ResourcesArmOperation(new DeploymentStackOperationSource(Client), _deploymentStackClientDiagnostics, Pipeline, _deploymentStackRestClient.CreateCreateOrUpdateAtScopeRequest(Id, deploymentStackName, data).Request, response, OperationFinalStateVia.AzureAsyncOperation); + if (waitUntil == WaitUntil.Completed) + await operation.WaitForCompletionAsync(cancellationToken).ConfigureAwait(false); + return operation; + } + catch (Exception e) + { + scope.Failed(e); + throw; + } + } + + /// + /// Creates or updates a Deployment stack at specific scope. + /// + /// + /// Request Path + /// /{scope}/providers/Microsoft.Resources/deploymentStacks/{deploymentStackName} + /// + /// + /// Operation Id + /// DeploymentStacks_CreateOrUpdateAtScope + /// + /// + /// Default Api Version + /// 2024-03-01 + /// + /// + /// Resource + /// + /// + /// + /// + /// if the method should wait to return until the long-running operation has completed on the service; if it should return after starting the operation. For more information on long-running operations, please see Azure.Core Long-Running Operation samples. + /// Name of the deployment stack. + /// Deployment stack supplied to the operation. + /// The cancellation token to use. + /// is an empty string, and was expected to be non-empty. + /// or is null. + public virtual ArmOperation CreateOrUpdate(WaitUntil waitUntil, string deploymentStackName, DeploymentStackData data, CancellationToken cancellationToken = default) + { + Argument.AssertNotNullOrEmpty(deploymentStackName, nameof(deploymentStackName)); + Argument.AssertNotNull(data, nameof(data)); + + using var scope = _deploymentStackClientDiagnostics.CreateScope("DeploymentStackCollection.CreateOrUpdate"); + scope.Start(); + try + { + var response = _deploymentStackRestClient.CreateOrUpdateAtScope(Id, deploymentStackName, data, cancellationToken); + var operation = new ResourcesArmOperation(new DeploymentStackOperationSource(Client), _deploymentStackClientDiagnostics, Pipeline, _deploymentStackRestClient.CreateCreateOrUpdateAtScopeRequest(Id, deploymentStackName, data).Request, response, OperationFinalStateVia.AzureAsyncOperation); + if (waitUntil == WaitUntil.Completed) + operation.WaitForCompletion(cancellationToken); + return operation; + } + catch (Exception e) + { + scope.Failed(e); + throw; + } + } + + /// + /// Gets a Deployment stack with a given name at specific scope. + /// + /// + /// Request Path + /// /{scope}/providers/Microsoft.Resources/deploymentStacks/{deploymentStackName} + /// + /// + /// Operation Id + /// DeploymentStacks_GetAtScope + /// + /// + /// Default Api Version + /// 2024-03-01 + /// + /// + /// Resource + /// + /// + /// + /// + /// Name of the deployment stack. + /// The cancellation token to use. + /// is an empty string, and was expected to be non-empty. + /// is null. + public virtual async Task> GetAsync(string deploymentStackName, CancellationToken cancellationToken = default) + { + Argument.AssertNotNullOrEmpty(deploymentStackName, nameof(deploymentStackName)); + + using var scope = _deploymentStackClientDiagnostics.CreateScope("DeploymentStackCollection.Get"); + scope.Start(); + try + { + var response = await _deploymentStackRestClient.GetAtScopeAsync(Id, deploymentStackName, cancellationToken).ConfigureAwait(false); + if (response.Value == null) + throw new RequestFailedException(response.GetRawResponse()); + return Response.FromValue(new DeploymentStackResource(Client, response.Value), response.GetRawResponse()); + } + catch (Exception e) + { + scope.Failed(e); + throw; + } + } + + /// + /// Gets a Deployment stack with a given name at specific scope. + /// + /// + /// Request Path + /// /{scope}/providers/Microsoft.Resources/deploymentStacks/{deploymentStackName} + /// + /// + /// Operation Id + /// DeploymentStacks_GetAtScope + /// + /// + /// Default Api Version + /// 2024-03-01 + /// + /// + /// Resource + /// + /// + /// + /// + /// Name of the deployment stack. + /// The cancellation token to use. + /// is an empty string, and was expected to be non-empty. + /// is null. + public virtual Response Get(string deploymentStackName, CancellationToken cancellationToken = default) + { + Argument.AssertNotNullOrEmpty(deploymentStackName, nameof(deploymentStackName)); + + using var scope = _deploymentStackClientDiagnostics.CreateScope("DeploymentStackCollection.Get"); + scope.Start(); + try + { + var response = _deploymentStackRestClient.GetAtScope(Id, deploymentStackName, cancellationToken); + if (response.Value == null) + throw new RequestFailedException(response.GetRawResponse()); + return Response.FromValue(new DeploymentStackResource(Client, response.Value), response.GetRawResponse()); + } + catch (Exception e) + { + scope.Failed(e); + throw; + } + } + + /// + /// Lists all the Deployment stacks within the specified scope. + /// + /// + /// Request Path + /// /{scope}/providers/Microsoft.Resources/deploymentStacks + /// + /// + /// Operation Id + /// DeploymentStacks_ListAtScope + /// + /// + /// Default Api Version + /// 2024-03-01 + /// + /// + /// Resource + /// + /// + /// + /// + /// The cancellation token to use. + /// An async collection of that may take multiple service requests to iterate over. + public virtual AsyncPageable GetAllAsync(CancellationToken cancellationToken = default) + { + HttpMessage FirstPageRequest(int? pageSizeHint) => _deploymentStackRestClient.CreateListAtScopeRequest(Id); + HttpMessage NextPageRequest(int? pageSizeHint, string nextLink) => _deploymentStackRestClient.CreateListAtScopeNextPageRequest(nextLink, Id); + return GeneratorPageableHelpers.CreateAsyncPageable(FirstPageRequest, NextPageRequest, e => new DeploymentStackResource(Client, DeploymentStackData.DeserializeDeploymentStackData(e)), _deploymentStackClientDiagnostics, Pipeline, "DeploymentStackCollection.GetAll", "value", "nextLink", cancellationToken); + } + + /// + /// Lists all the Deployment stacks within the specified scope. + /// + /// + /// Request Path + /// /{scope}/providers/Microsoft.Resources/deploymentStacks + /// + /// + /// Operation Id + /// DeploymentStacks_ListAtScope + /// + /// + /// Default Api Version + /// 2024-03-01 + /// + /// + /// Resource + /// + /// + /// + /// + /// The cancellation token to use. + /// A collection of that may take multiple service requests to iterate over. + public virtual Pageable GetAll(CancellationToken cancellationToken = default) + { + HttpMessage FirstPageRequest(int? pageSizeHint) => _deploymentStackRestClient.CreateListAtScopeRequest(Id); + HttpMessage NextPageRequest(int? pageSizeHint, string nextLink) => _deploymentStackRestClient.CreateListAtScopeNextPageRequest(nextLink, Id); + return GeneratorPageableHelpers.CreatePageable(FirstPageRequest, NextPageRequest, e => new DeploymentStackResource(Client, DeploymentStackData.DeserializeDeploymentStackData(e)), _deploymentStackClientDiagnostics, Pipeline, "DeploymentStackCollection.GetAll", "value", "nextLink", cancellationToken); + } + + /// + /// Checks to see if the resource exists in azure. + /// + /// + /// Request Path + /// /{scope}/providers/Microsoft.Resources/deploymentStacks/{deploymentStackName} + /// + /// + /// Operation Id + /// DeploymentStacks_GetAtScope + /// + /// + /// Default Api Version + /// 2024-03-01 + /// + /// + /// Resource + /// + /// + /// + /// + /// Name of the deployment stack. + /// The cancellation token to use. + /// is an empty string, and was expected to be non-empty. + /// is null. + public virtual async Task> ExistsAsync(string deploymentStackName, CancellationToken cancellationToken = default) + { + Argument.AssertNotNullOrEmpty(deploymentStackName, nameof(deploymentStackName)); + + using var scope = _deploymentStackClientDiagnostics.CreateScope("DeploymentStackCollection.Exists"); + scope.Start(); + try + { + var response = await _deploymentStackRestClient.GetAtScopeAsync(Id, deploymentStackName, cancellationToken: cancellationToken).ConfigureAwait(false); + return Response.FromValue(response.Value != null, response.GetRawResponse()); + } + catch (Exception e) + { + scope.Failed(e); + throw; + } + } + + /// + /// Checks to see if the resource exists in azure. + /// + /// + /// Request Path + /// /{scope}/providers/Microsoft.Resources/deploymentStacks/{deploymentStackName} + /// + /// + /// Operation Id + /// DeploymentStacks_GetAtScope + /// + /// + /// Default Api Version + /// 2024-03-01 + /// + /// + /// Resource + /// + /// + /// + /// + /// Name of the deployment stack. + /// The cancellation token to use. + /// is an empty string, and was expected to be non-empty. + /// is null. + public virtual Response Exists(string deploymentStackName, CancellationToken cancellationToken = default) + { + Argument.AssertNotNullOrEmpty(deploymentStackName, nameof(deploymentStackName)); + + using var scope = _deploymentStackClientDiagnostics.CreateScope("DeploymentStackCollection.Exists"); + scope.Start(); + try + { + var response = _deploymentStackRestClient.GetAtScope(Id, deploymentStackName, cancellationToken: cancellationToken); + return Response.FromValue(response.Value != null, response.GetRawResponse()); + } + catch (Exception e) + { + scope.Failed(e); + throw; + } + } + + /// + /// Tries to get details for this resource from the service. + /// + /// + /// Request Path + /// /{scope}/providers/Microsoft.Resources/deploymentStacks/{deploymentStackName} + /// + /// + /// Operation Id + /// DeploymentStacks_GetAtScope + /// + /// + /// Default Api Version + /// 2024-03-01 + /// + /// + /// Resource + /// + /// + /// + /// + /// Name of the deployment stack. + /// The cancellation token to use. + /// is an empty string, and was expected to be non-empty. + /// is null. + public virtual async Task> GetIfExistsAsync(string deploymentStackName, CancellationToken cancellationToken = default) + { + Argument.AssertNotNullOrEmpty(deploymentStackName, nameof(deploymentStackName)); + + using var scope = _deploymentStackClientDiagnostics.CreateScope("DeploymentStackCollection.GetIfExists"); + scope.Start(); + try + { + var response = await _deploymentStackRestClient.GetAtScopeAsync(Id, deploymentStackName, cancellationToken: cancellationToken).ConfigureAwait(false); + if (response.Value == null) + return new NoValueResponse(response.GetRawResponse()); + return Response.FromValue(new DeploymentStackResource(Client, response.Value), response.GetRawResponse()); + } + catch (Exception e) + { + scope.Failed(e); + throw; + } + } + + /// + /// Tries to get details for this resource from the service. + /// + /// + /// Request Path + /// /{scope}/providers/Microsoft.Resources/deploymentStacks/{deploymentStackName} + /// + /// + /// Operation Id + /// DeploymentStacks_GetAtScope + /// + /// + /// Default Api Version + /// 2024-03-01 + /// + /// + /// Resource + /// + /// + /// + /// + /// Name of the deployment stack. + /// The cancellation token to use. + /// is an empty string, and was expected to be non-empty. + /// is null. + public virtual NullableResponse GetIfExists(string deploymentStackName, CancellationToken cancellationToken = default) + { + Argument.AssertNotNullOrEmpty(deploymentStackName, nameof(deploymentStackName)); + + using var scope = _deploymentStackClientDiagnostics.CreateScope("DeploymentStackCollection.GetIfExists"); + scope.Start(); + try + { + var response = _deploymentStackRestClient.GetAtScope(Id, deploymentStackName, cancellationToken: cancellationToken); + if (response.Value == null) + return new NoValueResponse(response.GetRawResponse()); + return Response.FromValue(new DeploymentStackResource(Client, response.Value), response.GetRawResponse()); + } + catch (Exception e) + { + scope.Failed(e); + throw; + } + } + + IEnumerator IEnumerable.GetEnumerator() + { + return GetAll().GetEnumerator(); + } + + IEnumerator IEnumerable.GetEnumerator() + { + return GetAll().GetEnumerator(); + } + + IAsyncEnumerator IAsyncEnumerable.GetAsyncEnumerator(CancellationToken cancellationToken) + { + return GetAllAsync(cancellationToken: cancellationToken).GetAsyncEnumerator(cancellationToken); + } + } +} diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/DeploymentStackData.Serialization.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/DeploymentStackData.Serialization.cs new file mode 100644 index 0000000000000..b87a44ec0eb74 --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/DeploymentStackData.Serialization.cs @@ -0,0 +1,1100 @@ +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. + +// + +#nullable disable + +using System; +using System.ClientModel.Primitives; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Text.Json; +using Azure.Core; +using Azure.ResourceManager.Models; +using Azure.ResourceManager.Resources.Models; + +namespace Azure.ResourceManager.Resources +{ + public partial class DeploymentStackData : IUtf8JsonSerializable, IJsonModel + { + void IUtf8JsonSerializable.Write(Utf8JsonWriter writer) => ((IJsonModel)this).Write(writer, ModelSerializationExtensions.WireOptions); + + void IJsonModel.Write(Utf8JsonWriter writer, ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + if (format != "J") + { + throw new FormatException($"The model {nameof(DeploymentStackData)} does not support writing '{format}' format."); + } + + writer.WriteStartObject(); + if (Optional.IsDefined(Location)) + { + writer.WritePropertyName("location"u8); + writer.WriteStringValue(Location.Value); + } + if (Optional.IsCollectionDefined(Tags)) + { + writer.WritePropertyName("tags"u8); + writer.WriteStartObject(); + foreach (var item in Tags) + { + writer.WritePropertyName(item.Key); + writer.WriteStringValue(item.Value); + } + writer.WriteEndObject(); + } + if (options.Format != "W") + { + writer.WritePropertyName("id"u8); + writer.WriteStringValue(Id); + } + if (options.Format != "W") + { + writer.WritePropertyName("name"u8); + writer.WriteStringValue(Name); + } + if (options.Format != "W") + { + writer.WritePropertyName("type"u8); + writer.WriteStringValue(ResourceType); + } + if (options.Format != "W" && Optional.IsDefined(SystemData)) + { + writer.WritePropertyName("systemData"u8); + JsonSerializer.Serialize(writer, SystemData); + } + writer.WritePropertyName("properties"u8); + writer.WriteStartObject(); + if (Optional.IsDefined(Error)) + { + writer.WritePropertyName("error"u8); + JsonSerializer.Serialize(writer, Error); + } + if (Optional.IsDefined(Template)) + { + writer.WritePropertyName("template"u8); +#if NET6_0_OR_GREATER + writer.WriteRawValue(Template); +#else + using (JsonDocument document = JsonDocument.Parse(Template)) + { + JsonSerializer.Serialize(writer, document.RootElement); + } +#endif + } + if (Optional.IsDefined(TemplateLink)) + { + writer.WritePropertyName("templateLink"u8); + writer.WriteObjectValue(TemplateLink, options); + } + if (Optional.IsCollectionDefined(Parameters)) + { + writer.WritePropertyName("parameters"u8); + writer.WriteStartObject(); + foreach (var item in Parameters) + { + writer.WritePropertyName(item.Key); + writer.WriteObjectValue(item.Value, options); + } + writer.WriteEndObject(); + } + if (Optional.IsDefined(ParametersLink)) + { + writer.WritePropertyName("parametersLink"u8); + writer.WriteObjectValue(ParametersLink, options); + } + if (Optional.IsDefined(ActionOnUnmanage)) + { + writer.WritePropertyName("actionOnUnmanage"u8); + writer.WriteObjectValue(ActionOnUnmanage, options); + } + if (Optional.IsDefined(DebugSetting)) + { + writer.WritePropertyName("debugSetting"u8); + writer.WriteObjectValue(DebugSetting, options); + } + if (Optional.IsDefined(BypassStackOutOfSyncError)) + { + writer.WritePropertyName("bypassStackOutOfSyncError"u8); + writer.WriteBooleanValue(BypassStackOutOfSyncError.Value); + } + if (Optional.IsDefined(DeploymentScope)) + { + writer.WritePropertyName("deploymentScope"u8); + writer.WriteStringValue(DeploymentScope); + } + if (Optional.IsDefined(Description)) + { + writer.WritePropertyName("description"u8); + writer.WriteStringValue(Description); + } + if (Optional.IsDefined(DenySettings)) + { + writer.WritePropertyName("denySettings"u8); + writer.WriteObjectValue(DenySettings, options); + } + if (options.Format != "W" && Optional.IsDefined(ProvisioningState)) + { + writer.WritePropertyName("provisioningState"u8); + writer.WriteStringValue(ProvisioningState.Value.ToString()); + } + if (options.Format != "W" && Optional.IsDefined(CorrelationId)) + { + writer.WritePropertyName("correlationId"u8); + writer.WriteStringValue(CorrelationId); + } + if (options.Format != "W" && Optional.IsCollectionDefined(DetachedResources)) + { + writer.WritePropertyName("detachedResources"u8); + writer.WriteStartArray(); + foreach (var item in DetachedResources) + { + JsonSerializer.Serialize(writer, item); + } + writer.WriteEndArray(); + } + if (options.Format != "W" && Optional.IsCollectionDefined(DeletedResources)) + { + writer.WritePropertyName("deletedResources"u8); + writer.WriteStartArray(); + foreach (var item in DeletedResources) + { + JsonSerializer.Serialize(writer, item); + } + writer.WriteEndArray(); + } + if (options.Format != "W" && Optional.IsCollectionDefined(FailedResources)) + { + writer.WritePropertyName("failedResources"u8); + writer.WriteStartArray(); + foreach (var item in FailedResources) + { + writer.WriteObjectValue(item, options); + } + writer.WriteEndArray(); + } + if (options.Format != "W" && Optional.IsCollectionDefined(Resources)) + { + writer.WritePropertyName("resources"u8); + writer.WriteStartArray(); + foreach (var item in Resources) + { + writer.WriteObjectValue(item, options); + } + writer.WriteEndArray(); + } + if (options.Format != "W" && Optional.IsDefined(DeploymentId)) + { + writer.WritePropertyName("deploymentId"u8); + writer.WriteStringValue(DeploymentId); + } + if (options.Format != "W" && Optional.IsDefined(Outputs)) + { + writer.WritePropertyName("outputs"u8); +#if NET6_0_OR_GREATER + writer.WriteRawValue(Outputs); +#else + using (JsonDocument document = JsonDocument.Parse(Outputs)) + { + JsonSerializer.Serialize(writer, document.RootElement); + } +#endif + } + if (options.Format != "W" && Optional.IsDefined(Duration)) + { + writer.WritePropertyName("duration"u8); + writer.WriteStringValue(Duration.Value, "P"); + } + writer.WriteEndObject(); + if (options.Format != "W" && _serializedAdditionalRawData != null) + { + foreach (var item in _serializedAdditionalRawData) + { + writer.WritePropertyName(item.Key); +#if NET6_0_OR_GREATER + writer.WriteRawValue(item.Value); +#else + using (JsonDocument document = JsonDocument.Parse(item.Value)) + { + JsonSerializer.Serialize(writer, document.RootElement); + } +#endif + } + } + writer.WriteEndObject(); + } + + DeploymentStackData IJsonModel.Create(ref Utf8JsonReader reader, ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + if (format != "J") + { + throw new FormatException($"The model {nameof(DeploymentStackData)} does not support reading '{format}' format."); + } + + using JsonDocument document = JsonDocument.ParseValue(ref reader); + return DeserializeDeploymentStackData(document.RootElement, options); + } + + internal static DeploymentStackData DeserializeDeploymentStackData(JsonElement element, ModelReaderWriterOptions options = null) + { + options ??= ModelSerializationExtensions.WireOptions; + + if (element.ValueKind == JsonValueKind.Null) + { + return null; + } + AzureLocation? location = default; + IDictionary tags = default; + ResourceIdentifier id = default; + string name = default; + ResourceType type = default; + SystemData systemData = default; + ResponseError error = default; + BinaryData template = default; + DeploymentStacksTemplateLink templateLink = default; + IDictionary parameters = default; + DeploymentStacksParametersLink parametersLink = default; + ActionOnUnmanage actionOnUnmanage = default; + DeploymentStacksDebugSetting debugSetting = default; + bool? bypassStackOutOfSyncError = default; + string deploymentScope = default; + string description = default; + DenySettings denySettings = default; + DeploymentStackProvisioningState? provisioningState = default; + string correlationId = default; + IReadOnlyList detachedResources = default; + IReadOnlyList deletedResources = default; + IReadOnlyList failedResources = default; + IReadOnlyList resources = default; + string deploymentId = default; + BinaryData outputs = default; + TimeSpan? duration = default; + IDictionary serializedAdditionalRawData = default; + Dictionary rawDataDictionary = new Dictionary(); + foreach (var property in element.EnumerateObject()) + { + if (property.NameEquals("location"u8)) + { + if (property.Value.ValueKind == JsonValueKind.Null) + { + continue; + } + location = new AzureLocation(property.Value.GetString()); + continue; + } + if (property.NameEquals("tags"u8)) + { + if (property.Value.ValueKind == JsonValueKind.Null) + { + continue; + } + Dictionary dictionary = new Dictionary(); + foreach (var property0 in property.Value.EnumerateObject()) + { + dictionary.Add(property0.Name, property0.Value.GetString()); + } + tags = dictionary; + continue; + } + if (property.NameEquals("id"u8)) + { + id = new ResourceIdentifier(property.Value.GetString()); + continue; + } + if (property.NameEquals("name"u8)) + { + name = property.Value.GetString(); + continue; + } + if (property.NameEquals("type"u8)) + { + type = new ResourceType(property.Value.GetString()); + continue; + } + if (property.NameEquals("systemData"u8)) + { + if (property.Value.ValueKind == JsonValueKind.Null) + { + continue; + } + systemData = JsonSerializer.Deserialize(property.Value.GetRawText()); + continue; + } + if (property.NameEquals("properties"u8)) + { + if (property.Value.ValueKind == JsonValueKind.Null) + { + property.ThrowNonNullablePropertyIsNull(); + continue; + } + foreach (var property0 in property.Value.EnumerateObject()) + { + if (property0.NameEquals("error"u8)) + { + if (property0.Value.ValueKind == JsonValueKind.Null) + { + continue; + } + error = JsonSerializer.Deserialize(property0.Value.GetRawText()); + continue; + } + if (property0.NameEquals("template"u8)) + { + if (property0.Value.ValueKind == JsonValueKind.Null) + { + continue; + } + template = BinaryData.FromString(property0.Value.GetRawText()); + continue; + } + if (property0.NameEquals("templateLink"u8)) + { + if (property0.Value.ValueKind == JsonValueKind.Null) + { + continue; + } + templateLink = DeploymentStacksTemplateLink.DeserializeDeploymentStacksTemplateLink(property0.Value, options); + continue; + } + if (property0.NameEquals("parameters"u8)) + { + if (property0.Value.ValueKind == JsonValueKind.Null) + { + continue; + } + Dictionary dictionary = new Dictionary(); + foreach (var property1 in property0.Value.EnumerateObject()) + { + dictionary.Add(property1.Name, DeploymentParameter.DeserializeDeploymentParameter(property1.Value, options)); + } + parameters = dictionary; + continue; + } + if (property0.NameEquals("parametersLink"u8)) + { + if (property0.Value.ValueKind == JsonValueKind.Null) + { + continue; + } + parametersLink = DeploymentStacksParametersLink.DeserializeDeploymentStacksParametersLink(property0.Value, options); + continue; + } + if (property0.NameEquals("actionOnUnmanage"u8)) + { + if (property0.Value.ValueKind == JsonValueKind.Null) + { + continue; + } + actionOnUnmanage = ActionOnUnmanage.DeserializeActionOnUnmanage(property0.Value, options); + continue; + } + if (property0.NameEquals("debugSetting"u8)) + { + if (property0.Value.ValueKind == JsonValueKind.Null) + { + continue; + } + debugSetting = DeploymentStacksDebugSetting.DeserializeDeploymentStacksDebugSetting(property0.Value, options); + continue; + } + if (property0.NameEquals("bypassStackOutOfSyncError"u8)) + { + if (property0.Value.ValueKind == JsonValueKind.Null) + { + continue; + } + bypassStackOutOfSyncError = property0.Value.GetBoolean(); + continue; + } + if (property0.NameEquals("deploymentScope"u8)) + { + deploymentScope = property0.Value.GetString(); + continue; + } + if (property0.NameEquals("description"u8)) + { + description = property0.Value.GetString(); + continue; + } + if (property0.NameEquals("denySettings"u8)) + { + if (property0.Value.ValueKind == JsonValueKind.Null) + { + continue; + } + denySettings = DenySettings.DeserializeDenySettings(property0.Value, options); + continue; + } + if (property0.NameEquals("provisioningState"u8)) + { + if (property0.Value.ValueKind == JsonValueKind.Null) + { + continue; + } + provisioningState = new DeploymentStackProvisioningState(property0.Value.GetString()); + continue; + } + if (property0.NameEquals("correlationId"u8)) + { + correlationId = property0.Value.GetString(); + continue; + } + if (property0.NameEquals("detachedResources"u8)) + { + if (property0.Value.ValueKind == JsonValueKind.Null) + { + continue; + } + List array = new List(); + foreach (var item in property0.Value.EnumerateArray()) + { + array.Add(JsonSerializer.Deserialize(item.GetRawText())); + } + detachedResources = array; + continue; + } + if (property0.NameEquals("deletedResources"u8)) + { + if (property0.Value.ValueKind == JsonValueKind.Null) + { + continue; + } + List array = new List(); + foreach (var item in property0.Value.EnumerateArray()) + { + array.Add(JsonSerializer.Deserialize(item.GetRawText())); + } + deletedResources = array; + continue; + } + if (property0.NameEquals("failedResources"u8)) + { + if (property0.Value.ValueKind == JsonValueKind.Null) + { + continue; + } + List array = new List(); + foreach (var item in property0.Value.EnumerateArray()) + { + array.Add(ResourceReferenceExtended.DeserializeResourceReferenceExtended(item, options)); + } + failedResources = array; + continue; + } + if (property0.NameEquals("resources"u8)) + { + if (property0.Value.ValueKind == JsonValueKind.Null) + { + continue; + } + List array = new List(); + foreach (var item in property0.Value.EnumerateArray()) + { + array.Add(ManagedResourceReference.DeserializeManagedResourceReference(item, options)); + } + resources = array; + continue; + } + if (property0.NameEquals("deploymentId"u8)) + { + deploymentId = property0.Value.GetString(); + continue; + } + if (property0.NameEquals("outputs"u8)) + { + if (property0.Value.ValueKind == JsonValueKind.Null) + { + continue; + } + outputs = BinaryData.FromString(property0.Value.GetRawText()); + continue; + } + if (property0.NameEquals("duration"u8)) + { + if (property0.Value.ValueKind == JsonValueKind.Null) + { + continue; + } + duration = property0.Value.GetTimeSpan("P"); + continue; + } + } + continue; + } + if (options.Format != "W") + { + rawDataDictionary.Add(property.Name, BinaryData.FromString(property.Value.GetRawText())); + } + } + serializedAdditionalRawData = rawDataDictionary; + return new DeploymentStackData( + id, + name, + type, + systemData, + location, + tags ?? new ChangeTrackingDictionary(), + error, + template, + templateLink, + parameters ?? new ChangeTrackingDictionary(), + parametersLink, + actionOnUnmanage, + debugSetting, + bypassStackOutOfSyncError, + deploymentScope, + description, + denySettings, + provisioningState, + correlationId, + detachedResources ?? new ChangeTrackingList(), + deletedResources ?? new ChangeTrackingList(), + failedResources ?? new ChangeTrackingList(), + resources ?? new ChangeTrackingList(), + deploymentId, + outputs, + duration, + serializedAdditionalRawData); + } + + private BinaryData SerializeBicep(ModelReaderWriterOptions options) + { + StringBuilder builder = new StringBuilder(); + BicepModelReaderWriterOptions bicepOptions = options as BicepModelReaderWriterOptions; + IDictionary propertyOverrides = null; + bool hasObjectOverride = bicepOptions != null && bicepOptions.PropertyOverrides.TryGetValue(this, out propertyOverrides); + bool hasPropertyOverride = false; + string propertyOverride = null; + + builder.AppendLine("{"); + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(Name), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" name: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(Name)) + { + builder.Append(" name: "); + if (Name.Contains(Environment.NewLine)) + { + builder.AppendLine("'''"); + builder.AppendLine($"{Name}'''"); + } + else + { + builder.AppendLine($"'{Name}'"); + } + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(Location), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" location: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(Location)) + { + builder.Append(" location: "); + builder.AppendLine($"'{Location.Value.ToString()}'"); + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(Tags), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" tags: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsCollectionDefined(Tags)) + { + if (Tags.Any()) + { + builder.Append(" tags: "); + builder.AppendLine("{"); + foreach (var item in Tags) + { + builder.Append($" '{item.Key}': "); + if (item.Value == null) + { + builder.Append("null"); + continue; + } + if (item.Value.Contains(Environment.NewLine)) + { + builder.AppendLine("'''"); + builder.AppendLine($"{item.Value}'''"); + } + else + { + builder.AppendLine($"'{item.Value}'"); + } + } + builder.AppendLine(" }"); + } + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(Id), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" id: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(Id)) + { + builder.Append(" id: "); + builder.AppendLine($"'{Id.ToString()}'"); + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(SystemData), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" systemData: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(SystemData)) + { + builder.Append(" systemData: "); + builder.AppendLine($"'{SystemData.ToString()}'"); + } + } + + builder.Append(" properties:"); + builder.AppendLine(" {"); + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(Error), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" error: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(Error)) + { + builder.Append(" error: "); + BicepSerializationHelpers.AppendChildObject(builder, Error, options, 4, false, " error: "); + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(Template), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" template: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(Template)) + { + builder.Append(" template: "); + builder.AppendLine($"'{Template.ToString()}'"); + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(TemplateLink), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" templateLink: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(TemplateLink)) + { + builder.Append(" templateLink: "); + BicepSerializationHelpers.AppendChildObject(builder, TemplateLink, options, 4, false, " templateLink: "); + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(Parameters), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" parameters: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsCollectionDefined(Parameters)) + { + if (Parameters.Any()) + { + builder.Append(" parameters: "); + builder.AppendLine("{"); + foreach (var item in Parameters) + { + builder.Append($" '{item.Key}': "); + BicepSerializationHelpers.AppendChildObject(builder, item.Value, options, 6, false, " parameters: "); + } + builder.AppendLine(" }"); + } + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(ParametersLink), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" parametersLink: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(ParametersLink)) + { + builder.Append(" parametersLink: "); + BicepSerializationHelpers.AppendChildObject(builder, ParametersLink, options, 4, false, " parametersLink: "); + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(ActionOnUnmanage), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" actionOnUnmanage: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(ActionOnUnmanage)) + { + builder.Append(" actionOnUnmanage: "); + BicepSerializationHelpers.AppendChildObject(builder, ActionOnUnmanage, options, 4, false, " actionOnUnmanage: "); + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue("DebugSettingDetailLevel", out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" debugSetting: "); + builder.AppendLine("{"); + builder.AppendLine(" debugSetting: {"); + builder.Append(" detailLevel: "); + builder.AppendLine(propertyOverride); + builder.AppendLine(" }"); + builder.AppendLine(" }"); + } + else + { + if (Optional.IsDefined(DebugSetting)) + { + builder.Append(" debugSetting: "); + BicepSerializationHelpers.AppendChildObject(builder, DebugSetting, options, 4, false, " debugSetting: "); + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(BypassStackOutOfSyncError), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" bypassStackOutOfSyncError: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(BypassStackOutOfSyncError)) + { + builder.Append(" bypassStackOutOfSyncError: "); + var boolValue = BypassStackOutOfSyncError.Value == true ? "true" : "false"; + builder.AppendLine($"{boolValue}"); + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(DeploymentScope), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" deploymentScope: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(DeploymentScope)) + { + builder.Append(" deploymentScope: "); + if (DeploymentScope.Contains(Environment.NewLine)) + { + builder.AppendLine("'''"); + builder.AppendLine($"{DeploymentScope}'''"); + } + else + { + builder.AppendLine($"'{DeploymentScope}'"); + } + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(Description), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" description: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(Description)) + { + builder.Append(" description: "); + if (Description.Contains(Environment.NewLine)) + { + builder.AppendLine("'''"); + builder.AppendLine($"{Description}'''"); + } + else + { + builder.AppendLine($"'{Description}'"); + } + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(DenySettings), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" denySettings: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(DenySettings)) + { + builder.Append(" denySettings: "); + BicepSerializationHelpers.AppendChildObject(builder, DenySettings, options, 4, false, " denySettings: "); + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(ProvisioningState), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" provisioningState: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(ProvisioningState)) + { + builder.Append(" provisioningState: "); + builder.AppendLine($"'{ProvisioningState.Value.ToString()}'"); + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(CorrelationId), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" correlationId: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(CorrelationId)) + { + builder.Append(" correlationId: "); + if (CorrelationId.Contains(Environment.NewLine)) + { + builder.AppendLine("'''"); + builder.AppendLine($"{CorrelationId}'''"); + } + else + { + builder.AppendLine($"'{CorrelationId}'"); + } + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(DetachedResources), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" detachedResources: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsCollectionDefined(DetachedResources)) + { + if (DetachedResources.Any()) + { + builder.Append(" detachedResources: "); + builder.AppendLine("["); + foreach (var item in DetachedResources) + { + BicepSerializationHelpers.AppendChildObject(builder, item, options, 6, true, " detachedResources: "); + } + builder.AppendLine(" ]"); + } + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(DeletedResources), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" deletedResources: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsCollectionDefined(DeletedResources)) + { + if (DeletedResources.Any()) + { + builder.Append(" deletedResources: "); + builder.AppendLine("["); + foreach (var item in DeletedResources) + { + BicepSerializationHelpers.AppendChildObject(builder, item, options, 6, true, " deletedResources: "); + } + builder.AppendLine(" ]"); + } + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(FailedResources), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" failedResources: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsCollectionDefined(FailedResources)) + { + if (FailedResources.Any()) + { + builder.Append(" failedResources: "); + builder.AppendLine("["); + foreach (var item in FailedResources) + { + BicepSerializationHelpers.AppendChildObject(builder, item, options, 6, true, " failedResources: "); + } + builder.AppendLine(" ]"); + } + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(Resources), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" resources: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsCollectionDefined(Resources)) + { + if (Resources.Any()) + { + builder.Append(" resources: "); + builder.AppendLine("["); + foreach (var item in Resources) + { + BicepSerializationHelpers.AppendChildObject(builder, item, options, 6, true, " resources: "); + } + builder.AppendLine(" ]"); + } + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(DeploymentId), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" deploymentId: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(DeploymentId)) + { + builder.Append(" deploymentId: "); + if (DeploymentId.Contains(Environment.NewLine)) + { + builder.AppendLine("'''"); + builder.AppendLine($"{DeploymentId}'''"); + } + else + { + builder.AppendLine($"'{DeploymentId}'"); + } + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(Outputs), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" outputs: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(Outputs)) + { + builder.Append(" outputs: "); + builder.AppendLine($"'{Outputs.ToString()}'"); + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(Duration), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" duration: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(Duration)) + { + builder.Append(" duration: "); + var formattedTimeSpan = TypeFormatters.ToString(Duration.Value, "P"); + builder.AppendLine($"'{formattedTimeSpan}'"); + } + } + + builder.AppendLine(" }"); + builder.AppendLine("}"); + return BinaryData.FromString(builder.ToString()); + } + + BinaryData IPersistableModel.Write(ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + + switch (format) + { + case "J": + return ModelReaderWriter.Write(this, options); + case "bicep": + return SerializeBicep(options); + default: + throw new FormatException($"The model {nameof(DeploymentStackData)} does not support writing '{options.Format}' format."); + } + } + + DeploymentStackData IPersistableModel.Create(BinaryData data, ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + + switch (format) + { + case "J": + { + using JsonDocument document = JsonDocument.Parse(data); + return DeserializeDeploymentStackData(document.RootElement, options); + } + default: + throw new FormatException($"The model {nameof(DeploymentStackData)} does not support reading '{options.Format}' format."); + } + } + + string IPersistableModel.GetFormatFromOptions(ModelReaderWriterOptions options) => "J"; + } +} diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/DeploymentStackData.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/DeploymentStackData.cs new file mode 100644 index 0000000000000..4078243e51012 --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/DeploymentStackData.cs @@ -0,0 +1,257 @@ +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. + +// + +#nullable disable + +using System; +using System.Collections.Generic; +using Azure.Core; +using Azure.ResourceManager.Models; +using Azure.ResourceManager.Resources.Models; + +namespace Azure.ResourceManager.Resources +{ + /// + /// A class representing the DeploymentStack data model. + /// Deployment stack object. + /// + public partial class DeploymentStackData : ResourceData + { + /// + /// Keeps track of any properties unknown to the library. + /// + /// To assign an object to the value of this property use . + /// + /// + /// To assign an already formatted json string to this property use . + /// + /// + /// Examples: + /// + /// + /// BinaryData.FromObjectAsJson("foo") + /// Creates a payload of "foo". + /// + /// + /// BinaryData.FromString("\"foo\"") + /// Creates a payload of "foo". + /// + /// + /// BinaryData.FromObjectAsJson(new { key = "value" }) + /// Creates a payload of { "key": "value" }. + /// + /// + /// BinaryData.FromString("{\"key\": \"value\"}") + /// Creates a payload of { "key": "value" }. + /// + /// + /// + /// + private IDictionary _serializedAdditionalRawData; + + /// Initializes a new instance of . + public DeploymentStackData() + { + Tags = new ChangeTrackingDictionary(); + Parameters = new ChangeTrackingDictionary(); + DetachedResources = new ChangeTrackingList(); + DeletedResources = new ChangeTrackingList(); + FailedResources = new ChangeTrackingList(); + Resources = new ChangeTrackingList(); + } + + /// Initializes a new instance of . + /// The id. + /// The name. + /// The resourceType. + /// The systemData. + /// The location of the Deployment stack. It cannot be changed after creation. It must be one of the supported Azure locations. + /// Deployment stack resource tags. + /// The error detail. + /// The template content. You use this element when you want to pass the template syntax directly in the request rather than link to an existing template. It can be a JObject or well-formed JSON string. Use either the templateLink property or the template property, but not both. + /// The URI of the template. Use either the templateLink property or the template property, but not both. + /// Name and value pairs that define the deployment parameters for the template. Use this element when providing the parameter values directly in the request, rather than linking to an existing parameter file. Use either the parametersLink property or the parameters property, but not both. + /// The URI of parameters file. Use this element to link to an existing parameters file. Use either the parametersLink property or the parameters property, but not both. + /// Defines the behavior of resources that are no longer managed after the Deployment stack is updated or deleted. + /// The debug setting of the deployment. + /// Flag to bypass service errors that indicate the stack resource list is not correctly synchronized. + /// The scope at which the initial deployment should be created. If a scope is not specified, it will default to the scope of the deployment stack. Valid scopes are: management group (format: '/providers/Microsoft.Management/managementGroups/{managementGroupId}'), subscription (format: '/subscriptions/{subscriptionId}'), resource group (format: '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}'). + /// Deployment stack description. Max length of 4096 characters. + /// Defines how resources deployed by the stack are locked. + /// State of the deployment stack. + /// The correlation id of the last Deployment stack upsert or delete operation. It is in GUID format and is used for tracing. + /// An array of resources that were detached during the most recent Deployment stack update. Detached means that the resource was removed from the template, but no relevant deletion operations were specified. So, the resource still exists while no longer being associated with the stack. + /// An array of resources that were deleted during the most recent Deployment stack update. Deleted means that the resource was removed from the template and relevant deletion operations were specified. + /// An array of resources that failed to reach goal state during the most recent update. Each resourceId is accompanied by an error message. + /// An array of resources currently managed by the deployment stack. + /// The resourceId of the deployment resource created by the deployment stack. + /// The outputs of the deployment resource created by the deployment stack. + /// The duration of the last successful Deployment stack update. + /// Keeps track of any properties unknown to the library. + internal DeploymentStackData(ResourceIdentifier id, string name, ResourceType resourceType, SystemData systemData, AzureLocation? location, IDictionary tags, ResponseError error, BinaryData template, DeploymentStacksTemplateLink templateLink, IDictionary parameters, DeploymentStacksParametersLink parametersLink, ActionOnUnmanage actionOnUnmanage, DeploymentStacksDebugSetting debugSetting, bool? bypassStackOutOfSyncError, string deploymentScope, string description, DenySettings denySettings, DeploymentStackProvisioningState? provisioningState, string correlationId, IReadOnlyList detachedResources, IReadOnlyList deletedResources, IReadOnlyList failedResources, IReadOnlyList resources, string deploymentId, BinaryData outputs, TimeSpan? duration, IDictionary serializedAdditionalRawData) : base(id, name, resourceType, systemData) + { + Location = location; + Tags = tags; + Error = error; + Template = template; + TemplateLink = templateLink; + Parameters = parameters; + ParametersLink = parametersLink; + ActionOnUnmanage = actionOnUnmanage; + DebugSetting = debugSetting; + BypassStackOutOfSyncError = bypassStackOutOfSyncError; + DeploymentScope = deploymentScope; + Description = description; + DenySettings = denySettings; + ProvisioningState = provisioningState; + CorrelationId = correlationId; + DetachedResources = detachedResources; + DeletedResources = deletedResources; + FailedResources = failedResources; + Resources = resources; + DeploymentId = deploymentId; + Outputs = outputs; + Duration = duration; + _serializedAdditionalRawData = serializedAdditionalRawData; + } + + /// The location of the Deployment stack. It cannot be changed after creation. It must be one of the supported Azure locations. + [WirePath("location")] + public AzureLocation? Location { get; set; } + /// Deployment stack resource tags. + [WirePath("tags")] + public IDictionary Tags { get; } + /// The error detail. + [WirePath("properties.error")] + public ResponseError Error { get; set; } + /// + /// The template content. You use this element when you want to pass the template syntax directly in the request rather than link to an existing template. It can be a JObject or well-formed JSON string. Use either the templateLink property or the template property, but not both. + /// + /// To assign an object to this property use . + /// + /// + /// To assign an already formatted json string to this property use . + /// + /// + /// Examples: + /// + /// + /// BinaryData.FromObjectAsJson("foo") + /// Creates a payload of "foo". + /// + /// + /// BinaryData.FromString("\"foo\"") + /// Creates a payload of "foo". + /// + /// + /// BinaryData.FromObjectAsJson(new { key = "value" }) + /// Creates a payload of { "key": "value" }. + /// + /// + /// BinaryData.FromString("{\"key\": \"value\"}") + /// Creates a payload of { "key": "value" }. + /// + /// + /// + /// + [WirePath("properties.template")] + public BinaryData Template { get; set; } + /// The URI of the template. Use either the templateLink property or the template property, but not both. + [WirePath("properties.templateLink")] + public DeploymentStacksTemplateLink TemplateLink { get; set; } + /// Name and value pairs that define the deployment parameters for the template. Use this element when providing the parameter values directly in the request, rather than linking to an existing parameter file. Use either the parametersLink property or the parameters property, but not both. + [WirePath("properties.parameters")] + public IDictionary Parameters { get; } + /// The URI of parameters file. Use this element to link to an existing parameters file. Use either the parametersLink property or the parameters property, but not both. + [WirePath("properties.parametersLink")] + public DeploymentStacksParametersLink ParametersLink { get; set; } + /// Defines the behavior of resources that are no longer managed after the Deployment stack is updated or deleted. + [WirePath("properties.actionOnUnmanage")] + public ActionOnUnmanage ActionOnUnmanage { get; set; } + /// The debug setting of the deployment. + internal DeploymentStacksDebugSetting DebugSetting { get; set; } + /// Specifies the type of information to log for debugging. The permitted values are none, requestContent, responseContent, or both requestContent and responseContent separated by a comma. The default is none. When setting this value, carefully consider the type of information that is being passed in during deployment. By logging information about the request or response, sensitive data that is retrieved through the deployment operations could potentially be exposed. + [WirePath("properties.debugSetting.detailLevel")] + public string DebugSettingDetailLevel + { + get => DebugSetting is null ? default : DebugSetting.DetailLevel; + set + { + if (DebugSetting is null) + DebugSetting = new DeploymentStacksDebugSetting(); + DebugSetting.DetailLevel = value; + } + } + + /// Flag to bypass service errors that indicate the stack resource list is not correctly synchronized. + [WirePath("properties.bypassStackOutOfSyncError")] + public bool? BypassStackOutOfSyncError { get; set; } + /// The scope at which the initial deployment should be created. If a scope is not specified, it will default to the scope of the deployment stack. Valid scopes are: management group (format: '/providers/Microsoft.Management/managementGroups/{managementGroupId}'), subscription (format: '/subscriptions/{subscriptionId}'), resource group (format: '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}'). + [WirePath("properties.deploymentScope")] + public string DeploymentScope { get; set; } + /// Deployment stack description. Max length of 4096 characters. + [WirePath("properties.description")] + public string Description { get; set; } + /// Defines how resources deployed by the stack are locked. + [WirePath("properties.denySettings")] + public DenySettings DenySettings { get; set; } + /// State of the deployment stack. + [WirePath("properties.provisioningState")] + public DeploymentStackProvisioningState? ProvisioningState { get; } + /// The correlation id of the last Deployment stack upsert or delete operation. It is in GUID format and is used for tracing. + [WirePath("properties.correlationId")] + public string CorrelationId { get; } + /// An array of resources that were detached during the most recent Deployment stack update. Detached means that the resource was removed from the template, but no relevant deletion operations were specified. So, the resource still exists while no longer being associated with the stack. + [WirePath("properties.detachedResources")] + public IReadOnlyList DetachedResources { get; } + /// An array of resources that were deleted during the most recent Deployment stack update. Deleted means that the resource was removed from the template and relevant deletion operations were specified. + [WirePath("properties.deletedResources")] + public IReadOnlyList DeletedResources { get; } + /// An array of resources that failed to reach goal state during the most recent update. Each resourceId is accompanied by an error message. + [WirePath("properties.failedResources")] + public IReadOnlyList FailedResources { get; } + /// An array of resources currently managed by the deployment stack. + [WirePath("properties.resources")] + public IReadOnlyList Resources { get; } + /// The resourceId of the deployment resource created by the deployment stack. + [WirePath("properties.deploymentId")] + public string DeploymentId { get; } + /// + /// The outputs of the deployment resource created by the deployment stack. + /// + /// To assign an object to this property use . + /// + /// + /// To assign an already formatted json string to this property use . + /// + /// + /// Examples: + /// + /// + /// BinaryData.FromObjectAsJson("foo") + /// Creates a payload of "foo". + /// + /// + /// BinaryData.FromString("\"foo\"") + /// Creates a payload of "foo". + /// + /// + /// BinaryData.FromObjectAsJson(new { key = "value" }) + /// Creates a payload of { "key": "value" }. + /// + /// + /// BinaryData.FromString("{\"key\": \"value\"}") + /// Creates a payload of { "key": "value" }. + /// + /// + /// + /// + [WirePath("properties.outputs")] + public BinaryData Outputs { get; } + /// The duration of the last successful Deployment stack update. + [WirePath("properties.duration")] + public TimeSpan? Duration { get; } + } +} diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/DeploymentStackResource.Serialization.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/DeploymentStackResource.Serialization.cs new file mode 100644 index 0000000000000..fcb29ed47817c --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/DeploymentStackResource.Serialization.cs @@ -0,0 +1,26 @@ +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. + +// + +#nullable disable + +using System; +using System.ClientModel.Primitives; +using System.Text.Json; + +namespace Azure.ResourceManager.Resources +{ + public partial class DeploymentStackResource : IJsonModel + { + void IJsonModel.Write(Utf8JsonWriter writer, ModelReaderWriterOptions options) => ((IJsonModel)Data).Write(writer, options); + + DeploymentStackData IJsonModel.Create(ref Utf8JsonReader reader, ModelReaderWriterOptions options) => ((IJsonModel)Data).Create(ref reader, options); + + BinaryData IPersistableModel.Write(ModelReaderWriterOptions options) => ModelReaderWriter.Write(Data, options); + + DeploymentStackData IPersistableModel.Create(BinaryData data, ModelReaderWriterOptions options) => ModelReaderWriter.Read(data, options); + + string IPersistableModel.GetFormatFromOptions(ModelReaderWriterOptions options) => ((IPersistableModel)Data).GetFormatFromOptions(options); + } +} diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/DeploymentStackResource.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/DeploymentStackResource.cs new file mode 100644 index 0000000000000..94f9f1e5abac1 --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/DeploymentStackResource.cs @@ -0,0 +1,860 @@ +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. + +// + +#nullable disable + +using System; +using System.Collections.Generic; +using System.Globalization; +using System.Threading; +using System.Threading.Tasks; +using Azure.Core; +using Azure.Core.Pipeline; +using Azure.ResourceManager.ManagementGroups; +using Azure.ResourceManager.Resources.Models; + +namespace Azure.ResourceManager.Resources +{ + /// + /// A Class representing a DeploymentStack along with the instance operations that can be performed on it. + /// If you have a you can construct a + /// from an instance of using the GetDeploymentStackResource method. + /// Otherwise you can get one from its parent resource , or using the GetDeploymentStack method. + /// + public partial class DeploymentStackResource : ArmResource + { + /// Generate the resource identifier of a instance. + /// The scope. + /// The deploymentStackName. + public static ResourceIdentifier CreateResourceIdentifier(string scope, string deploymentStackName) + { + var resourceId = $"{scope}/providers/Microsoft.Resources/deploymentStacks/{deploymentStackName}"; + return new ResourceIdentifier(resourceId); + } + + private readonly ClientDiagnostics _deploymentStackClientDiagnostics; + private readonly DeploymentStacksRestOperations _deploymentStackRestClient; + private readonly DeploymentStackData _data; + + /// Gets the resource type for the operations. + public static readonly ResourceType ResourceType = "Microsoft.Resources/deploymentStacks"; + + /// Initializes a new instance of the class for mocking. + protected DeploymentStackResource() + { + } + + /// Initializes a new instance of the class. + /// The client parameters to use in these operations. + /// The resource that is the target of operations. + internal DeploymentStackResource(ArmClient client, DeploymentStackData data) : this(client, data.Id) + { + HasData = true; + _data = data; + } + + /// Initializes a new instance of the class. + /// The client parameters to use in these operations. + /// The identifier of the resource that is the target of operations. + internal DeploymentStackResource(ArmClient client, ResourceIdentifier id) : base(client, id) + { + _deploymentStackClientDiagnostics = new ClientDiagnostics("Azure.ResourceManager.Resources", ResourceType.Namespace, Diagnostics); + TryGetApiVersion(ResourceType, out string deploymentStackApiVersion); + _deploymentStackRestClient = new DeploymentStacksRestOperations(Pipeline, Diagnostics.ApplicationId, Endpoint, deploymentStackApiVersion); +#if DEBUG + ValidateResourceId(Id); +#endif + } + + /// Gets whether or not the current instance has data. + public virtual bool HasData { get; } + + /// Gets the data representing this Feature. + /// Throws if there is no data loaded in the current instance. + public virtual DeploymentStackData Data + { + get + { + if (!HasData) + throw new InvalidOperationException("The current instance does not have data, you must call Get first."); + return _data; + } + } + + internal static void ValidateResourceId(ResourceIdentifier id) + { + if (id.ResourceType != ResourceType) + throw new ArgumentException(string.Format(CultureInfo.CurrentCulture, "Invalid resource type {0} expected {1}", id.ResourceType, ResourceType), nameof(id)); + } + + /// + /// Gets a Deployment stack with a given name at specific scope. + /// + /// + /// Request Path + /// /{scope}/providers/Microsoft.Resources/deploymentStacks/{deploymentStackName} + /// + /// + /// Operation Id + /// DeploymentStacks_GetAtScope + /// + /// + /// Default Api Version + /// 2024-03-01 + /// + /// + /// Resource + /// + /// + /// + /// + /// The cancellation token to use. + public virtual async Task> GetAsync(CancellationToken cancellationToken = default) + { + using var scope = _deploymentStackClientDiagnostics.CreateScope("DeploymentStackResource.Get"); + scope.Start(); + try + { + var response = await _deploymentStackRestClient.GetAtScopeAsync(Id.Parent, Id.Name, cancellationToken).ConfigureAwait(false); + if (response.Value == null) + throw new RequestFailedException(response.GetRawResponse()); + return Response.FromValue(new DeploymentStackResource(Client, response.Value), response.GetRawResponse()); + } + catch (Exception e) + { + scope.Failed(e); + throw; + } + } + + /// + /// Gets a Deployment stack with a given name at specific scope. + /// + /// + /// Request Path + /// /{scope}/providers/Microsoft.Resources/deploymentStacks/{deploymentStackName} + /// + /// + /// Operation Id + /// DeploymentStacks_GetAtScope + /// + /// + /// Default Api Version + /// 2024-03-01 + /// + /// + /// Resource + /// + /// + /// + /// + /// The cancellation token to use. + public virtual Response Get(CancellationToken cancellationToken = default) + { + using var scope = _deploymentStackClientDiagnostics.CreateScope("DeploymentStackResource.Get"); + scope.Start(); + try + { + var response = _deploymentStackRestClient.GetAtScope(Id.Parent, Id.Name, cancellationToken); + if (response.Value == null) + throw new RequestFailedException(response.GetRawResponse()); + return Response.FromValue(new DeploymentStackResource(Client, response.Value), response.GetRawResponse()); + } + catch (Exception e) + { + scope.Failed(e); + throw; + } + } + + /// + /// Deletes a Deployment stack by name at specific scope. When operation completes, status code 200 returned without content. + /// + /// + /// Request Path + /// /{scope}/providers/Microsoft.Resources/deploymentStacks/{deploymentStackName} + /// + /// + /// Operation Id + /// DeploymentStacks_DeleteAtScope + /// + /// + /// Default Api Version + /// 2024-03-01 + /// + /// + /// Resource + /// + /// + /// + /// + /// if the method should wait to return until the long-running operation has completed on the service; if it should return after starting the operation. For more information on long-running operations, please see Azure.Core Long-Running Operation samples. + /// Flag to indicate delete rather than detach for unmanaged resources. + /// Flag to indicate delete rather than detach for unmanaged resource groups. + /// Flag to indicate delete rather than detach for unmanaged management groups. + /// Flag to bypass service errors that indicate the stack resource list is not correctly synchronized. + /// The cancellation token to use. + public virtual async Task DeleteAsync(WaitUntil waitUntil, UnmanageActionResourceMode? unmanageActionResources = null, UnmanageActionResourceGroupMode? unmanageActionResourceGroups = null, UnmanageActionManagementGroupMode? unmanageActionManagementGroups = null, bool? bypassStackOutOfSyncError = null, CancellationToken cancellationToken = default) + { + using var scope = _deploymentStackClientDiagnostics.CreateScope("DeploymentStackResource.Delete"); + scope.Start(); + try + { + var response = await _deploymentStackRestClient.DeleteAtScopeAsync(Id.Parent, Id.Name, unmanageActionResources, unmanageActionResourceGroups, unmanageActionManagementGroups, bypassStackOutOfSyncError, cancellationToken).ConfigureAwait(false); + var operation = new ResourcesArmOperation(_deploymentStackClientDiagnostics, Pipeline, _deploymentStackRestClient.CreateDeleteAtScopeRequest(Id.Parent, Id.Name, unmanageActionResources, unmanageActionResourceGroups, unmanageActionManagementGroups, bypassStackOutOfSyncError).Request, response, OperationFinalStateVia.Location); + if (waitUntil == WaitUntil.Completed) + await operation.WaitForCompletionResponseAsync(cancellationToken).ConfigureAwait(false); + return operation; + } + catch (Exception e) + { + scope.Failed(e); + throw; + } + } + + /// + /// Deletes a Deployment stack by name at specific scope. When operation completes, status code 200 returned without content. + /// + /// + /// Request Path + /// /{scope}/providers/Microsoft.Resources/deploymentStacks/{deploymentStackName} + /// + /// + /// Operation Id + /// DeploymentStacks_DeleteAtScope + /// + /// + /// Default Api Version + /// 2024-03-01 + /// + /// + /// Resource + /// + /// + /// + /// + /// if the method should wait to return until the long-running operation has completed on the service; if it should return after starting the operation. For more information on long-running operations, please see Azure.Core Long-Running Operation samples. + /// Flag to indicate delete rather than detach for unmanaged resources. + /// Flag to indicate delete rather than detach for unmanaged resource groups. + /// Flag to indicate delete rather than detach for unmanaged management groups. + /// Flag to bypass service errors that indicate the stack resource list is not correctly synchronized. + /// The cancellation token to use. + public virtual ArmOperation Delete(WaitUntil waitUntil, UnmanageActionResourceMode? unmanageActionResources = null, UnmanageActionResourceGroupMode? unmanageActionResourceGroups = null, UnmanageActionManagementGroupMode? unmanageActionManagementGroups = null, bool? bypassStackOutOfSyncError = null, CancellationToken cancellationToken = default) + { + using var scope = _deploymentStackClientDiagnostics.CreateScope("DeploymentStackResource.Delete"); + scope.Start(); + try + { + var response = _deploymentStackRestClient.DeleteAtScope(Id.Parent, Id.Name, unmanageActionResources, unmanageActionResourceGroups, unmanageActionManagementGroups, bypassStackOutOfSyncError, cancellationToken); + var operation = new ResourcesArmOperation(_deploymentStackClientDiagnostics, Pipeline, _deploymentStackRestClient.CreateDeleteAtScopeRequest(Id.Parent, Id.Name, unmanageActionResources, unmanageActionResourceGroups, unmanageActionManagementGroups, bypassStackOutOfSyncError).Request, response, OperationFinalStateVia.Location); + if (waitUntil == WaitUntil.Completed) + operation.WaitForCompletionResponse(cancellationToken); + return operation; + } + catch (Exception e) + { + scope.Failed(e); + throw; + } + } + + /// + /// Creates or updates a Deployment stack at specific scope. + /// + /// + /// Request Path + /// /{scope}/providers/Microsoft.Resources/deploymentStacks/{deploymentStackName} + /// + /// + /// Operation Id + /// DeploymentStacks_CreateOrUpdateAtScope + /// + /// + /// Default Api Version + /// 2024-03-01 + /// + /// + /// Resource + /// + /// + /// + /// + /// if the method should wait to return until the long-running operation has completed on the service; if it should return after starting the operation. For more information on long-running operations, please see Azure.Core Long-Running Operation samples. + /// Deployment stack supplied to the operation. + /// The cancellation token to use. + /// is null. + public virtual async Task> UpdateAsync(WaitUntil waitUntil, DeploymentStackData data, CancellationToken cancellationToken = default) + { + Argument.AssertNotNull(data, nameof(data)); + + using var scope = _deploymentStackClientDiagnostics.CreateScope("DeploymentStackResource.Update"); + scope.Start(); + try + { + var response = await _deploymentStackRestClient.CreateOrUpdateAtScopeAsync(Id.Parent, Id.Name, data, cancellationToken).ConfigureAwait(false); + var operation = new ResourcesArmOperation(new DeploymentStackOperationSource(Client), _deploymentStackClientDiagnostics, Pipeline, _deploymentStackRestClient.CreateCreateOrUpdateAtScopeRequest(Id.Parent, Id.Name, data).Request, response, OperationFinalStateVia.AzureAsyncOperation); + if (waitUntil == WaitUntil.Completed) + await operation.WaitForCompletionAsync(cancellationToken).ConfigureAwait(false); + return operation; + } + catch (Exception e) + { + scope.Failed(e); + throw; + } + } + + /// + /// Creates or updates a Deployment stack at specific scope. + /// + /// + /// Request Path + /// /{scope}/providers/Microsoft.Resources/deploymentStacks/{deploymentStackName} + /// + /// + /// Operation Id + /// DeploymentStacks_CreateOrUpdateAtScope + /// + /// + /// Default Api Version + /// 2024-03-01 + /// + /// + /// Resource + /// + /// + /// + /// + /// if the method should wait to return until the long-running operation has completed on the service; if it should return after starting the operation. For more information on long-running operations, please see Azure.Core Long-Running Operation samples. + /// Deployment stack supplied to the operation. + /// The cancellation token to use. + /// is null. + public virtual ArmOperation Update(WaitUntil waitUntil, DeploymentStackData data, CancellationToken cancellationToken = default) + { + Argument.AssertNotNull(data, nameof(data)); + + using var scope = _deploymentStackClientDiagnostics.CreateScope("DeploymentStackResource.Update"); + scope.Start(); + try + { + var response = _deploymentStackRestClient.CreateOrUpdateAtScope(Id.Parent, Id.Name, data, cancellationToken); + var operation = new ResourcesArmOperation(new DeploymentStackOperationSource(Client), _deploymentStackClientDiagnostics, Pipeline, _deploymentStackRestClient.CreateCreateOrUpdateAtScopeRequest(Id.Parent, Id.Name, data).Request, response, OperationFinalStateVia.AzureAsyncOperation); + if (waitUntil == WaitUntil.Completed) + operation.WaitForCompletion(cancellationToken); + return operation; + } + catch (Exception e) + { + scope.Failed(e); + throw; + } + } + + /// + /// Exports the template used to create the Deployment stack. + /// + /// + /// Request Path + /// /{scope}/providers/Microsoft.Resources/deploymentStacks/{deploymentStackName}/exportTemplate + /// + /// + /// Operation Id + /// DeploymentStacks_ExportTemplateAtScope + /// + /// + /// Default Api Version + /// 2024-03-01 + /// + /// + /// Resource + /// + /// + /// + /// + /// The cancellation token to use. + public virtual async Task> ExportTemplateAsync(CancellationToken cancellationToken = default) + { + using var scope = _deploymentStackClientDiagnostics.CreateScope("DeploymentStackResource.ExportTemplate"); + scope.Start(); + try + { + var response = await _deploymentStackRestClient.ExportTemplateAtScopeAsync(Id.Parent, Id.Name, cancellationToken).ConfigureAwait(false); + return response; + } + catch (Exception e) + { + scope.Failed(e); + throw; + } + } + + /// + /// Exports the template used to create the Deployment stack. + /// + /// + /// Request Path + /// /{scope}/providers/Microsoft.Resources/deploymentStacks/{deploymentStackName}/exportTemplate + /// + /// + /// Operation Id + /// DeploymentStacks_ExportTemplateAtScope + /// + /// + /// Default Api Version + /// 2024-03-01 + /// + /// + /// Resource + /// + /// + /// + /// + /// The cancellation token to use. + public virtual Response ExportTemplate(CancellationToken cancellationToken = default) + { + using var scope = _deploymentStackClientDiagnostics.CreateScope("DeploymentStackResource.ExportTemplate"); + scope.Start(); + try + { + var response = _deploymentStackRestClient.ExportTemplateAtScope(Id.Parent, Id.Name, cancellationToken); + return response; + } + catch (Exception e) + { + scope.Failed(e); + throw; + } + } + + /// + /// Runs preflight validation on the specific scoped Deployment stack template to verify its acceptance to Azure Resource Manager. + /// + /// + /// Request Path + /// /{scope}/providers/Microsoft.Resources/deploymentStacks/{deploymentStackName}/validate + /// + /// + /// Operation Id + /// DeploymentStacks_ValidateStackAtScope + /// + /// + /// Default Api Version + /// 2024-03-01 + /// + /// + /// Resource + /// + /// + /// + /// + /// if the method should wait to return until the long-running operation has completed on the service; if it should return after starting the operation. For more information on long-running operations, please see Azure.Core Long-Running Operation samples. + /// Deployment stack to validate. + /// The cancellation token to use. + /// is null. + public virtual async Task> ValidateStackAsync(WaitUntil waitUntil, DeploymentStackData data, CancellationToken cancellationToken = default) + { + Argument.AssertNotNull(data, nameof(data)); + + using var scope = _deploymentStackClientDiagnostics.CreateScope("DeploymentStackResource.ValidateStack"); + scope.Start(); + try + { + var response = await _deploymentStackRestClient.ValidateStackAtScopeAsync(Id.Parent, Id.Name, data, cancellationToken).ConfigureAwait(false); + var operation = new ResourcesArmOperation(new DeploymentStackValidateResultOperationSource(), _deploymentStackClientDiagnostics, Pipeline, _deploymentStackRestClient.CreateValidateStackAtScopeRequest(Id.Parent, Id.Name, data).Request, response, OperationFinalStateVia.Location); + if (waitUntil == WaitUntil.Completed) + await operation.WaitForCompletionAsync(cancellationToken).ConfigureAwait(false); + return operation; + } + catch (Exception e) + { + scope.Failed(e); + throw; + } + } + + /// + /// Runs preflight validation on the specific scoped Deployment stack template to verify its acceptance to Azure Resource Manager. + /// + /// + /// Request Path + /// /{scope}/providers/Microsoft.Resources/deploymentStacks/{deploymentStackName}/validate + /// + /// + /// Operation Id + /// DeploymentStacks_ValidateStackAtScope + /// + /// + /// Default Api Version + /// 2024-03-01 + /// + /// + /// Resource + /// + /// + /// + /// + /// if the method should wait to return until the long-running operation has completed on the service; if it should return after starting the operation. For more information on long-running operations, please see Azure.Core Long-Running Operation samples. + /// Deployment stack to validate. + /// The cancellation token to use. + /// is null. + public virtual ArmOperation ValidateStack(WaitUntil waitUntil, DeploymentStackData data, CancellationToken cancellationToken = default) + { + Argument.AssertNotNull(data, nameof(data)); + + using var scope = _deploymentStackClientDiagnostics.CreateScope("DeploymentStackResource.ValidateStack"); + scope.Start(); + try + { + var response = _deploymentStackRestClient.ValidateStackAtScope(Id.Parent, Id.Name, data, cancellationToken); + var operation = new ResourcesArmOperation(new DeploymentStackValidateResultOperationSource(), _deploymentStackClientDiagnostics, Pipeline, _deploymentStackRestClient.CreateValidateStackAtScopeRequest(Id.Parent, Id.Name, data).Request, response, OperationFinalStateVia.Location); + if (waitUntil == WaitUntil.Completed) + operation.WaitForCompletion(cancellationToken); + return operation; + } + catch (Exception e) + { + scope.Failed(e); + throw; + } + } + + /// + /// Add a tag to the current resource. + /// + /// + /// Request Path + /// /{scope}/providers/Microsoft.Resources/deploymentStacks/{deploymentStackName} + /// + /// + /// Operation Id + /// DeploymentStacks_GetAtScope + /// + /// + /// Default Api Version + /// 2024-03-01 + /// + /// + /// Resource + /// + /// + /// + /// + /// The key for the tag. + /// The value for the tag. + /// The cancellation token to use. + /// or is null. + public virtual async Task> AddTagAsync(string key, string value, CancellationToken cancellationToken = default) + { + Argument.AssertNotNull(key, nameof(key)); + Argument.AssertNotNull(value, nameof(value)); + + using var scope = _deploymentStackClientDiagnostics.CreateScope("DeploymentStackResource.AddTag"); + scope.Start(); + try + { + if (await CanUseTagResourceAsync(cancellationToken: cancellationToken).ConfigureAwait(false)) + { + var originalTags = await GetTagResource().GetAsync(cancellationToken).ConfigureAwait(false); + originalTags.Value.Data.TagValues[key] = value; + await GetTagResource().CreateOrUpdateAsync(WaitUntil.Completed, originalTags.Value.Data, cancellationToken: cancellationToken).ConfigureAwait(false); + var originalResponse = await _deploymentStackRestClient.GetAtScopeAsync(Id.Parent, Id.Name, cancellationToken).ConfigureAwait(false); + return Response.FromValue(new DeploymentStackResource(Client, originalResponse.Value), originalResponse.GetRawResponse()); + } + else + { + var current = (await GetAsync(cancellationToken: cancellationToken).ConfigureAwait(false)).Value.Data; + current.Tags[key] = value; + var result = await UpdateAsync(WaitUntil.Completed, current, cancellationToken: cancellationToken).ConfigureAwait(false); + return Response.FromValue(result.Value, result.GetRawResponse()); + } + } + catch (Exception e) + { + scope.Failed(e); + throw; + } + } + + /// + /// Add a tag to the current resource. + /// + /// + /// Request Path + /// /{scope}/providers/Microsoft.Resources/deploymentStacks/{deploymentStackName} + /// + /// + /// Operation Id + /// DeploymentStacks_GetAtScope + /// + /// + /// Default Api Version + /// 2024-03-01 + /// + /// + /// Resource + /// + /// + /// + /// + /// The key for the tag. + /// The value for the tag. + /// The cancellation token to use. + /// or is null. + public virtual Response AddTag(string key, string value, CancellationToken cancellationToken = default) + { + Argument.AssertNotNull(key, nameof(key)); + Argument.AssertNotNull(value, nameof(value)); + + using var scope = _deploymentStackClientDiagnostics.CreateScope("DeploymentStackResource.AddTag"); + scope.Start(); + try + { + if (CanUseTagResource(cancellationToken: cancellationToken)) + { + var originalTags = GetTagResource().Get(cancellationToken); + originalTags.Value.Data.TagValues[key] = value; + GetTagResource().CreateOrUpdate(WaitUntil.Completed, originalTags.Value.Data, cancellationToken: cancellationToken); + var originalResponse = _deploymentStackRestClient.GetAtScope(Id.Parent, Id.Name, cancellationToken); + return Response.FromValue(new DeploymentStackResource(Client, originalResponse.Value), originalResponse.GetRawResponse()); + } + else + { + var current = Get(cancellationToken: cancellationToken).Value.Data; + current.Tags[key] = value; + var result = Update(WaitUntil.Completed, current, cancellationToken: cancellationToken); + return Response.FromValue(result.Value, result.GetRawResponse()); + } + } + catch (Exception e) + { + scope.Failed(e); + throw; + } + } + + /// + /// Replace the tags on the resource with the given set. + /// + /// + /// Request Path + /// /{scope}/providers/Microsoft.Resources/deploymentStacks/{deploymentStackName} + /// + /// + /// Operation Id + /// DeploymentStacks_GetAtScope + /// + /// + /// Default Api Version + /// 2024-03-01 + /// + /// + /// Resource + /// + /// + /// + /// + /// The set of tags to use as replacement. + /// The cancellation token to use. + /// is null. + public virtual async Task> SetTagsAsync(IDictionary tags, CancellationToken cancellationToken = default) + { + Argument.AssertNotNull(tags, nameof(tags)); + + using var scope = _deploymentStackClientDiagnostics.CreateScope("DeploymentStackResource.SetTags"); + scope.Start(); + try + { + if (await CanUseTagResourceAsync(cancellationToken: cancellationToken).ConfigureAwait(false)) + { + await GetTagResource().DeleteAsync(WaitUntil.Completed, cancellationToken: cancellationToken).ConfigureAwait(false); + var originalTags = await GetTagResource().GetAsync(cancellationToken).ConfigureAwait(false); + originalTags.Value.Data.TagValues.ReplaceWith(tags); + await GetTagResource().CreateOrUpdateAsync(WaitUntil.Completed, originalTags.Value.Data, cancellationToken: cancellationToken).ConfigureAwait(false); + var originalResponse = await _deploymentStackRestClient.GetAtScopeAsync(Id.Parent, Id.Name, cancellationToken).ConfigureAwait(false); + return Response.FromValue(new DeploymentStackResource(Client, originalResponse.Value), originalResponse.GetRawResponse()); + } + else + { + var current = (await GetAsync(cancellationToken: cancellationToken).ConfigureAwait(false)).Value.Data; + current.Tags.ReplaceWith(tags); + var result = await UpdateAsync(WaitUntil.Completed, current, cancellationToken: cancellationToken).ConfigureAwait(false); + return Response.FromValue(result.Value, result.GetRawResponse()); + } + } + catch (Exception e) + { + scope.Failed(e); + throw; + } + } + + /// + /// Replace the tags on the resource with the given set. + /// + /// + /// Request Path + /// /{scope}/providers/Microsoft.Resources/deploymentStacks/{deploymentStackName} + /// + /// + /// Operation Id + /// DeploymentStacks_GetAtScope + /// + /// + /// Default Api Version + /// 2024-03-01 + /// + /// + /// Resource + /// + /// + /// + /// + /// The set of tags to use as replacement. + /// The cancellation token to use. + /// is null. + public virtual Response SetTags(IDictionary tags, CancellationToken cancellationToken = default) + { + Argument.AssertNotNull(tags, nameof(tags)); + + using var scope = _deploymentStackClientDiagnostics.CreateScope("DeploymentStackResource.SetTags"); + scope.Start(); + try + { + if (CanUseTagResource(cancellationToken: cancellationToken)) + { + GetTagResource().Delete(WaitUntil.Completed, cancellationToken: cancellationToken); + var originalTags = GetTagResource().Get(cancellationToken); + originalTags.Value.Data.TagValues.ReplaceWith(tags); + GetTagResource().CreateOrUpdate(WaitUntil.Completed, originalTags.Value.Data, cancellationToken: cancellationToken); + var originalResponse = _deploymentStackRestClient.GetAtScope(Id.Parent, Id.Name, cancellationToken); + return Response.FromValue(new DeploymentStackResource(Client, originalResponse.Value), originalResponse.GetRawResponse()); + } + else + { + var current = Get(cancellationToken: cancellationToken).Value.Data; + current.Tags.ReplaceWith(tags); + var result = Update(WaitUntil.Completed, current, cancellationToken: cancellationToken); + return Response.FromValue(result.Value, result.GetRawResponse()); + } + } + catch (Exception e) + { + scope.Failed(e); + throw; + } + } + + /// + /// Removes a tag by key from the resource. + /// + /// + /// Request Path + /// /{scope}/providers/Microsoft.Resources/deploymentStacks/{deploymentStackName} + /// + /// + /// Operation Id + /// DeploymentStacks_GetAtScope + /// + /// + /// Default Api Version + /// 2024-03-01 + /// + /// + /// Resource + /// + /// + /// + /// + /// The key for the tag. + /// The cancellation token to use. + /// is null. + public virtual async Task> RemoveTagAsync(string key, CancellationToken cancellationToken = default) + { + Argument.AssertNotNull(key, nameof(key)); + + using var scope = _deploymentStackClientDiagnostics.CreateScope("DeploymentStackResource.RemoveTag"); + scope.Start(); + try + { + if (await CanUseTagResourceAsync(cancellationToken: cancellationToken).ConfigureAwait(false)) + { + var originalTags = await GetTagResource().GetAsync(cancellationToken).ConfigureAwait(false); + originalTags.Value.Data.TagValues.Remove(key); + await GetTagResource().CreateOrUpdateAsync(WaitUntil.Completed, originalTags.Value.Data, cancellationToken: cancellationToken).ConfigureAwait(false); + var originalResponse = await _deploymentStackRestClient.GetAtScopeAsync(Id.Parent, Id.Name, cancellationToken).ConfigureAwait(false); + return Response.FromValue(new DeploymentStackResource(Client, originalResponse.Value), originalResponse.GetRawResponse()); + } + else + { + var current = (await GetAsync(cancellationToken: cancellationToken).ConfigureAwait(false)).Value.Data; + current.Tags.Remove(key); + var result = await UpdateAsync(WaitUntil.Completed, current, cancellationToken: cancellationToken).ConfigureAwait(false); + return Response.FromValue(result.Value, result.GetRawResponse()); + } + } + catch (Exception e) + { + scope.Failed(e); + throw; + } + } + + /// + /// Removes a tag by key from the resource. + /// + /// + /// Request Path + /// /{scope}/providers/Microsoft.Resources/deploymentStacks/{deploymentStackName} + /// + /// + /// Operation Id + /// DeploymentStacks_GetAtScope + /// + /// + /// Default Api Version + /// 2024-03-01 + /// + /// + /// Resource + /// + /// + /// + /// + /// The key for the tag. + /// The cancellation token to use. + /// is null. + public virtual Response RemoveTag(string key, CancellationToken cancellationToken = default) + { + Argument.AssertNotNull(key, nameof(key)); + + using var scope = _deploymentStackClientDiagnostics.CreateScope("DeploymentStackResource.RemoveTag"); + scope.Start(); + try + { + if (CanUseTagResource(cancellationToken: cancellationToken)) + { + var originalTags = GetTagResource().Get(cancellationToken); + originalTags.Value.Data.TagValues.Remove(key); + GetTagResource().CreateOrUpdate(WaitUntil.Completed, originalTags.Value.Data, cancellationToken: cancellationToken); + var originalResponse = _deploymentStackRestClient.GetAtScope(Id.Parent, Id.Name, cancellationToken); + return Response.FromValue(new DeploymentStackResource(Client, originalResponse.Value), originalResponse.GetRawResponse()); + } + else + { + var current = Get(cancellationToken: cancellationToken).Value.Data; + current.Tags.Remove(key); + var result = Update(WaitUntil.Completed, current, cancellationToken: cancellationToken); + return Response.FromValue(result.Value, result.GetRawResponse()); + } + } + catch (Exception e) + { + scope.Failed(e); + throw; + } + } + } +} diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Extensions/MockableResourcesArmClient.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Extensions/MockableResourcesArmClient.cs index 64ac6a54cd25d..3e29a2690d062 100644 --- a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Extensions/MockableResourcesArmClient.cs +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Extensions/MockableResourcesArmClient.cs @@ -129,5 +129,17 @@ public virtual JitRequestResource GetJitRequestResource(ResourceIdentifier id) JitRequestResource.ValidateResourceId(id); return new JitRequestResource(Client, id); } + + /// + /// Gets an object representing a along with the instance operations that can be performed on it but with no data. + /// You can use to create a from its components. + /// + /// The resource ID of the resource to get. + /// Returns a object. + public virtual DeploymentStackResource GetDeploymentStackResource(ResourceIdentifier id) + { + DeploymentStackResource.ValidateResourceId(id); + return new DeploymentStackResource(Client, id); + } } } diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Extensions/MockableResourcesManagementGroupResource.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Extensions/MockableResourcesManagementGroupResource.cs index 2443bf69f6829..db346608464c2 100644 --- a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Extensions/MockableResourcesManagementGroupResource.cs +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Extensions/MockableResourcesManagementGroupResource.cs @@ -53,7 +53,7 @@ public virtual ArmDeploymentCollection GetArmDeployments() /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -84,7 +84,7 @@ public virtual async Task> GetArmDeploymentAsync /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -101,5 +101,74 @@ public virtual Response GetArmDeployment(string deploymen { return GetArmDeployments().Get(deploymentName, cancellationToken); } + + /// Gets a collection of DeploymentStackResources in the ManagementGroupResource. + /// An object representing collection of DeploymentStackResources and their operations over a DeploymentStackResource. + public virtual DeploymentStackCollection GetDeploymentStacks() + { + return GetCachedClient(client => new DeploymentStackCollection(client, Id)); + } + + /// + /// Gets a Deployment stack with a given name at specific scope. + /// + /// + /// Request Path + /// /{scope}/providers/Microsoft.Resources/deploymentStacks/{deploymentStackName} + /// + /// + /// Operation Id + /// DeploymentStacks_GetAtScope + /// + /// + /// Default Api Version + /// 2024-03-01 + /// + /// + /// Resource + /// + /// + /// + /// + /// Name of the deployment stack. + /// The cancellation token to use. + /// is null. + /// is an empty string, and was expected to be non-empty. + [ForwardsClientCalls] + public virtual async Task> GetDeploymentStackAsync(string deploymentStackName, CancellationToken cancellationToken = default) + { + return await GetDeploymentStacks().GetAsync(deploymentStackName, cancellationToken).ConfigureAwait(false); + } + + /// + /// Gets a Deployment stack with a given name at specific scope. + /// + /// + /// Request Path + /// /{scope}/providers/Microsoft.Resources/deploymentStacks/{deploymentStackName} + /// + /// + /// Operation Id + /// DeploymentStacks_GetAtScope + /// + /// + /// Default Api Version + /// 2024-03-01 + /// + /// + /// Resource + /// + /// + /// + /// + /// Name of the deployment stack. + /// The cancellation token to use. + /// is null. + /// is an empty string, and was expected to be non-empty. + [ForwardsClientCalls] + public virtual Response GetDeploymentStack(string deploymentStackName, CancellationToken cancellationToken = default) + { + return GetDeploymentStacks().Get(deploymentStackName, cancellationToken); + } } } diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Extensions/MockableResourcesResourceGroupResource.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Extensions/MockableResourcesResourceGroupResource.cs index e181c9315fa90..6bdcc9a0735a1 100644 --- a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Extensions/MockableResourcesResourceGroupResource.cs +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Extensions/MockableResourcesResourceGroupResource.cs @@ -194,7 +194,7 @@ public virtual ArmDeploymentCollection GetArmDeployments() /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -225,7 +225,7 @@ public virtual async Task> GetArmDeploymentAsync /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -449,5 +449,74 @@ public virtual Response GetJitRequest(string jitRequestName, { return GetJitRequests().Get(jitRequestName, cancellationToken); } + + /// Gets a collection of DeploymentStackResources in the ResourceGroupResource. + /// An object representing collection of DeploymentStackResources and their operations over a DeploymentStackResource. + public virtual DeploymentStackCollection GetDeploymentStacks() + { + return GetCachedClient(client => new DeploymentStackCollection(client, Id)); + } + + /// + /// Gets a Deployment stack with a given name at specific scope. + /// + /// + /// Request Path + /// /{scope}/providers/Microsoft.Resources/deploymentStacks/{deploymentStackName} + /// + /// + /// Operation Id + /// DeploymentStacks_GetAtScope + /// + /// + /// Default Api Version + /// 2024-03-01 + /// + /// + /// Resource + /// + /// + /// + /// + /// Name of the deployment stack. + /// The cancellation token to use. + /// is null. + /// is an empty string, and was expected to be non-empty. + [ForwardsClientCalls] + public virtual async Task> GetDeploymentStackAsync(string deploymentStackName, CancellationToken cancellationToken = default) + { + return await GetDeploymentStacks().GetAsync(deploymentStackName, cancellationToken).ConfigureAwait(false); + } + + /// + /// Gets a Deployment stack with a given name at specific scope. + /// + /// + /// Request Path + /// /{scope}/providers/Microsoft.Resources/deploymentStacks/{deploymentStackName} + /// + /// + /// Operation Id + /// DeploymentStacks_GetAtScope + /// + /// + /// Default Api Version + /// 2024-03-01 + /// + /// + /// Resource + /// + /// + /// + /// + /// Name of the deployment stack. + /// The cancellation token to use. + /// is null. + /// is an empty string, and was expected to be non-empty. + [ForwardsClientCalls] + public virtual Response GetDeploymentStack(string deploymentStackName, CancellationToken cancellationToken = default) + { + return GetDeploymentStacks().Get(deploymentStackName, cancellationToken); + } } } diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Extensions/MockableResourcesSubscriptionResource.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Extensions/MockableResourcesSubscriptionResource.cs index 0de7283b20b69..ea1f959ac617d 100644 --- a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Extensions/MockableResourcesSubscriptionResource.cs +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Extensions/MockableResourcesSubscriptionResource.cs @@ -78,7 +78,7 @@ public virtual ArmDeploymentCollection GetArmDeployments() /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -109,7 +109,7 @@ public virtual async Task> GetArmDeploymentAsync /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -127,6 +127,75 @@ public virtual Response GetArmDeployment(string deploymen return GetArmDeployments().Get(deploymentName, cancellationToken); } + /// Gets a collection of DeploymentStackResources in the SubscriptionResource. + /// An object representing collection of DeploymentStackResources and their operations over a DeploymentStackResource. + public virtual DeploymentStackCollection GetDeploymentStacks() + { + return GetCachedClient(client => new DeploymentStackCollection(client, Id)); + } + + /// + /// Gets a Deployment stack with a given name at specific scope. + /// + /// + /// Request Path + /// /{scope}/providers/Microsoft.Resources/deploymentStacks/{deploymentStackName} + /// + /// + /// Operation Id + /// DeploymentStacks_GetAtScope + /// + /// + /// Default Api Version + /// 2024-03-01 + /// + /// + /// Resource + /// + /// + /// + /// + /// Name of the deployment stack. + /// The cancellation token to use. + /// is null. + /// is an empty string, and was expected to be non-empty. + [ForwardsClientCalls] + public virtual async Task> GetDeploymentStackAsync(string deploymentStackName, CancellationToken cancellationToken = default) + { + return await GetDeploymentStacks().GetAsync(deploymentStackName, cancellationToken).ConfigureAwait(false); + } + + /// + /// Gets a Deployment stack with a given name at specific scope. + /// + /// + /// Request Path + /// /{scope}/providers/Microsoft.Resources/deploymentStacks/{deploymentStackName} + /// + /// + /// Operation Id + /// DeploymentStacks_GetAtScope + /// + /// + /// Default Api Version + /// 2024-03-01 + /// + /// + /// Resource + /// + /// + /// + /// + /// Name of the deployment stack. + /// The cancellation token to use. + /// is null. + /// is an empty string, and was expected to be non-empty. + [ForwardsClientCalls] + public virtual Response GetDeploymentStack(string deploymentStackName, CancellationToken cancellationToken = default) + { + return GetDeploymentStacks().Get(deploymentStackName, cancellationToken); + } + /// /// Lists all the Template Specs within the specified subscriptions. /// diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Extensions/MockableResourcesTenantResource.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Extensions/MockableResourcesTenantResource.cs index f85a4cc5e69ac..e2d6772f74f5e 100644 --- a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Extensions/MockableResourcesTenantResource.cs +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Extensions/MockableResourcesTenantResource.cs @@ -61,7 +61,7 @@ public virtual ArmDeploymentCollection GetArmDeployments() /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -92,7 +92,7 @@ public virtual async Task> GetArmDeploymentAsync /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -123,7 +123,7 @@ public virtual Response GetArmDeployment(string deploymen /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -165,7 +165,7 @@ public virtual async Task> CalculateDeploymentTempl /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Extensions/ResourcesExtensions.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Extensions/ResourcesExtensions.cs index 70f2b84a07ffa..7ab531c5154d6 100644 --- a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Extensions/ResourcesExtensions.cs +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Extensions/ResourcesExtensions.cs @@ -195,6 +195,25 @@ public static JitRequestResource GetJitRequestResource(this ArmClient client, Re return GetMockableResourcesArmClient(client).GetJitRequestResource(id); } + /// + /// Gets an object representing a along with the instance operations that can be performed on it but with no data. + /// You can use to create a from its components. + /// + /// Mocking + /// To mock this method, please mock instead. + /// + /// + /// The instance the method will execute against. + /// The resource ID of the resource to get. + /// is null. + /// Returns a object. + public static DeploymentStackResource GetDeploymentStackResource(this ArmClient client, ResourceIdentifier id) + { + Argument.AssertNotNull(client, nameof(client)); + + return GetMockableResourcesArmClient(client).GetDeploymentStackResource(id); + } + /// /// Gets a collection of ArmDeploymentResources in the ManagementGroupResource. /// @@ -225,7 +244,7 @@ public static ArmDeploymentCollection GetArmDeployments(this ManagementGroupReso /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -263,7 +282,7 @@ public static async Task> GetArmDeploymentAsync( /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -288,6 +307,99 @@ public static Response GetArmDeployment(this ManagementGr return GetMockableResourcesManagementGroupResource(managementGroupResource).GetArmDeployment(deploymentName, cancellationToken); } + /// + /// Gets a collection of DeploymentStackResources in the ManagementGroupResource. + /// + /// Mocking + /// To mock this method, please mock instead. + /// + /// + /// The instance the method will execute against. + /// is null. + /// An object representing collection of DeploymentStackResources and their operations over a DeploymentStackResource. + public static DeploymentStackCollection GetDeploymentStacks(this ManagementGroupResource managementGroupResource) + { + Argument.AssertNotNull(managementGroupResource, nameof(managementGroupResource)); + + return GetMockableResourcesManagementGroupResource(managementGroupResource).GetDeploymentStacks(); + } + + /// + /// Gets a Deployment stack with a given name at specific scope. + /// + /// + /// Request Path + /// /{scope}/providers/Microsoft.Resources/deploymentStacks/{deploymentStackName} + /// + /// + /// Operation Id + /// DeploymentStacks_GetAtScope + /// + /// + /// Default Api Version + /// 2024-03-01 + /// + /// + /// Resource + /// + /// + /// + /// + /// Mocking + /// To mock this method, please mock instead. + /// + /// + /// The instance the method will execute against. + /// Name of the deployment stack. + /// The cancellation token to use. + /// or is null. + /// is an empty string, and was expected to be non-empty. + [ForwardsClientCalls] + public static async Task> GetDeploymentStackAsync(this ManagementGroupResource managementGroupResource, string deploymentStackName, CancellationToken cancellationToken = default) + { + Argument.AssertNotNull(managementGroupResource, nameof(managementGroupResource)); + + return await GetMockableResourcesManagementGroupResource(managementGroupResource).GetDeploymentStackAsync(deploymentStackName, cancellationToken).ConfigureAwait(false); + } + + /// + /// Gets a Deployment stack with a given name at specific scope. + /// + /// + /// Request Path + /// /{scope}/providers/Microsoft.Resources/deploymentStacks/{deploymentStackName} + /// + /// + /// Operation Id + /// DeploymentStacks_GetAtScope + /// + /// + /// Default Api Version + /// 2024-03-01 + /// + /// + /// Resource + /// + /// + /// + /// + /// Mocking + /// To mock this method, please mock instead. + /// + /// + /// The instance the method will execute against. + /// Name of the deployment stack. + /// The cancellation token to use. + /// or is null. + /// is an empty string, and was expected to be non-empty. + [ForwardsClientCalls] + public static Response GetDeploymentStack(this ManagementGroupResource managementGroupResource, string deploymentStackName, CancellationToken cancellationToken = default) + { + Argument.AssertNotNull(managementGroupResource, nameof(managementGroupResource)); + + return GetMockableResourcesManagementGroupResource(managementGroupResource).GetDeploymentStack(deploymentStackName, cancellationToken); + } + /// /// Gets a collection of TemplateSpecResources in the ResourceGroupResource. /// @@ -506,7 +618,7 @@ public static ArmDeploymentCollection GetArmDeployments(this ResourceGroupResour /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -544,7 +656,7 @@ public static async Task> GetArmDeploymentAsync( /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -848,6 +960,99 @@ public static Response GetJitRequest(this ResourceGroupResou return GetMockableResourcesResourceGroupResource(resourceGroupResource).GetJitRequest(jitRequestName, cancellationToken); } + /// + /// Gets a collection of DeploymentStackResources in the ResourceGroupResource. + /// + /// Mocking + /// To mock this method, please mock instead. + /// + /// + /// The instance the method will execute against. + /// is null. + /// An object representing collection of DeploymentStackResources and their operations over a DeploymentStackResource. + public static DeploymentStackCollection GetDeploymentStacks(this ResourceGroupResource resourceGroupResource) + { + Argument.AssertNotNull(resourceGroupResource, nameof(resourceGroupResource)); + + return GetMockableResourcesResourceGroupResource(resourceGroupResource).GetDeploymentStacks(); + } + + /// + /// Gets a Deployment stack with a given name at specific scope. + /// + /// + /// Request Path + /// /{scope}/providers/Microsoft.Resources/deploymentStacks/{deploymentStackName} + /// + /// + /// Operation Id + /// DeploymentStacks_GetAtScope + /// + /// + /// Default Api Version + /// 2024-03-01 + /// + /// + /// Resource + /// + /// + /// + /// + /// Mocking + /// To mock this method, please mock instead. + /// + /// + /// The instance the method will execute against. + /// Name of the deployment stack. + /// The cancellation token to use. + /// or is null. + /// is an empty string, and was expected to be non-empty. + [ForwardsClientCalls] + public static async Task> GetDeploymentStackAsync(this ResourceGroupResource resourceGroupResource, string deploymentStackName, CancellationToken cancellationToken = default) + { + Argument.AssertNotNull(resourceGroupResource, nameof(resourceGroupResource)); + + return await GetMockableResourcesResourceGroupResource(resourceGroupResource).GetDeploymentStackAsync(deploymentStackName, cancellationToken).ConfigureAwait(false); + } + + /// + /// Gets a Deployment stack with a given name at specific scope. + /// + /// + /// Request Path + /// /{scope}/providers/Microsoft.Resources/deploymentStacks/{deploymentStackName} + /// + /// + /// Operation Id + /// DeploymentStacks_GetAtScope + /// + /// + /// Default Api Version + /// 2024-03-01 + /// + /// + /// Resource + /// + /// + /// + /// + /// Mocking + /// To mock this method, please mock instead. + /// + /// + /// The instance the method will execute against. + /// Name of the deployment stack. + /// The cancellation token to use. + /// or is null. + /// is an empty string, and was expected to be non-empty. + [ForwardsClientCalls] + public static Response GetDeploymentStack(this ResourceGroupResource resourceGroupResource, string deploymentStackName, CancellationToken cancellationToken = default) + { + Argument.AssertNotNull(resourceGroupResource, nameof(resourceGroupResource)); + + return GetMockableResourcesResourceGroupResource(resourceGroupResource).GetDeploymentStack(deploymentStackName, cancellationToken); + } + /// /// Gets a collection of ArmDeploymentResources in the SubscriptionResource. /// @@ -878,7 +1083,7 @@ public static ArmDeploymentCollection GetArmDeployments(this SubscriptionResourc /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -916,7 +1121,7 @@ public static async Task> GetArmDeploymentAsync( /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -941,6 +1146,99 @@ public static Response GetArmDeployment(this Subscription return GetMockableResourcesSubscriptionResource(subscriptionResource).GetArmDeployment(deploymentName, cancellationToken); } + /// + /// Gets a collection of DeploymentStackResources in the SubscriptionResource. + /// + /// Mocking + /// To mock this method, please mock instead. + /// + /// + /// The instance the method will execute against. + /// is null. + /// An object representing collection of DeploymentStackResources and their operations over a DeploymentStackResource. + public static DeploymentStackCollection GetDeploymentStacks(this SubscriptionResource subscriptionResource) + { + Argument.AssertNotNull(subscriptionResource, nameof(subscriptionResource)); + + return GetMockableResourcesSubscriptionResource(subscriptionResource).GetDeploymentStacks(); + } + + /// + /// Gets a Deployment stack with a given name at specific scope. + /// + /// + /// Request Path + /// /{scope}/providers/Microsoft.Resources/deploymentStacks/{deploymentStackName} + /// + /// + /// Operation Id + /// DeploymentStacks_GetAtScope + /// + /// + /// Default Api Version + /// 2024-03-01 + /// + /// + /// Resource + /// + /// + /// + /// + /// Mocking + /// To mock this method, please mock instead. + /// + /// + /// The instance the method will execute against. + /// Name of the deployment stack. + /// The cancellation token to use. + /// or is null. + /// is an empty string, and was expected to be non-empty. + [ForwardsClientCalls] + public static async Task> GetDeploymentStackAsync(this SubscriptionResource subscriptionResource, string deploymentStackName, CancellationToken cancellationToken = default) + { + Argument.AssertNotNull(subscriptionResource, nameof(subscriptionResource)); + + return await GetMockableResourcesSubscriptionResource(subscriptionResource).GetDeploymentStackAsync(deploymentStackName, cancellationToken).ConfigureAwait(false); + } + + /// + /// Gets a Deployment stack with a given name at specific scope. + /// + /// + /// Request Path + /// /{scope}/providers/Microsoft.Resources/deploymentStacks/{deploymentStackName} + /// + /// + /// Operation Id + /// DeploymentStacks_GetAtScope + /// + /// + /// Default Api Version + /// 2024-03-01 + /// + /// + /// Resource + /// + /// + /// + /// + /// Mocking + /// To mock this method, please mock instead. + /// + /// + /// The instance the method will execute against. + /// Name of the deployment stack. + /// The cancellation token to use. + /// or is null. + /// is an empty string, and was expected to be non-empty. + [ForwardsClientCalls] + public static Response GetDeploymentStack(this SubscriptionResource subscriptionResource, string deploymentStackName, CancellationToken cancellationToken = default) + { + Argument.AssertNotNull(subscriptionResource, nameof(subscriptionResource)); + + return GetMockableResourcesSubscriptionResource(subscriptionResource).GetDeploymentStack(deploymentStackName, cancellationToken); + } + /// /// Lists all the Template Specs within the specified subscriptions. /// @@ -1325,7 +1623,7 @@ public static ArmDeploymentCollection GetArmDeployments(this TenantResource tena /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -1363,7 +1661,7 @@ public static async Task> GetArmDeploymentAsync( /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -1401,7 +1699,7 @@ public static Response GetArmDeployment(this TenantResour /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource @@ -1437,7 +1735,7 @@ public static async Task> CalculateDeploymentTempla /// /// /// Default Api Version - /// 2022-09-01 + /// 2024-03-01 /// /// /// Resource diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/LongRunningOperation/DeploymentStackOperationSource.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/LongRunningOperation/DeploymentStackOperationSource.cs new file mode 100644 index 0000000000000..24d61a2df9aa0 --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/LongRunningOperation/DeploymentStackOperationSource.cs @@ -0,0 +1,38 @@ +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. + +// + +#nullable disable + +using System.Text.Json; +using System.Threading; +using System.Threading.Tasks; +using Azure.Core; + +namespace Azure.ResourceManager.Resources +{ + internal class DeploymentStackOperationSource : IOperationSource + { + private readonly ArmClient _client; + + internal DeploymentStackOperationSource(ArmClient client) + { + _client = client; + } + + DeploymentStackResource IOperationSource.CreateResult(Response response, CancellationToken cancellationToken) + { + using var document = JsonDocument.Parse(response.ContentStream); + var data = DeploymentStackData.DeserializeDeploymentStackData(document.RootElement); + return new DeploymentStackResource(_client, data); + } + + async ValueTask IOperationSource.CreateResultAsync(Response response, CancellationToken cancellationToken) + { + using var document = await JsonDocument.ParseAsync(response.ContentStream, default, cancellationToken).ConfigureAwait(false); + var data = DeploymentStackData.DeserializeDeploymentStackData(document.RootElement); + return new DeploymentStackResource(_client, data); + } + } +} diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/LongRunningOperation/DeploymentStackValidateResultOperationSource.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/LongRunningOperation/DeploymentStackValidateResultOperationSource.cs new file mode 100644 index 0000000000000..fbbceab1542f4 --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/LongRunningOperation/DeploymentStackValidateResultOperationSource.cs @@ -0,0 +1,30 @@ +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. + +// + +#nullable disable + +using System.Text.Json; +using System.Threading; +using System.Threading.Tasks; +using Azure.Core; +using Azure.ResourceManager.Resources.Models; + +namespace Azure.ResourceManager.Resources +{ + internal class DeploymentStackValidateResultOperationSource : IOperationSource + { + DeploymentStackValidateResult IOperationSource.CreateResult(Response response, CancellationToken cancellationToken) + { + using var document = JsonDocument.Parse(response.ContentStream); + return DeploymentStackValidateResult.DeserializeDeploymentStackValidateResult(document.RootElement); + } + + async ValueTask IOperationSource.CreateResultAsync(Response response, CancellationToken cancellationToken) + { + using var document = await JsonDocument.ParseAsync(response.ContentStream, default, cancellationToken).ConfigureAwait(false); + return DeploymentStackValidateResult.DeserializeDeploymentStackValidateResult(document.RootElement); + } + } +} diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/ActionOnUnmanage.Serialization.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/ActionOnUnmanage.Serialization.cs new file mode 100644 index 0000000000000..fd97fd37c2ff5 --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/ActionOnUnmanage.Serialization.cs @@ -0,0 +1,209 @@ +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. + +// + +#nullable disable + +using System; +using System.ClientModel.Primitives; +using System.Collections.Generic; +using System.Text; +using System.Text.Json; +using Azure.Core; + +namespace Azure.ResourceManager.Resources.Models +{ + public partial class ActionOnUnmanage : IUtf8JsonSerializable, IJsonModel + { + void IUtf8JsonSerializable.Write(Utf8JsonWriter writer) => ((IJsonModel)this).Write(writer, ModelSerializationExtensions.WireOptions); + + void IJsonModel.Write(Utf8JsonWriter writer, ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + if (format != "J") + { + throw new FormatException($"The model {nameof(ActionOnUnmanage)} does not support writing '{format}' format."); + } + + writer.WriteStartObject(); + writer.WritePropertyName("resources"u8); + writer.WriteStringValue(Resources.ToString()); + if (Optional.IsDefined(ResourceGroups)) + { + writer.WritePropertyName("resourceGroups"u8); + writer.WriteStringValue(ResourceGroups.Value.ToString()); + } + if (Optional.IsDefined(ManagementGroups)) + { + writer.WritePropertyName("managementGroups"u8); + writer.WriteStringValue(ManagementGroups.Value.ToString()); + } + if (options.Format != "W" && _serializedAdditionalRawData != null) + { + foreach (var item in _serializedAdditionalRawData) + { + writer.WritePropertyName(item.Key); +#if NET6_0_OR_GREATER + writer.WriteRawValue(item.Value); +#else + using (JsonDocument document = JsonDocument.Parse(item.Value)) + { + JsonSerializer.Serialize(writer, document.RootElement); + } +#endif + } + } + writer.WriteEndObject(); + } + + ActionOnUnmanage IJsonModel.Create(ref Utf8JsonReader reader, ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + if (format != "J") + { + throw new FormatException($"The model {nameof(ActionOnUnmanage)} does not support reading '{format}' format."); + } + + using JsonDocument document = JsonDocument.ParseValue(ref reader); + return DeserializeActionOnUnmanage(document.RootElement, options); + } + + internal static ActionOnUnmanage DeserializeActionOnUnmanage(JsonElement element, ModelReaderWriterOptions options = null) + { + options ??= ModelSerializationExtensions.WireOptions; + + if (element.ValueKind == JsonValueKind.Null) + { + return null; + } + DeploymentStacksDeleteDetachEnum resources = default; + DeploymentStacksDeleteDetachEnum? resourceGroups = default; + DeploymentStacksDeleteDetachEnum? managementGroups = default; + IDictionary serializedAdditionalRawData = default; + Dictionary rawDataDictionary = new Dictionary(); + foreach (var property in element.EnumerateObject()) + { + if (property.NameEquals("resources"u8)) + { + resources = new DeploymentStacksDeleteDetachEnum(property.Value.GetString()); + continue; + } + if (property.NameEquals("resourceGroups"u8)) + { + if (property.Value.ValueKind == JsonValueKind.Null) + { + continue; + } + resourceGroups = new DeploymentStacksDeleteDetachEnum(property.Value.GetString()); + continue; + } + if (property.NameEquals("managementGroups"u8)) + { + if (property.Value.ValueKind == JsonValueKind.Null) + { + continue; + } + managementGroups = new DeploymentStacksDeleteDetachEnum(property.Value.GetString()); + continue; + } + if (options.Format != "W") + { + rawDataDictionary.Add(property.Name, BinaryData.FromString(property.Value.GetRawText())); + } + } + serializedAdditionalRawData = rawDataDictionary; + return new ActionOnUnmanage(resources, resourceGroups, managementGroups, serializedAdditionalRawData); + } + + private BinaryData SerializeBicep(ModelReaderWriterOptions options) + { + StringBuilder builder = new StringBuilder(); + BicepModelReaderWriterOptions bicepOptions = options as BicepModelReaderWriterOptions; + IDictionary propertyOverrides = null; + bool hasObjectOverride = bicepOptions != null && bicepOptions.PropertyOverrides.TryGetValue(this, out propertyOverrides); + bool hasPropertyOverride = false; + string propertyOverride = null; + + builder.AppendLine("{"); + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(Resources), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" resources: "); + builder.AppendLine(propertyOverride); + } + else + { + builder.Append(" resources: "); + builder.AppendLine($"'{Resources.ToString()}'"); + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(ResourceGroups), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" resourceGroups: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(ResourceGroups)) + { + builder.Append(" resourceGroups: "); + builder.AppendLine($"'{ResourceGroups.Value.ToString()}'"); + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(ManagementGroups), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" managementGroups: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(ManagementGroups)) + { + builder.Append(" managementGroups: "); + builder.AppendLine($"'{ManagementGroups.Value.ToString()}'"); + } + } + + builder.AppendLine("}"); + return BinaryData.FromString(builder.ToString()); + } + + BinaryData IPersistableModel.Write(ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + + switch (format) + { + case "J": + return ModelReaderWriter.Write(this, options); + case "bicep": + return SerializeBicep(options); + default: + throw new FormatException($"The model {nameof(ActionOnUnmanage)} does not support writing '{options.Format}' format."); + } + } + + ActionOnUnmanage IPersistableModel.Create(BinaryData data, ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + + switch (format) + { + case "J": + { + using JsonDocument document = JsonDocument.Parse(data); + return DeserializeActionOnUnmanage(document.RootElement, options); + } + default: + throw new FormatException($"The model {nameof(ActionOnUnmanage)} does not support reading '{options.Format}' format."); + } + } + + string IPersistableModel.GetFormatFromOptions(ModelReaderWriterOptions options) => "J"; + } +} diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/ActionOnUnmanage.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/ActionOnUnmanage.cs new file mode 100644 index 0000000000000..e5bfff9878bd2 --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/ActionOnUnmanage.cs @@ -0,0 +1,83 @@ +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. + +// + +#nullable disable + +using System; +using System.Collections.Generic; + +namespace Azure.ResourceManager.Resources.Models +{ + /// Defines the behavior of resources that are no longer managed after the stack is updated or deleted. + public partial class ActionOnUnmanage + { + /// + /// Keeps track of any properties unknown to the library. + /// + /// To assign an object to the value of this property use . + /// + /// + /// To assign an already formatted json string to this property use . + /// + /// + /// Examples: + /// + /// + /// BinaryData.FromObjectAsJson("foo") + /// Creates a payload of "foo". + /// + /// + /// BinaryData.FromString("\"foo\"") + /// Creates a payload of "foo". + /// + /// + /// BinaryData.FromObjectAsJson(new { key = "value" }) + /// Creates a payload of { "key": "value" }. + /// + /// + /// BinaryData.FromString("{\"key\": \"value\"}") + /// Creates a payload of { "key": "value" }. + /// + /// + /// + /// + private IDictionary _serializedAdditionalRawData; + + /// Initializes a new instance of . + /// Specifies an action for a newly unmanaged resource. Delete will attempt to delete the resource from Azure. Detach will leave the resource in it's current state. + public ActionOnUnmanage(DeploymentStacksDeleteDetachEnum resources) + { + Resources = resources; + } + + /// Initializes a new instance of . + /// Specifies an action for a newly unmanaged resource. Delete will attempt to delete the resource from Azure. Detach will leave the resource in it's current state. + /// Specifies an action for a newly unmanaged resource. Delete will attempt to delete the resource from Azure. Detach will leave the resource in it's current state. + /// Specifies an action for a newly unmanaged resource. Delete will attempt to delete the resource from Azure. Detach will leave the resource in it's current state. + /// Keeps track of any properties unknown to the library. + internal ActionOnUnmanage(DeploymentStacksDeleteDetachEnum resources, DeploymentStacksDeleteDetachEnum? resourceGroups, DeploymentStacksDeleteDetachEnum? managementGroups, IDictionary serializedAdditionalRawData) + { + Resources = resources; + ResourceGroups = resourceGroups; + ManagementGroups = managementGroups; + _serializedAdditionalRawData = serializedAdditionalRawData; + } + + /// Initializes a new instance of for deserialization. + internal ActionOnUnmanage() + { + } + + /// Specifies an action for a newly unmanaged resource. Delete will attempt to delete the resource from Azure. Detach will leave the resource in it's current state. + [WirePath("resources")] + public DeploymentStacksDeleteDetachEnum Resources { get; set; } + /// Specifies an action for a newly unmanaged resource. Delete will attempt to delete the resource from Azure. Detach will leave the resource in it's current state. + [WirePath("resourceGroups")] + public DeploymentStacksDeleteDetachEnum? ResourceGroups { get; set; } + /// Specifies an action for a newly unmanaged resource. Delete will attempt to delete the resource from Azure. Detach will leave the resource in it's current state. + [WirePath("managementGroups")] + public DeploymentStacksDeleteDetachEnum? ManagementGroups { get; set; } + } +} diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DenySettings.Serialization.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DenySettings.Serialization.cs new file mode 100644 index 0000000000000..5c3e2c64f4eec --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DenySettings.Serialization.cs @@ -0,0 +1,303 @@ +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. + +// + +#nullable disable + +using System; +using System.ClientModel.Primitives; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Text.Json; +using Azure.Core; + +namespace Azure.ResourceManager.Resources.Models +{ + public partial class DenySettings : IUtf8JsonSerializable, IJsonModel + { + void IUtf8JsonSerializable.Write(Utf8JsonWriter writer) => ((IJsonModel)this).Write(writer, ModelSerializationExtensions.WireOptions); + + void IJsonModel.Write(Utf8JsonWriter writer, ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + if (format != "J") + { + throw new FormatException($"The model {nameof(DenySettings)} does not support writing '{format}' format."); + } + + writer.WriteStartObject(); + writer.WritePropertyName("mode"u8); + writer.WriteStringValue(Mode.ToString()); + if (Optional.IsCollectionDefined(ExcludedPrincipals)) + { + writer.WritePropertyName("excludedPrincipals"u8); + writer.WriteStartArray(); + foreach (var item in ExcludedPrincipals) + { + writer.WriteStringValue(item); + } + writer.WriteEndArray(); + } + if (Optional.IsCollectionDefined(ExcludedActions)) + { + writer.WritePropertyName("excludedActions"u8); + writer.WriteStartArray(); + foreach (var item in ExcludedActions) + { + writer.WriteStringValue(item); + } + writer.WriteEndArray(); + } + if (Optional.IsDefined(ApplyToChildScopes)) + { + writer.WritePropertyName("applyToChildScopes"u8); + writer.WriteBooleanValue(ApplyToChildScopes.Value); + } + if (options.Format != "W" && _serializedAdditionalRawData != null) + { + foreach (var item in _serializedAdditionalRawData) + { + writer.WritePropertyName(item.Key); +#if NET6_0_OR_GREATER + writer.WriteRawValue(item.Value); +#else + using (JsonDocument document = JsonDocument.Parse(item.Value)) + { + JsonSerializer.Serialize(writer, document.RootElement); + } +#endif + } + } + writer.WriteEndObject(); + } + + DenySettings IJsonModel.Create(ref Utf8JsonReader reader, ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + if (format != "J") + { + throw new FormatException($"The model {nameof(DenySettings)} does not support reading '{format}' format."); + } + + using JsonDocument document = JsonDocument.ParseValue(ref reader); + return DeserializeDenySettings(document.RootElement, options); + } + + internal static DenySettings DeserializeDenySettings(JsonElement element, ModelReaderWriterOptions options = null) + { + options ??= ModelSerializationExtensions.WireOptions; + + if (element.ValueKind == JsonValueKind.Null) + { + return null; + } + DenySettingsMode mode = default; + IList excludedPrincipals = default; + IList excludedActions = default; + bool? applyToChildScopes = default; + IDictionary serializedAdditionalRawData = default; + Dictionary rawDataDictionary = new Dictionary(); + foreach (var property in element.EnumerateObject()) + { + if (property.NameEquals("mode"u8)) + { + mode = new DenySettingsMode(property.Value.GetString()); + continue; + } + if (property.NameEquals("excludedPrincipals"u8)) + { + if (property.Value.ValueKind == JsonValueKind.Null) + { + continue; + } + List array = new List(); + foreach (var item in property.Value.EnumerateArray()) + { + array.Add(item.GetString()); + } + excludedPrincipals = array; + continue; + } + if (property.NameEquals("excludedActions"u8)) + { + if (property.Value.ValueKind == JsonValueKind.Null) + { + continue; + } + List array = new List(); + foreach (var item in property.Value.EnumerateArray()) + { + array.Add(item.GetString()); + } + excludedActions = array; + continue; + } + if (property.NameEquals("applyToChildScopes"u8)) + { + if (property.Value.ValueKind == JsonValueKind.Null) + { + continue; + } + applyToChildScopes = property.Value.GetBoolean(); + continue; + } + if (options.Format != "W") + { + rawDataDictionary.Add(property.Name, BinaryData.FromString(property.Value.GetRawText())); + } + } + serializedAdditionalRawData = rawDataDictionary; + return new DenySettings(mode, excludedPrincipals ?? new ChangeTrackingList(), excludedActions ?? new ChangeTrackingList(), applyToChildScopes, serializedAdditionalRawData); + } + + private BinaryData SerializeBicep(ModelReaderWriterOptions options) + { + StringBuilder builder = new StringBuilder(); + BicepModelReaderWriterOptions bicepOptions = options as BicepModelReaderWriterOptions; + IDictionary propertyOverrides = null; + bool hasObjectOverride = bicepOptions != null && bicepOptions.PropertyOverrides.TryGetValue(this, out propertyOverrides); + bool hasPropertyOverride = false; + string propertyOverride = null; + + builder.AppendLine("{"); + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(Mode), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" mode: "); + builder.AppendLine(propertyOverride); + } + else + { + builder.Append(" mode: "); + builder.AppendLine($"'{Mode.ToString()}'"); + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(ExcludedPrincipals), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" excludedPrincipals: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsCollectionDefined(ExcludedPrincipals)) + { + if (ExcludedPrincipals.Any()) + { + builder.Append(" excludedPrincipals: "); + builder.AppendLine("["); + foreach (var item in ExcludedPrincipals) + { + if (item == null) + { + builder.Append("null"); + continue; + } + if (item.Contains(Environment.NewLine)) + { + builder.AppendLine(" '''"); + builder.AppendLine($"{item}'''"); + } + else + { + builder.AppendLine($" '{item}'"); + } + } + builder.AppendLine(" ]"); + } + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(ExcludedActions), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" excludedActions: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsCollectionDefined(ExcludedActions)) + { + if (ExcludedActions.Any()) + { + builder.Append(" excludedActions: "); + builder.AppendLine("["); + foreach (var item in ExcludedActions) + { + if (item == null) + { + builder.Append("null"); + continue; + } + if (item.Contains(Environment.NewLine)) + { + builder.AppendLine(" '''"); + builder.AppendLine($"{item}'''"); + } + else + { + builder.AppendLine($" '{item}'"); + } + } + builder.AppendLine(" ]"); + } + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(ApplyToChildScopes), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" applyToChildScopes: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(ApplyToChildScopes)) + { + builder.Append(" applyToChildScopes: "); + var boolValue = ApplyToChildScopes.Value == true ? "true" : "false"; + builder.AppendLine($"{boolValue}"); + } + } + + builder.AppendLine("}"); + return BinaryData.FromString(builder.ToString()); + } + + BinaryData IPersistableModel.Write(ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + + switch (format) + { + case "J": + return ModelReaderWriter.Write(this, options); + case "bicep": + return SerializeBicep(options); + default: + throw new FormatException($"The model {nameof(DenySettings)} does not support writing '{options.Format}' format."); + } + } + + DenySettings IPersistableModel.Create(BinaryData data, ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + + switch (format) + { + case "J": + { + using JsonDocument document = JsonDocument.Parse(data); + return DeserializeDenySettings(document.RootElement, options); + } + default: + throw new FormatException($"The model {nameof(DenySettings)} does not support reading '{options.Format}' format."); + } + } + + string IPersistableModel.GetFormatFromOptions(ModelReaderWriterOptions options) => "J"; + } +} diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DenySettings.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DenySettings.cs new file mode 100644 index 0000000000000..e55173d84192c --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DenySettings.cs @@ -0,0 +1,90 @@ +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. + +// + +#nullable disable + +using System; +using System.Collections.Generic; + +namespace Azure.ResourceManager.Resources.Models +{ + /// Defines how resources deployed by the Deployment stack are locked. + public partial class DenySettings + { + /// + /// Keeps track of any properties unknown to the library. + /// + /// To assign an object to the value of this property use . + /// + /// + /// To assign an already formatted json string to this property use . + /// + /// + /// Examples: + /// + /// + /// BinaryData.FromObjectAsJson("foo") + /// Creates a payload of "foo". + /// + /// + /// BinaryData.FromString("\"foo\"") + /// Creates a payload of "foo". + /// + /// + /// BinaryData.FromObjectAsJson(new { key = "value" }) + /// Creates a payload of { "key": "value" }. + /// + /// + /// BinaryData.FromString("{\"key\": \"value\"}") + /// Creates a payload of { "key": "value" }. + /// + /// + /// + /// + private IDictionary _serializedAdditionalRawData; + + /// Initializes a new instance of . + /// denySettings Mode that defines denied actions. + public DenySettings(DenySettingsMode mode) + { + Mode = mode; + ExcludedPrincipals = new ChangeTrackingList(); + ExcludedActions = new ChangeTrackingList(); + } + + /// Initializes a new instance of . + /// denySettings Mode that defines denied actions. + /// List of AAD principal IDs excluded from the lock. Up to 5 principals are permitted. + /// List of role-based management operations that are excluded from the denySettings. Up to 200 actions are permitted. If the denySetting mode is set to 'denyWriteAndDelete', then the following actions are automatically appended to 'excludedActions': '*\/read' and 'Microsoft.Authorization/locks/delete'. If the denySetting mode is set to 'denyDelete', then the following actions are automatically appended to 'excludedActions': 'Microsoft.Authorization/locks/delete'. Duplicate actions will be removed. + /// DenySettings will be applied to child resource scopes of every managed resource with a deny assignment. + /// Keeps track of any properties unknown to the library. + internal DenySettings(DenySettingsMode mode, IList excludedPrincipals, IList excludedActions, bool? applyToChildScopes, IDictionary serializedAdditionalRawData) + { + Mode = mode; + ExcludedPrincipals = excludedPrincipals; + ExcludedActions = excludedActions; + ApplyToChildScopes = applyToChildScopes; + _serializedAdditionalRawData = serializedAdditionalRawData; + } + + /// Initializes a new instance of for deserialization. + internal DenySettings() + { + } + + /// denySettings Mode that defines denied actions. + [WirePath("mode")] + public DenySettingsMode Mode { get; set; } + /// List of AAD principal IDs excluded from the lock. Up to 5 principals are permitted. + [WirePath("excludedPrincipals")] + public IList ExcludedPrincipals { get; } + /// List of role-based management operations that are excluded from the denySettings. Up to 200 actions are permitted. If the denySetting mode is set to 'denyWriteAndDelete', then the following actions are automatically appended to 'excludedActions': '*\/read' and 'Microsoft.Authorization/locks/delete'. If the denySetting mode is set to 'denyDelete', then the following actions are automatically appended to 'excludedActions': 'Microsoft.Authorization/locks/delete'. Duplicate actions will be removed. + [WirePath("excludedActions")] + public IList ExcludedActions { get; } + /// DenySettings will be applied to child resource scopes of every managed resource with a deny assignment. + [WirePath("applyToChildScopes")] + public bool? ApplyToChildScopes { get; set; } + } +} diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DenySettingsMode.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DenySettingsMode.cs new file mode 100644 index 0000000000000..4ff2064c8b802 --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DenySettingsMode.cs @@ -0,0 +1,54 @@ +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. + +// + +#nullable disable + +using System; +using System.ComponentModel; + +namespace Azure.ResourceManager.Resources.Models +{ + /// denySettings Mode that defines denied actions. + public readonly partial struct DenySettingsMode : IEquatable + { + private readonly string _value; + + /// Initializes a new instance of . + /// is null. + public DenySettingsMode(string value) + { + _value = value ?? throw new ArgumentNullException(nameof(value)); + } + + private const string DenyDeleteValue = "denyDelete"; + private const string DenyWriteAndDeleteValue = "denyWriteAndDelete"; + private const string NoneValue = "none"; + + /// Authorized users are able to read and modify the resources, but cannot delete. + public static DenySettingsMode DenyDelete { get; } = new DenySettingsMode(DenyDeleteValue); + /// Authorized users can read from a resource, but cannot modify or delete it. + public static DenySettingsMode DenyWriteAndDelete { get; } = new DenySettingsMode(DenyWriteAndDeleteValue); + /// No denyAssignments have been applied. + public static DenySettingsMode None { get; } = new DenySettingsMode(NoneValue); + /// Determines if two values are the same. + public static bool operator ==(DenySettingsMode left, DenySettingsMode right) => left.Equals(right); + /// Determines if two values are not the same. + public static bool operator !=(DenySettingsMode left, DenySettingsMode right) => !left.Equals(right); + /// Converts a string to a . + public static implicit operator DenySettingsMode(string value) => new DenySettingsMode(value); + + /// + [EditorBrowsable(EditorBrowsableState.Never)] + public override bool Equals(object obj) => obj is DenySettingsMode other && Equals(other); + /// + public bool Equals(DenySettingsMode other) => string.Equals(_value, other._value, StringComparison.InvariantCultureIgnoreCase); + + /// + [EditorBrowsable(EditorBrowsableState.Never)] + public override int GetHashCode() => _value != null ? StringComparer.InvariantCultureIgnoreCase.GetHashCode(_value) : 0; + /// + public override string ToString() => _value; + } +} diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DenyStatusMode.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DenyStatusMode.cs new file mode 100644 index 0000000000000..4fdd08e77956d --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DenyStatusMode.cs @@ -0,0 +1,63 @@ +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. + +// + +#nullable disable + +using System; +using System.ComponentModel; + +namespace Azure.ResourceManager.Resources.Models +{ + /// denyAssignment settings applied to the resource. + public readonly partial struct DenyStatusMode : IEquatable + { + private readonly string _value; + + /// Initializes a new instance of . + /// is null. + public DenyStatusMode(string value) + { + _value = value ?? throw new ArgumentNullException(nameof(value)); + } + + private const string DenyDeleteValue = "denyDelete"; + private const string NotSupportedValue = "notSupported"; + private const string InapplicableValue = "inapplicable"; + private const string DenyWriteAndDeleteValue = "denyWriteAndDelete"; + private const string RemovedBySystemValue = "removedBySystem"; + private const string NoneValue = "none"; + + /// Authorized users are able to read and modify the resources, but cannot delete. + public static DenyStatusMode DenyDelete { get; } = new DenyStatusMode(DenyDeleteValue); + /// Resource type does not support denyAssignments. + public static DenyStatusMode NotSupported { get; } = new DenyStatusMode(NotSupportedValue); + /// denyAssignments are not supported on resources outside the scope of the deployment stack. + public static DenyStatusMode Inapplicable { get; } = new DenyStatusMode(InapplicableValue); + /// Authorized users can only read from a resource, but cannot modify or delete it. + public static DenyStatusMode DenyWriteAndDelete { get; } = new DenyStatusMode(DenyWriteAndDeleteValue); + /// Deny assignment has been removed by Azure due to a resource management change (management group move, etc.). + public static DenyStatusMode RemovedBySystem { get; } = new DenyStatusMode(RemovedBySystemValue); + /// No denyAssignments have been applied. + public static DenyStatusMode None { get; } = new DenyStatusMode(NoneValue); + /// Determines if two values are the same. + public static bool operator ==(DenyStatusMode left, DenyStatusMode right) => left.Equals(right); + /// Determines if two values are not the same. + public static bool operator !=(DenyStatusMode left, DenyStatusMode right) => !left.Equals(right); + /// Converts a string to a . + public static implicit operator DenyStatusMode(string value) => new DenyStatusMode(value); + + /// + [EditorBrowsable(EditorBrowsableState.Never)] + public override bool Equals(object obj) => obj is DenyStatusMode other && Equals(other); + /// + public bool Equals(DenyStatusMode other) => string.Equals(_value, other._value, StringComparison.InvariantCultureIgnoreCase); + + /// + [EditorBrowsable(EditorBrowsableState.Never)] + public override int GetHashCode() => _value != null ? StringComparer.InvariantCultureIgnoreCase.GetHashCode(_value) : 0; + /// + public override string ToString() => _value; + } +} diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentParameter.Serialization.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentParameter.Serialization.cs new file mode 100644 index 0000000000000..2042c0e1d26c6 --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentParameter.Serialization.cs @@ -0,0 +1,230 @@ +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. + +// + +#nullable disable + +using System; +using System.ClientModel.Primitives; +using System.Collections.Generic; +using System.Text; +using System.Text.Json; +using Azure.Core; + +namespace Azure.ResourceManager.Resources.Models +{ + public partial class DeploymentParameter : IUtf8JsonSerializable, IJsonModel + { + void IUtf8JsonSerializable.Write(Utf8JsonWriter writer) => ((IJsonModel)this).Write(writer, ModelSerializationExtensions.WireOptions); + + void IJsonModel.Write(Utf8JsonWriter writer, ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + if (format != "J") + { + throw new FormatException($"The model {nameof(DeploymentParameter)} does not support writing '{format}' format."); + } + + writer.WriteStartObject(); + if (Optional.IsDefined(Value)) + { + writer.WritePropertyName("value"u8); +#if NET6_0_OR_GREATER + writer.WriteRawValue(Value); +#else + using (JsonDocument document = JsonDocument.Parse(Value)) + { + JsonSerializer.Serialize(writer, document.RootElement); + } +#endif + } + if (Optional.IsDefined(DeploymentParameterType)) + { + writer.WritePropertyName("type"u8); + writer.WriteStringValue(DeploymentParameterType); + } + if (Optional.IsDefined(Reference)) + { + writer.WritePropertyName("reference"u8); + writer.WriteObjectValue(Reference, options); + } + if (options.Format != "W" && _serializedAdditionalRawData != null) + { + foreach (var item in _serializedAdditionalRawData) + { + writer.WritePropertyName(item.Key); +#if NET6_0_OR_GREATER + writer.WriteRawValue(item.Value); +#else + using (JsonDocument document = JsonDocument.Parse(item.Value)) + { + JsonSerializer.Serialize(writer, document.RootElement); + } +#endif + } + } + writer.WriteEndObject(); + } + + DeploymentParameter IJsonModel.Create(ref Utf8JsonReader reader, ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + if (format != "J") + { + throw new FormatException($"The model {nameof(DeploymentParameter)} does not support reading '{format}' format."); + } + + using JsonDocument document = JsonDocument.ParseValue(ref reader); + return DeserializeDeploymentParameter(document.RootElement, options); + } + + internal static DeploymentParameter DeserializeDeploymentParameter(JsonElement element, ModelReaderWriterOptions options = null) + { + options ??= ModelSerializationExtensions.WireOptions; + + if (element.ValueKind == JsonValueKind.Null) + { + return null; + } + BinaryData value = default; + string type = default; + KeyVaultParameterReference reference = default; + IDictionary serializedAdditionalRawData = default; + Dictionary rawDataDictionary = new Dictionary(); + foreach (var property in element.EnumerateObject()) + { + if (property.NameEquals("value"u8)) + { + if (property.Value.ValueKind == JsonValueKind.Null) + { + continue; + } + value = BinaryData.FromString(property.Value.GetRawText()); + continue; + } + if (property.NameEquals("type"u8)) + { + type = property.Value.GetString(); + continue; + } + if (property.NameEquals("reference"u8)) + { + if (property.Value.ValueKind == JsonValueKind.Null) + { + continue; + } + reference = KeyVaultParameterReference.DeserializeKeyVaultParameterReference(property.Value, options); + continue; + } + if (options.Format != "W") + { + rawDataDictionary.Add(property.Name, BinaryData.FromString(property.Value.GetRawText())); + } + } + serializedAdditionalRawData = rawDataDictionary; + return new DeploymentParameter(value, type, reference, serializedAdditionalRawData); + } + + private BinaryData SerializeBicep(ModelReaderWriterOptions options) + { + StringBuilder builder = new StringBuilder(); + BicepModelReaderWriterOptions bicepOptions = options as BicepModelReaderWriterOptions; + IDictionary propertyOverrides = null; + bool hasObjectOverride = bicepOptions != null && bicepOptions.PropertyOverrides.TryGetValue(this, out propertyOverrides); + bool hasPropertyOverride = false; + string propertyOverride = null; + + builder.AppendLine("{"); + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(Value), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" value: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(Value)) + { + builder.Append(" value: "); + builder.AppendLine($"'{Value.ToString()}'"); + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(DeploymentParameterType), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" type: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(DeploymentParameterType)) + { + builder.Append(" type: "); + if (DeploymentParameterType.Contains(Environment.NewLine)) + { + builder.AppendLine("'''"); + builder.AppendLine($"{DeploymentParameterType}'''"); + } + else + { + builder.AppendLine($"'{DeploymentParameterType}'"); + } + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(Reference), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" reference: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(Reference)) + { + builder.Append(" reference: "); + BicepSerializationHelpers.AppendChildObject(builder, Reference, options, 2, false, " reference: "); + } + } + + builder.AppendLine("}"); + return BinaryData.FromString(builder.ToString()); + } + + BinaryData IPersistableModel.Write(ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + + switch (format) + { + case "J": + return ModelReaderWriter.Write(this, options); + case "bicep": + return SerializeBicep(options); + default: + throw new FormatException($"The model {nameof(DeploymentParameter)} does not support writing '{options.Format}' format."); + } + } + + DeploymentParameter IPersistableModel.Create(BinaryData data, ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + + switch (format) + { + case "J": + { + using JsonDocument document = JsonDocument.Parse(data); + return DeserializeDeploymentParameter(document.RootElement, options); + } + default: + throw new FormatException($"The model {nameof(DeploymentParameter)} does not support reading '{options.Format}' format."); + } + } + + string IPersistableModel.GetFormatFromOptions(ModelReaderWriterOptions options) => "J"; + } +} diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentParameter.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentParameter.cs new file mode 100644 index 0000000000000..e810c066b72f0 --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentParameter.cs @@ -0,0 +1,105 @@ +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. + +// + +#nullable disable + +using System; +using System.Collections.Generic; + +namespace Azure.ResourceManager.Resources.Models +{ + /// Deployment parameter for the template. + public partial class DeploymentParameter + { + /// + /// Keeps track of any properties unknown to the library. + /// + /// To assign an object to the value of this property use . + /// + /// + /// To assign an already formatted json string to this property use . + /// + /// + /// Examples: + /// + /// + /// BinaryData.FromObjectAsJson("foo") + /// Creates a payload of "foo". + /// + /// + /// BinaryData.FromString("\"foo\"") + /// Creates a payload of "foo". + /// + /// + /// BinaryData.FromObjectAsJson(new { key = "value" }) + /// Creates a payload of { "key": "value" }. + /// + /// + /// BinaryData.FromString("{\"key\": \"value\"}") + /// Creates a payload of { "key": "value" }. + /// + /// + /// + /// + private IDictionary _serializedAdditionalRawData; + + /// Initializes a new instance of . + public DeploymentParameter() + { + } + + /// Initializes a new instance of . + /// Input value to the parameter. + /// Type of the value. + /// Azure Key Vault parameter reference. + /// Keeps track of any properties unknown to the library. + internal DeploymentParameter(BinaryData value, string deploymentParameterType, KeyVaultParameterReference reference, IDictionary serializedAdditionalRawData) + { + Value = value; + DeploymentParameterType = deploymentParameterType; + Reference = reference; + _serializedAdditionalRawData = serializedAdditionalRawData; + } + + /// + /// Input value to the parameter. + /// + /// To assign an object to this property use . + /// + /// + /// To assign an already formatted json string to this property use . + /// + /// + /// Examples: + /// + /// + /// BinaryData.FromObjectAsJson("foo") + /// Creates a payload of "foo". + /// + /// + /// BinaryData.FromString("\"foo\"") + /// Creates a payload of "foo". + /// + /// + /// BinaryData.FromObjectAsJson(new { key = "value" }) + /// Creates a payload of { "key": "value" }. + /// + /// + /// BinaryData.FromString("{\"key\": \"value\"}") + /// Creates a payload of { "key": "value" }. + /// + /// + /// + /// + [WirePath("value")] + public BinaryData Value { get; set; } + /// Type of the value. + [WirePath("type")] + public string DeploymentParameterType { get; set; } + /// Azure Key Vault parameter reference. + [WirePath("reference")] + public KeyVaultParameterReference Reference { get; set; } + } +} diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStackListResult.Serialization.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStackListResult.Serialization.cs new file mode 100644 index 0000000000000..205eeb12438fe --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStackListResult.Serialization.cs @@ -0,0 +1,212 @@ +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. + +// + +#nullable disable + +using System; +using System.ClientModel.Primitives; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Text.Json; +using Azure.Core; + +namespace Azure.ResourceManager.Resources.Models +{ + internal partial class DeploymentStackListResult : IUtf8JsonSerializable, IJsonModel + { + void IUtf8JsonSerializable.Write(Utf8JsonWriter writer) => ((IJsonModel)this).Write(writer, ModelSerializationExtensions.WireOptions); + + void IJsonModel.Write(Utf8JsonWriter writer, ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + if (format != "J") + { + throw new FormatException($"The model {nameof(DeploymentStackListResult)} does not support writing '{format}' format."); + } + + writer.WriteStartObject(); + if (Optional.IsCollectionDefined(Value)) + { + writer.WritePropertyName("value"u8); + writer.WriteStartArray(); + foreach (var item in Value) + { + writer.WriteObjectValue(item, options); + } + writer.WriteEndArray(); + } + if (options.Format != "W" && Optional.IsDefined(NextLink)) + { + writer.WritePropertyName("nextLink"u8); + writer.WriteStringValue(NextLink); + } + if (options.Format != "W" && _serializedAdditionalRawData != null) + { + foreach (var item in _serializedAdditionalRawData) + { + writer.WritePropertyName(item.Key); +#if NET6_0_OR_GREATER + writer.WriteRawValue(item.Value); +#else + using (JsonDocument document = JsonDocument.Parse(item.Value)) + { + JsonSerializer.Serialize(writer, document.RootElement); + } +#endif + } + } + writer.WriteEndObject(); + } + + DeploymentStackListResult IJsonModel.Create(ref Utf8JsonReader reader, ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + if (format != "J") + { + throw new FormatException($"The model {nameof(DeploymentStackListResult)} does not support reading '{format}' format."); + } + + using JsonDocument document = JsonDocument.ParseValue(ref reader); + return DeserializeDeploymentStackListResult(document.RootElement, options); + } + + internal static DeploymentStackListResult DeserializeDeploymentStackListResult(JsonElement element, ModelReaderWriterOptions options = null) + { + options ??= ModelSerializationExtensions.WireOptions; + + if (element.ValueKind == JsonValueKind.Null) + { + return null; + } + IReadOnlyList value = default; + string nextLink = default; + IDictionary serializedAdditionalRawData = default; + Dictionary rawDataDictionary = new Dictionary(); + foreach (var property in element.EnumerateObject()) + { + if (property.NameEquals("value"u8)) + { + if (property.Value.ValueKind == JsonValueKind.Null) + { + continue; + } + List array = new List(); + foreach (var item in property.Value.EnumerateArray()) + { + array.Add(DeploymentStackData.DeserializeDeploymentStackData(item, options)); + } + value = array; + continue; + } + if (property.NameEquals("nextLink"u8)) + { + nextLink = property.Value.GetString(); + continue; + } + if (options.Format != "W") + { + rawDataDictionary.Add(property.Name, BinaryData.FromString(property.Value.GetRawText())); + } + } + serializedAdditionalRawData = rawDataDictionary; + return new DeploymentStackListResult(value ?? new ChangeTrackingList(), nextLink, serializedAdditionalRawData); + } + + private BinaryData SerializeBicep(ModelReaderWriterOptions options) + { + StringBuilder builder = new StringBuilder(); + BicepModelReaderWriterOptions bicepOptions = options as BicepModelReaderWriterOptions; + IDictionary propertyOverrides = null; + bool hasObjectOverride = bicepOptions != null && bicepOptions.PropertyOverrides.TryGetValue(this, out propertyOverrides); + bool hasPropertyOverride = false; + string propertyOverride = null; + + builder.AppendLine("{"); + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(Value), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" value: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsCollectionDefined(Value)) + { + if (Value.Any()) + { + builder.Append(" value: "); + builder.AppendLine("["); + foreach (var item in Value) + { + BicepSerializationHelpers.AppendChildObject(builder, item, options, 4, true, " value: "); + } + builder.AppendLine(" ]"); + } + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(NextLink), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" nextLink: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(NextLink)) + { + builder.Append(" nextLink: "); + if (NextLink.Contains(Environment.NewLine)) + { + builder.AppendLine("'''"); + builder.AppendLine($"{NextLink}'''"); + } + else + { + builder.AppendLine($"'{NextLink}'"); + } + } + } + + builder.AppendLine("}"); + return BinaryData.FromString(builder.ToString()); + } + + BinaryData IPersistableModel.Write(ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + + switch (format) + { + case "J": + return ModelReaderWriter.Write(this, options); + case "bicep": + return SerializeBicep(options); + default: + throw new FormatException($"The model {nameof(DeploymentStackListResult)} does not support writing '{options.Format}' format."); + } + } + + DeploymentStackListResult IPersistableModel.Create(BinaryData data, ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + + switch (format) + { + case "J": + { + using JsonDocument document = JsonDocument.Parse(data); + return DeserializeDeploymentStackListResult(document.RootElement, options); + } + default: + throw new FormatException($"The model {nameof(DeploymentStackListResult)} does not support reading '{options.Format}' format."); + } + } + + string IPersistableModel.GetFormatFromOptions(ModelReaderWriterOptions options) => "J"; + } +} diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStackListResult.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStackListResult.cs new file mode 100644 index 0000000000000..8b6ba6dd33ca0 --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStackListResult.cs @@ -0,0 +1,70 @@ +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. + +// + +#nullable disable + +using System; +using System.Collections.Generic; + +namespace Azure.ResourceManager.Resources.Models +{ + /// List of Deployment stacks. + internal partial class DeploymentStackListResult + { + /// + /// Keeps track of any properties unknown to the library. + /// + /// To assign an object to the value of this property use . + /// + /// + /// To assign an already formatted json string to this property use . + /// + /// + /// Examples: + /// + /// + /// BinaryData.FromObjectAsJson("foo") + /// Creates a payload of "foo". + /// + /// + /// BinaryData.FromString("\"foo\"") + /// Creates a payload of "foo". + /// + /// + /// BinaryData.FromObjectAsJson(new { key = "value" }) + /// Creates a payload of { "key": "value" }. + /// + /// + /// BinaryData.FromString("{\"key\": \"value\"}") + /// Creates a payload of { "key": "value" }. + /// + /// + /// + /// + private IDictionary _serializedAdditionalRawData; + + /// Initializes a new instance of . + internal DeploymentStackListResult() + { + Value = new ChangeTrackingList(); + } + + /// Initializes a new instance of . + /// An array of Deployment stacks. + /// The URL to use for getting the next set of results. + /// Keeps track of any properties unknown to the library. + internal DeploymentStackListResult(IReadOnlyList value, string nextLink, IDictionary serializedAdditionalRawData) + { + Value = value; + NextLink = nextLink; + _serializedAdditionalRawData = serializedAdditionalRawData; + } + + /// An array of Deployment stacks. + public IReadOnlyList Value { get; } + /// The URL to use for getting the next set of results. + public string NextLink { get; } + } +} diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStackProvisioningState.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStackProvisioningState.cs new file mode 100644 index 0000000000000..904280f2d6e18 --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStackProvisioningState.cs @@ -0,0 +1,78 @@ +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. + +// + +#nullable disable + +using System; +using System.ComponentModel; + +namespace Azure.ResourceManager.Resources.Models +{ + /// State of the deployment stack. + public readonly partial struct DeploymentStackProvisioningState : IEquatable + { + private readonly string _value; + + /// Initializes a new instance of . + /// is null. + public DeploymentStackProvisioningState(string value) + { + _value = value ?? throw new ArgumentNullException(nameof(value)); + } + + private const string CreatingValue = "creating"; + private const string ValidatingValue = "validating"; + private const string WaitingValue = "waiting"; + private const string DeployingValue = "deploying"; + private const string CancelingValue = "canceling"; + private const string UpdatingDenyAssignmentsValue = "updatingDenyAssignments"; + private const string DeletingResourcesValue = "deletingResources"; + private const string SucceededValue = "succeeded"; + private const string FailedValue = "failed"; + private const string CanceledValue = "canceled"; + private const string DeletingValue = "deleting"; + + /// creating. + public static DeploymentStackProvisioningState Creating { get; } = new DeploymentStackProvisioningState(CreatingValue); + /// validating. + public static DeploymentStackProvisioningState Validating { get; } = new DeploymentStackProvisioningState(ValidatingValue); + /// waiting. + public static DeploymentStackProvisioningState Waiting { get; } = new DeploymentStackProvisioningState(WaitingValue); + /// deploying. + public static DeploymentStackProvisioningState Deploying { get; } = new DeploymentStackProvisioningState(DeployingValue); + /// canceling. + public static DeploymentStackProvisioningState Canceling { get; } = new DeploymentStackProvisioningState(CancelingValue); + /// updatingDenyAssignments. + public static DeploymentStackProvisioningState UpdatingDenyAssignments { get; } = new DeploymentStackProvisioningState(UpdatingDenyAssignmentsValue); + /// deletingResources. + public static DeploymentStackProvisioningState DeletingResources { get; } = new DeploymentStackProvisioningState(DeletingResourcesValue); + /// succeeded. + public static DeploymentStackProvisioningState Succeeded { get; } = new DeploymentStackProvisioningState(SucceededValue); + /// failed. + public static DeploymentStackProvisioningState Failed { get; } = new DeploymentStackProvisioningState(FailedValue); + /// canceled. + public static DeploymentStackProvisioningState Canceled { get; } = new DeploymentStackProvisioningState(CanceledValue); + /// deleting. + public static DeploymentStackProvisioningState Deleting { get; } = new DeploymentStackProvisioningState(DeletingValue); + /// Determines if two values are the same. + public static bool operator ==(DeploymentStackProvisioningState left, DeploymentStackProvisioningState right) => left.Equals(right); + /// Determines if two values are not the same. + public static bool operator !=(DeploymentStackProvisioningState left, DeploymentStackProvisioningState right) => !left.Equals(right); + /// Converts a string to a . + public static implicit operator DeploymentStackProvisioningState(string value) => new DeploymentStackProvisioningState(value); + + /// + [EditorBrowsable(EditorBrowsableState.Never)] + public override bool Equals(object obj) => obj is DeploymentStackProvisioningState other && Equals(other); + /// + public bool Equals(DeploymentStackProvisioningState other) => string.Equals(_value, other._value, StringComparison.InvariantCultureIgnoreCase); + + /// + [EditorBrowsable(EditorBrowsableState.Never)] + public override int GetHashCode() => _value != null ? StringComparer.InvariantCultureIgnoreCase.GetHashCode(_value) : 0; + /// + public override string ToString() => _value; + } +} diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStackTemplateDefinition.Serialization.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStackTemplateDefinition.Serialization.cs new file mode 100644 index 0000000000000..86e22ee4f18ac --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStackTemplateDefinition.Serialization.cs @@ -0,0 +1,196 @@ +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. + +// + +#nullable disable + +using System; +using System.ClientModel.Primitives; +using System.Collections.Generic; +using System.Text; +using System.Text.Json; +using Azure.Core; + +namespace Azure.ResourceManager.Resources.Models +{ + public partial class DeploymentStackTemplateDefinition : IUtf8JsonSerializable, IJsonModel + { + void IUtf8JsonSerializable.Write(Utf8JsonWriter writer) => ((IJsonModel)this).Write(writer, ModelSerializationExtensions.WireOptions); + + void IJsonModel.Write(Utf8JsonWriter writer, ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + if (format != "J") + { + throw new FormatException($"The model {nameof(DeploymentStackTemplateDefinition)} does not support writing '{format}' format."); + } + + writer.WriteStartObject(); + if (Optional.IsDefined(Template)) + { + writer.WritePropertyName("template"u8); +#if NET6_0_OR_GREATER + writer.WriteRawValue(Template); +#else + using (JsonDocument document = JsonDocument.Parse(Template)) + { + JsonSerializer.Serialize(writer, document.RootElement); + } +#endif + } + if (Optional.IsDefined(TemplateLink)) + { + writer.WritePropertyName("templateLink"u8); + writer.WriteObjectValue(TemplateLink, options); + } + if (options.Format != "W" && _serializedAdditionalRawData != null) + { + foreach (var item in _serializedAdditionalRawData) + { + writer.WritePropertyName(item.Key); +#if NET6_0_OR_GREATER + writer.WriteRawValue(item.Value); +#else + using (JsonDocument document = JsonDocument.Parse(item.Value)) + { + JsonSerializer.Serialize(writer, document.RootElement); + } +#endif + } + } + writer.WriteEndObject(); + } + + DeploymentStackTemplateDefinition IJsonModel.Create(ref Utf8JsonReader reader, ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + if (format != "J") + { + throw new FormatException($"The model {nameof(DeploymentStackTemplateDefinition)} does not support reading '{format}' format."); + } + + using JsonDocument document = JsonDocument.ParseValue(ref reader); + return DeserializeDeploymentStackTemplateDefinition(document.RootElement, options); + } + + internal static DeploymentStackTemplateDefinition DeserializeDeploymentStackTemplateDefinition(JsonElement element, ModelReaderWriterOptions options = null) + { + options ??= ModelSerializationExtensions.WireOptions; + + if (element.ValueKind == JsonValueKind.Null) + { + return null; + } + BinaryData template = default; + DeploymentStacksTemplateLink templateLink = default; + IDictionary serializedAdditionalRawData = default; + Dictionary rawDataDictionary = new Dictionary(); + foreach (var property in element.EnumerateObject()) + { + if (property.NameEquals("template"u8)) + { + if (property.Value.ValueKind == JsonValueKind.Null) + { + continue; + } + template = BinaryData.FromString(property.Value.GetRawText()); + continue; + } + if (property.NameEquals("templateLink"u8)) + { + if (property.Value.ValueKind == JsonValueKind.Null) + { + continue; + } + templateLink = DeploymentStacksTemplateLink.DeserializeDeploymentStacksTemplateLink(property.Value, options); + continue; + } + if (options.Format != "W") + { + rawDataDictionary.Add(property.Name, BinaryData.FromString(property.Value.GetRawText())); + } + } + serializedAdditionalRawData = rawDataDictionary; + return new DeploymentStackTemplateDefinition(template, templateLink, serializedAdditionalRawData); + } + + private BinaryData SerializeBicep(ModelReaderWriterOptions options) + { + StringBuilder builder = new StringBuilder(); + BicepModelReaderWriterOptions bicepOptions = options as BicepModelReaderWriterOptions; + IDictionary propertyOverrides = null; + bool hasObjectOverride = bicepOptions != null && bicepOptions.PropertyOverrides.TryGetValue(this, out propertyOverrides); + bool hasPropertyOverride = false; + string propertyOverride = null; + + builder.AppendLine("{"); + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(Template), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" template: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(Template)) + { + builder.Append(" template: "); + builder.AppendLine($"'{Template.ToString()}'"); + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(TemplateLink), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" templateLink: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(TemplateLink)) + { + builder.Append(" templateLink: "); + BicepSerializationHelpers.AppendChildObject(builder, TemplateLink, options, 2, false, " templateLink: "); + } + } + + builder.AppendLine("}"); + return BinaryData.FromString(builder.ToString()); + } + + BinaryData IPersistableModel.Write(ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + + switch (format) + { + case "J": + return ModelReaderWriter.Write(this, options); + case "bicep": + return SerializeBicep(options); + default: + throw new FormatException($"The model {nameof(DeploymentStackTemplateDefinition)} does not support writing '{options.Format}' format."); + } + } + + DeploymentStackTemplateDefinition IPersistableModel.Create(BinaryData data, ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + + switch (format) + { + case "J": + { + using JsonDocument document = JsonDocument.Parse(data); + return DeserializeDeploymentStackTemplateDefinition(document.RootElement, options); + } + default: + throw new FormatException($"The model {nameof(DeploymentStackTemplateDefinition)} does not support reading '{options.Format}' format."); + } + } + + string IPersistableModel.GetFormatFromOptions(ModelReaderWriterOptions options) => "J"; + } +} diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStackTemplateDefinition.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStackTemplateDefinition.cs new file mode 100644 index 0000000000000..df86a78d43da0 --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStackTemplateDefinition.cs @@ -0,0 +1,100 @@ +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. + +// + +#nullable disable + +using System; +using System.Collections.Generic; + +namespace Azure.ResourceManager.Resources.Models +{ + /// Export Template specific properties of the Deployment stack. + public partial class DeploymentStackTemplateDefinition + { + /// + /// Keeps track of any properties unknown to the library. + /// + /// To assign an object to the value of this property use . + /// + /// + /// To assign an already formatted json string to this property use . + /// + /// + /// Examples: + /// + /// + /// BinaryData.FromObjectAsJson("foo") + /// Creates a payload of "foo". + /// + /// + /// BinaryData.FromString("\"foo\"") + /// Creates a payload of "foo". + /// + /// + /// BinaryData.FromObjectAsJson(new { key = "value" }) + /// Creates a payload of { "key": "value" }. + /// + /// + /// BinaryData.FromString("{\"key\": \"value\"}") + /// Creates a payload of { "key": "value" }. + /// + /// + /// + /// + private IDictionary _serializedAdditionalRawData; + + /// Initializes a new instance of . + internal DeploymentStackTemplateDefinition() + { + } + + /// Initializes a new instance of . + /// The template content. Use this element to pass the template syntax directly in the request rather than link to an existing template. It can be a JObject or well-formed JSON string. Use either the templateLink property or the template property, but not both. + /// The URI of the template. Use either the templateLink property or the template property, but not both. + /// Keeps track of any properties unknown to the library. + internal DeploymentStackTemplateDefinition(BinaryData template, DeploymentStacksTemplateLink templateLink, IDictionary serializedAdditionalRawData) + { + Template = template; + TemplateLink = templateLink; + _serializedAdditionalRawData = serializedAdditionalRawData; + } + + /// + /// The template content. Use this element to pass the template syntax directly in the request rather than link to an existing template. It can be a JObject or well-formed JSON string. Use either the templateLink property or the template property, but not both. + /// + /// To assign an object to this property use . + /// + /// + /// To assign an already formatted json string to this property use . + /// + /// + /// Examples: + /// + /// + /// BinaryData.FromObjectAsJson("foo") + /// Creates a payload of "foo". + /// + /// + /// BinaryData.FromString("\"foo\"") + /// Creates a payload of "foo". + /// + /// + /// BinaryData.FromObjectAsJson(new { key = "value" }) + /// Creates a payload of { "key": "value" }. + /// + /// + /// BinaryData.FromString("{\"key\": \"value\"}") + /// Creates a payload of { "key": "value" }. + /// + /// + /// + /// + [WirePath("template")] + public BinaryData Template { get; } + /// The URI of the template. Use either the templateLink property or the template property, but not both. + [WirePath("templateLink")] + public DeploymentStacksTemplateLink TemplateLink { get; } + } +} diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStackValidateProperties.Serialization.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStackValidateProperties.Serialization.cs new file mode 100644 index 0000000000000..42cf2b4ee0638 --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStackValidateProperties.Serialization.cs @@ -0,0 +1,429 @@ +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. + +// + +#nullable disable + +using System; +using System.ClientModel.Primitives; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Text.Json; +using Azure.Core; + +namespace Azure.ResourceManager.Resources.Models +{ + public partial class DeploymentStackValidateProperties : IUtf8JsonSerializable, IJsonModel + { + void IUtf8JsonSerializable.Write(Utf8JsonWriter writer) => ((IJsonModel)this).Write(writer, ModelSerializationExtensions.WireOptions); + + void IJsonModel.Write(Utf8JsonWriter writer, ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + if (format != "J") + { + throw new FormatException($"The model {nameof(DeploymentStackValidateProperties)} does not support writing '{format}' format."); + } + + writer.WriteStartObject(); + if (Optional.IsDefined(ActionOnUnmanage)) + { + writer.WritePropertyName("actionOnUnmanage"u8); + writer.WriteObjectValue(ActionOnUnmanage, options); + } + if (Optional.IsDefined(CorrelationId)) + { + writer.WritePropertyName("correlationId"u8); + writer.WriteStringValue(CorrelationId); + } + if (Optional.IsDefined(DenySettings)) + { + writer.WritePropertyName("denySettings"u8); + writer.WriteObjectValue(DenySettings, options); + } + if (Optional.IsDefined(DeploymentScope)) + { + writer.WritePropertyName("deploymentScope"u8); + writer.WriteStringValue(DeploymentScope); + } + if (Optional.IsDefined(Description)) + { + writer.WritePropertyName("description"u8); + writer.WriteStringValue(Description); + } + if (Optional.IsCollectionDefined(Parameters)) + { + writer.WritePropertyName("parameters"u8); + writer.WriteStartObject(); + foreach (var item in Parameters) + { + writer.WritePropertyName(item.Key); + writer.WriteObjectValue(item.Value, options); + } + writer.WriteEndObject(); + } + if (Optional.IsDefined(TemplateLink)) + { + writer.WritePropertyName("templateLink"u8); + writer.WriteObjectValue(TemplateLink, options); + } + if (Optional.IsCollectionDefined(ValidatedResources)) + { + writer.WritePropertyName("validatedResources"u8); + writer.WriteStartArray(); + foreach (var item in ValidatedResources) + { + JsonSerializer.Serialize(writer, item); + } + writer.WriteEndArray(); + } + if (options.Format != "W" && _serializedAdditionalRawData != null) + { + foreach (var item in _serializedAdditionalRawData) + { + writer.WritePropertyName(item.Key); +#if NET6_0_OR_GREATER + writer.WriteRawValue(item.Value); +#else + using (JsonDocument document = JsonDocument.Parse(item.Value)) + { + JsonSerializer.Serialize(writer, document.RootElement); + } +#endif + } + } + writer.WriteEndObject(); + } + + DeploymentStackValidateProperties IJsonModel.Create(ref Utf8JsonReader reader, ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + if (format != "J") + { + throw new FormatException($"The model {nameof(DeploymentStackValidateProperties)} does not support reading '{format}' format."); + } + + using JsonDocument document = JsonDocument.ParseValue(ref reader); + return DeserializeDeploymentStackValidateProperties(document.RootElement, options); + } + + internal static DeploymentStackValidateProperties DeserializeDeploymentStackValidateProperties(JsonElement element, ModelReaderWriterOptions options = null) + { + options ??= ModelSerializationExtensions.WireOptions; + + if (element.ValueKind == JsonValueKind.Null) + { + return null; + } + ActionOnUnmanage actionOnUnmanage = default; + string correlationId = default; + DenySettings denySettings = default; + string deploymentScope = default; + string description = default; + IDictionary parameters = default; + DeploymentStacksTemplateLink templateLink = default; + IList validatedResources = default; + IDictionary serializedAdditionalRawData = default; + Dictionary rawDataDictionary = new Dictionary(); + foreach (var property in element.EnumerateObject()) + { + if (property.NameEquals("actionOnUnmanage"u8)) + { + if (property.Value.ValueKind == JsonValueKind.Null) + { + continue; + } + actionOnUnmanage = ActionOnUnmanage.DeserializeActionOnUnmanage(property.Value, options); + continue; + } + if (property.NameEquals("correlationId"u8)) + { + correlationId = property.Value.GetString(); + continue; + } + if (property.NameEquals("denySettings"u8)) + { + if (property.Value.ValueKind == JsonValueKind.Null) + { + continue; + } + denySettings = DenySettings.DeserializeDenySettings(property.Value, options); + continue; + } + if (property.NameEquals("deploymentScope"u8)) + { + deploymentScope = property.Value.GetString(); + continue; + } + if (property.NameEquals("description"u8)) + { + description = property.Value.GetString(); + continue; + } + if (property.NameEquals("parameters"u8)) + { + if (property.Value.ValueKind == JsonValueKind.Null) + { + continue; + } + Dictionary dictionary = new Dictionary(); + foreach (var property0 in property.Value.EnumerateObject()) + { + dictionary.Add(property0.Name, DeploymentParameter.DeserializeDeploymentParameter(property0.Value, options)); + } + parameters = dictionary; + continue; + } + if (property.NameEquals("templateLink"u8)) + { + if (property.Value.ValueKind == JsonValueKind.Null) + { + continue; + } + templateLink = DeploymentStacksTemplateLink.DeserializeDeploymentStacksTemplateLink(property.Value, options); + continue; + } + if (property.NameEquals("validatedResources"u8)) + { + if (property.Value.ValueKind == JsonValueKind.Null) + { + continue; + } + List array = new List(); + foreach (var item in property.Value.EnumerateArray()) + { + array.Add(JsonSerializer.Deserialize(item.GetRawText())); + } + validatedResources = array; + continue; + } + if (options.Format != "W") + { + rawDataDictionary.Add(property.Name, BinaryData.FromString(property.Value.GetRawText())); + } + } + serializedAdditionalRawData = rawDataDictionary; + return new DeploymentStackValidateProperties( + actionOnUnmanage, + correlationId, + denySettings, + deploymentScope, + description, + parameters ?? new ChangeTrackingDictionary(), + templateLink, + validatedResources ?? new ChangeTrackingList(), + serializedAdditionalRawData); + } + + private BinaryData SerializeBicep(ModelReaderWriterOptions options) + { + StringBuilder builder = new StringBuilder(); + BicepModelReaderWriterOptions bicepOptions = options as BicepModelReaderWriterOptions; + IDictionary propertyOverrides = null; + bool hasObjectOverride = bicepOptions != null && bicepOptions.PropertyOverrides.TryGetValue(this, out propertyOverrides); + bool hasPropertyOverride = false; + string propertyOverride = null; + + builder.AppendLine("{"); + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(ActionOnUnmanage), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" actionOnUnmanage: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(ActionOnUnmanage)) + { + builder.Append(" actionOnUnmanage: "); + BicepSerializationHelpers.AppendChildObject(builder, ActionOnUnmanage, options, 2, false, " actionOnUnmanage: "); + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(CorrelationId), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" correlationId: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(CorrelationId)) + { + builder.Append(" correlationId: "); + if (CorrelationId.Contains(Environment.NewLine)) + { + builder.AppendLine("'''"); + builder.AppendLine($"{CorrelationId}'''"); + } + else + { + builder.AppendLine($"'{CorrelationId}'"); + } + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(DenySettings), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" denySettings: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(DenySettings)) + { + builder.Append(" denySettings: "); + BicepSerializationHelpers.AppendChildObject(builder, DenySettings, options, 2, false, " denySettings: "); + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(DeploymentScope), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" deploymentScope: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(DeploymentScope)) + { + builder.Append(" deploymentScope: "); + if (DeploymentScope.Contains(Environment.NewLine)) + { + builder.AppendLine("'''"); + builder.AppendLine($"{DeploymentScope}'''"); + } + else + { + builder.AppendLine($"'{DeploymentScope}'"); + } + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(Description), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" description: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(Description)) + { + builder.Append(" description: "); + if (Description.Contains(Environment.NewLine)) + { + builder.AppendLine("'''"); + builder.AppendLine($"{Description}'''"); + } + else + { + builder.AppendLine($"'{Description}'"); + } + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(Parameters), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" parameters: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsCollectionDefined(Parameters)) + { + if (Parameters.Any()) + { + builder.Append(" parameters: "); + builder.AppendLine("{"); + foreach (var item in Parameters) + { + builder.Append($" '{item.Key}': "); + BicepSerializationHelpers.AppendChildObject(builder, item.Value, options, 4, false, " parameters: "); + } + builder.AppendLine(" }"); + } + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(TemplateLink), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" templateLink: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(TemplateLink)) + { + builder.Append(" templateLink: "); + BicepSerializationHelpers.AppendChildObject(builder, TemplateLink, options, 2, false, " templateLink: "); + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(ValidatedResources), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" validatedResources: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsCollectionDefined(ValidatedResources)) + { + if (ValidatedResources.Any()) + { + builder.Append(" validatedResources: "); + builder.AppendLine("["); + foreach (var item in ValidatedResources) + { + BicepSerializationHelpers.AppendChildObject(builder, item, options, 4, true, " validatedResources: "); + } + builder.AppendLine(" ]"); + } + } + } + + builder.AppendLine("}"); + return BinaryData.FromString(builder.ToString()); + } + + BinaryData IPersistableModel.Write(ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + + switch (format) + { + case "J": + return ModelReaderWriter.Write(this, options); + case "bicep": + return SerializeBicep(options); + default: + throw new FormatException($"The model {nameof(DeploymentStackValidateProperties)} does not support writing '{options.Format}' format."); + } + } + + DeploymentStackValidateProperties IPersistableModel.Create(BinaryData data, ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + + switch (format) + { + case "J": + { + using JsonDocument document = JsonDocument.Parse(data); + return DeserializeDeploymentStackValidateProperties(document.RootElement, options); + } + default: + throw new FormatException($"The model {nameof(DeploymentStackValidateProperties)} does not support reading '{options.Format}' format."); + } + } + + string IPersistableModel.GetFormatFromOptions(ModelReaderWriterOptions options) => "J"; + } +} diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStackValidateProperties.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStackValidateProperties.cs new file mode 100644 index 0000000000000..f3ec759d52759 --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStackValidateProperties.cs @@ -0,0 +1,103 @@ +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. + +// + +#nullable disable + +using System; +using System.Collections.Generic; + +namespace Azure.ResourceManager.Resources.Models +{ + /// The Deployment stack validation result details. + public partial class DeploymentStackValidateProperties + { + /// + /// Keeps track of any properties unknown to the library. + /// + /// To assign an object to the value of this property use . + /// + /// + /// To assign an already formatted json string to this property use . + /// + /// + /// Examples: + /// + /// + /// BinaryData.FromObjectAsJson("foo") + /// Creates a payload of "foo". + /// + /// + /// BinaryData.FromString("\"foo\"") + /// Creates a payload of "foo". + /// + /// + /// BinaryData.FromObjectAsJson(new { key = "value" }) + /// Creates a payload of { "key": "value" }. + /// + /// + /// BinaryData.FromString("{\"key\": \"value\"}") + /// Creates a payload of { "key": "value" }. + /// + /// + /// + /// + private IDictionary _serializedAdditionalRawData; + + /// Initializes a new instance of . + public DeploymentStackValidateProperties() + { + Parameters = new ChangeTrackingDictionary(); + ValidatedResources = new ChangeTrackingList(); + } + + /// Initializes a new instance of . + /// Defines the behavior of resources that are no longer managed after the Deployment stack is updated or deleted. + /// The correlation id of the Deployment stack validate operation. It is in GUID format and is used for tracing. + /// The Deployment stack deny settings. + /// The Deployment stack deployment scope. + /// The Deployment stack validation description. + /// Deployment parameters. + /// The URI of the template. + /// The array of resources that were validated. + /// Keeps track of any properties unknown to the library. + internal DeploymentStackValidateProperties(ActionOnUnmanage actionOnUnmanage, string correlationId, DenySettings denySettings, string deploymentScope, string description, IDictionary parameters, DeploymentStacksTemplateLink templateLink, IList validatedResources, IDictionary serializedAdditionalRawData) + { + ActionOnUnmanage = actionOnUnmanage; + CorrelationId = correlationId; + DenySettings = denySettings; + DeploymentScope = deploymentScope; + Description = description; + Parameters = parameters; + TemplateLink = templateLink; + ValidatedResources = validatedResources; + _serializedAdditionalRawData = serializedAdditionalRawData; + } + + /// Defines the behavior of resources that are no longer managed after the Deployment stack is updated or deleted. + [WirePath("actionOnUnmanage")] + public ActionOnUnmanage ActionOnUnmanage { get; set; } + /// The correlation id of the Deployment stack validate operation. It is in GUID format and is used for tracing. + [WirePath("correlationId")] + public string CorrelationId { get; set; } + /// The Deployment stack deny settings. + [WirePath("denySettings")] + public DenySettings DenySettings { get; set; } + /// The Deployment stack deployment scope. + [WirePath("deploymentScope")] + public string DeploymentScope { get; set; } + /// The Deployment stack validation description. + [WirePath("description")] + public string Description { get; set; } + /// Deployment parameters. + [WirePath("parameters")] + public IDictionary Parameters { get; } + /// The URI of the template. + [WirePath("templateLink")] + public DeploymentStacksTemplateLink TemplateLink { get; set; } + /// The array of resources that were validated. + [WirePath("validatedResources")] + public IList ValidatedResources { get; } + } +} diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStackValidateResult.Serialization.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStackValidateResult.Serialization.cs new file mode 100644 index 0000000000000..1656965c7f31d --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStackValidateResult.Serialization.cs @@ -0,0 +1,298 @@ +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. + +// + +#nullable disable + +using System; +using System.ClientModel.Primitives; +using System.Collections.Generic; +using System.Text; +using System.Text.Json; +using Azure.Core; +using Azure.ResourceManager.Models; + +namespace Azure.ResourceManager.Resources.Models +{ + public partial class DeploymentStackValidateResult : IUtf8JsonSerializable, IJsonModel + { + void IUtf8JsonSerializable.Write(Utf8JsonWriter writer) => ((IJsonModel)this).Write(writer, ModelSerializationExtensions.WireOptions); + + void IJsonModel.Write(Utf8JsonWriter writer, ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + if (format != "J") + { + throw new FormatException($"The model {nameof(DeploymentStackValidateResult)} does not support writing '{format}' format."); + } + + writer.WriteStartObject(); + if (Optional.IsDefined(Properties)) + { + writer.WritePropertyName("properties"u8); + writer.WriteObjectValue(Properties, options); + } + if (Optional.IsDefined(Error)) + { + writer.WritePropertyName("error"u8); + JsonSerializer.Serialize(writer, Error); + } + if (options.Format != "W") + { + writer.WritePropertyName("id"u8); + writer.WriteStringValue(Id); + } + if (options.Format != "W") + { + writer.WritePropertyName("name"u8); + writer.WriteStringValue(Name); + } + if (options.Format != "W") + { + writer.WritePropertyName("type"u8); + writer.WriteStringValue(ResourceType); + } + if (options.Format != "W" && Optional.IsDefined(SystemData)) + { + writer.WritePropertyName("systemData"u8); + JsonSerializer.Serialize(writer, SystemData); + } + if (options.Format != "W" && _serializedAdditionalRawData != null) + { + foreach (var item in _serializedAdditionalRawData) + { + writer.WritePropertyName(item.Key); +#if NET6_0_OR_GREATER + writer.WriteRawValue(item.Value); +#else + using (JsonDocument document = JsonDocument.Parse(item.Value)) + { + JsonSerializer.Serialize(writer, document.RootElement); + } +#endif + } + } + writer.WriteEndObject(); + } + + DeploymentStackValidateResult IJsonModel.Create(ref Utf8JsonReader reader, ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + if (format != "J") + { + throw new FormatException($"The model {nameof(DeploymentStackValidateResult)} does not support reading '{format}' format."); + } + + using JsonDocument document = JsonDocument.ParseValue(ref reader); + return DeserializeDeploymentStackValidateResult(document.RootElement, options); + } + + internal static DeploymentStackValidateResult DeserializeDeploymentStackValidateResult(JsonElement element, ModelReaderWriterOptions options = null) + { + options ??= ModelSerializationExtensions.WireOptions; + + if (element.ValueKind == JsonValueKind.Null) + { + return null; + } + DeploymentStackValidateProperties properties = default; + ResponseError error = default; + ResourceIdentifier id = default; + string name = default; + ResourceType type = default; + SystemData systemData = default; + IDictionary serializedAdditionalRawData = default; + Dictionary rawDataDictionary = new Dictionary(); + foreach (var property in element.EnumerateObject()) + { + if (property.NameEquals("properties"u8)) + { + if (property.Value.ValueKind == JsonValueKind.Null) + { + continue; + } + properties = DeploymentStackValidateProperties.DeserializeDeploymentStackValidateProperties(property.Value, options); + continue; + } + if (property.NameEquals("error"u8)) + { + if (property.Value.ValueKind == JsonValueKind.Null) + { + continue; + } + error = JsonSerializer.Deserialize(property.Value.GetRawText()); + continue; + } + if (property.NameEquals("id"u8)) + { + id = new ResourceIdentifier(property.Value.GetString()); + continue; + } + if (property.NameEquals("name"u8)) + { + name = property.Value.GetString(); + continue; + } + if (property.NameEquals("type"u8)) + { + type = new ResourceType(property.Value.GetString()); + continue; + } + if (property.NameEquals("systemData"u8)) + { + if (property.Value.ValueKind == JsonValueKind.Null) + { + continue; + } + systemData = JsonSerializer.Deserialize(property.Value.GetRawText()); + continue; + } + if (options.Format != "W") + { + rawDataDictionary.Add(property.Name, BinaryData.FromString(property.Value.GetRawText())); + } + } + serializedAdditionalRawData = rawDataDictionary; + return new DeploymentStackValidateResult( + id, + name, + type, + systemData, + properties, + error, + serializedAdditionalRawData); + } + + private BinaryData SerializeBicep(ModelReaderWriterOptions options) + { + StringBuilder builder = new StringBuilder(); + BicepModelReaderWriterOptions bicepOptions = options as BicepModelReaderWriterOptions; + IDictionary propertyOverrides = null; + bool hasObjectOverride = bicepOptions != null && bicepOptions.PropertyOverrides.TryGetValue(this, out propertyOverrides); + bool hasPropertyOverride = false; + string propertyOverride = null; + + builder.AppendLine("{"); + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(Name), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" name: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(Name)) + { + builder.Append(" name: "); + if (Name.Contains(Environment.NewLine)) + { + builder.AppendLine("'''"); + builder.AppendLine($"{Name}'''"); + } + else + { + builder.AppendLine($"'{Name}'"); + } + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(Properties), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" properties: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(Properties)) + { + builder.Append(" properties: "); + BicepSerializationHelpers.AppendChildObject(builder, Properties, options, 2, false, " properties: "); + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(Error), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" error: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(Error)) + { + builder.Append(" error: "); + BicepSerializationHelpers.AppendChildObject(builder, Error, options, 2, false, " error: "); + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(Id), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" id: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(Id)) + { + builder.Append(" id: "); + builder.AppendLine($"'{Id.ToString()}'"); + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(SystemData), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" systemData: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(SystemData)) + { + builder.Append(" systemData: "); + builder.AppendLine($"'{SystemData.ToString()}'"); + } + } + + builder.AppendLine("}"); + return BinaryData.FromString(builder.ToString()); + } + + BinaryData IPersistableModel.Write(ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + + switch (format) + { + case "J": + return ModelReaderWriter.Write(this, options); + case "bicep": + return SerializeBicep(options); + default: + throw new FormatException($"The model {nameof(DeploymentStackValidateResult)} does not support writing '{options.Format}' format."); + } + } + + DeploymentStackValidateResult IPersistableModel.Create(BinaryData data, ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + + switch (format) + { + case "J": + { + using JsonDocument document = JsonDocument.Parse(data); + return DeserializeDeploymentStackValidateResult(document.RootElement, options); + } + default: + throw new FormatException($"The model {nameof(DeploymentStackValidateResult)} does not support reading '{options.Format}' format."); + } + } + + string IPersistableModel.GetFormatFromOptions(ModelReaderWriterOptions options) => "J"; + } +} diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStackValidateResult.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStackValidateResult.cs new file mode 100644 index 0000000000000..cb00b8393f8be --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStackValidateResult.cs @@ -0,0 +1,77 @@ +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. + +// + +#nullable disable + +using System; +using System.Collections.Generic; +using Azure.Core; +using Azure.ResourceManager.Models; + +namespace Azure.ResourceManager.Resources.Models +{ + /// The Deployment stack validation result. + public partial class DeploymentStackValidateResult : ResourceData + { + /// + /// Keeps track of any properties unknown to the library. + /// + /// To assign an object to the value of this property use . + /// + /// + /// To assign an already formatted json string to this property use . + /// + /// + /// Examples: + /// + /// + /// BinaryData.FromObjectAsJson("foo") + /// Creates a payload of "foo". + /// + /// + /// BinaryData.FromString("\"foo\"") + /// Creates a payload of "foo". + /// + /// + /// BinaryData.FromObjectAsJson(new { key = "value" }) + /// Creates a payload of { "key": "value" }. + /// + /// + /// BinaryData.FromString("{\"key\": \"value\"}") + /// Creates a payload of { "key": "value" }. + /// + /// + /// + /// + private IDictionary _serializedAdditionalRawData; + + /// Initializes a new instance of . + public DeploymentStackValidateResult() + { + } + + /// Initializes a new instance of . + /// The id. + /// The name. + /// The resourceType. + /// The systemData. + /// The validation result details. + /// The error detail. + /// Keeps track of any properties unknown to the library. + internal DeploymentStackValidateResult(ResourceIdentifier id, string name, ResourceType resourceType, SystemData systemData, DeploymentStackValidateProperties properties, ResponseError error, IDictionary serializedAdditionalRawData) : base(id, name, resourceType, systemData) + { + Properties = properties; + Error = error; + _serializedAdditionalRawData = serializedAdditionalRawData; + } + + /// The validation result details. + [WirePath("properties")] + public DeploymentStackValidateProperties Properties { get; set; } + /// The error detail. + [WirePath("error")] + public ResponseError Error { get; set; } + } +} diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStacksDebugSetting.Serialization.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStacksDebugSetting.Serialization.cs new file mode 100644 index 0000000000000..a2c8a225d0952 --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStacksDebugSetting.Serialization.cs @@ -0,0 +1,163 @@ +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. + +// + +#nullable disable + +using System; +using System.ClientModel.Primitives; +using System.Collections.Generic; +using System.Text; +using System.Text.Json; +using Azure.Core; + +namespace Azure.ResourceManager.Resources.Models +{ + internal partial class DeploymentStacksDebugSetting : IUtf8JsonSerializable, IJsonModel + { + void IUtf8JsonSerializable.Write(Utf8JsonWriter writer) => ((IJsonModel)this).Write(writer, ModelSerializationExtensions.WireOptions); + + void IJsonModel.Write(Utf8JsonWriter writer, ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + if (format != "J") + { + throw new FormatException($"The model {nameof(DeploymentStacksDebugSetting)} does not support writing '{format}' format."); + } + + writer.WriteStartObject(); + if (Optional.IsDefined(DetailLevel)) + { + writer.WritePropertyName("detailLevel"u8); + writer.WriteStringValue(DetailLevel); + } + if (options.Format != "W" && _serializedAdditionalRawData != null) + { + foreach (var item in _serializedAdditionalRawData) + { + writer.WritePropertyName(item.Key); +#if NET6_0_OR_GREATER + writer.WriteRawValue(item.Value); +#else + using (JsonDocument document = JsonDocument.Parse(item.Value)) + { + JsonSerializer.Serialize(writer, document.RootElement); + } +#endif + } + } + writer.WriteEndObject(); + } + + DeploymentStacksDebugSetting IJsonModel.Create(ref Utf8JsonReader reader, ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + if (format != "J") + { + throw new FormatException($"The model {nameof(DeploymentStacksDebugSetting)} does not support reading '{format}' format."); + } + + using JsonDocument document = JsonDocument.ParseValue(ref reader); + return DeserializeDeploymentStacksDebugSetting(document.RootElement, options); + } + + internal static DeploymentStacksDebugSetting DeserializeDeploymentStacksDebugSetting(JsonElement element, ModelReaderWriterOptions options = null) + { + options ??= ModelSerializationExtensions.WireOptions; + + if (element.ValueKind == JsonValueKind.Null) + { + return null; + } + string detailLevel = default; + IDictionary serializedAdditionalRawData = default; + Dictionary rawDataDictionary = new Dictionary(); + foreach (var property in element.EnumerateObject()) + { + if (property.NameEquals("detailLevel"u8)) + { + detailLevel = property.Value.GetString(); + continue; + } + if (options.Format != "W") + { + rawDataDictionary.Add(property.Name, BinaryData.FromString(property.Value.GetRawText())); + } + } + serializedAdditionalRawData = rawDataDictionary; + return new DeploymentStacksDebugSetting(detailLevel, serializedAdditionalRawData); + } + + private BinaryData SerializeBicep(ModelReaderWriterOptions options) + { + StringBuilder builder = new StringBuilder(); + BicepModelReaderWriterOptions bicepOptions = options as BicepModelReaderWriterOptions; + IDictionary propertyOverrides = null; + bool hasObjectOverride = bicepOptions != null && bicepOptions.PropertyOverrides.TryGetValue(this, out propertyOverrides); + bool hasPropertyOverride = false; + string propertyOverride = null; + + builder.AppendLine("{"); + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(DetailLevel), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" detailLevel: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(DetailLevel)) + { + builder.Append(" detailLevel: "); + if (DetailLevel.Contains(Environment.NewLine)) + { + builder.AppendLine("'''"); + builder.AppendLine($"{DetailLevel}'''"); + } + else + { + builder.AppendLine($"'{DetailLevel}'"); + } + } + } + + builder.AppendLine("}"); + return BinaryData.FromString(builder.ToString()); + } + + BinaryData IPersistableModel.Write(ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + + switch (format) + { + case "J": + return ModelReaderWriter.Write(this, options); + case "bicep": + return SerializeBicep(options); + default: + throw new FormatException($"The model {nameof(DeploymentStacksDebugSetting)} does not support writing '{options.Format}' format."); + } + } + + DeploymentStacksDebugSetting IPersistableModel.Create(BinaryData data, ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + + switch (format) + { + case "J": + { + using JsonDocument document = JsonDocument.Parse(data); + return DeserializeDeploymentStacksDebugSetting(document.RootElement, options); + } + default: + throw new FormatException($"The model {nameof(DeploymentStacksDebugSetting)} does not support reading '{options.Format}' format."); + } + } + + string IPersistableModel.GetFormatFromOptions(ModelReaderWriterOptions options) => "J"; + } +} diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStacksDebugSetting.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStacksDebugSetting.cs new file mode 100644 index 0000000000000..b1c41ea88b884 --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStacksDebugSetting.cs @@ -0,0 +1,66 @@ +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. + +// + +#nullable disable + +using System; +using System.Collections.Generic; + +namespace Azure.ResourceManager.Resources.Models +{ + /// The debug setting. + internal partial class DeploymentStacksDebugSetting + { + /// + /// Keeps track of any properties unknown to the library. + /// + /// To assign an object to the value of this property use . + /// + /// + /// To assign an already formatted json string to this property use . + /// + /// + /// Examples: + /// + /// + /// BinaryData.FromObjectAsJson("foo") + /// Creates a payload of "foo". + /// + /// + /// BinaryData.FromString("\"foo\"") + /// Creates a payload of "foo". + /// + /// + /// BinaryData.FromObjectAsJson(new { key = "value" }) + /// Creates a payload of { "key": "value" }. + /// + /// + /// BinaryData.FromString("{\"key\": \"value\"}") + /// Creates a payload of { "key": "value" }. + /// + /// + /// + /// + private IDictionary _serializedAdditionalRawData; + + /// Initializes a new instance of . + public DeploymentStacksDebugSetting() + { + } + + /// Initializes a new instance of . + /// Specifies the type of information to log for debugging. The permitted values are none, requestContent, responseContent, or both requestContent and responseContent separated by a comma. The default is none. When setting this value, carefully consider the type of information that is being passed in during deployment. By logging information about the request or response, sensitive data that is retrieved through the deployment operations could potentially be exposed. + /// Keeps track of any properties unknown to the library. + internal DeploymentStacksDebugSetting(string detailLevel, IDictionary serializedAdditionalRawData) + { + DetailLevel = detailLevel; + _serializedAdditionalRawData = serializedAdditionalRawData; + } + + /// Specifies the type of information to log for debugging. The permitted values are none, requestContent, responseContent, or both requestContent and responseContent separated by a comma. The default is none. When setting this value, carefully consider the type of information that is being passed in during deployment. By logging information about the request or response, sensitive data that is retrieved through the deployment operations could potentially be exposed. + [WirePath("detailLevel")] + public string DetailLevel { get; set; } + } +} diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStacksDeleteDetachEnum.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStacksDeleteDetachEnum.cs new file mode 100644 index 0000000000000..b59810cebb3b7 --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStacksDeleteDetachEnum.cs @@ -0,0 +1,51 @@ +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. + +// + +#nullable disable + +using System; +using System.ComponentModel; + +namespace Azure.ResourceManager.Resources.Models +{ + /// Specifies an action for a newly unmanaged resource. Delete will attempt to delete the resource from Azure. Detach will leave the resource in it's current state. + public readonly partial struct DeploymentStacksDeleteDetachEnum : IEquatable + { + private readonly string _value; + + /// Initializes a new instance of . + /// is null. + public DeploymentStacksDeleteDetachEnum(string value) + { + _value = value ?? throw new ArgumentNullException(nameof(value)); + } + + private const string DeleteValue = "delete"; + private const string DetachValue = "detach"; + + /// delete. + public static DeploymentStacksDeleteDetachEnum Delete { get; } = new DeploymentStacksDeleteDetachEnum(DeleteValue); + /// detach. + public static DeploymentStacksDeleteDetachEnum Detach { get; } = new DeploymentStacksDeleteDetachEnum(DetachValue); + /// Determines if two values are the same. + public static bool operator ==(DeploymentStacksDeleteDetachEnum left, DeploymentStacksDeleteDetachEnum right) => left.Equals(right); + /// Determines if two values are not the same. + public static bool operator !=(DeploymentStacksDeleteDetachEnum left, DeploymentStacksDeleteDetachEnum right) => !left.Equals(right); + /// Converts a string to a . + public static implicit operator DeploymentStacksDeleteDetachEnum(string value) => new DeploymentStacksDeleteDetachEnum(value); + + /// + [EditorBrowsable(EditorBrowsableState.Never)] + public override bool Equals(object obj) => obj is DeploymentStacksDeleteDetachEnum other && Equals(other); + /// + public bool Equals(DeploymentStacksDeleteDetachEnum other) => string.Equals(_value, other._value, StringComparison.InvariantCultureIgnoreCase); + + /// + [EditorBrowsable(EditorBrowsableState.Never)] + public override int GetHashCode() => _value != null ? StringComparer.InvariantCultureIgnoreCase.GetHashCode(_value) : 0; + /// + public override string ToString() => _value; + } +} diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStacksParametersLink.Serialization.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStacksParametersLink.Serialization.cs new file mode 100644 index 0000000000000..2f4566cc45368 --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStacksParametersLink.Serialization.cs @@ -0,0 +1,186 @@ +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. + +// + +#nullable disable + +using System; +using System.ClientModel.Primitives; +using System.Collections.Generic; +using System.Text; +using System.Text.Json; +using Azure.Core; + +namespace Azure.ResourceManager.Resources.Models +{ + public partial class DeploymentStacksParametersLink : IUtf8JsonSerializable, IJsonModel + { + void IUtf8JsonSerializable.Write(Utf8JsonWriter writer) => ((IJsonModel)this).Write(writer, ModelSerializationExtensions.WireOptions); + + void IJsonModel.Write(Utf8JsonWriter writer, ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + if (format != "J") + { + throw new FormatException($"The model {nameof(DeploymentStacksParametersLink)} does not support writing '{format}' format."); + } + + writer.WriteStartObject(); + writer.WritePropertyName("uri"u8); + writer.WriteStringValue(Uri.AbsoluteUri); + if (Optional.IsDefined(ContentVersion)) + { + writer.WritePropertyName("contentVersion"u8); + writer.WriteStringValue(ContentVersion); + } + if (options.Format != "W" && _serializedAdditionalRawData != null) + { + foreach (var item in _serializedAdditionalRawData) + { + writer.WritePropertyName(item.Key); +#if NET6_0_OR_GREATER + writer.WriteRawValue(item.Value); +#else + using (JsonDocument document = JsonDocument.Parse(item.Value)) + { + JsonSerializer.Serialize(writer, document.RootElement); + } +#endif + } + } + writer.WriteEndObject(); + } + + DeploymentStacksParametersLink IJsonModel.Create(ref Utf8JsonReader reader, ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + if (format != "J") + { + throw new FormatException($"The model {nameof(DeploymentStacksParametersLink)} does not support reading '{format}' format."); + } + + using JsonDocument document = JsonDocument.ParseValue(ref reader); + return DeserializeDeploymentStacksParametersLink(document.RootElement, options); + } + + internal static DeploymentStacksParametersLink DeserializeDeploymentStacksParametersLink(JsonElement element, ModelReaderWriterOptions options = null) + { + options ??= ModelSerializationExtensions.WireOptions; + + if (element.ValueKind == JsonValueKind.Null) + { + return null; + } + Uri uri = default; + string contentVersion = default; + IDictionary serializedAdditionalRawData = default; + Dictionary rawDataDictionary = new Dictionary(); + foreach (var property in element.EnumerateObject()) + { + if (property.NameEquals("uri"u8)) + { + uri = new Uri(property.Value.GetString()); + continue; + } + if (property.NameEquals("contentVersion"u8)) + { + contentVersion = property.Value.GetString(); + continue; + } + if (options.Format != "W") + { + rawDataDictionary.Add(property.Name, BinaryData.FromString(property.Value.GetRawText())); + } + } + serializedAdditionalRawData = rawDataDictionary; + return new DeploymentStacksParametersLink(uri, contentVersion, serializedAdditionalRawData); + } + + private BinaryData SerializeBicep(ModelReaderWriterOptions options) + { + StringBuilder builder = new StringBuilder(); + BicepModelReaderWriterOptions bicepOptions = options as BicepModelReaderWriterOptions; + IDictionary propertyOverrides = null; + bool hasObjectOverride = bicepOptions != null && bicepOptions.PropertyOverrides.TryGetValue(this, out propertyOverrides); + bool hasPropertyOverride = false; + string propertyOverride = null; + + builder.AppendLine("{"); + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(Uri), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" uri: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(Uri)) + { + builder.Append(" uri: "); + builder.AppendLine($"'{Uri.AbsoluteUri}'"); + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(ContentVersion), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" contentVersion: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(ContentVersion)) + { + builder.Append(" contentVersion: "); + if (ContentVersion.Contains(Environment.NewLine)) + { + builder.AppendLine("'''"); + builder.AppendLine($"{ContentVersion}'''"); + } + else + { + builder.AppendLine($"'{ContentVersion}'"); + } + } + } + + builder.AppendLine("}"); + return BinaryData.FromString(builder.ToString()); + } + + BinaryData IPersistableModel.Write(ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + + switch (format) + { + case "J": + return ModelReaderWriter.Write(this, options); + case "bicep": + return SerializeBicep(options); + default: + throw new FormatException($"The model {nameof(DeploymentStacksParametersLink)} does not support writing '{options.Format}' format."); + } + } + + DeploymentStacksParametersLink IPersistableModel.Create(BinaryData data, ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + + switch (format) + { + case "J": + { + using JsonDocument document = JsonDocument.Parse(data); + return DeserializeDeploymentStacksParametersLink(document.RootElement, options); + } + default: + throw new FormatException($"The model {nameof(DeploymentStacksParametersLink)} does not support reading '{options.Format}' format."); + } + } + + string IPersistableModel.GetFormatFromOptions(ModelReaderWriterOptions options) => "J"; + } +} diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStacksParametersLink.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStacksParametersLink.cs new file mode 100644 index 0000000000000..72e7f5a22a7fa --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStacksParametersLink.cs @@ -0,0 +1,81 @@ +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. + +// + +#nullable disable + +using System; +using System.Collections.Generic; + +namespace Azure.ResourceManager.Resources.Models +{ + /// Entity representing the reference to the deployment parameters. + public partial class DeploymentStacksParametersLink + { + /// + /// Keeps track of any properties unknown to the library. + /// + /// To assign an object to the value of this property use . + /// + /// + /// To assign an already formatted json string to this property use . + /// + /// + /// Examples: + /// + /// + /// BinaryData.FromObjectAsJson("foo") + /// Creates a payload of "foo". + /// + /// + /// BinaryData.FromString("\"foo\"") + /// Creates a payload of "foo". + /// + /// + /// BinaryData.FromObjectAsJson(new { key = "value" }) + /// Creates a payload of { "key": "value" }. + /// + /// + /// BinaryData.FromString("{\"key\": \"value\"}") + /// Creates a payload of { "key": "value" }. + /// + /// + /// + /// + private IDictionary _serializedAdditionalRawData; + + /// Initializes a new instance of . + /// The URI of the parameters file. + /// is null. + public DeploymentStacksParametersLink(Uri uri) + { + Argument.AssertNotNull(uri, nameof(uri)); + + Uri = uri; + } + + /// Initializes a new instance of . + /// The URI of the parameters file. + /// If included, must match the ContentVersion in the template. + /// Keeps track of any properties unknown to the library. + internal DeploymentStacksParametersLink(Uri uri, string contentVersion, IDictionary serializedAdditionalRawData) + { + Uri = uri; + ContentVersion = contentVersion; + _serializedAdditionalRawData = serializedAdditionalRawData; + } + + /// Initializes a new instance of for deserialization. + internal DeploymentStacksParametersLink() + { + } + + /// The URI of the parameters file. + [WirePath("uri")] + public Uri Uri { get; set; } + /// If included, must match the ContentVersion in the template. + [WirePath("contentVersion")] + public string ContentVersion { get; set; } + } +} diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStacksTemplateLink.Serialization.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStacksTemplateLink.Serialization.cs new file mode 100644 index 0000000000000..dc4c06562d8df --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStacksTemplateLink.Serialization.cs @@ -0,0 +1,301 @@ +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. + +// + +#nullable disable + +using System; +using System.ClientModel.Primitives; +using System.Collections.Generic; +using System.Text; +using System.Text.Json; +using Azure.Core; + +namespace Azure.ResourceManager.Resources.Models +{ + public partial class DeploymentStacksTemplateLink : IUtf8JsonSerializable, IJsonModel + { + void IUtf8JsonSerializable.Write(Utf8JsonWriter writer) => ((IJsonModel)this).Write(writer, ModelSerializationExtensions.WireOptions); + + void IJsonModel.Write(Utf8JsonWriter writer, ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + if (format != "J") + { + throw new FormatException($"The model {nameof(DeploymentStacksTemplateLink)} does not support writing '{format}' format."); + } + + writer.WriteStartObject(); + if (Optional.IsDefined(Uri)) + { + writer.WritePropertyName("uri"u8); + writer.WriteStringValue(Uri.AbsoluteUri); + } + if (Optional.IsDefined(Id)) + { + writer.WritePropertyName("id"u8); + writer.WriteStringValue(Id); + } + if (Optional.IsDefined(RelativePath)) + { + writer.WritePropertyName("relativePath"u8); + writer.WriteStringValue(RelativePath); + } + if (Optional.IsDefined(QueryString)) + { + writer.WritePropertyName("queryString"u8); + writer.WriteStringValue(QueryString); + } + if (Optional.IsDefined(ContentVersion)) + { + writer.WritePropertyName("contentVersion"u8); + writer.WriteStringValue(ContentVersion); + } + if (options.Format != "W" && _serializedAdditionalRawData != null) + { + foreach (var item in _serializedAdditionalRawData) + { + writer.WritePropertyName(item.Key); +#if NET6_0_OR_GREATER + writer.WriteRawValue(item.Value); +#else + using (JsonDocument document = JsonDocument.Parse(item.Value)) + { + JsonSerializer.Serialize(writer, document.RootElement); + } +#endif + } + } + writer.WriteEndObject(); + } + + DeploymentStacksTemplateLink IJsonModel.Create(ref Utf8JsonReader reader, ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + if (format != "J") + { + throw new FormatException($"The model {nameof(DeploymentStacksTemplateLink)} does not support reading '{format}' format."); + } + + using JsonDocument document = JsonDocument.ParseValue(ref reader); + return DeserializeDeploymentStacksTemplateLink(document.RootElement, options); + } + + internal static DeploymentStacksTemplateLink DeserializeDeploymentStacksTemplateLink(JsonElement element, ModelReaderWriterOptions options = null) + { + options ??= ModelSerializationExtensions.WireOptions; + + if (element.ValueKind == JsonValueKind.Null) + { + return null; + } + Uri uri = default; + string id = default; + string relativePath = default; + string queryString = default; + string contentVersion = default; + IDictionary serializedAdditionalRawData = default; + Dictionary rawDataDictionary = new Dictionary(); + foreach (var property in element.EnumerateObject()) + { + if (property.NameEquals("uri"u8)) + { + if (property.Value.ValueKind == JsonValueKind.Null) + { + continue; + } + uri = new Uri(property.Value.GetString()); + continue; + } + if (property.NameEquals("id"u8)) + { + id = property.Value.GetString(); + continue; + } + if (property.NameEquals("relativePath"u8)) + { + relativePath = property.Value.GetString(); + continue; + } + if (property.NameEquals("queryString"u8)) + { + queryString = property.Value.GetString(); + continue; + } + if (property.NameEquals("contentVersion"u8)) + { + contentVersion = property.Value.GetString(); + continue; + } + if (options.Format != "W") + { + rawDataDictionary.Add(property.Name, BinaryData.FromString(property.Value.GetRawText())); + } + } + serializedAdditionalRawData = rawDataDictionary; + return new DeploymentStacksTemplateLink( + uri, + id, + relativePath, + queryString, + contentVersion, + serializedAdditionalRawData); + } + + private BinaryData SerializeBicep(ModelReaderWriterOptions options) + { + StringBuilder builder = new StringBuilder(); + BicepModelReaderWriterOptions bicepOptions = options as BicepModelReaderWriterOptions; + IDictionary propertyOverrides = null; + bool hasObjectOverride = bicepOptions != null && bicepOptions.PropertyOverrides.TryGetValue(this, out propertyOverrides); + bool hasPropertyOverride = false; + string propertyOverride = null; + + builder.AppendLine("{"); + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(Uri), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" uri: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(Uri)) + { + builder.Append(" uri: "); + builder.AppendLine($"'{Uri.AbsoluteUri}'"); + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(Id), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" id: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(Id)) + { + builder.Append(" id: "); + if (Id.Contains(Environment.NewLine)) + { + builder.AppendLine("'''"); + builder.AppendLine($"{Id}'''"); + } + else + { + builder.AppendLine($"'{Id}'"); + } + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(RelativePath), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" relativePath: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(RelativePath)) + { + builder.Append(" relativePath: "); + if (RelativePath.Contains(Environment.NewLine)) + { + builder.AppendLine("'''"); + builder.AppendLine($"{RelativePath}'''"); + } + else + { + builder.AppendLine($"'{RelativePath}'"); + } + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(QueryString), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" queryString: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(QueryString)) + { + builder.Append(" queryString: "); + if (QueryString.Contains(Environment.NewLine)) + { + builder.AppendLine("'''"); + builder.AppendLine($"{QueryString}'''"); + } + else + { + builder.AppendLine($"'{QueryString}'"); + } + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(ContentVersion), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" contentVersion: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(ContentVersion)) + { + builder.Append(" contentVersion: "); + if (ContentVersion.Contains(Environment.NewLine)) + { + builder.AppendLine("'''"); + builder.AppendLine($"{ContentVersion}'''"); + } + else + { + builder.AppendLine($"'{ContentVersion}'"); + } + } + } + + builder.AppendLine("}"); + return BinaryData.FromString(builder.ToString()); + } + + BinaryData IPersistableModel.Write(ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + + switch (format) + { + case "J": + return ModelReaderWriter.Write(this, options); + case "bicep": + return SerializeBicep(options); + default: + throw new FormatException($"The model {nameof(DeploymentStacksTemplateLink)} does not support writing '{options.Format}' format."); + } + } + + DeploymentStacksTemplateLink IPersistableModel.Create(BinaryData data, ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + + switch (format) + { + case "J": + { + using JsonDocument document = JsonDocument.Parse(data); + return DeserializeDeploymentStacksTemplateLink(document.RootElement, options); + } + default: + throw new FormatException($"The model {nameof(DeploymentStacksTemplateLink)} does not support reading '{options.Format}' format."); + } + } + + string IPersistableModel.GetFormatFromOptions(ModelReaderWriterOptions options) => "J"; + } +} diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStacksTemplateLink.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStacksTemplateLink.cs new file mode 100644 index 0000000000000..6da14d9e0ac6d --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/DeploymentStacksTemplateLink.cs @@ -0,0 +1,86 @@ +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. + +// + +#nullable disable + +using System; +using System.Collections.Generic; + +namespace Azure.ResourceManager.Resources.Models +{ + /// Entity representing the reference to the template. + public partial class DeploymentStacksTemplateLink + { + /// + /// Keeps track of any properties unknown to the library. + /// + /// To assign an object to the value of this property use . + /// + /// + /// To assign an already formatted json string to this property use . + /// + /// + /// Examples: + /// + /// + /// BinaryData.FromObjectAsJson("foo") + /// Creates a payload of "foo". + /// + /// + /// BinaryData.FromString("\"foo\"") + /// Creates a payload of "foo". + /// + /// + /// BinaryData.FromObjectAsJson(new { key = "value" }) + /// Creates a payload of { "key": "value" }. + /// + /// + /// BinaryData.FromString("{\"key\": \"value\"}") + /// Creates a payload of { "key": "value" }. + /// + /// + /// + /// + private IDictionary _serializedAdditionalRawData; + + /// Initializes a new instance of . + public DeploymentStacksTemplateLink() + { + } + + /// Initializes a new instance of . + /// The URI of the template to deploy. Use either the uri or id property, but not both. + /// The resourceId of a Template Spec. Use either the id or uri property, but not both. + /// The relativePath property can be used to deploy a linked template at a location relative to the parent. If the parent template was linked with a TemplateSpec, this will reference an artifact in the TemplateSpec. If the parent was linked with a URI, the child deployment will be a combination of the parent and relativePath URIs. + /// The query string (for example, a SAS token) to be used with the templateLink URI. + /// If included, must match the ContentVersion in the template. + /// Keeps track of any properties unknown to the library. + internal DeploymentStacksTemplateLink(Uri uri, string id, string relativePath, string queryString, string contentVersion, IDictionary serializedAdditionalRawData) + { + Uri = uri; + Id = id; + RelativePath = relativePath; + QueryString = queryString; + ContentVersion = contentVersion; + _serializedAdditionalRawData = serializedAdditionalRawData; + } + + /// The URI of the template to deploy. Use either the uri or id property, but not both. + [WirePath("uri")] + public Uri Uri { get; set; } + /// The resourceId of a Template Spec. Use either the id or uri property, but not both. + [WirePath("id")] + public string Id { get; set; } + /// The relativePath property can be used to deploy a linked template at a location relative to the parent. If the parent template was linked with a TemplateSpec, this will reference an artifact in the TemplateSpec. If the parent was linked with a URI, the child deployment will be a combination of the parent and relativePath URIs. + [WirePath("relativePath")] + public string RelativePath { get; set; } + /// The query string (for example, a SAS token) to be used with the templateLink URI. + [WirePath("queryString")] + public string QueryString { get; set; } + /// If included, must match the ContentVersion in the template. + [WirePath("contentVersion")] + public string ContentVersion { get; set; } + } +} diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/KeyVaultParameterReference.Serialization.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/KeyVaultParameterReference.Serialization.cs new file mode 100644 index 0000000000000..19da8ae7126ba --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/KeyVaultParameterReference.Serialization.cs @@ -0,0 +1,220 @@ +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. + +// + +#nullable disable + +using System; +using System.ClientModel.Primitives; +using System.Collections.Generic; +using System.Text; +using System.Text.Json; +using Azure.Core; + +namespace Azure.ResourceManager.Resources.Models +{ + public partial class KeyVaultParameterReference : IUtf8JsonSerializable, IJsonModel + { + void IUtf8JsonSerializable.Write(Utf8JsonWriter writer) => ((IJsonModel)this).Write(writer, ModelSerializationExtensions.WireOptions); + + void IJsonModel.Write(Utf8JsonWriter writer, ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + if (format != "J") + { + throw new FormatException($"The model {nameof(KeyVaultParameterReference)} does not support writing '{format}' format."); + } + + writer.WriteStartObject(); + writer.WritePropertyName("keyVault"u8); + JsonSerializer.Serialize(writer, KeyVault); + writer.WritePropertyName("secretName"u8); + writer.WriteStringValue(SecretName); + if (Optional.IsDefined(SecretVersion)) + { + writer.WritePropertyName("secretVersion"u8); + writer.WriteStringValue(SecretVersion); + } + if (options.Format != "W" && _serializedAdditionalRawData != null) + { + foreach (var item in _serializedAdditionalRawData) + { + writer.WritePropertyName(item.Key); +#if NET6_0_OR_GREATER + writer.WriteRawValue(item.Value); +#else + using (JsonDocument document = JsonDocument.Parse(item.Value)) + { + JsonSerializer.Serialize(writer, document.RootElement); + } +#endif + } + } + writer.WriteEndObject(); + } + + KeyVaultParameterReference IJsonModel.Create(ref Utf8JsonReader reader, ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + if (format != "J") + { + throw new FormatException($"The model {nameof(KeyVaultParameterReference)} does not support reading '{format}' format."); + } + + using JsonDocument document = JsonDocument.ParseValue(ref reader); + return DeserializeKeyVaultParameterReference(document.RootElement, options); + } + + internal static KeyVaultParameterReference DeserializeKeyVaultParameterReference(JsonElement element, ModelReaderWriterOptions options = null) + { + options ??= ModelSerializationExtensions.WireOptions; + + if (element.ValueKind == JsonValueKind.Null) + { + return null; + } + WritableSubResource keyVault = default; + string secretName = default; + string secretVersion = default; + IDictionary serializedAdditionalRawData = default; + Dictionary rawDataDictionary = new Dictionary(); + foreach (var property in element.EnumerateObject()) + { + if (property.NameEquals("keyVault"u8)) + { + keyVault = JsonSerializer.Deserialize(property.Value.GetRawText()); + continue; + } + if (property.NameEquals("secretName"u8)) + { + secretName = property.Value.GetString(); + continue; + } + if (property.NameEquals("secretVersion"u8)) + { + secretVersion = property.Value.GetString(); + continue; + } + if (options.Format != "W") + { + rawDataDictionary.Add(property.Name, BinaryData.FromString(property.Value.GetRawText())); + } + } + serializedAdditionalRawData = rawDataDictionary; + return new KeyVaultParameterReference(keyVault, secretName, secretVersion, serializedAdditionalRawData); + } + + private BinaryData SerializeBicep(ModelReaderWriterOptions options) + { + StringBuilder builder = new StringBuilder(); + BicepModelReaderWriterOptions bicepOptions = options as BicepModelReaderWriterOptions; + IDictionary propertyOverrides = null; + bool hasObjectOverride = bicepOptions != null && bicepOptions.PropertyOverrides.TryGetValue(this, out propertyOverrides); + bool hasPropertyOverride = false; + string propertyOverride = null; + + builder.AppendLine("{"); + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue("KeyVaultId", out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" keyVault: "); + builder.AppendLine("{"); + builder.Append(" id: "); + builder.AppendLine(propertyOverride); + builder.AppendLine(" }"); + } + else + { + if (Optional.IsDefined(KeyVault)) + { + builder.Append(" keyVault: "); + BicepSerializationHelpers.AppendChildObject(builder, KeyVault, options, 2, false, " keyVault: "); + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(SecretName), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" secretName: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(SecretName)) + { + builder.Append(" secretName: "); + if (SecretName.Contains(Environment.NewLine)) + { + builder.AppendLine("'''"); + builder.AppendLine($"{SecretName}'''"); + } + else + { + builder.AppendLine($"'{SecretName}'"); + } + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(SecretVersion), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" secretVersion: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(SecretVersion)) + { + builder.Append(" secretVersion: "); + if (SecretVersion.Contains(Environment.NewLine)) + { + builder.AppendLine("'''"); + builder.AppendLine($"{SecretVersion}'''"); + } + else + { + builder.AppendLine($"'{SecretVersion}'"); + } + } + } + + builder.AppendLine("}"); + return BinaryData.FromString(builder.ToString()); + } + + BinaryData IPersistableModel.Write(ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + + switch (format) + { + case "J": + return ModelReaderWriter.Write(this, options); + case "bicep": + return SerializeBicep(options); + default: + throw new FormatException($"The model {nameof(KeyVaultParameterReference)} does not support writing '{options.Format}' format."); + } + } + + KeyVaultParameterReference IPersistableModel.Create(BinaryData data, ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + + switch (format) + { + case "J": + { + using JsonDocument document = JsonDocument.Parse(data); + return DeserializeKeyVaultParameterReference(document.RootElement, options); + } + default: + throw new FormatException($"The model {nameof(KeyVaultParameterReference)} does not support reading '{options.Format}' format."); + } + } + + string IPersistableModel.GetFormatFromOptions(ModelReaderWriterOptions options) => "J"; + } +} diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/KeyVaultParameterReference.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/KeyVaultParameterReference.cs new file mode 100644 index 0000000000000..a87236944709f --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/KeyVaultParameterReference.cs @@ -0,0 +1,102 @@ +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. + +// + +#nullable disable + +using System; +using System.Collections.Generic; +using Azure.Core; + +namespace Azure.ResourceManager.Resources.Models +{ + /// Azure Key Vault parameter reference. + public partial class KeyVaultParameterReference + { + /// + /// Keeps track of any properties unknown to the library. + /// + /// To assign an object to the value of this property use . + /// + /// + /// To assign an already formatted json string to this property use . + /// + /// + /// Examples: + /// + /// + /// BinaryData.FromObjectAsJson("foo") + /// Creates a payload of "foo". + /// + /// + /// BinaryData.FromString("\"foo\"") + /// Creates a payload of "foo". + /// + /// + /// BinaryData.FromObjectAsJson(new { key = "value" }) + /// Creates a payload of { "key": "value" }. + /// + /// + /// BinaryData.FromString("{\"key\": \"value\"}") + /// Creates a payload of { "key": "value" }. + /// + /// + /// + /// + private IDictionary _serializedAdditionalRawData; + + /// Initializes a new instance of . + /// Azure Key Vault reference. + /// Azure Key Vault secret name. + /// or is null. + public KeyVaultParameterReference(WritableSubResource keyVault, string secretName) + { + Argument.AssertNotNull(keyVault, nameof(keyVault)); + Argument.AssertNotNull(secretName, nameof(secretName)); + + KeyVault = keyVault; + SecretName = secretName; + } + + /// Initializes a new instance of . + /// Azure Key Vault reference. + /// Azure Key Vault secret name. + /// Azure Key Vault secret version. + /// Keeps track of any properties unknown to the library. + internal KeyVaultParameterReference(WritableSubResource keyVault, string secretName, string secretVersion, IDictionary serializedAdditionalRawData) + { + KeyVault = keyVault; + SecretName = secretName; + SecretVersion = secretVersion; + _serializedAdditionalRawData = serializedAdditionalRawData; + } + + /// Initializes a new instance of for deserialization. + internal KeyVaultParameterReference() + { + } + + /// Azure Key Vault reference. + internal WritableSubResource KeyVault { get; set; } + /// Gets or sets Id. + [WirePath("keyVault.id")] + public ResourceIdentifier KeyVaultId + { + get => KeyVault is null ? default : KeyVault.Id; + set + { + if (KeyVault is null) + KeyVault = new WritableSubResource(); + KeyVault.Id = value; + } + } + + /// Azure Key Vault secret name. + [WirePath("secretName")] + public string SecretName { get; set; } + /// Azure Key Vault secret version. + [WirePath("secretVersion")] + public string SecretVersion { get; set; } + } +} diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/ManagedResourceReference.Serialization.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/ManagedResourceReference.Serialization.cs new file mode 100644 index 0000000000000..b3c9259d66a2b --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/ManagedResourceReference.Serialization.cs @@ -0,0 +1,223 @@ +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. + +// + +#nullable disable + +using System; +using System.ClientModel.Primitives; +using System.Collections.Generic; +using System.Text; +using System.Text.Json; +using Azure.Core; + +namespace Azure.ResourceManager.Resources.Models +{ + public partial class ManagedResourceReference : IUtf8JsonSerializable, IJsonModel + { + void IUtf8JsonSerializable.Write(Utf8JsonWriter writer) => ((IJsonModel)this).Write(writer, ModelSerializationExtensions.WireOptions); + + void IJsonModel.Write(Utf8JsonWriter writer, ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + if (format != "J") + { + throw new FormatException($"The model {nameof(ManagedResourceReference)} does not support writing '{format}' format."); + } + + writer.WriteStartObject(); + if (Optional.IsDefined(Status)) + { + writer.WritePropertyName("status"u8); + writer.WriteStringValue(Status.Value.ToString()); + } + if (Optional.IsDefined(DenyStatus)) + { + writer.WritePropertyName("denyStatus"u8); + writer.WriteStringValue(DenyStatus.Value.ToString()); + } + if (options.Format != "W" && Optional.IsDefined(Id)) + { + writer.WritePropertyName("id"u8); + writer.WriteStringValue(Id); + } + if (options.Format != "W" && _serializedAdditionalRawData != null) + { + foreach (var item in _serializedAdditionalRawData) + { + writer.WritePropertyName(item.Key); +#if NET6_0_OR_GREATER + writer.WriteRawValue(item.Value); +#else + using (JsonDocument document = JsonDocument.Parse(item.Value)) + { + JsonSerializer.Serialize(writer, document.RootElement); + } +#endif + } + } + writer.WriteEndObject(); + } + + ManagedResourceReference IJsonModel.Create(ref Utf8JsonReader reader, ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + if (format != "J") + { + throw new FormatException($"The model {nameof(ManagedResourceReference)} does not support reading '{format}' format."); + } + + using JsonDocument document = JsonDocument.ParseValue(ref reader); + return DeserializeManagedResourceReference(document.RootElement, options); + } + + internal static ManagedResourceReference DeserializeManagedResourceReference(JsonElement element, ModelReaderWriterOptions options = null) + { + options ??= ModelSerializationExtensions.WireOptions; + + if (element.ValueKind == JsonValueKind.Null) + { + return null; + } + ResourceStatusMode? status = default; + DenyStatusMode? denyStatus = default; + string id = default; + IDictionary serializedAdditionalRawData = default; + Dictionary rawDataDictionary = new Dictionary(); + foreach (var property in element.EnumerateObject()) + { + if (property.NameEquals("status"u8)) + { + if (property.Value.ValueKind == JsonValueKind.Null) + { + continue; + } + status = new ResourceStatusMode(property.Value.GetString()); + continue; + } + if (property.NameEquals("denyStatus"u8)) + { + if (property.Value.ValueKind == JsonValueKind.Null) + { + continue; + } + denyStatus = new DenyStatusMode(property.Value.GetString()); + continue; + } + if (property.NameEquals("id"u8)) + { + id = property.Value.GetString(); + continue; + } + if (options.Format != "W") + { + rawDataDictionary.Add(property.Name, BinaryData.FromString(property.Value.GetRawText())); + } + } + serializedAdditionalRawData = rawDataDictionary; + return new ManagedResourceReference(id, serializedAdditionalRawData, status, denyStatus); + } + + private BinaryData SerializeBicep(ModelReaderWriterOptions options) + { + StringBuilder builder = new StringBuilder(); + BicepModelReaderWriterOptions bicepOptions = options as BicepModelReaderWriterOptions; + IDictionary propertyOverrides = null; + bool hasObjectOverride = bicepOptions != null && bicepOptions.PropertyOverrides.TryGetValue(this, out propertyOverrides); + bool hasPropertyOverride = false; + string propertyOverride = null; + + builder.AppendLine("{"); + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(Status), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" status: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(Status)) + { + builder.Append(" status: "); + builder.AppendLine($"'{Status.Value.ToString()}'"); + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(DenyStatus), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" denyStatus: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(DenyStatus)) + { + builder.Append(" denyStatus: "); + builder.AppendLine($"'{DenyStatus.Value.ToString()}'"); + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(Id), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" id: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(Id)) + { + builder.Append(" id: "); + if (Id.Contains(Environment.NewLine)) + { + builder.AppendLine("'''"); + builder.AppendLine($"{Id}'''"); + } + else + { + builder.AppendLine($"'{Id}'"); + } + } + } + + builder.AppendLine("}"); + return BinaryData.FromString(builder.ToString()); + } + + BinaryData IPersistableModel.Write(ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + + switch (format) + { + case "J": + return ModelReaderWriter.Write(this, options); + case "bicep": + return SerializeBicep(options); + default: + throw new FormatException($"The model {nameof(ManagedResourceReference)} does not support writing '{options.Format}' format."); + } + } + + ManagedResourceReference IPersistableModel.Create(BinaryData data, ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + + switch (format) + { + case "J": + { + using JsonDocument document = JsonDocument.Parse(data); + return DeserializeManagedResourceReference(document.RootElement, options); + } + default: + throw new FormatException($"The model {nameof(ManagedResourceReference)} does not support reading '{options.Format}' format."); + } + } + + string IPersistableModel.GetFormatFromOptions(ModelReaderWriterOptions options) => "J"; + } +} diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/ManagedResourceReference.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/ManagedResourceReference.cs new file mode 100644 index 0000000000000..057cf0eaba60c --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/ManagedResourceReference.cs @@ -0,0 +1,39 @@ +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. + +// + +#nullable disable + +using System; +using System.Collections.Generic; + +namespace Azure.ResourceManager.Resources.Models +{ + /// The managed resource model. + public partial class ManagedResourceReference : ResourceReferenceAutoGenerated + { + /// Initializes a new instance of . + public ManagedResourceReference() + { + } + + /// Initializes a new instance of . + /// The resourceId of a resource managed by the deployment stack. + /// Keeps track of any properties unknown to the library. + /// Current management state of the resource in the deployment stack. + /// denyAssignment settings applied to the resource. + internal ManagedResourceReference(string id, IDictionary serializedAdditionalRawData, ResourceStatusMode? status, DenyStatusMode? denyStatus) : base(id, serializedAdditionalRawData) + { + Status = status; + DenyStatus = denyStatus; + } + + /// Current management state of the resource in the deployment stack. + [WirePath("status")] + public ResourceStatusMode? Status { get; set; } + /// denyAssignment settings applied to the resource. + [WirePath("denyStatus")] + public DenyStatusMode? DenyStatus { get; set; } + } +} diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/ResourceReferenceAutoGenerated.Serialization.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/ResourceReferenceAutoGenerated.Serialization.cs new file mode 100644 index 0000000000000..7f1b67d46ed50 --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/ResourceReferenceAutoGenerated.Serialization.cs @@ -0,0 +1,163 @@ +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. + +// + +#nullable disable + +using System; +using System.ClientModel.Primitives; +using System.Collections.Generic; +using System.Text; +using System.Text.Json; +using Azure.Core; + +namespace Azure.ResourceManager.Resources.Models +{ + public partial class ResourceReferenceAutoGenerated : IUtf8JsonSerializable, IJsonModel + { + void IUtf8JsonSerializable.Write(Utf8JsonWriter writer) => ((IJsonModel)this).Write(writer, ModelSerializationExtensions.WireOptions); + + void IJsonModel.Write(Utf8JsonWriter writer, ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + if (format != "J") + { + throw new FormatException($"The model {nameof(ResourceReferenceAutoGenerated)} does not support writing '{format}' format."); + } + + writer.WriteStartObject(); + if (options.Format != "W" && Optional.IsDefined(Id)) + { + writer.WritePropertyName("id"u8); + writer.WriteStringValue(Id); + } + if (options.Format != "W" && _serializedAdditionalRawData != null) + { + foreach (var item in _serializedAdditionalRawData) + { + writer.WritePropertyName(item.Key); +#if NET6_0_OR_GREATER + writer.WriteRawValue(item.Value); +#else + using (JsonDocument document = JsonDocument.Parse(item.Value)) + { + JsonSerializer.Serialize(writer, document.RootElement); + } +#endif + } + } + writer.WriteEndObject(); + } + + ResourceReferenceAutoGenerated IJsonModel.Create(ref Utf8JsonReader reader, ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + if (format != "J") + { + throw new FormatException($"The model {nameof(ResourceReferenceAutoGenerated)} does not support reading '{format}' format."); + } + + using JsonDocument document = JsonDocument.ParseValue(ref reader); + return DeserializeResourceReferenceAutoGenerated(document.RootElement, options); + } + + internal static ResourceReferenceAutoGenerated DeserializeResourceReferenceAutoGenerated(JsonElement element, ModelReaderWriterOptions options = null) + { + options ??= ModelSerializationExtensions.WireOptions; + + if (element.ValueKind == JsonValueKind.Null) + { + return null; + } + string id = default; + IDictionary serializedAdditionalRawData = default; + Dictionary rawDataDictionary = new Dictionary(); + foreach (var property in element.EnumerateObject()) + { + if (property.NameEquals("id"u8)) + { + id = property.Value.GetString(); + continue; + } + if (options.Format != "W") + { + rawDataDictionary.Add(property.Name, BinaryData.FromString(property.Value.GetRawText())); + } + } + serializedAdditionalRawData = rawDataDictionary; + return new ResourceReferenceAutoGenerated(id, serializedAdditionalRawData); + } + + private BinaryData SerializeBicep(ModelReaderWriterOptions options) + { + StringBuilder builder = new StringBuilder(); + BicepModelReaderWriterOptions bicepOptions = options as BicepModelReaderWriterOptions; + IDictionary propertyOverrides = null; + bool hasObjectOverride = bicepOptions != null && bicepOptions.PropertyOverrides.TryGetValue(this, out propertyOverrides); + bool hasPropertyOverride = false; + string propertyOverride = null; + + builder.AppendLine("{"); + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(Id), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" id: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(Id)) + { + builder.Append(" id: "); + if (Id.Contains(Environment.NewLine)) + { + builder.AppendLine("'''"); + builder.AppendLine($"{Id}'''"); + } + else + { + builder.AppendLine($"'{Id}'"); + } + } + } + + builder.AppendLine("}"); + return BinaryData.FromString(builder.ToString()); + } + + BinaryData IPersistableModel.Write(ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + + switch (format) + { + case "J": + return ModelReaderWriter.Write(this, options); + case "bicep": + return SerializeBicep(options); + default: + throw new FormatException($"The model {nameof(ResourceReferenceAutoGenerated)} does not support writing '{options.Format}' format."); + } + } + + ResourceReferenceAutoGenerated IPersistableModel.Create(BinaryData data, ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + + switch (format) + { + case "J": + { + using JsonDocument document = JsonDocument.Parse(data); + return DeserializeResourceReferenceAutoGenerated(document.RootElement, options); + } + default: + throw new FormatException($"The model {nameof(ResourceReferenceAutoGenerated)} does not support reading '{options.Format}' format."); + } + } + + string IPersistableModel.GetFormatFromOptions(ModelReaderWriterOptions options) => "J"; + } +} diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/ResourceReferenceAutoGenerated.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/ResourceReferenceAutoGenerated.cs new file mode 100644 index 0000000000000..c49b3ed0893f5 --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/ResourceReferenceAutoGenerated.cs @@ -0,0 +1,66 @@ +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. + +// + +#nullable disable + +using System; +using System.Collections.Generic; + +namespace Azure.ResourceManager.Resources.Models +{ + /// The resourceId model. + public partial class ResourceReferenceAutoGenerated + { + /// + /// Keeps track of any properties unknown to the library. + /// + /// To assign an object to the value of this property use . + /// + /// + /// To assign an already formatted json string to this property use . + /// + /// + /// Examples: + /// + /// + /// BinaryData.FromObjectAsJson("foo") + /// Creates a payload of "foo". + /// + /// + /// BinaryData.FromString("\"foo\"") + /// Creates a payload of "foo". + /// + /// + /// BinaryData.FromObjectAsJson(new { key = "value" }) + /// Creates a payload of { "key": "value" }. + /// + /// + /// BinaryData.FromString("{\"key\": \"value\"}") + /// Creates a payload of { "key": "value" }. + /// + /// + /// + /// + private protected IDictionary _serializedAdditionalRawData; + + /// Initializes a new instance of . + public ResourceReferenceAutoGenerated() + { + } + + /// Initializes a new instance of . + /// The resourceId of a resource managed by the deployment stack. + /// Keeps track of any properties unknown to the library. + internal ResourceReferenceAutoGenerated(string id, IDictionary serializedAdditionalRawData) + { + Id = id; + _serializedAdditionalRawData = serializedAdditionalRawData; + } + + /// The resourceId of a resource managed by the deployment stack. + [WirePath("id")] + public string Id { get; } + } +} diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/ResourceReferenceExtended.Serialization.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/ResourceReferenceExtended.Serialization.cs new file mode 100644 index 0000000000000..26e718825ebea --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/ResourceReferenceExtended.Serialization.cs @@ -0,0 +1,193 @@ +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. + +// + +#nullable disable + +using System; +using System.ClientModel.Primitives; +using System.Collections.Generic; +using System.Text; +using System.Text.Json; +using Azure.Core; + +namespace Azure.ResourceManager.Resources.Models +{ + public partial class ResourceReferenceExtended : IUtf8JsonSerializable, IJsonModel + { + void IUtf8JsonSerializable.Write(Utf8JsonWriter writer) => ((IJsonModel)this).Write(writer, ModelSerializationExtensions.WireOptions); + + void IJsonModel.Write(Utf8JsonWriter writer, ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + if (format != "J") + { + throw new FormatException($"The model {nameof(ResourceReferenceExtended)} does not support writing '{format}' format."); + } + + writer.WriteStartObject(); + if (Optional.IsDefined(Error)) + { + writer.WritePropertyName("error"u8); + JsonSerializer.Serialize(writer, Error); + } + if (options.Format != "W" && Optional.IsDefined(Id)) + { + writer.WritePropertyName("id"u8); + writer.WriteStringValue(Id); + } + if (options.Format != "W" && _serializedAdditionalRawData != null) + { + foreach (var item in _serializedAdditionalRawData) + { + writer.WritePropertyName(item.Key); +#if NET6_0_OR_GREATER + writer.WriteRawValue(item.Value); +#else + using (JsonDocument document = JsonDocument.Parse(item.Value)) + { + JsonSerializer.Serialize(writer, document.RootElement); + } +#endif + } + } + writer.WriteEndObject(); + } + + ResourceReferenceExtended IJsonModel.Create(ref Utf8JsonReader reader, ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + if (format != "J") + { + throw new FormatException($"The model {nameof(ResourceReferenceExtended)} does not support reading '{format}' format."); + } + + using JsonDocument document = JsonDocument.ParseValue(ref reader); + return DeserializeResourceReferenceExtended(document.RootElement, options); + } + + internal static ResourceReferenceExtended DeserializeResourceReferenceExtended(JsonElement element, ModelReaderWriterOptions options = null) + { + options ??= ModelSerializationExtensions.WireOptions; + + if (element.ValueKind == JsonValueKind.Null) + { + return null; + } + ResponseError error = default; + string id = default; + IDictionary serializedAdditionalRawData = default; + Dictionary rawDataDictionary = new Dictionary(); + foreach (var property in element.EnumerateObject()) + { + if (property.NameEquals("error"u8)) + { + if (property.Value.ValueKind == JsonValueKind.Null) + { + continue; + } + error = JsonSerializer.Deserialize(property.Value.GetRawText()); + continue; + } + if (property.NameEquals("id"u8)) + { + id = property.Value.GetString(); + continue; + } + if (options.Format != "W") + { + rawDataDictionary.Add(property.Name, BinaryData.FromString(property.Value.GetRawText())); + } + } + serializedAdditionalRawData = rawDataDictionary; + return new ResourceReferenceExtended(id, serializedAdditionalRawData, error); + } + + private BinaryData SerializeBicep(ModelReaderWriterOptions options) + { + StringBuilder builder = new StringBuilder(); + BicepModelReaderWriterOptions bicepOptions = options as BicepModelReaderWriterOptions; + IDictionary propertyOverrides = null; + bool hasObjectOverride = bicepOptions != null && bicepOptions.PropertyOverrides.TryGetValue(this, out propertyOverrides); + bool hasPropertyOverride = false; + string propertyOverride = null; + + builder.AppendLine("{"); + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(Error), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" error: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(Error)) + { + builder.Append(" error: "); + BicepSerializationHelpers.AppendChildObject(builder, Error, options, 2, false, " error: "); + } + } + + hasPropertyOverride = hasObjectOverride && propertyOverrides.TryGetValue(nameof(Id), out propertyOverride); + if (hasPropertyOverride) + { + builder.Append(" id: "); + builder.AppendLine(propertyOverride); + } + else + { + if (Optional.IsDefined(Id)) + { + builder.Append(" id: "); + if (Id.Contains(Environment.NewLine)) + { + builder.AppendLine("'''"); + builder.AppendLine($"{Id}'''"); + } + else + { + builder.AppendLine($"'{Id}'"); + } + } + } + + builder.AppendLine("}"); + return BinaryData.FromString(builder.ToString()); + } + + BinaryData IPersistableModel.Write(ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + + switch (format) + { + case "J": + return ModelReaderWriter.Write(this, options); + case "bicep": + return SerializeBicep(options); + default: + throw new FormatException($"The model {nameof(ResourceReferenceExtended)} does not support writing '{options.Format}' format."); + } + } + + ResourceReferenceExtended IPersistableModel.Create(BinaryData data, ModelReaderWriterOptions options) + { + var format = options.Format == "W" ? ((IPersistableModel)this).GetFormatFromOptions(options) : options.Format; + + switch (format) + { + case "J": + { + using JsonDocument document = JsonDocument.Parse(data); + return DeserializeResourceReferenceExtended(document.RootElement, options); + } + default: + throw new FormatException($"The model {nameof(ResourceReferenceExtended)} does not support reading '{options.Format}' format."); + } + } + + string IPersistableModel.GetFormatFromOptions(ModelReaderWriterOptions options) => "J"; + } +} diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/ResourceReferenceExtended.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/ResourceReferenceExtended.cs new file mode 100644 index 0000000000000..f8a45a98a0cd7 --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/ResourceReferenceExtended.cs @@ -0,0 +1,34 @@ +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. + +// + +#nullable disable + +using System; +using System.Collections.Generic; + +namespace Azure.ResourceManager.Resources.Models +{ + /// The resourceId extended model. This is used to document failed resources with a resourceId and a corresponding error. + public partial class ResourceReferenceExtended : ResourceReferenceAutoGenerated + { + /// Initializes a new instance of . + public ResourceReferenceExtended() + { + } + + /// Initializes a new instance of . + /// The resourceId of a resource managed by the deployment stack. + /// Keeps track of any properties unknown to the library. + /// The error detail. + internal ResourceReferenceExtended(string id, IDictionary serializedAdditionalRawData, ResponseError error) : base(id, serializedAdditionalRawData) + { + Error = error; + } + + /// The error detail. + [WirePath("error")] + public ResponseError Error { get; set; } + } +} diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/ResourceStatusMode.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/ResourceStatusMode.cs new file mode 100644 index 0000000000000..42fa3a9618a5c --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/ResourceStatusMode.cs @@ -0,0 +1,54 @@ +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. + +// + +#nullable disable + +using System; +using System.ComponentModel; + +namespace Azure.ResourceManager.Resources.Models +{ + /// Current management state of the resource in the deployment stack. + public readonly partial struct ResourceStatusMode : IEquatable + { + private readonly string _value; + + /// Initializes a new instance of . + /// is null. + public ResourceStatusMode(string value) + { + _value = value ?? throw new ArgumentNullException(nameof(value)); + } + + private const string ManagedValue = "managed"; + private const string RemoveDenyFailedValue = "removeDenyFailed"; + private const string DeleteFailedValue = "deleteFailed"; + + /// This resource is managed by the deployment stack. + public static ResourceStatusMode Managed { get; } = new ResourceStatusMode(ManagedValue); + /// Unable to remove the deny assignment on resource. + public static ResourceStatusMode RemoveDenyFailed { get; } = new ResourceStatusMode(RemoveDenyFailedValue); + /// Unable to delete the resource from Azure. The delete will be retried on the next stack deployment, or can be deleted manually. + public static ResourceStatusMode DeleteFailed { get; } = new ResourceStatusMode(DeleteFailedValue); + /// Determines if two values are the same. + public static bool operator ==(ResourceStatusMode left, ResourceStatusMode right) => left.Equals(right); + /// Determines if two values are not the same. + public static bool operator !=(ResourceStatusMode left, ResourceStatusMode right) => !left.Equals(right); + /// Converts a string to a . + public static implicit operator ResourceStatusMode(string value) => new ResourceStatusMode(value); + + /// + [EditorBrowsable(EditorBrowsableState.Never)] + public override bool Equals(object obj) => obj is ResourceStatusMode other && Equals(other); + /// + public bool Equals(ResourceStatusMode other) => string.Equals(_value, other._value, StringComparison.InvariantCultureIgnoreCase); + + /// + [EditorBrowsable(EditorBrowsableState.Never)] + public override int GetHashCode() => _value != null ? StringComparer.InvariantCultureIgnoreCase.GetHashCode(_value) : 0; + /// + public override string ToString() => _value; + } +} diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/UnmanageActionManagementGroupMode.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/UnmanageActionManagementGroupMode.cs new file mode 100644 index 0000000000000..70208e28cf011 --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/UnmanageActionManagementGroupMode.cs @@ -0,0 +1,51 @@ +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. + +// + +#nullable disable + +using System; +using System.ComponentModel; + +namespace Azure.ResourceManager.Resources.Models +{ + /// The UnmanageActionManagementGroupMode. + public readonly partial struct UnmanageActionManagementGroupMode : IEquatable + { + private readonly string _value; + + /// Initializes a new instance of . + /// is null. + public UnmanageActionManagementGroupMode(string value) + { + _value = value ?? throw new ArgumentNullException(nameof(value)); + } + + private const string DeleteValue = "delete"; + private const string DetachValue = "detach"; + + /// delete. + public static UnmanageActionManagementGroupMode Delete { get; } = new UnmanageActionManagementGroupMode(DeleteValue); + /// detach. + public static UnmanageActionManagementGroupMode Detach { get; } = new UnmanageActionManagementGroupMode(DetachValue); + /// Determines if two values are the same. + public static bool operator ==(UnmanageActionManagementGroupMode left, UnmanageActionManagementGroupMode right) => left.Equals(right); + /// Determines if two values are not the same. + public static bool operator !=(UnmanageActionManagementGroupMode left, UnmanageActionManagementGroupMode right) => !left.Equals(right); + /// Converts a string to a . + public static implicit operator UnmanageActionManagementGroupMode(string value) => new UnmanageActionManagementGroupMode(value); + + /// + [EditorBrowsable(EditorBrowsableState.Never)] + public override bool Equals(object obj) => obj is UnmanageActionManagementGroupMode other && Equals(other); + /// + public bool Equals(UnmanageActionManagementGroupMode other) => string.Equals(_value, other._value, StringComparison.InvariantCultureIgnoreCase); + + /// + [EditorBrowsable(EditorBrowsableState.Never)] + public override int GetHashCode() => _value != null ? StringComparer.InvariantCultureIgnoreCase.GetHashCode(_value) : 0; + /// + public override string ToString() => _value; + } +} diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/UnmanageActionResourceGroupMode.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/UnmanageActionResourceGroupMode.cs new file mode 100644 index 0000000000000..d23a76128b002 --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/UnmanageActionResourceGroupMode.cs @@ -0,0 +1,51 @@ +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. + +// + +#nullable disable + +using System; +using System.ComponentModel; + +namespace Azure.ResourceManager.Resources.Models +{ + /// The UnmanageActionResourceGroupMode. + public readonly partial struct UnmanageActionResourceGroupMode : IEquatable + { + private readonly string _value; + + /// Initializes a new instance of . + /// is null. + public UnmanageActionResourceGroupMode(string value) + { + _value = value ?? throw new ArgumentNullException(nameof(value)); + } + + private const string DeleteValue = "delete"; + private const string DetachValue = "detach"; + + /// delete. + public static UnmanageActionResourceGroupMode Delete { get; } = new UnmanageActionResourceGroupMode(DeleteValue); + /// detach. + public static UnmanageActionResourceGroupMode Detach { get; } = new UnmanageActionResourceGroupMode(DetachValue); + /// Determines if two values are the same. + public static bool operator ==(UnmanageActionResourceGroupMode left, UnmanageActionResourceGroupMode right) => left.Equals(right); + /// Determines if two values are not the same. + public static bool operator !=(UnmanageActionResourceGroupMode left, UnmanageActionResourceGroupMode right) => !left.Equals(right); + /// Converts a string to a . + public static implicit operator UnmanageActionResourceGroupMode(string value) => new UnmanageActionResourceGroupMode(value); + + /// + [EditorBrowsable(EditorBrowsableState.Never)] + public override bool Equals(object obj) => obj is UnmanageActionResourceGroupMode other && Equals(other); + /// + public bool Equals(UnmanageActionResourceGroupMode other) => string.Equals(_value, other._value, StringComparison.InvariantCultureIgnoreCase); + + /// + [EditorBrowsable(EditorBrowsableState.Never)] + public override int GetHashCode() => _value != null ? StringComparer.InvariantCultureIgnoreCase.GetHashCode(_value) : 0; + /// + public override string ToString() => _value; + } +} diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/UnmanageActionResourceMode.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/UnmanageActionResourceMode.cs new file mode 100644 index 0000000000000..5cdceac5f4b6d --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/Models/UnmanageActionResourceMode.cs @@ -0,0 +1,51 @@ +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. + +// + +#nullable disable + +using System; +using System.ComponentModel; + +namespace Azure.ResourceManager.Resources.Models +{ + /// The UnmanageActionResourceMode. + public readonly partial struct UnmanageActionResourceMode : IEquatable + { + private readonly string _value; + + /// Initializes a new instance of . + /// is null. + public UnmanageActionResourceMode(string value) + { + _value = value ?? throw new ArgumentNullException(nameof(value)); + } + + private const string DeleteValue = "delete"; + private const string DetachValue = "detach"; + + /// delete. + public static UnmanageActionResourceMode Delete { get; } = new UnmanageActionResourceMode(DeleteValue); + /// detach. + public static UnmanageActionResourceMode Detach { get; } = new UnmanageActionResourceMode(DetachValue); + /// Determines if two values are the same. + public static bool operator ==(UnmanageActionResourceMode left, UnmanageActionResourceMode right) => left.Equals(right); + /// Determines if two values are not the same. + public static bool operator !=(UnmanageActionResourceMode left, UnmanageActionResourceMode right) => !left.Equals(right); + /// Converts a string to a . + public static implicit operator UnmanageActionResourceMode(string value) => new UnmanageActionResourceMode(value); + + /// + [EditorBrowsable(EditorBrowsableState.Never)] + public override bool Equals(object obj) => obj is UnmanageActionResourceMode other && Equals(other); + /// + public bool Equals(UnmanageActionResourceMode other) => string.Equals(_value, other._value, StringComparison.InvariantCultureIgnoreCase); + + /// + [EditorBrowsable(EditorBrowsableState.Never)] + public override int GetHashCode() => _value != null ? StringComparer.InvariantCultureIgnoreCase.GetHashCode(_value) : 0; + /// + public override string ToString() => _value; + } +} diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/RestOperations/DeploymentRestOperations.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/RestOperations/DeploymentRestOperations.cs index 0aaf5c1cf9595..643b645166559 100644 --- a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/RestOperations/DeploymentRestOperations.cs +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/RestOperations/DeploymentRestOperations.cs @@ -32,7 +32,7 @@ public DeploymentRestOperations(HttpPipeline pipeline, string applicationId, Uri { _pipeline = pipeline ?? throw new ArgumentNullException(nameof(pipeline)); _endpoint = endpoint ?? new Uri("https://management.azure.com"); - _apiVersion = apiVersion ?? "2022-09-01"; + _apiVersion = apiVersion ?? "2024-03-01"; _userAgent = new TelemetryDetails(GetType().Assembly, applicationId); } diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/RestOperations/DeploymentStacksRestOperations.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/RestOperations/DeploymentStacksRestOperations.cs new file mode 100644 index 0000000000000..0169d77f4adea --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/RestOperations/DeploymentStacksRestOperations.cs @@ -0,0 +1,653 @@ +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. + +// + +#nullable disable + +using System; +using System.Text.Json; +using System.Threading; +using System.Threading.Tasks; +using Azure.Core; +using Azure.Core.Pipeline; +using Azure.ResourceManager.Resources.Models; + +namespace Azure.ResourceManager.Resources +{ + internal partial class DeploymentStacksRestOperations + { + private readonly TelemetryDetails _userAgent; + private readonly HttpPipeline _pipeline; + private readonly Uri _endpoint; + private readonly string _apiVersion; + + /// Initializes a new instance of DeploymentStacksRestOperations. + /// The HTTP pipeline for sending and receiving REST requests and responses. + /// The application id to use for user agent. + /// server parameter. + /// Api Version. + /// or is null. + public DeploymentStacksRestOperations(HttpPipeline pipeline, string applicationId, Uri endpoint = null, string apiVersion = default) + { + _pipeline = pipeline ?? throw new ArgumentNullException(nameof(pipeline)); + _endpoint = endpoint ?? new Uri("https://management.azure.com"); + _apiVersion = apiVersion ?? "2024-03-01"; + _userAgent = new TelemetryDetails(GetType().Assembly, applicationId); + } + + internal RequestUriBuilder CreateExportTemplateAtScopeRequestUri(string scope, string deploymentStackName) + { + var uri = new RawRequestUriBuilder(); + uri.Reset(_endpoint); + uri.AppendPath("/", false); + uri.AppendPath(scope, false); + uri.AppendPath("/providers/Microsoft.Resources/deploymentStacks/", false); + uri.AppendPath(deploymentStackName, true); + uri.AppendPath("/exportTemplate", false); + uri.AppendQuery("api-version", _apiVersion, true); + return uri; + } + + internal Core.HttpMessage CreateExportTemplateAtScopeRequest(string scope, string deploymentStackName) + { + var message = _pipeline.CreateMessage(); + var request = message.Request; + request.Method = RequestMethod.Post; + var uri = new RawRequestUriBuilder(); + uri.Reset(_endpoint); + uri.AppendPath("/", false); + uri.AppendPath(scope, false); + uri.AppendPath("/providers/Microsoft.Resources/deploymentStacks/", false); + uri.AppendPath(deploymentStackName, true); + uri.AppendPath("/exportTemplate", false); + uri.AppendQuery("api-version", _apiVersion, true); + request.Uri = uri; + request.Headers.Add("Accept", "application/json"); + _userAgent.Apply(message); + return message; + } + + /// Exports the template used to create the Deployment stack. + /// The resource scope. + /// Name of the deployment stack. + /// The cancellation token to use. + /// or is null. + /// is an empty string, and was expected to be non-empty. + public async Task> ExportTemplateAtScopeAsync(string scope, string deploymentStackName, CancellationToken cancellationToken = default) + { + Argument.AssertNotNull(scope, nameof(scope)); + Argument.AssertNotNullOrEmpty(deploymentStackName, nameof(deploymentStackName)); + + using var message = CreateExportTemplateAtScopeRequest(scope, deploymentStackName); + await _pipeline.SendAsync(message, cancellationToken).ConfigureAwait(false); + switch (message.Response.Status) + { + case 200: + { + DeploymentStackTemplateDefinition value = default; + using var document = await JsonDocument.ParseAsync(message.Response.ContentStream, default, cancellationToken).ConfigureAwait(false); + value = DeploymentStackTemplateDefinition.DeserializeDeploymentStackTemplateDefinition(document.RootElement); + return Response.FromValue(value, message.Response); + } + default: + throw new RequestFailedException(message.Response); + } + } + + /// Exports the template used to create the Deployment stack. + /// The resource scope. + /// Name of the deployment stack. + /// The cancellation token to use. + /// or is null. + /// is an empty string, and was expected to be non-empty. + public Response ExportTemplateAtScope(string scope, string deploymentStackName, CancellationToken cancellationToken = default) + { + Argument.AssertNotNull(scope, nameof(scope)); + Argument.AssertNotNullOrEmpty(deploymentStackName, nameof(deploymentStackName)); + + using var message = CreateExportTemplateAtScopeRequest(scope, deploymentStackName); + _pipeline.Send(message, cancellationToken); + switch (message.Response.Status) + { + case 200: + { + DeploymentStackTemplateDefinition value = default; + using var document = JsonDocument.Parse(message.Response.ContentStream); + value = DeploymentStackTemplateDefinition.DeserializeDeploymentStackTemplateDefinition(document.RootElement); + return Response.FromValue(value, message.Response); + } + default: + throw new RequestFailedException(message.Response); + } + } + + internal RequestUriBuilder CreateValidateStackAtScopeRequestUri(string scope, string deploymentStackName, DeploymentStackData data) + { + var uri = new RawRequestUriBuilder(); + uri.Reset(_endpoint); + uri.AppendPath("/", false); + uri.AppendPath(scope, false); + uri.AppendPath("/providers/Microsoft.Resources/deploymentStacks/", false); + uri.AppendPath(deploymentStackName, true); + uri.AppendPath("/validate", false); + uri.AppendQuery("api-version", _apiVersion, true); + return uri; + } + + internal Core.HttpMessage CreateValidateStackAtScopeRequest(string scope, string deploymentStackName, DeploymentStackData data) + { + var message = _pipeline.CreateMessage(); + var request = message.Request; + request.Method = RequestMethod.Post; + var uri = new RawRequestUriBuilder(); + uri.Reset(_endpoint); + uri.AppendPath("/", false); + uri.AppendPath(scope, false); + uri.AppendPath("/providers/Microsoft.Resources/deploymentStacks/", false); + uri.AppendPath(deploymentStackName, true); + uri.AppendPath("/validate", false); + uri.AppendQuery("api-version", _apiVersion, true); + request.Uri = uri; + request.Headers.Add("Accept", "application/json"); + request.Headers.Add("Content-Type", "application/json"); + var content = new Utf8JsonRequestContent(); + content.JsonWriter.WriteObjectValue(data, ModelSerializationExtensions.WireOptions); + request.Content = content; + _userAgent.Apply(message); + return message; + } + + /// Runs preflight validation on the specific scoped Deployment stack template to verify its acceptance to Azure Resource Manager. + /// The resource scope. + /// Name of the deployment stack. + /// Deployment stack to validate. + /// The cancellation token to use. + /// , or is null. + /// is an empty string, and was expected to be non-empty. + public async Task ValidateStackAtScopeAsync(string scope, string deploymentStackName, DeploymentStackData data, CancellationToken cancellationToken = default) + { + Argument.AssertNotNull(scope, nameof(scope)); + Argument.AssertNotNullOrEmpty(deploymentStackName, nameof(deploymentStackName)); + Argument.AssertNotNull(data, nameof(data)); + + using var message = CreateValidateStackAtScopeRequest(scope, deploymentStackName, data); + await _pipeline.SendAsync(message, cancellationToken).ConfigureAwait(false); + switch (message.Response.Status) + { + case 200: + case 202: + case 400: + return message.Response; + default: + throw new RequestFailedException(message.Response); + } + } + + /// Runs preflight validation on the specific scoped Deployment stack template to verify its acceptance to Azure Resource Manager. + /// The resource scope. + /// Name of the deployment stack. + /// Deployment stack to validate. + /// The cancellation token to use. + /// , or is null. + /// is an empty string, and was expected to be non-empty. + public Response ValidateStackAtScope(string scope, string deploymentStackName, DeploymentStackData data, CancellationToken cancellationToken = default) + { + Argument.AssertNotNull(scope, nameof(scope)); + Argument.AssertNotNullOrEmpty(deploymentStackName, nameof(deploymentStackName)); + Argument.AssertNotNull(data, nameof(data)); + + using var message = CreateValidateStackAtScopeRequest(scope, deploymentStackName, data); + _pipeline.Send(message, cancellationToken); + switch (message.Response.Status) + { + case 200: + case 202: + case 400: + return message.Response; + default: + throw new RequestFailedException(message.Response); + } + } + + internal RequestUriBuilder CreateListAtScopeRequestUri(string scope) + { + var uri = new RawRequestUriBuilder(); + uri.Reset(_endpoint); + uri.AppendPath("/", false); + uri.AppendPath(scope, false); + uri.AppendPath("/providers/Microsoft.Resources/deploymentStacks", false); + uri.AppendQuery("api-version", _apiVersion, true); + return uri; + } + + internal Core.HttpMessage CreateListAtScopeRequest(string scope) + { + var message = _pipeline.CreateMessage(); + var request = message.Request; + request.Method = RequestMethod.Get; + var uri = new RawRequestUriBuilder(); + uri.Reset(_endpoint); + uri.AppendPath("/", false); + uri.AppendPath(scope, false); + uri.AppendPath("/providers/Microsoft.Resources/deploymentStacks", false); + uri.AppendQuery("api-version", _apiVersion, true); + request.Uri = uri; + request.Headers.Add("Accept", "application/json"); + _userAgent.Apply(message); + return message; + } + + /// Lists all the Deployment stacks within the specified scope. + /// The resource scope. + /// The cancellation token to use. + /// is null. + public async Task> ListAtScopeAsync(string scope, CancellationToken cancellationToken = default) + { + Argument.AssertNotNull(scope, nameof(scope)); + + using var message = CreateListAtScopeRequest(scope); + await _pipeline.SendAsync(message, cancellationToken).ConfigureAwait(false); + switch (message.Response.Status) + { + case 200: + { + DeploymentStackListResult value = default; + using var document = await JsonDocument.ParseAsync(message.Response.ContentStream, default, cancellationToken).ConfigureAwait(false); + value = DeploymentStackListResult.DeserializeDeploymentStackListResult(document.RootElement); + return Response.FromValue(value, message.Response); + } + default: + throw new RequestFailedException(message.Response); + } + } + + /// Lists all the Deployment stacks within the specified scope. + /// The resource scope. + /// The cancellation token to use. + /// is null. + public Response ListAtScope(string scope, CancellationToken cancellationToken = default) + { + Argument.AssertNotNull(scope, nameof(scope)); + + using var message = CreateListAtScopeRequest(scope); + _pipeline.Send(message, cancellationToken); + switch (message.Response.Status) + { + case 200: + { + DeploymentStackListResult value = default; + using var document = JsonDocument.Parse(message.Response.ContentStream); + value = DeploymentStackListResult.DeserializeDeploymentStackListResult(document.RootElement); + return Response.FromValue(value, message.Response); + } + default: + throw new RequestFailedException(message.Response); + } + } + + internal RequestUriBuilder CreateCreateOrUpdateAtScopeRequestUri(string scope, string deploymentStackName, DeploymentStackData data) + { + var uri = new RawRequestUriBuilder(); + uri.Reset(_endpoint); + uri.AppendPath("/", false); + uri.AppendPath(scope, false); + uri.AppendPath("/providers/Microsoft.Resources/deploymentStacks/", false); + uri.AppendPath(deploymentStackName, true); + uri.AppendQuery("api-version", _apiVersion, true); + return uri; + } + + internal Core.HttpMessage CreateCreateOrUpdateAtScopeRequest(string scope, string deploymentStackName, DeploymentStackData data) + { + var message = _pipeline.CreateMessage(); + var request = message.Request; + request.Method = RequestMethod.Put; + var uri = new RawRequestUriBuilder(); + uri.Reset(_endpoint); + uri.AppendPath("/", false); + uri.AppendPath(scope, false); + uri.AppendPath("/providers/Microsoft.Resources/deploymentStacks/", false); + uri.AppendPath(deploymentStackName, true); + uri.AppendQuery("api-version", _apiVersion, true); + request.Uri = uri; + request.Headers.Add("Accept", "application/json"); + request.Headers.Add("Content-Type", "application/json"); + var content = new Utf8JsonRequestContent(); + content.JsonWriter.WriteObjectValue(data, ModelSerializationExtensions.WireOptions); + request.Content = content; + _userAgent.Apply(message); + return message; + } + + /// Creates or updates a Deployment stack at specific scope. + /// The resource scope. + /// Name of the deployment stack. + /// Deployment stack supplied to the operation. + /// The cancellation token to use. + /// , or is null. + /// is an empty string, and was expected to be non-empty. + public async Task CreateOrUpdateAtScopeAsync(string scope, string deploymentStackName, DeploymentStackData data, CancellationToken cancellationToken = default) + { + Argument.AssertNotNull(scope, nameof(scope)); + Argument.AssertNotNullOrEmpty(deploymentStackName, nameof(deploymentStackName)); + Argument.AssertNotNull(data, nameof(data)); + + using var message = CreateCreateOrUpdateAtScopeRequest(scope, deploymentStackName, data); + await _pipeline.SendAsync(message, cancellationToken).ConfigureAwait(false); + switch (message.Response.Status) + { + case 200: + case 201: + return message.Response; + default: + throw new RequestFailedException(message.Response); + } + } + + /// Creates or updates a Deployment stack at specific scope. + /// The resource scope. + /// Name of the deployment stack. + /// Deployment stack supplied to the operation. + /// The cancellation token to use. + /// , or is null. + /// is an empty string, and was expected to be non-empty. + public Response CreateOrUpdateAtScope(string scope, string deploymentStackName, DeploymentStackData data, CancellationToken cancellationToken = default) + { + Argument.AssertNotNull(scope, nameof(scope)); + Argument.AssertNotNullOrEmpty(deploymentStackName, nameof(deploymentStackName)); + Argument.AssertNotNull(data, nameof(data)); + + using var message = CreateCreateOrUpdateAtScopeRequest(scope, deploymentStackName, data); + _pipeline.Send(message, cancellationToken); + switch (message.Response.Status) + { + case 200: + case 201: + return message.Response; + default: + throw new RequestFailedException(message.Response); + } + } + + internal RequestUriBuilder CreateGetAtScopeRequestUri(string scope, string deploymentStackName) + { + var uri = new RawRequestUriBuilder(); + uri.Reset(_endpoint); + uri.AppendPath("/", false); + uri.AppendPath(scope, false); + uri.AppendPath("/providers/Microsoft.Resources/deploymentStacks/", false); + uri.AppendPath(deploymentStackName, true); + uri.AppendQuery("api-version", _apiVersion, true); + return uri; + } + + internal Core.HttpMessage CreateGetAtScopeRequest(string scope, string deploymentStackName) + { + var message = _pipeline.CreateMessage(); + var request = message.Request; + request.Method = RequestMethod.Get; + var uri = new RawRequestUriBuilder(); + uri.Reset(_endpoint); + uri.AppendPath("/", false); + uri.AppendPath(scope, false); + uri.AppendPath("/providers/Microsoft.Resources/deploymentStacks/", false); + uri.AppendPath(deploymentStackName, true); + uri.AppendQuery("api-version", _apiVersion, true); + request.Uri = uri; + request.Headers.Add("Accept", "application/json"); + _userAgent.Apply(message); + return message; + } + + /// Gets a Deployment stack with a given name at specific scope. + /// The resource scope. + /// Name of the deployment stack. + /// The cancellation token to use. + /// or is null. + /// is an empty string, and was expected to be non-empty. + public async Task> GetAtScopeAsync(string scope, string deploymentStackName, CancellationToken cancellationToken = default) + { + Argument.AssertNotNull(scope, nameof(scope)); + Argument.AssertNotNullOrEmpty(deploymentStackName, nameof(deploymentStackName)); + + using var message = CreateGetAtScopeRequest(scope, deploymentStackName); + await _pipeline.SendAsync(message, cancellationToken).ConfigureAwait(false); + switch (message.Response.Status) + { + case 200: + { + DeploymentStackData value = default; + using var document = await JsonDocument.ParseAsync(message.Response.ContentStream, default, cancellationToken).ConfigureAwait(false); + value = DeploymentStackData.DeserializeDeploymentStackData(document.RootElement); + return Response.FromValue(value, message.Response); + } + case 404: + return Response.FromValue((DeploymentStackData)null, message.Response); + default: + throw new RequestFailedException(message.Response); + } + } + + /// Gets a Deployment stack with a given name at specific scope. + /// The resource scope. + /// Name of the deployment stack. + /// The cancellation token to use. + /// or is null. + /// is an empty string, and was expected to be non-empty. + public Response GetAtScope(string scope, string deploymentStackName, CancellationToken cancellationToken = default) + { + Argument.AssertNotNull(scope, nameof(scope)); + Argument.AssertNotNullOrEmpty(deploymentStackName, nameof(deploymentStackName)); + + using var message = CreateGetAtScopeRequest(scope, deploymentStackName); + _pipeline.Send(message, cancellationToken); + switch (message.Response.Status) + { + case 200: + { + DeploymentStackData value = default; + using var document = JsonDocument.Parse(message.Response.ContentStream); + value = DeploymentStackData.DeserializeDeploymentStackData(document.RootElement); + return Response.FromValue(value, message.Response); + } + case 404: + return Response.FromValue((DeploymentStackData)null, message.Response); + default: + throw new RequestFailedException(message.Response); + } + } + + internal RequestUriBuilder CreateDeleteAtScopeRequestUri(string scope, string deploymentStackName, UnmanageActionResourceMode? unmanageActionResources, UnmanageActionResourceGroupMode? unmanageActionResourceGroups, UnmanageActionManagementGroupMode? unmanageActionManagementGroups, bool? bypassStackOutOfSyncError) + { + var uri = new RawRequestUriBuilder(); + uri.Reset(_endpoint); + uri.AppendPath("/", false); + uri.AppendPath(scope, false); + uri.AppendPath("/providers/Microsoft.Resources/deploymentStacks/", false); + uri.AppendPath(deploymentStackName, true); + if (unmanageActionResources != null) + { + uri.AppendQuery("unmanageAction.Resources", unmanageActionResources.Value.ToString(), true); + } + if (unmanageActionResourceGroups != null) + { + uri.AppendQuery("unmanageAction.ResourceGroups", unmanageActionResourceGroups.Value.ToString(), true); + } + if (unmanageActionManagementGroups != null) + { + uri.AppendQuery("unmanageAction.ManagementGroups", unmanageActionManagementGroups.Value.ToString(), true); + } + if (bypassStackOutOfSyncError != null) + { + uri.AppendQuery("bypassStackOutOfSyncError", bypassStackOutOfSyncError.Value, true); + } + uri.AppendQuery("api-version", _apiVersion, true); + return uri; + } + + internal Core.HttpMessage CreateDeleteAtScopeRequest(string scope, string deploymentStackName, UnmanageActionResourceMode? unmanageActionResources, UnmanageActionResourceGroupMode? unmanageActionResourceGroups, UnmanageActionManagementGroupMode? unmanageActionManagementGroups, bool? bypassStackOutOfSyncError) + { + var message = _pipeline.CreateMessage(); + var request = message.Request; + request.Method = RequestMethod.Delete; + var uri = new RawRequestUriBuilder(); + uri.Reset(_endpoint); + uri.AppendPath("/", false); + uri.AppendPath(scope, false); + uri.AppendPath("/providers/Microsoft.Resources/deploymentStacks/", false); + uri.AppendPath(deploymentStackName, true); + if (unmanageActionResources != null) + { + uri.AppendQuery("unmanageAction.Resources", unmanageActionResources.Value.ToString(), true); + } + if (unmanageActionResourceGroups != null) + { + uri.AppendQuery("unmanageAction.ResourceGroups", unmanageActionResourceGroups.Value.ToString(), true); + } + if (unmanageActionManagementGroups != null) + { + uri.AppendQuery("unmanageAction.ManagementGroups", unmanageActionManagementGroups.Value.ToString(), true); + } + if (bypassStackOutOfSyncError != null) + { + uri.AppendQuery("bypassStackOutOfSyncError", bypassStackOutOfSyncError.Value, true); + } + uri.AppendQuery("api-version", _apiVersion, true); + request.Uri = uri; + request.Headers.Add("Accept", "application/json"); + _userAgent.Apply(message); + return message; + } + + /// Deletes a Deployment stack by name at specific scope. When operation completes, status code 200 returned without content. + /// The resource scope. + /// Name of the deployment stack. + /// Flag to indicate delete rather than detach for unmanaged resources. + /// Flag to indicate delete rather than detach for unmanaged resource groups. + /// Flag to indicate delete rather than detach for unmanaged management groups. + /// Flag to bypass service errors that indicate the stack resource list is not correctly synchronized. + /// The cancellation token to use. + /// or is null. + /// is an empty string, and was expected to be non-empty. + public async Task DeleteAtScopeAsync(string scope, string deploymentStackName, UnmanageActionResourceMode? unmanageActionResources = null, UnmanageActionResourceGroupMode? unmanageActionResourceGroups = null, UnmanageActionManagementGroupMode? unmanageActionManagementGroups = null, bool? bypassStackOutOfSyncError = null, CancellationToken cancellationToken = default) + { + Argument.AssertNotNull(scope, nameof(scope)); + Argument.AssertNotNullOrEmpty(deploymentStackName, nameof(deploymentStackName)); + + using var message = CreateDeleteAtScopeRequest(scope, deploymentStackName, unmanageActionResources, unmanageActionResourceGroups, unmanageActionManagementGroups, bypassStackOutOfSyncError); + await _pipeline.SendAsync(message, cancellationToken).ConfigureAwait(false); + switch (message.Response.Status) + { + case 200: + case 202: + case 204: + return message.Response; + default: + throw new RequestFailedException(message.Response); + } + } + + /// Deletes a Deployment stack by name at specific scope. When operation completes, status code 200 returned without content. + /// The resource scope. + /// Name of the deployment stack. + /// Flag to indicate delete rather than detach for unmanaged resources. + /// Flag to indicate delete rather than detach for unmanaged resource groups. + /// Flag to indicate delete rather than detach for unmanaged management groups. + /// Flag to bypass service errors that indicate the stack resource list is not correctly synchronized. + /// The cancellation token to use. + /// or is null. + /// is an empty string, and was expected to be non-empty. + public Response DeleteAtScope(string scope, string deploymentStackName, UnmanageActionResourceMode? unmanageActionResources = null, UnmanageActionResourceGroupMode? unmanageActionResourceGroups = null, UnmanageActionManagementGroupMode? unmanageActionManagementGroups = null, bool? bypassStackOutOfSyncError = null, CancellationToken cancellationToken = default) + { + Argument.AssertNotNull(scope, nameof(scope)); + Argument.AssertNotNullOrEmpty(deploymentStackName, nameof(deploymentStackName)); + + using var message = CreateDeleteAtScopeRequest(scope, deploymentStackName, unmanageActionResources, unmanageActionResourceGroups, unmanageActionManagementGroups, bypassStackOutOfSyncError); + _pipeline.Send(message, cancellationToken); + switch (message.Response.Status) + { + case 200: + case 202: + case 204: + return message.Response; + default: + throw new RequestFailedException(message.Response); + } + } + + internal RequestUriBuilder CreateListAtScopeNextPageRequestUri(string nextLink, string scope) + { + var uri = new RawRequestUriBuilder(); + uri.Reset(_endpoint); + uri.AppendRawNextLink(nextLink, false); + return uri; + } + + internal Core.HttpMessage CreateListAtScopeNextPageRequest(string nextLink, string scope) + { + var message = _pipeline.CreateMessage(); + var request = message.Request; + request.Method = RequestMethod.Get; + var uri = new RawRequestUriBuilder(); + uri.Reset(_endpoint); + uri.AppendRawNextLink(nextLink, false); + request.Uri = uri; + request.Headers.Add("Accept", "application/json"); + _userAgent.Apply(message); + return message; + } + + /// Lists all the Deployment stacks within the specified scope. + /// The URL to the next page of results. + /// The resource scope. + /// The cancellation token to use. + /// or is null. + public async Task> ListAtScopeNextPageAsync(string nextLink, string scope, CancellationToken cancellationToken = default) + { + Argument.AssertNotNull(nextLink, nameof(nextLink)); + Argument.AssertNotNull(scope, nameof(scope)); + + using var message = CreateListAtScopeNextPageRequest(nextLink, scope); + await _pipeline.SendAsync(message, cancellationToken).ConfigureAwait(false); + switch (message.Response.Status) + { + case 200: + { + DeploymentStackListResult value = default; + using var document = await JsonDocument.ParseAsync(message.Response.ContentStream, default, cancellationToken).ConfigureAwait(false); + value = DeploymentStackListResult.DeserializeDeploymentStackListResult(document.RootElement); + return Response.FromValue(value, message.Response); + } + default: + throw new RequestFailedException(message.Response); + } + } + + /// Lists all the Deployment stacks within the specified scope. + /// The URL to the next page of results. + /// The resource scope. + /// The cancellation token to use. + /// or is null. + public Response ListAtScopeNextPage(string nextLink, string scope, CancellationToken cancellationToken = default) + { + Argument.AssertNotNull(nextLink, nameof(nextLink)); + Argument.AssertNotNull(scope, nameof(scope)); + + using var message = CreateListAtScopeNextPageRequest(nextLink, scope); + _pipeline.Send(message, cancellationToken); + switch (message.Response.Status) + { + case 200: + { + DeploymentStackListResult value = default; + using var document = JsonDocument.Parse(message.Response.ContentStream); + value = DeploymentStackListResult.DeserializeDeploymentStackListResult(document.RootElement); + return Response.FromValue(value, message.Response); + } + default: + throw new RequestFailedException(message.Response); + } + } + } +} diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/RestOperations/DeploymentsRestOperations.cs b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/RestOperations/DeploymentsRestOperations.cs index d649c1f67d00b..64052ef2763d9 100644 --- a/sdk/resources/Azure.ResourceManager.Resources/src/Generated/RestOperations/DeploymentsRestOperations.cs +++ b/sdk/resources/Azure.ResourceManager.Resources/src/Generated/RestOperations/DeploymentsRestOperations.cs @@ -32,7 +32,7 @@ public DeploymentsRestOperations(HttpPipeline pipeline, string applicationId, Ur { _pipeline = pipeline ?? throw new ArgumentNullException(nameof(pipeline)); _endpoint = endpoint ?? new Uri("https://management.azure.com"); - _apiVersion = apiVersion ?? "2022-09-01"; + _apiVersion = apiVersion ?? "2024-03-01"; _userAgent = new TelemetryDetails(GetType().Assembly, applicationId); } diff --git a/sdk/resources/Azure.ResourceManager.Resources/src/autorest.md b/sdk/resources/Azure.ResourceManager.Resources/src/autorest.md index e4ddef1eeb946..5d5f89ab4ff61 100644 --- a/sdk/resources/Azure.ResourceManager.Resources/src/autorest.md +++ b/sdk/resources/Azure.ResourceManager.Resources/src/autorest.md @@ -51,6 +51,18 @@ request-path-to-scope-resource-types: - resourceGroups - managementGroups - tenant + /{scope}/providers/Microsoft.Resources/deploymentStacks: + - subscriptions + - resourceGroups + - managementGroups + /{scope}/providers/Microsoft.Resources/deploymentStacks/{deploymentStackName}: + - subscriptions + - resourceGroups + - managementGroups + /{scope}/providers/Microsoft.Resources/deploymentStacks/{deploymentStackName}/exportTemplate: + - subscriptions + - resourceGroups + - managementGroups override-operation-name: DeploymentOperations_ListAtScope: GetDeploymentOperations DeploymentOperations_GetAtScope: GetDeploymentOperation @@ -64,6 +76,8 @@ override-operation-name: Deployments_CheckExistenceAtScope: CheckExistence jitRequests_ListBySubscription: GetJitRequestDefinitions Deployments_CalculateTemplateHash: CalculateDeploymentTemplateHash + DeploymentStacks_ExportTemplateAtScope: ExportTemplate + DeploymentStacks_ValidateStackAtScope: ValidateStack operation-groups-to-omit: Providers;ProviderResourceTypes;Resources;ResourceGroups;Tags;Subscriptions;Tenants @@ -155,6 +169,24 @@ directive: - remove-operation: Applications_DeleteById - remove-operation: Applications_CreateOrUpdateById - remove-operation: Applications_UpdateById + - remove-operation: DeploymentStacks_ExportTemplateAtSubscription + - remove-operation: DeploymentStacks_ExportTemplateAtResourceGroup + - remove-operation: DeploymentStacks_ExportTemplateAtManagementGroup + - remove-operation: DeploymentStacks_ValidateStackAtResourceGroup + - remove-operation: DeploymentStacks_ValidateStackAtSubscription + - remove-operation: DeploymentStacks_ValidateStackAtManagementGroup + - remove-operation: DeploymentStacks_ListAtResourceGroup + - remove-operation: DeploymentStacks_ListAtSubscription + - remove-operation: DeploymentStacks_ListAtManagementGroup + - remove-operation: DeploymentStacks_CreateOrUpdateAtResourceGroup + - remove-operation: DeploymentStacks_GetAtResourceGroup + - remove-operation: DeploymentStacks_DeleteAtResourceGroup + - remove-operation: DeploymentStacks_CreateOrUpdateAtSubscription + - remove-operation: DeploymentStacks_GetAtSubscription + - remove-operation: DeploymentStacks_DeleteAtSubscription + - remove-operation: DeploymentStacks_CreateOrUpdateAtManagementGroup + - remove-operation: DeploymentStacks_GetAtManagementGroup + - remove-operation: DeploymentStacks_DeleteAtManagementGroup - from: managedapplications.json where: $['x-ms-paths'] @@ -344,6 +376,291 @@ directive: where: $.definitions.DeploymentProperties transform: delete $.properties.parameters.additionalProperties + # Specify the duration format + - from: deploymentStacks.json + where: $.definitions + transform: > + $.DeploymentStackProperties.properties.duration['format'] = 'duration'; + # Add scope operations + - from: deploymentStacks.json + where: $.paths + transform: > + $['/{scope}/providers/Microsoft.Resources/deploymentStacks/{deploymentStackName}/exportTemplate'] = { + "post": { + "tags": [ + "DeploymentStacks" + ], + "operationId": "DeploymentStacks_ExportTemplateAtScope", + "description": "Exports the template used to create the Deployment stack.", + "parameters": [ + { + "$ref": "./resources.json#/parameters/ScopeParameter" + }, + { + "$ref": "#/parameters/DeploymentStackNameParameter" + }, + { + "$ref": "../../../../../common-types/resource-management/v5/types.json#/parameters/ApiVersionParameter" + } + ], + "responses": { + "200": { + "description": "OK - Returns the Template or TemplateLink payload of the deployment stack.", + "schema": { + "$ref": "#/definitions/DeploymentStackTemplateDefinition" + } + }, + "default": { + "description": "Error response describing why the operation failed.", + "schema": { + "$ref": "#/definitions/DeploymentStacksError" + } + } + } + } + }; + $['/{scope}/providers/Microsoft.Resources/deploymentStacks/{deploymentStackName}/validate'] = { + "post": { + "tags": [ + "DeploymentStacks" + ], + "operationId": "DeploymentStacks_ValidateStackAtScope", + "description": "Runs preflight validation on the specific scoped Deployment stack template to verify its acceptance to Azure Resource Manager.", + "x-ms-long-running-operation": true, + "x-ms-long-running-operation-options": { + "final-state-via": "location" + }, + "parameters": [ + { + "$ref": "./resources.json#/parameters/ScopeParameter" + }, + { + "$ref": "#/parameters/DeploymentStackNameParameter" + }, + { + "$ref": "../../../../../common-types/resource-management/v5/types.json#/parameters/ApiVersionParameter" + }, + { + "name": "deploymentStack", + "in": "body", + "required": true, + "schema": { + "$ref": "#/definitions/DeploymentStack" + }, + "description": "Deployment stack to validate." + } + ], + "responses": { + "200": { + "description": "OK - The validation operation result.", + "schema": { + "$ref": "#/definitions/DeploymentStackValidateResult" + } + }, + "202": { + "description": "Accepted - The validation request has been accepted for processing and the operation will complete asynchronously.", + "headers": { + "Location": { + "type": "string" + }, + "Retry-After": { + "type": "string", + "description": "Number of seconds to wait before polling for status." + } + } + }, + "400": { + "description": "Failed - The validation operation result.", + "x-ms-error-response": false, + "schema": { + "$ref": "#/definitions/DeploymentStackValidateResult" + } + }, + "default": { + "description": "Error response describing why the operation failed.", + "schema": { + "$ref": "#/definitions/DeploymentStacksError" + } + } + } + } + }; + $['/{scope}/providers/Microsoft.Resources/deploymentStacks'] = { + "get": { + "tags": [ + "DeploymentStacks" + ], + "operationId": "DeploymentStacks_ListAtScope", + "description": "Lists all the Deployment stacks within the specified scope.", + "parameters": [ + { + "$ref": "./resources.json#/parameters/ScopeParameter" + }, + { + "$ref": "../../../../../common-types/resource-management/v5/types.json#/parameters/ApiVersionParameter" + } + ], + "responses": { + "200": { + "description": "OK - Returns an array of Deployment stacks.", + "schema": { + "$ref": "#/definitions/DeploymentStackListResult" + } + }, + "default": { + "description": "Error response describing why the operation failed.", + "schema": { + "$ref": "#/definitions/DeploymentStacksError" + } + } + }, + "x-ms-pageable": { + "nextLinkName": "nextLink" + } + } + }; + $['/{scope}/providers/Microsoft.Resources/deploymentStacks/{deploymentStackName}'] = { + "put": { + "tags": [ + "DeploymentStacks" + ], + "operationId": "DeploymentStacks_CreateOrUpdateAtScope", + "x-ms-long-running-operation": true, + "x-ms-long-running-operation-options": { + "final-state-via": "azure-async-operation" + }, + "description": "Creates or updates a Deployment stack at specific scope.", + "parameters": [ + { + "$ref": "./resources.json#/parameters/ScopeParameter" + }, + { + "$ref": "#/parameters/DeploymentStackNameParameter" + }, + { + "$ref": "../../../../../common-types/resource-management/v5/types.json#/parameters/ApiVersionParameter" + }, + { + "name": "deploymentStack", + "in": "body", + "required": true, + "schema": { + "$ref": "#/definitions/DeploymentStack" + }, + "description": "Deployment stack supplied to the operation." + } + ], + "responses": { + "200": { + "description": "OK - The Deployment stack update request has succeeded.", + "schema": { + "$ref": "#/definitions/DeploymentStack" + } + }, + "201": { + "description": "Deployment stack created.", + "schema": { + "$ref": "#/definitions/DeploymentStack" + } + }, + "default": { + "description": "Error response describing why the operation failed.", + "schema": { + "$ref": "#/definitions/DeploymentStacksError" + } + } + } + }, + "get": { + "tags": [ + "DeploymentStacks" + ], + "operationId": "DeploymentStacks_GetAtScope", + "description": "Gets a Deployment stack with a given name at specific scope.", + "parameters": [ + { + "$ref": "./resources.json#/parameters/ScopeParameter" + }, + { + "$ref": "#/parameters/DeploymentStackNameParameter" + }, + { + "$ref": "../../../../../common-types/resource-management/v5/types.json#/parameters/ApiVersionParameter" + } + ], + "responses": { + "200": { + "description": "OK - Returns information about the Deployment stack.", + "schema": { + "$ref": "#/definitions/DeploymentStack" + } + }, + "default": { + "description": "Error response describing why the operation failed.", + "schema": { + "$ref": "#/definitions/DeploymentStacksError" + } + } + } + }, + "delete": { + "tags": [ + "DeploymentStacks" + ], + "operationId": "DeploymentStacks_DeleteAtScope", + "description": "Deletes a Deployment stack by name at specific scope. When operation completes, status code 200 returned without content.", + "x-ms-long-running-operation": true, + "x-ms-long-running-operation-options": { + "final-state-via": "location" + }, + "parameters": [ + { + "$ref": "./resources.json#/parameters/ScopeParameter" + }, + { + "$ref": "#/parameters/DeploymentStackNameParameter" + }, + { + "$ref": "#/parameters/DeleteResourceParameter" + }, + { + "$ref": "#/parameters/DeleteResourceGroupParameter" + }, + { + "$ref": "#/parameters/DeleteManagementGroupParameter" + }, + { + "$ref": "#/parameters/BypassStackOutOfSyncErrorParameter" + }, + { + "$ref": "../../../../../common-types/resource-management/v5/types.json#/parameters/ApiVersionParameter" + } + ], + "responses": { + "200": { + "description": "OK - Deployment stack deleted." + }, + "202": { + "description": "Accepted - Check location header for deletion status.", + "headers": { + "Location": { + "type": "string" + } + } + }, + "204": { + "description": "Deployment stack does not exist." + }, + "default": { + "description": "Error response describing why the operation failed.", + "schema": { + "$ref": "#/definitions/DeploymentStacksError" + } + } + } + } + }; + ``` ### Tag: package-resources-2022-04 @@ -353,10 +670,11 @@ These settings apply only when `--tag=package-resources-2022-04` is specified on ```yaml $(tag) == 'package-resources-2022-04' input-file: - - https://github.com/Azure/azure-rest-api-specs/blob/6acab48bdaef738f88de60abc41826e9914ad8ad/specification/resources/resource-manager/Microsoft.Resources/stable/2021-05-01/templateSpecs.json - - https://github.com/Azure/azure-rest-api-specs/blob/6acab48bdaef738f88de60abc41826e9914ad8ad/specification/resources/resource-manager/Microsoft.Resources/stable/2020-10-01/deploymentScripts.json - - https://github.com/Azure/azure-rest-api-specs/blob/6acab48bdaef738f88de60abc41826e9914ad8ad/specification/resources/resource-manager/Microsoft.Resources/stable/2022-09-01/resources.json - - https://github.com/Azure/azure-rest-api-specs/blob/6acab48bdaef738f88de60abc41826e9914ad8ad/specification/resources/resource-manager/Microsoft.Solutions/stable/2019-07-01/managedapplications.json - - https://github.com/Azure/azure-rest-api-specs/blob/6acab48bdaef738f88de60abc41826e9914ad8ad/specification/resources/resource-manager/Microsoft.Resources/stable/2023-11-01/bicepClient.json# + - https://github.com/Azure/azure-rest-api-specs/blob/a220053360f9700f81abcdb6142769c85c3bcb27/specification/resources/resource-manager/Microsoft.Resources/stable/2021-05-01/templateSpecs.json + - https://github.com/Azure/azure-rest-api-specs/blob/a220053360f9700f81abcdb6142769c85c3bcb27/specification/resources/resource-manager/Microsoft.Resources/stable/2020-10-01/deploymentScripts.json + - https://github.com/Azure/azure-rest-api-specs/blob/a220053360f9700f81abcdb6142769c85c3bcb27/specification/resources/resource-manager/Microsoft.Resources/stable/2024-03-01/resources.json + - https://github.com/Azure/azure-rest-api-specs/blob/a220053360f9700f81abcdb6142769c85c3bcb27/specification/resources/resource-manager/Microsoft.Solutions/stable/2019-07-01/managedapplications.json + - https://github.com/Azure/azure-rest-api-specs/blob/a220053360f9700f81abcdb6142769c85c3bcb27/specification/resources/resource-manager/Microsoft.Resources/stable/2023-11-01/bicepClient.json# + - https://github.com/Azure/azure-rest-api-specs/blob/a220053360f9700f81abcdb6142769c85c3bcb27/specification/resources/resource-manager/Microsoft.Resources/stable/2024-03-01/deploymentStacks.json ``` diff --git a/sdk/resources/Azure.ResourceManager.Resources/tests/ResourcesTestBase.cs b/sdk/resources/Azure.ResourceManager.Resources/tests/ResourcesTestBase.cs index c2223f1038058..1b5e771f9bea6 100644 --- a/sdk/resources/Azure.ResourceManager.Resources/tests/ResourcesTestBase.cs +++ b/sdk/resources/Azure.ResourceManager.Resources/tests/ResourcesTestBase.cs @@ -13,7 +13,6 @@ using Azure.ResourceManager.Resources.Models; using NUnit.Framework; using JsonObject = System.Collections.Generic.Dictionary; -using System.Security.Policy; namespace Azure.ResourceManager.Resources.Tests { @@ -137,6 +136,87 @@ protected static ArmDeploymentProperties CreateDeploymentPropertiesUsingJsonElem Location = location }; + protected static DeploymentStackData CreateRGDeploymentStackDataWithTemplate() + { + var data = new DeploymentStackData(); + + data.Template = BinaryData.FromString(File.ReadAllText(Path.Combine( + Path.GetDirectoryName(Assembly.GetExecutingAssembly().Location), + "Scenario", + "DeploymentTemplates", + $"rg-stack-template.json"))); + + data.DenySettings = new DenySettings(DenySettingsMode.None); + + data.ActionOnUnmanage = new ActionOnUnmanage() + { + Resources = DeploymentStacksDeleteDetachEnum.Detach, + ResourceGroups = DeploymentStacksDeleteDetachEnum.Detach, + ManagementGroups = DeploymentStacksDeleteDetachEnum.Detach + }; + + data.BypassStackOutOfSyncError = false; + + data.Parameters.Add("templateSpecName", new DeploymentParameter { Value = BinaryData.FromString("\"stacksTestTemplate4321\"") }); + + return data; + } + + protected static DeploymentStackData CreateSubDeploymentStackDataWithTemplate(AzureLocation location) { + var data = new DeploymentStackData(); + + data.Location = location; + + data.Template = BinaryData.FromString(File.ReadAllText(Path.Combine( + Path.GetDirectoryName(Assembly.GetExecutingAssembly().Location), + "Scenario", + "DeploymentTemplates", + $"sub-stack-template.json"))); + + data.DenySettings = new DenySettings(DenySettingsMode.None); + + data.ActionOnUnmanage = new ActionOnUnmanage() + { + Resources = DeploymentStacksDeleteDetachEnum.Detach, + ResourceGroups = DeploymentStacksDeleteDetachEnum.Detach, + ManagementGroups = DeploymentStacksDeleteDetachEnum.Detach + }; + + data.BypassStackOutOfSyncError = false; + + data.Parameters.Add("rgName", new DeploymentParameter { Value = BinaryData.FromString("\"stacksTestRG4321\"") } ); + + return data; + } + + protected static DeploymentStackData CreateMGDeploymentStackDataWithTemplate(AzureLocation location) + { + var data = new DeploymentStackData(); + + data.Location = location; + + data.Template = BinaryData.FromString(File.ReadAllText(Path.Combine( + Path.GetDirectoryName(Assembly.GetExecutingAssembly().Location), + "Scenario", + "DeploymentTemplates", + $"mg-stack-template.json"))); + + data.DenySettings = new DenySettings(DenySettingsMode.None); + + data.ActionOnUnmanage = new ActionOnUnmanage() + { + Resources = DeploymentStacksDeleteDetachEnum.Detach, + ResourceGroups = DeploymentStacksDeleteDetachEnum.Detach, + ManagementGroups = DeploymentStacksDeleteDetachEnum.Detach + }; + + data.BypassStackOutOfSyncError = false; + + data.Parameters.Add("message", new DeploymentParameter { Value = BinaryData.FromString("\"hello world\"") }); + + return data; + } + private static GenericResourceData ConstructGenericUserAssignedIdentities() { var userAssignedIdentities = new GenericResourceData(AzureLocation.WestUS2); diff --git a/sdk/resources/Azure.ResourceManager.Resources/tests/Scenario/DeploymentStackCollectionTests.cs b/sdk/resources/Azure.ResourceManager.Resources/tests/Scenario/DeploymentStackCollectionTests.cs new file mode 100644 index 0000000000000..cb6e69387afc4 --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/tests/Scenario/DeploymentStackCollectionTests.cs @@ -0,0 +1,220 @@ +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. + +using System.Threading.Tasks; +using Azure.Core; +using Azure.Core.TestFramework; +using Azure.ResourceManager.ManagementGroups; +using Azure.ResourceManager.Resources.Models; +using NUnit.Framework; + +namespace Azure.ResourceManager.Resources.Tests +{ + public class DeploymentStackCollectionTests : ResourcesTestBase + { + public DeploymentStackCollectionTests(bool isAsync) + : base(isAsync)//, RecordedTestMode.Record + { + } + + /* RG Scoped Deployment Stack Tests */ + + [TestCase] + [RecordedTest] + public async Task CreateOrUpdateRG() + { + SubscriptionResource subscription = await Client.GetDefaultSubscriptionAsync(); + + string rgName = Recording.GenerateAssetName("testRg-1-"); + ResourceGroupData rgData = new ResourceGroupData(AzureLocation.WestUS); + ResourceGroupResource rg = (await subscription.GetResourceGroups().CreateOrUpdateAsync(WaitUntil.Completed, rgName, rgData)).Value; + + string deploymentStackName = Recording.GenerateAssetName("deployStackRG-CreateOrUpdate-"); + var deploymentStackData = CreateRGDeploymentStackDataWithTemplate(); + var deploymentStack = (await rg.GetDeploymentStacks().CreateOrUpdateAsync(WaitUntil.Completed ,deploymentStackName, deploymentStackData)).Value; + + Assert.AreEqual(deploymentStackName, deploymentStack.Data.Name); + + await deploymentStack.DeleteAsync(WaitUntil.Completed, unmanageActionResources: UnmanageActionResourceMode.Delete, unmanageActionResourceGroups: UnmanageActionResourceGroupMode.Delete, unmanageActionManagementGroups: UnmanageActionManagementGroupMode.Delete); + await rg.DeleteAsync(WaitUntil.Completed); + } + + [TestCase] + [RecordedTest] + public async Task GetRG() + { + SubscriptionResource subscription = await Client.GetDefaultSubscriptionAsync(); + + string rgName = Recording.GenerateAssetName("testRg-1-"); + ResourceGroupData rgData = new ResourceGroupData(AzureLocation.WestUS); + ResourceGroupResource rg = (await subscription.GetResourceGroups().CreateOrUpdateAsync(WaitUntil.Completed, rgName, rgData)).Value; + + string deploymentStackName = Recording.GenerateAssetName("deployStackRG-Get-"); + var deploymentStackData = CreateRGDeploymentStackDataWithTemplate(); + var deploymentStack = (await rg.GetDeploymentStacks().CreateOrUpdateAsync(WaitUntil.Completed, deploymentStackName, deploymentStackData)).Value; + + var deploymentStackGet = (await rg.GetDeploymentStackAsync(deploymentStackName)).Value; + + AssertValidDeploymentStack(deploymentStack, deploymentStackGet); + + await deploymentStack.DeleteAsync(WaitUntil.Completed, unmanageActionResources: UnmanageActionResourceMode.Delete, unmanageActionResourceGroups: UnmanageActionResourceGroupMode.Delete, unmanageActionManagementGroups: UnmanageActionManagementGroupMode.Delete); + await rg.DeleteAsync(WaitUntil.Completed); + } + + [TestCase] + [RecordedTest] + public async Task ListRG() + { + SubscriptionResource subscription = await Client.GetDefaultSubscriptionAsync(); + + string rgName = Recording.GenerateAssetName("testRg-1-"); + ResourceGroupData rgData = new ResourceGroupData(AzureLocation.WestUS); + ResourceGroupResource rg = (await subscription.GetResourceGroups().CreateOrUpdateAsync(WaitUntil.Completed, rgName, rgData)).Value; + + string deploymentStackName = Recording.GenerateAssetName("deployStackRG-List-"); + var deploymentStackData = CreateRGDeploymentStackDataWithTemplate(); + var getStack = (await rg.GetDeploymentStacks().CreateOrUpdateAsync(WaitUntil.Completed, deploymentStackName, deploymentStackData)).Value; + + var deploymentStacks = rg.GetDeploymentStacks(); + int count = 0; + await foreach (var deploymentStack in deploymentStacks) + { + count++; + } + + Assert.AreEqual(count, 1); + await getStack.DeleteAsync(WaitUntil.Completed); + await rg.DeleteAsync(WaitUntil.Completed); + } + + /* Sub Scoped Deployment Stack Tests */ + + [TestCase] + [RecordedTest] + public async Task CreateOrUpdateSub() + { + SubscriptionResource subscription = await Client.GetDefaultSubscriptionAsync(); + + string deploymentStackName = Recording.GenerateAssetName("deployStackSub-CreateOrUpdate-"); + var deploymentStackData = CreateSubDeploymentStackDataWithTemplate(AzureLocation.WestUS); + DeploymentStackResource deploymentStack = (await subscription.GetDeploymentStacks().CreateOrUpdateAsync(WaitUntil.Completed, deploymentStackName, deploymentStackData)).Value; + + Assert.AreEqual(deploymentStackName, deploymentStack.Data.Name); + + await deploymentStack.DeleteAsync(WaitUntil.Completed, unmanageActionResources: UnmanageActionResourceMode.Delete, unmanageActionResourceGroups: UnmanageActionResourceGroupMode.Delete, unmanageActionManagementGroups: UnmanageActionManagementGroupMode.Delete); + } + + [TestCase] + [RecordedTest] + public async Task GetSub() + { + SubscriptionResource subscription = await Client.GetDefaultSubscriptionAsync(); + + string deploymentStackName = Recording.GenerateAssetName("deployStackSub-Get-"); + var deploymentStackData = CreateSubDeploymentStackDataWithTemplate(AzureLocation.WestUS); + var deploymentStack = (await subscription.GetDeploymentStacks().CreateOrUpdateAsync(WaitUntil.Completed, deploymentStackName, deploymentStackData)).Value; + + var deploymentStackGet = (await subscription.GetDeploymentStackAsync(deploymentStackName)).Value; + + AssertValidDeploymentStack(deploymentStack, deploymentStackGet); + + await deploymentStack.DeleteAsync(WaitUntil.Completed, unmanageActionResources: UnmanageActionResourceMode.Delete, unmanageActionResourceGroups: UnmanageActionResourceGroupMode.Delete, unmanageActionManagementGroups: UnmanageActionManagementGroupMode.Delete); + } + + [TestCase] + [RecordedTest] + public async Task ListSub() + { + SubscriptionResource subscription = await Client.GetDefaultSubscriptionAsync(); + + string deploymentStackName = Recording.GenerateAssetName("deployStackSub-List-"); + var deploymentStackData = CreateSubDeploymentStackDataWithTemplate(AzureLocation.WestUS); + var getStack = (await subscription.GetDeploymentStacks().CreateOrUpdateAsync(WaitUntil.Completed, deploymentStackName, deploymentStackData)).Value; + + var deploymentStacks = subscription.GetDeploymentStacks(); + int count = 0; + await foreach (var deploymentStack in deploymentStacks) + { + count++; + } + + await getStack.DeleteAsync(WaitUntil.Completed, unmanageActionResources: UnmanageActionResourceMode.Delete, unmanageActionResourceGroups: UnmanageActionResourceGroupMode.Delete, unmanageActionManagementGroups: UnmanageActionManagementGroupMode.Delete); + + // There are more stacks in the sub than just the one created for the test: + Assert.GreaterOrEqual(count, 1); + } + + /* MG Scoped Deployment Stack Tests */ + + [TestCase] + [RecordedTest] + public async Task CreateOrUpdateMG() + { + ManagementGroupResource managementGroup = Client.GetManagementGroupResource(ManagementGroupResource.CreateResourceIdentifier("StacksSDKTest")); + + string deploymentStackName = Recording.GenerateAssetName("deployStackExMG-CreateOrUpdate-"); + var deploymentStackData = CreateMGDeploymentStackDataWithTemplate(AzureLocation.WestUS); + DeploymentStackResource deploymentStack = (await managementGroup.GetDeploymentStacks().CreateOrUpdateAsync(WaitUntil.Completed, deploymentStackName, deploymentStackData)).Value; + + Assert.AreEqual(deploymentStackName, deploymentStack.Data.Name); + + await deploymentStack.DeleteAsync(WaitUntil.Completed, unmanageActionResources: UnmanageActionResourceMode.Delete, unmanageActionResourceGroups: UnmanageActionResourceGroupMode.Delete, unmanageActionManagementGroups: UnmanageActionManagementGroupMode.Delete); + } + + [TestCase] + [RecordedTest] + public async Task GetMG() + { + ManagementGroupResource managementGroup = Client.GetManagementGroupResource(ManagementGroupResource.CreateResourceIdentifier("StacksSDKTest")); + + string deploymentStackName = Recording.GenerateAssetName("deployStackMG-Get-"); + var deploymentStackData = CreateMGDeploymentStackDataWithTemplate(AzureLocation.WestUS); + var deploymentStack = (await managementGroup.GetDeploymentStacks().CreateOrUpdateAsync(WaitUntil.Completed, deploymentStackName, deploymentStackData)).Value; + + var deploymentStackGet = (await managementGroup.GetDeploymentStackAsync(deploymentStackName)).Value; + + AssertValidDeploymentStack(deploymentStack, deploymentStackGet); + + await deploymentStack.DeleteAsync(WaitUntil.Completed, unmanageActionResources: UnmanageActionResourceMode.Delete, unmanageActionResourceGroups: UnmanageActionResourceGroupMode.Delete, unmanageActionManagementGroups: UnmanageActionManagementGroupMode.Delete); + } + + [TestCase] + [RecordedTest] + public async Task ListMG() + { + ManagementGroupResource managementGroup = Client.GetManagementGroupResource(ManagementGroupResource.CreateResourceIdentifier("StacksSDKTest")); + + string deploymentStackName = Recording.GenerateAssetName("deployStackExMG-List-"); + var deploymentStackData = CreateMGDeploymentStackDataWithTemplate(AzureLocation.WestUS); + var getStack = (await managementGroup.GetDeploymentStacks().CreateOrUpdateAsync(WaitUntil.Completed, deploymentStackName, deploymentStackData)).Value; + + var deploymentStacks = managementGroup.GetDeploymentStacks(); + int count = 0; + await foreach (var deploymentStack in deploymentStacks) + { + count++; + } + + Assert.AreEqual(count, 1); + await getStack.DeleteAsync(WaitUntil.Completed); + } + + private static void AssertValidDeploymentStack(DeploymentStackResource model, DeploymentStackResource getResult) + { + Assert.AreEqual(model.Data.Name, getResult.Data.Name); + Assert.AreEqual(model.Data.Id, getResult.Data.Id); + Assert.AreEqual(model.Data.ResourceType, getResult.Data.ResourceType); + Assert.AreEqual(model.Data.Location, getResult.Data.Location); + Assert.AreEqual(model.Data.Tags, getResult.Data.Tags); + + Assert.AreEqual(model.Data.ActionOnUnmanage.Resources, getResult.Data.ActionOnUnmanage.Resources); + Assert.AreEqual(model.Data.ActionOnUnmanage.ResourceGroups, getResult.Data.ActionOnUnmanage.ResourceGroups); + Assert.AreEqual(model.Data.ActionOnUnmanage.ManagementGroups, getResult.Data.ActionOnUnmanage.ManagementGroups); + Assert.AreEqual(model.Data.DenySettings.Mode, getResult.Data.DenySettings.Mode); + Assert.AreEqual(model.Data.DenySettings.ApplyToChildScopes, getResult.Data.DenySettings.ApplyToChildScopes); + Assert.AreEqual(model.Data.DenySettings.ExcludedPrincipals, getResult.Data.DenySettings.ExcludedPrincipals); + Assert.AreEqual(model.Data.DenySettings.ExcludedActions, getResult.Data.DenySettings.ExcludedActions); + Assert.AreEqual(model.Data.BypassStackOutOfSyncError, getResult.Data.BypassStackOutOfSyncError); + } + } +} diff --git a/sdk/resources/Azure.ResourceManager.Resources/tests/Scenario/DeploymentStackOperationsTests.cs b/sdk/resources/Azure.ResourceManager.Resources/tests/Scenario/DeploymentStackOperationsTests.cs new file mode 100644 index 0000000000000..f287cb4a9df45 --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/tests/Scenario/DeploymentStackOperationsTests.cs @@ -0,0 +1,187 @@ +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. + +using System.Threading.Tasks; +using Azure.Core; +using Azure.Core.TestFramework; +using Azure.ResourceManager.ManagementGroups; +using Azure.ResourceManager.Resources.Models; +using NUnit.Framework; + +namespace Azure.ResourceManager.Resources.Tests +{ + public class DeploymentStackOperationsTests : ResourcesTestBase + { + public DeploymentStackOperationsTests(bool isAsync) + : base(isAsync)//, RecordedTestMode.Record + { + } + + /* RG Scoped Deployment Stack Tests */ + + [TestCase] + [RecordedTest] + public async Task DeleteRG() + { + SubscriptionResource subscription = await Client.GetDefaultSubscriptionAsync(); + + string rgName = Recording.GenerateAssetName("testRg-1-"); + ResourceGroupData rgData = new ResourceGroupData(AzureLocation.WestUS); + ResourceGroupResource rg = (await subscription.GetResourceGroups().CreateOrUpdateAsync(WaitUntil.Completed, rgName, rgData)).Value; + + string deploymentStackName = Recording.GenerateAssetName("deployStackRG-Delete-"); + var deploymentStackData = CreateRGDeploymentStackDataWithTemplate(); + DeploymentStackResource deploymentStack = (await rg.GetDeploymentStacks().CreateOrUpdateAsync(WaitUntil.Completed, deploymentStackName, deploymentStackData)).Value; + await deploymentStack.DeleteAsync(WaitUntil.Completed); + + var ex = Assert.ThrowsAsync(async () => await deploymentStack.GetAsync()); + Assert.AreEqual(404, ex.Status); + await rg.DeleteAsync(WaitUntil.Completed); + } + + [TestCase] + [RecordedTest] + public async Task ExportRG() + { + SubscriptionResource subscription = await Client.GetDefaultSubscriptionAsync(); + + string rgName = Recording.GenerateAssetName("testRg-1-"); + ResourceGroupData rgData = new ResourceGroupData(AzureLocation.WestUS); + ResourceGroupResource rg = (await subscription.GetResourceGroups().CreateOrUpdateAsync(WaitUntil.Completed, rgName, rgData)).Value; + + string deploymentStackName = Recording.GenerateAssetName("deployStackRG-Export-"); + var deploymentStackData = CreateRGDeploymentStackDataWithTemplate(); + DeploymentStackResource deploymentStack = (await rg.GetDeploymentStacks().CreateOrUpdateAsync(WaitUntil.Completed, deploymentStackName, deploymentStackData)).Value; + var deploymentStackTemplate = (await deploymentStack.ExportTemplateAsync()).Value; + + Assert.IsNotNull(deploymentStackTemplate); + + // TODO: Output is off by a little and may be how the template is being read. + //Assert.AreEqual(deploymentStackTemplate.Template, deploymentStackData.Template); + + await deploymentStack.DeleteAsync(WaitUntil.Completed, unmanageActionResources: UnmanageActionResourceMode.Delete, unmanageActionResourceGroups: UnmanageActionResourceGroupMode.Delete, unmanageActionManagementGroups: UnmanageActionManagementGroupMode.Delete); + await rg.DeleteAsync(WaitUntil.Completed); + } + + [TestCase] + [RecordedTest] + public async Task ValidateRG() + { + SubscriptionResource subscription = await Client.GetDefaultSubscriptionAsync(); + + string rgName = Recording.GenerateAssetName("testRg-1-"); + ResourceGroupData rgData = new ResourceGroupData(AzureLocation.WestUS); + ResourceGroupResource rg = (await subscription.GetResourceGroups().CreateOrUpdateAsync(WaitUntil.Completed, rgName, rgData)).Value; + + string deploymentStackName = Recording.GenerateAssetName("deployStackRG-Validate-"); + var deploymentStackId = new ResourceIdentifier(rg.Id + "/providers/Microsoft.Resources/deploymentStacks/" + deploymentStackName); + var deploymentStack = Client.GetDeploymentStackResource(deploymentStackId); + + var deploymentStackData = CreateRGDeploymentStackDataWithTemplate(); + DeploymentStackValidateResult deploymentStackValidateResult = (await deploymentStack.ValidateStackAsync(WaitUntil.Completed, deploymentStackData)).Value; + + Assert.IsNotNull(deploymentStackValidateResult); + await rg.DeleteAsync(WaitUntil.Completed); + } + + /* Sub Scoped Deployment Stack Tests */ + + [TestCase] + [RecordedTest] + public async Task DeleteSub() + { + SubscriptionResource subscription = await Client.GetDefaultSubscriptionAsync(); + + string deploymentStackName = Recording.GenerateAssetName("deployStackSub-Delete-"); + var deploymentStackData = CreateSubDeploymentStackDataWithTemplate(AzureLocation.WestUS); + DeploymentStackResource deploymentStack = (await subscription.GetDeploymentStacks().CreateOrUpdateAsync(WaitUntil.Completed, deploymentStackName, deploymentStackData)).Value; + await deploymentStack.DeleteAsync(WaitUntil.Completed); + + var ex = Assert.ThrowsAsync(async () => await deploymentStack.GetAsync()); + Assert.AreEqual(404, ex.Status); + } + + [TestCase] + [RecordedTest] + public async Task ExportSub() + { + SubscriptionResource subscription = await Client.GetDefaultSubscriptionAsync(); + + string deploymentStackName = Recording.GenerateAssetName("deployStackSub-Export-"); + var deploymentStackData = CreateSubDeploymentStackDataWithTemplate(AzureLocation.WestUS); + DeploymentStackResource deploymentStack = (await subscription.GetDeploymentStacks().CreateOrUpdateAsync(WaitUntil.Completed, deploymentStackName, deploymentStackData)).Value; + var deploymentStackTemplate = (await deploymentStack.ExportTemplateAsync()).Value; + Assert.IsNotNull(deploymentStackTemplate); + + // TODO: Output is off by a little and may be how the template is being read. + //Assert.AreEqual(deploymentStackTemplate.Template, deploymentStackData.Template); + + await deploymentStack.DeleteAsync(WaitUntil.Completed, unmanageActionResources: UnmanageActionResourceMode.Delete, unmanageActionResourceGroups: UnmanageActionResourceGroupMode.Delete, unmanageActionManagementGroups: UnmanageActionManagementGroupMode.Delete); + } + + [TestCase] + [RecordedTest] + public async Task ValidateSub() + { + SubscriptionResource subscription = await Client.GetDefaultSubscriptionAsync(); + + string deploymentStackName = Recording.GenerateAssetName("deployStackSub-Validate-"); + var deploymentStackId = new ResourceIdentifier(subscription.Id + "/providers/Microsoft.Resources/deploymentStacks/" + deploymentStackName); + var deploymentStack = Client.GetDeploymentStackResource(deploymentStackId); + + var deploymentStackData = CreateSubDeploymentStackDataWithTemplate(AzureLocation.WestUS); + DeploymentStackValidateResult deploymentStackValidateResult = (await deploymentStack.ValidateStackAsync(WaitUntil.Completed, deploymentStackData)).Value; + Assert.NotNull(deploymentStackValidateResult); + } + + /* MG Scoped Deployment Stack Tests */ + + [TestCase] + [RecordedTest] + public async Task DeleteMG() + { + ManagementGroupResource managementGroup = Client.GetManagementGroupResource(ManagementGroupResource.CreateResourceIdentifier("StacksSDKTest")); + + string deploymentStackName = Recording.GenerateAssetName("deployStackMG-Delete-"); + var deploymentStackData = CreateMGDeploymentStackDataWithTemplate(AzureLocation.WestUS); + DeploymentStackResource deploymentStack = (await managementGroup.GetDeploymentStacks().CreateOrUpdateAsync(WaitUntil.Completed, deploymentStackName, deploymentStackData)).Value; + await deploymentStack.DeleteAsync(WaitUntil.Completed); + + var ex = Assert.ThrowsAsync(async () => await deploymentStack.GetAsync()); + Assert.AreEqual(404, ex.Status); + } + + [TestCase] + [RecordedTest] + public async Task ExportMG() + { + ManagementGroupResource managementGroup = Client.GetManagementGroupResource(ManagementGroupResource.CreateResourceIdentifier("StacksSDKTest")); + + string deploymentStackName = Recording.GenerateAssetName("deployStackMG-Export-"); + var deploymentStackData = CreateMGDeploymentStackDataWithTemplate(AzureLocation.WestUS); + DeploymentStackResource deploymentStack = (await managementGroup.GetDeploymentStacks().CreateOrUpdateAsync(WaitUntil.Completed, deploymentStackName, deploymentStackData)).Value; + var deploymentStackTemplate = (await deploymentStack.ExportTemplateAsync()).Value; + Assert.IsNotNull(deploymentStackTemplate); + + // TODO: Output is off by a little and may be how the template is being read. + //Assert.AreEqual(deploymentStackTemplate.Template, deploymentStackData.Template); + + await deploymentStack.DeleteAsync(WaitUntil.Completed, unmanageActionResources: UnmanageActionResourceMode.Delete, unmanageActionResourceGroups: UnmanageActionResourceGroupMode.Delete, unmanageActionManagementGroups: UnmanageActionManagementGroupMode.Delete); + } + + [TestCase] + [RecordedTest] + public async Task ValidateMG() + { + ManagementGroupResource managementGroup = Client.GetManagementGroupResource(ManagementGroupResource.CreateResourceIdentifier("StacksSDKTest")); + + string deploymentStackName = Recording.GenerateAssetName("deployStackMG-Validate-"); + var deploymentStackId = new ResourceIdentifier(managementGroup.Id + "/providers/Microsoft.Resources/deploymentStacks/" + deploymentStackName); + var deploymentStack = Client.GetDeploymentStackResource(deploymentStackId); + + var deploymentStackData = CreateMGDeploymentStackDataWithTemplate(AzureLocation.WestUS); + DeploymentStackValidateResult deploymentStackValidateResult = (await deploymentStack.ValidateStackAsync(WaitUntil.Completed, deploymentStackData)).Value; + Assert.IsNotNull(deploymentStackValidateResult); + } + } +} diff --git a/sdk/resources/Azure.ResourceManager.Resources/tests/Scenario/DeploymentTemplates/mg-stack-template.json b/sdk/resources/Azure.ResourceManager.Resources/tests/Scenario/DeploymentTemplates/mg-stack-template.json new file mode 100644 index 0000000000000..9103dd59aa005 --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/tests/Scenario/DeploymentTemplates/mg-stack-template.json @@ -0,0 +1,16 @@ +{ + "$schema": "https://schema.management.azure.com/schemas/2019-08-01/managementGroupDeploymentTemplate.json#", + "contentVersion": "1.0.0.0", + "parameters": { + "message": { + "type": "string" + } + }, + "resources": [], + "outputs": { + "outputMessage": { + "type": "string", + "value": "[parameters('message')]" + } + } +} \ No newline at end of file diff --git a/sdk/resources/Azure.ResourceManager.Resources/tests/Scenario/DeploymentTemplates/rg-stack-template.json b/sdk/resources/Azure.ResourceManager.Resources/tests/Scenario/DeploymentTemplates/rg-stack-template.json new file mode 100644 index 0000000000000..e63064520aa14 --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/tests/Scenario/DeploymentTemplates/rg-stack-template.json @@ -0,0 +1,24 @@ +{ + "$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#", + "contentVersion": "1.0.0.0", + "parameters": { + "templateSpecName": { + "type": "string" + } + }, + "variables": { + "location": "[resourceGroup().location]" + }, + "resources": [ + { + "type": "Microsoft.Resources/templateSpecs", + "apiVersion": "2022-02-01", + "name": "[parameters('templateSpecName')]", + "location": "[variables('location')]", + "properties": { + "displayName": "[parameters('templateSpecName')]", + "description": "Template Spec for RG scoped Deployment Stack Test" + } + } + ] +} \ No newline at end of file diff --git a/sdk/resources/Azure.ResourceManager.Resources/tests/Scenario/DeploymentTemplates/sub-stack-template.json b/sdk/resources/Azure.ResourceManager.Resources/tests/Scenario/DeploymentTemplates/sub-stack-template.json new file mode 100644 index 0000000000000..41eea5f5e12c3 --- /dev/null +++ b/sdk/resources/Azure.ResourceManager.Resources/tests/Scenario/DeploymentTemplates/sub-stack-template.json @@ -0,0 +1,22 @@ +{ + "$schema": "https://schema.management.azure.com/schemas/2018-05-01/subscriptionDeploymentTemplate.json#", + "contentVersion": "1.0.0.0", + "parameters": { + "rgname": { + "type": "string", + "defaultValue": "testStacksSDK321" + }, + "location": { + "type": "string", + "defaultValue": "[deployment().location]" + } + }, + "resources": [ + { + "type": "Microsoft.Resources/resourceGroups", + "apiVersion": "2021-04-01", + "name": "[parameters('rgname')]", + "location": "[parameters('location')]" + } + ] +} \ No newline at end of file