@horietakehiro/aws-cdk-utul 0.41.63 → 0.41.65

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.
Files changed (33) hide show
  1. package/lib/types/cfn-resource-types/aws-bedrockagentcore-gatewaytarget.d.ts +25 -2
  2. package/lib/types/cfn-resource-types/aws-bedrockagentcore-gatewaytarget.js +1 -1
  3. package/lib/types/cfn-resource-types/aws-bedrockagentcore-runtime.d.ts +63 -0
  4. package/lib/types/cfn-resource-types/aws-bedrockagentcore-runtime.js +1 -1
  5. package/lib/types/cfn-resource-types/aws-datazone-environment.d.ts +12 -0
  6. package/lib/types/cfn-resource-types/aws-datazone-environment.js +1 -1
  7. package/lib/types/cfn-resource-types/aws-ec2-natgateway.d.ts +0 -26
  8. package/lib/types/cfn-resource-types/aws-ec2-natgateway.js +1 -1
  9. package/lib/types/cfn-resource-types/aws-ec2-vpcendpoint.d.ts +5 -0
  10. package/lib/types/cfn-resource-types/aws-ec2-vpcendpoint.js +1 -1
  11. package/lib/types/cfn-resource-types/aws-emrcontainers-endpoint.d.ts +123 -0
  12. package/lib/types/cfn-resource-types/aws-emrcontainers-endpoint.js +3 -0
  13. package/lib/types/cfn-resource-types/aws-emrcontainers-securityconfiguration.d.ts +206 -0
  14. package/lib/types/cfn-resource-types/aws-emrcontainers-securityconfiguration.js +3 -0
  15. package/lib/types/cfn-resource-types/aws-gamelift-containerfleet.d.ts +154 -140
  16. package/lib/types/cfn-resource-types/aws-gamelift-containerfleet.js +1 -1
  17. package/lib/types/cfn-resource-types/aws-gamelift-fleet.d.ts +137 -123
  18. package/lib/types/cfn-resource-types/aws-gamelift-fleet.js +1 -1
  19. package/lib/types/cfn-resource-types/aws-iot-command.d.ts +43 -0
  20. package/lib/types/cfn-resource-types/aws-iot-command.js +1 -1
  21. package/lib/types/cfn-resource-types/aws-lightsail-databasesnapshot.d.ts +97 -0
  22. package/lib/types/cfn-resource-types/aws-lightsail-databasesnapshot.js +3 -0
  23. package/lib/types/cfn-resource-types/aws-medialive-channel.d.ts +13 -0
  24. package/lib/types/cfn-resource-types/aws-medialive-channel.js +1 -1
  25. package/lib/types/cfn-resource-types/aws-opensearchserverless-collection.d.ts +41 -23
  26. package/lib/types/cfn-resource-types/aws-opensearchserverless-collection.js +1 -1
  27. package/lib/types/cfn-resource-types/aws-organizations-policy.d.ts +2 -2
  28. package/lib/types/cfn-resource-types/aws-organizations-policy.js +1 -1
  29. package/lib/types/cfn-resource-types/aws-ses-configurationset.d.ts +10 -0
  30. package/lib/types/cfn-resource-types/aws-ses-configurationset.js +1 -1
  31. package/lib/types/cfn-resource-types.d.ts +6 -0
  32. package/lib/types/cfn-resource-types.js +26 -20
  33. package/package.json +1 -1
@@ -9,18 +9,24 @@ export interface _AWS_GAMELIFT_FLEET {
9
9
  * @maxItems 50
10
10
  */
11
11
  ScalingPolicies?: ScalingPolicy[];
12
+ AnywhereConfiguration?: AnywhereConfiguration;
12
13
  /**
13
- * A human-readable description of a fleet.
14
+ * Determines when and how to apply fleet or location capacities. Allowed options are ON_UPDATE (default), ON_CREATE_AND_UPDATE and ON_CREATE_AND_UPDATE_WITH_AUTOSCALING. If you choose ON_CREATE_AND_UPDATE_WITH_AUTOSCALING, MinSize and MaxSize will still be applied on creation and on updates, but DesiredEC2Instances will only be applied once on fleet creation and will be ignored during updates to prevent conflicts with auto-scaling. During updates with ON_CREATE_AND_UPDATE_WITH_AUTOSCALING chosen, if current desired instance is lower than the new MinSize, it will be increased to the new MinSize; if current desired instance is larger than the new MaxSize, it will be decreased to the new MaxSize.
14
15
  */
15
- Description?: string;
16
+ ApplyCapacity?: ("ON_UPDATE" | "ON_CREATE_AND_UPDATE" | "ON_CREATE_AND_UPDATE_WITH_AUTOSCALING");
17
+ CertificateConfiguration?: CertificateConfiguration;
16
18
  /**
17
- * A unique identifier for a VPC with resources to be accessed by your Amazon GameLift fleet. The VPC must be in the same Region as your fleet. To look up a VPC ID, use the VPC Dashboard in the AWS Management Console.
19
+ * ComputeType to differentiate EC2 hardware managed by GameLift and Anywhere hardware managed by the customer.
18
20
  */
19
- PeerVpcId?: string;
21
+ ComputeType?: ("EC2" | "ANYWHERE");
20
22
  /**
21
- * Determines when and how to apply fleet or location capacities. Allowed options are ON_UPDATE (default), ON_CREATE_AND_UPDATE and ON_CREATE_AND_UPDATE_WITH_AUTOSCALING. If you choose ON_CREATE_AND_UPDATE_WITH_AUTOSCALING, MinSize and MaxSize will still be applied on creation and on updates, but DesiredEC2Instances will only be applied once on fleet creation and will be ignored during updates to prevent conflicts with auto-scaling. During updates with ON_CREATE_AND_UPDATE_WITH_AUTOSCALING chosen, if current desired instance is lower than the new MinSize, it will be increased to the new MinSize; if current desired instance is larger than the new MaxSize, it will be decreased to the new MaxSize.
23
+ * A human-readable description of a fleet.
22
24
  */
23
- ApplyCapacity?: ("ON_UPDATE" | "ON_CREATE_AND_UPDATE" | "ON_CREATE_AND_UPDATE_WITH_AUTOSCALING");
25
+ Description?: string;
26
+ /**
27
+ * [DEPRECATED] The number of EC2 instances that you want this fleet to host. When creating a new fleet, GameLift automatically sets this value to "1" and initiates a single instance. Once the fleet is active, update this value to trigger GameLift to add or remove instances from the fleet.
28
+ */
29
+ DesiredEC2Instances?: number;
24
30
  /**
25
31
  * A range of IP addresses and port settings that allow inbound traffic to connect to server processes on an Amazon GameLift server.
26
32
  *
@@ -28,147 +34,141 @@ export interface _AWS_GAMELIFT_FLEET {
28
34
  */
29
35
  EC2InboundPermissions?: IpPermission[];
30
36
  /**
31
- * ComputeType to differentiate EC2 hardware managed by GameLift and Anywhere hardware managed by the customer.
37
+ * The name of an EC2 instance type that is supported in Amazon GameLift. A fleet instance type determines the computing resources of each instance in the fleet, including CPU, memory, storage, and networking capacity. Amazon GameLift supports the following EC2 instance types. See Amazon EC2 Instance Types for detailed descriptions.
32
38
  */
33
- ComputeType?: ("EC2" | "ANYWHERE");
39
+ EC2InstanceType?: string;
34
40
  /**
35
- * A descriptive label that is associated with a fleet. Fleet names do not need to be unique.
41
+ * Indicates whether to use On-Demand instances or Spot instances for this fleet. If empty, the default is ON_DEMAND. Both categories of instances use identical hardware and configurations based on the instance type selected for this fleet.
36
42
  */
37
- Name: string;
38
- AnywhereConfiguration?: AnywhereConfiguration;
43
+ FleetType?: ("ON_DEMAND" | "SPOT");
39
44
  /**
40
45
  * A unique identifier for an AWS IAM role that manages access to your AWS services. With an instance role ARN set, any application that runs on an instance in this fleet can assume the role, including install scripts, server processes, and daemons (background processes). Create a role or look up a role's ARN from the IAM dashboard in the AWS Management Console.
41
46
  */
42
47
  InstanceRoleARN?: string;
43
- /**
44
- * Unique fleet ID
45
- */
46
- FleetId?: string;
47
- CertificateConfiguration?: CertificateConfiguration;
48
48
  /**
49
49
  * Credentials provider implementation that loads credentials from the Amazon EC2 Instance Metadata Service.
50
50
  */
51
51
  InstanceRoleCredentialsProvider?: "SHARED_CREDENTIAL_FILE";
52
52
  /**
53
- * [DEPRECATED] The number of EC2 instances that you want this fleet to host. When creating a new fleet, GameLift automatically sets this value to "1" and initiates a single instance. Once the fleet is active, update this value to trigger GameLift to add or remove instances from the fleet.
53
+ * @minItems 1
54
+ * @maxItems 100
54
55
  */
55
- DesiredEC2Instances?: number;
56
+ Locations?: LocationConfiguration[];
56
57
  /**
57
- * An array of key-value pairs to apply to this resource.
58
- *
59
- * @maxItems 200
58
+ * This parameter is no longer used. When hosting a custom game build, specify where Amazon GameLift should store log files using the Amazon GameLift server API call ProcessReady()
60
59
  */
61
- Tags?: Tag[];
60
+ LogPaths?: string[];
62
61
  /**
63
- * The Amazon Resource Name (ARN) that is assigned to a Amazon GameLift Servers Fleet resource and uniquely identifies it. ARNs are unique across all Regions. In a GameLift Fleet ARN, the resource ID matches the FleetId value.
62
+ * [DEPRECATED] The maximum value that is allowed for the fleet's instance count. When creating a new fleet, GameLift automatically sets this value to "1". Once the fleet is active, you can change this value.
64
63
  */
65
- FleetArn?: string;
64
+ MaxSize?: number;
66
65
  /**
67
- * This parameter is no longer used but is retained for backward compatibility. Instead, specify server launch parameters in the RuntimeConfiguration parameter. A request must specify either a runtime configuration or values for both ServerLaunchParameters and ServerLaunchPath.
66
+ * The name of an Amazon CloudWatch metric group. A metric group aggregates the metrics for all fleets in the group. Specify a string containing the metric group name. You can use an existing name or use a new name to create a new metric group. Currently, this parameter can have only one string.
67
+ *
68
+ * @maxItems 1
68
69
  */
69
- ServerLaunchParameters?: string;
70
+ MetricGroups?: string[];
70
71
  /**
71
- * Indicates whether to use On-Demand instances or Spot instances for this fleet. If empty, the default is ON_DEMAND. Both categories of instances use identical hardware and configurations based on the instance type selected for this fleet.
72
+ * [DEPRECATED] The minimum value allowed for the fleet's instance count. When creating a new fleet, GameLift automatically sets this value to "0". After the fleet is active, you can change this value.
72
73
  */
73
- FleetType?: ("ON_DEMAND" | "SPOT");
74
+ MinSize?: number;
74
75
  /**
75
- * @minItems 1
76
- * @maxItems 100
76
+ * A descriptive label that is associated with a fleet. Fleet names do not need to be unique.
77
77
  */
78
- Locations?: LocationConfiguration[];
78
+ Name: string;
79
79
  /**
80
80
  * A game session protection policy to apply to all game sessions hosted on instances in this fleet. When protected, active game sessions cannot be terminated during a scale-down event. If this parameter is not set, instances in this fleet default to no protection. You can change a fleet's protection policy to affect future game sessions on the fleet. You can also set protection for individual game sessions.
81
81
  */
82
82
  NewGameSessionProtectionPolicy?: ("FullProtection" | "NoProtection");
83
83
  /**
84
- * A unique identifier for a Realtime script to be deployed on a new Realtime Servers fleet. The script must have been successfully uploaded to Amazon GameLift. This fleet setting cannot be changed once the fleet is created.
85
- *
86
- * Note: It is not currently possible to use the !Ref command to reference a script created with a CloudFormation template for the fleet property ScriptId. Instead, use Fn::GetAtt Script.Arn or Fn::GetAtt Script.Id to retrieve either of these properties as input for ScriptId. Alternatively, enter a ScriptId string manually.
84
+ * A unique identifier for the AWS account with the VPC that you want to peer your Amazon GameLift fleet with. You can find your account ID in the AWS Management Console under account settings.
87
85
  */
88
- ScriptId?: string;
86
+ PeerVpcAwsAccountId?: string;
89
87
  /**
90
- * [DEPRECATED] The maximum value that is allowed for the fleet's instance count. When creating a new fleet, GameLift automatically sets this value to "1". Once the fleet is active, you can change this value.
88
+ * A unique identifier for a VPC with resources to be accessed by your Amazon GameLift fleet. The VPC must be in the same Region as your fleet. To look up a VPC ID, use the VPC Dashboard in the AWS Management Console.
91
89
  */
92
- MaxSize?: number;
93
- RuntimeConfiguration?: RuntimeConfiguration;
90
+ PeerVpcId?: string;
91
+ ResourceCreationLimitPolicy?: ResourceCreationLimitPolicy;
94
92
  /**
95
- * This parameter is no longer used. When hosting a custom game build, specify where Amazon GameLift should store log files using the Amazon GameLift server API call ProcessReady()
93
+ * Unique fleet ID
96
94
  */
97
- LogPaths?: string[];
95
+ FleetId?: string;
98
96
  /**
99
- * This parameter is no longer used. Instead, specify a server launch path using the RuntimeConfiguration parameter. Requests that specify a server launch path and launch parameters instead of a runtime configuration will continue to work.
97
+ * A unique identifier for a build to be deployed on the new fleet. If you are deploying the fleet with a custom game build, you must specify this property. The build must have been successfully uploaded to Amazon GameLift and be in a READY status. This fleet setting cannot be changed once the fleet is created.
100
98
  */
101
- ServerLaunchPath?: string;
99
+ BuildId?: string;
102
100
  /**
103
- * [DEPRECATED] The minimum value allowed for the fleet's instance count. When creating a new fleet, GameLift automatically sets this value to "0". After the fleet is active, you can change this value.
101
+ * A unique identifier for a Realtime script to be deployed on a new Realtime Servers fleet. The script must have been successfully uploaded to Amazon GameLift. This fleet setting cannot be changed once the fleet is created.
102
+ *
103
+ * Note: It is not currently possible to use the !Ref command to reference a script created with a CloudFormation template for the fleet property ScriptId. Instead, use Fn::GetAtt Script.Arn or Fn::GetAtt Script.Id to retrieve either of these properties as input for ScriptId. Alternatively, enter a ScriptId string manually.
104
104
  */
105
- MinSize?: number;
105
+ ScriptId?: string;
106
+ RuntimeConfiguration?: RuntimeConfiguration;
106
107
  /**
107
- * A unique identifier for the AWS account with the VPC that you want to peer your Amazon GameLift fleet with. You can find your account ID in the AWS Management Console under account settings.
108
+ * This parameter is no longer used but is retained for backward compatibility. Instead, specify server launch parameters in the RuntimeConfiguration parameter. A request must specify either a runtime configuration or values for both ServerLaunchParameters and ServerLaunchPath.
108
109
  */
109
- PeerVpcAwsAccountId?: string;
110
+ ServerLaunchParameters?: string;
110
111
  /**
111
- * The name of an Amazon CloudWatch metric group. A metric group aggregates the metrics for all fleets in the group. Specify a string containing the metric group name. You can use an existing name or use a new name to create a new metric group. Currently, this parameter can have only one string.
112
- *
113
- * @maxItems 1
112
+ * This parameter is no longer used. Instead, specify a server launch path using the RuntimeConfiguration parameter. Requests that specify a server launch path and launch parameters instead of a runtime configuration will continue to work.
114
113
  */
115
- MetricGroups?: string[];
114
+ ServerLaunchPath?: string;
116
115
  /**
117
- * A unique identifier for a build to be deployed on the new fleet. If you are deploying the fleet with a custom game build, you must specify this property. The build must have been successfully uploaded to Amazon GameLift and be in a READY status. This fleet setting cannot be changed once the fleet is created.
116
+ * An array of key-value pairs to apply to this resource.
117
+ *
118
+ * @maxItems 200
118
119
  */
119
- BuildId?: string;
120
- ResourceCreationLimitPolicy?: ResourceCreationLimitPolicy;
120
+ Tags?: Tag[];
121
121
  /**
122
- * The name of an EC2 instance type that is supported in Amazon GameLift. A fleet instance type determines the computing resources of each instance in the fleet, including CPU, memory, storage, and networking capacity. Amazon GameLift supports the following EC2 instance types. See Amazon EC2 Instance Types for detailed descriptions.
122
+ * The Amazon Resource Name (ARN) that is assigned to a Amazon GameLift Servers Fleet resource and uniquely identifies it. ARNs are unique across all Regions. In a GameLift Fleet ARN, the resource ID matches the FleetId value.
123
123
  */
124
- EC2InstanceType?: string;
124
+ FleetArn?: string;
125
125
  }
126
126
  /**
127
127
  * Rule that controls how a fleet is scaled. Scaling policies are uniquely identified by the combination of name and fleet ID.
128
128
  */
