@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,136 @@
|
|
|
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 SyntheticsSecureCredentialConfig extends cdktn.TerraformMetaArguments {
|
|
8
|
+
/**
|
|
9
|
+
* The New Relic account ID where you want to create the secure credential.
|
|
10
|
+
*
|
|
11
|
+
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/newrelic/newrelic/3.80.2/docs/resources/synthetics_secure_credential#account_id SyntheticsSecureCredential#account_id}
|
|
12
|
+
*/
|
|
13
|
+
readonly accountId?: number;
|
|
14
|
+
/**
|
|
15
|
+
* The secure credential's description.
|
|
16
|
+
*
|
|
17
|
+
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/newrelic/newrelic/3.80.2/docs/resources/synthetics_secure_credential#description SyntheticsSecureCredential#description}
|
|
18
|
+
*/
|
|
19
|
+
readonly description?: string;
|
|
20
|
+
/**
|
|
21
|
+
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/newrelic/newrelic/3.80.2/docs/resources/synthetics_secure_credential#id SyntheticsSecureCredential#id}
|
|
22
|
+
*
|
|
23
|
+
* Please be aware that the id field is automatically added to all resources in Terraform providers using a Terraform provider SDK version below 2.
|
|
24
|
+
* 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.
|
|
25
|
+
*/
|
|
26
|
+
readonly id?: string;
|
|
27
|
+
/**
|
|
28
|
+
* The secure credential's key name. Regardless of the case used in the configuration, the provider will provide an upcased key to the underlying API.
|
|
29
|
+
*
|
|
30
|
+
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/newrelic/newrelic/3.80.2/docs/resources/synthetics_secure_credential#key SyntheticsSecureCredential#key}
|
|
31
|
+
*/
|
|
32
|
+
readonly key: string;
|
|
33
|
+
/**
|
|
34
|
+
* The time the secure credential was last updated.
|
|
35
|
+
*
|
|
36
|
+
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/newrelic/newrelic/3.80.2/docs/resources/synthetics_secure_credential#last_updated SyntheticsSecureCredential#last_updated}
|
|
37
|
+
*/
|
|
38
|
+
readonly lastUpdated?: string;
|
|
39
|
+
/**
|
|
40
|
+
* The secure credential's value.
|
|
41
|
+
*
|
|
42
|
+
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/newrelic/newrelic/3.80.2/docs/resources/synthetics_secure_credential#value SyntheticsSecureCredential#value}
|
|
43
|
+
*/
|
|
44
|
+
readonly value: string;
|
|
45
|
+
/**
|
|
46
|
+
* timeouts block
|
|
47
|
+
*
|
|
48
|
+
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/newrelic/newrelic/3.80.2/docs/resources/synthetics_secure_credential#timeouts SyntheticsSecureCredential#timeouts}
|
|
49
|
+
*/
|
|
50
|
+
readonly timeouts?: SyntheticsSecureCredentialTimeouts;
|
|
51
|
+
}
|
|
52
|
+
export interface SyntheticsSecureCredentialTimeouts {
|
|
53
|
+
/**
|
|
54
|
+
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/newrelic/newrelic/3.80.2/docs/resources/synthetics_secure_credential#read SyntheticsSecureCredential#read}
|
|
55
|
+
*/
|
|
56
|
+
readonly read?: string;
|
|
57
|
+
}
|
|
58
|
+
export declare function syntheticsSecureCredentialTimeoutsToTerraform(struct?: SyntheticsSecureCredentialTimeouts | cdktn.IResolvable): any;
|
|
59
|
+
export declare function syntheticsSecureCredentialTimeoutsToHclTerraform(struct?: SyntheticsSecureCredentialTimeouts | cdktn.IResolvable): any;
|
|
60
|
+
export declare class SyntheticsSecureCredentialTimeoutsOutputReference extends cdktn.ComplexObject {
|
|
61
|
+
private isEmptyObject;
|
|
62
|
+
private resolvableValue?;
|
|
63
|
+
/**
|
|
64
|
+
* @param terraformResource The parent resource
|
|
65
|
+
* @param terraformAttribute The attribute on the parent resource this class is referencing
|
|
66
|
+
*/
|
|
67
|
+
constructor(terraformResource: cdktn.IInterpolatingParent, terraformAttribute: string);
|
|
68
|
+
get internalValue(): SyntheticsSecureCredentialTimeouts | cdktn.IResolvable | undefined;
|
|
69
|
+
set internalValue(value: SyntheticsSecureCredentialTimeouts | cdktn.IResolvable | undefined);
|
|
70
|
+
private _read?;
|
|
71
|
+
get read(): string;
|
|
72
|
+
set read(value: string);
|
|
73
|
+
resetRead(): void;
|
|
74
|
+
get readInput(): string | undefined;
|
|
75
|
+
}
|
|
76
|
+
/**
|
|
77
|
+
* Represents a {@link https://registry.terraform.io/providers/newrelic/newrelic/3.80.2/docs/resources/synthetics_secure_credential newrelic_synthetics_secure_credential}
|
|
78
|
+
*/
|
|
79
|
+
export declare class SyntheticsSecureCredential extends cdktn.TerraformResource {
|
|
80
|
+
static readonly tfResourceType = "newrelic_synthetics_secure_credential";
|
|
81
|
+
/**
|
|
82
|
+
* Generates CDKTN code for importing a SyntheticsSecureCredential resource upon running "cdktn plan <stack-name>"
|
|
83
|
+
* @param scope The scope in which to define this construct
|
|
84
|
+
* @param importToId The construct id used in the generated config for the SyntheticsSecureCredential to import
|
|
85
|
+
* @param importFromId The id of the existing SyntheticsSecureCredential that should be imported. Refer to the {@link https://registry.terraform.io/providers/newrelic/newrelic/3.80.2/docs/resources/synthetics_secure_credential#import import section} in the documentation of this resource for the id to use
|
|
86
|
+
* @param provider? Optional instance of the provider where the SyntheticsSecureCredential to import is found
|
|
87
|
+
*/
|
|
88
|
+
static generateConfigForImport(scope: Construct, importToId: string, importFromId: string, provider?: cdktn.TerraformProvider): cdktn.ImportableResource;
|
|
89
|
+
/**
|
|
90
|
+
* Create a new {@link https://registry.terraform.io/providers/newrelic/newrelic/3.80.2/docs/resources/synthetics_secure_credential newrelic_synthetics_secure_credential} Resource
|
|
91
|
+
*
|
|
92
|
+
* @param scope The scope in which to define this construct
|
|
93
|
+
* @param id The scoped construct ID. Must be unique amongst siblings in the same scope
|
|
94
|
+
* @param options SyntheticsSecureCredentialConfig
|
|
95
|
+
*/
|
|
96
|
+
constructor(scope: Construct, id: string, config: SyntheticsSecureCredentialConfig);
|
|
97
|
+
private _accountId?;
|
|
98
|
+
get accountId(): number;
|
|
99
|
+
set accountId(value: number);
|
|
100
|
+
resetAccountId(): void;
|
|
101
|
+
get accountIdInput(): number | undefined;
|
|
102
|
+
private _description?;
|
|
103
|
+
get description(): string;
|
|
104
|
+
set description(value: string);
|
|
105
|
+
resetDescription(): void;
|
|
106
|
+
get descriptionInput(): string | undefined;
|
|
107
|
+
private _id?;
|
|
108
|
+
get id(): string;
|
|
109
|
+
set id(value: string);
|
|
110
|
+
resetId(): void;
|
|
111
|
+
get idInput(): string | undefined;
|
|
112
|
+
private _key?;
|
|
113
|
+
get key(): string;
|
|
114
|
+
set key(value: string);
|
|
115
|
+
get keyInput(): string | undefined;
|
|
116
|
+
private _lastUpdated?;
|
|
117
|
+
get lastUpdated(): string;
|
|
118
|
+
set lastUpdated(value: string);
|
|
119
|
+
resetLastUpdated(): void;
|
|
120
|
+
get lastUpdatedInput(): string | undefined;
|
|
121
|
+
private _value?;
|
|
122
|
+
get value(): string;
|
|
123
|
+
set value(value: string);
|
|
124
|
+
get valueInput(): string | undefined;
|
|
125
|
+
private _timeouts;
|
|
126
|
+
get timeouts(): SyntheticsSecureCredentialTimeoutsOutputReference;
|
|
127
|
+
putTimeouts(value: SyntheticsSecureCredentialTimeouts): void;
|
|
128
|
+
resetTimeouts(): void;
|
|
129
|
+
get timeoutsInput(): cdktn.IResolvable | SyntheticsSecureCredentialTimeouts | undefined;
|
|
130
|
+
protected synthesizeAttributes(): {
|
|
131
|
+
[name: string]: any;
|
|
132
|
+
};
|
|
133
|
+
protected synthesizeHclAttributes(): {
|
|
134
|
+
[name: string]: any;
|
|
135
|
+
};
|
|
136
|
+
}
|
|
@@ -0,0 +1,300 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var _a, _b;
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
exports.SyntheticsSecureCredential = exports.SyntheticsSecureCredentialTimeoutsOutputReference = void 0;
|
|
5
|
+
exports.syntheticsSecureCredentialTimeoutsToTerraform = syntheticsSecureCredentialTimeoutsToTerraform;
|
|
6
|
+
exports.syntheticsSecureCredentialTimeoutsToHclTerraform = syntheticsSecureCredentialTimeoutsToHclTerraform;
|
|
7
|
+
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
8
|
+
const cdktn = require("cdktn");
|
|
9
|
+
function syntheticsSecureCredentialTimeoutsToTerraform(struct) {
|
|
10
|
+
if (!cdktn.canInspect(struct) || cdktn.Tokenization.isResolvable(struct)) {
|
|
11
|
+
return struct;
|
|
12
|
+
}
|
|
13
|
+
if (cdktn.isComplexElement(struct)) {
|
|
14
|
+
throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
|
|
15
|
+
}
|
|
16
|
+
return {
|
|
17
|
+
read: cdktn.stringToTerraform(struct.read),
|
|
18
|
+
};
|
|
19
|
+
}
|
|
20
|
+
function syntheticsSecureCredentialTimeoutsToHclTerraform(struct) {
|
|
21
|
+
if (!cdktn.canInspect(struct) || cdktn.Tokenization.isResolvable(struct)) {
|
|
22
|
+
return struct;
|
|
23
|
+
}
|
|
24
|
+
if (cdktn.isComplexElement(struct)) {
|
|
25
|
+
throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
|
|
26
|
+
}
|
|
27
|
+
const attrs = {
|
|
28
|
+
read: {
|
|
29
|
+
value: cdktn.stringToHclTerraform(struct.read),
|
|
30
|
+
isBlock: false,
|
|
31
|
+
type: "simple",
|
|
32
|
+
storageClassType: "string",
|
|
33
|
+
},
|
|
34
|
+
};
|
|
35
|
+
// remove undefined attributes
|
|
36
|
+
return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined));
|
|
37
|
+
}
|
|
38
|
+
class SyntheticsSecureCredentialTimeoutsOutputReference extends cdktn.ComplexObject {
|
|
39
|
+
/**
|
|
40
|
+
* @param terraformResource The parent resource
|
|
41
|
+
* @param terraformAttribute The attribute on the parent resource this class is referencing
|
|
42
|
+
*/
|
|
43
|
+
constructor(terraformResource, terraformAttribute) {
|
|
44
|
+
super(terraformResource, terraformAttribute, false);
|
|
45
|
+
this.isEmptyObject = false;
|
|
46
|
+
}
|
|
47
|
+
get internalValue() {
|
|
48
|
+
if (this.resolvableValue) {
|
|
49
|
+
return this.resolvableValue;
|
|
50
|
+
}
|
|
51
|
+
let hasAnyValues = this.isEmptyObject;
|
|
52
|
+
const internalValueResult = {};
|
|
53
|
+
if (this._read !== undefined) {
|
|
54
|
+
hasAnyValues = true;
|
|
55
|
+
internalValueResult.read = this._read;
|
|
56
|
+
}
|
|
57
|
+
return hasAnyValues ? internalValueResult : undefined;
|
|
58
|
+
}
|
|
59
|
+
set internalValue(value) {
|
|
60
|
+
if (value === undefined) {
|
|
61
|
+
this.isEmptyObject = false;
|
|
62
|
+
this.resolvableValue = undefined;
|
|
63
|
+
this._read = undefined;
|
|
64
|
+
}
|
|
65
|
+
else if (cdktn.Tokenization.isResolvable(value)) {
|
|
66
|
+
this.isEmptyObject = false;
|
|
67
|
+
this.resolvableValue = value;
|
|
68
|
+
}
|
|
69
|
+
else {
|
|
70
|
+
this.isEmptyObject = Object.keys(value).length === 0;
|
|
71
|
+
this.resolvableValue = undefined;
|
|
72
|
+
this._read = value.read;
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
get read() {
|
|
76
|
+
return this.getStringAttribute('read');
|
|
77
|
+
}
|
|
78
|
+
set read(value) {
|
|
79
|
+
this._read = value;
|
|
80
|
+
}
|
|
81
|
+
resetRead() {
|
|
82
|
+
this._read = undefined;
|
|
83
|
+
}
|
|
84
|
+
// Temporarily expose input value. Use with caution.
|
|
85
|
+
get readInput() {
|
|
86
|
+
return this._read;
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
exports.SyntheticsSecureCredentialTimeoutsOutputReference = SyntheticsSecureCredentialTimeoutsOutputReference;
|
|
90
|
+
_a = JSII_RTTI_SYMBOL_1;
|
|
91
|
+
SyntheticsSecureCredentialTimeoutsOutputReference[_a] = { fqn: "@cdktn/provider-newrelic.syntheticsSecureCredential.SyntheticsSecureCredentialTimeoutsOutputReference", version: "14.0.0" };
|
|
92
|
+
/**
|
|
93
|
+
* Represents a {@link https://registry.terraform.io/providers/newrelic/newrelic/3.80.2/docs/resources/synthetics_secure_credential newrelic_synthetics_secure_credential}
|
|
94
|
+
*/
|
|
95
|
+
class SyntheticsSecureCredential extends cdktn.TerraformResource {
|
|
96
|
+
// ==============
|
|
97
|
+
// STATIC Methods
|
|
98
|
+
// ==============
|
|
99
|
+
/**
|
|
100
|
+
* Generates CDKTN code for importing a SyntheticsSecureCredential resource upon running "cdktn plan <stack-name>"
|
|
101
|
+
* @param scope The scope in which to define this construct
|
|
102
|
+
* @param importToId The construct id used in the generated config for the SyntheticsSecureCredential to import
|
|
103
|
+
* @param importFromId The id of the existing SyntheticsSecureCredential that should be imported. Refer to the {@link https://registry.terraform.io/providers/newrelic/newrelic/3.80.2/docs/resources/synthetics_secure_credential#import import section} in the documentation of this resource for the id to use
|
|
104
|
+
* @param provider? Optional instance of the provider where the SyntheticsSecureCredential to import is found
|
|
105
|
+
*/
|
|
106
|
+
static generateConfigForImport(scope, importToId, importFromId, provider) {
|
|
107
|
+
return new cdktn.ImportableResource(scope, importToId, { terraformResourceType: "newrelic_synthetics_secure_credential", importId: importFromId, provider });
|
|
108
|
+
}
|
|
109
|
+
// ===========
|
|
110
|
+
// INITIALIZER
|
|
111
|
+
// ===========
|
|
112
|
+
/**
|
|
113
|
+
* Create a new {@link https://registry.terraform.io/providers/newrelic/newrelic/3.80.2/docs/resources/synthetics_secure_credential newrelic_synthetics_secure_credential} Resource
|
|
114
|
+
*
|
|
115
|
+
* @param scope The scope in which to define this construct
|
|
116
|
+
* @param id The scoped construct ID. Must be unique amongst siblings in the same scope
|
|
117
|
+
* @param options SyntheticsSecureCredentialConfig
|
|
118
|
+
*/
|
|
119
|
+
constructor(scope, id, config) {
|
|
120
|
+
super(scope, id, {
|
|
121
|
+
terraformResourceType: 'newrelic_synthetics_secure_credential',
|
|
122
|
+
terraformGeneratorMetadata: {
|
|
123
|
+
providerName: 'newrelic',
|
|
124
|
+
providerVersion: '3.80.2',
|
|
125
|
+
providerVersionConstraint: '~> 3.7'
|
|
126
|
+
},
|
|
127
|
+
provider: config.provider,
|
|
128
|
+
dependsOn: config.dependsOn,
|
|
129
|
+
count: config.count,
|
|
130
|
+
lifecycle: config.lifecycle,
|
|
131
|
+
provisioners: config.provisioners,
|
|
132
|
+
connection: config.connection,
|
|
133
|
+
forEach: config.forEach
|
|
134
|
+
});
|
|
135
|
+
// timeouts - computed: false, optional: true, required: false
|
|
136
|
+
this._timeouts = new SyntheticsSecureCredentialTimeoutsOutputReference(this, "timeouts");
|
|
137
|
+
this._accountId = config.accountId;
|
|
138
|
+
this._description = config.description;
|
|
139
|
+
this._id = config.id;
|
|
140
|
+
this._key = config.key;
|
|
141
|
+
this._lastUpdated = config.lastUpdated;
|
|
142
|
+
this._value = config.value;
|
|
143
|
+
this._timeouts.internalValue = config.timeouts;
|
|
144
|
+
}
|
|
145
|
+
get accountId() {
|
|
146
|
+
return this.getNumberAttribute('account_id');
|
|
147
|
+
}
|
|
148
|
+
set accountId(value) {
|
|
149
|
+
this._accountId = value;
|
|
150
|
+
}
|
|
151
|
+
resetAccountId() {
|
|
152
|
+
this._accountId = undefined;
|
|
153
|
+
}
|
|
154
|
+
// Temporarily expose input value. Use with caution.
|
|
155
|
+
get accountIdInput() {
|
|
156
|
+
return this._accountId;
|
|
157
|
+
}
|
|
158
|
+
get description() {
|
|
159
|
+
return this.getStringAttribute('description');
|
|
160
|
+
}
|
|
161
|
+
set description(value) {
|
|
162
|
+
this._description = value;
|
|
163
|
+
}
|
|
164
|
+
resetDescription() {
|
|
165
|
+
this._description = undefined;
|
|
166
|
+
}
|
|
167
|
+
// Temporarily expose input value. Use with caution.
|
|
168
|
+
get descriptionInput() {
|
|
169
|
+
return this._description;
|
|
170
|
+
}
|
|
171
|
+
get id() {
|
|
172
|
+
return this.getStringAttribute('id');
|
|
173
|
+
}
|
|
174
|
+
set id(value) {
|
|
175
|
+
this._id = value;
|
|
176
|
+
}
|
|
177
|
+
resetId() {
|
|
178
|
+
this._id = undefined;
|
|
179
|
+
}
|
|
180
|
+
// Temporarily expose input value. Use with caution.
|
|
181
|
+
get idInput() {
|
|
182
|
+
return this._id;
|
|
183
|
+
}
|
|
184
|
+
get key() {
|
|
185
|
+
return this.getStringAttribute('key');
|
|
186
|
+
}
|
|
187
|
+
set key(value) {
|
|
188
|
+
this._key = value;
|
|
189
|
+
}
|
|
190
|
+
// Temporarily expose input value. Use with caution.
|
|
191
|
+
get keyInput() {
|
|
192
|
+
return this._key;
|
|
193
|
+
}
|
|
194
|
+
get lastUpdated() {
|
|
195
|
+
return this.getStringAttribute('last_updated');
|
|
196
|
+
}
|
|
197
|
+
set lastUpdated(value) {
|
|
198
|
+
this._lastUpdated = value;
|
|
199
|
+
}
|
|
200
|
+
resetLastUpdated() {
|
|
201
|
+
this._lastUpdated = undefined;
|
|
202
|
+
}
|
|
203
|
+
// Temporarily expose input value. Use with caution.
|
|
204
|
+
get lastUpdatedInput() {
|
|
205
|
+
return this._lastUpdated;
|
|
206
|
+
}
|
|
207
|
+
get value() {
|
|
208
|
+
return this.getStringAttribute('value');
|
|
209
|
+
}
|
|
210
|
+
set value(value) {
|
|
211
|
+
this._value = value;
|
|
212
|
+
}
|
|
213
|
+
// Temporarily expose input value. Use with caution.
|
|
214
|
+
get valueInput() {
|
|
215
|
+
return this._value;
|
|
216
|
+
}
|
|
217
|
+
get timeouts() {
|
|
218
|
+
return this._timeouts;
|
|
219
|
+
}
|
|
220
|
+
putTimeouts(value) {
|
|
221
|
+
this._timeouts.internalValue = value;
|
|
222
|
+
}
|
|
223
|
+
resetTimeouts() {
|
|
224
|
+
this._timeouts.internalValue = undefined;
|
|
225
|
+
}
|
|
226
|
+
// Temporarily expose input value. Use with caution.
|
|
227
|
+
get timeoutsInput() {
|
|
228
|
+
return this._timeouts.internalValue;
|
|
229
|
+
}
|
|
230
|
+
// =========
|
|
231
|
+
// SYNTHESIS
|
|
232
|
+
// =========
|
|
233
|
+
synthesizeAttributes() {
|
|
234
|
+
return {
|
|
235
|
+
account_id: cdktn.numberToTerraform(this._accountId),
|
|
236
|
+
description: cdktn.stringToTerraform(this._description),
|
|
237
|
+
id: cdktn.stringToTerraform(this._id),
|
|
238
|
+
key: cdktn.stringToTerraform(this._key),
|
|
239
|
+
last_updated: cdktn.stringToTerraform(this._lastUpdated),
|
|
240
|
+
value: cdktn.stringToTerraform(this._value),
|
|
241
|
+
timeouts: syntheticsSecureCredentialTimeoutsToTerraform(this._timeouts.internalValue),
|
|
242
|
+
};
|
|
243
|
+
}
|
|
244
|
+
synthesizeHclAttributes() {
|
|
245
|
+
const attrs = {
|
|
246
|
+
account_id: {
|
|
247
|
+
value: cdktn.numberToHclTerraform(this._accountId),
|
|
248
|
+
isBlock: false,
|
|
249
|
+
type: "simple",
|
|
250
|
+
storageClassType: "number",
|
|
251
|
+
},
|
|
252
|
+
description: {
|
|
253
|
+
value: cdktn.stringToHclTerraform(this._description),
|
|
254
|
+
isBlock: false,
|
|
255
|
+
type: "simple",
|
|
256
|
+
storageClassType: "string",
|
|
257
|
+
},
|
|
258
|
+
id: {
|
|
259
|
+
value: cdktn.stringToHclTerraform(this._id),
|
|
260
|
+
isBlock: false,
|
|
261
|
+
type: "simple",
|
|
262
|
+
storageClassType: "string",
|
|
263
|
+
},
|
|
264
|
+
key: {
|
|
265
|
+
value: cdktn.stringToHclTerraform(this._key),
|
|
266
|
+
isBlock: false,
|
|
267
|
+
type: "simple",
|
|
268
|
+
storageClassType: "string",
|
|
269
|
+
},
|
|
270
|
+
last_updated: {
|
|
271
|
+
value: cdktn.stringToHclTerraform(this._lastUpdated),
|
|
272
|
+
isBlock: false,
|
|
273
|
+
type: "simple",
|
|
274
|
+
storageClassType: "string",
|
|
275
|
+
},
|
|
276
|
+
value: {
|
|
277
|
+
value: cdktn.stringToHclTerraform(this._value),
|
|
278
|
+
isBlock: false,
|
|
279
|
+
type: "simple",
|
|
280
|
+
storageClassType: "string",
|
|
281
|
+
},
|
|
282
|
+
timeouts: {
|
|
283
|
+
value: syntheticsSecureCredentialTimeoutsToHclTerraform(this._timeouts.internalValue),
|
|
284
|
+
isBlock: true,
|
|
285
|
+
type: "struct",
|
|
286
|
+
storageClassType: "SyntheticsSecureCredentialTimeouts",
|
|
287
|
+
},
|
|
288
|
+
};
|
|
289
|
+
// remove undefined attributes
|
|
290
|
+
return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined));
|
|
291
|
+
}
|
|
292
|
+
}
|
|
293
|
+
exports.SyntheticsSecureCredential = SyntheticsSecureCredential;
|
|
294
|
+
_b = JSII_RTTI_SYMBOL_1;
|
|
295
|
+
SyntheticsSecureCredential[_b] = { fqn: "@cdktn/provider-newrelic.syntheticsSecureCredential.SyntheticsSecureCredential", version: "14.0.0" };
|
|
296
|
+
// =================
|
|
297
|
+
// STATIC PROPERTIES
|
|
298
|
+
// =================
|
|
299
|
+
SyntheticsSecureCredential.tfResourceType = "newrelic_synthetics_secure_credential";
|
|
300
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvc3ludGhldGljcy1zZWN1cmUtY3JlZGVudGlhbC9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7O0FBaUVBLHNHQVFDO0FBR0QsNEdBZ0JDOztBQW5GRCwrQkFBK0I7QUF3RC9CLFNBQWdCLDZDQUE2QyxDQUFDLE1BQStEO0lBQzNILElBQUksQ0FBQyxLQUFLLENBQUMsVUFBVSxDQUFDLE1BQU0sQ0FBQyxJQUFJLEtBQUssQ0FBQyxZQUFZLENBQUMsWUFBWSxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUM7UUFBQyxPQUFPLE1BQU0sQ0FBQztJQUFDLENBQUM7SUFDNUYsSUFBSSxLQUFLLENBQUMsZ0JBQWdCLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQztRQUNuQyxNQUFNLElBQUksS0FBSyxDQUFDLG9IQUFvSCxDQUFDLENBQUM7SUFDeEksQ0FBQztJQUNELE9BQU87UUFDTCxJQUFJLEVBQUUsS0FBSyxDQUFDLGlCQUFpQixDQUFDLE1BQU8sQ0FBQyxJQUFJLENBQUM7S0FDNUMsQ0FBQTtBQUNILENBQUM7QUFHRCxTQUFnQixnREFBZ0QsQ0FBQyxNQUErRDtJQUM5SCxJQUFJLENBQUMsS0FBSyxDQUFDLFVBQVUsQ0FBQyxNQUFNLENBQUMsSUFBSSxLQUFLLENBQUMsWUFBWSxDQUFDLFlBQVksQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDO1FBQUMsT0FBTyxNQUFNLENBQUM7SUFBQyxDQUFDO0lBQzVGLElBQUksS0FBSyxDQUFDLGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUM7UUFDbkMsTUFBTSxJQUFJLEtBQUssQ0FBQyxvSEFBb0gsQ0FBQyxDQUFDO0lBQ3hJLENBQUM7SUFDRCxNQUFNLEtBQUssR0FBRztRQUNaLElBQUksRUFBRTtZQUNKLEtBQUssRUFBRSxLQUFLLENBQUMsb0JBQW9CLENBQUMsTUFBTyxDQUFDLElBQUksQ0FBQztZQUMvQyxPQUFP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QUssU0FBUyxJQUFJLEtBQUssQ0FBQyxLQUFLLEtBQUssU0FBUyxDQUFFLENBQUMsQ0FBQTtJQUM1SCxDQUFDOztBQXZPSCxnRUF3T0M7OztBQXRPQyxvQkFBb0I7QUFDcEIsb0JBQW9CO0FBQ3BCLG9CQUFvQjtBQUNHLHlDQUFjLEdBQUcsdUNBQXVDLEFBQTFDLENBQTJDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgSUJNIENvcnAuIDIwMjEsIDIwMjZcbiAqIFNQRFgtTGljZW5zZS1JZGVudGlmaWVyOiBNUEwtMi4wXG4gKi9cblxuLy8gaHR0cHM6Ly9yZWdpc3RyeS50ZXJyYWZvcm0uaW8vcHJvdmlkZXJzL25ld3JlbGljL25ld3JlbGljLzMuODAuMi9kb2NzL3Jlc291cmNlcy9zeW50aGV0aWNzX3NlY3VyZV9jcmVkZW50aWFsXG4vLyBnZW5lcmF0ZWQgZnJvbSB0ZXJyYWZvcm0gcmVzb3VyY2Ugc2NoZW1hXG5cbmltcG9ydCB7IENvbnN0cnVjdCB9IGZyb20gJ2NvbnN0cnVjdHMnO1xuaW1wb3J0ICogYXMgY2RrdG4gZnJvbSAnY2RrdG4nO1xuXG4vLyBDb25maWd1cmF0aW9uXG5cbmV4cG9ydCBpbnRlcmZhY2UgU3ludGhldGljc1NlY3VyZUNyZWRlbnRpYWxDb25maWcgZXh0ZW5kcyBjZGt0bi5UZXJyYWZvcm1NZXRhQXJndW1lbnRzIHtcbiAgLyoqXG4gICogVGhlIE5ldyBSZWxpYyBhY2NvdW50IElEIHdoZXJlIHlvdSB3YW50IHRvIGNyZWF0ZSB0aGUgc2VjdXJlIGNyZWRlbnRpYWwuXG4gICpcbiAgKiBEb2NzIGF0IFRlcnJhZm9ybSBSZWdpc3RyeToge0BsaW5rIGh0dHBzOi8vcmVnaXN0cnkudGVycmFmb3JtLmlvL3Byb3ZpZGVycy9uZXdyZWxpYy9uZXdyZWxpYy8zLjgwLjIvZG9jcy9yZXNvdXJjZXMvc3ludGhldGljc19zZWN1cmVfY3JlZGVudGlhbCNhY2NvdW50X2lkIFN5bnRoZXRpY3NTZWN1cmVDcmVkZW50aWFsI2FjY291bnRfaWR9XG4gICovXG4gIHJlYWRvbmx5IGFjY291bnRJZD86IG51bWJlcjtcbiAgLyoqXG4gICogVGhlIHNlY3VyZSBjcmVkZW50aWFsJ3MgZGVzY3JpcHRpb24uXG4gICpcbiAgKiBEb2NzIGF0IFRlcnJhZm9ybSBSZWdpc3RyeToge0BsaW5rIGh0dHBzOi8vcmVnaXN0cnkudGVycmFmb3JtLmlvL3Byb3ZpZGVycy9uZXdyZWxpYy9uZXdyZWxpYy8zLjgwLjIvZG9jcy9yZXNvdXJjZXMvc3ludGhldGljc19zZWN1cmVfY3JlZGVudGlhbCNkZXNjcmlwdGlvbiBTeW50aGV0aWNzU2VjdXJlQ3JlZGVudGlhbCNkZXNjcmlwdGlvbn1cbiAgKi9cbiAgcmVhZG9ubHkgZGVzY3JpcHRpb24/OiBzdHJpbmc7XG4gIC8qKlxuICAqIERvY3MgYXQgVGVycmFmb3JtIFJlZ2lzdHJ5OiB7QGxpbmsgaHR0cHM6Ly9yZWdpc3RyeS50ZXJyYWZvcm0uaW8vcHJvdmlkZXJzL25ld3JlbGljL25ld3JlbGljLzMuODAuMi9kb2NzL3Jlc291cmNlcy9zeW50aGV0aWNzX3NlY3VyZV9jcmVkZW50aWFsI2lkIFN5bnRoZXRpY3NTZWN1cmVDcmVkZW50aWFsI2lkfVxuICAqXG4gICogUGxlYXNlIGJlIGF3YXJlIHRoYXQgdGhlIGlkIGZpZWxkIGlzIGF1dG9tYXRpY2FsbHkgYWRkZWQgdG8gYWxsIHJlc291cmNlcyBpbiBUZXJyYWZvcm0gcHJvdmlkZXJzIHVzaW5nIGEgVGVycmFmb3JtIHByb3ZpZGVyIFNESyB2ZXJzaW9uIGJlbG93IDIuXG4gICogSWYgeW91IGV4cGVyaWVuY2UgcHJvYmxlbXMgc2V0dGluZyB0aGlzIHZhbHVlIGl0IG1pZ2h0IG5vdCBiZSBzZXR0YWJsZS4gUGxlYXNlIHRha2UgYSBsb29rIGF0IHRoZSBwcm92aWRlciBkb2N1bWVudGF0aW9uIHRvIGVuc3VyZSBpdCBzaG91bGQgYmUgc2V0dGFibGUuXG4gICovXG4gIHJlYWRvbmx5IGlkPzogc3RyaW5nO1xuICAvKipcbiAgKiBUaGUgc2VjdXJlIGNyZWRlbnRpYWwncyBrZXkgbmFtZS4gUmVnYXJkbGVzcyBvZiB0aGUgY2FzZSB1c2VkIGluIHRoZSBjb25maWd1cmF0aW9uLCB0aGUgcHJvdmlkZXIgd2lsbCBwcm92aWRlIGFuIHVwY2FzZWQga2V5IHRvIHRoZSB1bmRlcmx5aW5nIEFQSS5cbiAgKlxuICAqIERvY3MgYXQgVGVycmFmb3JtIFJlZ2lzdHJ5OiB7QGxpbmsgaHR0cHM6Ly9yZWdpc3RyeS50ZXJyYWZvcm0uaW8vcHJvdmlkZXJzL25ld3JlbGljL25ld3JlbGljLzMuODAuMi9kb2NzL3Jlc291cmNlcy9zeW50aGV0aWNzX3NlY3VyZV9jcmVkZW50aWFsI2tleSBTeW50aGV0aWNzU2VjdXJlQ3JlZGVudGlhbCNrZXl9XG4gICovXG4gIHJlYWRvbmx5IGtleTogc3RyaW5nO1xuICAvKipcbiAgKiBUaGUgdGltZSB0aGUgc2VjdXJlIGNyZWRlbnRpYWwgd2FzIGxhc3QgdXBkYXRlZC5cbiAgKlxuICAqIERvY3MgYXQgVGVycmFmb3JtIFJlZ2lzdHJ5OiB7QGxpbmsgaHR0cHM6Ly9yZWdpc3RyeS50ZXJyYWZvcm0uaW8vcHJvdmlkZXJzL25ld3JlbGljL25ld3JlbGljLzMuODAuMi9kb2NzL3Jlc291cmNlcy9zeW50aGV0aWNzX3NlY3VyZV9jcmVkZW50aWFsI2xhc3RfdXBkYXRlZCBTeW50aGV0aWNzU2VjdXJlQ3JlZGVudGlhbCNsYXN0X3VwZGF0ZWR9XG4gICovXG4gIHJlYWRvbmx5IGxhc3RVcGRhdGVkPzogc3RyaW5nO1xuICAvKipcbiAgKiBUaGUgc2VjdXJlIGNyZWRlbnRpYWwncyB2YWx1ZS5cbiAgKlxuICAqIERvY3MgYXQgVGVycmFmb3JtIFJlZ2lzdHJ5OiB7QGxpbmsgaHR0cHM6Ly9yZWdpc3RyeS50ZXJyYWZvcm0uaW8vcHJvdmlkZXJzL25ld3JlbGljL25ld3JlbGljLzMuODAuMi9kb2NzL3Jlc291cmNlcy9zeW50aGV0aWNzX3NlY3VyZV9jcmVkZW50aWFsI3ZhbHVlIFN5bnRoZXRpY3NTZWN1cmVDcmVkZW50aWFsI3ZhbHVlfVxuICAqL1xuICByZWFkb25seSB2YWx1ZTogc3RyaW5nO1xuICAvKipcbiAgKiB0aW1lb3V0cyBibG9ja1xuICAqXG4gICogRG9jcyBhdCBUZXJyYWZvcm0gUmVnaXN0cnk6IHtAbGluayBodHRwczovL3JlZ2lzdHJ5LnRlcnJhZm9ybS5pby9wcm92aWRlcnMvbmV3cmVsaWMvbmV3cmVsaWMvMy44MC4yL2RvY3MvcmVzb3VyY2VzL3N5bnRoZXRpY3Nfc2VjdXJlX2NyZWRlbnRpYWwjdGltZW91dHMgU3ludGhldGljc1NlY3VyZUNyZWRlbnRpYWwjdGltZW91dHN9XG4gICovXG4gIHJlYWRvbmx5IHRpbWVvdXRzPzogU3ludGhldGljc1NlY3VyZUNyZWRlbnRpYWxUaW1lb3V0cztcbn1cbmV4cG9ydCBpbnRlcmZhY2UgU3ludGhldGljc1NlY3VyZUNyZWRlbnRpYWxUaW1lb3V0cyB7XG4gIC8qKlxuICAqIERvY3MgYXQgVGVycmFmb3JtIFJlZ2lzdHJ5OiB7QGxpbmsgaHR0cHM6Ly9yZWdpc3RyeS50ZXJyYWZvcm0uaW8vcHJvdmlkZXJzL25ld3JlbGljL25ld3JlbGljLzMuODAuMi9kb2NzL3Jlc291cmNlcy9zeW50aGV0aWNzX3NlY3VyZV9jcmVkZW50aWFsI3JlYWQgU3ludGhldGljc1NlY3VyZUNyZWRlbnRpYWwjcmVhZH1cbiAgKi9cbiAgcmVhZG9ubHkgcmVhZD86IHN0cmluZztcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHN5bnRoZXRpY3NTZWN1cmVDcmVkZW50aWFsVGltZW91dHNUb1RlcnJhZm9ybShzdHJ1Y3Q/OiBTeW50aGV0aWNzU2VjdXJlQ3JlZGVudGlhbFRpbWVvdXRzIHwgY2RrdG4uSVJlc29sdmFibGUpOiBhbnkge1xuICBpZiAoIWNka3RuLmNhbkluc3BlY3Qoc3RydWN0KSB8fCBjZGt0bi5Ub2tlbml6YXRpb24uaXNSZXNvbHZhYmxlKHN0cnVjdCkpIHsgcmV0dXJuIHN0cnVjdDsgfVxuICBpZiAoY2RrdG4uaXNDb21wbGV4RWxlbWVudChzdHJ1Y3QpKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKFwiQSBjb21wbGV4IGVsZW1lbnQgd2FzIHVzZWQgYXMgY29uZmlndXJhdGlvbiwgdGhpcyBpcyBub3Qgc3VwcG9ydGVkOiBodHRwczovL2Nkay50Zi9jb21wbGV4LW9iamVjdC1hcy1jb25maWd1cmF0aW9uXCIpO1xuICB9XG4gIHJldHVybiB7XG4gICAgcmVhZDogY2RrdG4uc3RyaW5nVG9UZXJyYWZvcm0oc3RydWN0IS5yZWFkKSxcbiAgfVxufVxuXG5cbmV4cG9ydCBmdW5jdGlvbiBzeW50aGV0aWNzU2VjdXJlQ3JlZGVudGlhbFRpbWVvdXRzVG9IY2xUZXJyYWZvcm0oc3RydWN0PzogU3ludGhldGljc1NlY3VyZUNyZWRlbnRpYWxUaW1lb3V0cyB8IGNka3RuLklSZXNvbHZhYmxlKTogYW55IHtcbiAgaWYgKCFjZGt0bi5jYW5JbnNwZWN0KHN0cnVjdCkgfHwgY2RrdG4uVG9rZW5pemF0aW9uLmlzUmVzb2x2YWJsZShzdHJ1Y3QpKSB7IHJldHVybiBzdHJ1Y3Q7IH1cbiAgaWYgKGNka3RuLmlzQ29tcGxleEVsZW1lbnQoc3RydWN0KSkge1xuICAgIHRocm93IG5ldyBFcnJvcihcIkEgY29tcGxleCBlbGVtZW50IHdhcyB1c2VkIGFzIGNvbmZpZ3VyYXRpb24sIHRoaXMgaXMgbm90IHN1cHBvcnRlZDogaHR0cHM6Ly9jZGsudGYvY29tcGxleC1vYmplY3QtYXMtY29uZmlndXJhdGlvblwiKTtcbiAgfVxuICBjb25zdCBhdHRycyA9IHtcbiAgICByZWFkOiB7XG4gICAgICB2YWx1ZTogY2RrdG4uc3RyaW5nVG9IY2xUZXJyYWZvcm0oc3RydWN0IS5yZWFkKSxcbiAgICAgIGlzQmxvY2s6IGZhbHNlLFxuICAgICAgdHlwZTogXCJzaW1wbGVcIixcbiAgICAgIHN0b3JhZ2VDbGFzc1R5cGU6IFwic3RyaW5nXCIsXG4gICAgfSxcbiAgfTtcblxuICAvLyByZW1vdmUgdW5kZWZpbmVkIGF0dHJpYnV0ZXNcbiAgcmV0dXJuIE9iamVjdC5mcm9tRW50cmllcyhPYmplY3QuZW50cmllcyhhdHRycykuZmlsdGVyKChbXywgdmFsdWVdKSA9PiB2YWx1ZSAhPT0gdW5kZWZpbmVkICYmIHZhbHVlLnZhbHVlICE9PSB1bmRlZmluZWQpKTtcbn1cblxuZXhwb3J0IGNsYXNzIFN5bnRoZXRpY3NTZWN1cmVDcmVkZW50aWFsVGltZW91dHNPdXRwdXRSZWZlcmVuY2UgZXh0ZW5kcyBjZGt0bi5Db21wbGV4T2JqZWN0IHtcbiAgcHJpdmF0ZSBpc0VtcHR5T2JqZWN0ID0gZmFsc2U7XG4gIHByaXZhdGUgcmVzb2x2YWJsZVZhbHVlPzogY2RrdG4uSVJlc29sdmFibGU7XG5cbiAgLyoqXG4gICogQHBhcmFtIHRlcnJhZm9ybVJlc291cmNlIFRoZSBwYXJlbnQgcmVzb3VyY2VcbiAgKiBAcGFyYW0gdGVycmFmb3JtQXR0cmlidXRlIFRoZSBhdHRyaWJ1dGUgb24gdGhlIHBhcmVudCByZXNvdXJjZSB0aGlzIGNsYXNzIGlzIHJlZmVyZW5jaW5nXG4gICovXG4gIHB1YmxpYyBjb25zdHJ1Y3Rvcih0ZXJyYWZvcm1SZXNvdXJjZTogY2RrdG4uSUludGVycG9sYXRpbmdQYXJlbnQsIHRlcnJhZm9ybUF0dHJpYnV0ZTogc3RyaW5nKSB7XG4gICAgc3VwZXIodGVycmFmb3JtUmVzb3VyY2UsIHRlcnJhZm9ybUF0dHJpYnV0ZSwgZmFsc2UpO1xuICB9XG5cbiAgcHVibGljIGdldCBpbnRlcm5hbFZhbHVlKCk6IFN5bnRoZXRpY3NTZWN1cmVDcmVkZW50aWFsVGltZW91dHMgfCBjZGt0bi5JUmVzb2x2YWJsZSB8IHVuZGVmaW5lZCB7XG4gICAgaWYgKHRoaXMucmVzb2x2YWJsZVZhbHVlKSB7XG4gICAgICByZXR1cm4gdGhpcy5yZXNvbHZhYmxlVmFsdWU7XG4gICAgfVxuICAgIGxldCBoYXNBbnlWYWx1ZXMgPSB0aGlzLmlzRW1wdHlPYmplY3Q7XG4gICAgY29uc3QgaW50ZXJuYWxWYWx1ZVJlc3VsdDogYW55ID0ge307XG4gICAgaWYgKHRoaXMuX3JlYWQgIT09IHVuZGVmaW5lZCkge1xuICAgICAgaGFzQW55VmFsdWVzID0gdHJ1ZTtcbiAgICAgIGludGVybmFsVmFsdWVSZXN1bHQucmVhZCA9IHRoaXMuX3JlYWQ7XG4gICAgfVxuICAgIHJldHVybiBoYXNBbnlWYWx1ZXMgPyBpbnRlcm5hbFZhbHVlUmVzdWx0IDogdW5kZWZpbmVkO1xuICB9XG5cbiAgcHVibGljIHNldCBpbnRlcm5hbFZhbHVlKHZhbHVlOiBTeW50aGV0aWNzU2VjdXJlQ3JlZGVudGlhbFRpbWVvdXRzIHwgY2RrdG4uSVJlc29sdmFibGUgfCB1bmRlZmluZWQpIHtcbiAgICBpZiAodmFsdWUgPT09IHVuZGVmaW5lZCkge1xuICAgICAgdGhpcy5pc0VtcHR5T2JqZWN0ID0gZmFsc2U7XG4gICAgICB0aGlzLnJlc29sdmFibGVWYWx1ZSA9IHVuZGVmaW5lZDtcbiAgICAgIHRoaXMuX3JlYWQgPSB1bmRlZmluZWQ7XG4gICAgfVxuICAgIGVsc2UgaWYgKGNka3RuLlRva2VuaXphdGlvbi5pc1Jlc29sdmFibGUodmFsdWUpKSB7XG4gICAgICB0aGlzLmlzRW1wdHlPYmplY3QgPSBmYWxzZTtcbiAgICAgIHRoaXMucmVzb2x2YWJsZVZhbHVlID0gdmFsdWU7XG4gICAgfVxuICAgIGVsc2Uge1xuICAgICAgdGhpcy5pc0VtcHR5T2JqZWN0ID0gT2JqZWN0LmtleXModmFsdWUpLmxlbmd0aCA9PT0gMDtcbiAgICAgIHRoaXMucmVzb2x2YWJsZVZhbHVlID0gdW5kZWZpbmVkO1xuICAgICAgdGhpcy5fcmVhZCA9IHZhbHVlLnJlYWQ7XG4gICAgfVxuICB9XG5cbiAgLy8gcmVhZCAtIGNvbXB1dGVkOiBmYWxzZSwgb3B0aW9uYWw6IHRydWUsIHJlcXVpcmVkOiBmYWxzZVxuICBwcml2YXRlIF9yZWFkPzogc3RyaW5nOyBcbiAgcHVibGljIGdldCByZWFkKCkge1xuICAgIHJldHVybiB0aGlzLmdldFN0cmluZ0F0dHJpYnV0ZSgncmVhZCcpO1xuICB9XG4gIHB1YmxpYyBzZXQgcmVhZCh2YWx1ZTogc3RyaW5nKSB7XG4gICAgdGhpcy5fcmVhZCA9IHZhbHVlO1xuICB9XG4gIHB1YmxpYyByZXNldFJlYWQoKSB7XG4gICAgdGhpcy5fcmVhZCA9IHVuZGVmaW5lZDtcbiAgfVxuICAvLyBUZW1wb3JhcmlseSBleHBvc2UgaW5wdXQgdmFsdWUuIFVzZSB3aXRoIGNhdXRpb24uXG4gIHB1YmxpYyBnZXQgcmVhZElucHV0KCkge1xuICAgIHJldHVybiB0aGlzLl9yZWFkO1xuICB9XG59XG5cbi8qKlxuKiBSZXByZXNlbnRzIGEge0BsaW5rIGh0dHBzOi8vcmVnaXN0cnkudGVycmFmb3JtLmlvL3Byb3ZpZGVycy9uZXdyZWxpYy9uZXdyZWxpYy8zLjgwLjIvZG9jcy9yZXNvdXJjZXMvc3ludGhldGljc19zZWN1cmVfY3JlZGVudGlhbCBuZXdyZWxpY19zeW50aGV0aWNzX3NlY3VyZV9jcmVkZW50aWFsfVxuKi9cbmV4cG9ydCBjbGFzcyBTeW50aGV0aWNzU2VjdXJlQ3JlZGVudGlhbCBleHRlbmRzIGNka3RuLlRlcnJhZm9ybVJlc291cmNlIHtcblxuICAvLyA9PT09PT09PT09PT09PT09PVxuICAvLyBTVEFUSUMgUFJPUEVSVElFU1xuICAvLyA9PT09PT09PT09PT09PT09PVxuICBwdWJsaWMgc3RhdGljIHJlYWRvbmx5IHRmUmVzb3VyY2VUeXBlID0gXCJuZXdyZWxpY19zeW50aGV0aWNzX3NlY3VyZV9jcmVkZW50aWFsXCI7XG5cbiAgLy8gPT09PT09PT09PT09PT1cbiAgLy8gU1RBVElDIE1ldGhvZHNcbiAgLy8gPT09PT09PT09PT09PT1cbiAgLyoqXG4gICogR2VuZXJhdGVzIENES1ROIGNvZGUgZm9yIGltcG9ydGluZyBhIFN5bnRoZXRpY3NTZWN1cmVDcmVkZW50aWFsIHJlc291cmNlIHVwb24gcnVubmluZyBcImNka3RuIHBsYW4gPHN0YWNrLW5hbWU+XCJcbiAgKiBAcGFyYW0gc2NvcGUgVGhlIHNjb3BlIGluIHdoaWNoIHRvIGRlZmluZSB0aGlzIGNvbnN0cnVjdFxuICAqIEBwYXJhbSBpbXBvcnRUb0lkIFRoZSBjb25zdHJ1Y3QgaWQgdXNlZCBpbiB0aGUgZ2VuZXJhdGVkIGNvbmZpZyBmb3IgdGhlIFN5bnRoZXRpY3NTZWN1cmVDcmVkZW50aWFsIHRvIGltcG9ydFxuICAqIEBwYXJhbSBpbXBvcnRGcm9tSWQgVGhlIGlkIG9mIHRoZSBleGlzdGluZyBTeW50aGV0aWNzU2VjdXJlQ3JlZGVudGlhbCB0aGF0IHNob3VsZCBiZSBpbXBvcnRlZC4gUmVmZXIgdG8gdGhlIHtAbGluayBodHRwczovL3JlZ2lzdHJ5LnRlcnJhZm9ybS5pby9wcm92aWRlcnMvbmV3cmVsaWMvbmV3cmVsaWMvMy44MC4yL2RvY3MvcmVzb3VyY2VzL3N5bnRoZXRpY3Nfc2VjdXJlX2NyZWRlbnRpYWwjaW1wb3J0IGltcG9ydCBzZWN0aW9ufSBpbiB0aGUgZG9jdW1lbnRhdGlvbiBvZiB0aGlzIHJlc291cmNlIGZvciB0aGUgaWQgdG8gdXNlXG4gICogQHBhcmFtIHByb3ZpZGVyPyBPcHRpb25hbCBpbnN0YW5jZSBvZiB0aGUgcHJvdmlkZXIgd2hlcmUgdGhlIFN5bnRoZXRpY3NTZWN1cmVDcmVkZW50aWFsIHRvIGltcG9ydCBpcyBmb3VuZFxuICAqL1xuICBwdWJsaWMgc3RhdGljIGdlbmVyYXRlQ29uZmlnRm9ySW1wb3J0KHNjb3BlOiBDb25zdHJ1Y3QsIGltcG9ydFRvSWQ6IHN0cmluZywgaW1wb3J0RnJvbUlkOiBzdHJpbmcsIHByb3ZpZGVyPzogY2RrdG4uVGVycmFmb3JtUHJvdmlkZXIpIHtcbiAgICAgICAgcmV0dXJuIG5ldyBjZGt0bi5JbXBvcnRhYmxlUmVzb3VyY2Uoc2NvcGUsIGltcG9ydFRvSWQsIHsgdGVycmFmb3JtUmVzb3VyY2VUeXBlOiBcIm5ld3JlbGljX3N5bnRoZXRpY3Nfc2VjdXJlX2NyZWRlbnRpYWxcIiwgaW1wb3J0SWQ6IGltcG9ydEZyb21JZCwgcHJvdmlkZXIgfSk7XG4gICAgICB9XG5cbiAgLy8gPT09PT09PT09PT1cbiAgLy8gSU5JVElBTElaRVJcbiAgLy8gPT09PT09PT09PT1cblxuICAvKipcbiAgKiBDcmVhdGUgYSBuZXcge0BsaW5rIGh0dHBzOi8vcmVnaXN0cnkudGVycmFmb3JtLmlvL3Byb3ZpZGVycy9uZXdyZWxpYy9uZXdyZWxpYy8zLjgwLjIvZG9jcy9yZXNvdXJjZXMvc3ludGhldGljc19zZWN1cmVfY3JlZGVudGlhbCBuZXdyZWxpY19zeW50aGV0aWNzX3NlY3VyZV9jcmVkZW50aWFsfSBSZXNvdXJjZVxuICAqXG4gICogQHBhcmFtIHNjb3BlIFRoZSBzY29wZSBpbiB3aGljaCB0byBkZWZpbmUgdGhpcyBjb25zdHJ1Y3RcbiAgKiBAcGFyYW0gaWQgVGhlIHNjb3BlZCBjb25zdHJ1Y3QgSUQuIE11c3QgYmUgdW5pcXVlIGFtb25nc3Qgc2libGluZ3MgaW4gdGhlIHNhbWUgc2NvcGVcbiAgKiBAcGFyYW0gb3B0aW9ucyBTeW50aGV0aWNzU2VjdXJlQ3JlZGVudGlhbENvbmZpZ1xuICAqL1xuICBwdWJsaWMgY29uc3RydWN0b3Ioc2NvcGU6IENvbnN0cnVjdCwgaWQ6IHN0cmluZywgY29uZmlnOiBTeW50aGV0aWNzU2VjdXJlQ3JlZGVudGlhbENvbmZpZykge1xuICAgIHN1cGVyKHNjb3BlLCBpZCwge1xuICAgICAgdGVycmFmb3JtUmVzb3VyY2VUeXBlOiAnbmV3cmVsaWNfc3ludGhldGljc19zZWN1cmVfY3JlZGVudGlhbCcsXG4gICAgICB0ZXJyYWZvcm1HZW5lcmF0b3JNZXRhZGF0YToge1xuICAgICAgICBwcm92aWRlck5hbWU6ICduZXdyZWxpYycsXG4gICAgICAgIHByb3ZpZGVyVmVyc2lvbjogJzMuODAuMicsXG4gICAgICAgIHByb3ZpZGVyVmVyc2lvbkNvbnN0cmFpbnQ6ICd+PiAzLjcnXG4gICAgICB9LFxuICAgICAgcHJvdmlkZXI6IGNvbmZpZy5wcm92aWRlcixcbiAgICAgIGRlcGVuZHNPbjogY29uZmlnLmRlcGVuZHNPbixcbiAgICAgIGNvdW50OiBjb25maWcuY291bnQsXG4gICAgICBsaWZlY3ljbGU6IGNvbmZpZy5saWZlY3ljbGUsXG4gICAgICBwcm92aXNpb25lcnM6IGNvbmZpZy5wcm92aXNpb25lcnMsXG4gICAgICBjb25uZWN0aW9uOiBjb25maWcuY29ubmVjdGlvbixcbiAgICAgIGZvckVhY2g6IGNvbmZpZy5mb3JFYWNoXG4gICAgfSk7XG4gICAgdGhpcy5fYWNjb3VudElkID0gY29uZmlnLmFjY291bnRJZDtcbiAgICB0aGlzLl9kZXNjcmlwdGlvbiA9IGNvbmZpZy5kZXNjcmlwdGlvbjtcbiAgICB0aGlzLl9pZCA9IGNvbmZpZy5pZDtcbiAgICB0aGlzLl9rZXkgPSBjb25maWcua2V5O1xuICAgIHRoaXMuX2xhc3RVcGRhdGVkID0gY29uZmlnLmxhc3RVcGRhdGVkO1xuICAgIHRoaXMuX3ZhbHVlID0gY29uZmlnLnZhbHVlO1xuICAgIHRoaXMuX3RpbWVvdXRzLmludGVybmFsVmFsdWUgPSBjb25maWcudGltZW91dHM7XG4gIH1cblxuICAvLyA9PT09PT09PT09XG4gIC8vIEFUVFJJQlVURVNcbiAgLy8gPT09PT09PT09PVxuXG4gIC8vIGFjY291bnRfaWQgLSBjb21wdXRlZDogdHJ1ZSwgb3B0aW9uYWw6IHRydWUsIHJlcXVpcmVkOiBmYWxzZVxuICBwcml2YXRlIF9hY2NvdW50SWQ/OiBudW1iZXI7IFxuICBwdWJsaWMgZ2V0IGFjY291bnRJZCgpIHtcbiAgICByZXR1cm4gdGhpcy5nZXROdW1iZXJBdHRyaWJ1dGUoJ2FjY291bnRfaWQnKTtcbiAgfVxuICBwdWJsaWMgc2V0IGFjY291bnRJZCh2YWx1ZTogbnVtYmVyKSB7XG4gICAgdGhpcy5fYWNjb3VudElkID0gdmFsdWU7XG4gIH1cbiAgcHVibGljIHJlc2V0QWNjb3VudElkKCkge1xuICAgIHRoaXMuX2FjY291bnRJZCA9IHVuZGVmaW5lZDtcbiAgfVxuICAvLyBUZW1wb3JhcmlseSBleHBvc2UgaW5wdXQgdmFsdWUuIFVzZSB3aXRoIGNhdXRpb24uXG4gIHB1YmxpYyBnZXQgYWNjb3VudElkSW5wdXQoKSB7XG4gICAgcmV0dXJuIHRoaXMuX2FjY291bnRJZDtcbiAgfVxuXG4gIC8vIGRlc2NyaXB0aW9uIC0gY29tcHV0ZWQ6IGZhbHNlLCBvcHRpb25hbDogdHJ1ZSwgcmVxdWlyZWQ6IGZhbHNlXG4gIHByaXZhdGUgX2Rlc2NyaXB0aW9uPzogc3RyaW5nOyBcbiAgcHVibGljIGdldCBkZXNjcmlwdGlvbigpIHtcbiAgICByZXR1cm4gdGhpcy5nZXRTdHJpbmdBdHRyaWJ1dGUoJ2Rlc2NyaXB0aW9uJyk7XG4gIH1cbiAgcHVibGljIHNldCBkZXNjcmlwdGlvbih2YWx1ZTogc3RyaW5nKSB7XG4gICAgdGhpcy5fZGVzY3JpcHRpb24gPSB2YWx1ZTtcbiAgfVxuICBwdWJsaWMgcmVzZXREZXNjcmlwdGlvbigpIHtcbiAgICB0aGlzLl9kZXNjcmlwdGlvbiA9IHVuZGVmaW5lZDtcbiAgfVxuICAvLyBUZW1wb3JhcmlseSBleHBvc2UgaW5wdXQgdmFsdWUuIFVzZSB3aXRoIGNhdXRpb24uXG4gIHB1YmxpYyBnZXQgZGVzY3JpcHRpb25JbnB1dCgpIHtcbiAgICByZXR1cm4gdGhpcy5fZGVzY3JpcHRpb247XG4gIH1cblxuICAvLyBpZCAtIGNvbXB1dGVkOiB0cnVlLCBvcHRpb25hbDogdHJ1ZSwgcmVxdWlyZWQ6IGZhbHNlXG4gIHByaXZhdGUgX2lkPzogc3RyaW5nOyBcbiAgcHVibGljIGdldCBpZCgpIHtcbiAgICByZXR1cm4gdGhpcy5nZXRTdHJpbmdBdHRyaWJ1dGUoJ2lkJyk7XG4gIH1cbiAgcHVibGljIHNldCBpZCh2YWx1ZTogc3RyaW5nKSB7XG4gICAgdGhpcy5faWQgPSB2YWx1ZTtcbiAgfVxuICBwdWJsaWMgcmVzZXRJZCgpIHtcbiAgICB0aGlzLl9pZCA9IHVuZGVmaW5lZDtcbiAgfVxuICAvLyBUZW1wb3JhcmlseSBleHBvc2UgaW5wdXQgdmFsdWUuIFVzZSB3aXRoIGNhdXRpb24uXG4gIHB1YmxpYyBnZXQgaWRJbnB1dCgpIHtcbiAgICByZXR1cm4gdGhpcy5faWQ7XG4gIH1cblxuICAvLyBrZXkgLSBjb21wdXRlZDogZmFsc2UsIG9wdGlvbmFsOiBmYWxzZSwgcmVxdWlyZWQ6IHRydWVcbiAgcHJpdmF0ZSBfa2V5Pzogc3RyaW5nOyBcbiAgcHVibGljIGdldCBrZXkoKSB7XG4gICAgcmV0dXJuIHRoaXMuZ2V0U3RyaW5nQXR0cmlidXRlKCdrZXknKTtcbiAgfVxuICBwdWJsaWMgc2V0IGtleSh2YWx1ZTogc3RyaW5nKSB7XG4gICAgdGhpcy5fa2V5ID0gdmFsdWU7XG4gIH1cbiAgLy8gVGVtcG9yYXJpbHkgZXhwb3NlIGlucHV0IHZhbHVlLiBVc2Ugd2l0aCBjYXV0aW9uLlxuICBwdWJsaWMgZ2V0IGtleUlucHV0KCkge1xuICAgIHJldHVybiB0aGlzLl9rZXk7XG4gIH1cblxuICAvLyBsYXN0X3VwZGF0ZWQgLSBjb21wdXRlZDogdHJ1ZSwgb3B0aW9uYWw6IHRydWUsIHJlcXVpcmVkOiBmYWxzZVxuICBwcml2YXRlIF9sYXN0VXBkYXRlZD86IHN0cmluZzsgXG4gIHB1YmxpYyBnZXQgbGFzdFVwZGF0ZWQoKSB7XG4gICAgcmV0dXJuIHRoaXMuZ2V0U3RyaW5nQXR0cmlidXRlKCdsYXN0X3VwZGF0ZWQnKTtcbiAgfVxuICBwdWJsaWMgc2V0IGxhc3RVcGRhdGVkKHZhbHVlOiBzdHJpbmcpIHtcbiAgICB0aGlzLl9sYXN0VXBkYXRlZCA9IHZhbHVlO1xuICB9XG4gIHB1YmxpYyByZXNldExhc3RVcGRhdGVkKCkge1xuICAgIHRoaXMuX2xhc3RVcGRhdGVkID0gdW5kZWZpbmVkO1xuICB9XG4gIC8vIFRlbXBvcmFyaWx5IGV4cG9zZSBpbnB1dCB2YWx1ZS4gVXNlIHdpdGggY2F1dGlvbi5cbiAgcHVibGljIGdldCBsYXN0VXBkYXRlZElucHV0KCkge1xuICAgIHJldHVybiB0aGlzLl9sYXN0VXBkYXRlZDtcbiAgfVxuXG4gIC8vIHZhbHVlIC0gY29tcHV0ZWQ6IGZhbHNlLCBvcHRpb25hbDogZmFsc2UsIHJlcXVpcmVkOiB0cnVlXG4gIHByaXZhdGUgX3ZhbHVlPzogc3RyaW5nOyBcbiAgcHVibGljIGdldCB2YWx1ZSgpIHtcbiAgICByZXR1cm4gdGhpcy5nZXRTdHJpbmdBdHRyaWJ1dGUoJ3ZhbHVlJyk7XG4gIH1cbiAgcHVibGljIHNldCB2YWx1ZSh2YWx1ZTogc3RyaW5nKSB7XG4gICAgdGhpcy5fdmFsdWUgPSB2YWx1ZTtcbiAgfVxuICAvLyBUZW1wb3JhcmlseSBleHBvc2UgaW5wdXQgdmFsdWUuIFVzZSB3aXRoIGNhdXRpb24uXG4gIHB1YmxpYyBnZXQgdmFsdWVJbnB1dCgpIHtcbiAgICByZXR1cm4gdGhpcy5fdmFsdWU7XG4gIH1cblxuICAvLyB0aW1lb3V0cyAtIGNvbXB1dGVkOiBmYWxzZSwgb3B0aW9uYWw6IHRydWUsIHJlcXVpcmVkOiBmYWxzZVxuICBwcml2YXRlIF90aW1lb3V0cyA9IG5ldyBTeW50aGV0aWNzU2VjdXJlQ3JlZGVudGlhbFRpbWVvdXRzT3V0cHV0UmVmZXJlbmNlKHRoaXMsIFwidGltZW91dHNcIik7XG4gIHB1YmxpYyBnZXQgdGltZW91dHMoKSB7XG4gICAgcmV0dXJuIHRoaXMuX3RpbWVvdXRzO1xuICB9XG4gIHB1YmxpYyBwdXRUaW1lb3V0cyh2YWx1ZTogU3ludGhldGljc1NlY3VyZUNyZWRlbnRpYWxUaW1lb3V0cykge1xuICAgIHRoaXMuX3RpbWVvdXRzLmludGVybmFsVmFsdWUgPSB2YWx1ZTtcbiAgfVxuICBwdWJsaWMgcmVzZXRUaW1lb3V0cygpIHtcbiAgICB0aGlzLl90aW1lb3V0cy5pbnRlcm5hbFZhbHVlID0gdW5kZWZpbmVkO1xuICB9XG4gIC8vIFRlbXBvcmFyaWx5IGV4cG9zZSBpbnB1dCB2YWx1ZS4gVXNlIHdpdGggY2F1dGlvbi5cbiAgcHVibGljIGdldCB0aW1lb3V0c0lucHV0KCkge1xuICAgIHJldHVybiB0aGlzLl90aW1lb3V0cy5pbnRlcm5hbFZhbHVlO1xuICB9XG5cbiAgLy8gPT09PT09PT09XG4gIC8vIFNZTlRIRVNJU1xuICAvLyA9PT09PT09PT1cblxuICBwcm90ZWN0ZWQgc3ludGhlc2l6ZUF0dHJpYnV0ZXMoKTogeyBbbmFtZTogc3RyaW5nXTogYW55IH0ge1xuICAgIHJldHVybiB7XG4gICAgICBhY2NvdW50X2lkOiBjZGt0bi5udW1iZXJUb1RlcnJhZm9ybSh0aGlzLl9hY2NvdW50SWQpLFxuICAgICAgZGVzY3JpcHRpb246IGNka3RuLnN0cmluZ1RvVGVycmFmb3JtKHRoaXMuX2Rlc2NyaXB0aW9uKSxcbiAgICAgIGlkOiBjZGt0bi5zdHJpbmdUb1RlcnJhZm9ybSh0aGlzLl9pZCksXG4gICAgICBrZXk6IGNka3RuLnN0cmluZ1RvVGVycmFmb3JtKHRoaXMuX2tleSksXG4gICAgICBsYXN0X3VwZGF0ZWQ6IGNka3RuLnN0cmluZ1RvVGVycmFmb3JtKHRoaXMuX2xhc3RVcGRhdGVkKSxcbiAgICAgIHZhbHVlOiBjZGt0bi5zdHJpbmdUb1RlcnJhZm9ybSh0aGlzLl92YWx1ZSksXG4gICAgICB0aW1lb3V0czogc3ludGhldGljc1NlY3VyZUNyZWRlbnRpYWxUaW1lb3V0c1RvVGVycmFmb3JtKHRoaXMuX3RpbWVvdXRzLmludGVybmFsVmFsdWUpLFxuICAgIH07XG4gIH1cblxuICBwcm90ZWN0ZWQgc3ludGhlc2l6ZUhjbEF0dHJpYnV0ZXMoKTogeyBbbmFtZTogc3RyaW5nXTogYW55IH0ge1xuICAgIGNvbnN0IGF0dHJzID0ge1xuICAgICAgYWNjb3VudF9pZDoge1xuICAgICAgICB2YWx1ZTogY2RrdG4ubnVtYmVyVG9IY2xUZXJyYWZvcm0odGhpcy5fYWNjb3VudElkKSxcbiAgICAgICAgaXNCbG9jazogZmFsc2UsXG4gICAgICAgIHR5cGU6IFwic2ltcGxlXCIsXG4gICAgICAgIHN0b3JhZ2VDbGFzc1R5cGU6IFwibnVtYmVyXCIsXG4gICAgICB9LFxuICAgICAgZGVzY3JpcHRpb246IHtcbiAgICAgICAgdmFsdWU6IGNka3RuLnN0cmluZ1RvSGNsVGVycmFmb3JtKHRoaXMuX2Rlc2NyaXB0aW9uKSxcbiAgICAgICAgaXNCbG9jazogZmFsc2UsXG4gICAgICAgIHR5cGU6IFwic2ltcGxlXCIsXG4gICAgICAgIHN0b3JhZ2VDbGFzc1R5cGU6IFwic3RyaW5nXCIsXG4gICAgICB9LFxuICAgICAgaWQ6IHtcbiAgICAgICAgdmFsdWU6IGNka3RuLnN0cmluZ1RvSGNsVGVycmFmb3JtKHRoaXMuX2lkKSxcbiAgICAgICAgaXNCbG9jazogZmFsc2UsXG4gICAgICAgIHR5cGU6IFwic2ltcGxlXCIsXG4gICAgICAgIHN0b3JhZ2VDbGFzc1R5cGU6IFwic3RyaW5nXCIsXG4gICAgICB9LFxuICAgICAga2V5OiB7XG4gICAgICAgIHZhbHVlOiBjZGt0bi5zdHJpbmdUb0hjbFRlcnJhZm9ybSh0aGlzLl9rZXkpLFxuICAgICAgICBpc0Jsb2NrOiBmYWxzZSxcbiAgICAgICAgdHlwZTogXCJzaW1wbGVcIixcbiAgICAgICAgc3RvcmFnZUNsYXNzVHlwZTogXCJzdHJpbmdcIixcbiAgICAgIH0sXG4gICAgICBsYXN0X3VwZGF0ZWQ6IHtcbiAgICAgICAgdmFsdWU6IGNka3RuLnN0cmluZ1RvSGNsVGVycmFmb3JtKHRoaXMuX2xhc3RVcGRhdGVkKSxcbiAgICAgICAgaXNCbG9jazogZmFsc2UsXG4gICAgICAgIHR5cGU6IFwic2ltcGxlXCIsXG4gICAgICAgIHN0b3JhZ2VDbGFzc1R5cGU6IFwic3RyaW5nXCIsXG4gICAgICB9LFxuICAgICAgdmFsdWU6IHtcbiAgICAgICAgdmFsdWU6IGNka3RuLnN0cmluZ1RvSGNsVGVycmFmb3JtKHRoaXMuX3ZhbHVlKSxcbiAgICAgICAgaXNCbG9jazogZmFsc2UsXG4gICAgICAgIHR5cGU6IFwic2ltcGxlXCIsXG4gICAgICAgIHN0b3JhZ2VDbGFzc1R5cGU6IFwic3RyaW5nXCIsXG4gICAgICB9LFxuICAgICAgdGltZW91dHM6IHtcbiAgICAgICAgdmFsdWU6IHN5bnRoZXRpY3NTZWN1cmVDcmVkZW50aWFsVGltZW91dHNUb0hjbFRlcnJhZm9ybSh0aGlzLl90aW1lb3V0cy5pbnRlcm5hbFZhbHVlKSxcbiAgICAgICAgaXNCbG9jazogdHJ1ZSxcbiAgICAgICAgdHlwZTogXCJzdHJ1Y3RcIixcbiAgICAgICAgc3RvcmFnZUNsYXNzVHlwZTogXCJTeW50aGV0aWNzU2VjdXJlQ3JlZGVudGlhbFRpbWVvdXRzXCIsXG4gICAgICB9LFxuICAgIH07XG5cbiAgICAvLyByZW1vdmUgdW5kZWZpbmVkIGF0dHJpYnV0ZXNcbiAgICByZXR1cm4gT2JqZWN0LmZyb21FbnRyaWVzKE9iamVjdC5lbnRyaWVzKGF0dHJzKS5maWx0ZXIoKFtfLCB2YWx1ZV0pID0+IHZhbHVlICE9PSB1bmRlZmluZWQgJiYgdmFsdWUudmFsdWUgIT09IHVuZGVmaW5lZCApKVxuICB9XG59XG4iXX0=
|