-
Notifications
You must be signed in to change notification settings - Fork 4.6k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
new resource - azurerm_eventhub_namespace_authorization_rule (#1572)
* added new resource resource_arm_servicebus_queue_authorization_rule * updates & add docs * Update service bus topic auth rule tests * new resource - azurerm_eventhub_namespace_authorizzation_rule * Documentation fixes * Switching to use the Namespaces client * Consistency * Fixing a test failure
- Loading branch information
1 parent
710756e
commit 297b365
Showing
18 changed files
with
786 additions
and
424 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,145 @@ | ||
package azure | ||
|
||
import ( | ||
"fmt" | ||
"log" | ||
"regexp" | ||
|
||
"github.com/hashicorp/terraform/helper/schema" | ||
"github.com/hashicorp/terraform/helper/validation" | ||
|
||
"github.com/Azure/azure-sdk-for-go/services/eventhub/mgmt/2017-04-01/eventhub" | ||
) | ||
|
||
//validation | ||
func ValidateEventHubNamespaceName() schema.SchemaValidateFunc { | ||
return validation.StringMatch( | ||
regexp.MustCompile("^[a-zA-Z][-a-zA-Z0-9]{4,48}[a-zA-Z0-9]$"), | ||
"The namespace name can contain only letters, numbers, and hyphens. The namespace must start with a letter, and it must end with a letter or number and be between 6 and 50 characters long.", | ||
) | ||
} | ||
|
||
func ValidateEventHubName() schema.SchemaValidateFunc { | ||
return validation.StringMatch( | ||
regexp.MustCompile("^[a-zA-Z][-a-zA-Z0-9]{4,48}[a-zA-Z0-9]$"), | ||
"The namespace name can contain only letters, numbers, and hyphens. The namespace must start with a letter, and it must end with a letter or number and be between 6 and 50 characters long.", | ||
) | ||
} | ||
|
||
func ValidateEventHubConsumerName() schema.SchemaValidateFunc { | ||
return validation.StringMatch( | ||
regexp.MustCompile("^[a-zA-Z][-a-zA-Z0-9]{4,48}[a-zA-Z0-9]$"), | ||
"The namespace name can contain only letters, numbers, and hyphens. The namespace must start with a letter, and it must end with a letter or number and be between 6 and 50 characters long.", | ||
) | ||
} | ||
|
||
func ValidateEventHubAuthorizationRuleName() schema.SchemaValidateFunc { | ||
return validation.StringMatch( | ||
regexp.MustCompile("^[a-zA-Z0-9][-._a-zA-Z0-9]{0,48}([a-zA-Z0-9])?$"), | ||
"The name can contain only letters, numbers, periods, hyphens and underscores. The name must start and end with a letter or number and be less the 50 characters long.", | ||
) | ||
} | ||
|
||
//schema | ||
func ExpandEventHubAuthorizationRuleRights(d *schema.ResourceData) *[]eventhub.AccessRights { | ||
rights := []eventhub.AccessRights{} | ||
|
||
if d.Get("listen").(bool) { | ||
rights = append(rights, eventhub.Listen) | ||
} | ||
|
||
if d.Get("send").(bool) { | ||
rights = append(rights, eventhub.Send) | ||
} | ||
|
||
if d.Get("manage").(bool) { | ||
rights = append(rights, eventhub.Manage) | ||
} | ||
|
||
return &rights | ||
} | ||
|
||
func FlattenEventHubAuthorizationRuleRights(rights *[]eventhub.AccessRights) (listen bool, send bool, manage bool) { | ||
//zero (initial) value for a bool in go is false | ||
|
||
if rights != nil { | ||
for _, right := range *rights { | ||
switch right { | ||
case eventhub.Listen: | ||
listen = true | ||
case eventhub.Send: | ||
send = true | ||
case eventhub.Manage: | ||
manage = true | ||
default: | ||
log.Printf("[DEBUG] Unknown Authorization Rule Right '%s'", right) | ||
} | ||
} | ||
} | ||
|
||
return | ||
} | ||
|
||
func EventHubAuthorizationRuleSchemaFrom(s map[string]*schema.Schema) map[string]*schema.Schema { | ||
|
||
authSchema := map[string]*schema.Schema{ | ||
"listen": { | ||
Type: schema.TypeBool, | ||
Optional: true, | ||
Default: false, | ||
}, | ||
|
||
"send": { | ||
Type: schema.TypeBool, | ||
Optional: true, | ||
Default: false, | ||
}, | ||
|
||
"manage": { | ||
Type: schema.TypeBool, | ||
Optional: true, | ||
Default: false, | ||
}, | ||
|
||
"primary_key": { | ||
Type: schema.TypeString, | ||
Computed: true, | ||
Sensitive: true, | ||
}, | ||
|
||
"primary_connection_string": { | ||
Type: schema.TypeString, | ||
Computed: true, | ||
Sensitive: true, | ||
}, | ||
|
||
"secondary_key": { | ||
Type: schema.TypeString, | ||
Computed: true, | ||
Sensitive: true, | ||
}, | ||
|
||
"secondary_connection_string": { | ||
Type: schema.TypeString, | ||
Computed: true, | ||
Sensitive: true, | ||
}, | ||
} | ||
return MergeSchema(s, authSchema) | ||
} | ||
|
||
func EventHubAuthorizationRuleCustomizeDiff(d *schema.ResourceDiff, _ interface{}) error { | ||
listen, hasListen := d.GetOk("listen") | ||
send, hasSend := d.GetOk("send") | ||
manage, hasManage := d.GetOk("manage") | ||
|
||
if !hasListen && !hasSend && !hasManage { | ||
return fmt.Errorf("One of the `listen`, `send` or `manage` properties needs to be set") | ||
} | ||
|
||
if manage.(bool) && !listen.(bool) && !send.(bool) { | ||
return fmt.Errorf("if `manage` is set both `listen` and `send` must be set to true too") | ||
} | ||
|
||
return nil | ||
} |
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.