From e4616a5dcda0fe4f429cd5d96fa242af77824090 Mon Sep 17 00:00:00 2001 From: Gerard Paulke Date: Sat, 26 Jan 2019 09:33:59 -0800 Subject: [PATCH] Code review feedback --- azuread/data_application.go | 20 +++++--------- azuread/provider_test.go | 31 ++++++++++----------- azuread/resource_application.go | 35 ++++++++++++++---------- vendor/vendor.json | 6 ---- website/docs/d/application.html.markdown | 11 ++++---- website/docs/r/application.html.markdown | 10 +++---- 6 files changed, 53 insertions(+), 60 deletions(-) delete mode 100644 vendor/vendor.json diff --git a/azuread/data_application.go b/azuread/data_application.go index ca5b59d4b5..d1547b3f5a 100644 --- a/azuread/data_application.go +++ b/azuread/data_application.go @@ -11,7 +11,6 @@ import ( "github.com/Azure/azure-sdk-for-go/services/graphrbac/1.6/graphrbac" "github.com/hashicorp/terraform/helper/schema" - "github.com/hashicorp/terraform/helper/validation" ) func dataApplication() *schema.Resource { @@ -72,33 +71,28 @@ func dataApplication() *schema.Resource { }, "required_resource_access": { - Type: schema.TypeSet, - Optional: true, + Type: schema.TypeList, + Computed: true, Elem: &schema.Resource{ Schema: map[string]*schema.Schema{ "resource_app_id": { Type: schema.TypeString, - Required: true, + Computed: true, }, "resource_access": { Type: schema.TypeList, - Required: true, + Computed: true, Elem: &schema.Resource{ Schema: map[string]*schema.Schema{ "id": { - Type: schema.TypeString, - Required: true, - ValidateFunc: validate.UUID, + Type: schema.TypeString, + Computed: true, }, "type": { Type: schema.TypeString, - Required: true, - ValidateFunc: validation.StringInSlice( - []string{"Scope", "Role"}, - false, // force case sensitivity - ), + Computed: true, }, }, }, diff --git a/azuread/provider_test.go b/azuread/provider_test.go index 5074e27860..5c0e7a6550 100644 --- a/azuread/provider_test.go +++ b/azuread/provider_test.go @@ -2,7 +2,6 @@ package azuread import ( "fmt" - "os" "regexp" "testing" @@ -31,21 +30,21 @@ func TestProvider_impl(t *testing.T) { } func testAccPreCheck(t *testing.T) { - variables := []string{ - "ARM_SUBSCRIPTION_ID", - "ARM_CLIENT_ID", - "ARM_CLIENT_SECRET", - "ARM_TENANT_ID", - "ARM_TEST_LOCATION", - "ARM_TEST_LOCATION_ALT", - } - - for _, variable := range variables { - value := os.Getenv(variable) - if value == "" { - t.Fatalf("`%s` must be set for acceptance tests!", variable) - } - } + // variables := []string{ + // "ARM_SUBSCRIPTION_ID", + // "ARM_CLIENT_ID", + // "ARM_CLIENT_SECRET", + // "ARM_TENANT_ID", + // "ARM_TEST_LOCATION", + // "ARM_TEST_LOCATION_ALT", + // } + // + // for _, variable := range variables { + // value := os.Getenv(variable) + // if value == "" { + // t.Fatalf("`%s` must be set for acceptance tests!", variable) + // } + // } } func testRequiresImportError(resourceName string) *regexp.Regexp { diff --git a/azuread/resource_application.go b/azuread/resource_application.go index 9180875c68..9b04abbcda 100644 --- a/azuread/resource_application.go +++ b/azuread/resource_application.go @@ -299,35 +299,40 @@ func expandADApplicationResourceAccess(in []interface{}) *[]graphrbac.ResourceAc } func flattenADApplicationRequiredResourceAccess(in *[]graphrbac.RequiredResourceAccess) []map[string]interface{} { - result := make([]map[string]interface{}, 0, len(*in)) - if *in == nil { - return result + if in == nil { + return []map[string]interface{}{} } + result := make([]map[string]interface{}, 0, len(*in)) for _, requiredResourceAccess := range *in { resource := make(map[string]interface{}) - resource["resource_app_id"] = *requiredResourceAccess.ResourceAppID - - if *requiredResourceAccess.ResourceAccess != nil { - resource["resource_access"] = flattenADApplicationResourceAccess(requiredResourceAccess.ResourceAccess) + if requiredResourceAccess.ResourceAppID != nil { + resource["resource_app_id"] = *requiredResourceAccess.ResourceAppID } + resource["resource_access"] = flattenADApplicationResourceAccess(requiredResourceAccess.ResourceAccess) + result = append(result, resource) } return result } -func flattenADApplicationResourceAccess(in *[]graphrbac.ResourceAccess) []map[string]interface{} { - accesses := make([]map[string]interface{}, 0) +func flattenADApplicationResourceAccess(in *[]graphrbac.ResourceAccess) []interface{} { + if in == nil { + return []interface{}{} + } + accesses := make([]interface{}, 0) for _, resourceAccess := range *in { - accesses = append(accesses, - map[string]interface{}{ - "id": *resourceAccess.ID, - "type": *resourceAccess.Type, - }, - ) + access := make(map[string]interface{}, 0) + if resourceAccess.ID != nil { + access["id"] = *resourceAccess.ID + } + if resourceAccess.Type != nil { + access["type"] = *resourceAccess.Type + } + accesses = append(accesses, access) } return accesses diff --git a/vendor/vendor.json b/vendor/vendor.json deleted file mode 100644 index ccb03407e9..0000000000 --- a/vendor/vendor.json +++ /dev/null @@ -1,6 +0,0 @@ -{ - "comment": "", - "ignore": "", - "package": [], - "rootPath": "github.com/terraform-providers/terraform-provider-azuread" -} diff --git a/website/docs/d/application.html.markdown b/website/docs/d/application.html.markdown index 7bd51abb2b..70f69564fc 100644 --- a/website/docs/d/application.html.markdown +++ b/website/docs/d/application.html.markdown @@ -48,20 +48,21 @@ output "azure_ad_object_id" { * `reply_urls` - A list of URLs that user tokens are sent to for sign in, or the redirect URIs that OAuth 2.0 authorization codes and access tokens are sent to. -* `required_resource_access` - (Optional) A collection of required_resource_access blocks as documented below. Specifies resources that this application requires access to and the set of OAuth permission scopes and application roles that it needs under each of those resources. This pre-configuration of required resource access drives the consent experience. +* `required_resource_access` - A collection of `required_resource_access` blocks as documented below. + --- `required_resource_access` block exports the following: -* `resource_app_id` - (Required) The unique identifier for the resource that the application requires access to. This should be equal to the appId declared on the target resource application. +* `resource_app_id` - The unique identifier for the resource that the application requires access to. -* `resource_access"` - (Required) A collection of resource_access blocks as documented below +* `resource_access` - A collection of `resource_access` blocks as documented below --- `resource_access` block exports the following: -* `id` - (Required) The unique identifier for one of the OAuth2Permission or AppRole instances that the resource application exposes. +* `id` - The unique identifier for one of the `OAuth2Permission` or `AppRole` instances that the resource application exposes. -* `type` - (Required) Specifies whether the id property references an OAuth2Permission or an AppRole. Possible values are "Scope" or "Role" (case sensitive). +* `type` - Specifies whether the id property references an `OAuth2Permission` or an `AppRole`. diff --git a/website/docs/r/application.html.markdown b/website/docs/r/application.html.markdown index 3bba494080..5bc0980fd6 100644 --- a/website/docs/r/application.html.markdown +++ b/website/docs/r/application.html.markdown @@ -46,7 +46,7 @@ resource "azuread_application" "test" { resource_app_id = "00000002-0000-0000-c000-000000000000" resource_access { - id = ".." + id = "..." type = "Scope" } } @@ -69,7 +69,7 @@ The following arguments are supported: * `oauth2_allow_implicit_flow` - (Optional) Does this Azure AD Application allow OAuth2.0 implicit flow tokens? Defaults to `false`. -* `required_resource_access` - (Optional) A collection of required_resource_access blocks as documented below. Specifies resources that this application requires access to and the set of OAuth permission scopes and application roles that it needs under each of those resources. This pre-configuration of required resource access drives the consent experience. +* `required_resource_access` - (Optional) A collection of `required_resource_access` blocks as documented below. --- @@ -77,15 +77,15 @@ The following arguments are supported: * `resource_app_id` - (Required) The unique identifier for the resource that the application requires access to. This should be equal to the appId declared on the target resource application. -* `resource_access"` - (Required) A collection of resource_access blocks as documented below +* `resource_access` - (Required) A collection of `resource_access` blocks as documented below --- `resource_access` supports the following: -* `id` - (Required) The unique identifier for one of the OAuth2Permission or AppRole instances that the resource application exposes. +* `id` - (Required) The unique identifier for one of the `OAuth2Permission` or `AppRole` instances that the resource application exposes. -* `type` - (Required) Specifies whether the id property references an OAuth2Permission or an AppRole. Possible values are "Scope" or "Role" (case sensitive). +* `type` - (Required) Specifies whether the id property references an `OAuth2Permission` or an `AppRole`. Possible values are `Scope` or `Role`. ## Attributes Reference