129
129
  export interface ScalingPolicy {
130
130
  /**
131
- * Current status of the scaling policy. The scaling policy can be in force only when in an ACTIVE status. Scaling policies can be suspended for individual fleets. If the policy is suspended for a fleet, the policy status does not change.
131
+ * Comparison operator to use when measuring a metric against the threshold value.
132
132
  */
133
- Status?: ("ACTIVE" | "UPDATE_REQUESTED" | "UPDATING" | "DELETE_REQUESTED" | "DELETING" | "DELETED" | "ERROR");
133
+ ComparisonOperator?: ("GreaterThanOrEqualToThreshold" | "GreaterThanThreshold" | "LessThanThreshold" | "LessThanOrEqualToThreshold");
134
134
  /**
135
- * Name of the Amazon GameLift-defined metric that is used to trigger a scaling adjustment.
135
+ * Length of time (in minutes) the metric must be at or beyond the threshold before a scaling event is triggered.
136
136
  */
137
- MetricName: ("ActivatingGameSessions" | "ActiveGameSessions" | "ActiveInstances" | "AvailableGameSessions" | "AvailablePlayerSessions" | "CurrentPlayerSessions" | "IdleInstances" | "PercentAvailableGameSessions" | "PercentIdleInstances" | "QueueDepth" | "WaitTime" | "ConcurrentActivatableGameSessions");
137
+ EvaluationPeriods?: number;
138
+ Location?: Location;
138
139
  /**
139
- * The type of scaling policy to create. For a target-based policy, set the parameter MetricName to 'PercentAvailableGameSessions' and specify a TargetConfiguration. For a rule-based policy set the following parameters: MetricName, ComparisonOperator, Threshold, EvaluationPeriods, ScalingAdjustmentType, and ScalingAdjustment.
140
+ * Name of the Amazon GameLift-defined metric that is used to trigger a scaling adjustment.
140
141
  */
141
- PolicyType?: ("RuleBased" | "TargetBased");
142
+ MetricName: ("ActivatingGameSessions" | "ActiveGameSessions" | "ActiveInstances" | "AvailableGameSessions" | "AvailablePlayerSessions" | "CurrentPlayerSessions" | "IdleInstances" | "PercentAvailableGameSessions" | "PercentIdleInstances" | "QueueDepth" | "WaitTime" | "ConcurrentActivatableGameSessions");
142
143
  /**
143
- * Comparison operator to use when measuring a metric against the threshold value.
144
+ * A descriptive label that is associated with a fleet's scaling policy. Policy names do not need to be unique.
144
145
  */
145
- ComparisonOperator?: ("GreaterThanOrEqualToThreshold" | "GreaterThanThreshold" | "LessThanThreshold" | "LessThanOrEqualToThreshold");
146
- TargetConfiguration?: TargetConfiguration;
146
+ Name: string;
147
147
  /**
148
- * The current status of the fleet's scaling policies in a requested fleet location. The status PENDING_UPDATE indicates that an update was requested for the fleet but has not yet been completed for the location.
148
+ * The type of scaling policy to create. For a target-based policy, set the parameter MetricName to 'PercentAvailableGameSessions' and specify a TargetConfiguration. For a rule-based policy set the following parameters: MetricName, ComparisonOperator, Threshold, EvaluationPeriods, ScalingAdjustmentType, and ScalingAdjustment.
149
149
  */
150
- UpdateStatus?: "PENDING_UPDATE";
150
+ PolicyType?: ("RuleBased" | "TargetBased");
151
151
  /**
152
152
  * Amount of adjustment to make, based on the scaling adjustment type.
153
153
  */
154
154
  ScalingAdjustment?: number;
155
- /**
156
- * Length of time (in minutes) the metric must be at or beyond the threshold before a scaling event is triggered.
157
- */
158
- EvaluationPeriods?: number;
159
- Location?: Location;
160
- /**
161
- * A descriptive label that is associated with a fleet's scaling policy. Policy names do not need to be unique.
162
- */
163
- Name: string;
164
155
  /**
165
156
  * The type of adjustment to make to a fleet's instance count.
166
157
  */
167
158
  ScalingAdjustmentType?: ("ChangeInCapacity" | "ExactCapacity" | "PercentChangeInCapacity");
159
+ /**
160
+ * Current status of the scaling policy. The scaling policy can be in force only when in an ACTIVE status. Scaling policies can be suspended for individual fleets. If the policy is suspended for a fleet, the policy status does not change.
161
+ */
162
+ Status?: ("ACTIVE" | "UPDATE_REQUESTED" | "UPDATING" | "DELETE_REQUESTED" | "DELETING" | "DELETED" | "ERROR");
163
+ TargetConfiguration?: TargetConfiguration;
168
164
  /**
169
165
  * Metric value used to trigger a scaling event.
170
166
  */
171
167
  Threshold?: number;
168
+ /**
169
+ * The current status of the fleet's scaling policies in a requested fleet location. The status PENDING_UPDATE indicates that an update was requested for the fleet but has not yet been completed for the location.
170
+ */
171
+ UpdateStatus?: "PENDING_UPDATE";
172
172
  }
173
173
  /**
174
174
  * An object that contains settings for a target-based scaling policy.
@@ -179,27 +179,6 @@ export interface TargetConfiguration {
179
179
  */
180
180
  TargetValue: number;
181
181
  }
182
- /**
183
- * A range of IP addresses and port settings that allow inbound traffic to connect to server processes on an Amazon GameLift hosting resource. New game sessions that are started on the fleet are assigned an IP address/port number combination, which must fall into the fleet's allowed ranges. For fleets created with a custom game server, the ranges reflect the server's game session assignments. For Realtime Servers fleets, Amazon GameLift automatically opens two port ranges, one for TCP messaging and one for UDP, for use by the Realtime servers.
184
- */
185
- export interface IpPermission {
186
- /**
187
- * A range of allowed IP addresses. This value must be expressed in CIDR notation. Example: "000.000.000.000/[subnet mask]" or optionally the shortened version "0.0.0.0/[subnet mask]".
188
- */
189
- IpRange: string;
190
- /**
191
- * A starting value for a range of allowed port numbers.
192
- */
193
- FromPort: number;
194
- /**
195
- * An ending value for a range of allowed port numbers. Port numbers are end-inclusive. This value must be higher than FromPort.
196
- */
197
- ToPort: number;
198
- /**
199
- * The network communication protocol used by the fleet.
200
- */
201
- Protocol: ("TCP" | "UDP");
202
- }
203
182
  /**
204
183
  * Configuration for Anywhere fleet.
205
184
  */
@@ -216,41 +195,76 @@ export interface CertificateConfiguration {
216
195
  CertificateType: ("DISABLED" | "GENERATED");
217
196
  }
218
197
  /**
219
- * A key-value pair to associate with a resource.
198
+ * A range of IP addresses and port settings that allow inbound traffic to connect to server processes on an Amazon GameLift hosting resource. New game sessions that are started on the fleet are assigned an IP address/port number combination, which must fall into the fleet's allowed ranges. For fleets created with a custom game server, the ranges reflect the server's game session assignments. For Realtime Servers fleets, Amazon GameLift automatically opens two port ranges, one for TCP messaging and one for UDP, for use by the Realtime servers.
220
199
  */
221
- export interface Tag {
200
+ export interface IpPermission {
222
201
  /**
223
- * The value for the tag. You can specify a value that is 0 to 256 Unicode characters in length.
202
+ * A starting value for a range of allowed port numbers.
224
203
  */
225
- Value: string;
204
+ FromPort: number;
226
205
  /**
227
- * The key name of the tag. You can specify a value that is 1 to 128 Unicode characters in length.
206
+ * A range of allowed IP addresses. This value must be expressed in CIDR notation. Example: "000.000.000.000/[subnet mask]" or optionally the shortened version "0.0.0.0/[subnet mask]".
228
207
  */
229
- Key: string;
208
+ IpRange: string;
209
+ /**
210
+ * The network communication protocol used by the fleet.
211
+ */
212
+ Protocol: ("TCP" | "UDP");
213
+ /**
214
+ * An ending value for a range of allowed port numbers. Port numbers are end-inclusive. This value must be higher than FromPort.
215
+ */
216
+ ToPort: number;
230
217
  }
231
218
  /**
232
219
  * A remote location where a multi-location fleet can deploy EC2 instances for game hosting.
233
220
  */
234
221
  export interface LocationConfiguration {
235
- LocationCapacity?: LocationCapacity;
236
222
  Location: Location;
223
+ LocationCapacity?: LocationCapacity;
237
224
  }
238
225
  /**
239
226
  * Current resource capacity settings in a specified fleet or location. The location value might refer to a fleet's remote location or its home Region.
240
227
  */
241
228
  export interface LocationCapacity {
242
- /**
243
- * The minimum value allowed for the fleet's instance count for a location. When creating a new fleet, GameLift automatically sets this value to "0". After the fleet is active, you can change this value.
244
- */
245
- MinSize?: number;
246
229
  /**
247
230
  * Defaults to MinSize if not defined. The number of EC2 instances you want to maintain in the specified fleet location. This value must fall between the minimum and maximum size limits.
248
231
  */
249
232
  DesiredEC2Instances?: number;
233
+ /**
234
+ * The minimum value allowed for the fleet's instance count for a location. When creating a new fleet, GameLift automatically sets this value to "0". After the fleet is active, you can change this value.
235
+ */
236
+ MinSize?: number;
250
237
  /**
251
238
  * The maximum value that is allowed for the fleet's instance count for a location. When creating a new fleet, GameLift automatically sets this value to "1". Once the fleet is active, you can change this value.
252
239
  */
253
240
  MaxSize: number;
241
+ ManagedCapacityConfiguration?: ManagedCapacityConfiguration;
242
+ }
243
+ /**
244
+ * Configuration options for Amazon GameLift Servers-managed capacity behavior.
245
+ */
246
+ export interface ManagedCapacityConfiguration {
247
+ /**
248
+ * The strategy Amazon GameLift Servers will use to automatically scale your capacity to and from zero in response to game session activity. Game session activity refers to any active running sessions or game session requests. When set to SCALE_TO_AND_FROM_ZERO, MinSize must not be specified and will be managed automatically. When set to MANUAL, MinSize is required.
249
+ */
250
+ ZeroCapacityStrategy: ("SCALE_TO_AND_FROM_ZERO" | "MANUAL");
251
+ /**
252
+ * Length of time, in minutes, that Amazon GameLift Servers will wait before scaling in your MinSize and DesiredInstances to 0 after a period with no game session activity.
253
+ */
254
+ ScaleInAfterInactivityMinutes?: number;
255
+ }
256
+ /**
257
+ * A policy that limits the number of game sessions an individual player can create over a span of time for this fleet.
258
+ */
259
+ export interface ResourceCreationLimitPolicy {
260
+ /**
261
+ * The maximum number of game sessions that an individual can create during the policy period.
262
+ */
263
+ NewGameSessionsPerCreator?: number;
264
+ /**
265
+ * The time span used in evaluating the resource creation limit policy.
266
+ */
267
+ PolicyPeriodInMinutes?: number;
254
268
  }
255
269
  /**
256
270
  * Instructions for launching server processes on each instance in the fleet. Server processes run either a custom game build executable or a Realtime script. The runtime configuration defines the server executables or launch script file, launch parameters, and the number of processes to run concurrently on each instance. When creating a fleet, the runtime configuration must have at least one server process configuration; otherwise the request fails with an invalid request exception.
@@ -259,19 +273,19 @@ export interface LocationCapacity {
259
273
  */
260
274
  export interface RuntimeConfiguration {
261
275
  /**
262
- * A collection of server process configurations that describe which server processes to run on each instance in a fleet.
263
- *
264
- * @maxItems 50
276
+ * The maximum amount of time (in seconds) that a game session can remain in status ACTIVATING. If the game session is not active before the timeout, activation is terminated and the game session status is changed to TERMINATED.
265
277
  */
266
- ServerProcesses?: ServerProcess[];
278
+ GameSessionActivationTimeoutSeconds?: number;
267
279
  /**
268
280
  * The maximum number of game sessions with status ACTIVATING to allow on an instance simultaneously. This setting limits the amount of instance resources that can be used for new game activations at any one time.
269
281
  */
270
282
  MaxConcurrentGameSessionActivations?: number;
271
283
  /**
272
- * The maximum amount of time (in seconds) that a game session can remain in status ACTIVATING. If the game session is not active before the timeout, activation is terminated and the game session status is changed to TERMINATED.
284
+ * A collection of server process configurations that describe which server processes to run on each instance in a fleet.
285
+ *
286
+ * @maxItems 50
273
287
  */
274
- GameSessionActivationTimeoutSeconds?: number;
288
+ ServerProcesses?: ServerProcess[];
275
289
  }
276
290
  /**
277
291
  * A set of instructions for launching server processes on each instance in a fleet. Each instruction set identifies the location of the server executable, optional launch parameters, and the number of server processes with this configuration to maintain concurrently on the instance. Server process configurations make up a fleet's RuntimeConfiguration.
@@ -281,10 +295,6 @@ export interface ServerProcess {
281
295
  * The number of server processes that use this configuration to run concurrently on an instance.
282
296
  */
283
297
  ConcurrentExecutions: number;
284
- /**
285
- * An optional list of parameters to pass to the server executable or Realtime script on launch.
286
- */
287
- Parameters?: string;
288
298
  /**
289
299
  * The location of the server executable in a custom game build or the name of the Realtime script file that contains the Init() function. Game builds and Realtime scripts are installed on instances at the root:
290
300
  *
@@ -293,17 +303,21 @@ export interface ServerProcess {
293
303
  * Linux: /local/game. Examples: "/local/game/MyGame/server.exe" or "/local/game/MyRealtimeScript.js"
294
304
  */
295
305
  LaunchPath: string;
306
+ /**
307
+ * An optional list of parameters to pass to the server executable or Realtime script on launch.
308
+ */
309
+ Parameters?: string;
296
310
  }
297
311
  /**
298
- * A policy that limits the number of game sessions an individual player can create over a span of time for this fleet.
312
+ * A key-value pair to associate with a resource.
299
313
  */
