From 930a999ec1d336d2c958c8a85992b82f0e3218c7 Mon Sep 17 00:00:00 2001 From: "hashicorp-tsccr[bot]" <129506189+hashicorp-tsccr[bot]@users.noreply.github.com> Date: Mon, 18 Dec 2023 12:24:34 +0000 Subject: [PATCH 01/11] Result of tsccr-helper -log-level=info gha update -latest . (#24262) Co-authored-by: hashicorp-tsccr[bot] --- .github/workflows/breaking-change-detection.yaml | 2 +- .github/workflows/comment-stale-prs.yaml | 2 +- .github/workflows/depscheck.yaml | 2 +- .github/workflows/document-lint.yaml | 2 +- .github/workflows/gencheck.yaml | 2 +- .github/workflows/golint.yaml | 2 +- .github/workflows/gradually-deprecated.yaml | 2 +- .github/workflows/link-milestone.yaml | 2 +- .github/workflows/provider-test.yaml | 2 +- .github/workflows/pull-request.yaml | 2 +- .github/workflows/tflint.yaml | 2 +- .github/workflows/thirty-two-bit.yaml | 2 +- .github/workflows/unit-test.yaml | 2 +- .github/workflows/validate-examples.yaml | 2 +- .github/workflows/website-lint.yaml | 2 +- 15 files changed, 15 insertions(+), 15 deletions(-) diff --git a/.github/workflows/breaking-change-detection.yaml b/.github/workflows/breaking-change-detection.yaml index 5ed4447c09e5..f02ad0fd4495 100644 --- a/.github/workflows/breaking-change-detection.yaml +++ b/.github/workflows/breaking-change-detection.yaml @@ -23,7 +23,7 @@ jobs: runs-on: [custom, linux, small] steps: - uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1 - - uses: actions/setup-go@93397bea11091df50f3d7e59dc26a7711a8bcfbe # v4.1.0 + - uses: actions/setup-go@0c52d547c9bc32b1aa3301fd7a9cb496313a4491 # v5.0.0 with: go-version-file: ./.go-version - run: bash ./scripts/run-breaking-change-detection.sh \ No newline at end of file diff --git a/.github/workflows/comment-stale-prs.yaml b/.github/workflows/comment-stale-prs.yaml index 205768db8e90..b701de95c865 100644 --- a/.github/workflows/comment-stale-prs.yaml +++ b/.github/workflows/comment-stale-prs.yaml @@ -11,7 +11,7 @@ jobs: comment-stale-prs: runs-on: ubuntu-latest steps: - - uses: actions/stale@1160a2240286f5da8ec72b1c0816ce2481aabf84 # v8.0.0 + - uses: actions/stale@28ca1036281a5e5922ead5184a1bbf96e5fc984e # v9.0.0 with: stale-pr-message: | This PR is being labeled as "stale" because it has not been updated for 30 or more days. diff --git a/.github/workflows/depscheck.yaml b/.github/workflows/depscheck.yaml index 47351fdab5cb..6a7ca253757c 100644 --- a/.github/workflows/depscheck.yaml +++ b/.github/workflows/depscheck.yaml @@ -17,7 +17,7 @@ jobs: runs-on: ubuntu-latest steps: - uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1 - - uses: actions/setup-go@93397bea11091df50f3d7e59dc26a7711a8bcfbe # v4.1.0 + - uses: actions/setup-go@0c52d547c9bc32b1aa3301fd7a9cb496313a4491 # v5.0.0 with: go-version-file: ./.go-version - run: bash scripts/gogetcookie.sh diff --git a/.github/workflows/document-lint.yaml b/.github/workflows/document-lint.yaml index cd20d1bbf024..71315bd8f929 100644 --- a/.github/workflows/document-lint.yaml +++ b/.github/workflows/document-lint.yaml @@ -19,7 +19,7 @@ jobs: runs-on: ubuntu-latest steps: - uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1 - - uses: actions/setup-go@93397bea11091df50f3d7e59dc26a7711a8bcfbe # v4.1.0 + - uses: actions/setup-go@0c52d547c9bc32b1aa3301fd7a9cb496313a4491 # v5.0.0 with: go-version-file: ./.go-version - run: bash scripts/gogetcookie.sh diff --git a/.github/workflows/gencheck.yaml b/.github/workflows/gencheck.yaml index 3637bfbf31b8..0a6549f42532 100644 --- a/.github/workflows/gencheck.yaml +++ b/.github/workflows/gencheck.yaml @@ -20,7 +20,7 @@ jobs: runs-on: [custom, linux, large] steps: - uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1 - - uses: actions/setup-go@93397bea11091df50f3d7e59dc26a7711a8bcfbe # v4.1.0 + - uses: actions/setup-go@0c52d547c9bc32b1aa3301fd7a9cb496313a4491 # v5.0.0 with: go-version-file: ./.go-version - run: bash scripts/gogetcookie.sh diff --git a/.github/workflows/golint.yaml b/.github/workflows/golint.yaml index 1eedb610a30b..2ea486ac9597 100644 --- a/.github/workflows/golint.yaml +++ b/.github/workflows/golint.yaml @@ -21,7 +21,7 @@ jobs: runs-on: [custom, linux, large] steps: - uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1 - - uses: actions/setup-go@93397bea11091df50f3d7e59dc26a7711a8bcfbe # v4.1.0 + - uses: actions/setup-go@0c52d547c9bc32b1aa3301fd7a9cb496313a4491 # v5.0.0 with: go-version-file: ./.go-version - uses: golangci/golangci-lint-action@3a919529898de77ec3da873e3063ca4b10e7f5cc # v3.7.0 diff --git a/.github/workflows/gradually-deprecated.yaml b/.github/workflows/gradually-deprecated.yaml index 951fd59fd7e1..e85e2593976f 100644 --- a/.github/workflows/gradually-deprecated.yaml +++ b/.github/workflows/gradually-deprecated.yaml @@ -19,7 +19,7 @@ jobs: - uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1 with: fetch-depth: 0 - - uses: actions/setup-go@93397bea11091df50f3d7e59dc26a7711a8bcfbe # v4.1.0 + - uses: actions/setup-go@0c52d547c9bc32b1aa3301fd7a9cb496313a4491 # v5.0.0 with: go-version-file: ./.go-version - run: bash ./scripts/run-gradually-deprecated.sh diff --git a/.github/workflows/link-milestone.yaml b/.github/workflows/link-milestone.yaml index 34546ef47962..70c19391117c 100644 --- a/.github/workflows/link-milestone.yaml +++ b/.github/workflows/link-milestone.yaml @@ -15,7 +15,7 @@ jobs: pull-requests: write issues: write steps: - - uses: actions/setup-go@93397bea11091df50f3d7e59dc26a7711a8bcfbe # v4.1.0 + - uses: actions/setup-go@0c52d547c9bc32b1aa3301fd7a9cb496313a4491 # v5.0.0 with: # we cannot use go-version-file here because no repositories are checked out so there is no file to reference go-version: '1.21.3' diff --git a/.github/workflows/provider-test.yaml b/.github/workflows/provider-test.yaml index 452be5b2be0e..5e7eeb824a6d 100644 --- a/.github/workflows/provider-test.yaml +++ b/.github/workflows/provider-test.yaml @@ -39,7 +39,7 @@ jobs: uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1 - name: Install Go - uses: actions/setup-go@93397bea11091df50f3d7e59dc26a7711a8bcfbe # v4.1.0 + uses: actions/setup-go@0c52d547c9bc32b1aa3301fd7a9cb496313a4491 # v5.0.0 with: go-version-file: ./.go-version diff --git a/.github/workflows/pull-request.yaml b/.github/workflows/pull-request.yaml index 9532933e4534..103e04b31a36 100644 --- a/.github/workflows/pull-request.yaml +++ b/.github/workflows/pull-request.yaml @@ -11,7 +11,7 @@ jobs: triage: runs-on: ubuntu-latest steps: - - uses: actions/labeler@ac9175f8a1f3625fd0d4fb234536d26811351594 # v4.3.0 + - uses: actions/labeler@8558fd74291d67161a8a78ce36a881fa63b766a9 # v5.0.0 with: configuration-path: .github/labeler-pull-request-triage.yml repo-token: "${{ secrets.GITHUB_TOKEN }}" diff --git a/.github/workflows/tflint.yaml b/.github/workflows/tflint.yaml index d7d45805fdcd..76a9a128c10c 100644 --- a/.github/workflows/tflint.yaml +++ b/.github/workflows/tflint.yaml @@ -21,7 +21,7 @@ jobs: runs-on: [custom, linux, medium] steps: - uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1 - - uses: actions/setup-go@93397bea11091df50f3d7e59dc26a7711a8bcfbe # v4.1.0 + - uses: actions/setup-go@0c52d547c9bc32b1aa3301fd7a9cb496313a4491 # v5.0.0 with: go-version-file: ./.go-version - run: bash scripts/gogetcookie.sh diff --git a/.github/workflows/thirty-two-bit.yaml b/.github/workflows/thirty-two-bit.yaml index a5b26848108d..ef91db389454 100644 --- a/.github/workflows/thirty-two-bit.yaml +++ b/.github/workflows/thirty-two-bit.yaml @@ -22,7 +22,7 @@ jobs: runs-on: [custom, linux, small] steps: - uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1 - - uses: actions/setup-go@93397bea11091df50f3d7e59dc26a7711a8bcfbe # v4.1.0 + - uses: actions/setup-go@0c52d547c9bc32b1aa3301fd7a9cb496313a4491 # v5.0.0 with: go-version-file: ./.go-version - run: bash scripts/gogetcookie.sh diff --git a/.github/workflows/unit-test.yaml b/.github/workflows/unit-test.yaml index 0c4d85d294c5..632bde3e5e5f 100644 --- a/.github/workflows/unit-test.yaml +++ b/.github/workflows/unit-test.yaml @@ -22,7 +22,7 @@ jobs: runs-on: [custom, linux, large] steps: - uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1 - - uses: actions/setup-go@93397bea11091df50f3d7e59dc26a7711a8bcfbe # v4.1.0 + - uses: actions/setup-go@0c52d547c9bc32b1aa3301fd7a9cb496313a4491 # v5.0.0 with: go-version-file: ./.go-version - run: bash scripts/gogetcookie.sh diff --git a/.github/workflows/validate-examples.yaml b/.github/workflows/validate-examples.yaml index 29506fd24ec8..97008182783e 100644 --- a/.github/workflows/validate-examples.yaml +++ b/.github/workflows/validate-examples.yaml @@ -21,7 +21,7 @@ jobs: runs-on: [custom, linux, small] steps: - uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1 - - uses: actions/setup-go@93397bea11091df50f3d7e59dc26a7711a8bcfbe # v4.1.0 + - uses: actions/setup-go@0c52d547c9bc32b1aa3301fd7a9cb496313a4491 # v5.0.0 with: go-version-file: ./.go-version - run: bash scripts/gogetcookie.sh diff --git a/.github/workflows/website-lint.yaml b/.github/workflows/website-lint.yaml index 92f2e406b52c..0eb0be15cb28 100644 --- a/.github/workflows/website-lint.yaml +++ b/.github/workflows/website-lint.yaml @@ -17,7 +17,7 @@ jobs: runs-on: ubuntu-latest steps: - uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1 - - uses: actions/setup-go@93397bea11091df50f3d7e59dc26a7711a8bcfbe # v4.1.0 + - uses: actions/setup-go@0c52d547c9bc32b1aa3301fd7a9cb496313a4491 # v5.0.0 with: go-version-file: ./.go-version - run: bash scripts/gogetcookie.sh From 185c86d9d3d12183d4eaeffe5e713e897e52d75d Mon Sep 17 00:00:00 2001 From: Harshavardhan Musanalli Date: Mon, 18 Dec 2023 13:30:39 +0100 Subject: [PATCH 02/11] #24242: Preserve public_network_access_enabled during refresh (#24255) Co-authored-by: Harshavardhan Musanalli --- internal/services/bot/bot_service_resource_base.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/internal/services/bot/bot_service_resource_base.go b/internal/services/bot/bot_service_resource_base.go index bf2980f06f68..e5bf53aca3c5 100644 --- a/internal/services/bot/bot_service_resource_base.go +++ b/internal/services/bot/bot_service_resource_base.go @@ -402,7 +402,7 @@ func (br botBaseResource) readFunc() sdk.ResourceFunc { metadata.ResourceData.Set("local_authentication_enabled", localAuthEnabled) publicNetworkAccessEnabled := true - if v := props.PublicNetworkAccess; v != botservice.PublicNetworkAccessDisabled { + if v := props.PublicNetworkAccess; v != botservice.PublicNetworkAccessEnabled { publicNetworkAccessEnabled = false } metadata.ResourceData.Set("public_network_access_enabled", publicNetworkAccessEnabled) From a3febf6835f9a5d6168bed35fae139de6c244a3f Mon Sep 17 00:00:00 2001 From: catriona-m <86247157+catriona-m@users.noreply.github.com> Date: Mon, 18 Dec 2023 12:36:35 +0000 Subject: [PATCH 03/11] Update CHANGELOG.md #24255 --- CHANGELOG.md | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index ffb591dbb6b4..4248cf7fe9b3 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,3 +1,9 @@ +## 3.86.0 (Unreleased) + +BUG FIXES: + +* `azurerm_bot_service` - fixing a bug where `public_network_access_enabled` was always set to `true` in Read func [GH-24255] + ## 3.85.0 (December 14, 2023) FEATURES: From fba38949209d692d3f203d06c08b3fb058108070 Mon Sep 17 00:00:00 2001 From: hc-github-team-tf-azure <105039713+hc-github-team-tf-azure@users.noreply.github.com> Date: Mon, 18 Dec 2023 14:25:25 +0100 Subject: [PATCH 04/11] dependencies: updating to version `v0.20231215.1114251` of `github.com/hashicorp/go-azure-sdk` (#24251) Co-authored-by: hc-github-team-tf-azure <> --- go.mod | 2 +- go.sum | 4 ++-- vendor/modules.txt | 2 +- 3 files changed, 4 insertions(+), 4 deletions(-) diff --git a/go.mod b/go.mod index 0e9f81742218..4091da3c01ab 100644 --- a/go.mod +++ b/go.mod @@ -17,7 +17,7 @@ require ( github.com/google/go-cmp v0.5.9 github.com/google/uuid v1.3.1 github.com/hashicorp/go-azure-helpers v0.65.0 - github.com/hashicorp/go-azure-sdk v0.20231214.1220802 + github.com/hashicorp/go-azure-sdk v0.20231215.1114251 github.com/hashicorp/go-hclog v1.5.0 github.com/hashicorp/go-multierror v1.1.1 github.com/hashicorp/go-uuid v1.0.3 diff --git a/go.sum b/go.sum index 9195911ecd5f..60b1a2da3a36 100644 --- a/go.sum +++ b/go.sum @@ -113,8 +113,8 @@ github.com/hashicorp/errwrap v1.1.0/go.mod h1:YH+1FKiLXxHSkmPseP+kNlulaMuP3n2brv github.com/hashicorp/go-azure-helpers v0.12.0/go.mod h1:Zc3v4DNeX6PDdy7NljlYpnrdac1++qNW0I4U+ofGwpg= github.com/hashicorp/go-azure-helpers v0.65.0 h1:aOZV7HcxvqAlnaWJ/Fhfu321dXLs++TyBIVelWOb/8w= github.com/hashicorp/go-azure-helpers v0.65.0/go.mod h1:ELmZ65vzHJNTk6ml4jsPD+xq2gZb7t78D35s+XN02Kk= -github.com/hashicorp/go-azure-sdk v0.20231214.1220802 h1:8bRaPuWFrjwGMx3gNnB4sECigPABXkf/4fuhBedVcqU= -github.com/hashicorp/go-azure-sdk v0.20231214.1220802/go.mod h1:69DSA+VMovHYJyQkRuUP3BCgwlEFrKvzeIHKi9m5xzY= +github.com/hashicorp/go-azure-sdk v0.20231215.1114251 h1:SxPZYo5UrS1HcGOkTvz9k+ymHn4EFB3I1gbBiU3DksI= +github.com/hashicorp/go-azure-sdk v0.20231215.1114251/go.mod h1:69DSA+VMovHYJyQkRuUP3BCgwlEFrKvzeIHKi9m5xzY= github.com/hashicorp/go-checkpoint v0.5.0 h1:MFYpPZCnQqQTE18jFwSII6eUQrD/oxMFp3mlgcqk5mU= github.com/hashicorp/go-checkpoint v0.5.0/go.mod h1:7nfLNL10NsxqO4iWuW6tWW0HjZuDrwkBuEQsVcpCOgg= github.com/hashicorp/go-cleanhttp v0.5.0/go.mod h1:JpRdi6/HCYpAwUzNwuwqhbovhLtngrth3wmdIIUrZ80= diff --git a/vendor/modules.txt b/vendor/modules.txt index 03bd06ba8572..19096045e88d 100644 --- a/vendor/modules.txt +++ b/vendor/modules.txt @@ -157,7 +157,7 @@ github.com/hashicorp/go-azure-helpers/resourcemanager/tags github.com/hashicorp/go-azure-helpers/resourcemanager/zones github.com/hashicorp/go-azure-helpers/sender github.com/hashicorp/go-azure-helpers/storage -# github.com/hashicorp/go-azure-sdk v0.20231214.1220802 +# github.com/hashicorp/go-azure-sdk v0.20231215.1114251 ## explicit; go 1.21 github.com/hashicorp/go-azure-sdk/resource-manager/aad/2021-05-01/domainservices github.com/hashicorp/go-azure-sdk/resource-manager/aadb2c/2021-04-01-preview From 12a1fa0e9b1df4133bde2ff58d974b63de1409a2 Mon Sep 17 00:00:00 2001 From: catriona-m <86247157+catriona-m@users.noreply.github.com> Date: Mon, 18 Dec 2023 13:27:11 +0000 Subject: [PATCH 05/11] Update CHANGELOG.md #24251 --- CHANGELOG.md | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index 4248cf7fe9b3..d3cfbcaaca5a 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -4,6 +4,11 @@ BUG FIXES: * `azurerm_bot_service` - fixing a bug where `public_network_access_enabled` was always set to `true` in Read func [GH-24255] +ENHANCEMENTS: + +* dependencies: updating to `v0.20231215.1114251` of `hashicorp/go-azure-sdk` [GH-24251] + + ## 3.85.0 (December 14, 2023) FEATURES: From b5e30961597cbf09ba12892d98b5498ee928755a Mon Sep 17 00:00:00 2001 From: Dries Harnie Date: Mon, 18 Dec 2023 14:38:43 +0100 Subject: [PATCH 06/11] `azurerm_container_app_environment`: Fix documentation for instance counts (#24254) --- website/docs/r/container_app_environment.html.markdown | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/website/docs/r/container_app_environment.html.markdown b/website/docs/r/container_app_environment.html.markdown index 7554c328a40e..608042096844 100644 --- a/website/docs/r/container_app_environment.html.markdown +++ b/website/docs/r/container_app_environment.html.markdown @@ -74,9 +74,9 @@ A `workload_profile` block supports the following: * `workload_profile_type` - (Required) Workload profile type for the workloads to run on. Possible values include `D4`, `D8`, `D16`, `D32`, `E4`, `E8`, `E16` and `E32`. -* `maximum_container_count` - (Optional) The maximum number of instances of workload profile that can be deployed in the Container App Environment. +* `maximum_count` - (Optional) The maximum number of instances of workload profile that can be deployed in the Container App Environment. -* `minimum_container_count` - (Optional) The minimum number of instances of workload profile that can be deployed in the Container App Environment. +* `minimum_count` - (Optional) The minimum number of instances of workload profile that can be deployed in the Container App Environment. ## Attributes Reference From e20135c306f100d30c1f65e7869e4cc9c4365067 Mon Sep 17 00:00:00 2001 From: Heng Lu <79895375+ms-henglu@users.noreply.github.com> Date: Mon, 18 Dec 2023 22:24:01 +0800 Subject: [PATCH 07/11] `azurerm_spring_cloud_container_deployment`, `azurerm_spring_cloud_build_deployment` - fix tests (#24263) * `azurerm_spring_cloud_container_deployment`, `azurerm_spring_cloud_build_deployment` - fix tests * make terrafmt --- .../services/springcloud/spring_cloud_app_resource_test.go | 6 +++--- .../spring_cloud_build_deployment_resource_test.go | 4 ++-- .../spring_cloud_container_deployment_resource_test.go | 4 ++-- 3 files changed, 7 insertions(+), 7 deletions(-) diff --git a/internal/services/springcloud/spring_cloud_app_resource_test.go b/internal/services/springcloud/spring_cloud_app_resource_test.go index d7de5cc162cb..aba58da9c6de 100644 --- a/internal/services/springcloud/spring_cloud_app_resource_test.go +++ b/internal/services/springcloud/spring_cloud_app_resource_test.go @@ -391,9 +391,9 @@ resource "azurerm_spring_cloud_configuration_service" "test" { repository { name = "fake" label = "master" - patterns = ["app/dev", "app/prod"] - uri = "https://github.com/Azure-Samples/piggymetrics" - search_paths = ["dir1", "dir2"] + patterns = ["auth-service", "gateway"] + uri = "https://github.com/Azure-Samples/piggymetrics-config" + search_paths = ["/"] strict_host_key_checking = false username = "adminuser" password = "H@Sh1CoR3!" diff --git a/internal/services/springcloud/spring_cloud_build_deployment_resource_test.go b/internal/services/springcloud/spring_cloud_build_deployment_resource_test.go index 18649f66e751..c407cbb9c632 100644 --- a/internal/services/springcloud/spring_cloud_build_deployment_resource_test.go +++ b/internal/services/springcloud/spring_cloud_build_deployment_resource_test.go @@ -69,14 +69,14 @@ func TestAccSpringCloudBuildDeployment_addon(t *testing.T) { data.ResourceTest(t, r, []acceptance.TestStep{ { - Config: r.addon(data, "app/dev"), + Config: r.addon(data, "auth-service"), Check: acceptance.ComposeTestCheckFunc( check.That(data.ResourceName).ExistsInAzure(r), ), }, data.ImportStep(), { - Config: r.addon(data, "app/prod"), + Config: r.addon(data, "gateway"), Check: acceptance.ComposeTestCheckFunc( check.That(data.ResourceName).ExistsInAzure(r), ), diff --git a/internal/services/springcloud/spring_cloud_container_deployment_resource_test.go b/internal/services/springcloud/spring_cloud_container_deployment_resource_test.go index 5af8efb0e021..35f6dd2eac92 100644 --- a/internal/services/springcloud/spring_cloud_container_deployment_resource_test.go +++ b/internal/services/springcloud/spring_cloud_container_deployment_resource_test.go @@ -69,14 +69,14 @@ func TestAccSpringCloudContainerDeployment_addon(t *testing.T) { data.ResourceTest(t, r, []acceptance.TestStep{ { - Config: r.addon(data, "app/dev"), + Config: r.addon(data, "auth-service"), Check: acceptance.ComposeTestCheckFunc( check.That(data.ResourceName).ExistsInAzure(r), ), }, data.ImportStep(), { - Config: r.addon(data, "app/prod"), + Config: r.addon(data, "gateway"), Check: acceptance.ComposeTestCheckFunc( check.That(data.ResourceName).ExistsInAzure(r), ), From cc1de533ac0ed5f4a4dc2fb3664831ff32fd164d Mon Sep 17 00:00:00 2001 From: Matthew Frahry Date: Mon, 18 Dec 2023 10:47:49 -0800 Subject: [PATCH 08/11] `azurerm_logic_app_standard` - add support for `site_config.0.public_network_access_enabled` (#24257) --- .../logic/logic_app_standard_resource.go | 22 +++++++++ .../logic/logic_app_standard_resource_test.go | 47 +++++++++++++++++++ .../docs/r/logic_app_standard.html.markdown | 2 + 3 files changed, 71 insertions(+) diff --git a/internal/services/logic/logic_app_standard_resource.go b/internal/services/logic/logic_app_standard_resource.go index ed63c76e14f6..4f74724c7e07 100644 --- a/internal/services/logic/logic_app_standard_resource.go +++ b/internal/services/logic/logic_app_standard_resource.go @@ -11,12 +11,14 @@ import ( "time" "github.com/Azure/azure-sdk-for-go/services/web/mgmt/2021-02-01/web" // nolint: staticcheck + "github.com/hashicorp/go-azure-helpers/lang/pointer" "github.com/hashicorp/go-azure-helpers/resourcemanager/commonids" "github.com/hashicorp/go-azure-helpers/resourcemanager/commonschema" "github.com/hashicorp/go-azure-helpers/resourcemanager/identity" "github.com/hashicorp/terraform-provider-azurerm/helpers/azure" "github.com/hashicorp/terraform-provider-azurerm/helpers/tf" "github.com/hashicorp/terraform-provider-azurerm/internal/clients" + "github.com/hashicorp/terraform-provider-azurerm/internal/services/appservice/helpers" "github.com/hashicorp/terraform-provider-azurerm/internal/services/logic/parse" "github.com/hashicorp/terraform-provider-azurerm/internal/services/logic/validate" storageValidate "github.com/hashicorp/terraform-provider-azurerm/internal/services/storage/validate" @@ -868,6 +870,12 @@ func schemaLogicAppStandardSiteConfig() *pluginsdk.Schema { Computed: true, }, + "public_network_access_enabled": { + Type: pluginsdk.TypeBool, + Optional: true, + Default: true, + }, + "auto_swap_slot_name": { Type: pluginsdk.TypeString, Computed: true, @@ -1115,6 +1123,12 @@ func flattenLogicAppStandardSiteConfig(input *web.SiteConfig) []interface{} { } result["vnet_route_all_enabled"] = vnetRouteAllEnabled + publicNetworkAccessEnabled := true + if input.PublicNetworkAccess != nil { + publicNetworkAccessEnabled = !strings.EqualFold(pointer.From(input.PublicNetworkAccess), helpers.PublicNetworkAccessDisabled) + } + result["public_network_access_enabled"] = publicNetworkAccessEnabled + results = append(results, result) return results } @@ -1342,6 +1356,14 @@ func expandLogicAppStandardSiteConfig(d *pluginsdk.ResourceData) (web.SiteConfig siteConfig.VnetRouteAllEnabled = utils.Bool(v.(bool)) } + if v, ok := config["public_network_access_enabled"]; ok { + pna := helpers.PublicNetworkAccessEnabled + if !v.(bool) { + pna = helpers.PublicNetworkAccessDisabled + } + siteConfig.PublicNetworkAccess = pointer.To(pna) + } + return siteConfig, nil } diff --git a/internal/services/logic/logic_app_standard_resource_test.go b/internal/services/logic/logic_app_standard_resource_test.go index 187652de3880..201efecac485 100644 --- a/internal/services/logic/logic_app_standard_resource_test.go +++ b/internal/services/logic/logic_app_standard_resource_test.go @@ -866,6 +866,30 @@ func TestAccLogicAppStandard_vNetIntegrationUpdate(t *testing.T) { }) } +func TestAccLogicAppStandard_publicNetworkAccessEnabled(t *testing.T) { + data := acceptance.BuildTestData(t, "azurerm_logic_app_standard", "test") + r := LogicAppStandardResource{} + + data.ResourceTest(t, r, []acceptance.TestStep{ + { + Config: r.publicNetworkAccessEnabled(data, false), + Check: acceptance.ComposeTestCheckFunc( + check.That(data.ResourceName).ExistsInAzure(r), + check.That(data.ResourceName).Key("site_config.0.public_network_access_enabled").HasValue("false"), + ), + }, + data.ImportStep(), + { + Config: r.publicNetworkAccessEnabled(data, true), + Check: acceptance.ComposeTestCheckFunc( + check.That(data.ResourceName).ExistsInAzure(r), + check.That(data.ResourceName).Key("site_config.0.public_network_access_enabled").HasValue("true"), + ), + }, + data.ImportStep(), + }) +} + func (r LogicAppStandardResource) Exists(ctx context.Context, clients *clients.Client, state *pluginsdk.InstanceState) (*bool, error) { id, err := parse.LogicAppStandardID(state.ID) if err != nil { @@ -2174,3 +2198,26 @@ resource "azurerm_logic_app_standard" "test" { `, data.RandomInteger, data.Locations.Primary, data.RandomString) } + +func (r LogicAppStandardResource) publicNetworkAccessEnabled(data acceptance.TestData, enabled bool) string { + return fmt.Sprintf(` +provider "azurerm" { + features {} +} + +%s + +resource "azurerm_logic_app_standard" "test" { + name = "acctest-%d-func" + location = azurerm_resource_group.test.location + resource_group_name = azurerm_resource_group.test.name + app_service_plan_id = azurerm_app_service_plan.test.id + storage_account_name = azurerm_storage_account.test.name + storage_account_access_key = azurerm_storage_account.test.primary_access_key + + site_config { + public_network_access_enabled = %t + } +} +`, r.template(data), data.RandomInteger, enabled) +} diff --git a/website/docs/r/logic_app_standard.html.markdown b/website/docs/r/logic_app_standard.html.markdown index 0af9d8bbaf48..5eff9eab07ba 100644 --- a/website/docs/r/logic_app_standard.html.markdown +++ b/website/docs/r/logic_app_standard.html.markdown @@ -211,6 +211,8 @@ The `site_config` block supports the following: * `pre_warmed_instance_count` - (Optional) The number of pre-warmed instances for this Logic App Only affects apps on the Premium plan. +* `public_network_access_enabled` - (Optional) Is public network access enabled? Defaults to `true`. + * `runtime_scale_monitoring_enabled` - (Optional) Should Runtime Scale Monitoring be enabled?. Only applicable to apps on the Premium plan. Defaults to `false`. * `use_32_bit_worker_process` - (Optional) Should the Logic App run in 32 bit mode, rather than 64 bit mode? Defaults to `true`. From 102e9ba046d90c718495f470eaf361c272d802ce Mon Sep 17 00:00:00 2001 From: Matthew Frahry Date: Mon, 18 Dec 2023 10:48:37 -0800 Subject: [PATCH 09/11] Update CHANGELOG.md for #24257 --- CHANGELOG.md | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index d3cfbcaaca5a..89606929caf2 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,13 +1,13 @@ ## 3.86.0 (Unreleased) -BUG FIXES: - -* `azurerm_bot_service` - fixing a bug where `public_network_access_enabled` was always set to `true` in Read func [GH-24255] - ENHANCEMENTS: * dependencies: updating to `v0.20231215.1114251` of `hashicorp/go-azure-sdk` [GH-24251] - +* `azurerm_logic_app_standard` - add support for `site_config.0.public_network_access_enabled` [GH-24257] + +BUG FIXES: + +* `azurerm_bot_service` - fixing a bug where `public_network_access_enabled` was always set to `true` in Read func [GH-24255] ## 3.85.0 (December 14, 2023) From f411200ff38ecc284f410cf704fab0ce9814b421 Mon Sep 17 00:00:00 2001 From: Vladimir Lazarenko Date: Mon, 18 Dec 2023 22:32:55 +0100 Subject: [PATCH 10/11] New resource: `azurerm_log_analytics_workspace_table` (#24229) Fixes #10573 Fixes #6199 --- .../services/loganalytics/client/client.go | 9 + .../log_analytics_workspace_table_resource.go | 212 +++++++++++ ...analytics_workspace_table_resource_test.go | 70 ++++ .../services/loganalytics/registration.go | 1 + .../2022-10-01/tables/README.md | 130 +++++++ .../2022-10-01/tables/client.go | 26 ++ .../2022-10-01/tables/constants.go | 336 ++++++++++++++++++ .../2022-10-01/tables/id_table.go | 134 +++++++ .../2022-10-01/tables/id_workspace.go | 125 +++++++ .../2022-10-01/tables/method_cancelsearch.go | 47 +++ .../tables/method_createorupdate.go | 74 ++++ .../2022-10-01/tables/method_delete.go | 71 ++++ .../2022-10-01/tables/method_get.go | 51 +++ .../tables/method_listbyworkspace.go | 52 +++ .../2022-10-01/tables/method_migrate.go | 47 +++ .../2022-10-01/tables/method_update.go | 74 ++++ .../2022-10-01/tables/model_column.go | 14 + .../2022-10-01/tables/model_restoredlogs.go | 41 +++ .../tables/model_resultstatistics.go | 10 + .../2022-10-01/tables/model_schema.go | 18 + .../2022-10-01/tables/model_searchresults.go | 44 +++ .../2022-10-01/tables/model_table.go | 16 + .../tables/model_tableproperties.go | 19 + .../tables/model_tableslistresult.go | 8 + .../2022-10-01/tables/version.go | 12 + vendor/modules.txt | 1 + ...og_analytics_workspace_table.html.markdown | 65 ++++ 27 files changed, 1707 insertions(+) create mode 100644 internal/services/loganalytics/log_analytics_workspace_table_resource.go create mode 100644 internal/services/loganalytics/log_analytics_workspace_table_resource_test.go create mode 100644 vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/README.md create mode 100644 vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/client.go create mode 100644 vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/constants.go create mode 100644 vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/id_table.go create mode 100644 vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/id_workspace.go create mode 100644 vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/method_cancelsearch.go create mode 100644 vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/method_createorupdate.go create mode 100644 vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/method_delete.go create mode 100644 vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/method_get.go create mode 100644 vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/method_listbyworkspace.go create mode 100644 vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/method_migrate.go create mode 100644 vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/method_update.go create mode 100644 vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/model_column.go create mode 100644 vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/model_restoredlogs.go create mode 100644 vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/model_resultstatistics.go create mode 100644 vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/model_schema.go create mode 100644 vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/model_searchresults.go create mode 100644 vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/model_table.go create mode 100644 vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/model_tableproperties.go create mode 100644 vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/model_tableslistresult.go create mode 100644 vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/version.go create mode 100644 website/docs/r/log_analytics_workspace_table.html.markdown diff --git a/internal/services/loganalytics/client/client.go b/internal/services/loganalytics/client/client.go index 6c23cd15c7b8..549ec71276bb 100644 --- a/internal/services/loganalytics/client/client.go +++ b/internal/services/loganalytics/client/client.go @@ -16,6 +16,7 @@ import ( "github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2020-08-01/savedsearches" "github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2020-08-01/storageinsights" "github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2020-08-01/workspaces" + "github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables" featureWorkspaces "github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/workspaces" "github.com/hashicorp/go-azure-sdk/resource-manager/operationsmanagement/2015-11-01-preview/solution" "github.com/hashicorp/terraform-provider-azurerm/internal/common" @@ -33,6 +34,7 @@ type Client struct { StorageInsightsClient *storageinsights.StorageInsightsClient QueryPackQueriesClient *querypackqueries.QueryPackQueriesClient SharedKeyWorkspacesClient *workspaces.WorkspacesClient + TablesClient *tables.TablesClient WorkspaceClient *featureWorkspaces.WorkspacesClient // 2022-10-01 API version does not contain sharedkeys related API, so we keep two versions SDK of this API } @@ -109,6 +111,12 @@ func NewClient(o *common.ClientOptions) (*Client, error) { } o.Configure(queryPackQueriesClient.Client, o.Authorizers.ResourceManager) + tablesClient, err := tables.NewTablesClientWithBaseURI(o.Environment.ResourceManager) + if err != nil { + return nil, fmt.Errorf("building Tables client: %+v", err) + } + o.Configure(tablesClient.Client, o.Authorizers.ResourceManager) + return &Client{ ClusterClient: clusterClient, DataExportClient: dataExportClient, @@ -121,6 +129,7 @@ func NewClient(o *common.ClientOptions) (*Client, error) { SolutionsClient: solutionsClient, StorageInsightsClient: storageInsightsClient, SharedKeyWorkspacesClient: workspacesClient, + TablesClient: tablesClient, WorkspaceClient: featureWorkspaceClient, }, nil } diff --git a/internal/services/loganalytics/log_analytics_workspace_table_resource.go b/internal/services/loganalytics/log_analytics_workspace_table_resource.go new file mode 100644 index 000000000000..d348191f62ae --- /dev/null +++ b/internal/services/loganalytics/log_analytics_workspace_table_resource.go @@ -0,0 +1,212 @@ +package loganalytics + +import ( + "context" + "fmt" + "log" + "time" + + "github.com/hashicorp/go-azure-helpers/lang/response" + "github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables" + "github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/workspaces" + "github.com/hashicorp/terraform-provider-azurerm/internal/sdk" + "github.com/hashicorp/terraform-provider-azurerm/internal/tf/pluginsdk" + "github.com/hashicorp/terraform-provider-azurerm/internal/tf/validation" + "github.com/hashicorp/terraform-provider-azurerm/utils" +) + +type LogAnalyticsWorkspaceTableResource struct { +} + +var _ sdk.ResourceWithUpdate = LogAnalyticsWorkspaceTableResource{} + +type LogAnalyticsWorkspaceTableResourceModel struct { + Name string `tfschema:"name"` + WorkspaceId string `tfschema:"workspace_id"` + RetentionInDays int64 `tfschema:"retention_in_days"` +} + +func (r LogAnalyticsWorkspaceTableResource) Arguments() map[string]*pluginsdk.Schema { + return map[string]*pluginsdk.Schema{ + "workspace_id": { + Type: pluginsdk.TypeString, + Required: true, + ValidateFunc: workspaces.ValidateWorkspaceID, + }, + + "name": { + Type: pluginsdk.TypeString, + Required: true, + }, + + "retention_in_days": { + Type: pluginsdk.TypeInt, + Required: true, + ValidateFunc: validation.Any(validation.IntBetween(30, 730), validation.IntInSlice([]int{7})), + }, + } +} + +func (r LogAnalyticsWorkspaceTableResource) Attributes() map[string]*pluginsdk.Schema { + return map[string]*pluginsdk.Schema{} +} + +func (r LogAnalyticsWorkspaceTableResource) ModelObject() interface{} { + return &LogAnalyticsWorkspaceTableResourceModel{} +} + +func (r LogAnalyticsWorkspaceTableResource) ResourceType() string { + return "azurerm_log_analytics_workspace_table" +} + +func (r LogAnalyticsWorkspaceTableResource) IDValidationFunc() pluginsdk.SchemaValidateFunc { + return tables.ValidateTableID +} + +func (r LogAnalyticsWorkspaceTableResource) Create() sdk.ResourceFunc { + return sdk.ResourceFunc{ + Timeout: 5 * time.Minute, + Func: func(ctx context.Context, metadata sdk.ResourceMetaData) error { + var model LogAnalyticsWorkspaceTableResourceModel + if err := metadata.Decode(&model); err != nil { + return fmt.Errorf("decoding %+v", err) + } + client := metadata.Client.LogAnalytics.TablesClient + subscriptionId := metadata.Client.Account.SubscriptionId + + tableName := model.Name + log.Printf("[INFO] preparing arguments for AzureRM Log Analytics Workspace Table %s update.", tableName) + + workspaceId, err := workspaces.ParseWorkspaceID(model.WorkspaceId) + if err != nil { + return fmt.Errorf("invalid workspace object ID for table %s: %s", tableName, err) + } + + id := tables.NewTableID(subscriptionId, workspaceId.ResourceGroupName, workspaceId.WorkspaceName, tableName) + + retentionInDays := model.RetentionInDays + updateInput := tables.Table{ + Properties: &tables.TableProperties{ + RetentionInDays: &retentionInDays, + }, + } + if err := client.CreateOrUpdateThenPoll(ctx, id, updateInput); err != nil { + return fmt.Errorf("failed to update table %s in workspace %s in resource group %s: %s", tableName, workspaceId.WorkspaceName, workspaceId.ResourceGroupName, err) + } + + metadata.SetID(id) + return nil + }, + } +} + +func (r LogAnalyticsWorkspaceTableResource) Update() sdk.ResourceFunc { + return sdk.ResourceFunc{ + Timeout: 5 * time.Minute, + Func: func(ctx context.Context, metadata sdk.ResourceMetaData) error { + client := metadata.Client.LogAnalytics.TablesClient + id, err := tables.ParseTableID(metadata.ResourceData.Id()) + if err != nil { + return err + } + + var state LogAnalyticsWorkspaceTableResourceModel + if err := metadata.Decode(&state); err != nil { + return fmt.Errorf("decoding: %+v", err) + } + + existing, err := client.Get(ctx, *id) + if err != nil { + return fmt.Errorf("reading Log Analytics Workspace Table %s: %v", id, err) + } + + updateInput := tables.Table{ + Properties: &tables.TableProperties{ + RetentionInDays: existing.Model.Properties.RetentionInDays, + }, + } + + if metadata.ResourceData.HasChange("retention_in_days") { + updateInput.Properties.RetentionInDays = &state.RetentionInDays + } + if err := client.CreateOrUpdateThenPoll(ctx, *id, updateInput); err != nil { + return fmt.Errorf("failed to update table: %s: %+v", id.TableName, err) + } + + return nil + }, + } +} + +func (r LogAnalyticsWorkspaceTableResource) Read() sdk.ResourceFunc { + return sdk.ResourceFunc{ + Timeout: 5 * time.Minute, + Func: func(ctx context.Context, metadata sdk.ResourceMetaData) error { + id, err := tables.ParseTableID(metadata.ResourceData.Id()) + if err != nil { + return fmt.Errorf("while parsing resource ID: %+v", err) + } + + workspaceId, err := workspaces.ParseWorkspaceID(metadata.ResourceData.Get("workspace_id").(string)) + if err != nil { + return fmt.Errorf("while parsing resource ID: %+v", err) + } + + client := metadata.Client.LogAnalytics.TablesClient + + resp, err := client.Get(ctx, *id) + if err != nil { + if response.WasNotFound(resp.HttpResponse) { + return metadata.MarkAsGone(id) + } + return fmt.Errorf("retrieving Log Analytics Workspace Table %s: %+v", *id, err) + } + + state := LogAnalyticsWorkspaceTableResourceModel{ + Name: id.TableName, + WorkspaceId: workspaceId.ID(), + } + + if model := resp.Model; model != nil { + if model.Properties.RetentionInDays != nil { + state.RetentionInDays = *model.Properties.RetentionInDays + } + } + + return metadata.Encode(&state) + }, + } +} + +func (r LogAnalyticsWorkspaceTableResource) Delete() sdk.ResourceFunc { + return sdk.ResourceFunc{ + Timeout: 30 * time.Minute, + Func: func(ctx context.Context, metadata sdk.ResourceMetaData) error { + var model LogAnalyticsWorkspaceTableResourceModel + if err := metadata.Decode(&model); err != nil { + return fmt.Errorf("decoding %+v", err) + } + client := metadata.Client.LogAnalytics.TablesClient + id, err := tables.ParseTableID(metadata.ResourceData.Id()) + if err != nil { + return fmt.Errorf("while parsing resource ID: %+v", err) + } + + // We do not delete the resource here, just set the retention to workspace default value, which is + // achieved by setting the value to `-1` + retentionInDays := utils.Int64(-1) + + updateInput := tables.Table{ + Properties: &tables.TableProperties{ + RetentionInDays: retentionInDays, + }, + } + + if err := client.CreateOrUpdateThenPoll(ctx, *id, updateInput); err != nil { + return fmt.Errorf("failed to update table %s in workspace %s in resource group %s: %s", id.TableName, id.WorkspaceName, id.ResourceGroupName, err) + } + + return nil + }, + } +} diff --git a/internal/services/loganalytics/log_analytics_workspace_table_resource_test.go b/internal/services/loganalytics/log_analytics_workspace_table_resource_test.go new file mode 100644 index 000000000000..fe36fd411706 --- /dev/null +++ b/internal/services/loganalytics/log_analytics_workspace_table_resource_test.go @@ -0,0 +1,70 @@ +package loganalytics_test + +import ( + "context" + "fmt" + "testing" + + "github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables" + "github.com/hashicorp/terraform-provider-azurerm/internal/acceptance" + "github.com/hashicorp/terraform-provider-azurerm/internal/acceptance/check" + "github.com/hashicorp/terraform-provider-azurerm/internal/clients" + "github.com/hashicorp/terraform-provider-azurerm/internal/tf/pluginsdk" + "github.com/hashicorp/terraform-provider-azurerm/utils" +) + +type LogAnalyticsWorkspaceTableResource struct{} + +func TestAccLogAnalyticsWorkspaceTable_updateTableRetention(t *testing.T) { + data := acceptance.BuildTestData(t, "azurerm_log_analytics_workspace_table", "test") + r := LogAnalyticsWorkspaceTableResource{} + + data.ResourceTest(t, r, []acceptance.TestStep{ + { + Config: r.updateRetention(data), + Check: acceptance.ComposeTestCheckFunc( + check.That(data.ResourceName).ExistsInAzure(r), + check.That(data.ResourceName).Key("id").Exists(), + check.That(data.ResourceName).Key("name").HasValue("AppEvents"), + check.That(data.ResourceName).Key("retention_in_days").HasValue("7"), + ), + }, + }) +} + +func (t LogAnalyticsWorkspaceTableResource) Exists(ctx context.Context, clients *clients.Client, state *pluginsdk.InstanceState) (*bool, error) { + id, err := tables.ParseTableID(state.ID) + if err != nil { + return nil, err + } + + resp, err := clients.LogAnalytics.TablesClient.Get(ctx, *id) + if err != nil { + return nil, fmt.Errorf("reading Log Analytics Workspace Table (%s): %+v", id.ID(), err) + } + + return utils.Bool(resp.Model.Id != nil), nil +} + +func (LogAnalyticsWorkspaceTableResource) updateRetention(data acceptance.TestData) string { + return fmt.Sprintf(` +provider "azurerm" { + features {} +} +resource "azurerm_resource_group" "test" { + name = "acctestRG-%d" + location = "%s" +} +resource "azurerm_log_analytics_workspace" "test" { + name = "acctestLAW-%d" + location = azurerm_resource_group.test.location + resource_group_name = azurerm_resource_group.test.name + retention_in_days = 30 +} +resource "azurerm_log_analytics_workspace_table" "test" { + name = "AppEvents" + workspace_id = azurerm_log_analytics_workspace.test.id + retention_in_days = 7 +} +`, data.RandomInteger, data.Locations.Primary, data.RandomInteger) +} diff --git a/internal/services/loganalytics/registration.go b/internal/services/loganalytics/registration.go index dcbd895f49bb..8dbf237b4754 100644 --- a/internal/services/loganalytics/registration.go +++ b/internal/services/loganalytics/registration.go @@ -28,6 +28,7 @@ func (r Registration) Resources() []sdk.Resource { LogAnalyticsQueryPackResource{}, LogAnalyticsQueryPackQueryResource{}, LogAnalyticsSolutionResource{}, + LogAnalyticsWorkspaceTableResource{}, } } diff --git a/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/README.md b/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/README.md new file mode 100644 index 000000000000..cffb6cdec393 --- /dev/null +++ b/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/README.md @@ -0,0 +1,130 @@ + +## `github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables` Documentation + +The `tables` SDK allows for interaction with the Azure Resource Manager Service `operationalinsights` (API Version `2022-10-01`). + +This readme covers example usages, but further information on [using this SDK can be found in the project root](https://github.com/hashicorp/go-azure-sdk/tree/main/docs). + +### Import Path + +```go +import "github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables" +``` + + +### Client Initialization + +```go +client := tables.NewTablesClientWithBaseURI("https://management.azure.com") +client.Client.Authorizer = authorizer +``` + + +### Example Usage: `TablesClient.CancelSearch` + +```go +ctx := context.TODO() +id := tables.NewTableID("12345678-1234-9876-4563-123456789012", "example-resource-group", "workspaceValue", "tableValue") + +read, err := client.CancelSearch(ctx, id) +if err != nil { + // handle the error +} +if model := read.Model; model != nil { + // do something with the model/response object +} +``` + + +### Example Usage: `TablesClient.CreateOrUpdate` + +```go +ctx := context.TODO() +id := tables.NewTableID("12345678-1234-9876-4563-123456789012", "example-resource-group", "workspaceValue", "tableValue") + +payload := tables.Table{ + // ... +} + + +if err := client.CreateOrUpdateThenPoll(ctx, id, payload); err != nil { + // handle the error +} +``` + + +### Example Usage: `TablesClient.Delete` + +```go +ctx := context.TODO() +id := tables.NewTableID("12345678-1234-9876-4563-123456789012", "example-resource-group", "workspaceValue", "tableValue") + +if err := client.DeleteThenPoll(ctx, id); err != nil { + // handle the error +} +``` + + +### Example Usage: `TablesClient.Get` + +```go +ctx := context.TODO() +id := tables.NewTableID("12345678-1234-9876-4563-123456789012", "example-resource-group", "workspaceValue", "tableValue") + +read, err := client.Get(ctx, id) +if err != nil { + // handle the error +} +if model := read.Model; model != nil { + // do something with the model/response object +} +``` + + +### Example Usage: `TablesClient.ListByWorkspace` + +```go +ctx := context.TODO() +id := tables.NewWorkspaceID("12345678-1234-9876-4563-123456789012", "example-resource-group", "workspaceValue") + +read, err := client.ListByWorkspace(ctx, id) +if err != nil { + // handle the error +} +if model := read.Model; model != nil { + // do something with the model/response object +} +``` + + +### Example Usage: `TablesClient.Migrate` + +```go +ctx := context.TODO() +id := tables.NewTableID("12345678-1234-9876-4563-123456789012", "example-resource-group", "workspaceValue", "tableValue") + +read, err := client.Migrate(ctx, id) +if err != nil { + // handle the error +} +if model := read.Model; model != nil { + // do something with the model/response object +} +``` + + +### Example Usage: `TablesClient.Update` + +```go +ctx := context.TODO() +id := tables.NewTableID("12345678-1234-9876-4563-123456789012", "example-resource-group", "workspaceValue", "tableValue") + +payload := tables.Table{ + // ... +} + + +if err := client.UpdateThenPoll(ctx, id, payload); err != nil { + // handle the error +} +``` diff --git a/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/client.go b/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/client.go new file mode 100644 index 000000000000..406ff177ddbd --- /dev/null +++ b/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/client.go @@ -0,0 +1,26 @@ +package tables + +import ( + "fmt" + + "github.com/hashicorp/go-azure-sdk/sdk/client/resourcemanager" + sdkEnv "github.com/hashicorp/go-azure-sdk/sdk/environments" +) + +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. See NOTICE.txt in the project root for license information. + +type TablesClient struct { + Client *resourcemanager.Client +} + +func NewTablesClientWithBaseURI(sdkApi sdkEnv.Api) (*TablesClient, error) { + client, err := resourcemanager.NewResourceManagerClient(sdkApi, "tables", defaultApiVersion) + if err != nil { + return nil, fmt.Errorf("instantiating TablesClient: %+v", err) + } + + return &TablesClient{ + Client: client, + }, nil +} diff --git a/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/constants.go b/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/constants.go new file mode 100644 index 000000000000..3b59c402f7ce --- /dev/null +++ b/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/constants.go @@ -0,0 +1,336 @@ +package tables + +import ( + "encoding/json" + "fmt" + "strings" +) + +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. See NOTICE.txt in the project root for license information. + +type ColumnDataTypeHintEnum string + +const ( + ColumnDataTypeHintEnumArmPath ColumnDataTypeHintEnum = "armPath" + ColumnDataTypeHintEnumGuid ColumnDataTypeHintEnum = "guid" + ColumnDataTypeHintEnumIP ColumnDataTypeHintEnum = "ip" + ColumnDataTypeHintEnumUri ColumnDataTypeHintEnum = "uri" +) + +func PossibleValuesForColumnDataTypeHintEnum() []string { + return []string{ + string(ColumnDataTypeHintEnumArmPath), + string(ColumnDataTypeHintEnumGuid), + string(ColumnDataTypeHintEnumIP), + string(ColumnDataTypeHintEnumUri), + } +} + +func (s *ColumnDataTypeHintEnum) UnmarshalJSON(bytes []byte) error { + var decoded string + if err := json.Unmarshal(bytes, &decoded); err != nil { + return fmt.Errorf("unmarshaling: %+v", err) + } + out, err := parseColumnDataTypeHintEnum(decoded) + if err != nil { + return fmt.Errorf("parsing %q: %+v", decoded, err) + } + *s = *out + return nil +} + +func parseColumnDataTypeHintEnum(input string) (*ColumnDataTypeHintEnum, error) { + vals := map[string]ColumnDataTypeHintEnum{ + "armpath": ColumnDataTypeHintEnumArmPath, + "guid": ColumnDataTypeHintEnumGuid, + "ip": ColumnDataTypeHintEnumIP, + "uri": ColumnDataTypeHintEnumUri, + } + if v, ok := vals[strings.ToLower(input)]; ok { + return &v, nil + } + + // otherwise presume it's an undefined value and best-effort it + out := ColumnDataTypeHintEnum(input) + return &out, nil +} + +type ColumnTypeEnum string + +const ( + ColumnTypeEnumBoolean ColumnTypeEnum = "boolean" + ColumnTypeEnumDateTime ColumnTypeEnum = "dateTime" + ColumnTypeEnumDynamic ColumnTypeEnum = "dynamic" + ColumnTypeEnumGuid ColumnTypeEnum = "guid" + ColumnTypeEnumInt ColumnTypeEnum = "int" + ColumnTypeEnumLong ColumnTypeEnum = "long" + ColumnTypeEnumReal ColumnTypeEnum = "real" + ColumnTypeEnumString ColumnTypeEnum = "string" +) + +func PossibleValuesForColumnTypeEnum() []string { + return []string{ + string(ColumnTypeEnumBoolean), + string(ColumnTypeEnumDateTime), + string(ColumnTypeEnumDynamic), + string(ColumnTypeEnumGuid), + string(ColumnTypeEnumInt), + string(ColumnTypeEnumLong), + string(ColumnTypeEnumReal), + string(ColumnTypeEnumString), + } +} + +func (s *ColumnTypeEnum) UnmarshalJSON(bytes []byte) error { + var decoded string + if err := json.Unmarshal(bytes, &decoded); err != nil { + return fmt.Errorf("unmarshaling: %+v", err) + } + out, err := parseColumnTypeEnum(decoded) + if err != nil { + return fmt.Errorf("parsing %q: %+v", decoded, err) + } + *s = *out + return nil +} + +func parseColumnTypeEnum(input string) (*ColumnTypeEnum, error) { + vals := map[string]ColumnTypeEnum{ + "boolean": ColumnTypeEnumBoolean, + "datetime": ColumnTypeEnumDateTime, + "dynamic": ColumnTypeEnumDynamic, + "guid": ColumnTypeEnumGuid, + "int": ColumnTypeEnumInt, + "long": ColumnTypeEnumLong, + "real": ColumnTypeEnumReal, + "string": ColumnTypeEnumString, + } + if v, ok := vals[strings.ToLower(input)]; ok { + return &v, nil + } + + // otherwise presume it's an undefined value and best-effort it + out := ColumnTypeEnum(input) + return &out, nil +} + +type ProvisioningStateEnum string + +const ( + ProvisioningStateEnumDeleting ProvisioningStateEnum = "Deleting" + ProvisioningStateEnumInProgress ProvisioningStateEnum = "InProgress" + ProvisioningStateEnumSucceeded ProvisioningStateEnum = "Succeeded" + ProvisioningStateEnumUpdating ProvisioningStateEnum = "Updating" +) + +func PossibleValuesForProvisioningStateEnum() []string { + return []string{ + string(ProvisioningStateEnumDeleting), + string(ProvisioningStateEnumInProgress), + string(ProvisioningStateEnumSucceeded), + string(ProvisioningStateEnumUpdating), + } +} + +func (s *ProvisioningStateEnum) UnmarshalJSON(bytes []byte) error { + var decoded string + if err := json.Unmarshal(bytes, &decoded); err != nil { + return fmt.Errorf("unmarshaling: %+v", err) + } + out, err := parseProvisioningStateEnum(decoded) + if err != nil { + return fmt.Errorf("parsing %q: %+v", decoded, err) + } + *s = *out + return nil +} + +func parseProvisioningStateEnum(input string) (*ProvisioningStateEnum, error) { + vals := map[string]ProvisioningStateEnum{ + "deleting": ProvisioningStateEnumDeleting, + "inprogress": ProvisioningStateEnumInProgress, + "succeeded": ProvisioningStateEnumSucceeded, + "updating": ProvisioningStateEnumUpdating, + } + if v, ok := vals[strings.ToLower(input)]; ok { + return &v, nil + } + + // otherwise presume it's an undefined value and best-effort it + out := ProvisioningStateEnum(input) + return &out, nil +} + +type SourceEnum string + +const ( + SourceEnumCustomer SourceEnum = "customer" + SourceEnumMicrosoft SourceEnum = "microsoft" +) + +func PossibleValuesForSourceEnum() []string { + return []string{ + string(SourceEnumCustomer), + string(SourceEnumMicrosoft), + } +} + +func (s *SourceEnum) UnmarshalJSON(bytes []byte) error { + var decoded string + if err := json.Unmarshal(bytes, &decoded); err != nil { + return fmt.Errorf("unmarshaling: %+v", err) + } + out, err := parseSourceEnum(decoded) + if err != nil { + return fmt.Errorf("parsing %q: %+v", decoded, err) + } + *s = *out + return nil +} + +func parseSourceEnum(input string) (*SourceEnum, error) { + vals := map[string]SourceEnum{ + "customer": SourceEnumCustomer, + "microsoft": SourceEnumMicrosoft, + } + if v, ok := vals[strings.ToLower(input)]; ok { + return &v, nil + } + + // otherwise presume it's an undefined value and best-effort it + out := SourceEnum(input) + return &out, nil +} + +type TablePlanEnum string + +const ( + TablePlanEnumAnalytics TablePlanEnum = "Analytics" + TablePlanEnumBasic TablePlanEnum = "Basic" +) + +func PossibleValuesForTablePlanEnum() []string { + return []string{ + string(TablePlanEnumAnalytics), + string(TablePlanEnumBasic), + } +} + +func (s *TablePlanEnum) UnmarshalJSON(bytes []byte) error { + var decoded string + if err := json.Unmarshal(bytes, &decoded); err != nil { + return fmt.Errorf("unmarshaling: %+v", err) + } + out, err := parseTablePlanEnum(decoded) + if err != nil { + return fmt.Errorf("parsing %q: %+v", decoded, err) + } + *s = *out + return nil +} + +func parseTablePlanEnum(input string) (*TablePlanEnum, error) { + vals := map[string]TablePlanEnum{ + "analytics": TablePlanEnumAnalytics, + "basic": TablePlanEnumBasic, + } + if v, ok := vals[strings.ToLower(input)]; ok { + return &v, nil + } + + // otherwise presume it's an undefined value and best-effort it + out := TablePlanEnum(input) + return &out, nil +} + +type TableSubTypeEnum string + +const ( + TableSubTypeEnumAny TableSubTypeEnum = "Any" + TableSubTypeEnumClassic TableSubTypeEnum = "Classic" + TableSubTypeEnumDataCollectionRuleBased TableSubTypeEnum = "DataCollectionRuleBased" +) + +func PossibleValuesForTableSubTypeEnum() []string { + return []string{ + string(TableSubTypeEnumAny), + string(TableSubTypeEnumClassic), + string(TableSubTypeEnumDataCollectionRuleBased), + } +} + +func (s *TableSubTypeEnum) UnmarshalJSON(bytes []byte) error { + var decoded string + if err := json.Unmarshal(bytes, &decoded); err != nil { + return fmt.Errorf("unmarshaling: %+v", err) + } + out, err := parseTableSubTypeEnum(decoded) + if err != nil { + return fmt.Errorf("parsing %q: %+v", decoded, err) + } + *s = *out + return nil +} + +func parseTableSubTypeEnum(input string) (*TableSubTypeEnum, error) { + vals := map[string]TableSubTypeEnum{ + "any": TableSubTypeEnumAny, + "classic": TableSubTypeEnumClassic, + "datacollectionrulebased": TableSubTypeEnumDataCollectionRuleBased, + } + if v, ok := vals[strings.ToLower(input)]; ok { + return &v, nil + } + + // otherwise presume it's an undefined value and best-effort it + out := TableSubTypeEnum(input) + return &out, nil +} + +type TableTypeEnum string + +const ( + TableTypeEnumCustomLog TableTypeEnum = "CustomLog" + TableTypeEnumMicrosoft TableTypeEnum = "Microsoft" + TableTypeEnumRestoredLogs TableTypeEnum = "RestoredLogs" + TableTypeEnumSearchResults TableTypeEnum = "SearchResults" +) + +func PossibleValuesForTableTypeEnum() []string { + return []string{ + string(TableTypeEnumCustomLog), + string(TableTypeEnumMicrosoft), + string(TableTypeEnumRestoredLogs), + string(TableTypeEnumSearchResults), + } +} + +func (s *TableTypeEnum) UnmarshalJSON(bytes []byte) error { + var decoded string + if err := json.Unmarshal(bytes, &decoded); err != nil { + return fmt.Errorf("unmarshaling: %+v", err) + } + out, err := parseTableTypeEnum(decoded) + if err != nil { + return fmt.Errorf("parsing %q: %+v", decoded, err) + } + *s = *out + return nil +} + +func parseTableTypeEnum(input string) (*TableTypeEnum, error) { + vals := map[string]TableTypeEnum{ + "customlog": TableTypeEnumCustomLog, + "microsoft": TableTypeEnumMicrosoft, + "restoredlogs": TableTypeEnumRestoredLogs, + "searchresults": TableTypeEnumSearchResults, + } + if v, ok := vals[strings.ToLower(input)]; ok { + return &v, nil + } + + // otherwise presume it's an undefined value and best-effort it + out := TableTypeEnum(input) + return &out, nil +} diff --git a/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/id_table.go b/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/id_table.go new file mode 100644 index 000000000000..43b615488dbb --- /dev/null +++ b/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/id_table.go @@ -0,0 +1,134 @@ +package tables + +import ( + "fmt" + "strings" + + "github.com/hashicorp/go-azure-helpers/resourcemanager/resourceids" +) + +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. See NOTICE.txt in the project root for license information. + +var _ resourceids.ResourceId = TableId{} + +// TableId is a struct representing the Resource ID for a Table +type TableId struct { + SubscriptionId string + ResourceGroupName string + WorkspaceName string + TableName string +} + +// NewTableID returns a new TableId struct +func NewTableID(subscriptionId string, resourceGroupName string, workspaceName string, tableName string) TableId { + return TableId{ + SubscriptionId: subscriptionId, + ResourceGroupName: resourceGroupName, + WorkspaceName: workspaceName, + TableName: tableName, + } +} + +// ParseTableID parses 'input' into a TableId +func ParseTableID(input string) (*TableId, error) { + parser := resourceids.NewParserFromResourceIdType(TableId{}) + parsed, err := parser.Parse(input, false) + if err != nil { + return nil, fmt.Errorf("parsing %q: %+v", input, err) + } + + id := TableId{} + if err := id.FromParseResult(*parsed); err != nil { + return nil, err + } + + return &id, nil +} + +// ParseTableIDInsensitively parses 'input' case-insensitively into a TableId +// note: this method should only be used for API response data and not user input +func ParseTableIDInsensitively(input string) (*TableId, error) { + parser := resourceids.NewParserFromResourceIdType(TableId{}) + parsed, err := parser.Parse(input, true) + if err != nil { + return nil, fmt.Errorf("parsing %q: %+v", input, err) + } + + id := TableId{} + if err := id.FromParseResult(*parsed); err != nil { + return nil, err + } + + return &id, nil +} + +func (id *TableId) FromParseResult(input resourceids.ParseResult) error { + var ok bool + + if id.SubscriptionId, ok = input.Parsed["subscriptionId"]; !ok { + return resourceids.NewSegmentNotSpecifiedError(id, "subscriptionId", input) + } + + if id.ResourceGroupName, ok = input.Parsed["resourceGroupName"]; !ok { + return resourceids.NewSegmentNotSpecifiedError(id, "resourceGroupName", input) + } + + if id.WorkspaceName, ok = input.Parsed["workspaceName"]; !ok { + return resourceids.NewSegmentNotSpecifiedError(id, "workspaceName", input) + } + + if id.TableName, ok = input.Parsed["tableName"]; !ok { + return resourceids.NewSegmentNotSpecifiedError(id, "tableName", input) + } + + return nil +} + +// ValidateTableID checks that 'input' can be parsed as a Table ID +func ValidateTableID(input interface{}, key string) (warnings []string, errors []error) { + v, ok := input.(string) + if !ok { + errors = append(errors, fmt.Errorf("expected %q to be a string", key)) + return + } + + if _, err := ParseTableID(v); err != nil { + errors = append(errors, err) + } + + return +} + +// ID returns the formatted Table ID +func (id TableId) ID() string { + fmtString := "/subscriptions/%s/resourceGroups/%s/providers/Microsoft.OperationalInsights/workspaces/%s/tables/%s" + return fmt.Sprintf(fmtString, id.SubscriptionId, id.ResourceGroupName, id.WorkspaceName, id.TableName) +} + +// Segments returns a slice of Resource ID Segments which comprise this Table ID +func (id TableId) Segments() []resourceids.Segment { + return []resourceids.Segment{ + resourceids.StaticSegment("staticSubscriptions", "subscriptions", "subscriptions"), + resourceids.SubscriptionIdSegment("subscriptionId", "12345678-1234-9876-4563-123456789012"), + resourceids.StaticSegment("staticResourceGroups", "resourceGroups", "resourceGroups"), + resourceids.ResourceGroupSegment("resourceGroupName", "example-resource-group"), + resourceids.StaticSegment("staticProviders", "providers", "providers"), + resourceids.ResourceProviderSegment("staticMicrosoftOperationalInsights", "Microsoft.OperationalInsights", "Microsoft.OperationalInsights"), + resourceids.StaticSegment("staticWorkspaces", "workspaces", "workspaces"), + resourceids.UserSpecifiedSegment("workspaceName", "workspaceValue"), + resourceids.StaticSegment("staticTables", "tables", "tables"), + resourceids.UserSpecifiedSegment("tableName", "tableValue"), + } +} + +// String returns a human-readable description of this Table ID +func (id TableId) String() string { + components := []string{ + fmt.Sprintf("Subscription: %q", id.SubscriptionId), + fmt.Sprintf("Resource Group Name: %q", id.ResourceGroupName), + fmt.Sprintf("Workspace Name: %q", id.WorkspaceName), + fmt.Sprintf("Table Name: %q", id.TableName), + } + return fmt.Sprintf("Table (%s)", strings.Join(components, "\n")) +} diff --git a/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/id_workspace.go b/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/id_workspace.go new file mode 100644 index 000000000000..faa86da9be17 --- /dev/null +++ b/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/id_workspace.go @@ -0,0 +1,125 @@ +package tables + +import ( + "fmt" + "strings" + + "github.com/hashicorp/go-azure-helpers/resourcemanager/resourceids" +) + +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. See NOTICE.txt in the project root for license information. + +var _ resourceids.ResourceId = WorkspaceId{} + +// WorkspaceId is a struct representing the Resource ID for a Workspace +type WorkspaceId struct { + SubscriptionId string + ResourceGroupName string + WorkspaceName string +} + +// NewWorkspaceID returns a new WorkspaceId struct +func NewWorkspaceID(subscriptionId string, resourceGroupName string, workspaceName string) WorkspaceId { + return WorkspaceId{ + SubscriptionId: subscriptionId, + ResourceGroupName: resourceGroupName, + WorkspaceName: workspaceName, + } +} + +// ParseWorkspaceID parses 'input' into a WorkspaceId +func ParseWorkspaceID(input string) (*WorkspaceId, error) { + parser := resourceids.NewParserFromResourceIdType(WorkspaceId{}) + parsed, err := parser.Parse(input, false) + if err != nil { + return nil, fmt.Errorf("parsing %q: %+v", input, err) + } + + id := WorkspaceId{} + if err := id.FromParseResult(*parsed); err != nil { + return nil, err + } + + return &id, nil +} + +// ParseWorkspaceIDInsensitively parses 'input' case-insensitively into a WorkspaceId +// note: this method should only be used for API response data and not user input +func ParseWorkspaceIDInsensitively(input string) (*WorkspaceId, error) { + parser := resourceids.NewParserFromResourceIdType(WorkspaceId{}) + parsed, err := parser.Parse(input, true) + if err != nil { + return nil, fmt.Errorf("parsing %q: %+v", input, err) + } + + id := WorkspaceId{} + if err := id.FromParseResult(*parsed); err != nil { + return nil, err + } + + return &id, nil +} + +func (id *WorkspaceId) FromParseResult(input resourceids.ParseResult) error { + var ok bool + + if id.SubscriptionId, ok = input.Parsed["subscriptionId"]; !ok { + return resourceids.NewSegmentNotSpecifiedError(id, "subscriptionId", input) + } + + if id.ResourceGroupName, ok = input.Parsed["resourceGroupName"]; !ok { + return resourceids.NewSegmentNotSpecifiedError(id, "resourceGroupName", input) + } + + if id.WorkspaceName, ok = input.Parsed["workspaceName"]; !ok { + return resourceids.NewSegmentNotSpecifiedError(id, "workspaceName", input) + } + + return nil +} + +// ValidateWorkspaceID checks that 'input' can be parsed as a Workspace ID +func ValidateWorkspaceID(input interface{}, key string) (warnings []string, errors []error) { + v, ok := input.(string) + if !ok { + errors = append(errors, fmt.Errorf("expected %q to be a string", key)) + return + } + + if _, err := ParseWorkspaceID(v); err != nil { + errors = append(errors, err) + } + + return +} + +// ID returns the formatted Workspace ID +func (id WorkspaceId) ID() string { + fmtString := "/subscriptions/%s/resourceGroups/%s/providers/Microsoft.OperationalInsights/workspaces/%s" + return fmt.Sprintf(fmtString, id.SubscriptionId, id.ResourceGroupName, id.WorkspaceName) +} + +// Segments returns a slice of Resource ID Segments which comprise this Workspace ID +func (id WorkspaceId) Segments() []resourceids.Segment { + return []resourceids.Segment{ + resourceids.StaticSegment("staticSubscriptions", "subscriptions", "subscriptions"), + resourceids.SubscriptionIdSegment("subscriptionId", "12345678-1234-9876-4563-123456789012"), + resourceids.StaticSegment("staticResourceGroups", "resourceGroups", "resourceGroups"), + resourceids.ResourceGroupSegment("resourceGroupName", "example-resource-group"), + resourceids.StaticSegment("staticProviders", "providers", "providers"), + resourceids.ResourceProviderSegment("staticMicrosoftOperationalInsights", "Microsoft.OperationalInsights", "Microsoft.OperationalInsights"), + resourceids.StaticSegment("staticWorkspaces", "workspaces", "workspaces"), + resourceids.UserSpecifiedSegment("workspaceName", "workspaceValue"), + } +} + +// String returns a human-readable description of this Workspace ID +func (id WorkspaceId) String() string { + components := []string{ + fmt.Sprintf("Subscription: %q", id.SubscriptionId), + fmt.Sprintf("Resource Group Name: %q", id.ResourceGroupName), + fmt.Sprintf("Workspace Name: %q", id.WorkspaceName), + } + return fmt.Sprintf("Workspace (%s)", strings.Join(components, "\n")) +} diff --git a/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/method_cancelsearch.go b/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/method_cancelsearch.go new file mode 100644 index 000000000000..5268e6542a72 --- /dev/null +++ b/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/method_cancelsearch.go @@ -0,0 +1,47 @@ +package tables + +import ( + "context" + "fmt" + "net/http" + + "github.com/hashicorp/go-azure-sdk/sdk/client" + "github.com/hashicorp/go-azure-sdk/sdk/odata" +) + +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. See NOTICE.txt in the project root for license information. + +type CancelSearchOperationResponse struct { + HttpResponse *http.Response + OData *odata.OData +} + +// CancelSearch ... +func (c TablesClient) CancelSearch(ctx context.Context, id TableId) (result CancelSearchOperationResponse, err error) { + opts := client.RequestOptions{ + ContentType: "application/json; charset=utf-8", + ExpectedStatusCodes: []int{ + http.StatusOK, + }, + HttpMethod: http.MethodPost, + Path: fmt.Sprintf("%s/cancelSearch", id.ID()), + } + + req, err := c.Client.NewRequest(ctx, opts) + if err != nil { + return + } + + var resp *client.Response + resp, err = req.Execute(ctx) + if resp != nil { + result.OData = resp.OData + result.HttpResponse = resp.Response + } + if err != nil { + return + } + + return +} diff --git a/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/method_createorupdate.go b/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/method_createorupdate.go new file mode 100644 index 000000000000..09d419a5596c --- /dev/null +++ b/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/method_createorupdate.go @@ -0,0 +1,74 @@ +package tables + +import ( + "context" + "fmt" + "net/http" + + "github.com/hashicorp/go-azure-sdk/sdk/client" + "github.com/hashicorp/go-azure-sdk/sdk/client/pollers" + "github.com/hashicorp/go-azure-sdk/sdk/client/resourcemanager" + "github.com/hashicorp/go-azure-sdk/sdk/odata" +) + +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. See NOTICE.txt in the project root for license information. + +type CreateOrUpdateOperationResponse struct { + Poller pollers.Poller + HttpResponse *http.Response + OData *odata.OData +} + +// CreateOrUpdate ... +func (c TablesClient) CreateOrUpdate(ctx context.Context, id TableId, input Table) (result CreateOrUpdateOperationResponse, err error) { + opts := client.RequestOptions{ + ContentType: "application/json; charset=utf-8", + ExpectedStatusCodes: []int{ + http.StatusAccepted, + http.StatusOK, + }, + HttpMethod: http.MethodPut, + Path: id.ID(), + } + + req, err := c.Client.NewRequest(ctx, opts) + if err != nil { + return + } + + if err = req.Marshal(input); err != nil { + return + } + + var resp *client.Response + resp, err = req.Execute(ctx) + if resp != nil { + result.OData = resp.OData + result.HttpResponse = resp.Response + } + if err != nil { + return + } + + result.Poller, err = resourcemanager.PollerFromResponse(resp, c.Client) + if err != nil { + return + } + + return +} + +// CreateOrUpdateThenPoll performs CreateOrUpdate then polls until it's completed +func (c TablesClient) CreateOrUpdateThenPoll(ctx context.Context, id TableId, input Table) error { + result, err := c.CreateOrUpdate(ctx, id, input) + if err != nil { + return fmt.Errorf("performing CreateOrUpdate: %+v", err) + } + + if err := result.Poller.PollUntilDone(ctx); err != nil { + return fmt.Errorf("polling after CreateOrUpdate: %+v", err) + } + + return nil +} diff --git a/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/method_delete.go b/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/method_delete.go new file mode 100644 index 000000000000..26e68dd6ed8b --- /dev/null +++ b/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/method_delete.go @@ -0,0 +1,71 @@ +package tables + +import ( + "context" + "fmt" + "net/http" + + "github.com/hashicorp/go-azure-sdk/sdk/client" + "github.com/hashicorp/go-azure-sdk/sdk/client/pollers" + "github.com/hashicorp/go-azure-sdk/sdk/client/resourcemanager" + "github.com/hashicorp/go-azure-sdk/sdk/odata" +) + +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. See NOTICE.txt in the project root for license information. + +type DeleteOperationResponse struct { + Poller pollers.Poller + HttpResponse *http.Response + OData *odata.OData +} + +// Delete ... +func (c TablesClient) Delete(ctx context.Context, id TableId) (result DeleteOperationResponse, err error) { + opts := client.RequestOptions{ + ContentType: "application/json; charset=utf-8", + ExpectedStatusCodes: []int{ + http.StatusAccepted, + http.StatusNoContent, + http.StatusOK, + }, + HttpMethod: http.MethodDelete, + Path: id.ID(), + } + + req, err := c.Client.NewRequest(ctx, opts) + if err != nil { + return + } + + var resp *client.Response + resp, err = req.Execute(ctx) + if resp != nil { + result.OData = resp.OData + result.HttpResponse = resp.Response + } + if err != nil { + return + } + + result.Poller, err = resourcemanager.PollerFromResponse(resp, c.Client) + if err != nil { + return + } + + return +} + +// DeleteThenPoll performs Delete then polls until it's completed +func (c TablesClient) DeleteThenPoll(ctx context.Context, id TableId) error { + result, err := c.Delete(ctx, id) + if err != nil { + return fmt.Errorf("performing Delete: %+v", err) + } + + if err := result.Poller.PollUntilDone(ctx); err != nil { + return fmt.Errorf("polling after Delete: %+v", err) + } + + return nil +} diff --git a/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/method_get.go b/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/method_get.go new file mode 100644 index 000000000000..faf3b42925d7 --- /dev/null +++ b/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/method_get.go @@ -0,0 +1,51 @@ +package tables + +import ( + "context" + "net/http" + + "github.com/hashicorp/go-azure-sdk/sdk/client" + "github.com/hashicorp/go-azure-sdk/sdk/odata" +) + +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. See NOTICE.txt in the project root for license information. + +type GetOperationResponse struct { + HttpResponse *http.Response + OData *odata.OData + Model *Table +} + +// Get ... +func (c TablesClient) Get(ctx context.Context, id TableId) (result GetOperationResponse, err error) { + opts := client.RequestOptions{ + ContentType: "application/json; charset=utf-8", + ExpectedStatusCodes: []int{ + http.StatusOK, + }, + HttpMethod: http.MethodGet, + Path: id.ID(), + } + + req, err := c.Client.NewRequest(ctx, opts) + if err != nil { + return + } + + var resp *client.Response + resp, err = req.Execute(ctx) + if resp != nil { + result.OData = resp.OData + result.HttpResponse = resp.Response + } + if err != nil { + return + } + + if err = resp.Unmarshal(&result.Model); err != nil { + return + } + + return +} diff --git a/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/method_listbyworkspace.go b/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/method_listbyworkspace.go new file mode 100644 index 000000000000..cf7139998c32 --- /dev/null +++ b/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/method_listbyworkspace.go @@ -0,0 +1,52 @@ +package tables + +import ( + "context" + "fmt" + "net/http" + + "github.com/hashicorp/go-azure-sdk/sdk/client" + "github.com/hashicorp/go-azure-sdk/sdk/odata" +) + +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. See NOTICE.txt in the project root for license information. + +type ListByWorkspaceOperationResponse struct { + HttpResponse *http.Response + OData *odata.OData + Model *TablesListResult +} + +// ListByWorkspace ... +func (c TablesClient) ListByWorkspace(ctx context.Context, id WorkspaceId) (result ListByWorkspaceOperationResponse, err error) { + opts := client.RequestOptions{ + ContentType: "application/json; charset=utf-8", + ExpectedStatusCodes: []int{ + http.StatusOK, + }, + HttpMethod: http.MethodGet, + Path: fmt.Sprintf("%s/tables", id.ID()), + } + + req, err := c.Client.NewRequest(ctx, opts) + if err != nil { + return + } + + var resp *client.Response + resp, err = req.Execute(ctx) + if resp != nil { + result.OData = resp.OData + result.HttpResponse = resp.Response + } + if err != nil { + return + } + + if err = resp.Unmarshal(&result.Model); err != nil { + return + } + + return +} diff --git a/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/method_migrate.go b/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/method_migrate.go new file mode 100644 index 000000000000..af5f8e9acd1f --- /dev/null +++ b/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/method_migrate.go @@ -0,0 +1,47 @@ +package tables + +import ( + "context" + "fmt" + "net/http" + + "github.com/hashicorp/go-azure-sdk/sdk/client" + "github.com/hashicorp/go-azure-sdk/sdk/odata" +) + +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. See NOTICE.txt in the project root for license information. + +type MigrateOperationResponse struct { + HttpResponse *http.Response + OData *odata.OData +} + +// Migrate ... +func (c TablesClient) Migrate(ctx context.Context, id TableId) (result MigrateOperationResponse, err error) { + opts := client.RequestOptions{ + ContentType: "application/json; charset=utf-8", + ExpectedStatusCodes: []int{ + http.StatusOK, + }, + HttpMethod: http.MethodPost, + Path: fmt.Sprintf("%s/migrate", id.ID()), + } + + req, err := c.Client.NewRequest(ctx, opts) + if err != nil { + return + } + + var resp *client.Response + resp, err = req.Execute(ctx) + if resp != nil { + result.OData = resp.OData + result.HttpResponse = resp.Response + } + if err != nil { + return + } + + return +} diff --git a/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/method_update.go b/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/method_update.go new file mode 100644 index 000000000000..bbac70988edb --- /dev/null +++ b/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/method_update.go @@ -0,0 +1,74 @@ +package tables + +import ( + "context" + "fmt" + "net/http" + + "github.com/hashicorp/go-azure-sdk/sdk/client" + "github.com/hashicorp/go-azure-sdk/sdk/client/pollers" + "github.com/hashicorp/go-azure-sdk/sdk/client/resourcemanager" + "github.com/hashicorp/go-azure-sdk/sdk/odata" +) + +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. See NOTICE.txt in the project root for license information. + +type UpdateOperationResponse struct { + Poller pollers.Poller + HttpResponse *http.Response + OData *odata.OData +} + +// Update ... +func (c TablesClient) Update(ctx context.Context, id TableId, input Table) (result UpdateOperationResponse, err error) { + opts := client.RequestOptions{ + ContentType: "application/json; charset=utf-8", + ExpectedStatusCodes: []int{ + http.StatusAccepted, + http.StatusOK, + }, + HttpMethod: http.MethodPatch, + Path: id.ID(), + } + + req, err := c.Client.NewRequest(ctx, opts) + if err != nil { + return + } + + if err = req.Marshal(input); err != nil { + return + } + + var resp *client.Response + resp, err = req.Execute(ctx) + if resp != nil { + result.OData = resp.OData + result.HttpResponse = resp.Response + } + if err != nil { + return + } + + result.Poller, err = resourcemanager.PollerFromResponse(resp, c.Client) + if err != nil { + return + } + + return +} + +// UpdateThenPoll performs Update then polls until it's completed +func (c TablesClient) UpdateThenPoll(ctx context.Context, id TableId, input Table) error { + result, err := c.Update(ctx, id, input) + if err != nil { + return fmt.Errorf("performing Update: %+v", err) + } + + if err := result.Poller.PollUntilDone(ctx); err != nil { + return fmt.Errorf("polling after Update: %+v", err) + } + + return nil +} diff --git a/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/model_column.go b/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/model_column.go new file mode 100644 index 000000000000..8ec13720b700 --- /dev/null +++ b/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/model_column.go @@ -0,0 +1,14 @@ +package tables + +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. See NOTICE.txt in the project root for license information. + +type Column struct { + DataTypeHint *ColumnDataTypeHintEnum `json:"dataTypeHint,omitempty"` + Description *string `json:"description,omitempty"` + DisplayName *string `json:"displayName,omitempty"` + IsDefaultDisplay *bool `json:"isDefaultDisplay,omitempty"` + IsHidden *bool `json:"isHidden,omitempty"` + Name *string `json:"name,omitempty"` + Type *ColumnTypeEnum `json:"type,omitempty"` +} diff --git a/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/model_restoredlogs.go b/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/model_restoredlogs.go new file mode 100644 index 000000000000..3d3bfc3f6983 --- /dev/null +++ b/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/model_restoredlogs.go @@ -0,0 +1,41 @@ +package tables + +import ( + "time" + + "github.com/hashicorp/go-azure-helpers/lang/dates" +) + +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. See NOTICE.txt in the project root for license information. + +type RestoredLogs struct { + AzureAsyncOperationId *string `json:"azureAsyncOperationId,omitempty"` + EndRestoreTime *string `json:"endRestoreTime,omitempty"` + SourceTable *string `json:"sourceTable,omitempty"` + StartRestoreTime *string `json:"startRestoreTime,omitempty"` +} + +func (o *RestoredLogs) GetEndRestoreTimeAsTime() (*time.Time, error) { + if o.EndRestoreTime == nil { + return nil, nil + } + return dates.ParseAsFormat(o.EndRestoreTime, "2006-01-02T15:04:05Z07:00") +} + +func (o *RestoredLogs) SetEndRestoreTimeAsTime(input time.Time) { + formatted := input.Format("2006-01-02T15:04:05Z07:00") + o.EndRestoreTime = &formatted +} + +func (o *RestoredLogs) GetStartRestoreTimeAsTime() (*time.Time, error) { + if o.StartRestoreTime == nil { + return nil, nil + } + return dates.ParseAsFormat(o.StartRestoreTime, "2006-01-02T15:04:05Z07:00") +} + +func (o *RestoredLogs) SetStartRestoreTimeAsTime(input time.Time) { + formatted := input.Format("2006-01-02T15:04:05Z07:00") + o.StartRestoreTime = &formatted +} diff --git a/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/model_resultstatistics.go b/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/model_resultstatistics.go new file mode 100644 index 000000000000..81582f6b191e --- /dev/null +++ b/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/model_resultstatistics.go @@ -0,0 +1,10 @@ +package tables + +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. See NOTICE.txt in the project root for license information. + +type ResultStatistics struct { + IngestedRecords *int64 `json:"ingestedRecords,omitempty"` + Progress *float64 `json:"progress,omitempty"` + ScannedGb *float64 `json:"scannedGb,omitempty"` +} diff --git a/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/model_schema.go b/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/model_schema.go new file mode 100644 index 000000000000..13eb3820bd95 --- /dev/null +++ b/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/model_schema.go @@ -0,0 +1,18 @@ +package tables + +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. See NOTICE.txt in the project root for license information. + +type Schema struct { + Categories *[]string `json:"categories,omitempty"` + Columns *[]Column `json:"columns,omitempty"` + Description *string `json:"description,omitempty"` + DisplayName *string `json:"displayName,omitempty"` + Labels *[]string `json:"labels,omitempty"` + Name *string `json:"name,omitempty"` + Solutions *[]string `json:"solutions,omitempty"` + Source *SourceEnum `json:"source,omitempty"` + StandardColumns *[]Column `json:"standardColumns,omitempty"` + TableSubType *TableSubTypeEnum `json:"tableSubType,omitempty"` + TableType *TableTypeEnum `json:"tableType,omitempty"` +} diff --git a/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/model_searchresults.go b/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/model_searchresults.go new file mode 100644 index 000000000000..8c11e8df14a2 --- /dev/null +++ b/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/model_searchresults.go @@ -0,0 +1,44 @@ +package tables + +import ( + "time" + + "github.com/hashicorp/go-azure-helpers/lang/dates" +) + +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. See NOTICE.txt in the project root for license information. + +type SearchResults struct { + AzureAsyncOperationId *string `json:"azureAsyncOperationId,omitempty"` + Description *string `json:"description,omitempty"` + EndSearchTime *string `json:"endSearchTime,omitempty"` + Limit *int64 `json:"limit,omitempty"` + Query *string `json:"query,omitempty"` + SourceTable *string `json:"sourceTable,omitempty"` + StartSearchTime *string `json:"startSearchTime,omitempty"` +} + +func (o *SearchResults) GetEndSearchTimeAsTime() (*time.Time, error) { + if o.EndSearchTime == nil { + return nil, nil + } + return dates.ParseAsFormat(o.EndSearchTime, "2006-01-02T15:04:05Z07:00") +} + +func (o *SearchResults) SetEndSearchTimeAsTime(input time.Time) { + formatted := input.Format("2006-01-02T15:04:05Z07:00") + o.EndSearchTime = &formatted +} + +func (o *SearchResults) GetStartSearchTimeAsTime() (*time.Time, error) { + if o.StartSearchTime == nil { + return nil, nil + } + return dates.ParseAsFormat(o.StartSearchTime, "2006-01-02T15:04:05Z07:00") +} + +func (o *SearchResults) SetStartSearchTimeAsTime(input time.Time) { + formatted := input.Format("2006-01-02T15:04:05Z07:00") + o.StartSearchTime = &formatted +} diff --git a/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/model_table.go b/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/model_table.go new file mode 100644 index 000000000000..b74a23702c41 --- /dev/null +++ b/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/model_table.go @@ -0,0 +1,16 @@ +package tables + +import ( + "github.com/hashicorp/go-azure-helpers/resourcemanager/systemdata" +) + +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. See NOTICE.txt in the project root for license information. + +type Table struct { + Id *string `json:"id,omitempty"` + Name *string `json:"name,omitempty"` + Properties *TableProperties `json:"properties,omitempty"` + SystemData *systemdata.SystemData `json:"systemData,omitempty"` + Type *string `json:"type,omitempty"` +} diff --git a/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/model_tableproperties.go b/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/model_tableproperties.go new file mode 100644 index 000000000000..0b0714b4dac8 --- /dev/null +++ b/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/model_tableproperties.go @@ -0,0 +1,19 @@ +package tables + +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. See NOTICE.txt in the project root for license information. + +type TableProperties struct { + ArchiveRetentionInDays *int64 `json:"archiveRetentionInDays,omitempty"` + LastPlanModifiedDate *string `json:"lastPlanModifiedDate,omitempty"` + Plan *TablePlanEnum `json:"plan,omitempty"` + ProvisioningState *ProvisioningStateEnum `json:"provisioningState,omitempty"` + RestoredLogs *RestoredLogs `json:"restoredLogs,omitempty"` + ResultStatistics *ResultStatistics `json:"resultStatistics,omitempty"` + RetentionInDays *int64 `json:"retentionInDays,omitempty"` + RetentionInDaysAsDefault *bool `json:"retentionInDaysAsDefault,omitempty"` + Schema *Schema `json:"schema,omitempty"` + SearchResults *SearchResults `json:"searchResults,omitempty"` + TotalRetentionInDays *int64 `json:"totalRetentionInDays,omitempty"` + TotalRetentionInDaysAsDefault *bool `json:"totalRetentionInDaysAsDefault,omitempty"` +} diff --git a/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/model_tableslistresult.go b/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/model_tableslistresult.go new file mode 100644 index 000000000000..06dec5265ef7 --- /dev/null +++ b/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/model_tableslistresult.go @@ -0,0 +1,8 @@ +package tables + +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. See NOTICE.txt in the project root for license information. + +type TablesListResult struct { + Value *[]Table `json:"value,omitempty"` +} diff --git a/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/version.go b/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/version.go new file mode 100644 index 000000000000..538187ee2860 --- /dev/null +++ b/vendor/github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables/version.go @@ -0,0 +1,12 @@ +package tables + +import "fmt" + +// Copyright (c) Microsoft Corporation. All rights reserved. +// Licensed under the MIT License. See NOTICE.txt in the project root for license information. + +const defaultApiVersion = "2022-10-01" + +func userAgent() string { + return fmt.Sprintf("hashicorp/go-azure-sdk/tables/%s", defaultApiVersion) +} diff --git a/vendor/modules.txt b/vendor/modules.txt index 19096045e88d..d3f8d7d27c08 100644 --- a/vendor/modules.txt +++ b/vendor/modules.txt @@ -787,6 +787,7 @@ github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2020-08-0 github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2020-08-01/savedsearches github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2020-08-01/storageinsights github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2020-08-01/workspaces +github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/tables github.com/hashicorp/go-azure-sdk/resource-manager/operationalinsights/2022-10-01/workspaces github.com/hashicorp/go-azure-sdk/resource-manager/operationsmanagement/2015-11-01-preview/solution github.com/hashicorp/go-azure-sdk/resource-manager/orbital/2022-11-01/contact diff --git a/website/docs/r/log_analytics_workspace_table.html.markdown b/website/docs/r/log_analytics_workspace_table.html.markdown new file mode 100644 index 000000000000..66ffcad50467 --- /dev/null +++ b/website/docs/r/log_analytics_workspace_table.html.markdown @@ -0,0 +1,65 @@ +--- +subcategory: "Log Analytics" +layout: "azurerm" +page_title: "Azure Resource Manager: azurerm_log_analytics_workspace_table" +description: |- + Manages a Table in a Log Analytics (formally Operational Insights) Workspace. +--- + +# azurerm_log_analytics_workspace_table + +Manages a Table in a Log Analytics (formally Operational Insights) Workspace. + +~> **Note:** This resource does not create or destroy tables. This resource is used to update attributes (currently only retention_in_days) of the tables created when a Log Analytics Workspace is created. Deleting an azurerm_log_analytics_workspace_table resource will not delete the table. Instead, the table's retention_in_days field will be set to the value of azurerm_log_analytics_workspace retention_in_days + +## Example Usage + +```hcl +resource "azurerm_resource_group" "example" { + name = "example-resources" + location = "West Europe" +} +resource "azurerm_log_analytics_workspace" "example" { + name = "example" + location = azurerm_resource_group.example.location + resource_group_name = azurerm_resource_group.example.name + sku = "PerGB2018" + retention_in_days = 30 +} +resource "azurerm_log_analytics_workspace_table" "example" { + workspace_id = azurerm_log_analytics_workspace.example.id + name = "AppMetrics" + retention_in_days = 60 +} +``` + +## Argument Reference + +The following arguments are supported: + +* `name` - (Required) Specifies the name of a table in a Log Analytics Workspace. + +* `workspace_id` - (Required) The object ID of the Log Analytics Workspace that contains the table. + +* `retention_in_days` - (Required) The table's retention in days. Possible values are either 7 (Free Tier only) or range between 30 and 730. + +-> **Note:** retention_in_days will revert back to the value of azurerm_log_analytics_workspace retention_in_days when a azurerm_log_analytics_workspace_table is deleted. + +## Attributes Reference + +The following attributes are exported: + +* `id` - The Log Analytics Workspace Table ID. + +* `workspace_id` - The Workspace (or Customer) ID for the Log Analytics Workspace. + +* `retention_in_days` - The table's data retention in days. + +## Timeouts + +The `timeouts` block allows you to specify [timeouts](https://www.terraform.io/docs/configuration/resources.html#timeouts) for certain actions: + +* `create` - (Defaults to 30 minutes) Used when creating the Log Analytics Workspace. +* `update` - (Defaults to 30 minutes) Used when updating the Log Analytics Workspace. +* `read` - (Defaults to 5 minutes) Used when retrieving the Log Analytics Workspace. +* `delete` - (Defaults to 30 minutes) Used when deleting the Log Analytics Workspace. From ab4f143d37136a8b0b6a492de0e51178cb26e279 Mon Sep 17 00:00:00 2001 From: kt Date: Mon, 18 Dec 2023 13:33:35 -0800 Subject: [PATCH 11/11] Update CHANGELOG.md #24229 --- CHANGELOG.md | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index 89606929caf2..c8d0b9da5424 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,9 @@ ## 3.86.0 (Unreleased) +FEATURES: + +* New Resource: `azurerm_log_analytics_workspace_table` [GH-24229] + ENHANCEMENTS: * dependencies: updating to `v0.20231215.1114251` of `hashicorp/go-azure-sdk` [GH-24251]