-
Notifications
You must be signed in to change notification settings - Fork 38
/
id_accesspolicy.go
140 lines (114 loc) · 5.21 KB
/
id_accesspolicy.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
package accesspolicies
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 = AccessPolicyId{}
// AccessPolicyId is a struct representing the Resource ID for a Access Policy
type AccessPolicyId struct {
SubscriptionId string
ResourceGroupName string
EnvironmentName string
AccessPolicyName string
}
// NewAccessPolicyID returns a new AccessPolicyId struct
func NewAccessPolicyID(subscriptionId string, resourceGroupName string, environmentName string, accessPolicyName string) AccessPolicyId {
return AccessPolicyId{
SubscriptionId: subscriptionId,
ResourceGroupName: resourceGroupName,
EnvironmentName: environmentName,
AccessPolicyName: accessPolicyName,
}
}
// ParseAccessPolicyID parses 'input' into a AccessPolicyId
func ParseAccessPolicyID(input string) (*AccessPolicyId, error) {
parser := resourceids.NewParserFromResourceIdType(AccessPolicyId{})
parsed, err := parser.Parse(input, false)
if err != nil {
return nil, fmt.Errorf("parsing %q: %+v", input, err)
}
var ok bool
id := AccessPolicyId{}
if id.SubscriptionId, ok = parsed.Parsed["subscriptionId"]; !ok {
return nil, resourceids.NewSegmentNotSpecifiedError(id, "subscriptionId", *parsed)
}
if id.ResourceGroupName, ok = parsed.Parsed["resourceGroupName"]; !ok {
return nil, resourceids.NewSegmentNotSpecifiedError(id, "resourceGroupName", *parsed)
}
if id.EnvironmentName, ok = parsed.Parsed["environmentName"]; !ok {
return nil, resourceids.NewSegmentNotSpecifiedError(id, "environmentName", *parsed)
}
if id.AccessPolicyName, ok = parsed.Parsed["accessPolicyName"]; !ok {
return nil, resourceids.NewSegmentNotSpecifiedError(id, "accessPolicyName", *parsed)
}
return &id, nil
}
// ParseAccessPolicyIDInsensitively parses 'input' case-insensitively into a AccessPolicyId
// note: this method should only be used for API response data and not user input
func ParseAccessPolicyIDInsensitively(input string) (*AccessPolicyId, error) {
parser := resourceids.NewParserFromResourceIdType(AccessPolicyId{})
parsed, err := parser.Parse(input, true)
if err != nil {
return nil, fmt.Errorf("parsing %q: %+v", input, err)
}
var ok bool
id := AccessPolicyId{}
if id.SubscriptionId, ok = parsed.Parsed["subscriptionId"]; !ok {
return nil, resourceids.NewSegmentNotSpecifiedError(id, "subscriptionId", *parsed)
}
if id.ResourceGroupName, ok = parsed.Parsed["resourceGroupName"]; !ok {
return nil, resourceids.NewSegmentNotSpecifiedError(id, "resourceGroupName", *parsed)
}
if id.EnvironmentName, ok = parsed.Parsed["environmentName"]; !ok {
return nil, resourceids.NewSegmentNotSpecifiedError(id, "environmentName", *parsed)
}
if id.AccessPolicyName, ok = parsed.Parsed["accessPolicyName"]; !ok {
return nil, resourceids.NewSegmentNotSpecifiedError(id, "accessPolicyName", *parsed)
}
return &id, nil
}
// ValidateAccessPolicyID checks that 'input' can be parsed as a Access Policy ID
func ValidateAccessPolicyID(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 := ParseAccessPolicyID(v); err != nil {
errors = append(errors, err)
}
return
}
// ID returns the formatted Access Policy ID
func (id AccessPolicyId) ID() string {
fmtString := "/subscriptions/%s/resourceGroups/%s/providers/Microsoft.TimeSeriesInsights/environments/%s/accessPolicies/%s"
return fmt.Sprintf(fmtString, id.SubscriptionId, id.ResourceGroupName, id.EnvironmentName, id.AccessPolicyName)
}
// Segments returns a slice of Resource ID Segments which comprise this Access Policy ID
func (id AccessPolicyId) 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("staticMicrosoftTimeSeriesInsights", "Microsoft.TimeSeriesInsights", "Microsoft.TimeSeriesInsights"),
resourceids.StaticSegment("staticEnvironments", "environments", "environments"),
resourceids.UserSpecifiedSegment("environmentName", "environmentValue"),
resourceids.StaticSegment("staticAccessPolicies", "accessPolicies", "accessPolicies"),
resourceids.UserSpecifiedSegment("accessPolicyName", "accessPolicyValue"),
}
}
// String returns a human-readable description of this Access Policy ID
func (id AccessPolicyId) String() string {
components := []string{
fmt.Sprintf("Subscription: %q", id.SubscriptionId),
fmt.Sprintf("Resource Group Name: %q", id.ResourceGroupName),
fmt.Sprintf("Environment Name: %q", id.EnvironmentName),
fmt.Sprintf("Access Policy Name: %q", id.AccessPolicyName),
}
return fmt.Sprintf("Access Policy (%s)", strings.Join(components, "\n"))
}