300
- export interface ResourceCreationLimitPolicy {
314
+ export interface Tag {
301
315
  /**
302
- * The time span used in evaluating the resource creation limit policy.
316
+ * The key name of the tag. You can specify a value that is 1 to 128 Unicode characters in length.
303
317
  */
304
- PolicyPeriodInMinutes?: number;
318
+ Key: string;
305
319
  /**
306
- * The maximum number of game sessions that an individual can create during the policy period.
320
+ * The value for the tag. You can specify a value that is 0 to 256 Unicode characters in length.
307
321
  */
308
- NewGameSessionsPerCreator?: number;
322
+ Value: string;
309
323
  }
@@ -1,3 +1,3 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXdzLWdhbWVsaWZ0LWZsZWV0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiYXdzLWdhbWVsaWZ0LWZsZWV0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgdHlwZSBMb2NhdGlvbiA9IHN0cmluZ1xuXG4vKipcbiAqIFRoZSBBV1M6OkdhbWVMaWZ0OjpGbGVldCByZXNvdXJjZSBjcmVhdGVzIGFuIEFtYXpvbiBHYW1lTGlmdCAoR2FtZUxpZnQpIGZsZWV0IHRvIGhvc3QgZ2FtZSBzZXJ2ZXJzLiBBIGZsZWV0IGlzIGEgc2V0IG9mIEVDMiBvciBBbnl3aGVyZSBpbnN0YW5jZXMsIGVhY2ggb2Ygd2hpY2ggY2FuIGhvc3QgbXVsdGlwbGUgZ2FtZSBzZXNzaW9ucy5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBfQVdTX0dBTUVMSUZUX0ZMRUVUIHtcbi8qKlxuICogQSBsaXN0IG9mIHJ1bGVzIHRoYXQgY29udHJvbCBob3cgYSBmbGVldCBpcyBzY2FsZWQuXG4gKiBcbiAqIEBtYXhJdGVtcyA1MFxuICovXG5TY2FsaW5nUG9saWNpZXM/OiBTY2FsaW5nUG9saWN5W11cbi8qKlxuICogQSBodW1hbi1yZWFkYWJsZSBkZXNjcmlwdGlvbiBvZiBhIGZsZWV0LlxuICovXG5EZXNjcmlwdGlvbj86IHN0cmluZ1xuLyoqXG4gKiBBIHVuaXF1ZSBpZGVudGlmaWVyIGZvciBhIFZQQyB3aXRoIHJlc291cmNlcyB0byBiZSBhY2Nlc3NlZCBieSB5b3VyIEFtYXpvbiBHYW1lTGlmdCBmbGVldC4gVGhlIFZQQyBtdXN0IGJlIGluIHRoZSBzYW1lIFJlZ2lvbiBhcyB5b3VyIGZsZWV0LiBUbyBsb29rIHVwIGEgVlBDIElELCB1c2UgdGhlIFZQQyBEYXNoYm9hcmQgaW4gdGhlIEFXUyBNYW5hZ2VtZW50IENvbnNvbGUuXG4gKi9cblBlZXJWcGNJZD86IHN0cmluZ1xuLyoqXG4gKiBEZXRlcm1pbmVzIHdoZW4gYW5kIGhvdyB0byBhcHBseSBmbGVldCBvciBsb2NhdGlvbiBjYXBhY2l0aWVzLiBBbGxvd2VkIG9wdGlvbnMgYXJlIE9OX1VQREFURSAoZGVmYXVsdCksIE9OX0NSRUFURV9BTkRfVVBEQVRFIGFuZCBPTl9DUkVBVEVfQU5EX1VQREFURV9XSVRIX0FVVE9TQ0FMSU5HLiBJZiB5b3UgY2hvb3NlIE9OX0NSRUFURV9BTkRfVVBEQVRFX1dJVEhfQVVUT1NDQUxJTkcsIE1pblNpemUgYW5kIE1heFNpemUgd2lsbCBzdGlsbCBiZSBhcHBsaWVkIG9uIGNyZWF0aW9uIGFuZCBvbiB1cGRhdGVzLCBidXQgRGVzaXJlZEVDMkluc3RhbmNlcyB3aWxsIG9ubHkgYmUgYXBwbGllZCBvbmNlIG9uIGZsZWV0IGNyZWF0aW9uIGFuZCB3aWxsIGJlIGlnbm9yZWQgZHVyaW5nIHVwZGF0ZXMgdG8gcHJldmVudCBjb25mbGljdHMgd2l0aCBhdXRvLXNjYWxpbmcuIER1cmluZyB1cGRhdGVzIHdpdGggT05fQ1JFQVRFX0FORF9VUERBVEVfV0lUSF9BVVRPU0NBTElORyBjaG9zZW4sIGlmIGN1cnJlbnQgZGVzaXJlZCBpbnN0YW5jZSBpcyBsb3dlciB0aGFuIHRoZSBuZXcgTWluU2l6ZSwgaXQgd2lsbCBiZSBpbmNyZWFzZWQgdG8gdGhlIG5ldyBNaW5TaXplOyBpZiBjdXJyZW50IGRlc2lyZWQgaW5zdGFuY2UgaXMgbGFyZ2VyIHRoYW4gdGhlIG5ldyBNYXhTaXplLCBpdCB3aWxsIGJlIGRlY3JlYXNlZCB0byB0aGUgbmV3IE1heFNpemUuXG4gKi9cbkFwcGx5Q2FwYWNpdHk/OiAoXCJPTl9VUERBVEVcIiB8IFwiT05fQ1JFQVRFX0FORF9VUERBVEVcIiB8IFwiT05fQ1JFQVRFX0FORF9VUERBVEVfV0lUSF9BVVRPU0NBTElOR1wiKVxuLyoqXG4gKiBBIHJhbmdlIG9mIElQIGFkZHJlc3NlcyBhbmQgcG9ydCBzZXR0aW5ncyB0aGF0IGFsbG93IGluYm91bmQgdHJhZmZpYyB0byBjb25uZWN0IHRvIHNlcnZlciBwcm9jZXNzZXMgb24gYW4gQW1hem9uIEdhbWVMaWZ0IHNlcnZlci5cbiAqIFxuICogQG1heEl0ZW1zIDUwXG4gKi9cbkVDMkluYm91bmRQZXJtaXNzaW9ucz86IElwUGVybWlzc2lvbltdXG4vKipcbiAqIENvbXB1dGVUeXBlIHRvIGRpZmZlcmVudGlhdGUgRUMyIGhhcmR3YXJlIG1hbmFnZWQgYnkgR2FtZUxpZnQgYW5kIEFueXdoZXJlIGhhcmR3YXJlIG1hbmFnZWQgYnkgdGhlIGN1c3RvbWVyLlxuICovXG5Db21wdXRlVHlwZT86IChcIkVDMlwiIHwgXCJBTllXSEVSRVwiKVxuLyoqXG4gKiBBIGRlc2NyaXB0aXZlIGxhYmVsIHRoYXQgaXMgYXNzb2NpYXRlZCB3aXRoIGEgZmxlZXQuIEZsZWV0IG5hbWVzIGRvIG5vdCBuZWVkIHRvIGJlIHVuaXF1ZS5cbiAqL1xuTmFtZTogc3RyaW5nXG5Bbnl3aGVyZUNvbmZpZ3VyYXRpb24/OiBBbnl3aGVyZUNvbmZpZ3VyYXRpb25cbi8qKlxuICogQSB1bmlxdWUgaWRlbnRpZmllciBmb3IgYW4gQVdTIElBTSByb2xlIHRoYXQgbWFuYWdlcyBhY2Nlc3MgdG8geW91ciBBV1Mgc2VydmljZXMuIFdpdGggYW4gaW5zdGFuY2Ugcm9sZSBBUk4gc2V0LCBhbnkgYXBwbGljYXRpb24gdGhhdCBydW5zIG9uIGFuIGluc3RhbmNlIGluIHRoaXMgZmxlZXQgY2FuIGFzc3VtZSB0aGUgcm9sZSwgaW5jbHVkaW5nIGluc3RhbGwgc2NyaXB0cywgc2VydmVyIHByb2Nlc3NlcywgYW5kIGRhZW1vbnMgKGJhY2tncm91bmQgcHJvY2Vzc2VzKS4gQ3JlYXRlIGEgcm9sZSBvciBsb29rIHVwIGEgcm9sZSdzIEFSTiBmcm9tIHRoZSBJQU0gZGFzaGJvYXJkIGluIHRoZSBBV1MgTWFuYWdlbWVudCBDb25zb2xlLlxuICovXG5JbnN0YW5jZVJvbGVBUk4/OiBzdHJpbmdcbi8qKlxuICogVW5pcXVlIGZsZWV0IElEXG4gKi9cbkZsZWV0SWQ/OiBzdHJpbmdcbkNlcnRpZmljYXRlQ29uZmlndXJhdGlvbj86IENlcnRpZmljYXRlQ29uZmlndXJhdGlvblxuLyoqXG4gKiBDcmVkZW50aWFscyBwcm92aWRlciBpbXBsZW1lbnRhdGlvbiB0aGF0IGxvYWRzIGNyZWRlbnRpYWxzIGZyb20gdGhlIEFtYXpvbiBFQzIgSW5zdGFuY2UgTWV0YWRhdGEgU2VydmljZS5cbiAqL1xuSW5zdGFuY2VSb2xlQ3JlZGVudGlhbHNQcm92aWRlcj86IFwiU0hBUkVEX0NSRURFTlRJQUxfRklMRVwiXG4vKipcbiAqIFtERVBSRUNBVEVEXSBUaGUgbnVtYmVyIG9mIEVDMiBpbnN0YW5jZXMgdGhhdCB5b3Ugd2FudCB0aGlzIGZsZWV0IHRvIGhvc3QuIFdoZW4gY3JlYXRpbmcgYSBuZXcgZmxlZXQsIEdhbWVMaWZ0IGF1dG9tYXRpY2FsbHkgc2V0cyB0aGlzIHZhbHVlIHRvIFwiMVwiIGFuZCBpbml0aWF0ZXMgYSBzaW5nbGUgaW5zdGFuY2UuIE9uY2UgdGhlIGZsZWV0IGlzIGFjdGl2ZSwgdXBkYXRlIHRoaXMgdmFsdWUgdG8gdHJpZ2dlciBHYW1lTGlmdCB0byBhZGQgb3IgcmVtb3ZlIGluc3RhbmNlcyBmcm9tIHRoZSBmbGVldC5cbiAqL1xuRGVzaXJlZEVDMkluc3RhbmNlcz86IG51bWJlclxuLyoqXG4gKiBBbiBhcnJheSBvZiBrZXktdmFsdWUgcGFpcnMgdG8gYXBwbHkgdG8gdGhpcyByZXNvdXJjZS5cbiAqIFxuICogQG1heEl0ZW1zIDIwMFxuICovXG5UYWdzPzogVGFnW11cbi8qKlxuICogVGhlIEFtYXpvbiBSZXNvdXJjZSBOYW1lIChBUk4pIHRoYXQgaXMgYXNzaWduZWQgdG8gYSBBbWF6b24gR2FtZUxpZnQgU2VydmVycyBGbGVldCByZXNvdXJjZSBhbmQgdW5pcXVlbHkgaWRlbnRpZmllcyBpdC4gQVJOcyBhcmUgdW5pcXVlIGFjcm9zcyBhbGwgUmVnaW9ucy4gSW4gYSBHYW1lTGlmdCBGbGVldCBBUk4sIHRoZSByZXNvdXJjZSBJRCBtYXRjaGVzIHRoZSBGbGVldElkIHZhbHVlLlxuICovXG5GbGVldEFybj86IHN0cmluZ1xuLyoqXG4gKiBUaGlzIHBhcmFtZXRlciBpcyBubyBsb25nZXIgdXNlZCBidXQgaXMgcmV0YWluZWQgZm9yIGJhY2t3YXJkIGNvbXBhdGliaWxpdHkuIEluc3RlYWQsIHNwZWNpZnkgc2VydmVyIGxhdW5jaCBwYXJhbWV0ZXJzIGluIHRoZSBSdW50aW1lQ29uZmlndXJhdGlvbiBwYXJhbWV0ZXIuIEEgcmVxdWVzdCBtdXN0IHNwZWNpZnkgZWl0aGVyIGEgcnVudGltZSBjb25maWd1cmF0aW9uIG9yIHZhbHVlcyBmb3IgYm90aCBTZXJ2ZXJMYXVuY2hQYXJhbWV0ZXJzIGFuZCBTZXJ2ZXJMYXVuY2hQYXRoLlxuICovXG5TZXJ2ZXJMYXVuY2hQYXJhbWV0ZXJzPzogc3RyaW5nXG4vKipcbiAqIEluZGljYXRlcyB3aGV0aGVyIHRvIHVzZSBPbi1EZW1hbmQgaW5zdGFuY2VzIG9yIFNwb3QgaW5zdGFuY2VzIGZvciB0aGlzIGZsZWV0LiBJZiBlbXB0eSwgdGhlIGRlZmF1bHQgaXMgT05fREVNQU5ELiBCb3RoIGNhdGVnb3JpZXMgb2YgaW5zdGFuY2VzIHVzZSBpZGVudGljYWwgaGFyZHdhcmUgYW5kIGNvbmZpZ3VyYXRpb25zIGJhc2VkIG9uIHRoZSBpbnN0YW5jZSB0eXBlIHNlbGVjdGVkIGZvciB0aGlzIGZsZWV0LlxuICovXG5GbGVldFR5cGU/OiAoXCJPTl9ERU1BTkRcIiB8IFwiU1BPVFwiKVxuLyoqXG4gKiBAbWluSXRlbXMgMVxuICogQG1heEl0ZW1zIDEwMFxuICovXG5Mb2NhdGlvbnM/OiBMb2NhdGlvbkNvbmZpZ3VyYXRpb25bXVxuLyoqXG4gKiBBIGdhbWUgc2Vzc2lvbiBwcm90ZWN0aW9uIHBvbGljeSB0byBhcHBseSB0byBhbGwgZ2FtZSBzZXNzaW9ucyBob3N0ZWQgb24gaW5zdGFuY2VzIGluIHRoaXMgZmxlZXQuIFdoZW4gcHJvdGVjdGVkLCBhY3RpdmUgZ2FtZSBzZXNzaW9ucyBjYW5ub3QgYmUgdGVybWluYXRlZCBkdXJpbmcgYSBzY2FsZS1kb3duIGV2ZW50LiBJZiB0aGlzIHBhcmFtZXRlciBpcyBub3Qgc2V0LCBpbnN0YW5jZXMgaW4gdGhpcyBmbGVldCBkZWZhdWx0IHRvIG5vIHByb3RlY3Rpb24uIFlvdSBjYW4gY2hhbmdlIGEgZmxlZXQncyBwcm90ZWN0aW9uIHBvbGljeSB0byBhZmZlY3QgZnV0dXJlIGdhbWUgc2Vzc2lvbnMgb24gdGhlIGZsZWV0LiBZb3UgY2FuIGFsc28gc2V0IHByb3RlY3Rpb24gZm9yIGluZGl2aWR1YWwgZ2FtZSBzZXNzaW9ucy5cbiAqL1xuTmV3R2FtZVNlc3Npb25Qcm90ZWN0aW9uUG9saWN5PzogKFwiRnVsbFByb3RlY3Rpb25cIiB8IFwiTm9Qcm90ZWN0aW9uXCIpXG4vKipcbiAqIEEgdW5pcXVlIGlkZW50aWZpZXIgZm9yIGEgUmVhbHRpbWUgc2NyaXB0IHRvIGJlIGRlcGxveWVkIG9uIGEgbmV3IFJlYWx0aW1lIFNlcnZlcnMgZmxlZXQuIFRoZSBzY3JpcHQgbXVzdCBoYXZlIGJlZW4gc3VjY2Vzc2Z1bGx5IHVwbG9hZGVkIHRvIEFtYXpvbiBHYW1lTGlmdC4gVGhpcyBmbGVldCBzZXR0aW5nIGNhbm5vdCBiZSBjaGFuZ2VkIG9uY2UgdGhlIGZsZWV0IGlzIGNyZWF0ZWQuXG4gKiBcbiAqIE5vdGU6IEl0IGlzIG5vdCBjdXJyZW50bHkgcG9zc2libGUgdG8gdXNlIHRoZSAhUmVmIGNvbW1hbmQgdG8gcmVmZXJlbmNlIGEgc2NyaXB0IGNyZWF0ZWQgd2l0aCBhIENsb3VkRm9ybWF0aW9uIHRlbXBsYXRlIGZvciB0aGUgZmxlZXQgcHJvcGVydHkgU2NyaXB0SWQuIEluc3RlYWQsIHVzZSBGbjo6R2V0QXR0IFNjcmlwdC5Bcm4gb3IgRm46OkdldEF0dCBTY3JpcHQuSWQgdG8gcmV0cmlldmUgZWl0aGVyIG9mIHRoZXNlIHByb3BlcnRpZXMgYXMgaW5wdXQgZm9yIFNjcmlwdElkLiBBbHRlcm5hdGl2ZWx5LCBlbnRlciBhIFNjcmlwdElkIHN0cmluZyBtYW51YWxseS5cbiAqL1xuU2NyaXB0SWQ/OiBzdHJpbmdcbi8qKlxuICogW0RFUFJFQ0FURURdIFRoZSBtYXhpbXVtIHZhbHVlIHRoYXQgaXMgYWxsb3dlZCBmb3IgdGhlIGZsZWV0J3MgaW5zdGFuY2UgY291bnQuIFdoZW4gY3JlYXRpbmcgYSBuZXcgZmxlZXQsIEdhbWVMaWZ0IGF1dG9tYXRpY2FsbHkgc2V0cyB0aGlzIHZhbHVlIHRvIFwiMVwiLiBPbmNlIHRoZSBmbGVldCBpcyBhY3RpdmUsIHlvdSBjYW4gY2hhbmdlIHRoaXMgdmFsdWUuXG4gKi9cbk1heFNpemU/OiBudW1iZXJcblJ1bnRpbWVDb25maWd1cmF0aW9uPzogUnVudGltZUNvbmZpZ3VyYXRpb25cbi8qKlxuICogVGhpcyBwYXJhbWV0ZXIgaXMgbm8gbG9uZ2VyIHVzZWQuIFdoZW4gaG9zdGluZyBhIGN1c3RvbSBnYW1lIGJ1aWxkLCBzcGVjaWZ5IHdoZXJlIEFtYXpvbiBHYW1lTGlmdCBzaG91bGQgc3RvcmUgbG9nIGZpbGVzIHVzaW5nIHRoZSBBbWF6b24gR2FtZUxpZnQgc2VydmVyIEFQSSBjYWxsIFByb2Nlc3NSZWFkeSgpXG4gKi9cbkxvZ1BhdGhzPzogc3RyaW5nW11cbi8qKlxuICogVGhpcyBwYXJhbWV0ZXIgaXMgbm8gbG9uZ2VyIHVzZWQuIEluc3RlYWQsIHNwZWNpZnkgYSBzZXJ2ZXIgbGF1bmNoIHBhdGggdXNpbmcgdGhlIFJ1bnRpbWVDb25maWd1cmF0aW9uIHBhcmFtZXRlci4gUmVxdWVzdHMgdGhhdCBzcGVjaWZ5IGEgc2VydmVyIGxhdW5jaCBwYXRoIGFuZCBsYXVuY2ggcGFyYW1ldGVycyBpbnN0ZWFkIG9mIGEgcnVudGltZSBjb25maWd1cmF0aW9uIHdpbGwgY29udGludWUgdG8gd29yay5cbiAqL1xuU2VydmVyTGF1bmNoUGF0aD86IHN0cmluZ1xuLyoqXG4gKiBbREVQUkVDQVRFRF0gVGhlIG1pbmltdW0gdmFsdWUgYWxsb3dlZCBmb3IgdGhlIGZsZWV0J3MgaW5zdGFuY2UgY291bnQuIFdoZW4gY3JlYXRpbmcgYSBuZXcgZmxlZXQsIEdhbWVMaWZ0IGF1dG9tYXRpY2FsbHkgc2V0cyB0aGlzIHZhbHVlIHRvIFwiMFwiLiBBZnRlciB0aGUgZmxlZXQgaXMgYWN0aXZlLCB5b3UgY2FuIGNoYW5nZSB0aGlzIHZhbHVlLlxuICovXG5NaW5TaXplPzogbnVtYmVyXG4vKipcbiAqIEEgdW5pcXVlIGlkZW50aWZpZXIgZm9yIHRoZSBBV1MgYWNjb3VudCB3aXRoIHRoZSBWUEMgdGhhdCB5b3Ugd2FudCB0byBwZWVyIHlvdXIgQW1hem9uIEdhbWVMaWZ0IGZsZWV0IHdpdGguIFlvdSBjYW4gZmluZCB5b3VyIGFjY291bnQgSUQgaW4gdGhlIEFXUyBNYW5hZ2VtZW50IENvbnNvbGUgdW5kZXIgYWNjb3VudCBzZXR0aW5ncy5cbiAqL1xuUGVlclZwY0F3c0FjY291bnRJZD86IHN0cmluZ1xuLyoqXG4gKiBUaGUgbmFtZSBvZiBhbiBBbWF6b24gQ2xvdWRXYXRjaCBtZXRyaWMgZ3JvdXAuIEEgbWV0cmljIGdyb3VwIGFnZ3JlZ2F0ZXMgdGhlIG1ldHJpY3MgZm9yIGFsbCBmbGVldHMgaW4gdGhlIGdyb3VwLiBTcGVjaWZ5IGEgc3RyaW5nIGNvbnRhaW5pbmcgdGhlIG1ldHJpYyBncm91cCBuYW1lLiBZb3UgY2FuIHVzZSBhbiBleGlzdGluZyBuYW1lIG9yIHVzZSBhIG5ldyBuYW1lIHRvIGNyZWF0ZSBhIG5ldyBtZXRyaWMgZ3JvdXAuIEN1cnJlbnRseSwgdGhpcyBwYXJhbWV0ZXIgY2FuIGhhdmUgb25seSBvbmUgc3RyaW5nLlxuICogXG4gKiBAbWF4SXRlbXMgMVxuICovXG5NZXRyaWNHcm91cHM/OiBzdHJpbmdbXVxuLyoqXG4gKiBBIHVuaXF1ZSBpZGVudGlmaWVyIGZvciBhIGJ1aWxkIHRvIGJlIGRlcGxveWVkIG9uIHRoZSBuZXcgZmxlZXQuIElmIHlvdSBhcmUgZGVwbG95aW5nIHRoZSBmbGVldCB3aXRoIGEgY3VzdG9tIGdhbWUgYnVpbGQsIHlvdSBtdXN0IHNwZWNpZnkgdGhpcyBwcm9wZXJ0eS4gVGhlIGJ1aWxkIG11c3QgaGF2ZSBiZWVuIHN1Y2Nlc3NmdWxseSB1cGxvYWRlZCB0byBBbWF6b24gR2FtZUxpZnQgYW5kIGJlIGluIGEgUkVBRFkgc3RhdHVzLiBUaGlzIGZsZWV0IHNldHRpbmcgY2Fubm90IGJlIGNoYW5nZWQgb25jZSB0aGUgZmxlZXQgaXMgY3JlYXRlZC5cbiAqL1xuQnVpbGRJZD86IHN0cmluZ1xuUmVzb3VyY2VDcmVhdGlvbkxpbWl0UG9saWN5PzogUmVzb3VyY2VDcmVhdGlvbkxpbWl0UG9saWN5XG4vKipcbiAqIFRoZSBuYW1lIG9mIGFuIEVDMiBpbnN0YW5jZSB0eXBlIHRoYXQgaXMgc3VwcG9ydGVkIGluIEFtYXpvbiBHYW1lTGlmdC4gQSBmbGVldCBpbnN0YW5jZSB0eXBlIGRldGVybWluZXMgdGhlIGNvbXB1dGluZyByZXNvdXJjZXMgb2YgZWFjaCBpbnN0YW5jZSBpbiB0aGUgZmxlZXQsIGluY2x1ZGluZyBDUFUsIG1lbW9yeSwgc3RvcmFnZSwgYW5kIG5ldHdvcmtpbmcgY2FwYWNpdHkuIEFtYXpvbiBHYW1lTGlmdCBzdXBwb3J0cyB0aGUgZm9sbG93aW5nIEVDMiBpbnN0YW5jZSB0eXBlcy4gU2VlIEFtYXpvbiBFQzIgSW5zdGFuY2UgVHlwZXMgZm9yIGRldGFpbGVkIGRlc2NyaXB0aW9ucy5cbiAqL1xuRUMySW5zdGFuY2VUeXBlPzogc3RyaW5nXG59XG4vKipcbiAqIFJ1bGUgdGhhdCBjb250cm9scyBob3cgYSBmbGVldCBpcyBzY2FsZWQuIFNjYWxpbmcgcG9saWNpZXMgYXJlIHVuaXF1ZWx5IGlkZW50aWZpZWQgYnkgdGhlIGNvbWJpbmF0aW9uIG9mIG5hbWUgYW5kIGZsZWV0IElELlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFNjYWxpbmdQb2xpY3kge1xuLyoqXG4gKiBDdXJyZW50IHN0YXR1cyBvZiB0aGUgc2NhbGluZyBwb2xpY3kuIFRoZSBzY2FsaW5nIHBvbGljeSBjYW4gYmUgaW4gZm9yY2Ugb25seSB3aGVuIGluIGFuIEFDVElWRSBzdGF0dXMuIFNjYWxpbmcgcG9saWNpZXMgY2FuIGJlIHN1c3BlbmRlZCBmb3IgaW5kaXZpZHVhbCBmbGVldHMuIElmIHRoZSBwb2xpY3kgaXMgc3VzcGVuZGVkIGZvciBhIGZsZWV0LCB0aGUgcG9saWN5IHN0YXR1cyBkb2VzIG5vdCBjaGFuZ2UuXG4gKi9cblN0YXR1cz86IChcIkFDVElWRVwiIHwgXCJVUERBVEVfUkVRVUVTVEVEXCIgfCBcIlVQREFUSU5HXCIgfCBcIkRFTEVURV9SRVFVRVNURURcIiB8IFwiREVMRVRJTkdcIiB8IFwiREVMRVRFRFwiIHwgXCJFUlJPUlwiKVxuLyoqXG4gKiBOYW1lIG9mIHRoZSBBbWF6b24gR2FtZUxpZnQtZGVmaW5lZCBtZXRyaWMgdGhhdCBpcyB1c2VkIHRvIHRyaWdnZXIgYSBzY2FsaW5nIGFkanVzdG1lbnQuXG4gKi9cbk1ldHJpY05hbWU6IChcIkFjdGl2YXRpbmdHYW1lU2Vzc2lvbnNcIiB8IFwiQWN0aXZlR2FtZVNlc3Npb25zXCIgfCBcIkFjdGl2ZUluc3RhbmNlc1wiIHwgXCJBdmFpbGFibGVHYW1lU2Vzc2lvbnNcIiB8IFwiQXZhaWxhYmxlUGxheWVyU2Vzc2lvbnNcIiB8IFwiQ3VycmVudFBsYXllclNlc3Npb25zXCIgfCBcIklkbGVJbnN0YW5jZXNcIiB8IFwiUGVyY2VudEF2YWlsYWJsZUdhbWVTZXNzaW9uc1wiIHwgXCJQZXJjZW50SWRsZUluc3RhbmNlc1wiIHwgXCJRdWV1ZURlcHRoXCIgfCBcIldhaXRUaW1lXCIgfCBcIkNvbmN1cnJlbnRBY3RpdmF0YWJsZUdhbWVTZXNzaW9uc1wiKVxuLyoqXG4gKiBUaGUgdHlwZSBvZiBzY2FsaW5nIHBvbGljeSB0byBjcmVhdGUuIEZvciBhIHRhcmdldC1iYXNlZCBwb2xpY3ksIHNldCB0aGUgcGFyYW1ldGVyIE1ldHJpY05hbWUgdG8gJ1BlcmNlbnRBdmFpbGFibGVHYW1lU2Vzc2lvbnMnIGFuZCBzcGVjaWZ5IGEgVGFyZ2V0Q29uZmlndXJhdGlvbi4gRm9yIGEgcnVsZS1iYXNlZCBwb2xpY3kgc2V0IHRoZSBmb2xsb3dpbmcgcGFyYW1ldGVyczogTWV0cmljTmFtZSwgQ29tcGFyaXNvbk9wZXJhdG9yLCBUaHJlc2hvbGQsIEV2YWx1YXRpb25QZXJpb2RzLCBTY2FsaW5nQWRqdXN0bWVudFR5cGUsIGFuZCBTY2FsaW5nQWRqdXN0bWVudC5cbiAqL1xuUG9saWN5VHlwZT86IChcIlJ1bGVCYXNlZFwiIHwgXCJUYXJnZXRCYXNlZFwiKVxuLyoqXG4gKiBDb21wYXJpc29uIG9wZXJhdG9yIHRvIHVzZSB3aGVuIG1lYXN1cmluZyBhIG1ldHJpYyBhZ2FpbnN0IHRoZSB0aHJlc2hvbGQgdmFsdWUuXG4gKi9cbkNvbXBhcmlzb25PcGVyYXRvcj86IChcIkdyZWF0ZXJUaGFuT3JFcXVhbFRvVGhyZXNob2xkXCIgfCBcIkdyZWF0ZXJUaGFuVGhyZXNob2xkXCIgfCBcIkxlc3NUaGFuVGhyZXNob2xkXCIgfCBcIkxlc3NUaGFuT3JFcXVhbFRvVGhyZXNob2xkXCIpXG5UYXJnZXRDb25maWd1cmF0aW9uPzogVGFyZ2V0Q29uZmlndXJhdGlvblxuLyoqXG4gKiBUaGUgY3VycmVudCBzdGF0dXMgb2YgdGhlIGZsZWV0J3Mgc2NhbGluZyBwb2xpY2llcyBpbiBhIHJlcXVlc3RlZCBmbGVldCBsb2NhdGlvbi4gVGhlIHN0YXR1cyBQRU5ESU5HX1VQREFURSBpbmRpY2F0ZXMgdGhhdCBhbiB1cGRhdGUgd2FzIHJlcXVlc3RlZCBmb3IgdGhlIGZsZWV0IGJ1dCBoYXMgbm90IHlldCBiZWVuIGNvbXBsZXRlZCBmb3IgdGhlIGxvY2F0aW9uLlxuICovXG5VcGRhdGVTdGF0dXM/OiBcIlBFTkRJTkdfVVBEQVRFXCJcbi8qKlxuICogQW1vdW50IG9mIGFkanVzdG1lbnQgdG8gbWFrZSwgYmFzZWQgb24gdGhlIHNjYWxpbmcgYWRqdXN0bWVudCB0eXBlLlxuICovXG5TY2FsaW5nQWRqdXN0bWVudD86IG51bWJlclxuLyoqXG4gKiBMZW5ndGggb2YgdGltZSAoaW4gbWludXRlcykgdGhlIG1ldHJpYyBtdXN0IGJlIGF0IG9yIGJleW9uZCB0aGUgdGhyZXNob2xkIGJlZm9yZSBhIHNjYWxpbmcgZXZlbnQgaXMgdHJpZ2dlcmVkLlxuICovXG5FdmFsdWF0aW9uUGVyaW9kcz86IG51bWJlclxuTG9jYXRpb24/OiBMb2NhdGlvblxuLyoqXG4gKiBBIGRlc2NyaXB0aXZlIGxhYmVsIHRoYXQgaXMgYXNzb2NpYXRlZCB3aXRoIGEgZmxlZXQncyBzY2FsaW5nIHBvbGljeS4gUG9saWN5IG5hbWVzIGRvIG5vdCBuZWVkIHRvIGJlIHVuaXF1ZS5cbiAqL1xuTmFtZTogc3RyaW5nXG4vKipcbiAqIFRoZSB0eXBlIG9mIGFkanVzdG1lbnQgdG8gbWFrZSB0byBhIGZsZWV0J3MgaW5zdGFuY2UgY291bnQuXG4gKi9cblNjYWxpbmdBZGp1c3RtZW50VHlwZT86IChcIkNoYW5nZUluQ2FwYWNpdHlcIiB8IFwiRXhhY3RDYXBhY2l0eVwiIHwgXCJQZXJjZW50Q2hhbmdlSW5DYXBhY2l0eVwiKVxuLyoqXG4gKiBNZXRyaWMgdmFsdWUgdXNlZCB0byB0cmlnZ2VyIGEgc2NhbGluZyBldmVudC5cbiAqL1xuVGhyZXNob2xkPzogbnVtYmVyXG59XG4vKipcbiAqIEFuIG9iamVjdCB0aGF0IGNvbnRhaW5zIHNldHRpbmdzIGZvciBhIHRhcmdldC1iYXNlZCBzY2FsaW5nIHBvbGljeS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBUYXJnZXRDb25maWd1cmF0aW9uIHtcbi8qKlxuICogRGVzaXJlZCB2YWx1ZSB0byB1c2Ugd2l0aCBhIHRhcmdldC1iYXNlZCBzY2FsaW5nIHBvbGljeS4gVGhlIHZhbHVlIG11c3QgYmUgcmVsZXZhbnQgZm9yIHdoYXRldmVyIG1ldHJpYyB0aGUgc2NhbGluZyBwb2xpY3kgaXMgdXNpbmcuIEZvciBleGFtcGxlLCBpbiBhIHBvbGljeSB1c2luZyB0aGUgbWV0cmljIFBlcmNlbnRBdmFpbGFibGVHYW1lU2Vzc2lvbnMsIHRoZSB0YXJnZXQgdmFsdWUgc2hvdWxkIGJlIHRoZSBwcmVmZXJyZWQgc2l6ZSBvZiB0aGUgZmxlZXQncyBidWZmZXIgKHRoZSBwZXJjZW50IG9mIGNhcGFjaXR5IHRoYXQgc2hvdWxkIGJlIGlkbGUgYW5kIHJlYWR5IGZvciBuZXcgZ2FtZSBzZXNzaW9ucykuXG4gKi9cblRhcmdldFZhbHVlOiBudW1iZXJcbn1cbi8qKlxuICogQSByYW5nZSBvZiBJUCBhZGRyZXNzZXMgYW5kIHBvcnQgc2V0dGluZ3MgdGhhdCBhbGxvdyBpbmJvdW5kIHRyYWZmaWMgdG8gY29ubmVjdCB0byBzZXJ2ZXIgcHJvY2Vzc2VzIG9uIGFuIEFtYXpvbiBHYW1lTGlmdCBob3N0aW5nIHJlc291cmNlLiBOZXcgZ2FtZSBzZXNzaW9ucyB0aGF0IGFyZSBzdGFydGVkIG9uIHRoZSBmbGVldCBhcmUgYXNzaWduZWQgYW4gSVAgYWRkcmVzcy9wb3J0IG51bWJlciBjb21iaW5hdGlvbiwgd2hpY2ggbXVzdCBmYWxsIGludG8gdGhlIGZsZWV0J3MgYWxsb3dlZCByYW5nZXMuIEZvciBmbGVldHMgY3JlYXRlZCB3aXRoIGEgY3VzdG9tIGdhbWUgc2VydmVyLCB0aGUgcmFuZ2VzIHJlZmxlY3QgdGhlIHNlcnZlcidzIGdhbWUgc2Vzc2lvbiBhc3NpZ25tZW50cy4gRm9yIFJlYWx0aW1lIFNlcnZlcnMgZmxlZXRzLCBBbWF6b24gR2FtZUxpZnQgYXV0b21hdGljYWxseSBvcGVucyB0d28gcG9ydCByYW5nZXMsIG9uZSBmb3IgVENQIG1lc3NhZ2luZyBhbmQgb25lIGZvciBVRFAsIGZvciB1c2UgYnkgdGhlIFJlYWx0aW1lIHNlcnZlcnMuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgSXBQZXJtaXNzaW9uIHtcbi8qKlxuICogQSByYW5nZSBvZiBhbGxvd2VkIElQIGFkZHJlc3Nlcy4gVGhpcyB2YWx1ZSBtdXN0IGJlIGV4cHJlc3NlZCBpbiBDSURSIG5vdGF0aW9uLiBFeGFtcGxlOiBcIjAwMC4wMDAuMDAwLjAwMC9bc3VibmV0IG1hc2tdXCIgb3Igb3B0aW9uYWxseSB0aGUgc2hvcnRlbmVkIHZlcnNpb24gXCIwLjAuMC4wL1tzdWJuZXQgbWFza11cIi5cbiAqL1xuSXBSYW5nZTogc3RyaW5nXG4vKipcbiAqIEEgc3RhcnRpbmcgdmFsdWUgZm9yIGEgcmFuZ2Ugb2YgYWxsb3dlZCBwb3J0IG51bWJlcnMuXG4gKi9cbkZyb21Qb3J0OiBudW1iZXJcbi8qKlxuICogQW4gZW5kaW5nIHZhbHVlIGZvciBhIHJhbmdlIG9mIGFsbG93ZWQgcG9ydCBudW1iZXJzLiBQb3J0IG51bWJlcnMgYXJlIGVuZC1pbmNsdXNpdmUuIFRoaXMgdmFsdWUgbXVzdCBiZSBoaWdoZXIgdGhhbiBGcm9tUG9ydC5cbiAqL1xuVG9Qb3J0OiBudW1iZXJcbi8qKlxuICogVGhlIG5ldHdvcmsgY29tbXVuaWNhdGlvbiBwcm90b2NvbCB1c2VkIGJ5IHRoZSBmbGVldC5cbiAqL1xuUHJvdG9jb2w6IChcIlRDUFwiIHwgXCJVRFBcIilcbn1cbi8qKlxuICogQ29uZmlndXJhdGlvbiBmb3IgQW55d2hlcmUgZmxlZXQuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQW55d2hlcmVDb25maWd1cmF0aW9uIHtcbi8qKlxuICogQ29zdCBvZiBjb21wdXRlIGNhbiBiZSBzcGVjaWZpZWQgb24gQW55d2hlcmUgRmxlZXRzIHRvIHByaW9yaXRpemUgcGxhY2VtZW50IGFjcm9zcyBRdWV1ZSBkZXN0aW5hdGlvbnMgYmFzZWQgb24gQ29zdC5cbiAqL1xuQ29zdDogc3RyaW5nXG59XG4vKipcbiAqIEluZGljYXRlcyB3aGV0aGVyIHRvIGdlbmVyYXRlIGEgVExTL1NTTCBjZXJ0aWZpY2F0ZSBmb3IgdGhlIG5ldyBmbGVldC4gVExTIGNlcnRpZmljYXRlcyBhcmUgdXNlZCBmb3IgZW5jcnlwdGluZyB0cmFmZmljIGJldHdlZW4gZ2FtZSBjbGllbnRzIGFuZCBnYW1lIHNlcnZlcnMgcnVubmluZyBvbiBHYW1lTGlmdC4gSWYgdGhpcyBwYXJhbWV0ZXIgaXMgbm90IHNldCwgY2VydGlmaWNhdGUgZ2VuZXJhdGlvbiBpcyBkaXNhYmxlZC4gVGhpcyBmbGVldCBzZXR0aW5nIGNhbm5vdCBiZSBjaGFuZ2VkIG9uY2UgdGhlIGZsZWV0IGlzIGNyZWF0ZWQuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQ2VydGlmaWNhdGVDb25maWd1cmF0aW9uIHtcbkNlcnRpZmljYXRlVHlwZTogKFwiRElTQUJMRURcIiB8IFwiR0VORVJBVEVEXCIpXG59XG4vKipcbiAqIEEga2V5LXZhbHVlIHBhaXIgdG8gYXNzb2NpYXRlIHdpdGggYSByZXNvdXJjZS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBUYWcge1xuLyoqXG4gKiBUaGUgdmFsdWUgZm9yIHRoZSB0YWcuIFlvdSBjYW4gc3BlY2lmeSBhIHZhbHVlIHRoYXQgaXMgMCB0byAyNTYgVW5pY29kZSBjaGFyYWN0ZXJzIGluIGxlbmd0aC5cbiAqL1xuVmFsdWU6IHN0cmluZ1xuLyoqXG4gKiBUaGUga2V5IG5hbWUgb2YgdGhlIHRhZy4gWW91IGNhbiBzcGVjaWZ5IGEgdmFsdWUgdGhhdCBpcyAxIHRvIDEyOCBVbmljb2RlIGNoYXJhY3RlcnMgaW4gbGVuZ3RoLlxuICovXG5LZXk6IHN0cmluZ1xufVxuLyoqXG4gKiBBIHJlbW90ZSBsb2NhdGlvbiB3aGVyZSBhIG11bHRpLWxvY2F0aW9uIGZsZWV0IGNhbiBkZXBsb3kgRUMyIGluc3RhbmNlcyBmb3IgZ2FtZSBob3N0aW5nLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIExvY2F0aW9uQ29uZmlndXJhdGlvbiB7XG5Mb2NhdGlvbkNhcGFjaXR5PzogTG9jYXRpb25DYXBhY2l0eVxuTG9jYXRpb246IExvY2F0aW9uXG59XG4vKipcbiAqIEN1cnJlbnQgcmVzb3VyY2UgY2FwYWNpdHkgc2V0dGluZ3MgaW4gYSBzcGVjaWZpZWQgZmxlZXQgb3IgbG9jYXRpb24uIFRoZSBsb2NhdGlvbiB2YWx1ZSBtaWdodCByZWZlciB0byBhIGZsZWV0J3MgcmVtb3RlIGxvY2F0aW9uIG9yIGl0cyBob21lIFJlZ2lvbi5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBMb2NhdGlvbkNhcGFjaXR5IHtcbi8qKlxuICogVGhlIG1pbmltdW0gdmFsdWUgYWxsb3dlZCBmb3IgdGhlIGZsZWV0J3MgaW5zdGFuY2UgY291bnQgZm9yIGEgbG9jYXRpb24uIFdoZW4gY3JlYXRpbmcgYSBuZXcgZmxlZXQsIEdhbWVMaWZ0IGF1dG9tYXRpY2FsbHkgc2V0cyB0aGlzIHZhbHVlIHRvIFwiMFwiLiBBZnRlciB0aGUgZmxlZXQgaXMgYWN0aXZlLCB5b3UgY2FuIGNoYW5nZSB0aGlzIHZhbHVlLlxuICovXG5NaW5TaXplPzogbnVtYmVyXG4vKipcbiAqIERlZmF1bHRzIHRvIE1pblNpemUgaWYgbm90IGRlZmluZWQuIFRoZSBudW1iZXIgb2YgRUMyIGluc3RhbmNlcyB5b3Ugd2FudCB0byBtYWludGFpbiBpbiB0aGUgc3BlY2lmaWVkIGZsZWV0IGxvY2F0aW9uLiBUaGlzIHZhbHVlIG11c3QgZmFsbCBiZXR3ZWVuIHRoZSBtaW5pbXVtIGFuZCBtYXhpbXVtIHNpemUgbGltaXRzLlxuICovXG5EZXNpcmVkRUMySW5zdGFuY2VzPzogbnVtYmVyXG4vKipcbiAqIFRoZSBtYXhpbXVtIHZhbHVlIHRoYXQgaXMgYWxsb3dlZCBmb3IgdGhlIGZsZWV0J3MgaW5zdGFuY2UgY291bnQgZm9yIGEgbG9jYXRpb24uIFdoZW4gY3JlYXRpbmcgYSBuZXcgZmxlZXQsIEdhbWVMaWZ0IGF1dG9tYXRpY2FsbHkgc2V0cyB0aGlzIHZhbHVlIHRvIFwiMVwiLiBPbmNlIHRoZSBmbGVldCBpcyBhY3RpdmUsIHlvdSBjYW4gY2hhbmdlIHRoaXMgdmFsdWUuXG4gKi9cbk1heFNpemU6IG51bWJlclxufVxuLyoqXG4gKiBJbnN0cnVjdGlvbnMgZm9yIGxhdW5jaGluZyBzZXJ2ZXIgcHJvY2Vzc2VzIG9uIGVhY2ggaW5zdGFuY2UgaW4gdGhlIGZsZWV0LiBTZXJ2ZXIgcHJvY2Vzc2VzIHJ1biBlaXRoZXIgYSBjdXN0b20gZ2FtZSBidWlsZCBleGVjdXRhYmxlIG9yIGEgUmVhbHRpbWUgc2NyaXB0LiBUaGUgcnVudGltZSBjb25maWd1cmF0aW9uIGRlZmluZXMgdGhlIHNlcnZlciBleGVjdXRhYmxlcyBvciBsYXVuY2ggc2NyaXB0IGZpbGUsIGxhdW5jaCBwYXJhbWV0ZXJzLCBhbmQgdGhlIG51bWJlciBvZiBwcm9jZXNzZXMgdG8gcnVuIGNvbmN1cnJlbnRseSBvbiBlYWNoIGluc3RhbmNlLiBXaGVuIGNyZWF0aW5nIGEgZmxlZXQsIHRoZSBydW50aW1lIGNvbmZpZ3VyYXRpb24gbXVzdCBoYXZlIGF0IGxlYXN0IG9uZSBzZXJ2ZXIgcHJvY2VzcyBjb25maWd1cmF0aW9uOyBvdGhlcndpc2UgdGhlIHJlcXVlc3QgZmFpbHMgd2l0aCBhbiBpbnZhbGlkIHJlcXVlc3QgZXhjZXB0aW9uLlxuICogXG4gKiBUaGlzIHBhcmFtZXRlciBpcyByZXF1aXJlZCB1bmxlc3MgdGhlIHBhcmFtZXRlcnMgU2VydmVyTGF1bmNoUGF0aCBhbmQgU2VydmVyTGF1bmNoUGFyYW1ldGVycyBhcmUgZGVmaW5lZC4gUnVudGltZSBjb25maWd1cmF0aW9uIGhhcyByZXBsYWNlZCB0aGVzZSBwYXJhbWV0ZXJzLCBidXQgZmxlZXRzIHRoYXQgdXNlIHRoZW0gd2lsbCBjb250aW51ZSB0byB3b3JrLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFJ1bnRpbWVDb25maWd1cmF0aW9uIHtcbi8qKlxuICogQSBjb2xsZWN0aW9uIG9mIHNlcnZlciBwcm9jZXNzIGNvbmZpZ3VyYXRpb25zIHRoYXQgZGVzY3JpYmUgd2hpY2ggc2VydmVyIHByb2Nlc3NlcyB0byBydW4gb24gZWFjaCBpbnN0YW5jZSBpbiBhIGZsZWV0LlxuICogXG4gKiBAbWF4SXRlbXMgNTBcbiAqL1xuU2VydmVyUHJvY2Vzc2VzPzogU2VydmVyUHJvY2Vzc1tdXG4vKipcbiAqIFRoZSBtYXhpbXVtIG51bWJlciBvZiBnYW1lIHNlc3Npb25zIHdpdGggc3RhdHVzIEFDVElWQVRJTkcgdG8gYWxsb3cgb24gYW4gaW5zdGFuY2Ugc2ltdWx0YW5lb3VzbHkuIFRoaXMgc2V0dGluZyBsaW1pdHMgdGhlIGFtb3VudCBvZiBpbnN0YW5jZSByZXNvdXJjZXMgdGhhdCBjYW4gYmUgdXNlZCBmb3IgbmV3IGdhbWUgYWN0aXZhdGlvbnMgYXQgYW55IG9uZSB0aW1lLlxuICovXG5NYXhDb25jdXJyZW50R2FtZVNlc3Npb25BY3RpdmF0aW9ucz86IG51bWJlclxuLyoqXG4gKiBUaGUgbWF4aW11bSBhbW91bnQgb2YgdGltZSAoaW4gc2Vjb25kcykgdGhhdCBhIGdhbWUgc2Vzc2lvbiBjYW4gcmVtYWluIGluIHN0YXR1cyBBQ1RJVkFUSU5HLiBJZiB0aGUgZ2FtZSBzZXNzaW9uIGlzIG5vdCBhY3RpdmUgYmVmb3JlIHRoZSB0aW1lb3V0LCBhY3RpdmF0aW9uIGlzIHRlcm1pbmF0ZWQgYW5kIHRoZSBnYW1lIHNlc3Npb24gc3RhdHVzIGlzIGNoYW5nZWQgdG8gVEVSTUlOQVRFRC5cbiAqL1xuR2FtZVNlc3Npb25BY3RpdmF0aW9uVGltZW91dFNlY29uZHM/OiBudW1iZXJcbn1cbi8qKlxuICogQSBzZXQgb2YgaW5zdHJ1Y3Rpb25zIGZvciBsYXVuY2hpbmcgc2VydmVyIHByb2Nlc3NlcyBvbiBlYWNoIGluc3RhbmNlIGluIGEgZmxlZXQuIEVhY2ggaW5zdHJ1Y3Rpb24gc2V0IGlkZW50aWZpZXMgdGhlIGxvY2F0aW9uIG9mIHRoZSBzZXJ2ZXIgZXhlY3V0YWJsZSwgb3B0aW9uYWwgbGF1bmNoIHBhcmFtZXRlcnMsIGFuZCB0aGUgbnVtYmVyIG9mIHNlcnZlciBwcm9jZXNzZXMgd2l0aCB0aGlzIGNvbmZpZ3VyYXRpb24gdG8gbWFpbnRhaW4gY29uY3VycmVudGx5IG9uIHRoZSBpbnN0YW5jZS4gU2VydmVyIHByb2Nlc3MgY29uZmlndXJhdGlvbnMgbWFrZSB1cCBhIGZsZWV0J3MgUnVudGltZUNvbmZpZ3VyYXRpb24uXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgU2VydmVyUHJvY2VzcyB7XG4vKipcbiAqIFRoZSBudW1iZXIgb2Ygc2VydmVyIHByb2Nlc3NlcyB0aGF0IHVzZSB0aGlzIGNvbmZpZ3VyYXRpb24gdG8gcnVuIGNvbmN1cnJlbnRseSBvbiBhbiBpbnN0YW5jZS5cbiAqL1xuQ29uY3VycmVudEV4ZWN1dGlvbnM6IG51bWJlclxuLyoqXG4gKiBBbiBvcHRpb25hbCBsaXN0IG9mIHBhcmFtZXRlcnMgdG8gcGFzcyB0byB0aGUgc2VydmVyIGV4ZWN1dGFibGUgb3IgUmVhbHRpbWUgc2NyaXB0IG9uIGxhdW5jaC5cbiAqL1xuUGFyYW1ldGVycz86IHN0cmluZ1xuLyoqXG4gKiBUaGUgbG9jYXRpb24gb2YgdGhlIHNlcnZlciBleGVjdXRhYmxlIGluIGEgY3VzdG9tIGdhbWUgYnVpbGQgb3IgdGhlIG5hbWUgb2YgdGhlIFJlYWx0aW1lIHNjcmlwdCBmaWxlIHRoYXQgY29udGFpbnMgdGhlIEluaXQoKSBmdW5jdGlvbi4gR2FtZSBidWlsZHMgYW5kIFJlYWx0aW1lIHNjcmlwdHMgYXJlIGluc3RhbGxlZCBvbiBpbnN0YW5jZXMgYXQgdGhlIHJvb3Q6XG4gKiBcbiAqIFdpbmRvd3MgKGZvciBjdXN0b20gZ2FtZSBidWlsZHMgb25seSk6IEM6XFxnYW1lLiBFeGFtcGxlOiBcIkM6XFxnYW1lXFxNeUdhbWVcXHNlcnZlci5leGVcIlxuICogXG4gKiBMaW51eDogL2xvY2FsL2dhbWUuIEV4YW1wbGVzOiBcIi9sb2NhbC9nYW1lL015R2FtZS9zZXJ2ZXIuZXhlXCIgb3IgXCIvbG9jYWwvZ2FtZS9NeVJlYWx0aW1lU2NyaXB0LmpzXCJcbiAqL1xuTGF1bmNoUGF0aDogc3RyaW5nXG59XG4vKipcbiAqIEEgcG9saWN5IHRoYXQgbGltaXRzIHRoZSBudW1iZXIgb2YgZ2FtZSBzZXNzaW9ucyBhbiBpbmRpdmlkdWFsIHBsYXllciBjYW4gY3JlYXRlIG92ZXIgYSBzcGFuIG9mIHRpbWUgZm9yIHRoaXMgZmxlZXQuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgUmVzb3VyY2VDcmVhdGlvbkxpbWl0UG9saWN5IHtcbi8qKlxuICogVGhlIHRpbWUgc3BhbiB1c2VkIGluIGV2YWx1YXRpbmcgdGhlIHJlc291cmNlIGNyZWF0aW9uIGxpbWl0IHBvbGljeS5cbiAqL1xuUG9saWN5UGVyaW9kSW5NaW51dGVzPzogbnVtYmVyXG4vKipcbiAqIFRoZSBtYXhpbXVtIG51bWJlciBvZiBnYW1lIHNlc3Npb25zIHRoYXQgYW4gaW5kaXZpZHVhbCBjYW4gY3JlYXRlIGR1cmluZyB0aGUgcG9saWN5IHBlcmlvZC5cbiAqL1xuTmV3R2FtZVNlc3Npb25zUGVyQ3JlYXRvcj86IG51bWJlclxufVxuIl19
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXdzLWdhbWVsaWZ0LWZsZWV0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiYXdzLWdhbWVsaWZ0LWZsZWV0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgdHlwZSBMb2NhdGlvbiA9IHN0cmluZ1xuXG4vKipcbiAqIFRoZSBBV1M6OkdhbWVMaWZ0OjpGbGVldCByZXNvdXJjZSBjcmVhdGVzIGFuIEFtYXpvbiBHYW1lTGlmdCAoR2FtZUxpZnQpIGZsZWV0IHRvIGhvc3QgZ2FtZSBzZXJ2ZXJzLiBBIGZsZWV0IGlzIGEgc2V0IG9mIEVDMiBvciBBbnl3aGVyZSBpbnN0YW5jZXMsIGVhY2ggb2Ygd2hpY2ggY2FuIGhvc3QgbXVsdGlwbGUgZ2FtZSBzZXNzaW9ucy5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBfQVdTX0dBTUVMSUZUX0ZMRUVUIHtcbi8qKlxuICogQSBsaXN0IG9mIHJ1bGVzIHRoYXQgY29udHJvbCBob3cgYSBmbGVldCBpcyBzY2FsZWQuXG4gKiBcbiAqIEBtYXhJdGVtcyA1MFxuICovXG5TY2FsaW5nUG9saWNpZXM/OiBTY2FsaW5nUG9saWN5W11cbkFueXdoZXJlQ29uZmlndXJhdGlvbj86IEFueXdoZXJlQ29uZmlndXJhdGlvblxuLyoqXG4gKiBEZXRlcm1pbmVzIHdoZW4gYW5kIGhvdyB0byBhcHBseSBmbGVldCBvciBsb2NhdGlvbiBjYXBhY2l0aWVzLiBBbGxvd2VkIG9wdGlvbnMgYXJlIE9OX1VQREFURSAoZGVmYXVsdCksIE9OX0NSRUFURV9BTkRfVVBEQVRFIGFuZCBPTl9DUkVBVEVfQU5EX1VQREFURV9XSVRIX0FVVE9TQ0FMSU5HLiBJZiB5b3UgY2hvb3NlIE9OX0NSRUFURV9BTkRfVVBEQVRFX1dJVEhfQVVUT1NDQUxJTkcsIE1pblNpemUgYW5kIE1heFNpemUgd2lsbCBzdGlsbCBiZSBhcHBsaWVkIG9uIGNyZWF0aW9uIGFuZCBvbiB1cGRhdGVzLCBidXQgRGVzaXJlZEVDMkluc3RhbmNlcyB3aWxsIG9ubHkgYmUgYXBwbGllZCBvbmNlIG9uIGZsZWV0IGNyZWF0aW9uIGFuZCB3aWxsIGJlIGlnbm9yZWQgZHVyaW5nIHVwZGF0ZXMgdG8gcHJldmVudCBjb25mbGljdHMgd2l0aCBhdXRvLXNjYWxpbmcuIER1cmluZyB1cGRhdGVzIHdpdGggT05fQ1JFQVRFX0FORF9VUERBVEVfV0lUSF9BVVRPU0NBTElORyBjaG9zZW4sIGlmIGN1cnJlbnQgZGVzaXJlZCBpbnN0YW5jZSBpcyBsb3dlciB0aGFuIHRoZSBuZXcgTWluU2l6ZSwgaXQgd2lsbCBiZSBpbmNyZWFzZWQgdG8gdGhlIG5ldyBNaW5TaXplOyBpZiBjdXJyZW50IGRlc2lyZWQgaW5zdGFuY2UgaXMgbGFyZ2VyIHRoYW4gdGhlIG5ldyBNYXhTaXplLCBpdCB3aWxsIGJlIGRlY3JlYXNlZCB0byB0aGUgbmV3IE1heFNpemUuXG4gKi9cbkFwcGx5Q2FwYWNpdHk/OiAoXCJPTl9VUERBVEVcIiB8IFwiT05fQ1JFQVRFX0FORF9VUERBVEVcIiB8IFwiT05fQ1JFQVRFX0FORF9VUERBVEVfV0lUSF9BVVRPU0NBTElOR1wiKVxuQ2VydGlmaWNhdGVDb25maWd1cmF0aW9uPzogQ2VydGlmaWNhdGVDb25maWd1cmF0aW9uXG4vKipcbiAqIENvbXB1dGVUeXBlIHRvIGRpZmZlcmVudGlhdGUgRUMyIGhhcmR3YXJlIG1hbmFnZWQgYnkgR2FtZUxpZnQgYW5kIEFueXdoZXJlIGhhcmR3YXJlIG1hbmFnZWQgYnkgdGhlIGN1c3RvbWVyLlxuICovXG5Db21wdXRlVHlwZT86IChcIkVDMlwiIHwgXCJBTllXSEVSRVwiKVxuLyoqXG4gKiBBIGh1bWFuLXJlYWRhYmxlIGRlc2NyaXB0aW9uIG9mIGEgZmxlZXQuXG4gKi9cbkRlc2NyaXB0aW9uPzogc3RyaW5nXG4vKipcbiAqIFtERVBSRUNBVEVEXSBUaGUgbnVtYmVyIG9mIEVDMiBpbnN0YW5jZXMgdGhhdCB5b3Ugd2FudCB0aGlzIGZsZWV0IHRvIGhvc3QuIFdoZW4gY3JlYXRpbmcgYSBuZXcgZmxlZXQsIEdhbWVMaWZ0IGF1dG9tYXRpY2FsbHkgc2V0cyB0aGlzIHZhbHVlIHRvIFwiMVwiIGFuZCBpbml0aWF0ZXMgYSBzaW5nbGUgaW5zdGFuY2UuIE9uY2UgdGhlIGZsZWV0IGlzIGFjdGl2ZSwgdXBkYXRlIHRoaXMgdmFsdWUgdG8gdHJpZ2dlciBHYW1lTGlmdCB0byBhZGQgb3IgcmVtb3ZlIGluc3RhbmNlcyBmcm9tIHRoZSBmbGVldC5cbiAqL1xuRGVzaXJlZEVDMkluc3RhbmNlcz86IG51bWJlclxuLyoqXG4gKiBBIHJhbmdlIG9mIElQIGFkZHJlc3NlcyBhbmQgcG9ydCBzZXR0aW5ncyB0aGF0IGFsbG93IGluYm91bmQgdHJhZmZpYyB0byBjb25uZWN0IHRvIHNlcnZlciBwcm9jZXNzZXMgb24gYW4gQW1hem9uIEdhbWVMaWZ0IHNlcnZlci5cbiAqIFxuICogQG1heEl0ZW1zIDUwXG4gKi9cbkVDMkluYm91bmRQZXJtaXNzaW9ucz86IElwUGVybWlzc2lvbltdXG4vKipcbiAqIFRoZSBuYW1lIG9mIGFuIEVDMiBpbnN0YW5jZSB0eXBlIHRoYXQgaXMgc3VwcG9ydGVkIGluIEFtYXpvbiBHYW1lTGlmdC4gQSBmbGVldCBpbnN0YW5jZSB0eXBlIGRldGVybWluZXMgdGhlIGNvbXB1dGluZyByZXNvdXJjZXMgb2YgZWFjaCBpbnN0YW5jZSBpbiB0aGUgZmxlZXQsIGluY2x1ZGluZyBDUFUsIG1lbW9yeSwgc3RvcmFnZSwgYW5kIG5ldHdvcmtpbmcgY2FwYWNpdHkuIEFtYXpvbiBHYW1lTGlmdCBzdXBwb3J0cyB0aGUgZm9sbG93aW5nIEVDMiBpbnN0YW5jZSB0eXBlcy4gU2VlIEFtYXpvbiBFQzIgSW5zdGFuY2UgVHlwZXMgZm9yIGRldGFpbGVkIGRlc2NyaXB0aW9ucy5cbiAqL1xuRUMySW5zdGFuY2VUeXBlPzogc3RyaW5nXG4vKipcbiAqIEluZGljYXRlcyB3aGV0aGVyIHRvIHVzZSBPbi1EZW1hbmQgaW5zdGFuY2VzIG9yIFNwb3QgaW5zdGFuY2VzIGZvciB0aGlzIGZsZWV0LiBJZiBlbXB0eSwgdGhlIGRlZmF1bHQgaXMgT05fREVNQU5ELiBCb3RoIGNhdGVnb3JpZXMgb2YgaW5zdGFuY2VzIHVzZSBpZGVudGljYWwgaGFyZHdhcmUgYW5kIGNvbmZpZ3VyYXRpb25zIGJhc2VkIG9uIHRoZSBpbnN0YW5jZSB0eXBlIHNlbGVjdGVkIGZvciB0aGlzIGZsZWV0LlxuICovXG5GbGVldFR5cGU/OiAoXCJPTl9ERU1BTkRcIiB8IFwiU1BPVFwiKVxuLyoqXG4gKiBBIHVuaXF1ZSBpZGVudGlmaWVyIGZvciBhbiBBV1MgSUFNIHJvbGUgdGhhdCBtYW5hZ2VzIGFjY2VzcyB0byB5b3VyIEFXUyBzZXJ2aWNlcy4gV2l0aCBhbiBpbnN0YW5jZSByb2xlIEFSTiBzZXQsIGFueSBhcHBsaWNhdGlvbiB0aGF0IHJ1bnMgb24gYW4gaW5zdGFuY2UgaW4gdGhpcyBmbGVldCBjYW4gYXNzdW1lIHRoZSByb2xlLCBpbmNsdWRpbmcgaW5zdGFsbCBzY3JpcHRzLCBzZXJ2ZXIgcHJvY2Vzc2VzLCBhbmQgZGFlbW9ucyAoYmFja2dyb3VuZCBwcm9jZXNzZXMpLiBDcmVhdGUgYSByb2xlIG9yIGxvb2sgdXAgYSByb2xlJ3MgQVJOIGZyb20gdGhlIElBTSBkYXNoYm9hcmQgaW4gdGhlIEFXUyBNYW5hZ2VtZW50IENvbnNvbGUuXG4gKi9cbkluc3RhbmNlUm9sZUFSTj86IHN0cmluZ1xuLyoqXG4gKiBDcmVkZW50aWFscyBwcm92aWRlciBpbXBsZW1lbnRhdGlvbiB0aGF0IGxvYWRzIGNyZWRlbnRpYWxzIGZyb20gdGhlIEFtYXpvbiBFQzIgSW5zdGFuY2UgTWV0YWRhdGEgU2VydmljZS5cbiAqL1xuSW5zdGFuY2VSb2xlQ3JlZGVudGlhbHNQcm92aWRlcj86IFwiU0hBUkVEX0NSRURFTlRJQUxfRklMRVwiXG4vKipcbiAqIEBtaW5JdGVtcyAxXG4gKiBAbWF4SXRlbXMgMTAwXG4gKi9cbkxvY2F0aW9ucz86IExvY2F0aW9uQ29uZmlndXJhdGlvbltdXG4vKipcbiAqIFRoaXMgcGFyYW1ldGVyIGlzIG5vIGxvbmdlciB1c2VkLiBXaGVuIGhvc3RpbmcgYSBjdXN0b20gZ2FtZSBidWlsZCwgc3BlY2lmeSB3aGVyZSBBbWF6b24gR2FtZUxpZnQgc2hvdWxkIHN0b3JlIGxvZyBmaWxlcyB1c2luZyB0aGUgQW1hem9uIEdhbWVMaWZ0IHNlcnZlciBBUEkgY2FsbCBQcm9jZXNzUmVhZHkoKVxuICovXG5Mb2dQYXRocz86IHN0cmluZ1tdXG4vKipcbiAqIFtERVBSRUNBVEVEXSBUaGUgbWF4aW11bSB2YWx1ZSB0aGF0IGlzIGFsbG93ZWQgZm9yIHRoZSBmbGVldCdzIGluc3RhbmNlIGNvdW50LiBXaGVuIGNyZWF0aW5nIGEgbmV3IGZsZWV0LCBHYW1lTGlmdCBhdXRvbWF0aWNhbGx5IHNldHMgdGhpcyB2YWx1ZSB0byBcIjFcIi4gT25jZSB0aGUgZmxlZXQgaXMgYWN0aXZlLCB5b3UgY2FuIGNoYW5nZSB0aGlzIHZhbHVlLlxuICovXG5NYXhTaXplPzogbnVtYmVyXG4vKipcbiAqIFRoZSBuYW1lIG9mIGFuIEFtYXpvbiBDbG91ZFdhdGNoIG1ldHJpYyBncm91cC4gQSBtZXRyaWMgZ3JvdXAgYWdncmVnYXRlcyB0aGUgbWV0cmljcyBmb3IgYWxsIGZsZWV0cyBpbiB0aGUgZ3JvdXAuIFNwZWNpZnkgYSBzdHJpbmcgY29udGFpbmluZyB0aGUgbWV0cmljIGdyb3VwIG5hbWUuIFlvdSBjYW4gdXNlIGFuIGV4aXN0aW5nIG5hbWUgb3IgdXNlIGEgbmV3IG5hbWUgdG8gY3JlYXRlIGEgbmV3IG1ldHJpYyBncm91cC4gQ3VycmVudGx5LCB0aGlzIHBhcmFtZXRlciBjYW4gaGF2ZSBvbmx5IG9uZSBzdHJpbmcuXG4gKiBcbiAqIEBtYXhJdGVtcyAxXG4gKi9cbk1ldHJpY0dyb3Vwcz86IHN0cmluZ1tdXG4vKipcbiAqIFtERVBSRUNBVEVEXSBUaGUgbWluaW11bSB2YWx1ZSBhbGxvd2VkIGZvciB0aGUgZmxlZXQncyBpbnN0YW5jZSBjb3VudC4gV2hlbiBjcmVhdGluZyBhIG5ldyBmbGVldCwgR2FtZUxpZnQgYXV0b21hdGljYWxseSBzZXRzIHRoaXMgdmFsdWUgdG8gXCIwXCIuIEFmdGVyIHRoZSBmbGVldCBpcyBhY3RpdmUsIHlvdSBjYW4gY2hhbmdlIHRoaXMgdmFsdWUuXG4gKi9cbk1pblNpemU/OiBudW1iZXJcbi8qKlxuICogQSBkZXNjcmlwdGl2ZSBsYWJlbCB0aGF0IGlzIGFzc29jaWF0ZWQgd2l0aCBhIGZsZWV0LiBGbGVldCBuYW1lcyBkbyBub3QgbmVlZCB0byBiZSB1bmlxdWUuXG4gKi9cbk5hbWU6IHN0cmluZ1xuLyoqXG4gKiBBIGdhbWUgc2Vzc2lvbiBwcm90ZWN0aW9uIHBvbGljeSB0byBhcHBseSB0byBhbGwgZ2FtZSBzZXNzaW9ucyBob3N0ZWQgb24gaW5zdGFuY2VzIGluIHRoaXMgZmxlZXQuIFdoZW4gcHJvdGVjdGVkLCBhY3RpdmUgZ2FtZSBzZXNzaW9ucyBjYW5ub3QgYmUgdGVybWluYXRlZCBkdXJpbmcgYSBzY2FsZS1kb3duIGV2ZW50LiBJZiB0aGlzIHBhcmFtZXRlciBpcyBub3Qgc2V0LCBpbnN0YW5jZXMgaW4gdGhpcyBmbGVldCBkZWZhdWx0IHRvIG5vIHByb3RlY3Rpb24uIFlvdSBjYW4gY2hhbmdlIGEgZmxlZXQncyBwcm90ZWN0aW9uIHBvbGljeSB0byBhZmZlY3QgZnV0dXJlIGdhbWUgc2Vzc2lvbnMgb24gdGhlIGZsZWV0LiBZb3UgY2FuIGFsc28gc2V0IHByb3RlY3Rpb24gZm9yIGluZGl2aWR1YWwgZ2FtZSBzZXNzaW9ucy5cbiAqL1xuTmV3R2FtZVNlc3Npb25Qcm90ZWN0aW9uUG9saWN5PzogKFwiRnVsbFByb3RlY3Rpb25cIiB8IFwiTm9Qcm90ZWN0aW9uXCIpXG4vKipcbiAqIEEgdW5pcXVlIGlkZW50aWZpZXIgZm9yIHRoZSBBV1MgYWNjb3VudCB3aXRoIHRoZSBWUEMgdGhhdCB5b3Ugd2FudCB0byBwZWVyIHlvdXIgQW1hem9uIEdhbWVMaWZ0IGZsZWV0IHdpdGguIFlvdSBjYW4gZmluZCB5b3VyIGFjY291bnQgSUQgaW4gdGhlIEFXUyBNYW5hZ2VtZW50IENvbnNvbGUgdW5kZXIgYWNjb3VudCBzZXR0aW5ncy5cbiAqL1xuUGVlclZwY0F3c0FjY291bnRJZD86IHN0cmluZ1xuLyoqXG4gKiBBIHVuaXF1ZSBpZGVudGlmaWVyIGZvciBhIFZQQyB3aXRoIHJlc291cmNlcyB0byBiZSBhY2Nlc3NlZCBieSB5b3VyIEFtYXpvbiBHYW1lTGlmdCBmbGVldC4gVGhlIFZQQyBtdXN0IGJlIGluIHRoZSBzYW1lIFJlZ2lvbiBhcyB5b3VyIGZsZWV0LiBUbyBsb29rIHVwIGEgVlBDIElELCB1c2UgdGhlIFZQQyBEYXNoYm9hcmQgaW4gdGhlIEFXUyBNYW5hZ2VtZW50IENvbnNvbGUuXG4gKi9cblBlZXJWcGNJZD86IHN0cmluZ1xuUmVzb3VyY2VDcmVhdGlvbkxpbWl0UG9saWN5PzogUmVzb3VyY2VDcmVhdGlvbkxpbWl0UG9saWN5XG4vKipcbiAqIFVuaXF1ZSBmbGVldCBJRFxuICovXG5GbGVldElkPzogc3RyaW5nXG4vKipcbiAqIEEgdW5pcXVlIGlkZW50aWZpZXIgZm9yIGEgYnVpbGQgdG8gYmUgZGVwbG95ZWQgb24gdGhlIG5ldyBmbGVldC4gSWYgeW91IGFyZSBkZXBsb3lpbmcgdGhlIGZsZWV0IHdpdGggYSBjdXN0b20gZ2FtZSBidWlsZCwgeW91IG11c3Qgc3BlY2lmeSB0aGlzIHByb3BlcnR5LiBUaGUgYnVpbGQgbXVzdCBoYXZlIGJlZW4gc3VjY2Vzc2Z1bGx5IHVwbG9hZGVkIHRvIEFtYXpvbiBHYW1lTGlmdCBhbmQgYmUgaW4gYSBSRUFEWSBzdGF0dXMuIFRoaXMgZmxlZXQgc2V0dGluZyBjYW5ub3QgYmUgY2hhbmdlZCBvbmNlIHRoZSBmbGVldCBpcyBjcmVhdGVkLlxuICovXG5CdWlsZElkPzogc3RyaW5nXG4vKipcbiAqIEEgdW5pcXVlIGlkZW50aWZpZXIgZm9yIGEgUmVhbHRpbWUgc2NyaXB0IHRvIGJlIGRlcGxveWVkIG9uIGEgbmV3IFJlYWx0aW1lIFNlcnZlcnMgZmxlZXQuIFRoZSBzY3JpcHQgbXVzdCBoYXZlIGJlZW4gc3VjY2Vzc2Z1bGx5IHVwbG9hZGVkIHRvIEFtYXpvbiBHYW1lTGlmdC4gVGhpcyBmbGVldCBzZXR0aW5nIGNhbm5vdCBiZSBjaGFuZ2VkIG9uY2UgdGhlIGZsZWV0IGlzIGNyZWF0ZWQuXG4gKiBcbiAqIE5vdGU6IEl0IGlzIG5vdCBjdXJyZW50bHkgcG9zc2libGUgdG8gdXNlIHRoZSAhUmVmIGNvbW1hbmQgdG8gcmVmZXJlbmNlIGEgc2NyaXB0IGNyZWF0ZWQgd2l0aCBhIENsb3VkRm9ybWF0aW9uIHRlbXBsYXRlIGZvciB0aGUgZmxlZXQgcHJvcGVydHkgU2NyaXB0SWQuIEluc3RlYWQsIHVzZSBGbjo6R2V0QXR0IFNjcmlwdC5Bcm4gb3IgRm46OkdldEF0dCBTY3JpcHQuSWQgdG8gcmV0cmlldmUgZWl0aGVyIG9mIHRoZXNlIHByb3BlcnRpZXMgYXMgaW5wdXQgZm9yIFNjcmlwdElkLiBBbHRlcm5hdGl2ZWx5LCBlbnRlciBhIFNjcmlwdElkIHN0cmluZyBtYW51YWxseS5cbiAqL1xuU2NyaXB0SWQ/OiBzdHJpbmdcblJ1bnRpbWVDb25maWd1cmF0aW9uPzogUnVudGltZUNvbmZpZ3VyYXRpb25cbi8qKlxuICogVGhpcyBwYXJhbWV0ZXIgaXMgbm8gbG9uZ2VyIHVzZWQgYnV0IGlzIHJldGFpbmVkIGZvciBiYWNrd2FyZCBjb21wYXRpYmlsaXR5LiBJbnN0ZWFkLCBzcGVjaWZ5IHNlcnZlciBsYXVuY2ggcGFyYW1ldGVycyBpbiB0aGUgUnVudGltZUNvbmZpZ3VyYXRpb24gcGFyYW1ldGVyLiBBIHJlcXVlc3QgbXVzdCBzcGVjaWZ5IGVpdGhlciBhIHJ1bnRpbWUgY29uZmlndXJhdGlvbiBvciB2YWx1ZXMgZm9yIGJvdGggU2VydmVyTGF1bmNoUGFyYW1ldGVycyBhbmQgU2VydmVyTGF1bmNoUGF0aC5cbiAqL1xuU2VydmVyTGF1bmNoUGFyYW1ldGVycz86IHN0cmluZ1xuLyoqXG4gKiBUaGlzIHBhcmFtZXRlciBpcyBubyBsb25nZXIgdXNlZC4gSW5zdGVhZCwgc3BlY2lmeSBhIHNlcnZlciBsYXVuY2ggcGF0aCB1c2luZyB0aGUgUnVudGltZUNvbmZpZ3VyYXRpb24gcGFyYW1ldGVyLiBSZXF1ZXN0cyB0aGF0IHNwZWNpZnkgYSBzZXJ2ZXIgbGF1bmNoIHBhdGggYW5kIGxhdW5jaCBwYXJhbWV0ZXJzIGluc3RlYWQgb2YgYSBydW50aW1lIGNvbmZpZ3VyYXRpb24gd2lsbCBjb250aW51ZSB0byB3b3JrLlxuICovXG5TZXJ2ZXJMYXVuY2hQYXRoPzogc3RyaW5nXG4vKipcbiAqIEFuIGFycmF5IG9mIGtleS12YWx1ZSBwYWlycyB0byBhcHBseSB0byB0aGlzIHJlc291cmNlLlxuICogXG4gKiBAbWF4SXRlbXMgMjAwXG4gKi9cblRhZ3M/OiBUYWdbXVxuLyoqXG4gKiBUaGUgQW1hem9uIFJlc291cmNlIE5hbWUgKEFSTikgdGhhdCBpcyBhc3NpZ25lZCB0byBhIEFtYXpvbiBHYW1lTGlmdCBTZXJ2ZXJzIEZsZWV0IHJlc291cmNlIGFuZCB1bmlxdWVseSBpZGVudGlmaWVzIGl0LiBBUk5zIGFyZSB1bmlxdWUgYWNyb3NzIGFsbCBSZWdpb25zLiBJbiBhIEdhbWVMaWZ0IEZsZWV0IEFSTiwgdGhlIHJlc291cmNlIElEIG1hdGNoZXMgdGhlIEZsZWV0SWQgdmFsdWUuXG4gKi9cbkZsZWV0QXJuPzogc3RyaW5nXG59XG4vKipcbiAqIFJ1bGUgdGhhdCBjb250cm9scyBob3cgYSBmbGVldCBpcyBzY2FsZWQuIFNjYWxpbmcgcG9saWNpZXMgYXJlIHVuaXF1ZWx5IGlkZW50aWZpZWQgYnkgdGhlIGNvbWJpbmF0aW9uIG9mIG5hbWUgYW5kIGZsZWV0IElELlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFNjYWxpbmdQb2xpY3kge1xuLyoqXG4gKiBDb21wYXJpc29uIG9wZXJhdG9yIHRvIHVzZSB3aGVuIG1lYXN1cmluZyBhIG1ldHJpYyBhZ2FpbnN0IHRoZSB0aHJlc2hvbGQgdmFsdWUuXG4gKi9cbkNvbXBhcmlzb25PcGVyYXRvcj86IChcIkdyZWF0ZXJUaGFuT3JFcXVhbFRvVGhyZXNob2xkXCIgfCBcIkdyZWF0ZXJUaGFuVGhyZXNob2xkXCIgfCBcIkxlc3NUaGFuVGhyZXNob2xkXCIgfCBcIkxlc3NUaGFuT3JFcXVhbFRvVGhyZXNob2xkXCIpXG4vKipcbiAqIExlbmd0aCBvZiB0aW1lIChpbiBtaW51dGVzKSB0aGUgbWV0cmljIG11c3QgYmUgYXQgb3IgYmV5b25kIHRoZSB0aHJlc2hvbGQgYmVmb3JlIGEgc2NhbGluZyBldmVudCBpcyB0cmlnZ2VyZWQuXG4gKi9cbkV2YWx1YXRpb25QZXJpb2RzPzogbnVtYmVyXG5Mb2NhdGlvbj86IExvY2F0aW9uXG4vKipcbiAqIE5hbWUgb2YgdGhlIEFtYXpvbiBHYW1lTGlmdC1kZWZpbmVkIG1ldHJpYyB0aGF0IGlzIHVzZWQgdG8gdHJpZ2dlciBhIHNjYWxpbmcgYWRqdXN0bWVudC5cbiAqL1xuTWV0cmljTmFtZTogKFwiQWN0aXZhdGluZ0dhbWVTZXNzaW9uc1wiIHwgXCJBY3RpdmVHYW1lU2Vzc2lvbnNcIiB8IFwiQWN0aXZlSW5zdGFuY2VzXCIgfCBcIkF2YWlsYWJsZUdhbWVTZXNzaW9uc1wiIHwgXCJBdmFpbGFibGVQbGF5ZXJTZXNzaW9uc1wiIHwgXCJDdXJyZW50UGxheWVyU2Vzc2lvbnNcIiB8IFwiSWRsZUluc3RhbmNlc1wiIHwgXCJQZXJjZW50QXZhaWxhYmxlR2FtZVNlc3Npb25zXCIgfCBcIlBlcmNlbnRJZGxlSW5zdGFuY2VzXCIgfCBcIlF1ZXVlRGVwdGhcIiB8IFwiV2FpdFRpbWVcIiB8IFwiQ29uY3VycmVudEFjdGl2YXRhYmxlR2FtZVNlc3Npb25zXCIpXG4vKipcbiAqIEEgZGVzY3JpcHRpdmUgbGFiZWwgdGhhdCBpcyBhc3NvY2lhdGVkIHdpdGggYSBmbGVldCdzIHNjYWxpbmcgcG9saWN5LiBQb2xpY3kgbmFtZXMgZG8gbm90IG5lZWQgdG8gYmUgdW5pcXVlLlxuICovXG5OYW1lOiBzdHJpbmdcbi8qKlxuICogVGhlIHR5cGUgb2Ygc2NhbGluZyBwb2xpY3kgdG8gY3JlYXRlLiBGb3IgYSB0YXJnZXQtYmFzZWQgcG9saWN5LCBzZXQgdGhlIHBhcmFtZXRlciBNZXRyaWNOYW1lIHRvICdQZXJjZW50QXZhaWxhYmxlR2FtZVNlc3Npb25zJyBhbmQgc3BlY2lmeSBhIFRhcmdldENvbmZpZ3VyYXRpb24uIEZvciBhIHJ1bGUtYmFzZWQgcG9saWN5IHNldCB0aGUgZm9sbG93aW5nIHBhcmFtZXRlcnM6IE1ldHJpY05hbWUsIENvbXBhcmlzb25PcGVyYXRvciwgVGhyZXNob2xkLCBFdmFsdWF0aW9uUGVyaW9kcywgU2NhbGluZ0FkanVzdG1lbnRUeXBlLCBhbmQgU2NhbGluZ0FkanVzdG1lbnQuXG4gKi9cblBvbGljeVR5cGU/OiAoXCJSdWxlQmFzZWRcIiB8IFwiVGFyZ2V0QmFzZWRcIilcbi8qKlxuICogQW1vdW50IG9mIGFkanVzdG1lbnQgdG8gbWFrZSwgYmFzZWQgb24gdGhlIHNjYWxpbmcgYWRqdXN0bWVudCB0eXBlLlxuICovXG5TY2FsaW5nQWRqdXN0bWVudD86IG51bWJlclxuLyoqXG4gKiBUaGUgdHlwZSBvZiBhZGp1c3RtZW50IHRvIG1ha2UgdG8gYSBmbGVldCdzIGluc3RhbmNlIGNvdW50LlxuICovXG5TY2FsaW5nQWRqdXN0bWVudFR5cGU/OiAoXCJDaGFuZ2VJbkNhcGFjaXR5XCIgfCBcIkV4YWN0Q2FwYWNpdHlcIiB8IFwiUGVyY2VudENoYW5nZUluQ2FwYWNpdHlcIilcbi8qKlxuICogQ3VycmVudCBzdGF0dXMgb2YgdGhlIHNjYWxpbmcgcG9saWN5LiBUaGUgc2NhbGluZyBwb2xpY3kgY2FuIGJlIGluIGZvcmNlIG9ubHkgd2hlbiBpbiBhbiBBQ1RJVkUgc3RhdHVzLiBTY2FsaW5nIHBvbGljaWVzIGNhbiBiZSBzdXNwZW5kZWQgZm9yIGluZGl2aWR1YWwgZmxlZXRzLiBJZiB0aGUgcG9saWN5IGlzIHN1c3BlbmRlZCBmb3IgYSBmbGVldCwgdGhlIHBvbGljeSBzdGF0dXMgZG9lcyBub3QgY2hhbmdlLlxuICovXG5TdGF0dXM/OiAoXCJBQ1RJVkVcIiB8IFwiVVBEQVRFX1JFUVVFU1RFRFwiIHwgXCJVUERBVElOR1wiIHwgXCJERUxFVEVfUkVRVUVTVEVEXCIgfCBcIkRFTEVUSU5HXCIgfCBcIkRFTEVURURcIiB8IFwiRVJST1JcIilcblRhcmdldENvbmZpZ3VyYXRpb24/OiBUYXJnZXRDb25maWd1cmF0aW9uXG4vKipcbiAqIE1ldHJpYyB2YWx1ZSB1c2VkIHRvIHRyaWdnZXIgYSBzY2FsaW5nIGV2ZW50LlxuICovXG5UaHJlc2hvbGQ/OiBudW1iZXJcbi8qKlxuICogVGhlIGN1cnJlbnQgc3RhdHVzIG9mIHRoZSBmbGVldCdzIHNjYWxpbmcgcG9saWNpZXMgaW4gYSByZXF1ZXN0ZWQgZmxlZXQgbG9jYXRpb24uIFRoZSBzdGF0dXMgUEVORElOR19VUERBVEUgaW5kaWNhdGVzIHRoYXQgYW4gdXBkYXRlIHdhcyByZXF1ZXN0ZWQgZm9yIHRoZSBmbGVldCBidXQgaGFzIG5vdCB5ZXQgYmVlbiBjb21wbGV0ZWQgZm9yIHRoZSBsb2NhdGlvbi5cbiAqL1xuVXBkYXRlU3RhdHVzPzogXCJQRU5ESU5HX1VQREFURVwiXG59XG4vKipcbiAqIEFuIG9iamVjdCB0aGF0IGNvbnRhaW5zIHNldHRpbmdzIGZvciBhIHRhcmdldC1iYXNlZCBzY2FsaW5nIHBvbGljeS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBUYXJnZXRDb25maWd1cmF0aW9uIHtcbi8qKlxuICogRGVzaXJlZCB2YWx1ZSB0byB1c2Ugd2l0aCBhIHRhcmdldC1iYXNlZCBzY2FsaW5nIHBvbGljeS4gVGhlIHZhbHVlIG11c3QgYmUgcmVsZXZhbnQgZm9yIHdoYXRldmVyIG1ldHJpYyB0aGUgc2NhbGluZyBwb2xpY3kgaXMgdXNpbmcuIEZvciBleGFtcGxlLCBpbiBhIHBvbGljeSB1c2luZyB0aGUgbWV0cmljIFBlcmNlbnRBdmFpbGFibGVHYW1lU2Vzc2lvbnMsIHRoZSB0YXJnZXQgdmFsdWUgc2hvdWxkIGJlIHRoZSBwcmVmZXJyZWQgc2l6ZSBvZiB0aGUgZmxlZXQncyBidWZmZXIgKHRoZSBwZXJjZW50IG9mIGNhcGFjaXR5IHRoYXQgc2hvdWxkIGJlIGlkbGUgYW5kIHJlYWR5IGZvciBuZXcgZ2FtZSBzZXNzaW9ucykuXG4gKi9cblRhcmdldFZhbHVlOiBudW1iZXJcbn1cbi8qKlxuICogQ29uZmlndXJhdGlvbiBmb3IgQW55d2hlcmUgZmxlZXQuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQW55d2hlcmVDb25maWd1cmF0aW9uIHtcbi8qKlxuICogQ29zdCBvZiBjb21wdXRlIGNhbiBiZSBzcGVjaWZpZWQgb24gQW55d2hlcmUgRmxlZXRzIHRvIHByaW9yaXRpemUgcGxhY2VtZW50IGFjcm9zcyBRdWV1ZSBkZXN0aW5hdGlvbnMgYmFzZWQgb24gQ29zdC5cbiAqL1xuQ29zdDogc3RyaW5nXG59XG4vKipcbiAqIEluZGljYXRlcyB3aGV0aGVyIHRvIGdlbmVyYXRlIGEgVExTL1NTTCBjZXJ0aWZpY2F0ZSBmb3IgdGhlIG5ldyBmbGVldC4gVExTIGNlcnRpZmljYXRlcyBhcmUgdXNlZCBmb3IgZW5jcnlwdGluZyB0cmFmZmljIGJldHdlZW4gZ2FtZSBjbGllbnRzIGFuZCBnYW1lIHNlcnZlcnMgcnVubmluZyBvbiBHYW1lTGlmdC4gSWYgdGhpcyBwYXJhbWV0ZXIgaXMgbm90IHNldCwgY2VydGlmaWNhdGUgZ2VuZXJhdGlvbiBpcyBkaXNhYmxlZC4gVGhpcyBmbGVldCBzZXR0aW5nIGNhbm5vdCBiZSBjaGFuZ2VkIG9uY2UgdGhlIGZsZWV0IGlzIGNyZWF0ZWQuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQ2VydGlmaWNhdGVDb25maWd1cmF0aW9uIHtcbkNlcnRpZmljYXRlVHlwZTogKFwiRElTQUJMRURcIiB8IFwiR0VORVJBVEVEXCIpXG59XG4vKipcbiAqIEEgcmFuZ2Ugb2YgSVAgYWRkcmVzc2VzIGFuZCBwb3J0IHNldHRpbmdzIHRoYXQgYWxsb3cgaW5ib3VuZCB0cmFmZmljIHRvIGNvbm5lY3QgdG8gc2VydmVyIHByb2Nlc3NlcyBvbiBhbiBBbWF6b24gR2FtZUxpZnQgaG9zdGluZyByZXNvdXJjZS4gTmV3IGdhbWUgc2Vzc2lvbnMgdGhhdCBhcmUgc3RhcnRlZCBvbiB0aGUgZmxlZXQgYXJlIGFzc2lnbmVkIGFuIElQIGFkZHJlc3MvcG9ydCBudW1iZXIgY29tYmluYXRpb24sIHdoaWNoIG11c3QgZmFsbCBpbnRvIHRoZSBmbGVldCdzIGFsbG93ZWQgcmFuZ2VzLiBGb3IgZmxlZXRzIGNyZWF0ZWQgd2l0aCBhIGN1c3RvbSBnYW1lIHNlcnZlciwgdGhlIHJhbmdlcyByZWZsZWN0IHRoZSBzZXJ2ZXIncyBnYW1lIHNlc3Npb24gYXNzaWdubWVudHMuIEZvciBSZWFsdGltZSBTZXJ2ZXJzIGZsZWV0cywgQW1hem9uIEdhbWVMaWZ0IGF1dG9tYXRpY2FsbHkgb3BlbnMgdHdvIHBvcnQgcmFuZ2VzLCBvbmUgZm9yIFRDUCBtZXNzYWdpbmcgYW5kIG9uZSBmb3IgVURQLCBmb3IgdXNlIGJ5IHRoZSBSZWFsdGltZSBzZXJ2ZXJzLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIElwUGVybWlzc2lvbiB7XG4vKipcbiAqIEEgc3RhcnRpbmcgdmFsdWUgZm9yIGEgcmFuZ2Ugb2YgYWxsb3dlZCBwb3J0IG51bWJlcnMuXG4gKi9cbkZyb21Qb3J0OiBudW1iZXJcbi8qKlxuICogQSByYW5nZSBvZiBhbGxvd2VkIElQIGFkZHJlc3Nlcy4gVGhpcyB2YWx1ZSBtdXN0IGJlIGV4cHJlc3NlZCBpbiBDSURSIG5vdGF0aW9uLiBFeGFtcGxlOiBcIjAwMC4wMDAuMDAwLjAwMC9bc3VibmV0IG1hc2tdXCIgb3Igb3B0aW9uYWxseSB0aGUgc2hvcnRlbmVkIHZlcnNpb24gXCIwLjAuMC4wL1tzdWJuZXQgbWFza11cIi5cbiAqL1xuSXBSYW5nZTogc3RyaW5nXG4vKipcbiAqIFRoZSBuZXR3b3JrIGNvbW11bmljYXRpb24gcHJvdG9jb2wgdXNlZCBieSB0aGUgZmxlZXQuXG4gKi9cblByb3RvY29sOiAoXCJUQ1BcIiB8IFwiVURQXCIpXG4vKipcbiAqIEFuIGVuZGluZyB2YWx1ZSBmb3IgYSByYW5nZSBvZiBhbGxvd2VkIHBvcnQgbnVtYmVycy4gUG9ydCBudW1iZXJzIGFyZSBlbmQtaW5jbHVzaXZlLiBUaGlzIHZhbHVlIG11c3QgYmUgaGlnaGVyIHRoYW4gRnJvbVBvcnQuXG4gKi9cblRvUG9ydDogbnVtYmVyXG59XG4vKipcbiAqIEEgcmVtb3RlIGxvY2F0aW9uIHdoZXJlIGEgbXVsdGktbG9jYXRpb24gZmxlZXQgY2FuIGRlcGxveSBFQzIgaW5zdGFuY2VzIGZvciBnYW1lIGhvc3RpbmcuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgTG9jYXRpb25Db25maWd1cmF0aW9uIHtcbkxvY2F0aW9uOiBMb2NhdGlvblxuTG9jYXRpb25DYXBhY2l0eT86IExvY2F0aW9uQ2FwYWNpdHlcbn1cbi8qKlxuICogQ3VycmVudCByZXNvdXJjZSBjYXBhY2l0eSBzZXR0aW5ncyBpbiBhIHNwZWNpZmllZCBmbGVldCBvciBsb2NhdGlvbi4gVGhlIGxvY2F0aW9uIHZhbHVlIG1pZ2h0IHJlZmVyIHRvIGEgZmxlZXQncyByZW1vdGUgbG9jYXRpb24gb3IgaXRzIGhvbWUgUmVnaW9uLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIExvY2F0aW9uQ2FwYWNpdHkge1xuLyoqXG4gKiBEZWZhdWx0cyB0byBNaW5TaXplIGlmIG5vdCBkZWZpbmVkLiBUaGUgbnVtYmVyIG9mIEVDMiBpbnN0YW5jZXMgeW91IHdhbnQgdG8gbWFpbnRhaW4gaW4gdGhlIHNwZWNpZmllZCBmbGVldCBsb2NhdGlvbi4gVGhpcyB2YWx1ZSBtdXN0IGZhbGwgYmV0d2VlbiB0aGUgbWluaW11bSBhbmQgbWF4aW11bSBzaXplIGxpbWl0cy5cbiAqL1xuRGVzaXJlZEVDMkluc3RhbmNlcz86IG51bWJlclxuLyoqXG4gKiBUaGUgbWluaW11bSB2YWx1ZSBhbGxvd2VkIGZvciB0aGUgZmxlZXQncyBpbnN0YW5jZSBjb3VudCBmb3IgYSBsb2NhdGlvbi4gV2hlbiBjcmVhdGluZyBhIG5ldyBmbGVldCwgR2FtZUxpZnQgYXV0b21hdGljYWxseSBzZXRzIHRoaXMgdmFsdWUgdG8gXCIwXCIuIEFmdGVyIHRoZSBmbGVldCBpcyBhY3RpdmUsIHlvdSBjYW4gY2hhbmdlIHRoaXMgdmFsdWUuXG4gKi9cbk1pblNpemU/OiBudW1iZXJcbi8qKlxuICogVGhlIG1heGltdW0gdmFsdWUgdGhhdCBpcyBhbGxvd2VkIGZvciB0aGUgZmxlZXQncyBpbnN0YW5jZSBjb3VudCBmb3IgYSBsb2NhdGlvbi4gV2hlbiBjcmVhdGluZyBhIG5ldyBmbGVldCwgR2FtZUxpZnQgYXV0b21hdGljYWxseSBzZXRzIHRoaXMgdmFsdWUgdG8gXCIxXCIuIE9uY2UgdGhlIGZsZWV0IGlzIGFjdGl2ZSwgeW91IGNhbiBjaGFuZ2UgdGhpcyB2YWx1ZS5cbiAqL1xuTWF4U2l6ZTogbnVtYmVyXG5NYW5hZ2VkQ2FwYWNpdHlDb25maWd1cmF0aW9uPzogTWFuYWdlZENhcGFjaXR5Q29uZmlndXJhdGlvblxufVxuLyoqXG4gKiBDb25maWd1cmF0aW9uIG9wdGlvbnMgZm9yIEFtYXpvbiBHYW1lTGlmdCBTZXJ2ZXJzLW1hbmFnZWQgY2FwYWNpdHkgYmVoYXZpb3IuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgTWFuYWdlZENhcGFjaXR5Q29uZmlndXJhdGlvbiB7XG4vKipcbiAqIFRoZSBzdHJhdGVneSBBbWF6b24gR2FtZUxpZnQgU2VydmVycyB3aWxsIHVzZSB0byBhdXRvbWF0aWNhbGx5IHNjYWxlIHlvdXIgY2FwYWNpdHkgdG8gYW5kIGZyb20gemVybyBpbiByZXNwb25zZSB0byBnYW1lIHNlc3Npb24gYWN0aXZpdHkuIEdhbWUgc2Vzc2lvbiBhY3Rpdml0eSByZWZlcnMgdG8gYW55IGFjdGl2ZSBydW5uaW5nIHNlc3Npb25zIG9yIGdhbWUgc2Vzc2lvbiByZXF1ZXN0cy4gV2hlbiBzZXQgdG8gU0NBTEVfVE9fQU5EX0ZST01fWkVSTywgTWluU2l6ZSBtdXN0IG5vdCBiZSBzcGVjaWZpZWQgYW5kIHdpbGwgYmUgbWFuYWdlZCBhdXRvbWF0aWNhbGx5LiBXaGVuIHNldCB0byBNQU5VQUwsIE1pblNpemUgaXMgcmVxdWlyZWQuXG4gKi9cblplcm9DYXBhY2l0eVN0cmF0ZWd5OiAoXCJTQ0FMRV9UT19BTkRfRlJPTV9aRVJPXCIgfCBcIk1BTlVBTFwiKVxuLyoqXG4gKiBMZW5ndGggb2YgdGltZSwgaW4gbWludXRlcywgdGhhdCBBbWF6b24gR2FtZUxpZnQgU2VydmVycyB3aWxsIHdhaXQgYmVmb3JlIHNjYWxpbmcgaW4geW91ciBNaW5TaXplIGFuZCBEZXNpcmVkSW5zdGFuY2VzIHRvIDAgYWZ0ZXIgYSBwZXJpb2Qgd2l0aCBubyBnYW1lIHNlc3Npb24gYWN0aXZpdHkuXG4gKi9cblNjYWxlSW5BZnRlckluYWN0aXZpdHlNaW51dGVzPzogbnVtYmVyXG59XG4vKipcbiAqIEEgcG9saWN5IHRoYXQgbGltaXRzIHRoZSBudW1iZXIgb2YgZ2FtZSBzZXNzaW9ucyBhbiBpbmRpdmlkdWFsIHBsYXllciBjYW4gY3JlYXRlIG92ZXIgYSBzcGFuIG9mIHRpbWUgZm9yIHRoaXMgZmxlZXQuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgUmVzb3VyY2VDcmVhdGlvbkxpbWl0UG9saWN5IHtcbi8qKlxuICogVGhlIG1heGltdW0gbnVtYmVyIG9mIGdhbWUgc2Vzc2lvbnMgdGhhdCBhbiBpbmRpdmlkdWFsIGNhbiBjcmVhdGUgZHVyaW5nIHRoZSBwb2xpY3kgcGVyaW9kLlxuICovXG5OZXdHYW1lU2Vzc2lvbnNQZXJDcmVhdG9yPzogbnVtYmVyXG4vKipcbiAqIFRoZSB0aW1lIHNwYW4gdXNlZCBpbiBldmFsdWF0aW5nIHRoZSByZXNvdXJjZSBjcmVhdGlvbiBsaW1pdCBwb2xpY3kuXG4gKi9cblBvbGljeVBlcmlvZEluTWludXRlcz86IG51bWJlclxufVxuLyoqXG4gKiBJbnN0cnVjdGlvbnMgZm9yIGxhdW5jaGluZyBzZXJ2ZXIgcHJvY2Vzc2VzIG9uIGVhY2ggaW5zdGFuY2UgaW4gdGhlIGZsZWV0LiBTZXJ2ZXIgcHJvY2Vzc2VzIHJ1biBlaXRoZXIgYSBjdXN0b20gZ2FtZSBidWlsZCBleGVjdXRhYmxlIG9yIGEgUmVhbHRpbWUgc2NyaXB0LiBUaGUgcnVudGltZSBjb25maWd1cmF0aW9uIGRlZmluZXMgdGhlIHNlcnZlciBleGVjdXRhYmxlcyBvciBsYXVuY2ggc2NyaXB0IGZpbGUsIGxhdW5jaCBwYXJhbWV0ZXJzLCBhbmQgdGhlIG51bWJlciBvZiBwcm9jZXNzZXMgdG8gcnVuIGNvbmN1cnJlbnRseSBvbiBlYWNoIGluc3RhbmNlLiBXaGVuIGNyZWF0aW5nIGEgZmxlZXQsIHRoZSBydW50aW1lIGNvbmZpZ3VyYXRpb24gbXVzdCBoYXZlIGF0IGxlYXN0IG9uZSBzZXJ2ZXIgcHJvY2VzcyBjb25maWd1cmF0aW9uOyBvdGhlcndpc2UgdGhlIHJlcXVlc3QgZmFpbHMgd2l0aCBhbiBpbnZhbGlkIHJlcXVlc3QgZXhjZXB0aW9uLlxuICogXG4gKiBUaGlzIHBhcmFtZXRlciBpcyByZXF1aXJlZCB1bmxlc3MgdGhlIHBhcmFtZXRlcnMgU2VydmVyTGF1bmNoUGF0aCBhbmQgU2VydmVyTGF1bmNoUGFyYW1ldGVycyBhcmUgZGVmaW5lZC4gUnVudGltZSBjb25maWd1cmF0aW9uIGhhcyByZXBsYWNlZCB0aGVzZSBwYXJhbWV0ZXJzLCBidXQgZmxlZXRzIHRoYXQgdXNlIHRoZW0gd2lsbCBjb250aW51ZSB0byB3b3JrLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFJ1bnRpbWVDb25maWd1cmF0aW9uIHtcbi8qKlxuICogVGhlIG1heGltdW0gYW1vdW50IG9mIHRpbWUgKGluIHNlY29uZHMpIHRoYXQgYSBnYW1lIHNlc3Npb24gY2FuIHJlbWFpbiBpbiBzdGF0dXMgQUNUSVZBVElORy4gSWYgdGhlIGdhbWUgc2Vzc2lvbiBpcyBub3QgYWN0aXZlIGJlZm9yZSB0aGUgdGltZW91dCwgYWN0aXZhdGlvbiBpcyB0ZXJtaW5hdGVkIGFuZCB0aGUgZ2FtZSBzZXNzaW9uIHN0YXR1cyBpcyBjaGFuZ2VkIHRvIFRFUk1JTkFURUQuXG4gKi9cbkdhbWVTZXNzaW9uQWN0aXZhdGlvblRpbWVvdXRTZWNvbmRzPzogbnVtYmVyXG4vKipcbiAqIFRoZSBtYXhpbXVtIG51bWJlciBvZiBnYW1lIHNlc3Npb25zIHdpdGggc3RhdHVzIEFDVElWQVRJTkcgdG8gYWxsb3cgb24gYW4gaW5zdGFuY2Ugc2ltdWx0YW5lb3VzbHkuIFRoaXMgc2V0dGluZyBsaW1pdHMgdGhlIGFtb3VudCBvZiBpbnN0YW5jZSByZXNvdXJjZXMgdGhhdCBjYW4gYmUgdXNlZCBmb3IgbmV3IGdhbWUgYWN0aXZhdGlvbnMgYXQgYW55IG9uZSB0aW1lLlxuICovXG5NYXhDb25jdXJyZW50R2FtZVNlc3Npb25BY3RpdmF0aW9ucz86IG51bWJlclxuLyoqXG4gKiBBIGNvbGxlY3Rpb24gb2Ygc2VydmVyIHByb2Nlc3MgY29uZmlndXJhdGlvbnMgdGhhdCBkZXNjcmliZSB3aGljaCBzZXJ2ZXIgcHJvY2Vzc2VzIHRvIHJ1biBvbiBlYWNoIGluc3RhbmNlIGluIGEgZmxlZXQuXG4gKiBcbiAqIEBtYXhJdGVtcyA1MFxuICovXG5TZXJ2ZXJQcm9jZXNzZXM/OiBTZXJ2ZXJQcm9jZXNzW11cbn1cbi8qKlxuICogQSBzZXQgb2YgaW5zdHJ1Y3Rpb25zIGZvciBsYXVuY2hpbmcgc2VydmVyIHByb2Nlc3NlcyBvbiBlYWNoIGluc3RhbmNlIGluIGEgZmxlZXQuIEVhY2ggaW5zdHJ1Y3Rpb24gc2V0IGlkZW50aWZpZXMgdGhlIGxvY2F0aW9uIG9mIHRoZSBzZXJ2ZXIgZXhlY3V0YWJsZSwgb3B0aW9uYWwgbGF1bmNoIHBhcmFtZXRlcnMsIGFuZCB0aGUgbnVtYmVyIG9mIHNlcnZlciBwcm9jZXNzZXMgd2l0aCB0aGlzIGNvbmZpZ3VyYXRpb24gdG8gbWFpbnRhaW4gY29uY3VycmVudGx5IG9uIHRoZSBpbnN0YW5jZS4gU2VydmVyIHByb2Nlc3MgY29uZmlndXJhdGlvbnMgbWFrZSB1cCBhIGZsZWV0J3MgUnVudGltZUNvbmZpZ3VyYXRpb24uXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgU2VydmVyUHJvY2VzcyB7XG4vKipcbiAqIFRoZSBudW1iZXIgb2Ygc2VydmVyIHByb2Nlc3NlcyB0aGF0IHVzZSB0aGlzIGNvbmZpZ3VyYXRpb24gdG8gcnVuIGNvbmN1cnJlbnRseSBvbiBhbiBpbnN0YW5jZS5cbiAqL1xuQ29uY3VycmVudEV4ZWN1dGlvbnM6IG51bWJlclxuLyoqXG4gKiBUaGUgbG9jYXRpb24gb2YgdGhlIHNlcnZlciBleGVjdXRhYmxlIGluIGEgY3VzdG9tIGdhbWUgYnVpbGQgb3IgdGhlIG5hbWUgb2YgdGhlIFJlYWx0aW1lIHNjcmlwdCBmaWxlIHRoYXQgY29udGFpbnMgdGhlIEluaXQoKSBmdW5jdGlvbi4gR2FtZSBidWlsZHMgYW5kIFJlYWx0aW1lIHNjcmlwdHMgYXJlIGluc3RhbGxlZCBvbiBpbnN0YW5jZXMgYXQgdGhlIHJvb3Q6XG4gKiBcbiAqIFdpbmRvd3MgKGZvciBjdXN0b20gZ2FtZSBidWlsZHMgb25seSk6IEM6XFxnYW1lLiBFeGFtcGxlOiBcIkM6XFxnYW1lXFxNeUdhbWVcXHNlcnZlci5leGVcIlxuICogXG4gKiBMaW51eDogL2xvY2FsL2dhbWUuIEV4YW1wbGVzOiBcIi9sb2NhbC9nYW1lL015R2FtZS9zZXJ2ZXIuZXhlXCIgb3IgXCIvbG9jYWwvZ2FtZS9NeVJlYWx0aW1lU2NyaXB0LmpzXCJcbiAqL1xuTGF1bmNoUGF0aDogc3RyaW5nXG4vKipcbiAqIEFuIG9wdGlvbmFsIGxpc3Qgb2YgcGFyYW1ldGVycyB0byBwYXNzIHRvIHRoZSBzZXJ2ZXIgZXhlY3V0YWJsZSBvciBSZWFsdGltZSBzY3JpcHQgb24gbGF1bmNoLlxuICovXG5QYXJhbWV0ZXJzPzogc3RyaW5nXG59XG4vKipcbiAqIEEga2V5LXZhbHVlIHBhaXIgdG8gYXNzb2NpYXRlIHdpdGggYSByZXNvdXJjZS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBUYWcge1xuLyoqXG4gKiBUaGUga2V5IG5hbWUgb2YgdGhlIHRhZy4gWW91IGNhbiBzcGVjaWZ5IGEgdmFsdWUgdGhhdCBpcyAxIHRvIDEyOCBVbmljb2RlIGNoYXJhY3RlcnMgaW4gbGVuZ3RoLlxuICovXG5LZXk6IHN0cmluZ1xuLyoqXG4gKiBUaGUgdmFsdWUgZm9yIHRoZSB0YWcuIFlvdSBjYW4gc3BlY2lmeSBhIHZhbHVlIHRoYXQgaXMgMCB0byAyNTYgVW5pY29kZSBjaGFyYWN0ZXJzIGluIGxlbmd0aC5cbiAqL1xuVmFsdWU6IHN0cmluZ1xufVxuIl19