/
getAppSecCustomRules.go
159 lines (140 loc) · 5.9 KB
/
getAppSecCustomRules.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
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
// Code generated by the Pulumi Terraform Bridge (tfgen) Tool DO NOT EDIT.
// *** WARNING: Do not edit by hand unless you're certain you know what you are doing! ***
package akamai
import (
"context"
"reflect"
"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
)
// **Scopes**: Security configuration; custom rule
//
// Returns a list of the custom rules defined for a security configuration; you can also use this resource to return information for an individual custom rule. Custom rules are rules you have created yourself and are not part of the Kona Rule Set.
//
// **Related API Endpoint**:[/appsec/v1/configs/{configId}/versions/{versionNumber}/security-policies/{policyId}/custom-rules](https://techdocs.akamai.com/application-security/reference/get-custom-rules)
//
// ## Example Usage
//
// Basic usage:
//
// ```go
// package main
//
// import (
//
// "github.com/pulumi/pulumi-akamai/sdk/v3/go/akamai"
// "github.com/pulumi/pulumi/sdk/v3/go/pulumi"
//
// )
//
// func main() {
// pulumi.Run(func(ctx *pulumi.Context) error {
// configuration, err := akamai.LookupAppSecConfiguration(ctx, &GetAppSecConfigurationArgs{
// Name: pulumi.StringRef("Documentation"),
// }, nil)
// if err != nil {
// return err
// }
// customRules, err := akamai.GetAppSecCustomRules(ctx, &GetAppSecCustomRulesArgs{
// ConfigId: configuration.ConfigId,
// }, nil)
// if err != nil {
// return err
// }
// ctx.Export("customRulesOutputText", customRules.OutputText)
// ctx.Export("customRulesJson", customRules.Json)
// ctx.Export("customRulesConfigId", customRules.ConfigId)
// specificCustomRule, err := akamai.GetAppSecCustomRules(ctx, &GetAppSecCustomRulesArgs{
// ConfigId: configuration.ConfigId,
// CustomRuleId: pulumi.IntRef(60029316),
// }, nil)
// if err != nil {
// return err
// }
// ctx.Export("specificCustomRuleJson", specificCustomRule.Json)
// return nil
// })
// }
//
// ```
// ## Output Options
//
// The following options can be used to determine the information returned, and how that returned information is formatted:
//
// - `outputText`. Tabular report showing the ID and name of the custom rule information.
// - `json`. JSON-formatted report of the custom rule information.
func GetAppSecCustomRules(ctx *pulumi.Context, args *GetAppSecCustomRulesArgs, opts ...pulumi.InvokeOption) (*GetAppSecCustomRulesResult, error) {
var rv GetAppSecCustomRulesResult
err := ctx.Invoke("akamai:index/getAppSecCustomRules:getAppSecCustomRules", args, &rv, opts...)
if err != nil {
return nil, err
}
return &rv, nil
}
// A collection of arguments for invoking getAppSecCustomRules.
type GetAppSecCustomRulesArgs struct {
// . Unique identifier of the security configuration associated with the custom rules.
ConfigId int `pulumi:"configId"`
// . Unique identifier of the custom rule you want to return information for. If not included, information is returned for all your custom rules.
CustomRuleId *int `pulumi:"customRuleId"`
}
// A collection of values returned by getAppSecCustomRules.
type GetAppSecCustomRulesResult struct {
ConfigId int `pulumi:"configId"`
CustomRuleId *int `pulumi:"customRuleId"`
// The provider-assigned unique ID for this managed resource.
Id string `pulumi:"id"`
Json string `pulumi:"json"`
OutputText string `pulumi:"outputText"`
}
func GetAppSecCustomRulesOutput(ctx *pulumi.Context, args GetAppSecCustomRulesOutputArgs, opts ...pulumi.InvokeOption) GetAppSecCustomRulesResultOutput {
return pulumi.ToOutputWithContext(context.Background(), args).
ApplyT(func(v interface{}) (GetAppSecCustomRulesResult, error) {
args := v.(GetAppSecCustomRulesArgs)
r, err := GetAppSecCustomRules(ctx, &args, opts...)
var s GetAppSecCustomRulesResult
if r != nil {
s = *r
}
return s, err
}).(GetAppSecCustomRulesResultOutput)
}
// A collection of arguments for invoking getAppSecCustomRules.
type GetAppSecCustomRulesOutputArgs struct {
// . Unique identifier of the security configuration associated with the custom rules.
ConfigId pulumi.IntInput `pulumi:"configId"`
// . Unique identifier of the custom rule you want to return information for. If not included, information is returned for all your custom rules.
CustomRuleId pulumi.IntPtrInput `pulumi:"customRuleId"`
}
func (GetAppSecCustomRulesOutputArgs) ElementType() reflect.Type {
return reflect.TypeOf((*GetAppSecCustomRulesArgs)(nil)).Elem()
}
// A collection of values returned by getAppSecCustomRules.
type GetAppSecCustomRulesResultOutput struct{ *pulumi.OutputState }
func (GetAppSecCustomRulesResultOutput) ElementType() reflect.Type {
return reflect.TypeOf((*GetAppSecCustomRulesResult)(nil)).Elem()
}
func (o GetAppSecCustomRulesResultOutput) ToGetAppSecCustomRulesResultOutput() GetAppSecCustomRulesResultOutput {
return o
}
func (o GetAppSecCustomRulesResultOutput) ToGetAppSecCustomRulesResultOutputWithContext(ctx context.Context) GetAppSecCustomRulesResultOutput {
return o
}
func (o GetAppSecCustomRulesResultOutput) ConfigId() pulumi.IntOutput {
return o.ApplyT(func(v GetAppSecCustomRulesResult) int { return v.ConfigId }).(pulumi.IntOutput)
}
func (o GetAppSecCustomRulesResultOutput) CustomRuleId() pulumi.IntPtrOutput {
return o.ApplyT(func(v GetAppSecCustomRulesResult) *int { return v.CustomRuleId }).(pulumi.IntPtrOutput)
}
// The provider-assigned unique ID for this managed resource.
func (o GetAppSecCustomRulesResultOutput) Id() pulumi.StringOutput {
return o.ApplyT(func(v GetAppSecCustomRulesResult) string { return v.Id }).(pulumi.StringOutput)
}
func (o GetAppSecCustomRulesResultOutput) Json() pulumi.StringOutput {
return o.ApplyT(func(v GetAppSecCustomRulesResult) string { return v.Json }).(pulumi.StringOutput)
}
func (o GetAppSecCustomRulesResultOutput) OutputText() pulumi.StringOutput {
return o.ApplyT(func(v GetAppSecCustomRulesResult) string { return v.OutputText }).(pulumi.StringOutput)
}
func init() {
pulumi.RegisterOutputType(GetAppSecCustomRulesResultOutput{})
}