@cdktn/provider-newrelic 14.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.jsii +198156 -0
- package/LICENSE +355 -0
- package/README.md +94 -0
- package/lib/account-management/index.d.ts +122 -0
- package/lib/account-management/index.js +293 -0
- package/lib/alert-channel/index.d.ts +351 -0
- package/lib/alert-channel/index.js +769 -0
- package/lib/alert-compound-condition/index.d.ts +233 -0
- package/lib/alert-compound-condition/index.js +506 -0
- package/lib/alert-condition/index.d.ts +271 -0
- package/lib/alert-condition/index.js +558 -0
- package/lib/alert-muting-rule/index.d.ts +309 -0
- package/lib/alert-muting-rule/index.js +714 -0
- package/lib/alert-policy/index.d.ts +91 -0
- package/lib/alert-policy/index.js +174 -0
- package/lib/alert-policy-channel/index.d.ts +114 -0
- package/lib/alert-policy-channel/index.js +258 -0
- package/lib/api-access-key/index.d.ts +102 -0
- package/lib/api-access-key/index.js +220 -0
- package/lib/application-settings/index.d.ts +414 -0
- package/lib/application-settings/index.js +944 -0
- package/lib/browser-application/index.d.ts +149 -0
- package/lib/browser-application/index.js +341 -0
- package/lib/cloud-aws-eu-sovereign-integrations/index.d.ts +199 -0
- package/lib/cloud-aws-eu-sovereign-integrations/index.js +481 -0
- package/lib/cloud-aws-eu-sovereign-link-account/index.d.ts +90 -0
- package/lib/cloud-aws-eu-sovereign-link-account/index.js +171 -0
- package/lib/cloud-aws-govcloud-integrations/index.d.ts +1523 -0
- package/lib/cloud-aws-govcloud-integrations/index.js +3776 -0
- package/lib/cloud-aws-govcloud-link-account/index.d.ts +90 -0
- package/lib/cloud-aws-govcloud-link-account/index.js +171 -0
- package/lib/cloud-aws-integrations/index.d.ts +3345 -0
- package/lib/cloud-aws-integrations/index.js +8599 -0
- package/lib/cloud-aws-link-account/index.d.ts +90 -0
- package/lib/cloud-aws-link-account/index.js +171 -0
- package/lib/cloud-azure-integrations/index.d.ts +1666 -0
- package/lib/cloud-azure-integrations/index.js +4361 -0
- package/lib/cloud-azure-link-account/index.d.ts +109 -0
- package/lib/cloud-azure-link-account/index.js +204 -0
- package/lib/cloud-gcp-integrations/index.d.ts +1049 -0
- package/lib/cloud-gcp-integrations/index.js +2810 -0
- package/lib/cloud-gcp-link-account/index.d.ts +79 -0
- package/lib/cloud-gcp-link-account/index.js +150 -0
- package/lib/cloud-oci-link-account/index.d.ts +195 -0
- package/lib/cloud-oci-link-account/index.js +366 -0
- package/lib/data-newrelic-account/index.d.ts +82 -0
- package/lib/data-newrelic-account/index.js +160 -0
- package/lib/data-newrelic-alert-channel/index.d.ts +126 -0
- package/lib/data-newrelic-alert-channel/index.js +298 -0
- package/lib/data-newrelic-alert-policy/index.d.ts +82 -0
- package/lib/data-newrelic-alert-policy/index.js +161 -0
- package/lib/data-newrelic-application/index.d.ts +60 -0
- package/lib/data-newrelic-application/index.js +122 -0
- package/lib/data-newrelic-authentication-domain/index.d.ts +47 -0
- package/lib/data-newrelic-authentication-domain/index.js +97 -0
- package/lib/data-newrelic-cloud-account/index.d.ts +79 -0
- package/lib/data-newrelic-cloud-account/index.js +150 -0
- package/lib/data-newrelic-entity/index.d.ts +189 -0
- package/lib/data-newrelic-entity/index.js +401 -0
- package/lib/data-newrelic-group/index.d.ts +58 -0
- package/lib/data-newrelic-group/index.js +116 -0
- package/lib/data-newrelic-key-transaction/index.d.ts +82 -0
- package/lib/data-newrelic-key-transaction/index.js +161 -0
- package/lib/data-newrelic-notification-destination/index.d.ts +165 -0
- package/lib/data-newrelic-notification-destination/index.js +372 -0
- package/lib/data-newrelic-obfuscation-expression/index.d.ts +69 -0
- package/lib/data-newrelic-obfuscation-expression/index.js +132 -0
- package/lib/data-newrelic-service-level-alert-helper/index.d.ts +111 -0
- package/lib/data-newrelic-service-level-alert-helper/index.js +244 -0
- package/lib/data-newrelic-synthetics-private-location/index.d.ts +80 -0
- package/lib/data-newrelic-synthetics-private-location/index.js +153 -0
- package/lib/data-newrelic-synthetics-secure-credential/index.d.ts +71 -0
- package/lib/data-newrelic-synthetics-secure-credential/index.js +140 -0
- package/lib/data-newrelic-test-grok-pattern/index.d.ts +149 -0
- package/lib/data-newrelic-test-grok-pattern/index.js +318 -0
- package/lib/data-newrelic-user/index.d.ts +69 -0
- package/lib/data-newrelic-user/index.js +136 -0
- package/lib/data-partition-rule/index.d.ts +146 -0
- package/lib/data-partition-rule/index.js +319 -0
- package/lib/entity-tags/index.d.ts +156 -0
- package/lib/entity-tags/index.js +368 -0
- package/lib/events-to-metrics-rule/index.d.ts +102 -0
- package/lib/events-to-metrics-rule/index.js +196 -0
- package/lib/group/index.d.ts +79 -0
- package/lib/group/index.js +150 -0
- package/lib/index.d.ts +74 -0
- package/lib/index.js +80 -0
- package/lib/infra-alert-condition/index.d.ts +293 -0
- package/lib/infra-alert-condition/index.js +665 -0
- package/lib/insights-event/index.d.ts +186 -0
- package/lib/insights-event/index.js +425 -0
- package/lib/key-transaction/index.d.ts +100 -0
- package/lib/key-transaction/index.js +191 -0
- package/lib/lazy-index.d.ts +4 -0
- package/lib/lazy-index.js +77 -0
- package/lib/log-parsing-rule/index.d.ts +132 -0
- package/lib/log-parsing-rule/index.js +250 -0
- package/lib/monitor-downtime/index.d.ts +259 -0
- package/lib/monitor-downtime/index.js +594 -0
- package/lib/notification-channel/index.d.ts +240 -0
- package/lib/notification-channel/index.js +546 -0
- package/lib/notification-destination/index.d.ts +406 -0
- package/lib/notification-destination/index.js +1030 -0
- package/lib/nrql-alert-condition/index.d.ts +976 -0
- package/lib/nrql-alert-condition/index.js +2320 -0
- package/lib/nrql-drop-rule/index.d.ts +127 -0
- package/lib/nrql-drop-rule/index.js +287 -0
- package/lib/obfuscation-expression/index.d.ts +90 -0
- package/lib/obfuscation-expression/index.js +171 -0
- package/lib/obfuscation-rule/index.d.ts +173 -0
- package/lib/obfuscation-rule/index.js +361 -0
- package/lib/one-dashboard/index-structs/index.d.ts +6 -0
- package/lib/one-dashboard/index-structs/index.js +23 -0
- package/lib/one-dashboard/index-structs/structs0.d.ts +7000 -0
- package/lib/one-dashboard/index-structs/structs0.js +17966 -0
- package/lib/one-dashboard/index-structs/structs400.d.ts +3703 -0
- package/lib/one-dashboard/index-structs/structs400.js +9484 -0
- package/lib/one-dashboard/index.d.ts +116 -0
- package/lib/one-dashboard/index.js +246 -0
- package/lib/one-dashboard-json/index.d.ts +116 -0
- package/lib/one-dashboard-json/index.js +278 -0
- package/lib/one-dashboard-raw/index.d.ts +278 -0
- package/lib/one-dashboard-raw/index.js +646 -0
- package/lib/pipeline-cloud-rule/index.d.ts +90 -0
- package/lib/pipeline-cloud-rule/index.js +171 -0
- package/lib/provider/index.d.ts +164 -0
- package/lib/provider/index.js +354 -0
- package/lib/service-level/index.d.ts +505 -0
- package/lib/service-level/index.js +1429 -0
- package/lib/synthetics-alert-condition/index.d.ts +101 -0
- package/lib/synthetics-alert-condition/index.js +193 -0
- package/lib/synthetics-broken-links-monitor/index.d.ts +221 -0
- package/lib/synthetics-broken-links-monitor/index.js +455 -0
- package/lib/synthetics-cert-check-monitor/index.d.ts +226 -0
- package/lib/synthetics-cert-check-monitor/index.js +469 -0
- package/lib/synthetics-monitor/index.d.ts +408 -0
- package/lib/synthetics-monitor/index.js +843 -0
- package/lib/synthetics-multilocation-alert-condition/index.d.ts +181 -0
- package/lib/synthetics-multilocation-alert-condition/index.js +403 -0
- package/lib/synthetics-private-location/index.d.ts +94 -0
- package/lib/synthetics-private-location/index.js +187 -0
- package/lib/synthetics-script-monitor/index.d.ts +352 -0
- package/lib/synthetics-script-monitor/index.js +736 -0
- package/lib/synthetics-secure-credential/index.d.ts +136 -0
- package/lib/synthetics-secure-credential/index.js +300 -0
- package/lib/synthetics-step-monitor/index.d.ts +372 -0
- package/lib/synthetics-step-monitor/index.js +809 -0
- package/lib/user/index.d.ts +89 -0
- package/lib/user/index.js +168 -0
- package/lib/workflow/index.d.ts +445 -0
- package/lib/workflow/index.js +1058 -0
- package/lib/workload/index.d.ts +518 -0
- package/lib/workload/index.js +1279 -0
- package/package.json +155 -0
|
@@ -0,0 +1,171 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var _a;
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
exports.ObfuscationExpression = void 0;
|
|
5
|
+
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
6
|
+
const cdktn = require("cdktn");
|
|
7
|
+
/**
|
|
8
|
+
* Represents a {@link https://registry.terraform.io/providers/newrelic/newrelic/3.80.2/docs/resources/obfuscation_expression newrelic_obfuscation_expression}
|
|
9
|
+
*/
|
|
10
|
+
class ObfuscationExpression extends cdktn.TerraformResource {
|
|
11
|
+
// ==============
|
|
12
|
+
// STATIC Methods
|
|
13
|
+
// ==============
|
|
14
|
+
/**
|
|
15
|
+
* Generates CDKTN code for importing a ObfuscationExpression resource upon running "cdktn plan <stack-name>"
|
|
16
|
+
* @param scope The scope in which to define this construct
|
|
17
|
+
* @param importToId The construct id used in the generated config for the ObfuscationExpression to import
|
|
18
|
+
* @param importFromId The id of the existing ObfuscationExpression that should be imported. Refer to the {@link https://registry.terraform.io/providers/newrelic/newrelic/3.80.2/docs/resources/obfuscation_expression#import import section} in the documentation of this resource for the id to use
|
|
19
|
+
* @param provider? Optional instance of the provider where the ObfuscationExpression to import is found
|
|
20
|
+
*/
|
|
21
|
+
static generateConfigForImport(scope, importToId, importFromId, provider) {
|
|
22
|
+
return new cdktn.ImportableResource(scope, importToId, { terraformResourceType: "newrelic_obfuscation_expression", importId: importFromId, provider });
|
|
23
|
+
}
|
|
24
|
+
// ===========
|
|
25
|
+
// INITIALIZER
|
|
26
|
+
// ===========
|
|
27
|
+
/**
|
|
28
|
+
* Create a new {@link https://registry.terraform.io/providers/newrelic/newrelic/3.80.2/docs/resources/obfuscation_expression newrelic_obfuscation_expression} Resource
|
|
29
|
+
*
|
|
30
|
+
* @param scope The scope in which to define this construct
|
|
31
|
+
* @param id The scoped construct ID. Must be unique amongst siblings in the same scope
|
|
32
|
+
* @param options ObfuscationExpressionConfig
|
|
33
|
+
*/
|
|
34
|
+
constructor(scope, id, config) {
|
|
35
|
+
super(scope, id, {
|
|
36
|
+
terraformResourceType: 'newrelic_obfuscation_expression',
|
|
37
|
+
terraformGeneratorMetadata: {
|
|
38
|
+
providerName: 'newrelic',
|
|
39
|
+
providerVersion: '3.80.2',
|
|
40
|
+
providerVersionConstraint: '~> 3.7'
|
|
41
|
+
},
|
|
42
|
+
provider: config.provider,
|
|
43
|
+
dependsOn: config.dependsOn,
|
|
44
|
+
count: config.count,
|
|
45
|
+
lifecycle: config.lifecycle,
|
|
46
|
+
provisioners: config.provisioners,
|
|
47
|
+
connection: config.connection,
|
|
48
|
+
forEach: config.forEach
|
|
49
|
+
});
|
|
50
|
+
this._accountId = config.accountId;
|
|
51
|
+
this._description = config.description;
|
|
52
|
+
this._id = config.id;
|
|
53
|
+
this._name = config.name;
|
|
54
|
+
this._regex = config.regex;
|
|
55
|
+
}
|
|
56
|
+
get accountId() {
|
|
57
|
+
return this.getNumberAttribute('account_id');
|
|
58
|
+
}
|
|
59
|
+
set accountId(value) {
|
|
60
|
+
this._accountId = value;
|
|
61
|
+
}
|
|
62
|
+
resetAccountId() {
|
|
63
|
+
this._accountId = undefined;
|
|
64
|
+
}
|
|
65
|
+
// Temporarily expose input value. Use with caution.
|
|
66
|
+
get accountIdInput() {
|
|
67
|
+
return this._accountId;
|
|
68
|
+
}
|
|
69
|
+
get description() {
|
|
70
|
+
return this.getStringAttribute('description');
|
|
71
|
+
}
|
|
72
|
+
set description(value) {
|
|
73
|
+
this._description = value;
|
|
74
|
+
}
|
|
75
|
+
resetDescription() {
|
|
76
|
+
this._description = undefined;
|
|
77
|
+
}
|
|
78
|
+
// Temporarily expose input value. Use with caution.
|
|
79
|
+
get descriptionInput() {
|
|
80
|
+
return this._description;
|
|
81
|
+
}
|
|
82
|
+
get id() {
|
|
83
|
+
return this.getStringAttribute('id');
|
|
84
|
+
}
|
|
85
|
+
set id(value) {
|
|
86
|
+
this._id = value;
|
|
87
|
+
}
|
|
88
|
+
resetId() {
|
|
89
|
+
this._id = undefined;
|
|
90
|
+
}
|
|
91
|
+
// Temporarily expose input value. Use with caution.
|
|
92
|
+
get idInput() {
|
|
93
|
+
return this._id;
|
|
94
|
+
}
|
|
95
|
+
get name() {
|
|
96
|
+
return this.getStringAttribute('name');
|
|
97
|
+
}
|
|
98
|
+
set name(value) {
|
|
99
|
+
this._name = value;
|
|
100
|
+
}
|
|
101
|
+
// Temporarily expose input value. Use with caution.
|
|
102
|
+
get nameInput() {
|
|
103
|
+
return this._name;
|
|
104
|
+
}
|
|
105
|
+
get regex() {
|
|
106
|
+
return this.getStringAttribute('regex');
|
|
107
|
+
}
|
|
108
|
+
set regex(value) {
|
|
109
|
+
this._regex = value;
|
|
110
|
+
}
|
|
111
|
+
// Temporarily expose input value. Use with caution.
|
|
112
|
+
get regexInput() {
|
|
113
|
+
return this._regex;
|
|
114
|
+
}
|
|
115
|
+
// =========
|
|
116
|
+
// SYNTHESIS
|
|
117
|
+
// =========
|
|
118
|
+
synthesizeAttributes() {
|
|
119
|
+
return {
|
|
120
|
+
account_id: cdktn.numberToTerraform(this._accountId),
|
|
121
|
+
description: cdktn.stringToTerraform(this._description),
|
|
122
|
+
id: cdktn.stringToTerraform(this._id),
|
|
123
|
+
name: cdktn.stringToTerraform(this._name),
|
|
124
|
+
regex: cdktn.stringToTerraform(this._regex),
|
|
125
|
+
};
|
|
126
|
+
}
|
|
127
|
+
synthesizeHclAttributes() {
|
|
128
|
+
const attrs = {
|
|
129
|
+
account_id: {
|
|
130
|
+
value: cdktn.numberToHclTerraform(this._accountId),
|
|
131
|
+
isBlock: false,
|
|
132
|
+
type: "simple",
|
|
133
|
+
storageClassType: "number",
|
|
134
|
+
},
|
|
135
|
+
description: {
|
|
136
|
+
value: cdktn.stringToHclTerraform(this._description),
|
|
137
|
+
isBlock: false,
|
|
138
|
+
type: "simple",
|
|
139
|
+
storageClassType: "string",
|
|
140
|
+
},
|
|
141
|
+
id: {
|
|
142
|
+
value: cdktn.stringToHclTerraform(this._id),
|
|
143
|
+
isBlock: false,
|
|
144
|
+
type: "simple",
|
|
145
|
+
storageClassType: "string",
|
|
146
|
+
},
|
|
147
|
+
name: {
|
|
148
|
+
value: cdktn.stringToHclTerraform(this._name),
|
|
149
|
+
isBlock: false,
|
|
150
|
+
type: "simple",
|
|
151
|
+
storageClassType: "string",
|
|
152
|
+
},
|
|
153
|
+
regex: {
|
|
154
|
+
value: cdktn.stringToHclTerraform(this._regex),
|
|
155
|
+
isBlock: false,
|
|
156
|
+
type: "simple",
|
|
157
|
+
storageClassType: "string",
|
|
158
|
+
},
|
|
159
|
+
};
|
|
160
|
+
// remove undefined attributes
|
|
161
|
+
return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined));
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
exports.ObfuscationExpression = ObfuscationExpression;
|
|
165
|
+
_a = JSII_RTTI_SYMBOL_1;
|
|
166
|
+
ObfuscationExpression[_a] = { fqn: "@cdktn/provider-newrelic.obfuscationExpression.ObfuscationExpression", version: "14.0.0" };
|
|
167
|
+
// =================
|
|
168
|
+
// STATIC PROPERTIES
|
|
169
|
+
// =================
|
|
170
|
+
ObfuscationExpression.tfResourceType = "newrelic_obfuscation_expression";
|
|
171
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvb2JmdXNjYXRpb24tZXhwcmVzc2lvbi9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQVNBLCtCQUErQjtBQXNDL0I7O0VBRUU7QUFDRixNQUFhLHFCQUFzQixTQUFRLEtBQUssQ0FBQyxpQkFBaUI7SUFPaEUsaUJBQWlCO0lBQ2pCLGlCQUFpQjtJQUNqQixpQkFBaUI7SUFDakI7Ozs7OztNQU1FO0lBQ0ssTUFBTSxDQUFDLHVCQUF1QixDQUFDLEtBQWdCLEVBQUUsVUFBa0IsRUFBRSxZQUFvQixFQUFFLFFBQWtDO1FBQzlILE9BQU8sSUFBSSxLQUFLLENBQUMsa0JBQWtCLENBQUMsS0FBSyxFQUFFLFVBQVUsRUFBRSxFQUFFLHFCQUFxQixFQUFFLGlDQUFpQyxFQUFFLFFBQVEsRUFBRSxZQUFZLEVBQUUsUUFBUSxFQUFFLENBQUMsQ0FBQztJQUN6SixDQUFDO0lBRUwsY0FBYztJQUNkLGNBQWM7SUFDZCxjQUFjO0lBRWQ7Ozs7OztNQU1FO0lBQ0YsWUFBbUIsS0FBZ0IsRUFBRSxFQUFVLEVBQUUsTUFBbUM7UUFDbEYsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLEVBQUU7WUFDZixxQkFBcUIsRUFBRSxpQ0FBaUM7WUFDeEQsMEJBQTBCLEVBQUU7Z0JBQzFCLFlBQVksRUFBRSxVQUFVO2dCQUN4QixlQUFlLEVBQUUsUUFBUTtnQkFDekIseUJBQXlCLEVBQUUsUUFBUTthQUNwQztZQUNELFFBQVEsRUFBRSxNQUFNLENBQUMsUUFBUTtZQUN6QixTQUFTLEVBQUUsTUFBTSxDQUFDLFNBQVM7WUFDM0IsS0FBSyxFQUFFLE1BQU0sQ0FBQyxLQUFLO1lBQ25CLFNBQVMsRUFBRSxNQUFNLENBQUMsU0FBUztZQUMzQixZQUFZLEVBQUUsTUFBTSxDQUFDLFlBQVk7WUFDakMsVUFBVSxFQUFFLE1BQU0sQ0FBQyxVQUFVO1lBQzdCLE9BQU8sRUFBRSxNQUFNLENBQUMs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LENBQUMsS0FBSyxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsS0FBSyxDQUFDLEVBQUUsRUFBRSxDQUFDLEtBQUssS0FBSyxTQUFTLElBQUksS0FBSyxDQUFDLEtBQUssS0FBSyxTQUFTLENBQUUsQ0FBQyxDQUFBO0lBQzVILENBQUM7O0FBdkxILHNEQXdMQzs7O0FBdExDLG9CQUFvQjtBQUNwQixvQkFBb0I7QUFDcEIsb0JBQW9CO0FBQ0csb0NBQWMsR0FBRyxpQ0FBaUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IElCTSBDb3JwLiAyMDIxLCAyMDI2XG4gKiBTUERYLUxpY2Vuc2UtSWRlbnRpZmllcjogTVBMLTIuMFxuICovXG5cbi8vIGh0dHBzOi8vcmVnaXN0cnkudGVycmFmb3JtLmlvL3Byb3ZpZGVycy9uZXdyZWxpYy9uZXdyZWxpYy8zLjgwLjIvZG9jcy9yZXNvdXJjZXMvb2JmdXNjYXRpb25fZXhwcmVzc2lvblxuLy8gZ2VuZXJhdGVkIGZyb20gdGVycmFmb3JtIHJlc291cmNlIHNjaGVtYVxuXG5pbXBvcnQgeyBDb25zdHJ1Y3QgfSBmcm9tICdjb25zdHJ1Y3RzJztcbmltcG9ydCAqIGFzIGNka3RuIGZyb20gJ2Nka3RuJztcblxuLy8gQ29uZmlndXJhdGlvblxuXG5leHBvcnQgaW50ZXJmYWNlIE9iZnVzY2F0aW9uRXhwcmVzc2lvbkNvbmZpZyBleHRlbmRzIGNka3RuLlRlcnJhZm9ybU1ldGFBcmd1bWVudHMge1xuICAvKipcbiAgKiBUaGUgYWNjb3VudCBpZCBhc3NvY2lhdGVkIHdpdGggdGhlIG9iZnVzY2F0aW9uIGV4cHJlc3Npb24uXG4gICpcbiAgKiBEb2NzIGF0IFRlcnJhZm9ybSBSZWdpc3RyeToge0BsaW5rIGh0dHBzOi8vcmVnaXN0cnkudGVycmFmb3JtLmlvL3Byb3ZpZGVycy9uZXdyZWxpYy9uZXdyZWxpYy8zLjgwLjIvZG9jcy9yZXNvdXJjZXMvb2JmdXNjYXRpb25fZXhwcmVzc2lvbiNhY2NvdW50X2lkIE9iZnVzY2F0aW9uRXhwcmVzc2lvbiNhY2NvdW50X2lkfVxuICAqL1xuICByZWFkb25seSBhY2NvdW50SWQ/OiBudW1iZXI7XG4gIC8qKlxuICAqIERlc2NyaXB0aW9uIG9mIGV4cHJlc3Npb24uXG4gICpcbiAgKiBEb2NzIGF0IFRlcnJhZm9ybSBSZWdpc3RyeToge0BsaW5rIGh0dHBzOi8vcmVnaXN0cnkudGVycmFmb3JtLmlvL3Byb3ZpZGVycy9uZXdyZWxpYy9uZXdyZWxpYy8zLjgwLjIvZG9jcy9yZXNvdXJjZXMvb2JmdXNjYXRpb25fZXhwcmVzc2lvbiNkZXNjcmlwdGlvbiBPYmZ1c2NhdGlvbkV4cHJlc3Npb24jZGVzY3JpcHRpb259XG4gICovXG4gIHJlYWRvbmx5IGRlc2NyaXB0aW9uPzogc3RyaW5nO1xuICAvKipcbiAgKiBEb2NzIGF0IFRlcnJhZm9ybSBSZWdpc3RyeToge0BsaW5rIGh0dHBzOi8vcmVnaXN0cnkudGVycmFmb3JtLmlvL3Byb3ZpZGVycy9uZXdyZWxpYy9uZXdyZWxpYy8zLjgwLjIvZG9jcy9yZXNvdXJjZXMvb2JmdXNjYXRpb25fZXhwcmVzc2lvbiNpZCBPYmZ1c2NhdGlvbkV4cHJlc3Npb24jaWR9XG4gICpcbiAgKiBQbGVhc2UgYmUgYXdhcmUgdGhhdCB0aGUgaWQgZmllbGQgaXMgYXV0b21hdGljYWxseSBhZGRlZCB0byBhbGwgcmVzb3VyY2VzIGluIFRlcnJhZm9ybSBwcm92aWRlcnMgdXNpbmcgYSBUZXJyYWZvcm0gcHJvdmlkZXIgU0RLIHZlcnNpb24gYmVsb3cgMi5cbiAgKiBJZiB5b3UgZXhwZXJpZW5jZSBwcm9ibGVtcyBzZXR0aW5nIHRoaXMgdmFsdWUgaXQgbWlnaHQgbm90IGJlIHNldHRhYmxlLiBQbGVhc2UgdGFrZSBhIGxvb2sgYXQgdGhlIHByb3ZpZGVyIGRvY3VtZW50YXRpb24gdG8gZW5zdXJlIGl0IHNob3VsZCBiZSBzZXR0YWJsZS5cbiAgKi9cbiAgcmVhZG9ubHkgaWQ/OiBzdHJpbmc7XG4gIC8qKlxuICAqIE5hbWUgb2YgZXhwcmVzc2lvbi5cbiAgKlxuICAqIERvY3MgYXQgVGVycmFmb3JtIFJlZ2lzdHJ5OiB7QGxpbmsgaHR0cHM6Ly9yZWdpc3RyeS50ZXJyYWZvcm0uaW8vcHJvdmlkZXJzL25ld3JlbGljL25ld3JlbGljLzMuODAuMi9kb2NzL3Jlc291cmNlcy9vYmZ1c2NhdGlvbl9leHByZXNzaW9uI25hbWUgT2JmdXNjYXRpb25FeHByZXNzaW9uI25hbWV9XG4gICovXG4gIHJlYWRvbmx5IG5hbWU6IHN0cmluZztcbiAgLyoqXG4gICogUmVnZXggb2YgZXhwcmVzc2lvbi5cbiAgKlxuICAqIERvY3MgYXQgVGVycmFmb3JtIFJlZ2lzdHJ5OiB7QGxpbmsgaHR0cHM6Ly9yZWdpc3RyeS50ZXJyYWZvcm0uaW8vcHJvdmlkZXJzL25ld3JlbGljL25ld3JlbGljLzMuODAuMi9kb2NzL3Jlc291cmNlcy9vYmZ1c2NhdGlvbl9leHByZXNzaW9uI3JlZ2V4IE9iZnVzY2F0aW9uRXhwcmVzc2lvbiNyZWdleH1cbiAgKi9cbiAgcmVhZG9ubHkgcmVnZXg6IHN0cmluZztcbn1cblxuLyoqXG4qIFJlcHJlc2VudHMgYSB7QGxpbmsgaHR0cHM6Ly9yZWdpc3RyeS50ZXJyYWZvcm0uaW8vcHJvdmlkZXJzL25ld3JlbGljL25ld3JlbGljLzMuODAuMi9kb2NzL3Jlc291cmNlcy9vYmZ1c2NhdGlvbl9leHByZXNzaW9uIG5ld3JlbGljX29iZnVzY2F0aW9uX2V4cHJlc3Npb259XG4qL1xuZXhwb3J0IGNsYXNzIE9iZnVzY2F0aW9uRXhwcmVzc2lvbiBleHRlbmRzIGNka3RuLlRlcnJhZm9ybVJlc291cmNlIHtcblxuICAvLyA9PT09PT09PT09PT09PT09PVxuICAvLyBTVEFUSUMgUFJPUEVSVElFU1xuICAvLyA9PT09PT09PT09PT09PT09PVxuICBwdWJsaWMgc3RhdGljIHJlYWRvbmx5IHRmUmVzb3VyY2VUeXBlID0gXCJuZXdyZWxpY19vYmZ1c2NhdGlvbl9leHByZXNzaW9uXCI7XG5cbiAgLy8gPT09PT09PT09PT09PT1cbiAgLy8gU1RBVElDIE1ldGhvZHNcbiAgLy8gPT09PT09PT09PT09PT1cbiAgLyoqXG4gICogR2VuZXJhdGVzIENES1ROIGNvZGUgZm9yIGltcG9ydGluZyBhIE9iZnVzY2F0aW9uRXhwcmVzc2lvbiByZXNvdXJjZSB1cG9uIHJ1bm5pbmcgXCJjZGt0biBwbGFuIDxzdGFjay1uYW1lPlwiXG4gICogQHBhcmFtIHNjb3BlIFRoZSBzY29wZSBpbiB3aGljaCB0byBkZWZpbmUgdGhpcyBjb25zdHJ1Y3RcbiAgKiBAcGFyYW0gaW1wb3J0VG9JZCBUaGUgY29uc3RydWN0IGlkIHVzZWQgaW4gdGhlIGdlbmVyYXRlZCBjb25maWcgZm9yIHRoZSBPYmZ1c2NhdGlvbkV4cHJlc3Npb24gdG8gaW1wb3J0XG4gICogQHBhcmFtIGltcG9ydEZyb21JZCBUaGUgaWQgb2YgdGhlIGV4aXN0aW5nIE9iZnVzY2F0aW9uRXhwcmVzc2lvbiB0aGF0IHNob3VsZCBiZSBpbXBvcnRlZC4gUmVmZXIgdG8gdGhlIHtAbGluayBodHRwczovL3JlZ2lzdHJ5LnRlcnJhZm9ybS5pby9wcm92aWRlcnMvbmV3cmVsaWMvbmV3cmVsaWMvMy44MC4yL2RvY3MvcmVzb3VyY2VzL29iZnVzY2F0aW9uX2V4cHJlc3Npb24jaW1wb3J0IGltcG9ydCBzZWN0aW9ufSBpbiB0aGUgZG9jdW1lbnRhdGlvbiBvZiB0aGlzIHJlc291cmNlIGZvciB0aGUgaWQgdG8gdXNlXG4gICogQHBhcmFtIHByb3ZpZGVyPyBPcHRpb25hbCBpbnN0YW5jZSBvZiB0aGUgcHJvdmlkZXIgd2hlcmUgdGhlIE9iZnVzY2F0aW9uRXhwcmVzc2lvbiB0byBpbXBvcnQgaXMgZm91bmRcbiAgKi9cbiAgcHVibGljIHN0YXRpYyBnZW5lcmF0ZUNvbmZpZ0ZvckltcG9ydChzY29wZTogQ29uc3RydWN0LCBpbXBvcnRUb0lkOiBzdHJpbmcsIGltcG9ydEZyb21JZDogc3RyaW5nLCBwcm92aWRlcj86IGNka3RuLlRlcnJhZm9ybVByb3ZpZGVyKSB7XG4gICAgICAgIHJldHVybiBuZXcgY2RrdG4uSW1wb3J0YWJsZVJlc291cmNlKHNjb3BlLCBpbXBvcnRUb0lkLCB7IHRlcnJhZm9ybVJlc291cmNlVHlwZTogXCJuZXdyZWxpY19vYmZ1c2NhdGlvbl9leHByZXNzaW9uXCIsIGltcG9ydElkOiBpbXBvcnRGcm9tSWQsIHByb3ZpZGVyIH0pO1xuICAgICAgfVxuXG4gIC8vID09PT09PT09PT09XG4gIC8vIElOSVRJQUxJWkVSXG4gIC8vID09PT09PT09PT09XG5cbiAgLyoqXG4gICogQ3JlYXRlIGEgbmV3IHtAbGluayBodHRwczovL3JlZ2lzdHJ5LnRlcnJhZm9ybS5pby9wcm92aWRlcnMvbmV3cmVsaWMvbmV3cmVsaWMvMy44MC4yL2RvY3MvcmVzb3VyY2VzL29iZnVzY2F0aW9uX2V4cHJlc3Npb24gbmV3cmVsaWNfb2JmdXNjYXRpb25fZXhwcmVzc2lvbn0gUmVzb3VyY2VcbiAgKlxuICAqIEBwYXJhbSBzY29wZSBUaGUgc2NvcGUgaW4gd2hpY2ggdG8gZGVmaW5lIHRoaXMgY29uc3RydWN0XG4gICogQHBhcmFtIGlkIFRoZSBzY29wZWQgY29uc3RydWN0IElELiBNdXN0IGJlIHVuaXF1ZSBhbW9uZ3N0IHNpYmxpbmdzIGluIHRoZSBzYW1lIHNjb3BlXG4gICogQHBhcmFtIG9wdGlvbnMgT2JmdXNjYXRpb25FeHByZXNzaW9uQ29uZmlnXG4gICovXG4gIHB1YmxpYyBjb25zdHJ1Y3RvcihzY29wZTogQ29uc3RydWN0LCBpZDogc3RyaW5nLCBjb25maWc6IE9iZnVzY2F0aW9uRXhwcmVzc2lvbkNvbmZpZykge1xuICAgIHN1cGVyKHNjb3BlLCBpZCwge1xuICAgICAgdGVycmFmb3JtUmVzb3VyY2VUeXBlOiAnbmV3cmVsaWNfb2JmdXNjYXRpb25fZXhwcmVzc2lvbicsXG4gICAgICB0ZXJyYWZvcm1HZW5lcmF0b3JNZXRhZGF0YToge1xuICAgICAgICBwcm92aWRlck5hbWU6ICduZXdyZWxpYycsXG4gICAgICAgIHByb3ZpZGVyVmVyc2lvbjogJzMuODAuMicsXG4gICAgICAgIHByb3ZpZGVyVmVyc2lvbkNvbnN0cmFpbnQ6ICd+PiAzLjcnXG4gICAgICB9LFxuICAgICAgcHJvdmlkZXI6IGNvbmZpZy5wcm92aWRlcixcbiAgICAgIGRlcGVuZHNPbjogY29uZmlnLmRlcGVuZHNPbixcbiAgICAgIGNvdW50OiBjb25maWcuY291bnQsXG4gICAgICBsaWZlY3ljbGU6IGNvbmZpZy5saWZlY3ljbGUsXG4gICAgICBwcm92aXNpb25lcnM6IGNvbmZpZy5wcm92aXNpb25lcnMsXG4gICAgICBjb25uZWN0aW9uOiBjb25maWcuY29ubmVjdGlvbixcbiAgICAgIGZvckVhY2g6IGNvbmZpZy5mb3JFYWNoXG4gICAgfSk7XG4gICAgdGhpcy5fYWNjb3VudElkID0gY29uZmlnLmFjY291bnRJZDtcbiAgICB0aGlzLl9kZXNjcmlwdGlvbiA9IGNvbmZpZy5kZXNjcmlwdGlvbjtcbiAgICB0aGlzLl9pZCA9IGNvbmZpZy5pZDtcbiAgICB0aGlzLl9uYW1lID0gY29uZmlnLm5hbWU7XG4gICAgdGhpcy5fcmVnZXggPSBjb25maWcucmVnZXg7XG4gIH1cblxuICAvLyA9PT09PT09PT09XG4gIC8vIEFUVFJJQlVURVNcbiAgLy8gPT09PT09PT09PVxuXG4gIC8vIGFjY291bnRfaWQgLSBjb21wdXRlZDogdHJ1ZSwgb3B0aW9uYWw6IHRydWUsIHJlcXVpcmVkOiBmYWxzZVxuICBwcml2YXRlIF9hY2NvdW50SWQ/OiBudW1iZXI7IFxuICBwdWJsaWMgZ2V0IGFjY291bnRJZCgpIHtcbiAgICByZXR1cm4gdGhpcy5nZXROdW1iZXJBdHRyaWJ1dGUoJ2FjY291bnRfaWQnKTtcbiAgfVxuICBwdWJsaWMgc2V0IGFjY291bnRJZCh2YWx1ZTogbnVtYmVyKSB7XG4gICAgdGhpcy5fYWNjb3VudElkID0gdmFsdWU7XG4gIH1cbiAgcHVibGljIHJlc2V0QWNjb3VudElkKCkge1xuICAgIHRoaXMuX2FjY291bnRJZCA9IHVuZGVmaW5lZDtcbiAgfVxuICAvLyBUZW1wb3JhcmlseSBleHBvc2UgaW5wdXQgdmFsdWUuIFVzZSB3aXRoIGNhdXRpb24uXG4gIHB1YmxpYyBnZXQgYWNjb3VudElkSW5wdXQoKSB7XG4gICAgcmV0dXJuIHRoaXMuX2FjY291bnRJZDtcbiAgfVxuXG4gIC8vIGRlc2NyaXB0aW9uIC0gY29tcHV0ZWQ6IGZhbHNlLCBvcHRpb25hbDogdHJ1ZSwgcmVxdWlyZWQ6IGZhbHNlXG4gIHByaXZhdGUgX2Rlc2NyaXB0aW9uPzogc3RyaW5nOyBcbiAgcHVibGljIGdldCBkZXNjcmlwdGlvbigpIHtcbiAgICByZXR1cm4gdGhpcy5nZXRTdHJpbmdBdHRyaWJ1dGUoJ2Rlc2NyaXB0aW9uJyk7XG4gIH1cbiAgcHVibGljIHNldCBkZXNjcmlwdGlvbih2YWx1ZTogc3RyaW5nKSB7XG4gICAgdGhpcy5fZGVzY3JpcHRpb24gPSB2YWx1ZTtcbiAgfVxuICBwdWJsaWMgcmVzZXREZXNjcmlwdGlvbigpIHtcbiAgICB0aGlzLl9kZXNjcmlwdGlvbiA9IHVuZGVmaW5lZDtcbiAgfVxuICAvLyBUZW1wb3JhcmlseSBleHBvc2UgaW5wdXQgdmFsdWUuIFVzZSB3aXRoIGNhdXRpb24uXG4gIHB1YmxpYyBnZXQgZGVzY3JpcHRpb25JbnB1dCgpIHtcbiAgICByZXR1cm4gdGhpcy5fZGVzY3JpcHRpb247XG4gIH1cblxuICAvLyBpZCAtIGNvbXB1dGVkOiB0cnVlLCBvcHRpb25hbDogdHJ1ZSwgcmVxdWlyZWQ6IGZhbHNlXG4gIHByaXZhdGUgX2lkPzogc3RyaW5nOyBcbiAgcHVibGljIGdldCBpZCgpIHtcbiAgICByZXR1cm4gdGhpcy5nZXRTdHJpbmdBdHRyaWJ1dGUoJ2lkJyk7XG4gIH1cbiAgcHVibGljIHNldCBpZCh2YWx1ZTogc3RyaW5nKSB7XG4gICAgdGhpcy5faWQgPSB2YWx1ZTtcbiAgfVxuICBwdWJsaWMgcmVzZXRJZCgpIHtcbiAgICB0aGlzLl9pZCA9IHVuZGVmaW5lZDtcbiAgfVxuICAvLyBUZW1wb3JhcmlseSBleHBvc2UgaW5wdXQgdmFsdWUuIFVzZSB3aXRoIGNhdXRpb24uXG4gIHB1YmxpYyBnZXQgaWRJbnB1dCgpIHtcbiAgICByZXR1cm4gdGhpcy5faWQ7XG4gIH1cblxuICAvLyBuYW1lIC0gY29tcHV0ZWQ6IGZhbHNlLCBvcHRpb25hbDogZmFsc2UsIHJlcXVpcmVkOiB0cnVlXG4gIHByaXZhdGUgX25hbWU/OiBzdHJpbmc7IFxuICBwdWJsaWMgZ2V0IG5hbWUoKSB7XG4gICAgcmV0dXJuIHRoaXMuZ2V0U3RyaW5nQXR0cmlidXRlKCduYW1lJyk7XG4gIH1cbiAgcHVibGljIHNldCBuYW1lKHZhbHVlOiBzdHJpbmcpIHtcbiAgICB0aGlzLl9uYW1lID0gdmFsdWU7XG4gIH1cbiAgLy8gVGVtcG9yYXJpbHkgZXhwb3NlIGlucHV0IHZhbHVlLiBVc2Ugd2l0aCBjYXV0aW9uLlxuICBwdWJsaWMgZ2V0IG5hbWVJbnB1dCgpIHtcbiAgICByZXR1cm4gdGhpcy5fbmFtZTtcbiAgfVxuXG4gIC8vIHJlZ2V4IC0gY29tcHV0ZWQ6IGZhbHNlLCBvcHRpb25hbDogZmFsc2UsIHJlcXVpcmVkOiB0cnVlXG4gIHByaXZhdGUgX3JlZ2V4Pzogc3RyaW5nOyBcbiAgcHVibGljIGdldCByZWdleCgpIHtcbiAgICByZXR1cm4gdGhpcy5nZXRTdHJpbmdBdHRyaWJ1dGUoJ3JlZ2V4Jyk7XG4gIH1cbiAgcHVibGljIHNldCByZWdleCh2YWx1ZTogc3RyaW5nKSB7XG4gICAgdGhpcy5fcmVnZXggPSB2YWx1ZTtcbiAgfVxuICAvLyBUZW1wb3JhcmlseSBleHBvc2UgaW5wdXQgdmFsdWUuIFVzZSB3aXRoIGNhdXRpb24uXG4gIHB1YmxpYyBnZXQgcmVnZXhJbnB1dCgpIHtcbiAgICByZXR1cm4gdGhpcy5fcmVnZXg7XG4gIH1cblxuICAvLyA9PT09PT09PT1cbiAgLy8gU1lOVEhFU0lTXG4gIC8vID09PT09PT09PVxuXG4gIHByb3RlY3RlZCBzeW50aGVzaXplQXR0cmlidXRlcygpOiB7IFtuYW1lOiBzdHJpbmddOiBhbnkgfSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIGFjY291bnRfaWQ6IGNka3RuLm51bWJlclRvVGVycmFmb3JtKHRoaXMuX2FjY291bnRJZCksXG4gICAgICBkZXNjcmlwdGlvbjogY2RrdG4uc3RyaW5nVG9UZXJyYWZvcm0odGhpcy5fZGVzY3JpcHRpb24pLFxuICAgICAgaWQ6IGNka3RuLnN0cmluZ1RvVGVycmFmb3JtKHRoaXMuX2lkKSxcbiAgICAgIG5hbWU6IGNka3RuLnN0cmluZ1RvVGVycmFmb3JtKHRoaXMuX25hbWUpLFxuICAgICAgcmVnZXg6IGNka3RuLnN0cmluZ1RvVGVycmFmb3JtKHRoaXMuX3JlZ2V4KSxcbiAgICB9O1xuICB9XG5cbiAgcHJvdGVjdGVkIHN5bnRoZXNpemVIY2xBdHRyaWJ1dGVzKCk6IHsgW25hbWU6IHN0cmluZ106IGFueSB9IHtcbiAgICBjb25zdCBhdHRycyA9IHtcbiAgICAgIGFjY291bnRfaWQ6IHtcbiAgICAgICAgdmFsdWU6IGNka3RuLm51bWJlclRvSGNsVGVycmFmb3JtKHRoaXMuX2FjY291bnRJZCksXG4gICAgICAgIGlzQmxvY2s6IGZhbHNlLFxuICAgICAgICB0eXBlOiBcInNpbXBsZVwiLFxuICAgICAgICBzdG9yYWdlQ2xhc3NUeXBlOiBcIm51bWJlclwiLFxuICAgICAgfSxcbiAgICAgIGRlc2NyaXB0aW9uOiB7XG4gICAgICAgIHZhbHVlOiBjZGt0bi5zdHJpbmdUb0hjbFRlcnJhZm9ybSh0aGlzLl9kZXNjcmlwdGlvbiksXG4gICAgICAgIGlzQmxvY2s6IGZhbHNlLFxuICAgICAgICB0eXBlOiBcInNpbXBsZVwiLFxuICAgICAgICBzdG9yYWdlQ2xhc3NUeXBlOiBcInN0cmluZ1wiLFxuICAgICAgfSxcbiAgICAgIGlkOiB7XG4gICAgICAgIHZhbHVlOiBjZGt0bi5zdHJpbmdUb0hjbFRlcnJhZm9ybSh0aGlzLl9pZCksXG4gICAgICAgIGlzQmxvY2s6IGZhbHNlLFxuICAgICAgICB0eXBlOiBcInNpbXBsZVwiLFxuICAgICAgICBzdG9yYWdlQ2xhc3NUeXBlOiBcInN0cmluZ1wiLFxuICAgICAgfSxcbiAgICAgIG5hbWU6IHtcbiAgICAgICAgdmFsdWU6IGNka3RuLnN0cmluZ1RvSGNsVGVycmFmb3JtKHRoaXMuX25hbWUpLFxuICAgICAgICBpc0Jsb2NrOiBmYWxzZSxcbiAgICAgICAgdHlwZTogXCJzaW1wbGVcIixcbiAgICAgICAgc3RvcmFnZUNsYXNzVHlwZTogXCJzdHJpbmdcIixcbiAgICAgIH0sXG4gICAgICByZWdleDoge1xuICAgICAgICB2YWx1ZTogY2RrdG4uc3RyaW5nVG9IY2xUZXJyYWZvcm0odGhpcy5fcmVnZXgpLFxuICAgICAgICBpc0Jsb2NrOiBmYWxzZSxcbiAgICAgICAgdHlwZTogXCJzaW1wbGVcIixcbiAgICAgICAgc3RvcmFnZUNsYXNzVHlwZTogXCJzdHJpbmdcIixcbiAgICAgIH0sXG4gICAgfTtcblxuICAgIC8vIHJlbW92ZSB1bmRlZmluZWQgYXR0cmlidXRlc1xuICAgIHJldHVybiBPYmplY3QuZnJvbUVudHJpZXMoT2JqZWN0LmVudHJpZXMoYXR0cnMpLmZpbHRlcigoW18sIHZhbHVlXSkgPT4gdmFsdWUgIT09IHVuZGVmaW5lZCAmJiB2YWx1ZS52YWx1ZSAhPT0gdW5kZWZpbmVkICkpXG4gIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,173 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Copyright IBM Corp. 2021, 2026
|
|
3
|
+
* SPDX-License-Identifier: MPL-2.0
|
|
4
|
+
*/
|
|
5
|
+
import { Construct } from 'constructs';
|
|
6
|
+
import * as cdktn from 'cdktn';
|
|
7
|
+
export interface ObfuscationRuleConfig extends cdktn.TerraformMetaArguments {
|
|
8
|
+
/**
|
|
9
|
+
* The account id associated with the obfuscation rule.
|
|
10
|
+
*
|
|
11
|
+
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/newrelic/newrelic/3.80.2/docs/resources/obfuscation_rule#account_id ObfuscationRule#account_id}
|
|
12
|
+
*/
|
|
13
|
+
readonly accountId?: number;
|
|
14
|
+
/**
|
|
15
|
+
* Description of rule.
|
|
16
|
+
*
|
|
17
|
+
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/newrelic/newrelic/3.80.2/docs/resources/obfuscation_rule#description ObfuscationRule#description}
|
|
18
|
+
*/
|
|
19
|
+
readonly description?: string;
|
|
20
|
+
/**
|
|
21
|
+
* Whether the rule should be applied or not to incoming data.
|
|
22
|
+
*
|
|
23
|
+
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/newrelic/newrelic/3.80.2/docs/resources/obfuscation_rule#enabled ObfuscationRule#enabled}
|
|
24
|
+
*/
|
|
25
|
+
readonly enabled: boolean | cdktn.IResolvable;
|
|
26
|
+
/**
|
|
27
|
+
* NRQL for determining whether a given log record should have obfuscation actions applied.
|
|
28
|
+
*
|
|
29
|
+
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/newrelic/newrelic/3.80.2/docs/resources/obfuscation_rule#filter ObfuscationRule#filter}
|
|
30
|
+
*/
|
|
31
|
+
readonly filter: string;
|
|
32
|
+
/**
|
|
33
|
+
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/newrelic/newrelic/3.80.2/docs/resources/obfuscation_rule#id ObfuscationRule#id}
|
|
34
|
+
*
|
|
35
|
+
* Please be aware that the id field is automatically added to all resources in Terraform providers using a Terraform provider SDK version below 2.
|
|
36
|
+
* If you experience problems setting this value it might not be settable. Please take a look at the provider documentation to ensure it should be settable.
|
|
37
|
+
*/
|
|
38
|
+
readonly id?: string;
|
|
39
|
+
/**
|
|
40
|
+
* Name of rule.
|
|
41
|
+
*
|
|
42
|
+
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/newrelic/newrelic/3.80.2/docs/resources/obfuscation_rule#name ObfuscationRule#name}
|
|
43
|
+
*/
|
|
44
|
+
readonly name: string;
|
|
45
|
+
/**
|
|
46
|
+
* action block
|
|
47
|
+
*
|
|
48
|
+
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/newrelic/newrelic/3.80.2/docs/resources/obfuscation_rule#action ObfuscationRule#action}
|
|
49
|
+
*/
|
|
50
|
+
readonly action: ObfuscationRuleAction[] | cdktn.IResolvable;
|
|
51
|
+
}
|
|
52
|
+
export interface ObfuscationRuleAction {
|
|
53
|
+
/**
|
|
54
|
+
* Attribute names for action. An empty list applies the action to all the attributes.
|
|
55
|
+
*
|
|
56
|
+
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/newrelic/newrelic/3.80.2/docs/resources/obfuscation_rule#attribute ObfuscationRule#attribute}
|
|
57
|
+
*/
|
|
58
|
+
readonly attribute: string[];
|
|
59
|
+
/**
|
|
60
|
+
* Expression Id for action.
|
|
61
|
+
*
|
|
62
|
+
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/newrelic/newrelic/3.80.2/docs/resources/obfuscation_rule#expression_id ObfuscationRule#expression_id}
|
|
63
|
+
*/
|
|
64
|
+
readonly expressionId: string;
|
|
65
|
+
/**
|
|
66
|
+
* Obfuscation method to use.
|
|
67
|
+
*
|
|
68
|
+
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/newrelic/newrelic/3.80.2/docs/resources/obfuscation_rule#method ObfuscationRule#method}
|
|
69
|
+
*/
|
|
70
|
+
readonly method: string;
|
|
71
|
+
}
|
|
72
|
+
export declare function obfuscationRuleActionToTerraform(struct?: ObfuscationRuleAction | cdktn.IResolvable): any;
|
|
73
|
+
export declare function obfuscationRuleActionToHclTerraform(struct?: ObfuscationRuleAction | cdktn.IResolvable): any;
|
|
74
|
+
export declare class ObfuscationRuleActionOutputReference extends cdktn.ComplexObject {
|
|
75
|
+
private isEmptyObject;
|
|
76
|
+
private resolvableValue?;
|
|
77
|
+
/**
|
|
78
|
+
* @param terraformResource The parent resource
|
|
79
|
+
* @param terraformAttribute The attribute on the parent resource this class is referencing
|
|
80
|
+
* @param complexObjectIndex the index of this item in the list
|
|
81
|
+
* @param complexObjectIsFromSet whether the list is wrapping a set (will add tolist() to be able to access an item via an index)
|
|
82
|
+
*/
|
|
83
|
+
constructor(terraformResource: cdktn.IInterpolatingParent, terraformAttribute: string, complexObjectIndex: number, complexObjectIsFromSet: boolean);
|
|
84
|
+
get internalValue(): ObfuscationRuleAction | cdktn.IResolvable | undefined;
|
|
85
|
+
set internalValue(value: ObfuscationRuleAction | cdktn.IResolvable | undefined);
|
|
86
|
+
private _attribute?;
|
|
87
|
+
get attribute(): string[];
|
|
88
|
+
set attribute(value: string[]);
|
|
89
|
+
get attributeInput(): string[] | undefined;
|
|
90
|
+
private _expressionId?;
|
|
91
|
+
get expressionId(): string;
|
|
92
|
+
set expressionId(value: string);
|
|
93
|
+
get expressionIdInput(): string | undefined;
|
|
94
|
+
private _method?;
|
|
95
|
+
get method(): string;
|
|
96
|
+
set method(value: string);
|
|
97
|
+
get methodInput(): string | undefined;
|
|
98
|
+
}
|
|
99
|
+
export declare class ObfuscationRuleActionList extends cdktn.ComplexList {
|
|
100
|
+
protected terraformResource: cdktn.IInterpolatingParent;
|
|
101
|
+
protected terraformAttribute: string;
|
|
102
|
+
protected wrapsSet: boolean;
|
|
103
|
+
internalValue?: ObfuscationRuleAction[] | cdktn.IResolvable;
|
|
104
|
+
/**
|
|
105
|
+
* @param terraformResource The parent resource
|
|
106
|
+
* @param terraformAttribute The attribute on the parent resource this class is referencing
|
|
107
|
+
* @param wrapsSet whether the list is wrapping a set (will add tolist() to be able to access an item via an index)
|
|
108
|
+
*/
|
|
109
|
+
constructor(terraformResource: cdktn.IInterpolatingParent, terraformAttribute: string, wrapsSet: boolean);
|
|
110
|
+
/**
|
|
111
|
+
* @param index the index of the item to return
|
|
112
|
+
*/
|
|
113
|
+
get(index: number): ObfuscationRuleActionOutputReference;
|
|
114
|
+
}
|
|
115
|
+
/**
|
|
116
|
+
* Represents a {@link https://registry.terraform.io/providers/newrelic/newrelic/3.80.2/docs/resources/obfuscation_rule newrelic_obfuscation_rule}
|
|
117
|
+
*/
|
|
118
|
+
export declare class ObfuscationRule extends cdktn.TerraformResource {
|
|
119
|
+
static readonly tfResourceType = "newrelic_obfuscation_rule";
|
|
120
|
+
/**
|
|
121
|
+
* Generates CDKTN code for importing a ObfuscationRule resource upon running "cdktn plan <stack-name>"
|
|
122
|
+
* @param scope The scope in which to define this construct
|
|
123
|
+
* @param importToId The construct id used in the generated config for the ObfuscationRule to import
|
|
124
|
+
* @param importFromId The id of the existing ObfuscationRule that should be imported. Refer to the {@link https://registry.terraform.io/providers/newrelic/newrelic/3.80.2/docs/resources/obfuscation_rule#import import section} in the documentation of this resource for the id to use
|
|
125
|
+
* @param provider? Optional instance of the provider where the ObfuscationRule to import is found
|
|
126
|
+
*/
|
|
127
|
+
static generateConfigForImport(scope: Construct, importToId: string, importFromId: string, provider?: cdktn.TerraformProvider): cdktn.ImportableResource;
|
|
128
|
+
/**
|
|
129
|
+
* Create a new {@link https://registry.terraform.io/providers/newrelic/newrelic/3.80.2/docs/resources/obfuscation_rule newrelic_obfuscation_rule} Resource
|
|
130
|
+
*
|
|
131
|
+
* @param scope The scope in which to define this construct
|
|
132
|
+
* @param id The scoped construct ID. Must be unique amongst siblings in the same scope
|
|
133
|
+
* @param options ObfuscationRuleConfig
|
|
134
|
+
*/
|
|
135
|
+
constructor(scope: Construct, id: string, config: ObfuscationRuleConfig);
|
|
136
|
+
private _accountId?;
|
|
137
|
+
get accountId(): number;
|
|
138
|
+
set accountId(value: number);
|
|
139
|
+
resetAccountId(): void;
|
|
140
|
+
get accountIdInput(): number | undefined;
|
|
141
|
+
private _description?;
|
|
142
|
+
get description(): string;
|
|
143
|
+
set description(value: string);
|
|
144
|
+
resetDescription(): void;
|
|
145
|
+
get descriptionInput(): string | undefined;
|
|
146
|
+
private _enabled?;
|
|
147
|
+
get enabled(): boolean | cdktn.IResolvable;
|
|
148
|
+
set enabled(value: boolean | cdktn.IResolvable);
|
|
149
|
+
get enabledInput(): boolean | cdktn.IResolvable | undefined;
|
|
150
|
+
private _filter?;
|
|
151
|
+
get filter(): string;
|
|
152
|
+
set filter(value: string);
|
|
153
|
+
get filterInput(): string | undefined;
|
|
154
|
+
private _id?;
|
|
155
|
+
get id(): string;
|
|
156
|
+
set id(value: string);
|
|
157
|
+
resetId(): void;
|
|
158
|
+
get idInput(): string | undefined;
|
|
159
|
+
private _name?;
|
|
160
|
+
get name(): string;
|
|
161
|
+
set name(value: string);
|
|
162
|
+
get nameInput(): string | undefined;
|
|
163
|
+
private _action;
|
|
164
|
+
get action(): ObfuscationRuleActionList;
|
|
165
|
+
putAction(value: ObfuscationRuleAction[] | cdktn.IResolvable): void;
|
|
166
|
+
get actionInput(): cdktn.IResolvable | ObfuscationRuleAction[] | undefined;
|
|
167
|
+
protected synthesizeAttributes(): {
|
|
168
|
+
[name: string]: any;
|
|
169
|
+
};
|
|
170
|
+
protected synthesizeHclAttributes(): {
|
|
171
|
+
[name: string]: any;
|
|
172
|
+
};
|
|
173
|
+
}
|