@horietakehiro/aws-cdk-utul 0.33.44 → 0.33.46
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/lib/types/cfn-resource-types/aws-autoscaling-autoscalinggroup.d.ts +50 -0
- package/lib/types/cfn-resource-types/aws-autoscaling-autoscalinggroup.js +1 -1
- package/lib/types/cfn-resource-types/aws-bedrock-blueprint.d.ts +1 -1
- package/lib/types/cfn-resource-types/aws-bedrock-blueprint.js +1 -1
- package/lib/types/cfn-resource-types/aws-cloudfront-cachepolicy.d.ts +12 -12
- package/lib/types/cfn-resource-types/aws-cloudfront-cachepolicy.js +1 -1
- package/lib/types/cfn-resource-types/aws-cloudfront-connectiongroup.d.ts +27 -1
- package/lib/types/cfn-resource-types/aws-cloudfront-connectiongroup.js +1 -1
- package/lib/types/cfn-resource-types/aws-cloudfront-distribution.d.ts +36 -21
- package/lib/types/cfn-resource-types/aws-cloudfront-distribution.js +1 -1
- package/lib/types/cfn-resource-types/aws-cloudfront-distributiontenant.d.ts +95 -1
- package/lib/types/cfn-resource-types/aws-cloudfront-distributiontenant.js +1 -1
- package/lib/types/cfn-resource-types/aws-cloudfront-originaccesscontrol.d.ts +3 -3
- package/lib/types/cfn-resource-types/aws-cloudfront-originaccesscontrol.js +1 -1
- package/lib/types/cfn-resource-types/aws-cloudfront-originrequestpolicy.d.ts +13 -13
- package/lib/types/cfn-resource-types/aws-cloudfront-originrequestpolicy.js +1 -1
- package/lib/types/cfn-resource-types/aws-cloudfront-realtimelogconfig.d.ts +2 -2
- package/lib/types/cfn-resource-types/aws-cloudfront-realtimelogconfig.js +1 -1
- package/lib/types/cfn-resource-types/aws-cloudfront-responseheaderspolicy.d.ts +1 -1
- package/lib/types/cfn-resource-types/aws-cloudfront-responseheaderspolicy.js +1 -1
- package/lib/types/cfn-resource-types/aws-codepipeline-pipeline.d.ts +4 -0
- package/lib/types/cfn-resource-types/aws-codepipeline-pipeline.js +1 -1
- package/lib/types/cfn-resource-types/aws-datazone-environmentblueprintconfiguration.d.ts +17 -3
- package/lib/types/cfn-resource-types/aws-datazone-environmentblueprintconfiguration.js +1 -1
- package/lib/types/cfn-resource-types/aws-datazone-project.d.ts +29 -0
- package/lib/types/cfn-resource-types/aws-datazone-project.js +1 -1
- package/lib/types/cfn-resource-types/aws-ec2-host.d.ts +8 -0
- package/lib/types/cfn-resource-types/aws-ec2-host.js +1 -1
- package/lib/types/cfn-resource-types/aws-ec2-launchtemplate.d.ts +1 -0
- package/lib/types/cfn-resource-types/aws-ec2-launchtemplate.js +1 -1
- package/lib/types/cfn-resource-types/aws-ecr-registryscanningconfiguration.d.ts +22 -30
- package/lib/types/cfn-resource-types/aws-ecr-registryscanningconfiguration.js +1 -1
- package/lib/types/cfn-resource-types/aws-ecs-service.d.ts +7 -4
- package/lib/types/cfn-resource-types/aws-ecs-service.js +1 -1
- package/lib/types/cfn-resource-types/aws-efs-mounttarget.d.ts +5 -5
- package/lib/types/cfn-resource-types/aws-efs-mounttarget.js +1 -1
- package/lib/types/cfn-resource-types/aws-gamelift-fleet.d.ts +23 -0
- package/lib/types/cfn-resource-types/aws-gamelift-fleet.js +1 -1
- package/lib/types/cfn-resource-types/aws-omics-workflow.d.ts +4 -0
- package/lib/types/cfn-resource-types/aws-omics-workflow.js +1 -1
- package/lib/types/cfn-resource-types/aws-omics-workflowversion.d.ts +50 -0
- package/lib/types/cfn-resource-types/aws-omics-workflowversion.js +3 -0
- package/lib/types/cfn-resource-types/aws-rolesanywhere-trustanchor.d.ts +2 -2
- package/lib/types/cfn-resource-types/aws-rolesanywhere-trustanchor.js +1 -1
- package/lib/types/cfn-resource-types/aws-sagemaker-app.d.ts +8 -0
- package/lib/types/cfn-resource-types/aws-sagemaker-app.js +1 -1
- package/lib/types/cfn-resource-types/aws-sagemaker-domain.d.ts +43 -0
- package/lib/types/cfn-resource-types/aws-sagemaker-domain.js +1 -1
- package/lib/types/cfn-resource-types/aws-sagemaker-userprofile.d.ts +39 -0
- package/lib/types/cfn-resource-types/aws-sagemaker-userprofile.js +1 -1
- package/lib/types/cfn-resource-types/aws-securityhub-automationrule.d.ts +16 -16
- package/lib/types/cfn-resource-types/aws-securityhub-automationrule.js +1 -1
- package/lib/types/cfn-resource-types/aws-securityhub-findingaggregator.d.ts +3 -3
- package/lib/types/cfn-resource-types/aws-securityhub-findingaggregator.js +1 -1
- package/lib/types/cfn-resource-types/aws-securityhub-standard.d.ts +1 -1
- package/lib/types/cfn-resource-types/aws-securityhub-standard.js +1 -1
- package/lib/types/cfn-resource-types/aws-ssm-document.d.ts +1 -1
- package/lib/types/cfn-resource-types/aws-ssm-document.js +1 -1
- package/lib/types/cfn-resource-types.d.ts +2 -0
- package/lib/types/cfn-resource-types.js +12 -10
- package/package.json +1 -1
|
@@ -1,5 +1,15 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Specify an instance family to use as the baseline reference for CPU performance. All instance types that match your specified attributes will be compared against the CPU performance of the referenced instance family, regardless of CPU manufacturer or architecture differences.
|
|
3
|
+
* Currently only one instance family can be specified in the list.
|
|
4
|
+
*/
|
|
1
5
|
export type PerformanceFactorReferenceSetRequest = PerformanceFactorReferenceRequest[];
|
|
6
|
+
/**
|
|
7
|
+
* The Capacity Reservation IDs to launch instances into.
|
|
8
|
+
*/
|
|
2
9
|
export type CapacityReservationIds = string[];
|
|
10
|
+
/**
|
|
11
|
+
* The resource group ARNs of the Capacity Reservation to launch instances into.
|
|
12
|
+
*/
|
|
3
13
|
export type CapacityReservationResourceGroupArns = string[];
|
|
4
14
|
/**
|
|
5
15
|
* The ``AWS::AutoScaling::AutoScalingGroup`` resource defines an Amazon EC2 Auto Scaling group, which is a collection of Amazon EC2 instances that are treated as a logical grouping for the purposes of automatic scaling and management.
|
|
@@ -89,6 +99,7 @@ export interface _AWS_AUTOSCALING_AUTOSCALINGGROUP {
|
|
|
89
99
|
* If you specify ``LaunchTemplate``, ``MixedInstancesPolicy``, or ``LaunchConfigurationName``, don't specify ``InstanceId``.
|
|
90
100
|
*/
|
|
91
101
|
InstanceId?: string;
|
|
102
|
+
AutoScalingGroupARN?: string;
|
|
92
103
|
/**
|
|
93
104
|
* A list of Availability Zones where instances in the Auto Scaling group can be created. Used for launching into the default VPC subnet in each Availability Zone when not using the ``VPCZoneIdentifier`` property, or for attaching a network interface when an existing network interface ID is specified in a launch template.
|
|
94
105
|
*/
|
|
@@ -583,13 +594,39 @@ export interface NetworkBandwidthGbpsRequest {
|
|
|
583
594
|
*/
|
|
584
595
|
Max?: number;
|
|
585
596
|
}
|
|
597
|
+
/**
|
|
598
|
+
* The baseline performance factors for the instance requirements.
|
|
599
|
+
*/
|
|
586
600
|
export interface BaselinePerformanceFactorsRequest {
|
|
587
601
|
Cpu?: CpuPerformanceFactorRequest;
|
|
588
602
|
}
|
|
603
|
+
/**
|
|
604
|
+
* The CPU performance to consider, using an instance family as the baseline reference.
|
|
605
|
+
*/
|
|
589
606
|
export interface CpuPerformanceFactorRequest {
|
|
590
607
|
References?: PerformanceFactorReferenceSetRequest;
|
|
591
608
|
}
|
|
609
|
+
/**
|
|
610
|
+
* Specify an instance family to use as the baseline reference for CPU performance. All instance types that All instance types that match your specified attributes will be compared against the CPU performance of the referenced instance family, regardless of CPU manufacturer or architecture differences.
|
|
611
|
+
* Currently only one instance family can be specified in the list.
|
|
612
|
+
*/
|
|
592
613
|
export interface PerformanceFactorReferenceRequest {
|
|
614
|
+
/**
|
|
615
|
+
* The instance family to use as a baseline reference.
|
|
616
|
+
* Make sure that you specify the correct value for the instance family. The instance family is everything before the period (.) in the instance type name. For example, in the instance ``c6i.large``, the instance family is ``c6i``, not ``c6``. For more information, see [Amazon EC2 instance type naming conventions](https://docs.aws.amazon.com/ec2/latest/instancetypes/instance-type-names.html) in *Amazon EC2 Instance Types*.
|
|
617
|
+
* The following instance types are *not supported* for performance protection.
|
|
618
|
+
* + ``c1``
|
|
619
|
+
* + ``g3| g3s``
|
|
620
|
+
* + ``hpc7g``
|
|
621
|
+
* + ``m1| m2``
|
|
622
|
+
* + ``mac1 | mac2 | mac2-m1ultra | mac2-m2 | mac2-m2pro``
|
|
623
|
+
* + ``p3dn | p4d | p5``
|
|
624
|
+
* + ``t1``
|
|
625
|
+
* + ``u-12tb1 | u-18tb1 | u-24tb1 | u-3tb1 | u-6tb1 | u-9tb1 | u7i-12tb | u7in-16tb | u7in-24tb | u7in-32tb``
|
|
626
|
+
*
|
|
627
|
+
* If you performance protection by specifying a supported instance family, the returned instance types will exclude the preceding unsupported instance families.
|
|
628
|
+
* If you specify an unsupported instance family as a value for baseline performance, the API returns an empty response.
|
|
629
|
+
*/
|
|
593
630
|
InstanceFamily?: string;
|
|
594
631
|
}
|
|
595
632
|
/**
|
|
@@ -767,10 +804,23 @@ export interface TrafficSourceIdentifier {
|
|
|
767
804
|
*/
|
|
768
805
|
Identifier: string;
|
|
769
806
|
}
|
|
807
|
+
/**
|
|
808
|
+
* The capacity reservation specification.
|
|
809
|
+
*/
|
|
770
810
|
export interface CapacityReservationSpecification {
|
|
811
|
+
/**
|
|
812
|
+
* The capacity reservation preference. The following options are available:
|
|
813
|
+
* + ``capacity-reservations-only`` - Auto Scaling will only launch instances into a Capacity Reservation or Capacity Reservation resource group. If capacity isn't available, instances will fail to launch.
|
|
814
|
+
* + ``capacity-reservations-first`` - Auto Scaling will try to launch instances into a Capacity Reservation or Capacity Reservation resource group first. If capacity isn't available, instances will run in On-Demand capacity.
|
|
815
|
+
* + ``none`` - Auto Scaling will not launch instances into a Capacity Reservation. Instances will run in On-Demand capacity.
|
|
816
|
+
* + ``default`` - Auto Scaling uses the Capacity Reservation preference from your launch template or an open Capacity Reservation.
|
|
817
|
+
*/
|
|
771
818
|
CapacityReservationPreference: string;
|
|
772
819
|
CapacityReservationTarget?: CapacityReservationTarget;
|
|
773
820
|
}
|
|
821
|
+
/**
|
|
822
|
+
* Describes a target Capacity Reservation or Capacity Reservation resource group.
|
|
823
|
+
*/
|
|
774
824
|
export interface CapacityReservationTarget {
|
|
775
825
|
CapacityReservationIds?: CapacityReservationIds;
|
|
776
826
|
CapacityReservationResourceGroupArns?: CapacityReservationResourceGroupArns;
|
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXdzLWF1dG9zY2FsaW5nLWF1dG9zY2FsaW5nZ3JvdXAuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJhd3MtYXV0b3NjYWxpbmctYXV0b3NjYWxpbmdncm91cC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHR5cGUgUGVyZm9ybWFuY2VGYWN0b3JSZWZlcmVuY2VTZXRSZXF1ZXN0ID0gUGVyZm9ybWFuY2VGYWN0b3JSZWZlcmVuY2VSZXF1ZXN0W11cbmV4cG9ydCB0eXBlIENhcGFjaXR5UmVzZXJ2YXRpb25JZHMgPSBzdHJpbmdbXVxuZXhwb3J0IHR5cGUgQ2FwYWNpdHlSZXNlcnZhdGlvblJlc291cmNlR3JvdXBBcm5zID0gc3RyaW5nW11cblxuLyoqXG4gKiBUaGUgYGBBV1M6OkF1dG9TY2FsaW5nOjpBdXRvU2NhbGluZ0dyb3VwYGAgcmVzb3VyY2UgZGVmaW5lcyBhbiBBbWF6b24gRUMyIEF1dG8gU2NhbGluZyBncm91cCwgd2hpY2ggaXMgYSBjb2xsZWN0aW9uIG9mIEFtYXpvbiBFQzIgaW5zdGFuY2VzIHRoYXQgYXJlIHRyZWF0ZWQgYXMgYSBsb2dpY2FsIGdyb3VwaW5nIGZvciB0aGUgcHVycG9zZXMgb2YgYXV0b21hdGljIHNjYWxpbmcgYW5kIG1hbmFnZW1lbnQuIFxuICogIEZvciBtb3JlIGluZm9ybWF0aW9uIGFib3V0IEFtYXpvbiBFQzIgQXV0byBTY2FsaW5nLCBzZWUgdGhlIFtBbWF6b24gRUMyIEF1dG8gU2NhbGluZyBVc2VyIEd1aWRlXShodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vYXV0b3NjYWxpbmcvZWMyL3VzZXJndWlkZS93aGF0LWlzLWFtYXpvbi1lYzItYXV0by1zY2FsaW5nLmh0bWwpLiBcbiAqICAgQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgY29uZmlndXJlcyBpbnN0YW5jZXMgbGF1bmNoZWQgYXMgcGFydCBvZiBhbiBBdXRvIFNjYWxpbmcgZ3JvdXAgdXNpbmcgZWl0aGVyIGEgW2xhdW5jaCB0ZW1wbGF0ZV0oaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL0FXU0Nsb3VkRm9ybWF0aW9uL2xhdGVzdC9Vc2VyR3VpZGUvYXdzLXJlc291cmNlLWVjMi1sYXVuY2h0ZW1wbGF0ZS5odG1sKSBvciBhIGxhdW5jaCBjb25maWd1cmF0aW9uLiBXZSBzdHJvbmdseSByZWNvbW1lbmQgdGhhdCB5b3UgZG8gbm90IHVzZSBsYXVuY2ggY29uZmlndXJhdGlvbnMuIEZvciBtb3JlIGluZm9ybWF0aW9uLCBzZWUgW0xhdW5jaCBjb25maWd1cmF0aW9uc10oaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL2F1dG9zY2FsaW5nL2VjMi91c2VyZ3VpZGUvbGF1bmNoLWNvbmZpZ3VyYXRpb25zLmh0bWwpIGluIHRoZSAqQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgVXNlciBHdWlkZSouXG4gKiAgRm9yIGhlbHAgbWlncmF0aW5nIGZyb20gbGF1bmNoIGNvbmZpZ3VyYXRpb25zIHRvIGxhdW5jaCB0ZW1wbGF0ZXMsIHNlZSBbTWlncmF0ZSBDbG91ZEZvcm1hdGlvbiBzdGFja3MgZnJvbSBsYXVuY2ggY29uZmlndXJhdGlvbnMgdG8gbGF1bmNoIHRlbXBsYXRlc10oaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL2F1dG9zY2FsaW5nL2VjMi91c2VyZ3VpZGUvbWlncmF0ZS1sYXVuY2gtY29uZmlndXJhdGlvbnMtd2l0aC1jbG91ZGZvcm1hdGlvbi5odG1sKSBpbiB0aGUgKkFtYXpvbiBFQzIgQXV0byBTY2FsaW5nIFVzZXIgR3VpZGUqLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIF9BV1NfQVVUT1NDQUxJTkdfQVVUT1NDQUxJTkdHUk9VUCB7XG4vKipcbiAqIE9uZSBvciBtb3JlIGxpZmVjeWNsZSBob29rcyB0byBhZGQgdG8gdGhlIEF1dG8gU2NhbGluZyBncm91cCBiZWZvcmUgaW5zdGFuY2VzIGFyZSBsYXVuY2hlZC5cbiAqL1xuTGlmZWN5Y2xlSG9va1NwZWNpZmljYXRpb25MaXN0PzogTGlmZWN5Y2xlSG9va1NwZWNpZmljYXRpb25bXVxuLyoqXG4gKiBBIGxpc3Qgb2YgQ2xhc3NpYyBMb2FkIEJhbGFuY2VycyBhc3NvY2lhdGVkIHdpdGggdGhpcyBBdXRvIFNjYWxpbmcgZ3JvdXAuIEZvciBBcHBsaWNhdGlvbiBMb2FkIEJhbGFuY2VycywgTmV0d29yayBMb2FkIEJhbGFuY2VycywgYW5kIEdhdGV3YXkgTG9hZCBCYWxhbmNlcnMsIHNwZWNpZnkgdGhlIGBgVGFyZ2V0R3JvdXBBUk5zYGAgcHJvcGVydHkgaW5zdGVhZC5cbiAqL1xuTG9hZEJhbGFuY2VyTmFtZXM/OiBzdHJpbmdbXVxuLyoqXG4gKiBUaGUgbmFtZSBvZiB0aGUgbGF1bmNoIGNvbmZpZ3VyYXRpb24gdG8gdXNlIHRvIGxhdW5jaCBpbnN0YW5jZXMuXG4gKiAgUmVxdWlyZWQgb25seSBpZiB5b3UgZG9uJ3Qgc3BlY2lmeSBgYExhdW5jaFRlbXBsYXRlYGAsIGBgTWl4ZWRJbnN0YW5jZXNQb2xpY3lgYCwgb3IgYGBJbnN0YW5jZUlkYGAuXG4gKi9cbkxhdW5jaENvbmZpZ3VyYXRpb25OYW1lPzogc3RyaW5nXG4vKipcbiAqIFRoZSBBbWF6b24gUmVzb3VyY2UgTmFtZSAoQVJOKSBvZiB0aGUgc2VydmljZS1saW5rZWQgcm9sZSB0aGF0IHRoZSBBdXRvIFNjYWxpbmcgZ3JvdXAgdXNlcyB0byBjYWxsIG90aGVyIEFXUyBzZXJ2aWNlIG9uIHlvdXIgYmVoYWxmLiBCeSBkZWZhdWx0LCBBbWF6b24gRUMyIEF1dG8gU2NhbGluZyB1c2VzIGEgc2VydmljZS1saW5rZWQgcm9sZSBuYW1lZCBgYEFXU1NlcnZpY2VSb2xlRm9yQXV0b1NjYWxpbmdgYCwgd2hpY2ggaXQgY3JlYXRlcyBpZiBpdCBkb2VzIG5vdCBleGlzdC4gRm9yIG1vcmUgaW5mb3JtYXRpb24sIHNlZSBbU2VydmljZS1saW5rZWQgcm9sZXNdKGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9hdXRvc2NhbGluZy9lYzIvdXNlcmd1aWRlL2F1dG9zY2FsaW5nLXNlcnZpY2UtbGlua2VkLXJvbGUuaHRtbCkgaW4gdGhlICpBbWF6b24gRUMyIEF1dG8gU2NhbGluZyBVc2VyIEd1aWRlKi5cbiAqL1xuU2VydmljZUxpbmtlZFJvbGVBUk4/OiBzdHJpbmdcbkF2YWlsYWJpbGl0eVpvbmVJbXBhaXJtZW50UG9saWN5PzogQXZhaWxhYmlsaXR5Wm9uZUltcGFpcm1lbnRQb2xpY3lcbi8qKlxuICogVGhlIEFtYXpvbiBSZXNvdXJjZSBOYW1lcyAoQVJOKSBvZiB0aGUgRWxhc3RpYyBMb2FkIEJhbGFuY2luZyB0YXJnZXQgZ3JvdXBzIHRvIGFzc29jaWF0ZSB3aXRoIHRoZSBBdXRvIFNjYWxpbmcgZ3JvdXAuIEluc3RhbmNlcyBhcmUgcmVnaXN0ZXJlZCBhcyB0YXJnZXRzIHdpdGggdGhlIHRhcmdldCBncm91cHMuIFRoZSB0YXJnZXQgZ3JvdXBzIHJlY2VpdmUgaW5jb21pbmcgdHJhZmZpYyBhbmQgcm91dGUgcmVxdWVzdHMgdG8gb25lIG9yIG1vcmUgcmVnaXN0ZXJlZCB0YXJnZXRzLiBGb3IgbW9yZSBpbmZvcm1hdGlvbiwgc2VlIFtVc2UgRWxhc3RpYyBMb2FkIEJhbGFuY2luZyB0byBkaXN0cmlidXRlIHRyYWZmaWMgYWNyb3NzIHRoZSBpbnN0YW5jZXMgaW4geW91ciBBdXRvIFNjYWxpbmcgZ3JvdXBdKGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9hdXRvc2NhbGluZy9lYzIvdXNlcmd1aWRlL2F1dG9zY2FsaW5nLWxvYWQtYmFsYW5jZXIuaHRtbCkgaW4gdGhlICpBbWF6b24gRUMyIEF1dG8gU2NhbGluZyBVc2VyIEd1aWRlKi5cbiAqL1xuVGFyZ2V0R3JvdXBBUk5zPzogc3RyaW5nW11cbi8qKlxuICogKk9ubHkgbmVlZGVkIGlmIHlvdSB1c2Ugc2ltcGxlIHNjYWxpbmcgcG9saWNpZXMuKiBcbiAqICBUaGUgYW1vdW50IG9mIHRpbWUsIGluIHNlY29uZHMsIGJldHdlZW4gb25lIHNjYWxpbmcgYWN0aXZpdHkgZW5kaW5nIGFuZCBhbm90aGVyIG9uZSBzdGFydGluZyBkdWUgdG8gc2ltcGxlIHNjYWxpbmcgcG9saWNpZXMuIEZvciBtb3JlIGluZm9ybWF0aW9uLCBzZWUgW1NjYWxpbmcgY29vbGRvd25zIGZvciBBbWF6b24gRUMyIEF1dG8gU2NhbGluZ10oaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL2F1dG9zY2FsaW5nL2VjMi91c2VyZ3VpZGUvZWMyLWF1dG8tc2NhbGluZy1zY2FsaW5nLWNvb2xkb3ducy5odG1sKSBpbiB0aGUgKkFtYXpvbiBFQzIgQXV0byBTY2FsaW5nIFVzZXIgR3VpZGUqLlxuICogIERlZmF1bHQ6IGBgMzAwYGAgc2Vjb25kc1xuICovXG5Db29sZG93bj86IHN0cmluZ1xuLyoqXG4gKiBDb25maWd1cmVzIGFuIEF1dG8gU2NhbGluZyBncm91cCB0byBzZW5kIG5vdGlmaWNhdGlvbnMgd2hlbiBzcGVjaWZpZWQgZXZlbnRzIHRha2UgcGxhY2UuXG4gKi9cbk5vdGlmaWNhdGlvbkNvbmZpZ3VyYXRpb25zPzogTm90aWZpY2F0aW9uQ29uZmlndXJhdGlvbltdXG4vKipcbiAqIFRoZSBkZXNpcmVkIGNhcGFjaXR5IGlzIHRoZSBpbml0aWFsIGNhcGFjaXR5IG9mIHRoZSBBdXRvIFNjYWxpbmcgZ3JvdXAgYXQgdGhlIHRpbWUgb2YgaXRzIGNyZWF0aW9uIGFuZCB0aGUgY2FwYWNpdHkgaXQgYXR0ZW1wdHMgdG8gbWFpbnRhaW4uIEl0IGNhbiBzY2FsZSBiZXlvbmQgdGhpcyBjYXBhY2l0eSBpZiB5b3UgY29uZmlndXJlIGF1dG9tYXRpYyBzY2FsaW5nLlxuICogIFRoZSBudW1iZXIgbXVzdCBiZSBncmVhdGVyIHRoYW4gb3IgZXF1YWwgdG8gdGhlIG1pbmltdW0gc2l6ZSBvZiB0aGUgZ3JvdXAgYW5kIGxlc3MgdGhhbiBvciBlcXVhbCB0byB0aGUgbWF4aW11bSBzaXplIG9mIHRoZSBncm91cC4gSWYgeW91IGRvIG5vdCBzcGVjaWZ5IGEgZGVzaXJlZCBjYXBhY2l0eSB3aGVuIGNyZWF0aW5nIHRoZSBzdGFjaywgdGhlIGRlZmF1bHQgaXMgdGhlIG1pbmltdW0gc2l6ZSBvZiB0aGUgZ3JvdXAuXG4gKiAgQ2xvdWRGb3JtYXRpb24gbWFya3MgdGhlIEF1dG8gU2NhbGluZyBncm91cCBhcyBzdWNjZXNzZnVsIChieSBzZXR0aW5nIGl0cyBzdGF0dXMgdG8gQ1JFQVRFX0NPTVBMRVRFKSB3aGVuIHRoZSBkZXNpcmVkIGNhcGFjaXR5IGlzIHJlYWNoZWQuIEhvd2V2ZXIsIGlmIGEgbWF4aW11bSBTcG90IHByaWNlIGlzIHNldCBpbiB0aGUgbGF1bmNoIHRlbXBsYXRlIG9yIGxhdW5jaCBjb25maWd1cmF0aW9uIHRoYXQgeW91IHNwZWNpZmllZCwgdGhlbiBkZXNpcmVkIGNhcGFjaXR5IGlzIG5vdCB1c2VkIGFzIGEgY3JpdGVyaWEgZm9yIHN1Y2Nlc3MuIFdoZXRoZXIgeW91ciByZXF1ZXN0IGlzIGZ1bGZpbGxlZCBkZXBlbmRzIG9uIFNwb3QgSW5zdGFuY2UgY2FwYWNpdHkgYW5kIHlvdXIgbWF4aW11bSBwcmljZS5cbiAqL1xuRGVzaXJlZENhcGFjaXR5Pzogc3RyaW5nXG4vKipcbiAqIFRoZSBhbW91bnQgb2YgdGltZSwgaW4gc2Vjb25kcywgdGhhdCBBbWF6b24gRUMyIEF1dG8gU2NhbGluZyB3YWl0cyBiZWZvcmUgY2hlY2tpbmcgdGhlIGhlYWx0aCBzdGF0dXMgb2YgYW4gRUMyIGluc3RhbmNlIHRoYXQgaGFzIGNvbWUgaW50byBzZXJ2aWNlIGFuZCBtYXJraW5nIGl0IHVuaGVhbHRoeSBkdWUgdG8gYSBmYWlsZWQgaGVhbHRoIGNoZWNrLiBUaGlzIGlzIHVzZWZ1bCBpZiB5b3VyIGluc3RhbmNlcyBkbyBub3QgaW1tZWRpYXRlbHkgcGFzcyB0aGVpciBoZWFsdGggY2hlY2tzIGFmdGVyIHRoZXkgZW50ZXIgdGhlIGBgSW5TZXJ2aWNlYGAgc3RhdGUuIEZvciBtb3JlIGluZm9ybWF0aW9uLCBzZWUgW1NldCB0aGUgaGVhbHRoIGNoZWNrIGdyYWNlIHBlcmlvZCBmb3IgYW4gQXV0byBTY2FsaW5nIGdyb3VwXShodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vYXV0b3NjYWxpbmcvZWMyL3VzZXJndWlkZS9oZWFsdGgtY2hlY2stZ3JhY2UtcGVyaW9kLmh0bWwpIGluIHRoZSAqQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgVXNlciBHdWlkZSouXG4gKiAgRGVmYXVsdDogYGAwYGAgc2Vjb25kc1xuICovXG5IZWFsdGhDaGVja0dyYWNlUGVyaW9kPzogbnVtYmVyXG4vKipcbiAqIFRoZSBhbW91bnQgb2YgdGltZSwgaW4gc2Vjb25kcywgdW50aWwgYSBuZXcgaW5zdGFuY2UgaXMgY29uc2lkZXJlZCB0byBoYXZlIGZpbmlzaGVkIGluaXRpYWxpemluZyBhbmQgcmVzb3VyY2UgY29uc3VtcHRpb24gdG8gYmVjb21lIHN0YWJsZSBhZnRlciBpdCBlbnRlcnMgdGhlIGBgSW5TZXJ2aWNlYGAgc3RhdGUuIFxuICogIER1cmluZyBhbiBpbnN0YW5jZSByZWZyZXNoLCBBbWF6b24gRUMyIEF1dG8gU2NhbGluZyB3YWl0cyBmb3IgdGhlIHdhcm0tdXAgcGVyaW9kIGFmdGVyIGl0IHJlcGxhY2VzIGFuIGluc3RhbmNlIGJlZm9yZSBpdCBtb3ZlcyBvbiB0byByZXBsYWNpbmcgdGhlIG5leHQgaW5zdGFuY2UuIEFtYXpvbiBFQzIgQXV0byBTY2FsaW5nIGFsc28gd2FpdHMgZm9yIHRoZSB3YXJtLXVwIHBlcmlvZCBiZWZvcmUgYWdncmVnYXRpbmcgdGhlIG1ldHJpY3MgZm9yIG5ldyBpbnN0YW5jZXMgd2l0aCBleGlzdGluZyBpbnN0YW5jZXMgaW4gdGhlIEFtYXpvbiBDbG91ZFdhdGNoIG1ldHJpY3MgdGhhdCBhcmUgdXNlZCBmb3Igc2NhbGluZywgcmVzdWx0aW5nIGluIG1vcmUgcmVsaWFibGUgdXNhZ2UgZGF0YS4gRm9yIG1vcmUgaW5mb3JtYXRpb24sIHNlZSBbU2V0IHRoZSBkZWZhdWx0IGluc3RhbmNlIHdhcm11cCBmb3IgYW4gQXV0byBTY2FsaW5nIGdyb3VwXShodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vYXV0b3NjYWxpbmcvZWMyL3VzZXJndWlkZS9lYzItYXV0by1zY2FsaW5nLWRlZmF1bHQtaW5zdGFuY2Utd2FybXVwLmh0bWwpIGluIHRoZSAqQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgVXNlciBHdWlkZSouXG4gKiAgIFRvIG1hbmFnZSB2YXJpb3VzIHdhcm0tdXAgc2V0dGluZ3MgYXQgdGhlIGdyb3VwIGxldmVsLCB3ZSByZWNvbW1lbmQgdGhhdCB5b3Ugc2V0IHRoZSBkZWZhdWx0IGluc3RhbmNlIHdhcm11cCwgKmV2ZW4gaWYgaXQgaXMgc2V0IHRvIDAgc2Vjb25kcyouIFRvIHJlbW92ZSBhIHZhbHVlIHRoYXQgeW91IHByZXZpb3VzbHkgc2V0LCBpbmNsdWRlIHRoZSBwcm9wZXJ0eSBidXQgc3BlY2lmeSBgYC0xYGAgZm9yIHRoZSB2YWx1ZS4gSG93ZXZlciwgd2Ugc3Ryb25nbHkgcmVjb21tZW5kIGtlZXBpbmcgdGhlIGRlZmF1bHQgaW5zdGFuY2Ugd2FybXVwIGVuYWJsZWQgYnkgc3BlY2lmeWluZyBhIHZhbHVlIG9mIGBgMGBgIG9yIG90aGVyIG5vbWluYWwgdmFsdWUuXG4gKiAgIERlZmF1bHQ6IE5vbmVcbiAqL1xuRGVmYXVsdEluc3RhbmNlV2FybXVwPzogbnVtYmVyXG5Ta2lwWm9uYWxTaGlmdFZhbGlkYXRpb24/OiBib29sZWFuXG4vKipcbiAqIEluZGljYXRlcyB3aGV0aGVyIG5ld2x5IGxhdW5jaGVkIGluc3RhbmNlcyBhcmUgcHJvdGVjdGVkIGZyb20gdGVybWluYXRpb24gYnkgQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgd2hlbiBzY2FsaW5nIGluLiBGb3IgbW9yZSBpbmZvcm1hdGlvbiBhYm91dCBwcmV2ZW50aW5nIGluc3RhbmNlcyBmcm9tIHRlcm1pbmF0aW5nIG9uIHNjYWxlIGluLCBzZWUgW1VzZSBpbnN0YW5jZSBzY2FsZS1pbiBwcm90ZWN0aW9uXShodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vYXV0b3NjYWxpbmcvZWMyL3VzZXJndWlkZS9lYzItYXV0by1zY2FsaW5nLWluc3RhbmNlLXByb3RlY3Rpb24uaHRtbCkgaW4gdGhlICpBbWF6b24gRUMyIEF1dG8gU2NhbGluZyBVc2VyIEd1aWRlKi5cbiAqL1xuTmV3SW5zdGFuY2VzUHJvdGVjdGVkRnJvbVNjYWxlSW4/OiBib29sZWFuXG5MYXVuY2hUZW1wbGF0ZT86IExhdW5jaFRlbXBsYXRlU3BlY2lmaWNhdGlvblxuTWl4ZWRJbnN0YW5jZXNQb2xpY3k/OiBNaXhlZEluc3RhbmNlc1BvbGljeVxuLyoqXG4gKiBBIGxpc3Qgb2Ygc3VibmV0IElEcyBmb3IgYSB2aXJ0dWFsIHByaXZhdGUgY2xvdWQgKFZQQykgd2hlcmUgaW5zdGFuY2VzIGluIHRoZSBBdXRvIFNjYWxpbmcgZ3JvdXAgY2FuIGJlIGNyZWF0ZWQuXG4gKiAgSWYgdGhpcyByZXNvdXJjZSBzcGVjaWZpZXMgcHVibGljIHN1Ym5ldHMgYW5kIGlzIGFsc28gaW4gYSBWUEMgdGhhdCBpcyBkZWZpbmVkIGluIHRoZSBzYW1lIHN0YWNrIHRlbXBsYXRlLCB5b3UgbXVzdCB1c2UgdGhlIFtEZXBlbmRzT24gYXR0cmlidXRlXShodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vQVdTQ2xvdWRGb3JtYXRpb24vbGF0ZXN0L1VzZXJHdWlkZS9hd3MtYXR0cmlidXRlLWRlcGVuZHNvbi5odG1sKSB0byBkZWNsYXJlIGEgZGVwZW5kZW5jeSBvbiB0aGUgW1ZQQy1nYXRld2F5IGF0dGFjaG1lbnRdKGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9BV1NDbG91ZEZvcm1hdGlvbi9sYXRlc3QvVXNlckd1aWRlL2F3cy1yZXNvdXJjZS1lYzItdnBjLWdhdGV3YXktYXR0YWNobWVudC5odG1sKS5cbiAqICAgV2hlbiB5b3UgdXBkYXRlIGBgVlBDWm9uZUlkZW50aWZpZXJgYCwgdGhpcyByZXRhaW5zIHRoZSBzYW1lIEF1dG8gU2NhbGluZyBncm91cCBhbmQgcmVwbGFjZXMgb2xkIGluc3RhbmNlcyB3aXRoIG5ldyBvbmVzLCBhY2NvcmRpbmcgdG8gdGhlIHNwZWNpZmllZCBzdWJuZXRzLiBZb3UgY2FuIG9wdGlvbmFsbHkgc3BlY2lmeSBob3cgQ2xvdWRGb3JtYXRpb24gaGFuZGxlcyB0aGVzZSB1cGRhdGVzIGJ5IHVzaW5nIGFuIFtVcGRhdGVQb2xpY3kgYXR0cmlidXRlXShodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vQVdTQ2xvdWRGb3JtYXRpb24vbGF0ZXN0L1VzZXJHdWlkZS9hd3MtYXR0cmlidXRlLXVwZGF0ZXBvbGljeS5odG1sKS5cbiAqICAgUmVxdWlyZWQgdG8gbGF1bmNoIGluc3RhbmNlcyBpbnRvIGEgbm9uZGVmYXVsdCBWUEMuIElmIHlvdSBzcGVjaWZ5IGBgVlBDWm9uZUlkZW50aWZpZXJgYCB3aXRoIGBgQXZhaWxhYmlsaXR5Wm9uZXNgYCwgdGhlIHN1Ym5ldHMgdGhhdCB5b3Ugc3BlY2lmeSBmb3IgdGhpcyBwcm9wZXJ0eSBtdXN0IHJlc2lkZSBpbiB0aG9zZSBBdmFpbGFiaWxpdHkgWm9uZXMuXG4gKi9cblZQQ1pvbmVJZGVudGlmaWVyPzogc3RyaW5nW11cbi8qKlxuICogT25lIG9yIG1vcmUgdGFncy4gWW91IGNhbiB0YWcgeW91ciBBdXRvIFNjYWxpbmcgZ3JvdXAgYW5kIHByb3BhZ2F0ZSB0aGUgdGFncyB0byB0aGUgQW1hem9uIEVDMiBpbnN0YW5jZXMgaXQgbGF1bmNoZXMuIFRhZ3MgYXJlIG5vdCBwcm9wYWdhdGVkIHRvIEFtYXpvbiBFQlMgdm9sdW1lcy4gVG8gYWRkIHRhZ3MgdG8gQW1hem9uIEVCUyB2b2x1bWVzLCBzcGVjaWZ5IHRoZSB0YWdzIGluIGEgbGF1bmNoIHRlbXBsYXRlIGJ1dCB1c2UgY2F1dGlvbi4gSWYgdGhlIGxhdW5jaCB0ZW1wbGF0ZSBzcGVjaWZpZXMgYW4gaW5zdGFuY2UgdGFnIHdpdGggYSBrZXkgdGhhdCBpcyBhbHNvIHNwZWNpZmllZCBmb3IgdGhlIEF1dG8gU2NhbGluZyBncm91cCwgQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgb3ZlcnJpZGVzIHRoZSB2YWx1ZSBvZiB0aGF0IGluc3RhbmNlIHRhZyB3aXRoIHRoZSB2YWx1ZSBzcGVjaWZpZWQgYnkgdGhlIEF1dG8gU2NhbGluZyBncm91cC4gRm9yIG1vcmUgaW5mb3JtYXRpb24sIHNlZSBbVGFnIEF1dG8gU2NhbGluZyBncm91cHMgYW5kIGluc3RhbmNlc10oaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL2F1dG9zY2FsaW5nL2VjMi91c2VyZ3VpZGUvZWMyLWF1dG8tc2NhbGluZy10YWdnaW5nLmh0bWwpIGluIHRoZSAqQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgVXNlciBHdWlkZSouXG4gKi9cblRhZ3M/OiBUYWdQcm9wZXJ0eVtdXG4vKipcbiAqIFJlc2VydmVkLlxuICovXG5Db250ZXh0Pzogc3RyaW5nXG4vKipcbiAqIEluZGljYXRlcyB3aGV0aGVyIENhcGFjaXR5IFJlYmFsYW5jaW5nIGlzIGVuYWJsZWQuIE90aGVyd2lzZSwgQ2FwYWNpdHkgUmViYWxhbmNpbmcgaXMgZGlzYWJsZWQuIFdoZW4geW91IHR1cm4gb24gQ2FwYWNpdHkgUmViYWxhbmNpbmcsIEFtYXpvbiBFQzIgQXV0byBTY2FsaW5nIGF0dGVtcHRzIHRvIGxhdW5jaCBhIFNwb3QgSW5zdGFuY2Ugd2hlbmV2ZXIgQW1hem9uIEVDMiBub3RpZmllcyB0aGF0IGEgU3BvdCBJbnN0YW5jZSBpcyBhdCBhbiBlbGV2YXRlZCByaXNrIG9mIGludGVycnVwdGlvbi4gQWZ0ZXIgbGF1bmNoaW5nIGEgbmV3IGluc3RhbmNlLCBpdCB0aGVuIHRlcm1pbmF0ZXMgYW4gb2xkIGluc3RhbmNlLiBGb3IgbW9yZSBpbmZvcm1hdGlvbiwgc2VlIFtVc2UgQ2FwYWNpdHkgUmViYWxhbmNpbmcgdG8gaGFuZGxlIEFtYXpvbiBFQzIgU3BvdCBJbnRlcnJ1cHRpb25zXShodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vYXV0b3NjYWxpbmcvZWMyL3VzZXJndWlkZS9lYzItYXV0by1zY2FsaW5nLWNhcGFjaXR5LXJlYmFsYW5jaW5nLmh0bWwpIGluIHRoZSBpbiB0aGUgKkFtYXpvbiBFQzIgQXV0byBTY2FsaW5nIFVzZXIgR3VpZGUqLlxuICovXG5DYXBhY2l0eVJlYmFsYW5jZT86IGJvb2xlYW5cbi8qKlxuICogVGhlIElEIG9mIHRoZSBpbnN0YW5jZSB1c2VkIHRvIGJhc2UgdGhlIGxhdW5jaCBjb25maWd1cmF0aW9uIG9uLiBGb3IgbW9yZSBpbmZvcm1hdGlvbiwgc2VlIFtDcmVhdGUgYW4gQXV0byBTY2FsaW5nIGdyb3VwIHVzaW5nIGFuIEVDMiBpbnN0YW5jZV0oaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL2F1dG9zY2FsaW5nL2VjMi91c2VyZ3VpZGUvY3JlYXRlLWFzZy1mcm9tLWluc3RhbmNlLmh0bWwpIGluIHRoZSAqQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgVXNlciBHdWlkZSouXG4gKiAgSWYgeW91IHNwZWNpZnkgYGBMYXVuY2hUZW1wbGF0ZWBgLCBgYE1peGVkSW5zdGFuY2VzUG9saWN5YGAsIG9yIGBgTGF1bmNoQ29uZmlndXJhdGlvbk5hbWVgYCwgZG9uJ3Qgc3BlY2lmeSBgYEluc3RhbmNlSWRgYC5cbiAqL1xuSW5zdGFuY2VJZD86IHN0cmluZ1xuLyoqXG4gKiBBIGxpc3Qgb2YgQXZhaWxhYmlsaXR5IFpvbmVzIHdoZXJlIGluc3RhbmNlcyBpbiB0aGUgQXV0byBTY2FsaW5nIGdyb3VwIGNhbiBiZSBjcmVhdGVkLiBVc2VkIGZvciBsYXVuY2hpbmcgaW50byB0aGUgZGVmYXVsdCBWUEMgc3VibmV0IGluIGVhY2ggQXZhaWxhYmlsaXR5IFpvbmUgd2hlbiBub3QgdXNpbmcgdGhlIGBgVlBDWm9uZUlkZW50aWZpZXJgYCBwcm9wZXJ0eSwgb3IgZm9yIGF0dGFjaGluZyBhIG5ldHdvcmsgaW50ZXJmYWNlIHdoZW4gYW4gZXhpc3RpbmcgbmV0d29yayBpbnRlcmZhY2UgSUQgaXMgc3BlY2lmaWVkIGluIGEgbGF1bmNoIHRlbXBsYXRlLlxuICovXG5BdmFpbGFiaWxpdHlab25lcz86IHN0cmluZ1tdXG5Ob3RpZmljYXRpb25Db25maWd1cmF0aW9uPzogTm90aWZpY2F0aW9uQ29uZmlndXJhdGlvbjFcbkF2YWlsYWJpbGl0eVpvbmVEaXN0cmlidXRpb24/OiBBdmFpbGFiaWxpdHlab25lRGlzdHJpYnV0aW9uXG4vKipcbiAqIEVuYWJsZXMgdGhlIG1vbml0b3Jpbmcgb2YgZ3JvdXAgbWV0cmljcyBvZiBhbiBBdXRvIFNjYWxpbmcgZ3JvdXAuIEJ5IGRlZmF1bHQsIHRoZXNlIG1ldHJpY3MgYXJlIGRpc2FibGVkLlxuICovXG5NZXRyaWNzQ29sbGVjdGlvbj86IE1ldHJpY3NDb2xsZWN0aW9uW11cbkluc3RhbmNlTWFpbnRlbmFuY2VQb2xpY3k/OiBJbnN0YW5jZU1haW50ZW5hbmNlUG9saWN5XG4vKipcbiAqIFRoZSBtYXhpbXVtIHNpemUgb2YgdGhlIGdyb3VwLlxuICogICBXaXRoIGEgbWl4ZWQgaW5zdGFuY2VzIHBvbGljeSB0aGF0IHVzZXMgaW5zdGFuY2Ugd2VpZ2h0aW5nLCBBbWF6b24gRUMyIEF1dG8gU2NhbGluZyBtYXkgbmVlZCB0byBnbyBhYm92ZSBgYE1heFNpemVgYCB0byBtZWV0IHlvdXIgY2FwYWNpdHkgcmVxdWlyZW1lbnRzLiBJbiB0aGlzIGV2ZW50LCBBbWF6b24gRUMyIEF1dG8gU2NhbGluZyB3aWxsIG5ldmVyIGdvIGFib3ZlIGBgTWF4U2l6ZWBgIGJ5IG1vcmUgdGhhbiB5b3VyIGxhcmdlc3QgaW5zdGFuY2Ugd2VpZ2h0ICh3ZWlnaHRzIHRoYXQgZGVmaW5lIGhvdyBtYW55IHVuaXRzIGVhY2ggaW5zdGFuY2UgY29udHJpYnV0ZXMgdG8gdGhlIGRlc2lyZWQgY2FwYWNpdHkgb2YgdGhlIGdyb3VwKS5cbiAqL1xuTWF4U2l6ZTogc3RyaW5nXG4vKipcbiAqIFRoZSBtaW5pbXVtIHNpemUgb2YgdGhlIGdyb3VwLlxuICovXG5NaW5TaXplOiBzdHJpbmdcbi8qKlxuICogQSBwb2xpY3kgb3IgYSBsaXN0IG9mIHBvbGljaWVzIHRoYXQgYXJlIHVzZWQgdG8gc2VsZWN0IHRoZSBpbnN0YW5jZSB0byB0ZXJtaW5hdGUuIFRoZXNlIHBvbGljaWVzIGFyZSBleGVjdXRlZCBpbiB0aGUgb3JkZXIgdGhhdCB5b3UgbGlzdCB0aGVtLiBGb3IgbW9yZSBpbmZvcm1hdGlvbiwgc2VlIFtDb25maWd1cmUgdGVybWluYXRpb24gcG9saWNpZXMgZm9yIEFtYXpvbiBFQzIgQXV0byBTY2FsaW5nXShodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vYXV0b3NjYWxpbmcvZWMyL3VzZXJndWlkZS9lYzItYXV0by1zY2FsaW5nLXRlcm1pbmF0aW9uLXBvbGljaWVzLmh0bWwpIGluIHRoZSAqQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgVXNlciBHdWlkZSouXG4gKiAgVmFsaWQgdmFsdWVzOiBgYERlZmF1bHRgYCB8IGBgQWxsb2NhdGlvblN0cmF0ZWd5YGAgfCBgYENsb3Nlc3RUb05leHRJbnN0YW5jZUhvdXJgYCB8IGBgTmV3ZXN0SW5zdGFuY2VgYCB8IGBgT2xkZXN0SW5zdGFuY2VgYCB8IGBgT2xkZXN0TGF1bmNoQ29uZmlndXJhdGlvbmBgIHwgYGBPbGRlc3RMYXVuY2hUZW1wbGF0ZWBgIHwgYGBhcm46YXdzOmxhbWJkYTpyZWdpb246YWNjb3VudC1pZDpmdW5jdGlvbjpteS1mdW5jdGlvbjpteS1hbGlhc2BgXG4gKi9cblRlcm1pbmF0aW9uUG9saWNpZXM/OiBzdHJpbmdbXVxuLyoqXG4gKiBUaGUgbmFtZSBvZiB0aGUgQXV0byBTY2FsaW5nIGdyb3VwLiBUaGlzIG5hbWUgbXVzdCBiZSB1bmlxdWUgcGVyIFJlZ2lvbiBwZXIgYWNjb3VudC5cbiAqICBUaGUgbmFtZSBjYW4gY29udGFpbiBhbnkgQVNDSUkgY2hhcmFjdGVyIDMzIHRvIDEyNiBpbmNsdWRpbmcgbW9zdCBwdW5jdHVhdGlvbiBjaGFyYWN0ZXJzLCBkaWdpdHMsIGFuZCB1cHBlciBhbmQgbG93ZXJjYXNlZCBsZXR0ZXJzLlxuICogICBZb3UgY2Fubm90IHVzZSBhIGNvbG9uICg6KSBpbiB0aGUgbmFtZS5cbiAqL1xuQXV0b1NjYWxpbmdHcm91cE5hbWU/OiBzdHJpbmdcbi8qKlxuICogVGhlIHRyYWZmaWMgc291cmNlcyBhc3NvY2lhdGVkIHdpdGggdGhpcyBBdXRvIFNjYWxpbmcgZ3JvdXAuXG4gKi9cblRyYWZmaWNTb3VyY2VzPzogVHJhZmZpY1NvdXJjZUlkZW50aWZpZXJbXVxuLyoqXG4gKiBUaGUgdW5pdCBvZiBtZWFzdXJlbWVudCBmb3IgdGhlIHZhbHVlIHNwZWNpZmllZCBmb3IgZGVzaXJlZCBjYXBhY2l0eS4gQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgc3VwcG9ydHMgYGBEZXNpcmVkQ2FwYWNpdHlUeXBlYGAgZm9yIGF0dHJpYnV0ZS1iYXNlZCBpbnN0YW5jZSB0eXBlIHNlbGVjdGlvbiBvbmx5LiBGb3IgbW9yZSBpbmZvcm1hdGlvbiwgc2VlIFtDcmVhdGUgYSBtaXhlZCBpbnN0YW5jZXMgZ3JvdXAgdXNpbmcgYXR0cmlidXRlLWJhc2VkIGluc3RhbmNlIHR5cGUgc2VsZWN0aW9uXShodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vYXV0b3NjYWxpbmcvZWMyL3VzZXJndWlkZS9jcmVhdGUtbWl4ZWQtaW5zdGFuY2VzLWdyb3VwLWF0dHJpYnV0ZS1iYXNlZC1pbnN0YW5jZS10eXBlLXNlbGVjdGlvbi5odG1sKSBpbiB0aGUgKkFtYXpvbiBFQzIgQXV0byBTY2FsaW5nIFVzZXIgR3VpZGUqLlxuICogIEJ5IGRlZmF1bHQsIEFtYXpvbiBFQzIgQXV0byBTY2FsaW5nIHNwZWNpZmllcyBgYHVuaXRzYGAsIHdoaWNoIHRyYW5zbGF0ZXMgaW50byBudW1iZXIgb2YgaW5zdGFuY2VzLlxuICogIFZhbGlkIHZhbHVlczogYGB1bml0c2BgIHwgYGB2Y3B1YGAgfCBgYG1lbW9yeS1taWJgYFxuICovXG5EZXNpcmVkQ2FwYWNpdHlUeXBlPzogc3RyaW5nXG4vKipcbiAqIFRoZSBuYW1lIG9mIHRoZSBwbGFjZW1lbnQgZ3JvdXAgaW50byB3aGljaCB0byBsYXVuY2ggeW91ciBpbnN0YW5jZXMuIEZvciBtb3JlIGluZm9ybWF0aW9uLCBzZWUgW1BsYWNlbWVudCBncm91cHNdKGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9BV1NFQzIvbGF0ZXN0L1VzZXJHdWlkZS9wbGFjZW1lbnQtZ3JvdXBzLmh0bWwpIGluIHRoZSAqQW1hem9uIEVDMiBVc2VyIEd1aWRlIGZvciBMaW51eCBJbnN0YW5jZXMqLlxuICogICBBICpjbHVzdGVyKiBwbGFjZW1lbnQgZ3JvdXAgaXMgYSBsb2dpY2FsIGdyb3VwaW5nIG9mIGluc3RhbmNlcyB3aXRoaW4gYSBzaW5nbGUgQXZhaWxhYmlsaXR5IFpvbmUuIFlvdSBjYW5ub3Qgc3BlY2lmeSBtdWx0aXBsZSBBdmFpbGFiaWxpdHkgWm9uZXMgYW5kIGEgY2x1c3RlciBwbGFjZW1lbnQgZ3JvdXAuXG4gKi9cblBsYWNlbWVudEdyb3VwPzogc3RyaW5nXG5DYXBhY2l0eVJlc2VydmF0aW9uU3BlY2lmaWNhdGlvbj86IENhcGFjaXR5UmVzZXJ2YXRpb25TcGVjaWZpY2F0aW9uXG4vKipcbiAqIEEgY29tbWEtc2VwYXJhdGVkIHZhbHVlIHN0cmluZyBvZiBvbmUgb3IgbW9yZSBoZWFsdGggY2hlY2sgdHlwZXMuXG4gKiAgVGhlIHZhbGlkIHZhbHVlcyBhcmUgYGBFQzJgYCwgYGBFQlNgYCwgYGBFTEJgYCwgYW5kIGBgVlBDX0xBVFRJQ0VgYC4gYGBFQzJgYCBpcyB0aGUgZGVmYXVsdCBoZWFsdGggY2hlY2sgYW5kIGNhbm5vdCBiZSBkaXNhYmxlZC4gRm9yIG1vcmUgaW5mb3JtYXRpb24sIHNlZSBbSGVhbHRoIGNoZWNrcyBmb3IgaW5zdGFuY2VzIGluIGFuIEF1dG8gU2NhbGluZyBncm91cF0oaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL2F1dG9zY2FsaW5nL2VjMi91c2VyZ3VpZGUvZWMyLWF1dG8tc2NhbGluZy1oZWFsdGgtY2hlY2tzLmh0bWwpIGluIHRoZSAqQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgVXNlciBHdWlkZSouXG4gKiAgT25seSBzcGVjaWZ5IGBgRUMyYGAgaWYgeW91IG11c3QgY2xlYXIgYSB2YWx1ZSB0aGF0IHdhcyBwcmV2aW91c2x5IHNldC5cbiAqL1xuSGVhbHRoQ2hlY2tUeXBlPzogc3RyaW5nXG4vKipcbiAqIFRoZSBtYXhpbXVtIGFtb3VudCBvZiB0aW1lLCBpbiBzZWNvbmRzLCB0aGF0IGFuIGluc3RhbmNlIGNhbiBiZSBpbiBzZXJ2aWNlLiBUaGUgZGVmYXVsdCBpcyBudWxsLiBJZiBzcGVjaWZpZWQsIHRoZSB2YWx1ZSBtdXN0IGJlIGVpdGhlciAwIG9yIGEgbnVtYmVyIGVxdWFsIHRvIG9yIGdyZWF0ZXIgdGhhbiA4Niw0MDAgc2Vjb25kcyAoMSBkYXkpLiBGb3IgbW9yZSBpbmZvcm1hdGlvbiwgc2VlIFtSZXBsYWNlIEF1dG8gU2NhbGluZyBpbnN0YW5jZXMgYmFzZWQgb24gbWF4aW11bSBpbnN0YW5jZSBsaWZldGltZV0oaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL2F1dG9zY2FsaW5nL2VjMi91c2VyZ3VpZGUvYXNnLW1heC1pbnN0YW5jZS1saWZldGltZS5odG1sKSBpbiB0aGUgKkFtYXpvbiBFQzIgQXV0byBTY2FsaW5nIFVzZXIgR3VpZGUqLlxuICovXG5NYXhJbnN0YW5jZUxpZmV0aW1lPzogbnVtYmVyXG59XG4vKipcbiAqIGBgTGlmZWN5Y2xlSG9va1NwZWNpZmljYXRpb25gYCBzcGVjaWZpZXMgYSBsaWZlY3ljbGUgaG9vayBmb3IgdGhlIGBgTGlmZWN5Y2xlSG9va1NwZWNpZmljYXRpb25MaXN0YGAgcHJvcGVydHkgb2YgdGhlIFtBV1M6OkF1dG9TY2FsaW5nOjpBdXRvU2NhbGluZ0dyb3VwXShodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vQVdTQ2xvdWRGb3JtYXRpb24vbGF0ZXN0L1VzZXJHdWlkZS9hd3MtcmVzb3VyY2UtYXV0b3NjYWxpbmctYXV0b3NjYWxpbmdncm91cC5odG1sKSByZXNvdXJjZS4gQSBsaWZlY3ljbGUgaG9vayBzcGVjaWZpZXMgYWN0aW9ucyB0byBwZXJmb3JtIHdoZW4gQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgbGF1bmNoZXMgb3IgdGVybWluYXRlcyBpbnN0YW5jZXMuIFxuICogIEZvciBtb3JlIGluZm9ybWF0aW9uLCBzZWUgW0FtYXpvbiBFQzIgQXV0byBTY2FsaW5nIGxpZmVjeWNsZSBob29rc10oaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL2F1dG9zY2FsaW5nL2VjMi91c2VyZ3VpZGUvbGlmZWN5Y2xlLWhvb2tzLmh0bWwpIGluIHRoZSAqQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgVXNlciBHdWlkZSouIFlvdSBjYW4gZmluZCBhIHNhbXBsZSB0ZW1wbGF0ZSBzbmlwcGV0IGluIHRoZSBbRXhhbXBsZXNdKGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9BV1NDbG91ZEZvcm1hdGlvbi9sYXRlc3QvVXNlckd1aWRlL2F3cy1yZXNvdXJjZS1hcy1saWZlY3ljbGVob29rLmh0bWwjYXdzLXJlc291cmNlLWFzLWxpZmVjeWNsZWhvb2stLWV4YW1wbGVzKSBzZWN0aW9uIG9mIHRoZSBgYEFXUzo6QXV0b1NjYWxpbmc6OkxpZmVjeWNsZUhvb2tgYCByZXNvdXJjZS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBMaWZlY3ljbGVIb29rU3BlY2lmaWNhdGlvbiB7XG4vKipcbiAqIFRoZSBuYW1lIG9mIHRoZSBsaWZlY3ljbGUgaG9vay5cbiAqL1xuTGlmZWN5Y2xlSG9va05hbWU6IHN0cmluZ1xuLyoqXG4gKiBUaGUgbGlmZWN5Y2xlIHRyYW5zaXRpb24uIEZvciBBdXRvIFNjYWxpbmcgZ3JvdXBzLCB0aGVyZSBhcmUgdHdvIG1ham9yIGxpZmVjeWNsZSB0cmFuc2l0aW9ucy5cbiAqICAgKyAgVG8gY3JlYXRlIGEgbGlmZWN5Y2xlIGhvb2sgZm9yIHNjYWxlLW91dCBldmVudHMsIHNwZWNpZnkgYGBhdXRvc2NhbGluZzpFQzJfSU5TVEFOQ0VfTEFVTkNISU5HYGAuXG4gKiAgICsgIFRvIGNyZWF0ZSBhIGxpZmVjeWNsZSBob29rIGZvciBzY2FsZS1pbiBldmVudHMsIHNwZWNpZnkgYGBhdXRvc2NhbGluZzpFQzJfSU5TVEFOQ0VfVEVSTUlOQVRJTkdgYC5cbiAqL1xuTGlmZWN5Y2xlVHJhbnNpdGlvbjogc3RyaW5nXG4vKipcbiAqIFRoZSBtYXhpbXVtIHRpbWUsIGluIHNlY29uZHMsIHRoYXQgY2FuIGVsYXBzZSBiZWZvcmUgdGhlIGxpZmVjeWNsZSBob29rIHRpbWVzIG91dC4gVGhlIHJhbmdlIGlzIGZyb20gYGAzMGBgIHRvIGBgNzIwMGBgIHNlY29uZHMuIFRoZSBkZWZhdWx0IHZhbHVlIGlzIGBgMzYwMGBgIHNlY29uZHMgKDEgaG91cikuXG4gKi9cbkhlYXJ0YmVhdFRpbWVvdXQ/OiBudW1iZXJcbi8qKlxuICogQWRkaXRpb25hbCBpbmZvcm1hdGlvbiB0aGF0IHlvdSB3YW50IHRvIGluY2x1ZGUgYW55IHRpbWUgQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgc2VuZHMgYSBtZXNzYWdlIHRvIHRoZSBub3RpZmljYXRpb24gdGFyZ2V0LlxuICovXG5Ob3RpZmljYXRpb25NZXRhZGF0YT86IHN0cmluZ1xuLyoqXG4gKiBUaGUgYWN0aW9uIHRoZSBBdXRvIFNjYWxpbmcgZ3JvdXAgdGFrZXMgd2hlbiB0aGUgbGlmZWN5Y2xlIGhvb2sgdGltZW91dCBlbGFwc2VzIG9yIGlmIGFuIHVuZXhwZWN0ZWQgZmFpbHVyZSBvY2N1cnMuIFRoZSBkZWZhdWx0IHZhbHVlIGlzIGBgQUJBTkRPTmBgLlxuICogIFZhbGlkIHZhbHVlczogYGBDT05USU5VRWBgIHwgYGBBQkFORE9OYGBcbiAqL1xuRGVmYXVsdFJlc3VsdD86IHN0cmluZ1xuLyoqXG4gKiBUaGUgQW1hem9uIFJlc291cmNlIE5hbWUgKEFSTikgb2YgdGhlIG5vdGlmaWNhdGlvbiB0YXJnZXQgdGhhdCBBbWF6b24gRUMyIEF1dG8gU2NhbGluZyBzZW5kcyBub3RpZmljYXRpb25zIHRvIHdoZW4gYW4gaW5zdGFuY2UgaXMgaW4gYSB3YWl0IHN0YXRlIGZvciB0aGUgbGlmZWN5Y2xlIGhvb2suIFlvdSBjYW4gc3BlY2lmeSBhbiBBbWF6b24gU05TIHRvcGljIG9yIGFuIEFtYXpvbiBTUVMgcXVldWUuXG4gKi9cbk5vdGlmaWNhdGlvblRhcmdldEFSTj86IHN0cmluZ1xuLyoqXG4gKiBUaGUgQVJOIG9mIHRoZSBJQU0gcm9sZSB0aGF0IGFsbG93cyB0aGUgQXV0byBTY2FsaW5nIGdyb3VwIHRvIHB1Ymxpc2ggdG8gdGhlIHNwZWNpZmllZCBub3RpZmljYXRpb24gdGFyZ2V0LiBGb3IgaW5mb3JtYXRpb24gYWJvdXQgY3JlYXRpbmcgdGhpcyByb2xlLCBzZWUgW1ByZXBhcmUgdG8gYWRkIGEgbGlmZWN5Y2xlIGhvb2sgdG8geW91ciBBdXRvIFNjYWxpbmcgZ3JvdXBdKGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9hdXRvc2NhbGluZy9lYzIvdXNlcmd1aWRlL3ByZXBhcmUtZm9yLWxpZmVjeWNsZS1ub3RpZmljYXRpb25zLmh0bWwpIGluIHRoZSAqQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgVXNlciBHdWlkZSouXG4gKiAgVmFsaWQgb25seSBpZiB0aGUgbm90aWZpY2F0aW9uIHRhcmdldCBpcyBhbiBBbWF6b24gU05TIHRvcGljIG9yIGFuIEFtYXpvbiBTUVMgcXVldWUuXG4gKi9cblJvbGVBUk4/OiBzdHJpbmdcbn1cbi8qKlxuICogVGhlIEF2YWlsYWJpbGl0eSBab25lIGltcGFpcm1lbnQgcG9saWN5LlxuICovXG5leHBvcnQgaW50ZXJmYWNlIEF2YWlsYWJpbGl0eVpvbmVJbXBhaXJtZW50UG9saWN5IHtcbi8qKlxuICogSWYgYGB0cnVlYGAsIGVuYWJsZSB6b25hbCBzaGlmdCBmb3IgeW91ciBBdXRvIFNjYWxpbmcgZ3JvdXAuXG4gKi9cblpvbmFsU2hpZnRFbmFibGVkOiBib29sZWFuXG4vKipcbiAqIFNwZWNpZmllcyB0aGUgaGVhbHRoIGNoZWNrIGJlaGF2aW9yIGZvciB0aGUgaW1wYWlyZWQgQXZhaWxhYmlsaXR5IFpvbmUgaW4gYW4gYWN0aXZlIHpvbmFsIHNoaWZ0LiBJZiB5b3Ugc2VsZWN0IGBgUmVwbGFjZSB1bmhlYWx0aHlgYCwgaW5zdGFuY2VzIHRoYXQgYXBwZWFyIHVuaGVhbHRoeSB3aWxsIGJlIHJlcGxhY2VkIGluIGFsbCBBdmFpbGFiaWxpdHkgWm9uZXMuIElmIHlvdSBzZWxlY3QgYGBJZ25vcmUgdW5oZWFsdGh5YGAsIGluc3RhbmNlcyB3aWxsIG5vdCBiZSByZXBsYWNlZCBpbiB0aGUgQXZhaWxhYmlsaXR5IFpvbmUgd2l0aCB0aGUgYWN0aXZlIHpvbmFsIHNoaWZ0LiBGb3IgbW9yZSBpbmZvcm1hdGlvbiwgc2VlIFtBdXRvIFNjYWxpbmcgZ3JvdXAgem9uYWwgc2hpZnRdKGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9hdXRvc2NhbGluZy9lYzIvdXNlcmd1aWRlL2VjMi1hdXRvLXNjYWxpbmctem9uYWwtc2hpZnQuaHRtbCkgaW4gdGhlICpBbWF6b24gRUMyIEF1dG8gU2NhbGluZyBVc2VyIEd1aWRlKi5cbiAqL1xuSW1wYWlyZWRab25lSGVhbHRoQ2hlY2tCZWhhdmlvcjogKFwiSWdub3JlVW5oZWFsdGh5XCIgfCBcIlJlcGxhY2VVbmhlYWx0aHlcIilcbn1cbi8qKlxuICogQSBzdHJ1Y3R1cmUgdGhhdCBzcGVjaWZpZXMgYW4gQW1hem9uIFNOUyBub3RpZmljYXRpb24gY29uZmlndXJhdGlvbiBmb3IgdGhlIGBgTm90aWZpY2F0aW9uQ29uZmlndXJhdGlvbnNgYCBwcm9wZXJ0eSBvZiB0aGUgW0FXUzo6QXV0b1NjYWxpbmc6OkF1dG9TY2FsaW5nR3JvdXBdKGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9BV1NDbG91ZEZvcm1hdGlvbi9sYXRlc3QvVXNlckd1aWRlL2F3cy1yZXNvdXJjZS1hdXRvc2NhbGluZy1hdXRvc2NhbGluZ2dyb3VwLmh0bWwpIHJlc291cmNlLlxuICogIEZvciBhbiBleGFtcGxlIHRlbXBsYXRlIHNuaXBwZXQsIHNlZSBbQ29uZmlndXJlIEFtYXpvbiBFQzIgQXV0byBTY2FsaW5nIHJlc291cmNlc10oaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL0FXU0Nsb3VkRm9ybWF0aW9uL2xhdGVzdC9Vc2VyR3VpZGUvcXVpY2tyZWYtZWMyLWF1dG8tc2NhbGluZy5odG1sKS5cbiAqICBGb3IgbW9yZSBpbmZvcm1hdGlvbiwgc2VlIFtHZXQgQW1hem9uIFNOUyBub3RpZmljYXRpb25zIHdoZW4geW91ciBBdXRvIFNjYWxpbmcgZ3JvdXAgc2NhbGVzXShodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vYXV0b3NjYWxpbmcvZWMyL3VzZXJndWlkZS9BU0dldHRpbmdOb3RpZmljYXRpb25zLmh0bWwpIGluIHRoZSAqQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgVXNlciBHdWlkZSouXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgTm90aWZpY2F0aW9uQ29uZmlndXJhdGlvbiB7XG4vKipcbiAqIFRoZSBBbWF6b24gUmVzb3VyY2UgTmFtZSAoQVJOKSBvZiB0aGUgQW1hem9uIFNOUyB0b3BpYy5cbiAqL1xuVG9waWNBUk46IChzdHJpbmcgfCBzdHJpbmdbXSlcbi8qKlxuICogQSBsaXN0IG9mIGV2ZW50IHR5cGVzIHRoYXQgc2VuZCBhIG5vdGlmaWNhdGlvbi4gRXZlbnQgdHlwZXMgY2FuIGluY2x1ZGUgYW55IG9mIHRoZSBmb2xsb3dpbmcgdHlwZXMuIFxuICogICAqQWxsb3dlZCB2YWx1ZXMqOlxuICogICArICAgYGBhdXRvc2NhbGluZzpFQzJfSU5TVEFOQ0VfTEFVTkNIYGAgXG4gKiAgICsgICBgYGF1dG9zY2FsaW5nOkVDMl9JTlNUQU5DRV9MQVVOQ0hfRVJST1JgYCBcbiAqICAgKyAgIGBgYXV0b3NjYWxpbmc6RUMyX0lOU1RBTkNFX1RFUk1JTkFURWBgIFxuICogICArICAgYGBhdXRvc2NhbGluZzpFQzJfSU5TVEFOQ0VfVEVSTUlOQVRFX0VSUk9SYGAgXG4gKiAgICsgICBgYGF1dG9zY2FsaW5nOlRFU1RfTk9USUZJQ0FUSU9OYGBcbiAqL1xuTm90aWZpY2F0aW9uVHlwZXM/OiBzdHJpbmdbXVxufVxuLyoqXG4gKiBJbmZvcm1hdGlvbiB1c2VkIHRvIHNwZWNpZnkgdGhlIGxhdW5jaCB0ZW1wbGF0ZSBhbmQgdmVyc2lvbiB0byB1c2UgdG8gbGF1bmNoIGluc3RhbmNlcy4gWW91IGNhbiBhbHRlcm5hdGl2ZWx5IGFzc29jaWF0ZSBhIGxhdW5jaCB0ZW1wbGF0ZSB0byB0aGUgQXV0byBTY2FsaW5nIGdyb3VwIGJ5IHNwZWNpZnlpbmcgYSBgYE1peGVkSW5zdGFuY2VzUG9saWN5YGAuIEZvciBtb3JlIGluZm9ybWF0aW9uIGFib3V0IGNyZWF0aW5nIGxhdW5jaCB0ZW1wbGF0ZXMsIHNlZSBbQ3JlYXRlIGEgbGF1bmNoIHRlbXBsYXRlIGZvciBhbiBBdXRvIFNjYWxpbmcgZ3JvdXBdKGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9hdXRvc2NhbGluZy9lYzIvdXNlcmd1aWRlL2NyZWF0ZS1sYXVuY2gtdGVtcGxhdGUuaHRtbCkgaW4gdGhlICpBbWF6b24gRUMyIEF1dG8gU2NhbGluZyBVc2VyIEd1aWRlKi5cbiAqICBJZiB5b3Ugb21pdCB0aGlzIHByb3BlcnR5LCB5b3UgbXVzdCBzcGVjaWZ5IGBgTWl4ZWRJbnN0YW5jZXNQb2xpY3lgYCwgYGBMYXVuY2hDb25maWd1cmF0aW9uTmFtZWBgLCBvciBgYEluc3RhbmNlSWRgYC5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBMYXVuY2hUZW1wbGF0ZVNwZWNpZmljYXRpb24ge1xuLyoqXG4gKiBUaGUgbmFtZSBvZiB0aGUgbGF1bmNoIHRlbXBsYXRlLlxuICogIFlvdSBtdXN0IHNwZWNpZnkgdGhlIGBgTGF1bmNoVGVtcGxhdGVOYW1lYGAgb3IgdGhlIGBgTGF1bmNoVGVtcGxhdGVJRGBgLCBidXQgbm90IGJvdGguXG4gKi9cbkxhdW5jaFRlbXBsYXRlTmFtZT86IHN0cmluZ1xuLyoqXG4gKiBUaGUgdmVyc2lvbiBudW1iZXIgb2YgdGhlIGxhdW5jaCB0ZW1wbGF0ZS5cbiAqICBTcGVjaWZ5aW5nIGBgJExhdGVzdGBgIG9yIGBgJERlZmF1bHRgYCBmb3IgdGhlIHRlbXBsYXRlIHZlcnNpb24gbnVtYmVyIGlzIG5vdCBzdXBwb3J0ZWQuIEhvd2V2ZXIsIHlvdSBjYW4gc3BlY2lmeSBgYExhdGVzdFZlcnNpb25OdW1iZXJgYCBvciBgYERlZmF1bHRWZXJzaW9uTnVtYmVyYGAgdXNpbmcgdGhlIGBgRm46OkdldEF0dGBgIGludHJpbnNpYyBmdW5jdGlvbi4gRm9yIG1vcmUgaW5mb3JtYXRpb24sIHNlZSBbRm46OkdldEF0dF0oaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL0FXU0Nsb3VkRm9ybWF0aW9uL2xhdGVzdC9Vc2VyR3VpZGUvaW50cmluc2ljLWZ1bmN0aW9uLXJlZmVyZW5jZS1nZXRhdHQuaHRtbCkuXG4gKiAgIEZvciBhbiBleGFtcGxlIG9mIHVzaW5nIHRoZSBgYEZuOjpHZXRBdHRgYCBmdW5jdGlvbiwgc2VlIHRoZSBbRXhhbXBsZXNdKGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9BV1NDbG91ZEZvcm1hdGlvbi9sYXRlc3QvVXNlckd1aWRlL2F3cy1yZXNvdXJjZS1hdXRvc2NhbGluZy1hdXRvc2NhbGluZ2dyb3VwLmh0bWwjYXdzLXJlc291cmNlLWF1dG9zY2FsaW5nLWF1dG9zY2FsaW5nZ3JvdXAtLWV4YW1wbGVzKSBzZWN0aW9uIG9mIHRoZSBgYEFXUzo6QXV0b1NjYWxpbmc6OkF1dG9TY2FsaW5nR3JvdXBgYCByZXNvdXJjZS5cbiAqL1xuVmVyc2lvbjogc3RyaW5nXG4vKipcbiAqIFRoZSBJRCBvZiB0aGUgbGF1bmNoIHRlbXBsYXRlLlxuICogIFlvdSBtdXN0IHNwZWNpZnkgdGhlIGBgTGF1bmNoVGVtcGxhdGVJRGBgIG9yIHRoZSBgYExhdW5jaFRlbXBsYXRlTmFtZWBgLCBidXQgbm90IGJvdGguXG4gKi9cbkxhdW5jaFRlbXBsYXRlSWQ/OiBzdHJpbmdcbn1cbi8qKlxuICogQW4gZW1iZWRkZWQgb2JqZWN0IHRoYXQgc3BlY2lmaWVzIGEgbWl4ZWQgaW5zdGFuY2VzIHBvbGljeS5cbiAqICBUaGUgcG9saWN5IGluY2x1ZGVzIHByb3BlcnRpZXMgdGhhdCBub3Qgb25seSBkZWZpbmUgdGhlIGRpc3RyaWJ1dGlvbiBvZiBPbi1EZW1hbmQgSW5zdGFuY2VzIGFuZCBTcG90IEluc3RhbmNlcywgdGhlIG1heGltdW0gcHJpY2UgdG8gcGF5IGZvciBTcG90IEluc3RhbmNlcyAob3B0aW9uYWwpLCBhbmQgaG93IHRoZSBBdXRvIFNjYWxpbmcgZ3JvdXAgYWxsb2NhdGVzIGluc3RhbmNlIHR5cGVzIHRvIGZ1bGZpbGwgT24tRGVtYW5kIGFuZCBTcG90IGNhcGFjaXRpZXMsIGJ1dCBhbHNvIHRoZSBwcm9wZXJ0aWVzIHRoYXQgc3BlY2lmeSB0aGUgaW5zdGFuY2UgY29uZmlndXJhdGlvbiBpbmZvcm1hdGlvbuKAlHRoZSBsYXVuY2ggdGVtcGxhdGUgYW5kIGluc3RhbmNlIHR5cGVzLiBUaGUgcG9saWN5IGNhbiBhbHNvIGluY2x1ZGUgYSB3ZWlnaHQgZm9yIGVhY2ggaW5zdGFuY2UgdHlwZSBhbmQgZGlmZmVyZW50IGxhdW5jaCB0ZW1wbGF0ZXMgZm9yIGluZGl2aWR1YWwgaW5zdGFuY2UgdHlwZXMuXG4gKiAgRm9yIG1vcmUgaW5mb3JtYXRpb24sIHNlZSBbQXV0byBTY2FsaW5nIGdyb3VwcyB3aXRoIG11bHRpcGxlIGluc3RhbmNlIHR5cGVzIGFuZCBwdXJjaGFzZSBvcHRpb25zXShodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vYXV0b3NjYWxpbmcvZWMyL3VzZXJndWlkZS9lYzItYXV0by1zY2FsaW5nLW1peGVkLWluc3RhbmNlcy1ncm91cHMuaHRtbCkgaW4gdGhlICpBbWF6b24gRUMyIEF1dG8gU2NhbGluZyBVc2VyIEd1aWRlKi5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBNaXhlZEluc3RhbmNlc1BvbGljeSB7XG5JbnN0YW5jZXNEaXN0cmlidXRpb24/OiBJbnN0YW5jZXNEaXN0cmlidXRpb25cbkxhdW5jaFRlbXBsYXRlOiBMYXVuY2hUZW1wbGF0ZVxufVxuLyoqXG4gKiBUaGUgaW5zdGFuY2VzIGRpc3RyaWJ1dGlvbi5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBJbnN0YW5jZXNEaXN0cmlidXRpb24ge1xuLyoqXG4gKiBUaGUgYWxsb2NhdGlvbiBzdHJhdGVneSB0byBhcHBseSB0byB5b3VyIE9uLURlbWFuZCBJbnN0YW5jZXMgd2hlbiB0aGV5IGFyZSBsYXVuY2hlZC4gUG9zc2libGUgaW5zdGFuY2UgdHlwZXMgYXJlIGRldGVybWluZWQgYnkgdGhlIGxhdW5jaCB0ZW1wbGF0ZSBvdmVycmlkZXMgdGhhdCB5b3Ugc3BlY2lmeS5cbiAqICBUaGUgZm9sbG93aW5nIGxpc3RzIHRoZSB2YWxpZCB2YWx1ZXM6XG4gKiAgICsgbG93ZXN0LXByaWNlIFVzZXMgcHJpY2UgdG8gZGV0ZXJtaW5lIHdoaWNoIGluc3RhbmNlIHR5cGVzIGFyZSB0aGUgaGlnaGVzdCBwcmlvcml0eSwgbGF1bmNoaW5nIHRoZSBsb3dlc3QgcHJpY2VkIGluc3RhbmNlIHR5cGVzIHdpdGhpbiBhbiBBdmFpbGFiaWxpdHkgWm9uZSBmaXJzdC4gVGhpcyBpcyB0aGUgZGVmYXVsdCB2YWx1ZSBmb3IgQXV0byBTY2FsaW5nIGdyb3VwcyB0aGF0IHNwZWNpZnkgSW5zdGFuY2VSZXF1aXJlbWVudHMuICsgcHJpb3JpdGl6ZWQgWW91IHNldCB0aGUgb3JkZXIgb2YgaW5zdGFuY2UgdHlwZXMgZm9yIHRoZSBsYXVuY2ggdGVtcGxhdGUgb3ZlcnJpZGVzIGZyb20gaGlnaGVzdCB0byBsb3dlc3QgcHJpb3JpdHkgKGZyb20gZmlyc3QgdG8gbGFzdCBpbiB0aGUgbGlzdCkuIEFtYXpvbiBFQzIgQXV0byBTY2FsaW5nIGxhdW5jaGVzIHlvdXIgaGlnaGVzdCBwcmlvcml0eSBpbnN0YW5jZSB0eXBlcyBmaXJzdC4gSWYgYWxsIHlvdXIgT24tRGVtYW5kIGNhcGFjaXR5IGNhbm5vdCBiZSBmdWxmaWxsZWQgdXNpbmcgeW91ciBoaWdoZXN0IHByaW9yaXR5IGluc3RhbmNlIHR5cGUsIHRoZW4gQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgbGF1bmNoZXMgdGhlIHJlbWFpbmluZyBjYXBhY2l0eSB1c2luZyB0aGUgc2Vjb25kIHByaW9yaXR5IGluc3RhbmNlIHR5cGUsIGFuZCBzbyBvbi4gVGhpcyBpcyB0aGUgZGVmYXVsdCB2YWx1ZSBmb3IgQXV0byBTY2FsaW5nIGdyb3VwcyB0aGF0IGRvbid0IHNwZWNpZnkgSW5zdGFuY2VSZXF1aXJlbWVudHMgYW5kIGNhbm5vdCBiZSB1c2VkIGZvciBncm91cHMgdGhhdCBkby5cbiAqL1xuT25EZW1hbmRBbGxvY2F0aW9uU3RyYXRlZ3k/OiBzdHJpbmdcbi8qKlxuICogVGhlIG1pbmltdW0gYW1vdW50IG9mIHRoZSBBdXRvIFNjYWxpbmcgZ3JvdXAncyBjYXBhY2l0eSB0aGF0IG11c3QgYmUgZnVsZmlsbGVkIGJ5IE9uLURlbWFuZCBJbnN0YW5jZXMuIFRoaXMgYmFzZSBwb3J0aW9uIGlzIGxhdW5jaGVkIGZpcnN0IGFzIHlvdXIgZ3JvdXAgc2NhbGVzLlxuICogIFRoaXMgbnVtYmVyIGhhcyB0aGUgc2FtZSB1bml0IG9mIG1lYXN1cmVtZW50IGFzIHRoZSBncm91cCdzIGRlc2lyZWQgY2FwYWNpdHkuIElmIHlvdSBjaGFuZ2UgdGhlIGRlZmF1bHQgdW5pdCBvZiBtZWFzdXJlbWVudCAobnVtYmVyIG9mIGluc3RhbmNlcykgYnkgc3BlY2lmeWluZyB3ZWlnaHRlZCBjYXBhY2l0eSB2YWx1ZXMgaW4geW91ciBsYXVuY2ggdGVtcGxhdGUgb3ZlcnJpZGVzIGxpc3QsIG9yIGJ5IGNoYW5naW5nIHRoZSBkZWZhdWx0IGRlc2lyZWQgY2FwYWNpdHkgdHlwZSBzZXR0aW5nIG9mIHRoZSBncm91cCwgeW91IG11c3Qgc3BlY2lmeSB0aGlzIG51bWJlciB1c2luZyB0aGUgc2FtZSB1bml0IG9mIG1lYXN1cmVtZW50LlxuICogIERlZmF1bHQ6IDBcbiAqICAgQW4gdXBkYXRlIHRvIHRoaXMgc2V0dGluZyBtZWFucyBhIGdyYWR1YWwgcmVwbGFjZW1lbnQgb2YgaW5zdGFuY2VzIHRvIGFkanVzdCB0aGUgY3VycmVudCBPbi1EZW1hbmQgSW5zdGFuY2UgbGV2ZWxzLiBXaGVuIHJlcGxhY2luZyBpbnN0YW5jZXMsIEFtYXpvbiBFQzIgQXV0byBTY2FsaW5nIGxhdW5jaGVzIG5ldyBpbnN0YW5jZXMgYmVmb3JlIHRlcm1pbmF0aW5nIHRoZSBwcmV2aW91cyBvbmVzLlxuICovXG5PbkRlbWFuZEJhc2VDYXBhY2l0eT86IG51bWJlclxuLyoqXG4gKiBDb250cm9scyB0aGUgcGVyY2VudGFnZXMgb2YgT24tRGVtYW5kIEluc3RhbmNlcyBhbmQgU3BvdCBJbnN0YW5jZXMgZm9yIHlvdXIgYWRkaXRpb25hbCBjYXBhY2l0eSBiZXlvbmQgYGBPbkRlbWFuZEJhc2VDYXBhY2l0eWBgLiBFeHByZXNzZWQgYXMgYSBudW1iZXIgKGZvciBleGFtcGxlLCAyMCBzcGVjaWZpZXMgMjAlIE9uLURlbWFuZCBJbnN0YW5jZXMsIDgwJSBTcG90IEluc3RhbmNlcykuIElmIHNldCB0byAxMDAsIG9ubHkgT24tRGVtYW5kIEluc3RhbmNlcyBhcmUgdXNlZC5cbiAqICBEZWZhdWx0OiAxMDBcbiAqICAgQW4gdXBkYXRlIHRvIHRoaXMgc2V0dGluZyBtZWFucyBhIGdyYWR1YWwgcmVwbGFjZW1lbnQgb2YgaW5zdGFuY2VzIHRvIGFkanVzdCB0aGUgY3VycmVudCBPbi1EZW1hbmQgYW5kIFNwb3QgSW5zdGFuY2UgbGV2ZWxzIGZvciB5b3VyIGFkZGl0aW9uYWwgY2FwYWNpdHkgaGlnaGVyIHRoYW4gdGhlIGJhc2UgY2FwYWNpdHkuIFdoZW4gcmVwbGFjaW5nIGluc3RhbmNlcywgQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgbGF1bmNoZXMgbmV3IGluc3RhbmNlcyBiZWZvcmUgdGVybWluYXRpbmcgdGhlIHByZXZpb3VzIG9uZXMuXG4gKi9cbk9uRGVtYW5kUGVyY2VudGFnZUFib3ZlQmFzZUNhcGFjaXR5PzogbnVtYmVyXG4vKipcbiAqIFRoZSBudW1iZXIgb2YgU3BvdCBJbnN0YW5jZSBwb29scyBhY3Jvc3Mgd2hpY2ggdG8gYWxsb2NhdGUgeW91ciBTcG90IEluc3RhbmNlcy4gVGhlIFNwb3QgcG9vbHMgYXJlIGRldGVybWluZWQgZnJvbSB0aGUgZGlmZmVyZW50IGluc3RhbmNlIHR5cGVzIGluIHRoZSBvdmVycmlkZXMuIFZhbGlkIG9ubHkgd2hlbiB0aGUgYGBTcG90QWxsb2NhdGlvblN0cmF0ZWd5YGAgaXMgYGBsb3dlc3QtcHJpY2VgYC4gVmFsdWUgbXVzdCBiZSBpbiB0aGUgcmFuZ2Ugb2YgMeKAkzIwLlxuICogIERlZmF1bHQ6IDJcbiAqL1xuU3BvdEluc3RhbmNlUG9vbHM/OiBudW1iZXJcbi8qKlxuICogVGhlIGFsbG9jYXRpb24gc3RyYXRlZ3kgdG8gYXBwbHkgdG8geW91ciBTcG90IEluc3RhbmNlcyB3aGVuIHRoZXkgYXJlIGxhdW5jaGVkLiBQb3NzaWJsZSBpbnN0YW5jZSB0eXBlcyBhcmUgZGV0ZXJtaW5lZCBieSB0aGUgbGF1bmNoIHRlbXBsYXRlIG92ZXJyaWRlcyB0aGF0IHlvdSBzcGVjaWZ5LlxuICogIFRoZSBmb2xsb3dpbmcgbGlzdHMgdGhlIHZhbGlkIHZhbHVlczpcbiAqICAgKyBjYXBhY2l0eS1vcHRpbWl6ZWQgUmVxdWVzdHMgU3BvdCBJbnN0YW5jZXMgdXNpbmcgcG9vbHMgdGhhdCBhcmUgb3B0aW1hbGx5IGNob3NlbiBiYXNlZCBvbiB0aGUgYXZhaWxhYmxlIFNwb3QgY2FwYWNpdHkuIFRoaXMgc3RyYXRlZ3kgaGFzIHRoZSBsb3dlc3QgcmlzayBvZiBpbnRlcnJ1cHRpb24uIFRvIGdpdmUgY2VydGFpbiBpbnN0YW5jZSB0eXBlcyBhIGhpZ2hlciBjaGFuY2Ugb2YgbGF1bmNoaW5nIGZpcnN0LCB1c2UgY2FwYWNpdHktb3B0aW1pemVkLXByaW9yaXRpemVkLiArIGNhcGFjaXR5LW9wdGltaXplZC1wcmlvcml0aXplZCBZb3Ugc2V0IHRoZSBvcmRlciBvZiBpbnN0YW5jZSB0eXBlcyBmb3IgdGhlIGxhdW5jaCB0ZW1wbGF0ZSBvdmVycmlkZXMgZnJvbSBoaWdoZXN0IHRvIGxvd2VzdCBwcmlvcml0eSAoZnJvbSBmaXJzdCB0byBsYXN0IGluIHRoZSBsaXN0KS4gQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgaG9ub3JzIHRoZSBpbnN0YW5jZSB0eXBlIHByaW9yaXRpZXMgb24gYSBiZXN0IGVmZm9ydCBiYXNpcyBidXQgb3B0aW1pemVzIGZvciBjYXBhY2l0eSBmaXJzdC4gTm90ZSB0aGF0IGlmIHRoZSBPbi1EZW1hbmQgYWxsb2NhdGlvbiBzdHJhdGVneSBpcyBzZXQgdG8gcHJpb3JpdGl6ZWQsIHRoZSBzYW1lIHByaW9yaXR5IGlzIGFwcGxpZWQgd2hlbiBmdWxmaWxsaW5nIE9uLURlbWFuZCBjYXBhY2l0eS4gVGhpcyBpcyBub3QgYSB2YWxpZCB2YWx1ZSBmb3IgQXV0byBTY2FsaW5nIGdyb3VwcyB0aGF0IHNwZWNpZnkgSW5zdGFuY2VSZXF1aXJlbWVudHMuICsgbG93ZXN0LXByaWNlIFJlcXVlc3RzIFNwb3QgSW5zdGFuY2VzIHVzaW5nIHRoZSBsb3dlc3QgcHJpY2VkIHBvb2xzIHdpdGhpbiBhbiBBdmFpbGFiaWxpdHkgWm9uZSwgYWNyb3NzIHRoZSBudW1iZXIgb2YgU3BvdCBwb29scyB0aGF0IHlvdSBzcGVjaWZ5IGZvciB0aGUgU3BvdEluc3RhbmNlUG9vbHMgcHJvcGVydHkuIFRvIGVuc3VyZSB0aGF0IHlvdXIgZGVzaXJlZCBjYXBhY2l0eSBpcyBtZXQsIHlvdSBtaWdodCByZWNlaXZlIFNwb3QgSW5zdGFuY2VzIGZyb20gc2V2ZXJhbCBwb29scy4gVGhpcyBpcyB0aGUgZGVmYXVsdCB2YWx1ZSwgYnV0IGl0IG1pZ2h0IGxlYWQgdG8gaGlnaCBpbnRlcnJ1cHRpb24gcmF0ZXMgYmVjYXVzZSB0aGlzIHN0cmF0ZWd5IG9ubHkgY29uc2lkZXJzIGluc3RhbmNlIHByaWNlIGFuZCBub3QgYXZhaWxhYmxlIGNhcGFjaXR5LiArIHByaWNlLWNhcGFjaXR5LW9wdGltaXplZCAocmVjb21tZW5kZWQpIFRoZSBwcmljZSBhbmQgY2FwYWNpdHkgb3B0aW1pemVkIGFsbG9jYXRpb24gc3RyYXRlZ3kgbG9va3MgYXQgYm90aCBwcmljZSBhbmQgY2FwYWNpdHkgdG8gc2VsZWN0IHRoZSBTcG90IEluc3RhbmNlIHBvb2xzIHRoYXQgYXJlIHRoZSBsZWFzdCBsaWtlbHkgdG8gYmUgaW50ZXJydXB0ZWQgYW5kIGhhdmUgdGhlIGxvd2VzdCBwb3NzaWJsZSBwcmljZS5cbiAqL1xuU3BvdEFsbG9jYXRpb25TdHJhdGVneT86IHN0cmluZ1xuLyoqXG4gKiBUaGUgbWF4aW11bSBwcmljZSBwZXIgdW5pdCBob3VyIHRoYXQgeW91IGFyZSB3aWxsaW5nIHRvIHBheSBmb3IgYSBTcG90IEluc3RhbmNlLiBJZiB5b3VyIG1heGltdW0gcHJpY2UgaXMgbG93ZXIgdGhhbiB0aGUgU3BvdCBwcmljZSBmb3IgdGhlIGluc3RhbmNlIHR5cGVzIHRoYXQgeW91IHNlbGVjdGVkLCB5b3VyIFNwb3QgSW5zdGFuY2VzIGFyZSBub3QgbGF1bmNoZWQuIFdlIGRvIG5vdCByZWNvbW1lbmQgc3BlY2lmeWluZyBhIG1heGltdW0gcHJpY2UgYmVjYXVzZSBpdCBjYW4gbGVhZCB0byBpbmNyZWFzZWQgaW50ZXJydXB0aW9ucy4gV2hlbiBTcG90IEluc3RhbmNlcyBsYXVuY2gsIHlvdSBwYXkgdGhlIGN1cnJlbnQgU3BvdCBwcmljZS4gVG8gcmVtb3ZlIGEgbWF4aW11bSBwcmljZSB0aGF0IHlvdSBwcmV2aW91c2x5IHNldCwgaW5jbHVkZSB0aGUgcHJvcGVydHkgYnV0IHNwZWNpZnkgYW4gZW1wdHkgc3RyaW5nIChcIlwiKSBmb3IgdGhlIHZhbHVlLlxuICogICBJZiB5b3Ugc3BlY2lmeSBhIG1heGltdW0gcHJpY2UsIHlvdXIgaW5zdGFuY2VzIHdpbGwgYmUgaW50ZXJydXB0ZWQgbW9yZSBmcmVxdWVudGx5IHRoYW4gaWYgeW91IGRvIG5vdCBzcGVjaWZ5IG9uZS5cbiAqICAgVmFsaWQgUmFuZ2U6IE1pbmltdW0gdmFsdWUgb2YgMC4wMDFcbiAqL1xuU3BvdE1heFByaWNlPzogc3RyaW5nXG59XG4vKipcbiAqIE9uZSBvciBtb3JlIGxhdW5jaCB0ZW1wbGF0ZXMgYW5kIHRoZSBpbnN0YW5jZSB0eXBlcyAob3ZlcnJpZGVzKSB0aGF0IGFyZSB1c2VkIHRvIGxhdW5jaCBFQzIgaW5zdGFuY2VzIHRvIGZ1bGZpbGwgT24tRGVtYW5kIGFuZCBTcG90IGNhcGFjaXRpZXMuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgTGF1bmNoVGVtcGxhdGUge1xuTGF1bmNoVGVtcGxhdGVTcGVjaWZpY2F0aW9uOiBMYXVuY2hUZW1wbGF0ZVNwZWNpZmljYXRpb24xXG4vKipcbiAqIEFueSBwcm9wZXJ0aWVzIHRoYXQgeW91IHNwZWNpZnkgb3ZlcnJpZGUgdGhlIHNhbWUgcHJvcGVydGllcyBpbiB0aGUgbGF1bmNoIHRlbXBsYXRlLlxuICovXG5PdmVycmlkZXM/OiBMYXVuY2hUZW1wbGF0ZU92ZXJyaWRlc1tdXG59XG4vKipcbiAqIFRoZSBsYXVuY2ggdGVtcGxhdGUuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgTGF1bmNoVGVtcGxhdGVTcGVjaWZpY2F0aW9uMSB7XG4vKipcbiAqIFRoZSBuYW1lIG9mIHRoZSBsYXVuY2ggdGVtcGxhdGUuXG4gKiAgWW91IG11c3Qgc3BlY2lmeSB0aGUgYGBMYXVuY2hUZW1wbGF0ZU5hbWVgYCBvciB0aGUgYGBMYXVuY2hUZW1wbGF0ZUlEYGAsIGJ1dCBub3QgYm90aC5cbiAqL1xuTGF1bmNoVGVtcGxhdGVOYW1lPzogc3RyaW5nXG4vKipcbiAqIFRoZSB2ZXJzaW9uIG51bWJlciBvZiB0aGUgbGF1bmNoIHRlbXBsYXRlLlxuICogIFNwZWNpZnlpbmcgYGAkTGF0ZXN0YGAgb3IgYGAkRGVmYXVsdGBgIGZvciB0aGUgdGVtcGxhdGUgdmVyc2lvbiBudW1iZXIgaXMgbm90IHN1cHBvcnRlZC4gSG93ZXZlciwgeW91IGNhbiBzcGVjaWZ5IGBgTGF0ZXN0VmVyc2lvbk51bWJlcmBgIG9yIGBgRGVmYXVsdFZlcnNpb25OdW1iZXJgYCB1c2luZyB0aGUgYGBGbjo6R2V0QXR0YGAgaW50cmluc2ljIGZ1bmN0aW9uLiBGb3IgbW9yZSBpbmZvcm1hdGlvbiwgc2VlIFtGbjo6R2V0QXR0XShodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vQVdTQ2xvdWRGb3JtYXRpb24vbGF0ZXN0L1VzZXJHdWlkZS9pbnRyaW5zaWMtZnVuY3Rpb24tcmVmZXJlbmNlLWdldGF0dC5odG1sKS5cbiAqICAgRm9yIGFuIGV4YW1wbGUgb2YgdXNpbmcgdGhlIGBgRm46OkdldEF0dGBgIGZ1bmN0aW9uLCBzZWUgdGhlIFtFeGFtcGxlc10oaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL0FXU0Nsb3VkRm9ybWF0aW9uL2xhdGVzdC9Vc2VyR3VpZGUvYXdzLXJlc291cmNlLWF1dG9zY2FsaW5nLWF1dG9zY2FsaW5nZ3JvdXAuaHRtbCNhd3MtcmVzb3VyY2UtYXV0b3NjYWxpbmctYXV0b3NjYWxpbmdncm91cC0tZXhhbXBsZXMpIHNlY3Rpb24gb2YgdGhlIGBgQVdTOjpBdXRvU2NhbGluZzo6QXV0b1NjYWxpbmdHcm91cGBgIHJlc291cmNlLlxuICovXG5WZXJzaW9uOiBzdHJpbmdcbi8qKlxuICogVGhlIElEIG9mIHRoZSBsYXVuY2ggdGVtcGxhdGUuXG4gKiAgWW91IG11c3Qgc3BlY2lmeSB0aGUgYGBMYXVuY2hUZW1wbGF0ZUlEYGAgb3IgdGhlIGBgTGF1bmNoVGVtcGxhdGVOYW1lYGAsIGJ1dCBub3QgYm90aC5cbiAqL1xuTGF1bmNoVGVtcGxhdGVJZD86IHN0cmluZ1xufVxuLyoqXG4gKiBVc2UgdGhpcyBzdHJ1Y3R1cmUgdG8gbGV0IEFtYXpvbiBFQzIgQXV0byBTY2FsaW5nIGRvIHRoZSBmb2xsb3dpbmcgd2hlbiB0aGUgQXV0byBTY2FsaW5nIGdyb3VwIGhhcyBhIG1peGVkIGluc3RhbmNlcyBwb2xpY3k6XG4gKiAgICsgIE92ZXJyaWRlIHRoZSBpbnN0YW5jZSB0eXBlIHRoYXQgaXMgc3BlY2lmaWVkIGluIHRoZSBsYXVuY2ggdGVtcGxhdGUuXG4gKiAgICsgIFVzZSBtdWx0aXBsZSBpbnN0YW5jZSB0eXBlcy5cbiAqICAgXG4gKiAgU3BlY2lmeSB0aGUgaW5zdGFuY2UgdHlwZXMgdGhhdCB5b3Ugd2FudCwgb3IgZGVmaW5lIHlvdXIgaW5zdGFuY2UgcmVxdWlyZW1lbnRzIGluc3RlYWQgYW5kIGxldCBBbWF6b24gRUMyIEF1dG8gU2NhbGluZyBwcm92aXNpb24gdGhlIGF2YWlsYWJsZSBpbnN0YW5jZSB0eXBlcyB0aGF0IG1lZXQgeW91ciByZXF1aXJlbWVudHMuIFRoaXMgY2FuIHByb3ZpZGUgQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgd2l0aCBhIGxhcmdlciBzZWxlY3Rpb24gb2YgaW5zdGFuY2UgdHlwZXMgdG8gY2hvb3NlIGZyb20gd2hlbiBmdWxmaWxsaW5nIFNwb3QgYW5kIE9uLURlbWFuZCBjYXBhY2l0aWVzLiBZb3UgY2FuIHZpZXcgd2hpY2ggaW5zdGFuY2UgdHlwZXMgYXJlIG1hdGNoZWQgYmVmb3JlIHlvdSBhcHBseSB0aGUgaW5zdGFuY2UgcmVxdWlyZW1lbnRzIHRvIHlvdXIgQXV0byBTY2FsaW5nIGdyb3VwLlxuICogIEFmdGVyIHlvdSBkZWZpbmUgeW91ciBpbnN0YW5jZSByZXF1aXJlbWVudHMsIHlvdSBkb24ndCBoYXZlIHRvIGtlZXAgdXBkYXRpbmcgdGhlc2Ugc2V0dGluZ3MgdG8gZ2V0IG5ldyBFQzIgaW5zdGFuY2UgdHlwZXMgYXV0b21hdGljYWxseS4gQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgdXNlcyB0aGUgaW5zdGFuY2UgcmVxdWlyZW1lbnRzIG9mIHRoZSBBdXRvIFNjYWxpbmcgZ3JvdXAgdG8gZGV0ZXJtaW5lIHdoZXRoZXIgYSBuZXcgRUMyIGluc3RhbmNlIHR5cGUgY2FuIGJlIHVzZWQuXG4gKiAgIGBgTGF1bmNoVGVtcGxhdGVPdmVycmlkZXNgYCBpcyBhIHByb3BlcnR5IG9mIHRoZSBbQVdTOjpBdXRvU2NhbGluZzo6QXV0b1NjYWxpbmdHcm91cCBMYXVuY2hUZW1wbGF0ZV0oaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL0FXU0Nsb3VkRm9ybWF0aW9uL2xhdGVzdC9Vc2VyR3VpZGUvYXdzLXByb3BlcnRpZXMtYXV0b3NjYWxpbmctYXV0b3NjYWxpbmdncm91cC1sYXVuY2h0ZW1wbGF0ZS5odG1sKSBwcm9wZXJ0eSB0eXBlLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIExhdW5jaFRlbXBsYXRlT3ZlcnJpZGVzIHtcbkxhdW5jaFRlbXBsYXRlU3BlY2lmaWNhdGlvbj86IExhdW5jaFRlbXBsYXRlU3BlY2lmaWNhdGlvbjJcbi8qKlxuICogSWYgeW91IHByb3ZpZGUgYSBsaXN0IG9mIGluc3RhbmNlIHR5cGVzIHRvIHVzZSwgeW91IGNhbiBzcGVjaWZ5IHRoZSBudW1iZXIgb2YgY2FwYWNpdHkgdW5pdHMgcHJvdmlkZWQgYnkgZWFjaCBpbnN0YW5jZSB0eXBlIGluIHRlcm1zIG9mIHZpcnR1YWwgQ1BVcywgbWVtb3J5LCBzdG9yYWdlLCB0aHJvdWdocHV0LCBvciBvdGhlciByZWxhdGl2ZSBwZXJmb3JtYW5jZSBjaGFyYWN0ZXJpc3RpYy4gV2hlbiBhIFNwb3Qgb3IgT24tRGVtYW5kIEluc3RhbmNlIGlzIGxhdW5jaGVkLCB0aGUgY2FwYWNpdHkgdW5pdHMgY291bnQgdG93YXJkIHRoZSBkZXNpcmVkIGNhcGFjaXR5LiBBbWF6b24gRUMyIEF1dG8gU2NhbGluZyBsYXVuY2hlcyBpbnN0YW5jZXMgdW50aWwgdGhlIGRlc2lyZWQgY2FwYWNpdHkgaXMgdG90YWxseSBmdWxmaWxsZWQsIGV2ZW4gaWYgdGhpcyByZXN1bHRzIGluIGFuIG92ZXJhZ2UuIEZvciBleGFtcGxlLCBpZiB0aGVyZSBhcmUgdHdvIHVuaXRzIHJlbWFpbmluZyB0byBmdWxmaWxsIGNhcGFjaXR5LCBhbmQgQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgY2FuIG9ubHkgbGF1bmNoIGFuIGluc3RhbmNlIHdpdGggYSBgYFdlaWdodGVkQ2FwYWNpdHlgYCBvZiBmaXZlIHVuaXRzLCB0aGUgaW5zdGFuY2UgaXMgbGF1bmNoZWQsIGFuZCB0aGUgZGVzaXJlZCBjYXBhY2l0eSBpcyBleGNlZWRlZCBieSB0aHJlZSB1bml0cy4gRm9yIG1vcmUgaW5mb3JtYXRpb24sIHNlZSBbQ29uZmlndXJlIGluc3RhbmNlIHdlaWdodGluZyBmb3IgQW1hem9uIEVDMiBBdXRvIFNjYWxpbmddKGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9hdXRvc2NhbGluZy9lYzIvdXNlcmd1aWRlL2VjMi1hdXRvLXNjYWxpbmctbWl4ZWQtaW5zdGFuY2VzLWdyb3Vwcy1pbnN0YW5jZS13ZWlnaHRpbmcuaHRtbCkgaW4gdGhlICpBbWF6b24gRUMyIEF1dG8gU2NhbGluZyBVc2VyIEd1aWRlKi4gVmFsdWUgbXVzdCBiZSBpbiB0aGUgcmFuZ2Ugb2YgMS05OTkuIFxuICogIElmIHlvdSBzcGVjaWZ5IGEgdmFsdWUgZm9yIGBgV2VpZ2h0ZWRDYXBhY2l0eWBgIGZvciBvbmUgaW5zdGFuY2UgdHlwZSwgeW91IG11c3Qgc3BlY2lmeSBhIHZhbHVlIGZvciBgYFdlaWdodGVkQ2FwYWNpdHlgYCBmb3IgYWxsIG9mIHRoZW0uXG4gKiAgIEV2ZXJ5IEF1dG8gU2NhbGluZyBncm91cCBoYXMgdGhyZWUgc2l6ZSBwYXJhbWV0ZXJzIChgYERlc2lyZWRDYXBhY2l0eWBgLCBgYE1heFNpemVgYCwgYW5kIGBgTWluU2l6ZWBgKS4gVXN1YWxseSwgeW91IHNldCB0aGVzZSBzaXplcyBiYXNlZCBvbiBhIHNwZWNpZmljIG51bWJlciBvZiBpbnN0YW5jZXMuIEhvd2V2ZXIsIGlmIHlvdSBjb25maWd1cmUgYSBtaXhlZCBpbnN0YW5jZXMgcG9saWN5IHRoYXQgZGVmaW5lcyB3ZWlnaHRzIGZvciB0aGUgaW5zdGFuY2UgdHlwZXMsIHlvdSBtdXN0IHNwZWNpZnkgdGhlc2Ugc2l6ZXMgd2l0aCB0aGUgc2FtZSB1bml0cyB0aGF0IHlvdSB1c2UgZm9yIHdlaWdodGluZyBpbnN0YW5jZXMuXG4gKi9cbldlaWdodGVkQ2FwYWNpdHk/OiBzdHJpbmdcbkluc3RhbmNlUmVxdWlyZW1lbnRzPzogSW5zdGFuY2VSZXF1aXJlbWVudHNcbi8qKlxuICogVGhlIGluc3RhbmNlIHR5cGUsIHN1Y2ggYXMgYGBtMy54bGFyZ2VgYC4gWW91IG11c3Qgc3BlY2lmeSBhbiBpbnN0YW5jZSB0eXBlIHRoYXQgaXMgc3VwcG9ydGVkIGluIHlvdXIgcmVxdWVzdGVkIFJlZ2lvbiBhbmQgQXZhaWxhYmlsaXR5IFpvbmVzLiBGb3IgbW9yZSBpbmZvcm1hdGlvbiwgc2VlIFtJbnN0YW5jZSB0eXBlc10oaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL0FXU0VDMi9sYXRlc3QvVXNlckd1aWRlL2luc3RhbmNlLXR5cGVzLmh0bWwpIGluIHRoZSAqQW1hem9uIEVDMiBVc2VyIEd1aWRlIGZvciBMaW51eCBJbnN0YW5jZXMqLlxuICogIFlvdSBjYW4gc3BlY2lmeSB1cCB0byA0MCBpbnN0YW5jZSB0eXBlcyBwZXIgQXV0byBTY2FsaW5nIGdyb3VwLlxuICovXG5JbnN0YW5jZVR5cGU/OiBzdHJpbmdcbn1cbi8qKlxuICogUHJvdmlkZXMgYSBsYXVuY2ggdGVtcGxhdGUgZm9yIHRoZSBzcGVjaWZpZWQgaW5zdGFuY2UgdHlwZSBvciBzZXQgb2YgaW5zdGFuY2UgcmVxdWlyZW1lbnRzLiBGb3IgZXhhbXBsZSwgc29tZSBpbnN0YW5jZSB0eXBlcyBtaWdodCByZXF1aXJlIGEgbGF1bmNoIHRlbXBsYXRlIHdpdGggYSBkaWZmZXJlbnQgQU1JLiBJZiBub3QgcHJvdmlkZWQsIEFtYXpvbiBFQzIgQXV0byBTY2FsaW5nIHVzZXMgdGhlIGxhdW5jaCB0ZW1wbGF0ZSB0aGF0J3Mgc3BlY2lmaWVkIGluIHRoZSBgYExhdW5jaFRlbXBsYXRlYGAgZGVmaW5pdGlvbi4gRm9yIG1vcmUgaW5mb3JtYXRpb24sIHNlZSBbU3BlY2lmeWluZyBhIGRpZmZlcmVudCBsYXVuY2ggdGVtcGxhdGUgZm9yIGFuIGluc3RhbmNlIHR5cGVdKGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9hdXRvc2NhbGluZy9lYzIvdXNlcmd1aWRlL2VjMi1hdXRvLXNjYWxpbmctbWl4ZWQtaW5zdGFuY2VzLWdyb3Vwcy1sYXVuY2gtdGVtcGxhdGUtb3ZlcnJpZGVzLmh0bWwpIGluIHRoZSAqQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgVXNlciBHdWlkZSouIFxuICogIFlvdSBjYW4gc3BlY2lmeSB1cCB0byAyMCBsYXVuY2ggdGVtcGxhdGVzIHBlciBBdXRvIFNjYWxpbmcgZ3JvdXAuIFRoZSBsYXVuY2ggdGVtcGxhdGVzIHNwZWNpZmllZCBpbiB0aGUgb3ZlcnJpZGVzIGFuZCBpbiB0aGUgYGBMYXVuY2hUZW1wbGF0ZWBgIGRlZmluaXRpb24gY291bnQgdG93YXJkcyB0aGlzIGxpbWl0LlxuICovXG5leHBvcnQgaW50ZXJmYWNlIExhdW5jaFRlbXBsYXRlU3BlY2lmaWNhdGlvbjIge1xuLyoqXG4gKiBUaGUgbmFtZSBvZiB0aGUgbGF1bmNoIHRlbXBsYXRlLlxuICogIFlvdSBtdXN0IHNwZWNpZnkgdGhlIGBgTGF1bmNoVGVtcGxhdGVOYW1lYGAgb3IgdGhlIGBgTGF1bmNoVGVtcGxhdGVJRGBgLCBidXQgbm90IGJvdGguXG4gKi9cbkxhdW5jaFRlbXBsYXRlTmFtZT86IHN0cmluZ1xuLyoqXG4gKiBUaGUgdmVyc2lvbiBudW1iZXIgb2YgdGhlIGxhdW5jaCB0ZW1wbGF0ZS5cbiAqICBTcGVjaWZ5aW5nIGBgJExhdGVzdGBgIG9yIGBgJERlZmF1bHRgYCBmb3IgdGhlIHRlbXBsYXRlIHZlcnNpb24gbnVtYmVyIGlzIG5vdCBzdXBwb3J0ZWQuIEhvd2V2ZXIsIHlvdSBjYW4gc3BlY2lmeSBgYExhdGVzdFZlcnNpb25OdW1iZXJgYCBvciBgYERlZmF1bHRWZXJzaW9uTnVtYmVyYGAgdXNpbmcgdGhlIGBgRm46OkdldEF0dGBgIGludHJpbnNpYyBmdW5jdGlvbi4gRm9yIG1vcmUgaW5mb3JtYXRpb24sIHNlZSBbRm46OkdldEF0dF0oaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL0FXU0Nsb3VkRm9ybWF0aW9uL2xhdGVzdC9Vc2VyR3VpZGUvaW50cmluc2ljLWZ1bmN0aW9uLXJlZmVyZW5jZS1nZXRhdHQuaHRtbCkuXG4gKiAgIEZvciBhbiBleGFtcGxlIG9mIHVzaW5nIHRoZSBgYEZuOjpHZXRBdHRgYCBmdW5jdGlvbiwgc2VlIHRoZSBbRXhhbXBsZXNdKGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9BV1NDbG91ZEZvcm1hdGlvbi9sYXRlc3QvVXNlckd1aWRlL2F3cy1yZXNvdXJjZS1hdXRvc2NhbGluZy1hdXRvc2NhbGluZ2dyb3VwLmh0bWwjYXdzLXJlc291cmNlLWF1dG9zY2FsaW5nLWF1dG9zY2FsaW5nZ3JvdXAtLWV4YW1wbGVzKSBzZWN0aW9uIG9mIHRoZSBgYEFXUzo6QXV0b1NjYWxpbmc6OkF1dG9TY2FsaW5nR3JvdXBgYCByZXNvdXJjZS5cbiAqL1xuVmVyc2lvbjogc3RyaW5nXG4vKipcbiAqIFRoZSBJRCBvZiB0aGUgbGF1bmNoIHRlbXBsYXRlLlxuICogIFlvdSBtdXN0IHNwZWNpZnkgdGhlIGBgTGF1bmNoVGVtcGxhdGVJRGBgIG9yIHRoZSBgYExhdW5jaFRlbXBsYXRlTmFtZWBgLCBidXQgbm90IGJvdGguXG4gKi9cbkxhdW5jaFRlbXBsYXRlSWQ/OiBzdHJpbmdcbn1cbi8qKlxuICogVGhlIGluc3RhbmNlIHJlcXVpcmVtZW50cy4gQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgdXNlcyB5b3VyIHNwZWNpZmllZCByZXF1aXJlbWVudHMgdG8gaWRlbnRpZnkgaW5zdGFuY2UgdHlwZXMuIFRoZW4sIGl0IHVzZXMgeW91ciBPbi1EZW1hbmQgYW5kIFNwb3QgYWxsb2NhdGlvbiBzdHJhdGVnaWVzIHRvIGxhdW5jaCBpbnN0YW5jZXMgZnJvbSB0aGVzZSBpbnN0YW5jZSB0eXBlcy5cbiAqICBZb3UgY2FuIHNwZWNpZnkgdXAgdG8gZm91ciBzZXBhcmF0ZSBzZXRzIG9mIGluc3RhbmNlIHJlcXVpcmVtZW50cyBwZXIgQXV0byBTY2FsaW5nIGdyb3VwLiBUaGlzIGlzIHVzZWZ1bCBmb3IgcHJvdmlzaW9uaW5nIGluc3RhbmNlcyBmcm9tIGRpZmZlcmVudCBBbWF6b24gTWFjaGluZSBJbWFnZXMgKEFNSXMpIGluIHRoZSBzYW1lIEF1dG8gU2NhbGluZyBncm91cC4gVG8gZG8gdGhpcywgY3JlYXRlIHRoZSBBTUlzIGFuZCBjcmVhdGUgYSBuZXcgbGF1bmNoIHRlbXBsYXRlIGZvciBlYWNoIEFNSS4gVGhlbiwgY3JlYXRlIGEgY29tcGF0aWJsZSBzZXQgb2YgaW5zdGFuY2UgcmVxdWlyZW1lbnRzIGZvciBlYWNoIGxhdW5jaCB0ZW1wbGF0ZS4gXG4gKiAgIElmIHlvdSBzcGVjaWZ5IGBgSW5zdGFuY2VSZXF1aXJlbWVudHNgYCwgeW91IGNhbid0IHNwZWNpZnkgYGBJbnN0YW5jZVR5cGVgYC5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBJbnN0YW5jZVJlcXVpcmVtZW50cyB7XG4vKipcbiAqIEluZGljYXRlcyB3aGV0aGVyIGN1cnJlbnQgb3IgcHJldmlvdXMgZ2VuZXJhdGlvbiBpbnN0YW5jZSB0eXBlcyBhcmUgaW5jbHVkZWQuXG4gKiAgICsgIEZvciBjdXJyZW50IGdlbmVyYXRpb24gaW5zdGFuY2UgdHlwZXMsIHNwZWNpZnkgYGBjdXJyZW50YGAuIFRoZSBjdXJyZW50IGdlbmVyYXRpb24gaW5jbHVkZXMgRUMyIGluc3RhbmNlIHR5cGVzIGN1cnJlbnRseSByZWNvbW1lbmRlZCBmb3IgdXNlLiBUaGlzIHR5cGljYWxseSBpbmNsdWRlcyB0aGUgbGF0ZXN0IHR3byB0byB0aHJlZSBnZW5lcmF0aW9ucyBpbiBlYWNoIGluc3RhbmNlIGZhbWlseS4gRm9yIG1vcmUgaW5mb3JtYXRpb24sIHNlZSBbSW5zdGFuY2UgdHlwZXNdKGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9BV1NFQzIvbGF0ZXN0L1VzZXJHdWlkZS9pbnN0YW5jZS10eXBlcy5odG1sKSBpbiB0aGUgKkFtYXpvbiBFQzIgVXNlciBHdWlkZSBmb3IgTGludXggSW5zdGFuY2VzKi5cbiAqICAgKyAgRm9yIHByZXZpb3VzIGdlbmVyYXRpb24gaW5zdGFuY2UgdHlwZXMsIHNwZWNpZnkgYGBwcmV2aW91c2BgLlxuICogICBcbiAqICBEZWZhdWx0OiBBbnkgY3VycmVudCBvciBwcmV2aW91cyBnZW5lcmF0aW9uXG4gKi9cbkluc3RhbmNlR2VuZXJhdGlvbnM/OiBzdHJpbmdbXVxuLyoqXG4gKiBMaXN0cyB0aGUgYWNjZWxlcmF0b3IgdHlwZXMgdGhhdCBtdXN0IGJlIG9uIGFuIGluc3RhbmNlIHR5cGUuXG4gKiAgICsgIEZvciBpbnN0YW5jZSB0eXBlcyB3aXRoIEdQVSBhY2NlbGVyYXRvcnMsIHNwZWNpZnkgYGBncHVgYC5cbiAqICAgKyAgRm9yIGluc3RhbmNlIHR5cGVzIHdpdGggRlBHQSBhY2NlbGVyYXRvcnMsIHNwZWNpZnkgYGBmcGdhYGAuXG4gKiAgICsgIEZvciBpbnN0YW5jZSB0eXBlcyB3aXRoIGluZmVyZW5jZSBhY2NlbGVyYXRvcnMsIHNwZWNpZnkgYGBpbmZlcmVuY2VgYC5cbiAqICAgXG4gKiAgRGVmYXVsdDogQW55IGFjY2VsZXJhdG9yIHR5cGVcbiAqL1xuQWNjZWxlcmF0b3JUeXBlcz86IHN0cmluZ1tdXG5NZW1vcnlHaUJQZXJWQ3B1PzogTWVtb3J5R2lCUGVyVkNwdVJlcXVlc3Rcbi8qKlxuICogSW5kaWNhdGVzIHdoZXRoZXIgaW5zdGFuY2UgdHlwZXMgbXVzdCBoYXZlIGFjY2VsZXJhdG9ycyBieSBzcGVjaWZpYyBtYW51ZmFjdHVyZXJzLlxuICogICArICBGb3IgaW5zdGFuY2UgdHlwZXMgd2l0aCBOVklESUEgZGV2aWNlcywgc3BlY2lmeSBgYG52aWRpYWBgLlxuICogICArICBGb3IgaW5zdGFuY2UgdHlwZXMgd2l0aCBBTUQgZGV2aWNlcywgc3BlY2lmeSBgYGFtZGBgLlxuICogICArICBGb3IgaW5zdGFuY2UgdHlwZXMgd2l0aCBBV1MgZGV2aWNlcywgc3BlY2lmeSBgYGFtYXpvbi13ZWItc2VydmljZXNgYC5cbiAqICAgKyAgRm9yIGluc3RhbmNlIHR5cGVzIHdpdGggWGlsaW54IGRldmljZXMsIHNwZWNpZnkgYGB4aWxpbnhgYC5cbiAqICAgXG4gKiAgRGVmYXVsdDogQW55IG1hbnVmYWN0dXJlclxuICovXG5BY2NlbGVyYXRvck1hbnVmYWN0dXJlcnM/OiBzdHJpbmdbXVxuVkNwdUNvdW50OiBWQ3B1Q291bnRSZXF1ZXN0XG4vKipcbiAqIEluZGljYXRlcyB3aGV0aGVyIGluc3RhbmNlIHR5cGVzIHdpdGggaW5zdGFuY2Ugc3RvcmUgdm9sdW1lcyBhcmUgaW5jbHVkZWQsIGV4Y2x1ZGVkLCBvciByZXF1aXJlZC4gRm9yIG1vcmUgaW5mb3JtYXRpb24sIHNlZSBbQW1hem9uIEVDMiBpbnN0YW5jZSBzdG9yZV0oaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL0FXU0VDMi9sYXRlc3QvVXNlckd1aWRlL0luc3RhbmNlU3RvcmFnZS5odG1sKSBpbiB0aGUgKkFtYXpvbiBFQzIgVXNlciBHdWlkZSBmb3IgTGludXggSW5zdGFuY2VzKi5cbiAqICBEZWZhdWx0OiBgYGluY2x1ZGVkYGBcbiAqL1xuTG9jYWxTdG9yYWdlPzogc3RyaW5nXG4vKipcbiAqIExpc3RzIHdoaWNoIHNwZWNpZmljIENQVSBtYW51ZmFjdHVyZXJzIHRvIGluY2x1ZGUuXG4gKiAgICsgIEZvciBpbnN0YW5jZSB0eXBlcyB3aXRoIEludGVsIENQVXMsIHNwZWNpZnkgYGBpbnRlbGBgLlxuICogICArICBGb3IgaW5zdGFuY2UgdHlwZXMgd2l0aCBBTUQgQ1BVcywgc3BlY2lmeSBgYGFtZGBgLlxuICogICArICBGb3IgaW5zdGFuY2UgdHlwZXMgd2l0aCBBV1MgQ1BVcywgc3BlY2lmeSBgYGFtYXpvbi13ZWItc2VydmljZXNgYC5cbiAqICAgXG4gKiAgIERvbid0IGNvbmZ1c2UgdGhlIENQVSBoYXJkd2FyZSBtYW51ZmFjdHVyZXIgd2l0aCB0aGUgQ1BVIGhhcmR3YXJlIGFyY2hpdGVjdHVyZS4gSW5zdGFuY2VzIHdpbGwgYmUgbGF1bmNoZWQgd2l0aCBhIGNvbXBhdGlibGUgQ1BVIGFyY2hpdGVjdHVyZSBiYXNlZCBvbiB0aGUgQW1hem9uIE1hY2hpbmUgSW1hZ2UgKEFNSSkgdGhhdCB5b3Ugc3BlY2lmeSBpbiB5b3VyIGxhdW5jaCB0ZW1wbGF0ZS4gXG4gKiAgIERlZmF1bHQ6IEFueSBtYW51ZmFjdHVyZXJcbiAqL1xuQ3B1TWFudWZhY3R1cmVycz86IHN0cmluZ1tdXG4vKipcbiAqIEluZGljYXRlcyB3aGV0aGVyIGJhcmUgbWV0YWwgaW5zdGFuY2UgdHlwZXMgYXJlIGluY2x1ZGVkLCBleGNsdWRlZCwgb3IgcmVxdWlyZWQuXG4gKiAgRGVmYXVsdDogYGBleGNsdWRlZGBgXG4gKi9cbkJhcmVNZXRhbD86IHN0cmluZ1xuLyoqXG4gKiBJbmRpY2F0ZXMgd2hldGhlciBpbnN0YW5jZSB0eXBlcyBtdXN0IHByb3ZpZGUgT24tRGVtYW5kIEluc3RhbmNlIGhpYmVybmF0aW9uIHN1cHBvcnQuXG4gKiAgRGVmYXVsdDogYGBmYWxzZWBgXG4gKi9cblJlcXVpcmVIaWJlcm5hdGVTdXBwb3J0PzogYm9vbGVhblxuLyoqXG4gKiBbUHJpY2UgcHJvdGVjdGlvbl0gVGhlIHByaWNlIHByb3RlY3Rpb24gdGhyZXNob2xkIGZvciBTcG90IEluc3RhbmNlcywgYXMgYSBwZXJjZW50YWdlIG9mIGFuIGlkZW50aWZpZWQgT24tRGVtYW5kIHByaWNlLiBUaGUgaWRlbnRpZmllZCBPbi1EZW1hbmQgcHJpY2UgaXMgdGhlIHByaWNlIG9mIHRoZSBsb3dlc3QgcHJpY2VkIGN1cnJlbnQgZ2VuZXJhdGlvbiBDLCBNLCBvciBSIGluc3RhbmNlIHR5cGUgd2l0aCB5b3VyIHNwZWNpZmllZCBhdHRyaWJ1dGVzLiBJZiBubyBjdXJyZW50IGdlbmVyYXRpb24gQywgTSwgb3IgUiBpbnN0YW5jZSB0eXBlIG1hdGNoZXMgeW91ciBhdHRyaWJ1dGVzLCB0aGVuIHRoZSBpZGVudGlmaWVkIHByaWNlIGlzIGZyb20gZWl0aGVyIHRoZSBsb3dlc3QgcHJpY2VkIGN1cnJlbnQgZ2VuZXJhdGlvbiBpbnN0YW5jZSB0eXBlcyBvciwgZmFpbGluZyB0aGF0LCB0aGUgbG93ZXN0IHByaWNlZCBwcmV2aW91cyBnZW5lcmF0aW9uIGluc3RhbmNlIHR5cGVzIHRoYXQgbWF0Y2ggeW91ciBhdHRyaWJ1dGVzLiBXaGVuIEFtYXpvbiBFQzIgQXV0byBTY2FsaW5nIHNlbGVjdHMgaW5zdGFuY2UgdHlwZXMgd2l0aCB5b3VyIGF0dHJpYnV0ZXMsIHdlIHdpbGwgZXhjbHVkZSBpbnN0YW5jZSB0eXBlcyB3aG9zZSBwcmljZSBleGNlZWRzIHlvdXIgc3BlY2lmaWVkIHRocmVzaG9sZC5cbiAqICBUaGUgcGFyYW1ldGVyIGFjY2VwdHMgYW4gaW50ZWdlciwgd2hpY2ggQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgaW50ZXJwcmV0cyBhcyBhIHBlcmNlbnRhZ2UuXG4gKiAgSWYgeW91IHNldCBgYERlc2lyZWRDYXBhY2l0eVR5cGVgYCB0byBgYHZjcHVgYCBvciBgYG1lbW9yeS1taWJgYCwgdGhlIHByaWNlIHByb3RlY3Rpb24gdGhyZXNob2xkIGlzIGJhc2VkIG9uIHRoZSBwZXItdkNQVSBvciBwZXItbWVtb3J5IHByaWNlIGluc3RlYWQgb2YgdGhlIHBlciBpbnN0YW5jZSBwcmljZS4gXG4gKiAgIE9ubHkgb25lIG9mIGBgU3BvdE1heFByaWNlUGVyY2VudGFnZU92ZXJMb3dlc3RQcmljZWBgIG9yIGBgTWF4U3BvdFByaWNlQXNQZXJjZW50YWdlT2ZPcHRpbWFsT25EZW1hbmRQcmljZWBgIGNhbiBiZSBzcGVjaWZpZWQuIElmIHlvdSBkb24ndCBzcGVjaWZ5IGVpdGhlciwgQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgd2lsbCBhdXRvbWF0aWNhbGx5IGFwcGx5IG9wdGltYWwgcHJpY2UgcHJvdGVjdGlvbiB0byBjb25zaXN0ZW50bHkgc2VsZWN0IGZyb20gYSB3aWRlIHJhbmdlIG9mIGluc3RhbmNlIHR5cGVzLiBUbyBpbmRpY2F0ZSBubyBwcmljZSBwcm90ZWN0aW9uIHRocmVzaG9sZCBmb3IgU3BvdCBJbnN0YW5jZXMsIG1lYW5pbmcgeW91IHdhbnQgdG8gY29uc2lkZXIgYWxsIGluc3RhbmNlIHR5cGVzIHRoYXQgbWF0Y2ggeW91ciBhdHRyaWJ1dGVzLCBpbmNsdWRlIG9uZSBvZiB0aGVzZSBwYXJhbWV0ZXJzIGFuZCBzcGVjaWZ5IGEgaGlnaCB2YWx1ZSwgc3VjaCBhcyBgYDk5OTk5OWBgLlxuICovXG5NYXhTcG90UHJpY2VBc1BlcmNlbnRhZ2VPZk9wdGltYWxPbkRlbWFuZFByaWNlPzogbnVtYmVyXG4vKipcbiAqIFtQcmljZSBwcm90ZWN0aW9uXSBUaGUgcHJpY2UgcHJvdGVjdGlvbiB0aHJlc2hvbGQgZm9yIE9uLURlbWFuZCBJbnN0YW5jZXMsIGFzIGEgcGVyY2VudGFnZSBoaWdoZXIgdGhhbiBhbiBpZGVudGlmaWVkIE9uLURlbWFuZCBwcmljZS4gVGhlIGlkZW50aWZpZWQgT24tRGVtYW5kIHByaWNlIGlzIHRoZSBwcmljZSBvZiB0aGUgbG93ZXN0IHByaWNlZCBjdXJyZW50IGdlbmVyYXRpb24gQywgTSwgb3IgUiBpbnN0YW5jZSB0eXBlIHdpdGggeW91ciBzcGVjaWZpZWQgYXR0cmlidXRlcy4gSWYgbm8gY3VycmVudCBnZW5lcmF0aW9uIEMsIE0sIG9yIFIgaW5zdGFuY2UgdHlwZSBtYXRjaGVzIHlvdXIgYXR0cmlidXRlcywgdGhlbiB0aGUgaWRlbnRpZmllZCBwcmljZSBpcyBmcm9tIGVpdGhlciB0aGUgbG93ZXN0IHByaWNlZCBjdXJyZW50IGdlbmVyYXRpb24gaW5zdGFuY2UgdHlwZXMgb3IsIGZhaWxpbmcgdGhhdCwgdGhlIGxvd2VzdCBwcmljZWQgcHJldmlvdXMgZ2VuZXJhdGlvbiBpbnN0YW5jZSB0eXBlcyB0aGF0IG1hdGNoIHlvdXIgYXR0cmlidXRlcy4gV2hlbiBBbWF6b24gRUMyIEF1dG8gU2NhbGluZyBzZWxlY3RzIGluc3RhbmNlIHR5cGVzIHdpdGggeW91ciBhdHRyaWJ1dGVzLCB3ZSB3aWxsIGV4Y2x1ZGUgaW5zdGFuY2UgdHlwZXMgd2hvc2UgcHJpY2UgZXhjZWVkcyB5b3VyIHNwZWNpZmllZCB0aHJlc2hvbGQuIFxuICogIFRoZSBwYXJhbWV0ZXIgYWNjZXB0cyBhbiBpbnRlZ2VyLCB3aGljaCBBbWF6b24gRUMyIEF1dG8gU2NhbGluZyBpbnRlcnByZXRzIGFzIGEgcGVyY2VudGFnZS5cbiAqICBUbyB0dXJuIG9mZiBwcmljZSBwcm90ZWN0aW9uLCBzcGVjaWZ5IGEgaGlnaCB2YWx1ZSwgc3VjaCBhcyBgYDk5OTk5OWBgLiBcbiAqICBJZiB5b3Ugc2V0IGBgRGVzaXJlZENhcGFjaXR5VHlwZWBgIHRvIGBgdmNwdWBgIG9yIGBgbWVtb3J5LW1pYmBgLCB0aGUgcHJpY2UgcHJvdGVjdGlvbiB0aHJlc2hvbGQgaXMgYXBwbGllZCBiYXNlZCBvbiB0aGUgcGVyLXZDUFUgb3IgcGVyLW1lbW9yeSBwcmljZSBpbnN0ZWFkIG9mIHRoZSBwZXIgaW5zdGFuY2UgcHJpY2UuIFxuICogIERlZmF1bHQ6IGBgMjBgYFxuICovXG5PbkRlbWFuZE1heFByaWNlUGVyY2VudGFnZU92ZXJMb3dlc3RQcmljZT86IG51bWJlclxuTWVtb3J5TWlCOiBNZW1vcnlNaUJSZXF1ZXN0XG4vKipcbiAqIEluZGljYXRlcyB0aGUgdHlwZSBvZiBsb2NhbCBzdG9yYWdlIHRoYXQgaXMgcmVxdWlyZWQuXG4gKiAgICsgIEZvciBpbnN0YW5jZSB0eXBlcyB3aXRoIGhhcmQgZGlzayBkcml2ZSAoSEREKSBzdG9yYWdlLCBzcGVjaWZ5IGBgaGRkYGAuXG4gKiAgICsgIEZvciBpbnN0YW5jZSB0eXBlcyB3aXRoIHNvbGlkIHN0YXRlIGRyaXZlIChTU0QpIHN0b3JhZ2UsIHNwZWNpZnkgYGBzc2RgYC5cbiAqICAgXG4gKiAgRGVmYXVsdDogQW55IGxvY2FsIHN0b3JhZ2UgdHlwZVxuICovXG5Mb2NhbFN0b3JhZ2VUeXBlcz86IHN0cmluZ1tdXG5OZXR3b3JrSW50ZXJmYWNlQ291bnQ/OiBOZXR3b3JrSW50ZXJmYWNlQ291bnRSZXF1ZXN0XG4vKipcbiAqIFRoZSBpbnN0YW5jZSB0eXBlcyB0byBleGNsdWRlLiBZb3UgY2FuIHVzZSBzdHJpbmdzIHdpdGggb25lIG9yIG1vcmUgd2lsZCBjYXJkcywgcmVwcmVzZW50ZWQgYnkgYW4gYXN0ZXJpc2sgKGBgKmBgKSwgdG8gZXhjbHVkZSBhbiBpbnN0YW5jZSBmYW1pbHksIHR5cGUsIHNpemUsIG9yIGdlbmVyYXRpb24uIFRoZSBmb2xsb3dpbmcgYXJlIGV4YW1wbGVzOiBgYG01Ljh4bGFyZ2VgYCwgYGBjNSouKmBgLCBgYG01YS4qYGAsIGBgcipgYCwgYGAqMypgYC4gXG4gKiAgRm9yIGV4YW1wbGUsIGlmIHlvdSBzcGVjaWZ5IGBgYzUqYGAsIHlvdSBhcmUgZXhjbHVkaW5nIHRoZSBlbnRpcmUgQzUgaW5zdGFuY2UgZmFtaWx5LCB3aGljaCBpbmNsdWRlcyBhbGwgQzVhIGFuZCBDNW4gaW5zdGFuY2UgdHlwZXMuIElmIHlvdSBzcGVjaWZ5IGBgbTVhLipgYCwgQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgd2lsbCBleGNsdWRlIGFsbCB0aGUgTTVhIGluc3RhbmNlIHR5cGVzLCBidXQgbm90IHRoZSBNNW4gaW5zdGFuY2UgdHlwZXMuXG4gKiAgIElmIHlvdSBzcGVjaWZ5IGBgRXhjbHVkZWRJbnN0YW5jZVR5cGVzYGAsIHlvdSBjYW4ndCBzcGVjaWZ5IGBgQWxsb3dlZEluc3RhbmNlVHlwZXNgYC5cbiAqICAgRGVmYXVsdDogTm8gZXhjbHVkZWQgaW5zdGFuY2UgdHlwZXNcbiAqL1xuRXhjbHVkZWRJbnN0YW5jZVR5cGVzPzogc3RyaW5nW11cbi8qKlxuICogVGhlIGluc3RhbmNlIHR5cGVzIHRvIGFwcGx5IHlvdXIgc3BlY2lmaWVkIGF0dHJpYnV0ZXMgYWdhaW5zdC4gQWxsIG90aGVyIGluc3RhbmNlIHR5cGVzIGFyZSBpZ25vcmVkLCBldmVuIGlmIHRoZXkgbWF0Y2ggeW91ciBzcGVjaWZpZWQgYXR0cmlidXRlcy5cbiAqICBZb3UgY2FuIHVzZSBzdHJpbmdzIHdpdGggb25lIG9yIG1vcmUgd2lsZCBjYXJkcywgcmVwcmVzZW50ZWQgYnkgYW4gYXN0ZXJpc2sgKGBgKmBgKSwgdG8gYWxsb3cgYW4gaW5zdGFuY2UgdHlwZSwgc2l6ZSwgb3IgZ2VuZXJhdGlvbi4gVGhlIGZvbGxvd2luZyBhcmUgZXhhbXBsZXM6IGBgbTUuOHhsYXJnZWBgLCBgYGM1Ki4qYGAsIGBgbTVhLipgYCwgYGByKmBgLCBgYCozKmBgLlxuICogIEZvciBleGFtcGxlLCBpZiB5b3Ugc3BlY2lmeSBgYGM1KmBgLCBBbWF6b24gRUMyIEF1dG8gU2NhbGluZyB3aWxsIGFsbG93IHRoZSBlbnRpcmUgQzUgaW5zdGFuY2UgZmFtaWx5LCB3aGljaCBpbmNsdWRlcyBhbGwgQzVhIGFuZCBDNW4gaW5zdGFuY2UgdHlwZXMuIElmIHlvdSBzcGVjaWZ5IGBgbTVhLipgYCwgQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgd2lsbCBhbGxvdyBhbGwgdGhlIE01YSBpbnN0YW5jZSB0eXBlcywgYnV0IG5vdCB0aGUgTTVuIGluc3RhbmNlIHR5cGVzLlxuICogICBJZiB5b3Ugc3BlY2lmeSBgYEFsbG93ZWRJbnN0YW5jZVR5cGVzYGAsIHlvdSBjYW4ndCBzcGVjaWZ5IGBgRXhjbHVkZWRJbnN0YW5jZVR5cGVzYGAuXG4gKiAgIERlZmF1bHQ6IEFsbCBpbnN0YW5jZSB0eXBlc1xuICovXG5BbGxvd2VkSW5zdGFuY2VUeXBlcz86IHN0cmluZ1tdXG5BY2NlbGVyYXRvckNvdW50PzogQWNjZWxlcmF0b3JDb3VudFJlcXVlc3Rcbk5ldHdvcmtCYW5kd2lkdGhHYnBzPzogTmV0d29ya0JhbmR3aWR0aEdicHNSZXF1ZXN0XG5CYXNlbGluZVBlcmZvcm1hbmNlRmFjdG9ycz86IEJhc2VsaW5lUGVyZm9ybWFuY2VGYWN0b3JzUmVxdWVzdFxuQmFzZWxpbmVFYnNCYW5kd2lkdGhNYnBzPzogQmFzZWxpbmVFYnNCYW5kd2lkdGhNYnBzUmVxdWVzdFxuLyoqXG4gKiBbUHJpY2UgcHJvdGVjdGlvbl0gVGhlIHByaWNlIHByb3RlY3Rpb24gdGhyZXNob2xkIGZvciBTcG90IEluc3RhbmNlcywgYXMgYSBwZXJjZW50YWdlIGhpZ2hlciB0aGFuIGFuIGlkZW50aWZpZWQgU3BvdCBwcmljZS4gVGhlIGlkZW50aWZpZWQgU3BvdCBwcmljZSBpcyB0aGUgcHJpY2Ugb2YgdGhlIGxvd2VzdCBwcmljZWQgY3VycmVudCBnZW5lcmF0aW9uIEMsIE0sIG9yIFIgaW5zdGFuY2UgdHlwZSB3aXRoIHlvdXIgc3BlY2lmaWVkIGF0dHJpYnV0ZXMuIElmIG5vIGN1cnJlbnQgZ2VuZXJhdGlvbiBDLCBNLCBvciBSIGluc3RhbmNlIHR5cGUgbWF0Y2hlcyB5b3VyIGF0dHJpYnV0ZXMsIHRoZW4gdGhlIGlkZW50aWZpZWQgcHJpY2UgaXMgZnJvbSBlaXRoZXIgdGhlIGxvd2VzdCBwcmljZWQgY3VycmVudCBnZW5lcmF0aW9uIGluc3RhbmNlIHR5cGVzIG9yLCBmYWlsaW5nIHRoYXQsIHRoZSBsb3dlc3QgcHJpY2VkIHByZXZpb3VzIGdlbmVyYXRpb24gaW5zdGFuY2UgdHlwZXMgdGhhdCBtYXRjaCB5b3VyIGF0dHJpYnV0ZXMuIFdoZW4gQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgc2VsZWN0cyBpbnN0YW5jZSB0eXBlcyB3aXRoIHlvdXIgYXR0cmlidXRlcywgd2Ugd2lsbCBleGNsdWRlIGluc3RhbmNlIHR5cGVzIHdob3NlIHByaWNlIGV4Y2VlZHMgeW91ciBzcGVjaWZpZWQgdGhyZXNob2xkLlxuICogIFRoZSBwYXJhbWV0ZXIgYWNjZXB0cyBhbiBpbnRlZ2VyLCB3aGljaCBBbWF6b24gRUMyIEF1dG8gU2NhbGluZyBpbnRlcnByZXRzIGFzIGEgcGVyY2VudGFnZS4gXG4gKiAgSWYgeW91IHNldCBgYERlc2lyZWRDYXBhY2l0eVR5cGVgYCB0byBgYHZjcHVgYCBvciBgYG1lbW9yeS1taWJgYCwgdGhlIHByaWNlIHByb3RlY3Rpb24gdGhyZXNob2xkIGlzIGJhc2VkIG9uIHRoZSBwZXItdkNQVSBvciBwZXItbWVtb3J5IHByaWNlIGluc3RlYWQgb2YgdGhlIHBlciBpbnN0YW5jZSBwcmljZS4gXG4gKiAgIE9ubHkgb25lIG9mIGBgU3BvdE1heFByaWNlUGVyY2VudGFnZU92ZXJMb3dlc3RQcmljZWBgIG9yIGBgTWF4U3BvdFByaWNlQXNQZXJjZW50YWdlT2ZPcHRpbWFsT25EZW1hbmRQcmljZWBgIGNhbiBiZSBzcGVjaWZpZWQuIElmIHlvdSBkb24ndCBzcGVjaWZ5IGVpdGhlciwgQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgd2lsbCBhdXRvbWF0aWNhbGx5IGFwcGx5IG9wdGltYWwgcHJpY2UgcHJvdGVjdGlvbiB0byBjb25zaXN0ZW50bHkgc2VsZWN0IGZyb20gYSB3aWRlIHJhbmdlIG9mIGluc3RhbmNlIHR5cGVzLiBUbyBpbmRpY2F0ZSBubyBwcmljZSBwcm90ZWN0aW9uIHRocmVzaG9sZCBmb3IgU3BvdCBJbnN0YW5jZXMsIG1lYW5pbmcgeW91IHdhbnQgdG8gY29uc2lkZXIgYWxsIGluc3RhbmNlIHR5cGVzIHRoYXQgbWF0Y2ggeW91ciBhdHRyaWJ1dGVzLCBpbmNsdWRlIG9uZSBvZiB0aGVzZSBwYXJhbWV0ZXJzIGFuZCBzcGVjaWZ5IGEgaGlnaCB2YWx1ZSwgc3VjaCBhcyBgYDk5OTk5OWBgLlxuICovXG5TcG90TWF4UHJpY2VQZXJjZW50YWdlT3Zlckxvd2VzdFByaWNlPzogbnVtYmVyXG4vKipcbiAqIExpc3RzIHRoZSBhY2NlbGVyYXRvcnMgdGhhdCBtdXN0IGJlIG9uIGFuIGluc3RhbmNlIHR5cGUuXG4gKiAgICsgIEZvciBpbnN0YW5jZSB0eXBlcyB3aXRoIE5WSURJQSBBMTAwIEdQVXMsIHNwZWNpZnkgYGBhMTAwYGAuXG4gKiAgICsgIEZvciBpbnN0YW5jZSB0eXBlcyB3aXRoIE5WSURJQSBWMTAwIEdQVXMsIHNwZWNpZnkgYGB2MTAwYGAuXG4gKiAgICsgIEZvciBpbnN0YW5jZSB0eXBlcyB3aXRoIE5WSURJQSBLODAgR1BVcywgc3BlY2lmeSBgYGs4MGBgLlxuICogICArICBGb3IgaW5zdGFuY2UgdHlwZXMgd2l0aCBOVklESUEgVDQgR1BVcywgc3BlY2lmeSBgYHQ0YGAuXG4gKiAgICsgIEZvciBpbnN0YW5jZSB0eXBlcyB3aXRoIE5WSURJQSBNNjAgR1BVcywgc3BlY2lmeSBgYG02MGBgLlxuICogICArICBGb3IgaW5zdGFuY2UgdHlwZXMgd2l0aCBBTUQgUmFkZW9uIFBybyBWNTIwIEdQVXMsIHNwZWNpZnkgYGByYWRlb24tcHJvLXY1MjBgYC5cbiAqICAgKyAgRm9yIGluc3RhbmNlIHR5cGVzIHdpdGggWGlsaW54IFZVOVAgRlBHQXMsIHNwZWNpZnkgYGB2dTlwYGAuXG4gKiAgIFxuICogIERlZmF1bHQ6IEFueSBhY2NlbGVyYXRvclxuICovXG5BY2NlbGVyYXRvck5hbWVzPzogc3RyaW5nW11cbkFjY2VsZXJhdG9yVG90YWxNZW1vcnlNaUI/OiBBY2NlbGVyYXRvclRvdGFsTWVtb3J5TWlCUmVxdWVzdFxuLyoqXG4gKiBJbmRpY2F0ZXMgd2hldGhlciBidXJzdGFibGUgcGVyZm9ybWFuY2UgaW5zdGFuY2UgdHlwZXMgYXJlIGluY2x1ZGVkLCBleGNsdWRlZCwgb3IgcmVxdWlyZWQuIEZvciBtb3JlIGluZm9ybWF0aW9uLCBzZWUgW0J1cnN0YWJsZSBwZXJmb3JtYW5jZSBpbnN0YW5jZXNdKGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9BV1NFQzIvbGF0ZXN0L1VzZXJHdWlkZS9idXJzdGFibGUtcGVyZm9ybWFuY2UtaW5zdGFuY2VzLmh0bWwpIGluIHRoZSAqQW1hem9uIEVDMiBVc2VyIEd1aWRlIGZvciBMaW51eCBJbnN0YW5jZXMqLlxuICogIERlZmF1bHQ6IGBgZXhjbHVkZWRgYFxuICovXG5CdXJzdGFibGVQZXJmb3JtYW5jZT86IHN0cmluZ1xuVG90YWxMb2NhbFN0b3JhZ2VHQj86IFRvdGFsTG9jYWxTdG9yYWdlR0JSZXF1ZXN0XG59XG4vKipcbiAqIFRoZSBtaW5pbXVtIGFuZCBtYXhpbXVtIGFtb3VudCBvZiBtZW1vcnkgcGVyIHZDUFUgZm9yIGFuIGluc3RhbmNlIHR5cGUsIGluIEdpQi5cbiAqICBEZWZhdWx0OiBObyBtaW5pbXVtIG9yIG1heGltdW0gbGltaXRzXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgTWVtb3J5R2lCUGVyVkNwdVJlcXVlc3Qge1xuLyoqXG4gKiBUaGUgbWVtb3J5IG1pbmltdW0gaW4gR2lCLlxuICovXG5NaW4/OiBudW1iZXJcbi8qKlxuICogVGhlIG1lbW9yeSBtYXhpbXVtIGluIEdpQi5cbiAqL1xuTWF4PzogbnVtYmVyXG59XG4vKipcbiAqIFRoZSBtaW5pbXVtIGFuZCBtYXhpbXVtIG51bWJlciBvZiB2Q1BVcyBmb3IgYW4gaW5zdGFuY2UgdHlwZS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBWQ3B1Q291bnRSZXF1ZXN0IHtcbi8qKlxuICogVGhlIG1pbmltdW0gbnVtYmVyIG9mIHZDUFVzLlxuICovXG5NaW4/OiBudW1iZXJcbi8qKlxuICogVGhlIG1heGltdW0gbnVtYmVyIG9mIHZDUFVzLlxuICovXG5NYXg/OiBudW1iZXJcbn1cbi8qKlxuICogVGhlIG1pbmltdW0gYW5kIG1heGltdW0gaW5zdGFuY2UgbWVtb3J5IHNpemUgZm9yIGFuIGluc3RhbmNlIHR5cGUsIGluIE1pQi5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBNZW1vcnlNaUJSZXF1ZXN0IHtcbi8qKlxuICogVGhlIG1lbW9yeSBtaW5pbXVtIGluIE1pQi5cbiAqL1xuTWluPzogbnVtYmVyXG4vKipcbiAqIFRoZSBtZW1vcnkgbWF4aW11bSBpbiBNaUIuXG4gKi9cbk1heD86IG51bWJlclxufVxuLyoqXG4gKiBUaGUgbWluaW11bSBhbmQgbWF4aW11bSBudW1iZXIgb2YgbmV0d29yayBpbnRlcmZhY2VzIGZvciBhbiBpbnN0YW5jZSB0eXBlLlxuICogIERlZmF1bHQ6IE5vIG1pbmltdW0gb3IgbWF4aW11bSBsaW1pdHNcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBOZXR3b3JrSW50ZXJmYWNlQ291bnRSZXF1ZXN0IHtcbi8qKlxuICogVGhlIG1pbmltdW0gbnVtYmVyIG9mIG5ldHdvcmsgaW50ZXJmYWNlcy5cbiAqL1xuTWluPzogbnVtYmVyXG4vKipcbiAqIFRoZSBtYXhpbXVtIG51bWJlciBvZiBuZXR3b3JrIGludGVyZmFjZXMuXG4gKi9cbk1heD86IG51bWJlclxufVxuLyoqXG4gKiBUaGUgbWluaW11bSBhbmQgbWF4aW11bSBudW1iZXIgb2YgYWNjZWxlcmF0b3JzIChHUFVzLCBGUEdBcywgb3IgQVdTIEluZmVyZW50aWEgY2hpcHMpIGZvciBhbiBpbnN0YW5jZSB0eXBlLlxuICogIFRvIGV4Y2x1ZGUgYWNjZWxlcmF0b3ItZW5hYmxlZCBpbnN0YW5jZSB0eXBlcywgc2V0IGBgTWF4YGAgdG8gYGAwYGAuXG4gKiAgRGVmYXVsdDogTm8gbWluaW11bSBvciBtYXhpbXVtIGxpbWl0c1xuICovXG5leHBvcnQgaW50ZXJmYWNlIEFjY2VsZXJhdG9yQ291bnRSZXF1ZXN0IHtcbi8qKlxuICogVGhlIG1pbmltdW0gdmFsdWUuXG4gKi9cbk1pbj86IG51bWJlclxuLyoqXG4gKiBUaGUgbWF4aW11bSB2YWx1ZS5cbiAqL1xuTWF4PzogbnVtYmVyXG59XG4vKipcbiAqIFRoZSBtaW5pbXVtIGFuZCBtYXhpbXVtIGFtb3VudCBvZiBuZXR3b3JrIGJhbmR3aWR0aCwgaW4gZ2lnYWJpdHMgcGVyIHNlY29uZCAoR2JwcykuXG4gKiAgRGVmYXVsdDogTm8gbWluaW11bSBvciBtYXhpbXVtIGxpbWl0c1xuICovXG5leHBvcnQgaW50ZXJmYWNlIE5ldHdvcmtCYW5kd2lkdGhHYnBzUmVxdWVzdCB7XG4vKipcbiAqIFRoZSBtaW5pbXVtIGFtb3VudCBvZiBuZXR3b3JrIGJhbmR3aWR0aCwgaW4gZ2lnYWJpdHMgcGVyIHNlY29uZCAoR2JwcykuXG4gKi9cbk1pbj86IG51bWJlclxuLyoqXG4gKiBUaGUgbWF4aW11bSBhbW91bnQgb2YgbmV0d29yayBiYW5kd2lkdGgsIGluIGdpZ2FiaXRzIHBlciBzZWNvbmQgKEdicHMpLlxuICovXG5NYXg/OiBudW1iZXJcbn1cbmV4cG9ydCBpbnRlcmZhY2UgQmFzZWxpbmVQZXJmb3JtYW5jZUZhY3RvcnNSZXF1ZXN0IHtcbkNwdT86IENwdVBlcmZvcm1hbmNlRmFjdG9yUmVxdWVzdFxufVxuZXhwb3J0IGludGVyZmFjZSBDcHVQZXJmb3JtYW5jZUZhY3RvclJlcXVlc3Qge1xuUmVmZXJlbmNlcz86IFBlcmZvcm1hbmNlRmFjdG9yUmVmZXJlbmNlU2V0UmVxdWVzdFxufVxuZXhwb3J0IGludGVyZmFjZSBQZXJmb3JtYW5jZUZhY3RvclJlZmVyZW5jZVJlcXVlc3Qge1xuSW5zdGFuY2VGYW1pbHk/OiBzdHJpbmdcbn1cbi8qKlxuICogVGhlIG1pbmltdW0gYW5kIG1heGltdW0gYmFzZWxpbmUgYmFuZHdpZHRoIHBlcmZvcm1hbmNlIGZvciBhbiBpbnN0YW5jZSB0eXBlLCBpbiBNYnBzLiBGb3IgbW9yZSBpbmZvcm1hdGlvbiwgc2VlIFtBbWF6b24gRUJT4oCTb3B0aW1pemVkIGluc3RhbmNlc10oaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL0FXU0VDMi9sYXRlc3QvVXNlckd1aWRlL2Vicy1vcHRpbWl6ZWQuaHRtbCkgaW4gdGhlICpBbWF6b24gRUMyIFVzZXIgR3VpZGUgZm9yIExpbnV4IEluc3RhbmNlcyouXG4gKiAgRGVmYXVsdDogTm8gbWluaW11bSBvciBtYXhpbXVtIGxpbWl0c1xuICovXG5leHBvcnQgaW50ZXJmYWNlIEJhc2VsaW5lRWJzQmFuZHdpZHRoTWJwc1JlcXVlc3Qge1xuLyoqXG4gKiBUaGUgbWluaW11bSB2YWx1ZSBpbiBNYnBzLlxuICovXG5NaW4/OiBudW1iZXJcbi8qKlxuICogVGhlIG1heGltdW0gdmFsdWUgaW4gTWJwcy5cbiAqL1xuTWF4PzogbnVtYmVyXG59XG4vKipcbiAqIFRoZSBtaW5pbXVtIGFuZCBtYXhpbXVtIHRvdGFsIG1lbW9yeSBzaXplIGZvciB0aGUgYWNjZWxlcmF0b3JzIG9uIGFuIGluc3RhbmNlIHR5cGUsIGluIE1pQi5cbiAqICBEZWZhdWx0OiBObyBtaW5pbXVtIG9yIG1heGltdW0gbGltaXRzXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQWNjZWxlcmF0b3JUb3RhbE1lbW9yeU1pQlJlcXVlc3Qge1xuLyoqXG4gKiBUaGUgbWVtb3J5IG1pbmltdW0gaW4gTWlCLlxuICovXG5NaW4/OiBudW1iZXJcbi8qKlxuICogVGhlIG1lbW9yeSBtYXhpbXVtIGluIE1pQi5cbiAqL1xuTWF4PzogbnVtYmVyXG59XG4vKipcbiAqIFRoZSBtaW5pbXVtIGFuZCBtYXhpbXVtIHRvdGFsIGxvY2FsIHN0b3JhZ2Ugc2l6ZSBmb3IgYW4gaW5zdGFuY2UgdHlwZSwgaW4gR0IuXG4gKiAgRGVmYXVsdDogTm8gbWluaW11bSBvciBtYXhpbXVtIGxpbWl0c1xuICovXG5leHBvcnQgaW50ZXJmYWNlIFRvdGFsTG9jYWxTdG9yYWdlR0JSZXF1ZXN0IHtcbi8qKlxuICogVGhlIHN0b3JhZ2UgbWluaW11bSBpbiBHQi5cbiAqL1xuTWluPzogbnVtYmVyXG4vKipcbiAqIFRoZSBzdG9yYWdlIG1heGltdW0gaW4gR0IuXG4gKi9cbk1heD86IG51bWJlclxufVxuLyoqXG4gKiBBIHN0cnVjdHVyZSB0aGF0IHNwZWNpZmllcyBhIHRhZyBmb3IgdGhlIGBgVGFnc2BgIHByb3BlcnR5IG9mIFtBV1M6OkF1dG9TY2FsaW5nOjpBdXRvU2NhbGluZ0dyb3VwXShodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vQVdTQ2xvdWRGb3JtYXRpb24vbGF0ZXN0L1VzZXJHdWlkZS9hd3MtcmVzb3VyY2UtYXV0b3NjYWxpbmctYXV0b3NjYWxpbmdncm91cC5odG1sKSByZXNvdXJjZS5cbiAqICBGb3IgbW9yZSBpbmZvcm1hdGlvbiwgc2VlIFtUYWcgQXV0byBTY2FsaW5nIGdyb3VwcyBhbmQgaW5zdGFuY2VzXShodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vYXV0b3NjYWxpbmcvZWMyL3VzZXJndWlkZS9hdXRvc2NhbGluZy10YWdnaW5nLmh0bWwpIGluIHRoZSAqQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgVXNlciBHdWlkZSouIFlvdSBjYW4gZmluZCBhIHNhbXBsZSB0ZW1wbGF0ZSBzbmlwcGV0IGluIHRoZSBbRXhhbXBsZXNdKGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9BV1NDbG91ZEZvcm1hdGlvbi9sYXRlc3QvVXNlckd1aWRlL2F3cy1yZXNvdXJjZS1hdXRvc2NhbGluZy1hdXRvc2NhbGluZ2dyb3VwLmh0bWwjYXdzLXJlc291cmNlLWF1dG9zY2FsaW5nLWF1dG9zY2FsaW5nZ3JvdXAtLWV4YW1wbGVzKSBzZWN0aW9uIG9mIHRoZSBgYEFXUzo6QXV0b1NjYWxpbmc6OkF1dG9TY2FsaW5nR3JvdXBgYCByZXNvdXJjZS5cbiAqICBDbG91ZEZvcm1hdGlvbiBhZGRzIHRoZSBmb2xsb3dpbmcgdGFncyB0byBhbGwgQXV0byBTY2FsaW5nIGdyb3VwcyBhbmQgYXNzb2NpYXRlZCBpbnN0YW5jZXM6IFxuICogICArICBhd3M6Y2xvdWRmb3JtYXRpb246c3RhY2stbmFtZVxuICogICArICBhd3M6Y2xvdWRmb3JtYXRpb246c3RhY2staWRcbiAqICAgKyAgYXdzOmNsb3VkZm9ybWF0aW9uOmxvZ2ljYWwtaWRcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBUYWdQcm9wZXJ0eSB7XG4vKipcbiAqIFRoZSB0YWcgdmFsdWUuXG4gKi9cblZhbHVlOiBzdHJpbmdcbi8qKlxuICogVGhlIHRhZyBrZXkuXG4gKi9cbktleTogc3RyaW5nXG4vKipcbiAqIFNldCB0byBgYHRydWVgYCBpZiB5b3Ugd2FudCBDbG91ZEZvcm1hdGlvbiB0byBjb3B5IHRoZSB0YWcgdG8gRUMyIGluc3RhbmNlcyB0aGF0IGFyZSBsYXVuY2hlZCBhcyBwYXJ0IG9mIHRoZSBBdXRvIFNjYWxpbmcgZ3JvdXAuIFNldCB0byBgYGZhbHNlYGAgaWYgeW91IHdhbnQgdGhlIHRhZyBhdHRhY2hlZCBvbmx5IHRvIHRoZSBBdXRvIFNjYWxpbmcgZ3JvdXAgYW5kIG5vdCBjb3BpZWQgdG8gYW55IGluc3RhbmNlcyBsYXVuY2hlZCBhcyBwYXJ0IG9mIHRoZSBBdXRvIFNjYWxpbmcgZ3JvdXAuXG4gKi9cblByb3BhZ2F0ZUF0TGF1bmNoOiBib29sZWFuXG59XG4vKipcbiAqIEEgc3RydWN0dXJlIHRoYXQgc3BlY2lmaWVzIGFuIEFtYXpvbiBTTlMgbm90aWZpY2F0aW9uIGNvbmZpZ3VyYXRpb24gZm9yIHRoZSBgYE5vdGlmaWNhdGlvbkNvbmZpZ3VyYXRpb25zYGAgcHJvcGVydHkgb2YgdGhlIFtBV1M6OkF1dG9TY2FsaW5nOjpBdXRvU2NhbGluZ0dyb3VwXShodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vQVdTQ2xvdWRGb3JtYXRpb24vbGF0ZXN0L1VzZXJHdWlkZS9hd3MtcmVzb3VyY2UtYXV0b3NjYWxpbmctYXV0b3NjYWxpbmdncm91cC5odG1sKSByZXNvdXJjZS5cbiAqICBGb3IgYW4gZXhhbXBsZSB0ZW1wbGF0ZSBzbmlwcGV0LCBzZWUgW0NvbmZpZ3VyZSBBbWF6b24gRUMyIEF1dG8gU2NhbGluZyByZXNvdXJjZXNdKGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9BV1NDbG91ZEZvcm1hdGlvbi9sYXRlc3QvVXNlckd1aWRlL3F1aWNrcmVmLWVjMi1hdXRvLXNjYWxpbmcuaHRtbCkuXG4gKiAgRm9yIG1vcmUgaW5mb3JtYXRpb24sIHNlZSBbR2V0IEFtYXpvbiBTTlMgbm90aWZpY2F0aW9ucyB3aGVuIHlvdXIgQXV0byBTY2FsaW5nIGdyb3VwIHNjYWxlc10oaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL2F1dG9zY2FsaW5nL2VjMi91c2VyZ3VpZGUvQVNHZXR0aW5nTm90aWZpY2F0aW9ucy5odG1sKSBpbiB0aGUgKkFtYXpvbiBFQzIgQXV0byBTY2FsaW5nIFVzZXIgR3VpZGUqLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIE5vdGlmaWNhdGlvbkNvbmZpZ3VyYXRpb24xIHtcbi8qKlxuICogVGhlIEFtYXpvbiBSZXNvdXJjZSBOYW1lIChBUk4pIG9mIHRoZSBBbWF6b24gU05TIHRvcGljLlxuICovXG5Ub3BpY0FSTjogKHN0cmluZyB8IHN0cmluZ1tdKVxuLyoqXG4gKiBBIGxpc3Qgb2YgZXZlbnQgdHlwZXMgdGhhdCBzZW5kIGEgbm90aWZpY2F0aW9uLiBFdmVudCB0eXBlcyBjYW4gaW5jbHVkZSBhbnkgb2YgdGhlIGZvbGxvd2luZyB0eXBlcy4gXG4gKiAgICpBbGxvd2VkIHZhbHVlcyo6XG4gKiAgICsgICBgYGF1dG9zY2FsaW5nOkVDMl9JTlNUQU5DRV9MQVVOQ0hgYCBcbiAqICAgKyAgIGBgYXV0b3NjYWxpbmc6RUMyX0lOU1RBTkNFX0xBVU5DSF9FUlJPUmBgIFxuICogICArICAgYGBhdXRvc2NhbGluZzpFQzJfSU5TVEFOQ0VfVEVSTUlOQVRFYGAgXG4gKiAgICsgICBgYGF1dG9zY2FsaW5nOkVDMl9JTlNUQU5DRV9URVJNSU5BVEVfRVJST1JgYCBcbiAqICAgKyAgIGBgYXV0b3NjYWxpbmc6VEVTVF9OT1RJRklDQVRJT05gYFxuICovXG5Ob3RpZmljYXRpb25UeXBlcz86IHN0cmluZ1tdXG59XG4vKipcbiAqIFRoZSBpbnN0YW5jZSBjYXBhY2l0eSBkaXN0cmlidXRpb24gYWNyb3NzIEF2YWlsYWJpbGl0eSBab25lcy5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBBdmFpbGFiaWxpdHlab25lRGlzdHJpYnV0aW9uIHtcbi8qKlxuICogSWYgbGF1bmNoZXMgZmFpbCBpbiBhbiBBdmFpbGFiaWxpdHkgWm9uZSwgdGhlIGZvbGxvd2luZyBzdHJhdGVnaWVzIGFyZSBhdmFpbGFibGUuIFRoZSBkZWZhdWx0IGlzIGBgYmFsYW5jZWQtYmVzdC1lZmZvcnRgYC4gXG4gKiAgICsgICBgYGJhbGFuY2VkLW9ubHlgYCAtIElmIGxhdW5jaGVzIGZhaWwgaW4gYW4gQXZhaWxhYmlsaXR5IFpvbmUsIEF1dG8gU2NhbGluZyB3aWxsIGNvbnRpbnVlIHRvIGF0dGVtcHQgdG8gbGF1bmNoIGluIHRoZSB1bmhlYWx0aHkgem9uZSB0byBwcmVzZXJ2ZSBhIGJhbGFuY2VkIGRpc3RyaWJ1dGlvbi5cbiAqICAgKyAgIGBgYmFsYW5jZWQtYmVzdC1lZmZvcnRgYCAtIElmIGxhdW5jaGVzIGZhaWwgaW4gYW4gQXZhaWxhYmlsaXR5IFpvbmUsIEF1dG8gU2NhbGluZyB3aWxsIGF0dGVtcHQgdG8gbGF1bmNoIGluIGFub3RoZXIgaGVhbHRoeSBBdmFpbGFiaWxpdHkgWm9uZSBpbnN0ZWFkLlxuICovXG5DYXBhY2l0eURpc3RyaWJ1dGlvblN0cmF0ZWd5PzogKFwiYmFsYW5jZWQtYmVzdC1lZmZvcnRcIiB8IFwiYmFsYW5jZWQtb25seVwiKVxufVxuLyoqXG4gKiBgYE1ldHJpY3NDb2xsZWN0aW9uYGAgaXMgYSBwcm9wZXJ0eSBvZiB0aGUgW0FXUzo6QXV0b1NjYWxpbmc6OkF1dG9TY2FsaW5nR3JvdXBdKGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9BV1NDbG91ZEZvcm1hdGlvbi9sYXRlc3QvVXNlckd1aWRlL2F3cy1yZXNvdXJjZS1hdXRvc2NhbGluZy1hdXRvc2NhbGluZ2dyb3VwLmh0bWwpIHJlc291cmNlIHRoYXQgZGVzY3JpYmVzIHRoZSBncm91cCBtZXRyaWNzIHRoYXQgYW4gQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgZ3JvdXAgc2VuZHMgdG8gQW1hem9uIENsb3VkV2F0Y2guIFRoZXNlIG1ldHJpY3MgZGVzY3JpYmUgdGhlIGdyb3VwIHJhdGhlciB0aGFuIGFueSBvZiBpdHMgaW5zdGFuY2VzLiBcbiAqICBGb3IgbW9yZSBpbmZvcm1hdGlvbiwgc2VlIFtNb25pdG9yIENsb3VkV2F0Y2ggbWV0cmljcyBmb3IgeW91ciBBdXRvIFNjYWxpbmcgZ3JvdXBzIGFuZCBpbnN0YW5jZXNdKGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9hdXRvc2NhbGluZy9lYzIvdXNlcmd1aWRlL2FzLWluc3RhbmNlLW1vbml0b3JpbmcuaHRtbCkgaW4gdGhlICpBbWF6b24gRUMyIEF1dG8gU2NhbGluZyBVc2VyIEd1aWRlKi4gWW91IGNhbiBmaW5kIGEgc2FtcGxlIHRlbXBsYXRlIHNuaXBwZXQgaW4gdGhlIFtFeGFtcGxlc10oaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL0FXU0Nsb3VkRm9ybWF0aW9uL2xhdGVzdC9Vc2VyR3VpZGUvYXdzLXJlc291cmNlLWF1dG9zY2FsaW5nLWF1dG9zY2FsaW5nZ3JvdXAuaHRtbCNhd3MtcmVzb3VyY2UtYXV0b3NjYWxpbmctYXV0b3NjYWxpbmdncm91cC0tZXhhbXBsZXMpIHNlY3Rpb24gb2YgdGhlIGBgQVdTOjpBdXRvU2NhbGluZzo6QXV0b1NjYWxpbmdHcm91cGBgIHJlc291cmNlLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIE1ldHJpY3NDb2xsZWN0aW9uIHtcbi8qKlxuICogSWRlbnRpZmllcyB0aGUgbWV0cmljcyB0byBlbmFibGUuXG4gKiAgWW91IGNhbiBzcGVjaWZ5IG9uZSBvciBtb3JlIG9mIHRoZSBmb2xsb3dpbmcgbWV0cmljczpcbiAqICAgKyAgIGBgR3JvdXBNaW5TaXplYGAgXG4gKiAgICsgICBgYEdyb3VwTWF4U2l6ZWBgIFxuICogICArICAgYGBHcm91cERlc2lyZWRDYXBhY2l0eWBgIFxuICogICArICAgYGBHcm91cEluU2VydmljZUluc3RhbmNlc2BgIFxuICogICArICAgYGBHcm91cFBlbmRpbmdJbnN0YW5jZXNgYCBcbiAqICAgKyAgIGBgR3JvdXBTdGFuZGJ5SW5zdGFuY2VzYGAgXG4gKiAgICsgICBgYEdyb3VwVGVybWluYXRpbmdJbnN0YW5jZXNgYCBcbiAqICAgKyAgIGBgR3JvdXBUb3RhbEluc3RhbmNlc2BgIFxuICogICArICAgYGBHcm91cEluU2VydmljZUNhcGFjaXR5YGAgXG4gKiAgICsgICBgYEdyb3VwUGVuZGluZ0NhcGFjaXR5YGAgXG4gKiAgICsgICBgYEdyb3VwU3RhbmRieUNhcGFjaXR5YGAgXG4gKiAgICsgICBgYEdyb3VwVGVybWluYXRpbmdDYXBhY2l0eWBgIFxuICogICArICAgYGBHcm91cFRvdGFsQ2FwYWNpdHlgYCBcbiAqICAgKyAgIGBgV2FybVBvb2xEZXNpcmVkQ2FwYWNpdHlgYCBcbiAqICAgKyAgIGBgV2FybVBvb2xXYXJtZWRDYXBhY2l0eWBgIFxuICogICArICAgYGBXYXJtUG9vbFBlbmRpbmdDYXBhY2l0eWBgIFxuICogICArICAgYGBXYXJtUG9vbFRlcm1pbmF0aW5nQ2FwYWNpdHlgYCBcbiAqICAgKyAgIGBgV2FybVBvb2xUb3RhbENhcGFjaXR5YGAgXG4gKiAgICsgICBgYEdyb3VwQW5kV2FybVBvb2xEZXNpcmVkQ2FwYWNpdHlgYCBcbiAqICAgKyAgIGBgR3JvdXBBbmRXYXJtUG9vbFRvdGFsQ2FwYWNpdHlgYCBcbiAqICAgXG4gKiAgSWYgeW91IHNwZWNpZnkgYGBHcmFudWxhcml0eWBgIGFuZCBkb24ndCBzcGVjaWZ5IGFueSBtZXRyaWNzLCBhbGwgbWV0cmljcyBhcmUgZW5hYmxlZC5cbiAqICBGb3IgbW9yZSBpbmZvcm1hdGlvbiwgc2VlIFtBbWF6b24gQ2xvdWRXYXRjaCBtZXRyaWNzIGZvciBBbWF6b24gRUMyIEF1dG8gU2NhbGluZ10oaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL2F1dG9zY2FsaW5nL2VjMi91c2VyZ3VpZGUvZWMyLWF1dG8tc2NhbGluZy1tZXRyaWNzLmh0bWwpIGluIHRoZSAqQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgVXNlciBHdWlkZSouXG4gKi9cbk1ldHJpY3M/OiBzdHJpbmdbXVxuLyoqXG4gKiBUaGUgZnJlcXVlbmN5IGF0IHdoaWNoIEFtYXpvbiBFQzIgQXV0byBTY2FsaW5nIHNlbmRzIGFnZ3JlZ2F0ZWQgZGF0YSB0byBDbG91ZFdhdGNoLiBUaGUgb25seSB2YWxpZCB2YWx1ZSBpcyBgYDFNaW51dGVgYC5cbiAqL1xuR3JhbnVsYXJpdHk6IHN0cmluZ1xufVxuLyoqXG4gKiBBbiBpbnN0YW5jZSBtYWludGVuYW5jZSBwb2xpY3kuIEZvciBtb3JlIGluZm9ybWF0aW9uLCBzZWUgW1NldCBpbnN0YW5jZSBtYWludGVuYW5jZSBwb2xpY3ldKGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9hdXRvc2NhbGluZy9lYzIvdXNlcmd1aWRlL2VjMi1hdXRvLXNjYWxpbmctaW5zdGFuY2UtbWFpbnRlbmFuY2UtcG9saWN5Lmh0bWwpIGluIHRoZSAqQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgVXNlciBHdWlkZSouXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgSW5zdGFuY2VNYWludGVuYW5jZVBvbGljeSB7XG4vKipcbiAqIFNwZWNpZmllcyB0aGUgdXBwZXIgdGhyZXNob2xkIGFzIGEgcGVyY2VudGFnZSBvZiB0aGUgZGVzaXJlZCBjYXBhY2l0eSBvZiB0aGUgQXV0byBTY2FsaW5nIGdyb3VwLiBJdCByZXByZXNlbnRzIHRoZSBtYXhpbXVtIHBlcmNlbnRhZ2Ugb2YgdGhlIGdyb3VwIHRoYXQgY2FuIGJlIGluIHNlcnZpY2UgYW5kIGhlYWx0aHksIG9yIHBlbmRpbmcsIHRvIHN1cHBvcnQgeW91ciB3b3JrbG9hZCB3aGVuIHJlcGxhY2luZyBpbnN0YW5jZXMuIFZhbHVlIHJhbmdlIGlzIDEwMCB0byAyMDAuIFRvIGNsZWFyIGEgcHJldmlvdXNseSBzZXQgdmFsdWUsIHNwZWNpZnkgYSB2YWx1ZSBvZiBgYC0xYGAuXG4gKiAgQm90aCBgYE1pbkhlYWx0aHlQZXJjZW50YWdlYGAgYW5kIGBgTWF4SGVhbHRoeVBlcmNlbnRhZ2VgYCBtdXN0IGJlIHNwZWNpZmllZCwgYW5kIHRoZSBkaWZmZXJlbmNlIGJldHdlZW4gdGhlbSBjYW5ub3QgYmUgZ3JlYXRlciB0aGFuIDEwMC4gQSBsYXJnZSByYW5nZSBpbmNyZWFzZXMgdGhlIG51bWJlciBvZiBpbnN0YW5jZXMgdGhhdCBjYW4gYmUgcmVwbGFjZWQgYXQgdGhlIHNhbWUgdGltZS5cbiAqL1xuTWF4SGVhbHRoeVBlcmNlbnRhZ2U/OiBudW1iZXJcbi8qKlxuICogU3BlY2lmaWVzIHRoZSBsb3dlciB0aHJlc2hvbGQgYXMgYSBwZXJjZW50YWdlIG9mIHRoZSBkZXNpcmVkIGNhcGFjaXR5IG9mIHRoZSBBdXRvIFNjYWxpbmcgZ3JvdXAuIEl0IHJlcHJlc2VudHMgdGhlIG1pbmltdW0gcGVyY2VudGFnZSBvZiB0aGUgZ3JvdXAgdG8ga2VlcCBpbiBzZXJ2aWNlLCBoZWFsdGh5LCBhbmQgcmVhZHkgdG8gdXNlIHRvIHN1cHBvcnQgeW91ciB3b3JrbG9hZCB3aGVuIHJlcGxhY2luZyBpbnN0YW5jZXMuIFZhbHVlIHJhbmdlIGlzIDAgdG8gMTAwLiBUbyBjbGVhciBhIHByZXZpb3VzbHkgc2V0IHZhbHVlLCBzcGVjaWZ5IGEgdmFsdWUgb2YgYGAtMWBgLlxuICovXG5NaW5IZWFsdGh5UGVyY2VudGFnZT86IG51bWJlclxufVxuLyoqXG4gKiBJZGVudGlmeWluZyBpbmZvcm1hdGlvbiBmb3IgYSB0cmFmZmljIHNvdXJjZS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBUcmFmZmljU291cmNlSWRlbnRpZmllciB7XG4vKipcbiAqIFByb3ZpZGVzIGFkZGl0aW9uYWwgY29udGV4dCBmb3IgdGhlIHZhbHVlIG9mIGBgSWRlbnRpZmllcmBgLlxuICogIFRoZSBmb2xsb3dpbmcgbGlzdHMgdGhlIHZhbGlkIHZhbHVlczpcbiAqICAgKyAgIGBgZWxiYGAgaWYgYGBJZGVudGlmaWVyYGAgaXMgdGhlIG5hbWUgb2YgYSBDbGFzc2ljIExvYWQgQmFsYW5jZXIuXG4gKiAgICsgICBgYGVsYnYyYGAgaWYgYGBJZGVudGlmaWVyYGAgaXMgdGhlIEFSTiBvZiBhbiBBcHBsaWNhdGlvbiBMb2FkIEJhbGFuY2VyLCBHYXRld2F5IExvYWQgQmFsYW5jZXIsIG9yIE5ldHdvcmsgTG9hZCBCYWxhbmNlciB0YXJnZXQgZ3JvdXAuXG4gKiAgICsgICBgYHZwYy1sYXR0aWNlYGAgaWYgYGBJZGVudGlmaWVyYGAgaXMgdGhlIEFSTiBvZiBhIFZQQyBMYXR0aWNlIHRhcmdldCBncm91cC5cbiAqICAgXG4gKiAgUmVxdWlyZWQgaWYgdGhlIGlkZW50aWZpZXIgaXMgdGhlIG5hbWUgb2YgYSBDbGFzc2ljIExvYWQgQmFsYW5jZXIuXG4gKi9cblR5cGU6IHN0cmluZ1xuLyoqXG4gKiBJZGVudGlmaWVzIHRoZSB0cmFmZmljIHNvdXJjZS5cbiAqICBGb3IgQXBwbGljYXRpb24gTG9hZCBCYWxhbmNlcnMsIEdhdGV3YXkgTG9hZCBCYWxhbmNlcnMsIE5ldHdvcmsgTG9hZCBCYWxhbmNlcnMsIGFuZCBWUEMgTGF0dGljZSwgdGhpcyB3aWxsIGJlIHRoZSBBbWF6b24gUmVzb3VyY2UgTmFtZSAoQVJOKSBmb3IgYSB0YXJnZXQgZ3JvdXAgaW4gdGhpcyBhY2NvdW50IGFuZCBSZWdpb24uIEZvciBDbGFzc2ljIExvYWQgQmFsYW5jZXJzLCB0aGlzIHdpbGwgYmUgdGhlIG5hbWUgb2YgdGhlIENsYXNzaWMgTG9hZCBCYWxhbmNlciBpbiB0aGlzIGFjY291bnQgYW5kIFJlZ2lvbi5cbiAqICBGb3IgZXhhbXBsZTogXG4gKiAgICsgIEFwcGxpY2F0aW9uIExvYWQgQmFsYW5jZXIgQVJOOiBgYGFybjphd3M6ZWxhc3RpY2xvYWRiYWxhbmNpbmc6dXMtd2VzdC0yOjEyMzQ1Njc4OTAxMjp0YXJnZXRncm91cC9teS10YXJnZXRzLzEyMzQ1Njc4OTAxMjM0NTZgYCBcbiAqICAgKyAgQ2xhc3NpYyBMb2FkIEJhbGFuY2VyIG5hbWU6IGBgbXktY2xhc3NpYy1sb2FkLWJhbGFuY2VyYGAgXG4gKiAgICsgIFZQQyBMYXR0aWNlIEFSTjogYGBhcm46YXdzOnZwYy1sYXR0aWNlOnVzLXdlc3QtMjoxMjM0NTY3ODkwMTI6dGFyZ2V0Z3JvdXAvdGctMTIzNDU2Nzg5MDEyMzQ1NmBgIFxuICogICBcbiAqICBUbyBnZXQgdGhlIEFSTiBvZiBhIHRhcmdldCBncm91cCBmb3IgYSBBcHBsaWNhdGlvbiBMb2FkIEJhbGFuY2VyLCBHYXRld2F5IExvYWQgQmFsYW5jZXIsIG9yIE5ldHdvcmsgTG9hZCBCYWxhbmNlciwgb3IgdGhlIG5hbWUgb2YgYSBDbGFzc2ljIExvYWQgQmFsYW5jZXIsIHVzZSB0aGUgRWxhc3RpYyBMb2FkIEJhbGFuY2luZyBbRGVzY3JpYmVUYXJnZXRHcm91cHNdKGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9lbGFzdGljbG9hZGJhbGFuY2luZy9sYXRlc3QvQVBJUmVmZXJlbmNlL0FQSV9EZXNjcmliZVRhcmdldEdyb3Vwcy5odG1sKSBhbmQgW0Rlc2NyaWJlTG9hZEJhbGFuY2Vyc10oaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL2VsYXN0aWNsb2FkYmFsYW5jaW5nL2xhdGVzdC9BUElSZWZlcmVuY2UvQVBJX0Rlc2NyaWJlTG9hZEJhbGFuY2Vycy5odG1sKSBBUEkgb3BlcmF0aW9ucy5cbiAqICBUbyBnZXQgdGhlIEFSTiBvZiBhIHRhcmdldCBncm91cCBmb3IgVlBDIExhdHRpY2UsIHVzZSB0aGUgVlBDIExhdHRpY2UgW0dldFRhcmdldEdyb3VwXShodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vdnBjLWxhdHRpY2UvbGF0ZXN0L0FQSVJlZmVyZW5jZS9BUElfR2V0VGFyZ2V0R3JvdXAuaHRtbCkgQVBJIG9wZXJhdGlvbi5cbiAqL1xuSWRlbnRpZmllcjogc3RyaW5nXG59XG5leHBvcnQgaW50ZXJmYWNlIENhcGFjaXR5UmVzZXJ2YXRpb25TcGVjaWZpY2F0aW9uIHtcbkNhcGFjaXR5UmVzZXJ2YXRpb25QcmVmZXJlbmNlOiBzdHJpbmdcbkNhcGFjaXR5UmVzZXJ2YXRpb25UYXJnZXQ/OiBDYXBhY2l0eVJlc2VydmF0aW9uVGFyZ2V0XG59XG5leHBvcnQgaW50ZXJmYWNlIENhcGFjaXR5UmVzZXJ2YXRpb25UYXJnZXQge1xuQ2FwYWNpdHlSZXNlcnZhdGlvbklkcz86IENhcGFjaXR5UmVzZXJ2YXRpb25JZHNcbkNhcGFjaXR5UmVzZXJ2YXRpb25SZXNvdXJjZUdyb3VwQXJucz86IENhcGFjaXR5UmVzZXJ2YXRpb25SZXNvdXJjZUdyb3VwQXJuc1xufVxuIl19
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXdzLWF1dG9zY2FsaW5nLWF1dG9zY2FsaW5nZ3JvdXAuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJhd3MtYXV0b3NjYWxpbmctYXV0b3NjYWxpbmdncm91cC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBTcGVjaWZ5IGFuIGluc3RhbmNlIGZhbWlseSB0byB1c2UgYXMgdGhlIGJhc2VsaW5lIHJlZmVyZW5jZSBmb3IgQ1BVIHBlcmZvcm1hbmNlLiBBbGwgaW5zdGFuY2UgdHlwZXMgdGhhdCBtYXRjaCB5b3VyIHNwZWNpZmllZCBhdHRyaWJ1dGVzIHdpbGwgYmUgY29tcGFyZWQgYWdhaW5zdCB0aGUgQ1BVIHBlcmZvcm1hbmNlIG9mIHRoZSByZWZlcmVuY2VkIGluc3RhbmNlIGZhbWlseSwgcmVnYXJkbGVzcyBvZiBDUFUgbWFudWZhY3R1cmVyIG9yIGFyY2hpdGVjdHVyZSBkaWZmZXJlbmNlcy4gXG4gKiAgIEN1cnJlbnRseSBvbmx5IG9uZSBpbnN0YW5jZSBmYW1pbHkgY2FuIGJlIHNwZWNpZmllZCBpbiB0aGUgbGlzdC5cbiAqL1xuZXhwb3J0IHR5cGUgUGVyZm9ybWFuY2VGYWN0b3JSZWZlcmVuY2VTZXRSZXF1ZXN0ID0gUGVyZm9ybWFuY2VGYWN0b3JSZWZlcmVuY2VSZXF1ZXN0W11cbi8qKlxuICogVGhlIENhcGFjaXR5IFJlc2VydmF0aW9uIElEcyB0byBsYXVuY2ggaW5zdGFuY2VzIGludG8uXG4gKi9cbmV4cG9ydCB0eXBlIENhcGFjaXR5UmVzZXJ2YXRpb25JZHMgPSBzdHJpbmdbXVxuLyoqXG4gKiBUaGUgcmVzb3VyY2UgZ3JvdXAgQVJOcyBvZiB0aGUgQ2FwYWNpdHkgUmVzZXJ2YXRpb24gdG8gbGF1bmNoIGluc3RhbmNlcyBpbnRvLlxuICovXG5leHBvcnQgdHlwZSBDYXBhY2l0eVJlc2VydmF0aW9uUmVzb3VyY2VHcm91cEFybnMgPSBzdHJpbmdbXVxuXG4vKipcbiAqIFRoZSBgYEFXUzo6QXV0b1NjYWxpbmc6OkF1dG9TY2FsaW5nR3JvdXBgYCByZXNvdXJjZSBkZWZpbmVzIGFuIEFtYXpvbiBFQzIgQXV0byBTY2FsaW5nIGdyb3VwLCB3aGljaCBpcyBhIGNvbGxlY3Rpb24gb2YgQW1hem9uIEVDMiBpbnN0YW5jZXMgdGhhdCBhcmUgdHJlYXRlZCBhcyBhIGxvZ2ljYWwgZ3JvdXBpbmcgZm9yIHRoZSBwdXJwb3NlcyBvZiBhdXRvbWF0aWMgc2NhbGluZyBhbmQgbWFuYWdlbWVudC4gXG4gKiAgRm9yIG1vcmUgaW5mb3JtYXRpb24gYWJvdXQgQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcsIHNlZSB0aGUgW0FtYXpvbiBFQzIgQXV0byBTY2FsaW5nIFVzZXIgR3VpZGVdKGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9hdXRvc2NhbGluZy9lYzIvdXNlcmd1aWRlL3doYXQtaXMtYW1hem9uLWVjMi1hdXRvLXNjYWxpbmcuaHRtbCkuIFxuICogICBBbWF6b24gRUMyIEF1dG8gU2NhbGluZyBjb25maWd1cmVzIGluc3RhbmNlcyBsYXVuY2hlZCBhcyBwYXJ0IG9mIGFuIEF1dG8gU2NhbGluZyBncm91cCB1c2luZyBlaXRoZXIgYSBbbGF1bmNoIHRlbXBsYXRlXShodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vQVdTQ2xvdWRGb3JtYXRpb24vbGF0ZXN0L1VzZXJHdWlkZS9hd3MtcmVzb3VyY2UtZWMyLWxhdW5jaHRlbXBsYXRlLmh0bWwpIG9yIGEgbGF1bmNoIGNvbmZpZ3VyYXRpb24uIFdlIHN0cm9uZ2x5IHJlY29tbWVuZCB0aGF0IHlvdSBkbyBub3QgdXNlIGxhdW5jaCBjb25maWd1cmF0aW9ucy4gRm9yIG1vcmUgaW5mb3JtYXRpb24sIHNlZSBbTGF1bmNoIGNvbmZpZ3VyYXRpb25zXShodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vYXV0b3NjYWxpbmcvZWMyL3VzZXJndWlkZS9sYXVuY2gtY29uZmlndXJhdGlvbnMuaHRtbCkgaW4gdGhlICpBbWF6b24gRUMyIEF1dG8gU2NhbGluZyBVc2VyIEd1aWRlKi5cbiAqICBGb3IgaGVscCBtaWdyYXRpbmcgZnJvbSBsYXVuY2ggY29uZmlndXJhdGlvbnMgdG8gbGF1bmNoIHRlbXBsYXRlcywgc2VlIFtNaWdyYXRlIENsb3VkRm9ybWF0aW9uIHN0YWNrcyBmcm9tIGxhdW5jaCBjb25maWd1cmF0aW9ucyB0byBsYXVuY2ggdGVtcGxhdGVzXShodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vYXV0b3NjYWxpbmcvZWMyL3VzZXJndWlkZS9taWdyYXRlLWxhdW5jaC1jb25maWd1cmF0aW9ucy13aXRoLWNsb3VkZm9ybWF0aW9uLmh0bWwpIGluIHRoZSAqQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgVXNlciBHdWlkZSouXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgX0FXU19BVVRPU0NBTElOR19BVVRPU0NBTElOR0dST1VQIHtcbi8qKlxuICogT25lIG9yIG1vcmUgbGlmZWN5Y2xlIGhvb2tzIHRvIGFkZCB0byB0aGUgQXV0byBTY2FsaW5nIGdyb3VwIGJlZm9yZSBpbnN0YW5jZXMgYXJlIGxhdW5jaGVkLlxuICovXG5MaWZlY3ljbGVIb29rU3BlY2lmaWNhdGlvbkxpc3Q/OiBMaWZlY3ljbGVIb29rU3BlY2lmaWNhdGlvbltdXG4vKipcbiAqIEEgbGlzdCBvZiBDbGFzc2ljIExvYWQgQmFsYW5jZXJzIGFzc29jaWF0ZWQgd2l0aCB0aGlzIEF1dG8gU2NhbGluZyBncm91cC4gRm9yIEFwcGxpY2F0aW9uIExvYWQgQmFsYW5jZXJzLCBOZXR3b3JrIExvYWQgQmFsYW5jZXJzLCBhbmQgR2F0ZXdheSBMb2FkIEJhbGFuY2Vycywgc3BlY2lmeSB0aGUgYGBUYXJnZXRHcm91cEFSTnNgYCBwcm9wZXJ0eSBpbnN0ZWFkLlxuICovXG5Mb2FkQmFsYW5jZXJOYW1lcz86IHN0cmluZ1tdXG4vKipcbiAqIFRoZSBuYW1lIG9mIHRoZSBsYXVuY2ggY29uZmlndXJhdGlvbiB0byB1c2UgdG8gbGF1bmNoIGluc3RhbmNlcy5cbiAqICBSZXF1aXJlZCBvbmx5IGlmIHlvdSBkb24ndCBzcGVjaWZ5IGBgTGF1bmNoVGVtcGxhdGVgYCwgYGBNaXhlZEluc3RhbmNlc1BvbGljeWBgLCBvciBgYEluc3RhbmNlSWRgYC5cbiAqL1xuTGF1bmNoQ29uZmlndXJhdGlvbk5hbWU/OiBzdHJpbmdcbi8qKlxuICogVGhlIEFtYXpvbiBSZXNvdXJjZSBOYW1lIChBUk4pIG9mIHRoZSBzZXJ2aWNlLWxpbmtlZCByb2xlIHRoYXQgdGhlIEF1dG8gU2NhbGluZyBncm91cCB1c2VzIHRvIGNhbGwgb3RoZXIgQVdTIHNlcnZpY2Ugb24geW91ciBiZWhhbGYuIEJ5IGRlZmF1bHQsIEFtYXpvbiBFQzIgQXV0byBTY2FsaW5nIHVzZXMgYSBzZXJ2aWNlLWxpbmtlZCByb2xlIG5hbWVkIGBgQVdTU2VydmljZVJvbGVGb3JBdXRvU2NhbGluZ2BgLCB3aGljaCBpdCBjcmVhdGVzIGlmIGl0IGRvZXMgbm90IGV4aXN0LiBGb3IgbW9yZSBpbmZvcm1hdGlvbiwgc2VlIFtTZXJ2aWNlLWxpbmtlZCByb2xlc10oaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL2F1dG9zY2FsaW5nL2VjMi91c2VyZ3VpZGUvYXV0b3NjYWxpbmctc2VydmljZS1saW5rZWQtcm9sZS5odG1sKSBpbiB0aGUgKkFtYXpvbiBFQzIgQXV0byBTY2FsaW5nIFVzZXIgR3VpZGUqLlxuICovXG5TZXJ2aWNlTGlua2VkUm9sZUFSTj86IHN0cmluZ1xuQXZhaWxhYmlsaXR5Wm9uZUltcGFpcm1lbnRQb2xpY3k/OiBBdmFpbGFiaWxpdHlab25lSW1wYWlybWVudFBvbGljeVxuLyoqXG4gKiBUaGUgQW1hem9uIFJlc291cmNlIE5hbWVzIChBUk4pIG9mIHRoZSBFbGFzdGljIExvYWQgQmFsYW5jaW5nIHRhcmdldCBncm91cHMgdG8gYXNzb2NpYXRlIHdpdGggdGhlIEF1dG8gU2NhbGluZyBncm91cC4gSW5zdGFuY2VzIGFyZSByZWdpc3RlcmVkIGFzIHRhcmdldHMgd2l0aCB0aGUgdGFyZ2V0IGdyb3Vwcy4gVGhlIHRhcmdldCBncm91cHMgcmVjZWl2ZSBpbmNvbWluZyB0cmFmZmljIGFuZCByb3V0ZSByZXF1ZXN0cyB0byBvbmUgb3IgbW9yZSByZWdpc3RlcmVkIHRhcmdldHMuIEZvciBtb3JlIGluZm9ybWF0aW9uLCBzZWUgW1VzZSBFbGFzdGljIExvYWQgQmFsYW5jaW5nIHRvIGRpc3RyaWJ1dGUgdHJhZmZpYyBhY3Jvc3MgdGhlIGluc3RhbmNlcyBpbiB5b3VyIEF1dG8gU2NhbGluZyBncm91cF0oaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL2F1dG9zY2FsaW5nL2VjMi91c2VyZ3VpZGUvYXV0b3NjYWxpbmctbG9hZC1iYWxhbmNlci5odG1sKSBpbiB0aGUgKkFtYXpvbiBFQzIgQXV0byBTY2FsaW5nIFVzZXIgR3VpZGUqLlxuICovXG5UYXJnZXRHcm91cEFSTnM/OiBzdHJpbmdbXVxuLyoqXG4gKiAqT25seSBuZWVkZWQgaWYgeW91IHVzZSBzaW1wbGUgc2NhbGluZyBwb2xpY2llcy4qIFxuICogIFRoZSBhbW91bnQgb2YgdGltZSwgaW4gc2Vjb25kcywgYmV0d2VlbiBvbmUgc2NhbGluZyBhY3Rpdml0eSBlbmRpbmcgYW5kIGFub3RoZXIgb25lIHN0YXJ0aW5nIGR1ZSB0byBzaW1wbGUgc2NhbGluZyBwb2xpY2llcy4gRm9yIG1vcmUgaW5mb3JtYXRpb24sIHNlZSBbU2NhbGluZyBjb29sZG93bnMgZm9yIEFtYXpvbiBFQzIgQXV0byBTY2FsaW5nXShodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vYXV0b3NjYWxpbmcvZWMyL3VzZXJndWlkZS9lYzItYXV0by1zY2FsaW5nLXNjYWxpbmctY29vbGRvd25zLmh0bWwpIGluIHRoZSAqQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgVXNlciBHdWlkZSouXG4gKiAgRGVmYXVsdDogYGAzMDBgYCBzZWNvbmRzXG4gKi9cbkNvb2xkb3duPzogc3RyaW5nXG4vKipcbiAqIENvbmZpZ3VyZXMgYW4gQXV0byBTY2FsaW5nIGdyb3VwIHRvIHNlbmQgbm90aWZpY2F0aW9ucyB3aGVuIHNwZWNpZmllZCBldmVudHMgdGFrZSBwbGFjZS5cbiAqL1xuTm90aWZpY2F0aW9uQ29uZmlndXJhdGlvbnM/OiBOb3RpZmljYXRpb25Db25maWd1cmF0aW9uW11cbi8qKlxuICogVGhlIGRlc2lyZWQgY2FwYWNpdHkgaXMgdGhlIGluaXRpYWwgY2FwYWNpdHkgb2YgdGhlIEF1dG8gU2NhbGluZyBncm91cCBhdCB0aGUgdGltZSBvZiBpdHMgY3JlYXRpb24gYW5kIHRoZSBjYXBhY2l0eSBpdCBhdHRlbXB0cyB0byBtYWludGFpbi4gSXQgY2FuIHNjYWxlIGJleW9uZCB0aGlzIGNhcGFjaXR5IGlmIHlvdSBjb25maWd1cmUgYXV0b21hdGljIHNjYWxpbmcuXG4gKiAgVGhlIG51bWJlciBtdXN0IGJlIGdyZWF0ZXIgdGhhbiBvciBlcXVhbCB0byB0aGUgbWluaW11bSBzaXplIG9mIHRoZSBncm91cCBhbmQgbGVzcyB0aGFuIG9yIGVxdWFsIHRvIHRoZSBtYXhpbXVtIHNpemUgb2YgdGhlIGdyb3VwLiBJZiB5b3UgZG8gbm90IHNwZWNpZnkgYSBkZXNpcmVkIGNhcGFjaXR5IHdoZW4gY3JlYXRpbmcgdGhlIHN0YWNrLCB0aGUgZGVmYXVsdCBpcyB0aGUgbWluaW11bSBzaXplIG9mIHRoZSBncm91cC5cbiAqICBDbG91ZEZvcm1hdGlvbiBtYXJrcyB0aGUgQXV0byBTY2FsaW5nIGdyb3VwIGFzIHN1Y2Nlc3NmdWwgKGJ5IHNldHRpbmcgaXRzIHN0YXR1cyB0byBDUkVBVEVfQ09NUExFVEUpIHdoZW4gdGhlIGRlc2lyZWQgY2FwYWNpdHkgaXMgcmVhY2hlZC4gSG93ZXZlciwgaWYgYSBtYXhpbXVtIFNwb3QgcHJpY2UgaXMgc2V0IGluIHRoZSBsYXVuY2ggdGVtcGxhdGUgb3IgbGF1bmNoIGNvbmZpZ3VyYXRpb24gdGhhdCB5b3Ugc3BlY2lmaWVkLCB0aGVuIGRlc2lyZWQgY2FwYWNpdHkgaXMgbm90IHVzZWQgYXMgYSBjcml0ZXJpYSBmb3Igc3VjY2Vzcy4gV2hldGhlciB5b3VyIHJlcXVlc3QgaXMgZnVsZmlsbGVkIGRlcGVuZHMgb24gU3BvdCBJbnN0YW5jZSBjYXBhY2l0eSBhbmQgeW91ciBtYXhpbXVtIHByaWNlLlxuICovXG5EZXNpcmVkQ2FwYWNpdHk/OiBzdHJpbmdcbi8qKlxuICogVGhlIGFtb3VudCBvZiB0aW1lLCBpbiBzZWNvbmRzLCB0aGF0IEFtYXpvbiBFQzIgQXV0byBTY2FsaW5nIHdhaXRzIGJlZm9yZSBjaGVja2luZyB0aGUgaGVhbHRoIHN0YXR1cyBvZiBhbiBFQzIgaW5zdGFuY2UgdGhhdCBoYXMgY29tZSBpbnRvIHNlcnZpY2UgYW5kIG1hcmtpbmcgaXQgdW5oZWFsdGh5IGR1ZSB0byBhIGZhaWxlZCBoZWFsdGggY2hlY2suIFRoaXMgaXMgdXNlZnVsIGlmIHlvdXIgaW5zdGFuY2VzIGRvIG5vdCBpbW1lZGlhdGVseSBwYXNzIHRoZWlyIGhlYWx0aCBjaGVja3MgYWZ0ZXIgdGhleSBlbnRlciB0aGUgYGBJblNlcnZpY2VgYCBzdGF0ZS4gRm9yIG1vcmUgaW5mb3JtYXRpb24sIHNlZSBbU2V0IHRoZSBoZWFsdGggY2hlY2sgZ3JhY2UgcGVyaW9kIGZvciBhbiBBdXRvIFNjYWxpbmcgZ3JvdXBdKGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9hdXRvc2NhbGluZy9lYzIvdXNlcmd1aWRlL2hlYWx0aC1jaGVjay1ncmFjZS1wZXJpb2QuaHRtbCkgaW4gdGhlICpBbWF6b24gRUMyIEF1dG8gU2NhbGluZyBVc2VyIEd1aWRlKi5cbiAqICBEZWZhdWx0OiBgYDBgYCBzZWNvbmRzXG4gKi9cbkhlYWx0aENoZWNrR3JhY2VQZXJpb2Q/OiBudW1iZXJcbi8qKlxuICogVGhlIGFtb3VudCBvZiB0aW1lLCBpbiBzZWNvbmRzLCB1bnRpbCBhIG5ldyBpbnN0YW5jZSBpcyBjb25zaWRlcmVkIHRvIGhhdmUgZmluaXNoZWQgaW5pdGlhbGl6aW5nIGFuZCByZXNvdXJjZSBjb25zdW1wdGlvbiB0byBiZWNvbWUgc3RhYmxlIGFmdGVyIGl0IGVudGVycyB0aGUgYGBJblNlcnZpY2VgYCBzdGF0ZS4gXG4gKiAgRHVyaW5nIGFuIGluc3RhbmNlIHJlZnJlc2gsIEFtYXpvbiBFQzIgQXV0byBTY2FsaW5nIHdhaXRzIGZvciB0aGUgd2FybS11cCBwZXJpb2QgYWZ0ZXIgaXQgcmVwbGFjZXMgYW4gaW5zdGFuY2UgYmVmb3JlIGl0IG1vdmVzIG9uIHRvIHJlcGxhY2luZyB0aGUgbmV4dCBpbnN0YW5jZS4gQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgYWxzbyB3YWl0cyBmb3IgdGhlIHdhcm0tdXAgcGVyaW9kIGJlZm9yZSBhZ2dyZWdhdGluZyB0aGUgbWV0cmljcyBmb3IgbmV3IGluc3RhbmNlcyB3aXRoIGV4aXN0aW5nIGluc3RhbmNlcyBpbiB0aGUgQW1hem9uIENsb3VkV2F0Y2ggbWV0cmljcyB0aGF0IGFyZSB1c2VkIGZvciBzY2FsaW5nLCByZXN1bHRpbmcgaW4gbW9yZSByZWxpYWJsZSB1c2FnZSBkYXRhLiBGb3IgbW9yZSBpbmZvcm1hdGlvbiwgc2VlIFtTZXQgdGhlIGRlZmF1bHQgaW5zdGFuY2Ugd2FybXVwIGZvciBhbiBBdXRvIFNjYWxpbmcgZ3JvdXBdKGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9hdXRvc2NhbGluZy9lYzIvdXNlcmd1aWRlL2VjMi1hdXRvLXNjYWxpbmctZGVmYXVsdC1pbnN0YW5jZS13YXJtdXAuaHRtbCkgaW4gdGhlICpBbWF6b24gRUMyIEF1dG8gU2NhbGluZyBVc2VyIEd1aWRlKi5cbiAqICAgVG8gbWFuYWdlIHZhcmlvdXMgd2FybS11cCBzZXR0aW5ncyBhdCB0aGUgZ3JvdXAgbGV2ZWwsIHdlIHJlY29tbWVuZCB0aGF0IHlvdSBzZXQgdGhlIGRlZmF1bHQgaW5zdGFuY2Ugd2FybXVwLCAqZXZlbiBpZiBpdCBpcyBzZXQgdG8gMCBzZWNvbmRzKi4gVG8gcmVtb3ZlIGEgdmFsdWUgdGhhdCB5b3UgcHJldmlvdXNseSBzZXQsIGluY2x1ZGUgdGhlIHByb3BlcnR5IGJ1dCBzcGVjaWZ5IGBgLTFgYCBmb3IgdGhlIHZhbHVlLiBIb3dldmVyLCB3ZSBzdHJvbmdseSByZWNvbW1lbmQga2VlcGluZyB0aGUgZGVmYXVsdCBpbnN0YW5jZSB3YXJtdXAgZW5hYmxlZCBieSBzcGVjaWZ5aW5nIGEgdmFsdWUgb2YgYGAwYGAgb3Igb3RoZXIgbm9taW5hbCB2YWx1ZS5cbiAqICAgRGVmYXVsdDogTm9uZVxuICovXG5EZWZhdWx0SW5zdGFuY2VXYXJtdXA/OiBudW1iZXJcblNraXBab25hbFNoaWZ0VmFsaWRhdGlvbj86IGJvb2xlYW5cbi8qKlxuICogSW5kaWNhdGVzIHdoZXRoZXIgbmV3bHkgbGF1bmNoZWQgaW5zdGFuY2VzIGFyZSBwcm90ZWN0ZWQgZnJvbSB0ZXJtaW5hdGlvbiBieSBBbWF6b24gRUMyIEF1dG8gU2NhbGluZyB3aGVuIHNjYWxpbmcgaW4uIEZvciBtb3JlIGluZm9ybWF0aW9uIGFib3V0IHByZXZlbnRpbmcgaW5zdGFuY2VzIGZyb20gdGVybWluYXRpbmcgb24gc2NhbGUgaW4sIHNlZSBbVXNlIGluc3RhbmNlIHNjYWxlLWluIHByb3RlY3Rpb25dKGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9hdXRvc2NhbGluZy9lYzIvdXNlcmd1aWRlL2VjMi1hdXRvLXNjYWxpbmctaW5zdGFuY2UtcHJvdGVjdGlvbi5odG1sKSBpbiB0aGUgKkFtYXpvbiBFQzIgQXV0byBTY2FsaW5nIFVzZXIgR3VpZGUqLlxuICovXG5OZXdJbnN0YW5jZXNQcm90ZWN0ZWRGcm9tU2NhbGVJbj86IGJvb2xlYW5cbkxhdW5jaFRlbXBsYXRlPzogTGF1bmNoVGVtcGxhdGVTcGVjaWZpY2F0aW9uXG5NaXhlZEluc3RhbmNlc1BvbGljeT86IE1peGVkSW5zdGFuY2VzUG9saWN5XG4vKipcbiAqIEEgbGlzdCBvZiBzdWJuZXQgSURzIGZvciBhIHZpcnR1YWwgcHJpdmF0ZSBjbG91ZCAoVlBDKSB3aGVyZSBpbnN0YW5jZXMgaW4gdGhlIEF1dG8gU2NhbGluZyBncm91cCBjYW4gYmUgY3JlYXRlZC5cbiAqICBJZiB0aGlzIHJlc291cmNlIHNwZWNpZmllcyBwdWJsaWMgc3VibmV0cyBhbmQgaXMgYWxzbyBpbiBhIFZQQyB0aGF0IGlzIGRlZmluZWQgaW4gdGhlIHNhbWUgc3RhY2sgdGVtcGxhdGUsIHlvdSBtdXN0IHVzZSB0aGUgW0RlcGVuZHNPbiBhdHRyaWJ1dGVdKGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9BV1NDbG91ZEZvcm1hdGlvbi9sYXRlc3QvVXNlckd1aWRlL2F3cy1hdHRyaWJ1dGUtZGVwZW5kc29uLmh0bWwpIHRvIGRlY2xhcmUgYSBkZXBlbmRlbmN5IG9uIHRoZSBbVlBDLWdhdGV3YXkgYXR0YWNobWVudF0oaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL0FXU0Nsb3VkRm9ybWF0aW9uL2xhdGVzdC9Vc2VyR3VpZGUvYXdzLXJlc291cmNlLWVjMi12cGMtZ2F0ZXdheS1hdHRhY2htZW50Lmh0bWwpLlxuICogICBXaGVuIHlvdSB1cGRhdGUgYGBWUENab25lSWRlbnRpZmllcmBgLCB0aGlzIHJldGFpbnMgdGhlIHNhbWUgQXV0byBTY2FsaW5nIGdyb3VwIGFuZCByZXBsYWNlcyBvbGQgaW5zdGFuY2VzIHdpdGggbmV3IG9uZXMsIGFjY29yZGluZyB0byB0aGUgc3BlY2lmaWVkIHN1Ym5ldHMuIFlvdSBjYW4gb3B0aW9uYWxseSBzcGVjaWZ5IGhvdyBDbG91ZEZvcm1hdGlvbiBoYW5kbGVzIHRoZXNlIHVwZGF0ZXMgYnkgdXNpbmcgYW4gW1VwZGF0ZVBvbGljeSBhdHRyaWJ1dGVdKGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9BV1NDbG91ZEZvcm1hdGlvbi9sYXRlc3QvVXNlckd1aWRlL2F3cy1hdHRyaWJ1dGUtdXBkYXRlcG9saWN5Lmh0bWwpLlxuICogICBSZXF1aXJlZCB0byBsYXVuY2ggaW5zdGFuY2VzIGludG8gYSBub25kZWZhdWx0IFZQQy4gSWYgeW91IHNwZWNpZnkgYGBWUENab25lSWRlbnRpZmllcmBgIHdpdGggYGBBdmFpbGFiaWxpdHlab25lc2BgLCB0aGUgc3VibmV0cyB0aGF0IHlvdSBzcGVjaWZ5IGZvciB0aGlzIHByb3BlcnR5IG11c3QgcmVzaWRlIGluIHRob3NlIEF2YWlsYWJpbGl0eSBab25lcy5cbiAqL1xuVlBDWm9uZUlkZW50aWZpZXI/OiBzdHJpbmdbXVxuLyoqXG4gKiBPbmUgb3IgbW9yZSB0YWdzLiBZb3UgY2FuIHRhZyB5b3VyIEF1dG8gU2NhbGluZyBncm91cCBhbmQgcHJvcGFnYXRlIHRoZSB0YWdzIHRvIHRoZSBBbWF6b24gRUMyIGluc3RhbmNlcyBpdCBsYXVuY2hlcy4gVGFncyBhcmUgbm90IHByb3BhZ2F0ZWQgdG8gQW1hem9uIEVCUyB2b2x1bWVzLiBUbyBhZGQgdGFncyB0byBBbWF6b24gRUJTIHZvbHVtZXMsIHNwZWNpZnkgdGhlIHRhZ3MgaW4gYSBsYXVuY2ggdGVtcGxhdGUgYnV0IHVzZSBjYXV0aW9uLiBJZiB0aGUgbGF1bmNoIHRlbXBsYXRlIHNwZWNpZmllcyBhbiBpbnN0YW5jZSB0YWcgd2l0aCBhIGtleSB0aGF0IGlzIGFsc28gc3BlY2lmaWVkIGZvciB0aGUgQXV0byBTY2FsaW5nIGdyb3VwLCBBbWF6b24gRUMyIEF1dG8gU2NhbGluZyBvdmVycmlkZXMgdGhlIHZhbHVlIG9mIHRoYXQgaW5zdGFuY2UgdGFnIHdpdGggdGhlIHZhbHVlIHNwZWNpZmllZCBieSB0aGUgQXV0byBTY2FsaW5nIGdyb3VwLiBGb3IgbW9yZSBpbmZvcm1hdGlvbiwgc2VlIFtUYWcgQXV0byBTY2FsaW5nIGdyb3VwcyBhbmQgaW5zdGFuY2VzXShodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vYXV0b3NjYWxpbmcvZWMyL3VzZXJndWlkZS9lYzItYXV0by1zY2FsaW5nLXRhZ2dpbmcuaHRtbCkgaW4gdGhlICpBbWF6b24gRUMyIEF1dG8gU2NhbGluZyBVc2VyIEd1aWRlKi5cbiAqL1xuVGFncz86IFRhZ1Byb3BlcnR5W11cbi8qKlxuICogUmVzZXJ2ZWQuXG4gKi9cbkNvbnRleHQ/OiBzdHJpbmdcbi8qKlxuICogSW5kaWNhdGVzIHdoZXRoZXIgQ2FwYWNpdHkgUmViYWxhbmNpbmcgaXMgZW5hYmxlZC4gT3RoZXJ3aXNlLCBDYXBhY2l0eSBSZWJhbGFuY2luZyBpcyBkaXNhYmxlZC4gV2hlbiB5b3UgdHVybiBvbiBDYXBhY2l0eSBSZWJhbGFuY2luZywgQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgYXR0ZW1wdHMgdG8gbGF1bmNoIGEgU3BvdCBJbnN0YW5jZSB3aGVuZXZlciBBbWF6b24gRUMyIG5vdGlmaWVzIHRoYXQgYSBTcG90IEluc3RhbmNlIGlzIGF0IGFuIGVsZXZhdGVkIHJpc2sgb2YgaW50ZXJydXB0aW9uLiBBZnRlciBsYXVuY2hpbmcgYSBuZXcgaW5zdGFuY2UsIGl0IHRoZW4gdGVybWluYXRlcyBhbiBvbGQgaW5zdGFuY2UuIEZvciBtb3JlIGluZm9ybWF0aW9uLCBzZWUgW1VzZSBDYXBhY2l0eSBSZWJhbGFuY2luZyB0byBoYW5kbGUgQW1hem9uIEVDMiBTcG90IEludGVycnVwdGlvbnNdKGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9hdXRvc2NhbGluZy9lYzIvdXNlcmd1aWRlL2VjMi1hdXRvLXNjYWxpbmctY2FwYWNpdHktcmViYWxhbmNpbmcuaHRtbCkgaW4gdGhlIGluIHRoZSAqQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgVXNlciBHdWlkZSouXG4gKi9cbkNhcGFjaXR5UmViYWxhbmNlPzogYm9vbGVhblxuLyoqXG4gKiBUaGUgSUQgb2YgdGhlIGluc3RhbmNlIHVzZWQgdG8gYmFzZSB0aGUgbGF1bmNoIGNvbmZpZ3VyYXRpb24gb24uIEZvciBtb3JlIGluZm9ybWF0aW9uLCBzZWUgW0NyZWF0ZSBhbiBBdXRvIFNjYWxpbmcgZ3JvdXAgdXNpbmcgYW4gRUMyIGluc3RhbmNlXShodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vYXV0b3NjYWxpbmcvZWMyL3VzZXJndWlkZS9jcmVhdGUtYXNnLWZyb20taW5zdGFuY2UuaHRtbCkgaW4gdGhlICpBbWF6b24gRUMyIEF1dG8gU2NhbGluZyBVc2VyIEd1aWRlKi5cbiAqICBJZiB5b3Ugc3BlY2lmeSBgYExhdW5jaFRlbXBsYXRlYGAsIGBgTWl4ZWRJbnN0YW5jZXNQb2xpY3lgYCwgb3IgYGBMYXVuY2hDb25maWd1cmF0aW9uTmFtZWBgLCBkb24ndCBzcGVjaWZ5IGBgSW5zdGFuY2VJZGBgLlxuICovXG5JbnN0YW5jZUlkPzogc3RyaW5nXG5BdXRvU2NhbGluZ0dyb3VwQVJOPzogc3RyaW5nXG4vKipcbiAqIEEgbGlzdCBvZiBBdmFpbGFiaWxpdHkgWm9uZXMgd2hlcmUgaW5zdGFuY2VzIGluIHRoZSBBdXRvIFNjYWxpbmcgZ3JvdXAgY2FuIGJlIGNyZWF0ZWQuIFVzZWQgZm9yIGxhdW5jaGluZyBpbnRvIHRoZSBkZWZhdWx0IFZQQyBzdWJuZXQgaW4gZWFjaCBBdmFpbGFiaWxpdHkgWm9uZSB3aGVuIG5vdCB1c2luZyB0aGUgYGBWUENab25lSWRlbnRpZmllcmBgIHByb3BlcnR5LCBvciBmb3IgYXR0YWNoaW5nIGEgbmV0d29yayBpbnRlcmZhY2Ugd2hlbiBhbiBleGlzdGluZyBuZXR3b3JrIGludGVyZmFjZSBJRCBpcyBzcGVjaWZpZWQgaW4gYSBsYXVuY2ggdGVtcGxhdGUuXG4gKi9cbkF2YWlsYWJpbGl0eVpvbmVzPzogc3RyaW5nW11cbk5vdGlmaWNhdGlvbkNvbmZpZ3VyYXRpb24/OiBOb3RpZmljYXRpb25Db25maWd1cmF0aW9uMVxuQXZhaWxhYmlsaXR5Wm9uZURpc3RyaWJ1dGlvbj86IEF2YWlsYWJpbGl0eVpvbmVEaXN0cmlidXRpb25cbi8qKlxuICogRW5hYmxlcyB0aGUgbW9uaXRvcmluZyBvZiBncm91cCBtZXRyaWNzIG9mIGFuIEF1dG8gU2NhbGluZyBncm91cC4gQnkgZGVmYXVsdCwgdGhlc2UgbWV0cmljcyBhcmUgZGlzYWJsZWQuXG4gKi9cbk1ldHJpY3NDb2xsZWN0aW9uPzogTWV0cmljc0NvbGxlY3Rpb25bXVxuSW5zdGFuY2VNYWludGVuYW5jZVBvbGljeT86IEluc3RhbmNlTWFpbnRlbmFuY2VQb2xpY3lcbi8qKlxuICogVGhlIG1heGltdW0gc2l6ZSBvZiB0aGUgZ3JvdXAuXG4gKiAgIFdpdGggYSBtaXhlZCBpbnN0YW5jZXMgcG9saWN5IHRoYXQgdXNlcyBpbnN0YW5jZSB3ZWlnaHRpbmcsIEFtYXpvbiBFQzIgQXV0byBTY2FsaW5nIG1heSBuZWVkIHRvIGdvIGFib3ZlIGBgTWF4U2l6ZWBgIHRvIG1lZXQgeW91ciBjYXBhY2l0eSByZXF1aXJlbWVudHMuIEluIHRoaXMgZXZlbnQsIEFtYXpvbiBFQzIgQXV0byBTY2FsaW5nIHdpbGwgbmV2ZXIgZ28gYWJvdmUgYGBNYXhTaXplYGAgYnkgbW9yZSB0aGFuIHlvdXIgbGFyZ2VzdCBpbnN0YW5jZSB3ZWlnaHQgKHdlaWdodHMgdGhhdCBkZWZpbmUgaG93IG1hbnkgdW5pdHMgZWFjaCBpbnN0YW5jZSBjb250cmlidXRlcyB0byB0aGUgZGVzaXJlZCBjYXBhY2l0eSBvZiB0aGUgZ3JvdXApLlxuICovXG5NYXhTaXplOiBzdHJpbmdcbi8qKlxuICogVGhlIG1pbmltdW0gc2l6ZSBvZiB0aGUgZ3JvdXAuXG4gKi9cbk1pblNpemU6IHN0cmluZ1xuLyoqXG4gKiBBIHBvbGljeSBvciBhIGxpc3Qgb2YgcG9saWNpZXMgdGhhdCBhcmUgdXNlZCB0byBzZWxlY3QgdGhlIGluc3RhbmNlIHRvIHRlcm1pbmF0ZS4gVGhlc2UgcG9saWNpZXMgYXJlIGV4ZWN1dGVkIGluIHRoZSBvcmRlciB0aGF0IHlvdSBsaXN0IHRoZW0uIEZvciBtb3JlIGluZm9ybWF0aW9uLCBzZWUgW0NvbmZpZ3VyZSB0ZXJtaW5hdGlvbiBwb2xpY2llcyBmb3IgQW1hem9uIEVDMiBBdXRvIFNjYWxpbmddKGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9hdXRvc2NhbGluZy9lYzIvdXNlcmd1aWRlL2VjMi1hdXRvLXNjYWxpbmctdGVybWluYXRpb24tcG9saWNpZXMuaHRtbCkgaW4gdGhlICpBbWF6b24gRUMyIEF1dG8gU2NhbGluZyBVc2VyIEd1aWRlKi5cbiAqICBWYWxpZCB2YWx1ZXM6IGBgRGVmYXVsdGBgIHwgYGBBbGxvY2F0aW9uU3RyYXRlZ3lgYCB8IGBgQ2xvc2VzdFRvTmV4dEluc3RhbmNlSG91cmBgIHwgYGBOZXdlc3RJbnN0YW5jZWBgIHwgYGBPbGRlc3RJbnN0YW5jZWBgIHwgYGBPbGRlc3RMYXVuY2hDb25maWd1cmF0aW9uYGAgfCBgYE9sZGVzdExhdW5jaFRlbXBsYXRlYGAgfCBgYGFybjphd3M6bGFtYmRhOnJlZ2lvbjphY2NvdW50LWlkOmZ1bmN0aW9uOm15LWZ1bmN0aW9uOm15LWFsaWFzYGBcbiAqL1xuVGVybWluYXRpb25Qb2xpY2llcz86IHN0cmluZ1tdXG4vKipcbiAqIFRoZSBuYW1lIG9mIHRoZSBBdXRvIFNjYWxpbmcgZ3JvdXAuIFRoaXMgbmFtZSBtdXN0IGJlIHVuaXF1ZSBwZXIgUmVnaW9uIHBlciBhY2NvdW50LlxuICogIFRoZSBuYW1lIGNhbiBjb250YWluIGFueSBBU0NJSSBjaGFyYWN0ZXIgMzMgdG8gMTI2IGluY2x1ZGluZyBtb3N0IHB1bmN0dWF0aW9uIGNoYXJhY3RlcnMsIGRpZ2l0cywgYW5kIHVwcGVyIGFuZCBsb3dlcmNhc2VkIGxldHRlcnMuXG4gKiAgIFlvdSBjYW5ub3QgdXNlIGEgY29sb24gKDopIGluIHRoZSBuYW1lLlxuICovXG5BdXRvU2NhbGluZ0dyb3VwTmFtZT86IHN0cmluZ1xuLyoqXG4gKiBUaGUgdHJhZmZpYyBzb3VyY2VzIGFzc29jaWF0ZWQgd2l0aCB0aGlzIEF1dG8gU2NhbGluZyBncm91cC5cbiAqL1xuVHJhZmZpY1NvdXJjZXM/OiBUcmFmZmljU291cmNlSWRlbnRpZmllcltdXG4vKipcbiAqIFRoZSB1bml0IG9mIG1lYXN1cmVtZW50IGZvciB0aGUgdmFsdWUgc3BlY2lmaWVkIGZvciBkZXNpcmVkIGNhcGFjaXR5LiBBbWF6b24gRUMyIEF1dG8gU2NhbGluZyBzdXBwb3J0cyBgYERlc2lyZWRDYXBhY2l0eVR5cGVgYCBmb3IgYXR0cmlidXRlLWJhc2VkIGluc3RhbmNlIHR5cGUgc2VsZWN0aW9uIG9ubHkuIEZvciBtb3JlIGluZm9ybWF0aW9uLCBzZWUgW0NyZWF0ZSBhIG1peGVkIGluc3RhbmNlcyBncm91cCB1c2luZyBhdHRyaWJ1dGUtYmFzZWQgaW5zdGFuY2UgdHlwZSBzZWxlY3Rpb25dKGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9hdXRvc2NhbGluZy9lYzIvdXNlcmd1aWRlL2NyZWF0ZS1taXhlZC1pbnN0YW5jZXMtZ3JvdXAtYXR0cmlidXRlLWJhc2VkLWluc3RhbmNlLXR5cGUtc2VsZWN0aW9uLmh0bWwpIGluIHRoZSAqQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgVXNlciBHdWlkZSouXG4gKiAgQnkgZGVmYXVsdCwgQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgc3BlY2lmaWVzIGBgdW5pdHNgYCwgd2hpY2ggdHJhbnNsYXRlcyBpbnRvIG51bWJlciBvZiBpbnN0YW5jZXMuXG4gKiAgVmFsaWQgdmFsdWVzOiBgYHVuaXRzYGAgfCBgYHZjcHVgYCB8IGBgbWVtb3J5LW1pYmBgXG4gKi9cbkRlc2lyZWRDYXBhY2l0eVR5cGU/OiBzdHJpbmdcbi8qKlxuICogVGhlIG5hbWUgb2YgdGhlIHBsYWNlbWVudCBncm91cCBpbnRvIHdoaWNoIHRvIGxhdW5jaCB5b3VyIGluc3RhbmNlcy4gRm9yIG1vcmUgaW5mb3JtYXRpb24sIHNlZSBbUGxhY2VtZW50IGdyb3Vwc10oaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL0FXU0VDMi9sYXRlc3QvVXNlckd1aWRlL3BsYWNlbWVudC1ncm91cHMuaHRtbCkgaW4gdGhlICpBbWF6b24gRUMyIFVzZXIgR3VpZGUgZm9yIExpbnV4IEluc3RhbmNlcyouXG4gKiAgIEEgKmNsdXN0ZXIqIHBsYWNlbWVudCBncm91cCBpcyBhIGxvZ2ljYWwgZ3JvdXBpbmcgb2YgaW5zdGFuY2VzIHdpdGhpbiBhIHNpbmdsZSBBdmFpbGFiaWxpdHkgWm9uZS4gWW91IGNhbm5vdCBzcGVjaWZ5IG11bHRpcGxlIEF2YWlsYWJpbGl0eSBab25lcyBhbmQgYSBjbHVzdGVyIHBsYWNlbWVudCBncm91cC5cbiAqL1xuUGxhY2VtZW50R3JvdXA/OiBzdHJpbmdcbkNhcGFjaXR5UmVzZXJ2YXRpb25TcGVjaWZpY2F0aW9uPzogQ2FwYWNpdHlSZXNlcnZhdGlvblNwZWNpZmljYXRpb25cbi8qKlxuICogQSBjb21tYS1zZXBhcmF0ZWQgdmFsdWUgc3RyaW5nIG9mIG9uZSBvciBtb3JlIGhlYWx0aCBjaGVjayB0eXBlcy5cbiAqICBUaGUgdmFsaWQgdmFsdWVzIGFyZSBgYEVDMmBgLCBgYEVCU2BgLCBgYEVMQmBgLCBhbmQgYGBWUENfTEFUVElDRWBgLiBgYEVDMmBgIGlzIHRoZSBkZWZhdWx0IGhlYWx0aCBjaGVjayBhbmQgY2Fubm90IGJlIGRpc2FibGVkLiBGb3IgbW9yZSBpbmZvcm1hdGlvbiwgc2VlIFtIZWFsdGggY2hlY2tzIGZvciBpbnN0YW5jZXMgaW4gYW4gQXV0byBTY2FsaW5nIGdyb3VwXShodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vYXV0b3NjYWxpbmcvZWMyL3VzZXJndWlkZS9lYzItYXV0by1zY2FsaW5nLWhlYWx0aC1jaGVja3MuaHRtbCkgaW4gdGhlICpBbWF6b24gRUMyIEF1dG8gU2NhbGluZyBVc2VyIEd1aWRlKi5cbiAqICBPbmx5IHNwZWNpZnkgYGBFQzJgYCBpZiB5b3UgbXVzdCBjbGVhciBhIHZhbHVlIHRoYXQgd2FzIHByZXZpb3VzbHkgc2V0LlxuICovXG5IZWFsdGhDaGVja1R5cGU/OiBzdHJpbmdcbi8qKlxuICogVGhlIG1heGltdW0gYW1vdW50IG9mIHRpbWUsIGluIHNlY29uZHMsIHRoYXQgYW4gaW5zdGFuY2UgY2FuIGJlIGluIHNlcnZpY2UuIFRoZSBkZWZhdWx0IGlzIG51bGwuIElmIHNwZWNpZmllZCwgdGhlIHZhbHVlIG11c3QgYmUgZWl0aGVyIDAgb3IgYSBudW1iZXIgZXF1YWwgdG8gb3IgZ3JlYXRlciB0aGFuIDg2LDQwMCBzZWNvbmRzICgxIGRheSkuIEZvciBtb3JlIGluZm9ybWF0aW9uLCBzZWUgW1JlcGxhY2UgQXV0byBTY2FsaW5nIGluc3RhbmNlcyBiYXNlZCBvbiBtYXhpbXVtIGluc3RhbmNlIGxpZmV0aW1lXShodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vYXV0b3NjYWxpbmcvZWMyL3VzZXJndWlkZS9hc2ctbWF4LWluc3RhbmNlLWxpZmV0aW1lLmh0bWwpIGluIHRoZSAqQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgVXNlciBHdWlkZSouXG4gKi9cbk1heEluc3RhbmNlTGlmZXRpbWU/OiBudW1iZXJcbn1cbi8qKlxuICogYGBMaWZlY3ljbGVIb29rU3BlY2lmaWNhdGlvbmBgIHNwZWNpZmllcyBhIGxpZmVjeWNsZSBob29rIGZvciB0aGUgYGBMaWZlY3ljbGVIb29rU3BlY2lmaWNhdGlvbkxpc3RgYCBwcm9wZXJ0eSBvZiB0aGUgW0FXUzo6QXV0b1NjYWxpbmc6OkF1dG9TY2FsaW5nR3JvdXBdKGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9BV1NDbG91ZEZvcm1hdGlvbi9sYXRlc3QvVXNlckd1aWRlL2F3cy1yZXNvdXJjZS1hdXRvc2NhbGluZy1hdXRvc2NhbGluZ2dyb3VwLmh0bWwpIHJlc291cmNlLiBBIGxpZmVjeWNsZSBob29rIHNwZWNpZmllcyBhY3Rpb25zIHRvIHBlcmZvcm0gd2hlbiBBbWF6b24gRUMyIEF1dG8gU2NhbGluZyBsYXVuY2hlcyBvciB0ZXJtaW5hdGVzIGluc3RhbmNlcy4gXG4gKiAgRm9yIG1vcmUgaW5mb3JtYXRpb24sIHNlZSBbQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgbGlmZWN5Y2xlIGhvb2tzXShodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vYXV0b3NjYWxpbmcvZWMyL3VzZXJndWlkZS9saWZlY3ljbGUtaG9va3MuaHRtbCkgaW4gdGhlICpBbWF6b24gRUMyIEF1dG8gU2NhbGluZyBVc2VyIEd1aWRlKi4gWW91IGNhbiBmaW5kIGEgc2FtcGxlIHRlbXBsYXRlIHNuaXBwZXQgaW4gdGhlIFtFeGFtcGxlc10oaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL0FXU0Nsb3VkRm9ybWF0aW9uL2xhdGVzdC9Vc2VyR3VpZGUvYXdzLXJlc291cmNlLWFzLWxpZmVjeWNsZWhvb2suaHRtbCNhd3MtcmVzb3VyY2UtYXMtbGlmZWN5Y2xlaG9vay0tZXhhbXBsZXMpIHNlY3Rpb24gb2YgdGhlIGBgQVdTOjpBdXRvU2NhbGluZzo6TGlmZWN5Y2xlSG9va2BgIHJlc291cmNlLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIExpZmVjeWNsZUhvb2tTcGVjaWZpY2F0aW9uIHtcbi8qKlxuICogVGhlIG5hbWUgb2YgdGhlIGxpZmVjeWNsZSBob29rLlxuICovXG5MaWZlY3ljbGVIb29rTmFtZTogc3RyaW5nXG4vKipcbiAqIFRoZSBsaWZlY3ljbGUgdHJhbnNpdGlvbi4gRm9yIEF1dG8gU2NhbGluZyBncm91cHMsIHRoZXJlIGFyZSB0d28gbWFqb3IgbGlmZWN5Y2xlIHRyYW5zaXRpb25zLlxuICogICArICBUbyBjcmVhdGUgYSBsaWZlY3ljbGUgaG9vayBmb3Igc2NhbGUtb3V0IGV2ZW50cywgc3BlY2lmeSBgYGF1dG9zY2FsaW5nOkVDMl9JTlNUQU5DRV9MQVVOQ0hJTkdgYC5cbiAqICAgKyAgVG8gY3JlYXRlIGEgbGlmZWN5Y2xlIGhvb2sgZm9yIHNjYWxlLWluIGV2ZW50cywgc3BlY2lmeSBgYGF1dG9zY2FsaW5nOkVDMl9JTlNUQU5DRV9URVJNSU5BVElOR2BgLlxuICovXG5MaWZlY3ljbGVUcmFuc2l0aW9uOiBzdHJpbmdcbi8qKlxuICogVGhlIG1heGltdW0gdGltZSwgaW4gc2Vjb25kcywgdGhhdCBjYW4gZWxhcHNlIGJlZm9yZSB0aGUgbGlmZWN5Y2xlIGhvb2sgdGltZXMgb3V0LiBUaGUgcmFuZ2UgaXMgZnJvbSBgYDMwYGAgdG8gYGA3MjAwYGAgc2Vjb25kcy4gVGhlIGRlZmF1bHQgdmFsdWUgaXMgYGAzNjAwYGAgc2Vjb25kcyAoMSBob3VyKS5cbiAqL1xuSGVhcnRiZWF0VGltZW91dD86IG51bWJlclxuLyoqXG4gKiBBZGRpdGlvbmFsIGluZm9ybWF0aW9uIHRoYXQgeW91IHdhbnQgdG8gaW5jbHVkZSBhbnkgdGltZSBBbWF6b24gRUMyIEF1dG8gU2NhbGluZyBzZW5kcyBhIG1lc3NhZ2UgdG8gdGhlIG5vdGlmaWNhdGlvbiB0YXJnZXQuXG4gKi9cbk5vdGlmaWNhdGlvbk1ldGFkYXRhPzogc3RyaW5nXG4vKipcbiAqIFRoZSBhY3Rpb24gdGhlIEF1dG8gU2NhbGluZyBncm91cCB0YWtlcyB3aGVuIHRoZSBsaWZlY3ljbGUgaG9vayB0aW1lb3V0IGVsYXBzZXMgb3IgaWYgYW4gdW5leHBlY3RlZCBmYWlsdXJlIG9jY3Vycy4gVGhlIGRlZmF1bHQgdmFsdWUgaXMgYGBBQkFORE9OYGAuXG4gKiAgVmFsaWQgdmFsdWVzOiBgYENPTlRJTlVFYGAgfCBgYEFCQU5ET05gYFxuICovXG5EZWZhdWx0UmVzdWx0Pzogc3RyaW5nXG4vKipcbiAqIFRoZSBBbWF6b24gUmVzb3VyY2UgTmFtZSAoQVJOKSBvZiB0aGUgbm90aWZpY2F0aW9uIHRhcmdldCB0aGF0IEFtYXpvbiBFQzIgQXV0byBTY2FsaW5nIHNlbmRzIG5vdGlmaWNhdGlvbnMgdG8gd2hlbiBhbiBpbnN0YW5jZSBpcyBpbiBhIHdhaXQgc3RhdGUgZm9yIHRoZSBsaWZlY3ljbGUgaG9vay4gWW91IGNhbiBzcGVjaWZ5IGFuIEFtYXpvbiBTTlMgdG9waWMgb3IgYW4gQW1hem9uIFNRUyBxdWV1ZS5cbiAqL1xuTm90aWZpY2F0aW9uVGFyZ2V0QVJOPzogc3RyaW5nXG4vKipcbiAqIFRoZSBBUk4gb2YgdGhlIElBTSByb2xlIHRoYXQgYWxsb3dzIHRoZSBBdXRvIFNjYWxpbmcgZ3JvdXAgdG8gcHVibGlzaCB0byB0aGUgc3BlY2lmaWVkIG5vdGlmaWNhdGlvbiB0YXJnZXQuIEZvciBpbmZvcm1hdGlvbiBhYm91dCBjcmVhdGluZyB0aGlzIHJvbGUsIHNlZSBbUHJlcGFyZSB0byBhZGQgYSBsaWZlY3ljbGUgaG9vayB0byB5b3VyIEF1dG8gU2NhbGluZyBncm91cF0oaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL2F1dG9zY2FsaW5nL2VjMi91c2VyZ3VpZGUvcHJlcGFyZS1mb3ItbGlmZWN5Y2xlLW5vdGlmaWNhdGlvbnMuaHRtbCkgaW4gdGhlICpBbWF6b24gRUMyIEF1dG8gU2NhbGluZyBVc2VyIEd1aWRlKi5cbiAqICBWYWxpZCBvbmx5IGlmIHRoZSBub3RpZmljYXRpb24gdGFyZ2V0IGlzIGFuIEFtYXpvbiBTTlMgdG9waWMgb3IgYW4gQW1hem9uIFNRUyBxdWV1ZS5cbiAqL1xuUm9sZUFSTj86IHN0cmluZ1xufVxuLyoqXG4gKiBUaGUgQXZhaWxhYmlsaXR5IFpvbmUgaW1wYWlybWVudCBwb2xpY3kuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQXZhaWxhYmlsaXR5Wm9uZUltcGFpcm1lbnRQb2xpY3kge1xuLyoqXG4gKiBJZiBgYHRydWVgYCwgZW5hYmxlIHpvbmFsIHNoaWZ0IGZvciB5b3VyIEF1dG8gU2NhbGluZyBncm91cC5cbiAqL1xuWm9uYWxTaGlmdEVuYWJsZWQ6IGJvb2xlYW5cbi8qKlxuICogU3BlY2lmaWVzIHRoZSBoZWFsdGggY2hlY2sgYmVoYXZpb3IgZm9yIHRoZSBpbXBhaXJlZCBBdmFpbGFiaWxpdHkgWm9uZSBpbiBhbiBhY3RpdmUgem9uYWwgc2hpZnQuIElmIHlvdSBzZWxlY3QgYGBSZXBsYWNlIHVuaGVhbHRoeWBgLCBpbnN0YW5jZXMgdGhhdCBhcHBlYXIgdW5oZWFsdGh5IHdpbGwgYmUgcmVwbGFjZWQgaW4gYWxsIEF2YWlsYWJpbGl0eSBab25lcy4gSWYgeW91IHNlbGVjdCBgYElnbm9yZSB1bmhlYWx0aHlgYCwgaW5zdGFuY2VzIHdpbGwgbm90IGJlIHJlcGxhY2VkIGluIHRoZSBBdmFpbGFiaWxpdHkgWm9uZSB3aXRoIHRoZSBhY3RpdmUgem9uYWwgc2hpZnQuIEZvciBtb3JlIGluZm9ybWF0aW9uLCBzZWUgW0F1dG8gU2NhbGluZyBncm91cCB6b25hbCBzaGlmdF0oaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL2F1dG9zY2FsaW5nL2VjMi91c2VyZ3VpZGUvZWMyLWF1dG8tc2NhbGluZy16b25hbC1zaGlmdC5odG1sKSBpbiB0aGUgKkFtYXpvbiBFQzIgQXV0byBTY2FsaW5nIFVzZXIgR3VpZGUqLlxuICovXG5JbXBhaXJlZFpvbmVIZWFsdGhDaGVja0JlaGF2aW9yOiAoXCJJZ25vcmVVbmhlYWx0aHlcIiB8IFwiUmVwbGFjZVVuaGVhbHRoeVwiKVxufVxuLyoqXG4gKiBBIHN0cnVjdHVyZSB0aGF0IHNwZWNpZmllcyBhbiBBbWF6b24gU05TIG5vdGlmaWNhdGlvbiBjb25maWd1cmF0aW9uIGZvciB0aGUgYGBOb3RpZmljYXRpb25Db25maWd1cmF0aW9uc2BgIHByb3BlcnR5IG9mIHRoZSBbQVdTOjpBdXRvU2NhbGluZzo6QXV0b1NjYWxpbmdHcm91cF0oaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL0FXU0Nsb3VkRm9ybWF0aW9uL2xhdGVzdC9Vc2VyR3VpZGUvYXdzLXJlc291cmNlLWF1dG9zY2FsaW5nLWF1dG9zY2FsaW5nZ3JvdXAuaHRtbCkgcmVzb3VyY2UuXG4gKiAgRm9yIGFuIGV4YW1wbGUgdGVtcGxhdGUgc25pcHBldCwgc2VlIFtDb25maWd1cmUgQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgcmVzb3VyY2VzXShodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vQVdTQ2xvdWRGb3JtYXRpb24vbGF0ZXN0L1VzZXJHdWlkZS9xdWlja3JlZi1lYzItYXV0by1zY2FsaW5nLmh0bWwpLlxuICogIEZvciBtb3JlIGluZm9ybWF0aW9uLCBzZWUgW0dldCBBbWF6b24gU05TIG5vdGlmaWNhdGlvbnMgd2hlbiB5b3VyIEF1dG8gU2NhbGluZyBncm91cCBzY2FsZXNdKGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9hdXRvc2NhbGluZy9lYzIvdXNlcmd1aWRlL0FTR2V0dGluZ05vdGlmaWNhdGlvbnMuaHRtbCkgaW4gdGhlICpBbWF6b24gRUMyIEF1dG8gU2NhbGluZyBVc2VyIEd1aWRlKi5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBOb3RpZmljYXRpb25Db25maWd1cmF0aW9uIHtcbi8qKlxuICogVGhlIEFtYXpvbiBSZXNvdXJjZSBOYW1lIChBUk4pIG9mIHRoZSBBbWF6b24gU05TIHRvcGljLlxuICovXG5Ub3BpY0FSTjogKHN0cmluZyB8IHN0cmluZ1tdKVxuLyoqXG4gKiBBIGxpc3Qgb2YgZXZlbnQgdHlwZXMgdGhhdCBzZW5kIGEgbm90aWZpY2F0aW9uLiBFdmVudCB0eXBlcyBjYW4gaW5jbHVkZSBhbnkgb2YgdGhlIGZvbGxvd2luZyB0eXBlcy4gXG4gKiAgICpBbGxvd2VkIHZhbHVlcyo6XG4gKiAgICsgICBgYGF1dG9zY2FsaW5nOkVDMl9JTlNUQU5DRV9MQVVOQ0hgYCBcbiAqICAgKyAgIGBgYXV0b3NjYWxpbmc6RUMyX0lOU1RBTkNFX0xBVU5DSF9FUlJPUmBgIFxuICogICArICAgYGBhdXRvc2NhbGluZzpFQzJfSU5TVEFOQ0VfVEVSTUlOQVRFYGAgXG4gKiAgICsgICBgYGF1dG9zY2FsaW5nOkVDMl9JTlNUQU5DRV9URVJNSU5BVEVfRVJST1JgYCBcbiAqICAgKyAgIGBgYXV0b3NjYWxpbmc6VEVTVF9OT1RJRklDQVRJT05gYFxuICovXG5Ob3RpZmljYXRpb25UeXBlcz86IHN0cmluZ1tdXG59XG4vKipcbiAqIEluZm9ybWF0aW9uIHVzZWQgdG8gc3BlY2lmeSB0aGUgbGF1bmNoIHRlbXBsYXRlIGFuZCB2ZXJzaW9uIHRvIHVzZSB0byBsYXVuY2ggaW5zdGFuY2VzLiBZb3UgY2FuIGFsdGVybmF0aXZlbHkgYXNzb2NpYXRlIGEgbGF1bmNoIHRlbXBsYXRlIHRvIHRoZSBBdXRvIFNjYWxpbmcgZ3JvdXAgYnkgc3BlY2lmeWluZyBhIGBgTWl4ZWRJbnN0YW5jZXNQb2xpY3lgYC4gRm9yIG1vcmUgaW5mb3JtYXRpb24gYWJvdXQgY3JlYXRpbmcgbGF1bmNoIHRlbXBsYXRlcywgc2VlIFtDcmVhdGUgYSBsYXVuY2ggdGVtcGxhdGUgZm9yIGFuIEF1dG8gU2NhbGluZyBncm91cF0oaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL2F1dG9zY2FsaW5nL2VjMi91c2VyZ3VpZGUvY3JlYXRlLWxhdW5jaC10ZW1wbGF0ZS5odG1sKSBpbiB0aGUgKkFtYXpvbiBFQzIgQXV0byBTY2FsaW5nIFVzZXIgR3VpZGUqLlxuICogIElmIHlvdSBvbWl0IHRoaXMgcHJvcGVydHksIHlvdSBtdXN0IHNwZWNpZnkgYGBNaXhlZEluc3RhbmNlc1BvbGljeWBgLCBgYExhdW5jaENvbmZpZ3VyYXRpb25OYW1lYGAsIG9yIGBgSW5zdGFuY2VJZGBgLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIExhdW5jaFRlbXBsYXRlU3BlY2lmaWNhdGlvbiB7XG4vKipcbiAqIFRoZSBuYW1lIG9mIHRoZSBsYXVuY2ggdGVtcGxhdGUuXG4gKiAgWW91IG11c3Qgc3BlY2lmeSB0aGUgYGBMYXVuY2hUZW1wbGF0ZU5hbWVgYCBvciB0aGUgYGBMYXVuY2hUZW1wbGF0ZUlEYGAsIGJ1dCBub3QgYm90aC5cbiAqL1xuTGF1bmNoVGVtcGxhdGVOYW1lPzogc3RyaW5nXG4vKipcbiAqIFRoZSB2ZXJzaW9uIG51bWJlciBvZiB0aGUgbGF1bmNoIHRlbXBsYXRlLlxuICogIFNwZWNpZnlpbmcgYGAkTGF0ZXN0YGAgb3IgYGAkRGVmYXVsdGBgIGZvciB0aGUgdGVtcGxhdGUgdmVyc2lvbiBudW1iZXIgaXMgbm90IHN1cHBvcnRlZC4gSG93ZXZlciwgeW91IGNhbiBzcGVjaWZ5IGBgTGF0ZXN0VmVyc2lvbk51bWJlcmBgIG9yIGBgRGVmYXVsdFZlcnNpb25OdW1iZXJgYCB1c2luZyB0aGUgYGBGbjo6R2V0QXR0YGAgaW50cmluc2ljIGZ1bmN0aW9uLiBGb3IgbW9yZSBpbmZvcm1hdGlvbiwgc2VlIFtGbjo6R2V0QXR0XShodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vQVdTQ2xvdWRGb3JtYXRpb24vbGF0ZXN0L1VzZXJHdWlkZS9pbnRyaW5zaWMtZnVuY3Rpb24tcmVmZXJlbmNlLWdldGF0dC5odG1sKS5cbiAqICAgRm9yIGFuIGV4YW1wbGUgb2YgdXNpbmcgdGhlIGBgRm46OkdldEF0dGBgIGZ1bmN0aW9uLCBzZWUgdGhlIFtFeGFtcGxlc10oaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL0FXU0Nsb3VkRm9ybWF0aW9uL2xhdGVzdC9Vc2VyR3VpZGUvYXdzLXJlc291cmNlLWF1dG9zY2FsaW5nLWF1dG9zY2FsaW5nZ3JvdXAuaHRtbCNhd3MtcmVzb3VyY2UtYXV0b3NjYWxpbmctYXV0b3NjYWxpbmdncm91cC0tZXhhbXBsZXMpIHNlY3Rpb24gb2YgdGhlIGBgQVdTOjpBdXRvU2NhbGluZzo6QXV0b1NjYWxpbmdHcm91cGBgIHJlc291cmNlLlxuICovXG5WZXJzaW9uOiBzdHJpbmdcbi8qKlxuICogVGhlIElEIG9mIHRoZSBsYXVuY2ggdGVtcGxhdGUuXG4gKiAgWW91IG11c3Qgc3BlY2lmeSB0aGUgYGBMYXVuY2hUZW1wbGF0ZUlEYGAgb3IgdGhlIGBgTGF1bmNoVGVtcGxhdGVOYW1lYGAsIGJ1dCBub3QgYm90aC5cbiAqL1xuTGF1bmNoVGVtcGxhdGVJZD86IHN0cmluZ1xufVxuLyoqXG4gKiBBbiBlbWJlZGRlZCBvYmplY3QgdGhhdCBzcGVjaWZpZXMgYSBtaXhlZCBpbnN0YW5jZXMgcG9saWN5LlxuICogIFRoZSBwb2xpY3kgaW5jbHVkZXMgcHJvcGVydGllcyB0aGF0IG5vdCBvbmx5IGRlZmluZSB0aGUgZGlzdHJpYnV0aW9uIG9mIE9uLURlbWFuZCBJbnN0YW5jZXMgYW5kIFNwb3QgSW5zdGFuY2VzLCB0aGUgbWF4aW11bSBwcmljZSB0byBwYXkgZm9yIFNwb3QgSW5zdGFuY2VzIChvcHRpb25hbCksIGFuZCBob3cgdGhlIEF1dG8gU2NhbGluZyBncm91cCBhbGxvY2F0ZXMgaW5zdGFuY2UgdHlwZXMgdG8gZnVsZmlsbCBPbi1EZW1hbmQgYW5kIFNwb3QgY2FwYWNpdGllcywgYnV0IGFsc28gdGhlIHByb3BlcnRpZXMgdGhhdCBzcGVjaWZ5IHRoZSBpbnN0YW5jZSBjb25maWd1cmF0aW9uIGluZm9ybWF0aW9u4oCUdGhlIGxhdW5jaCB0ZW1wbGF0ZSBhbmQgaW5zdGFuY2UgdHlwZXMuIFRoZSBwb2xpY3kgY2FuIGFsc28gaW5jbHVkZSBhIHdlaWdodCBmb3IgZWFjaCBpbnN0YW5jZSB0eXBlIGFuZCBkaWZmZXJlbnQgbGF1bmNoIHRlbXBsYXRlcyBmb3IgaW5kaXZpZHVhbCBpbnN0YW5jZSB0eXBlcy5cbiAqICBGb3IgbW9yZSBpbmZvcm1hdGlvbiwgc2VlIFtBdXRvIFNjYWxpbmcgZ3JvdXBzIHdpdGggbXVsdGlwbGUgaW5zdGFuY2UgdHlwZXMgYW5kIHB1cmNoYXNlIG9wdGlvbnNdKGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9hdXRvc2NhbGluZy9lYzIvdXNlcmd1aWRlL2VjMi1hdXRvLXNjYWxpbmctbWl4ZWQtaW5zdGFuY2VzLWdyb3Vwcy5odG1sKSBpbiB0aGUgKkFtYXpvbiBFQzIgQXV0byBTY2FsaW5nIFVzZXIgR3VpZGUqLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIE1peGVkSW5zdGFuY2VzUG9saWN5IHtcbkluc3RhbmNlc0Rpc3RyaWJ1dGlvbj86IEluc3RhbmNlc0Rpc3RyaWJ1dGlvblxuTGF1bmNoVGVtcGxhdGU6IExhdW5jaFRlbXBsYXRlXG59XG4vKipcbiAqIFRoZSBpbnN0YW5jZXMgZGlzdHJpYnV0aW9uLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIEluc3RhbmNlc0Rpc3RyaWJ1dGlvbiB7XG4vKipcbiAqIFRoZSBhbGxvY2F0aW9uIHN0cmF0ZWd5IHRvIGFwcGx5IHRvIHlvdXIgT24tRGVtYW5kIEluc3RhbmNlcyB3aGVuIHRoZXkgYXJlIGxhdW5jaGVkLiBQb3NzaWJsZSBpbnN0YW5jZSB0eXBlcyBhcmUgZGV0ZXJtaW5lZCBieSB0aGUgbGF1bmNoIHRlbXBsYXRlIG92ZXJyaWRlcyB0aGF0IHlvdSBzcGVjaWZ5LlxuICogIFRoZSBmb2xsb3dpbmcgbGlzdHMgdGhlIHZhbGlkIHZhbHVlczpcbiAqICAgKyBsb3dlc3QtcHJpY2UgVXNlcyBwcmljZSB0byBkZXRlcm1pbmUgd2hpY2ggaW5zdGFuY2UgdHlwZXMgYXJlIHRoZSBoaWdoZXN0IHByaW9yaXR5LCBsYXVuY2hpbmcgdGhlIGxvd2VzdCBwcmljZWQgaW5zdGFuY2UgdHlwZXMgd2l0aGluIGFuIEF2YWlsYWJpbGl0eSBab25lIGZpcnN0LiBUaGlzIGlzIHRoZSBkZWZhdWx0IHZhbHVlIGZvciBBdXRvIFNjYWxpbmcgZ3JvdXBzIHRoYXQgc3BlY2lmeSBJbnN0YW5jZVJlcXVpcmVtZW50cy4gKyBwcmlvcml0aXplZCBZb3Ugc2V0IHRoZSBvcmRlciBvZiBpbnN0YW5jZSB0eXBlcyBmb3IgdGhlIGxhdW5jaCB0ZW1wbGF0ZSBvdmVycmlkZXMgZnJvbSBoaWdoZXN0IHRvIGxvd2VzdCBwcmlvcml0eSAoZnJvbSBmaXJzdCB0byBsYXN0IGluIHRoZSBsaXN0KS4gQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgbGF1bmNoZXMgeW91ciBoaWdoZXN0IHByaW9yaXR5IGluc3RhbmNlIHR5cGVzIGZpcnN0LiBJZiBhbGwgeW91ciBPbi1EZW1hbmQgY2FwYWNpdHkgY2Fubm90IGJlIGZ1bGZpbGxlZCB1c2luZyB5b3VyIGhpZ2hlc3QgcHJpb3JpdHkgaW5zdGFuY2UgdHlwZSwgdGhlbiBBbWF6b24gRUMyIEF1dG8gU2NhbGluZyBsYXVuY2hlcyB0aGUgcmVtYWluaW5nIGNhcGFjaXR5IHVzaW5nIHRoZSBzZWNvbmQgcHJpb3JpdHkgaW5zdGFuY2UgdHlwZSwgYW5kIHNvIG9uLiBUaGlzIGlzIHRoZSBkZWZhdWx0IHZhbHVlIGZvciBBdXRvIFNjYWxpbmcgZ3JvdXBzIHRoYXQgZG9uJ3Qgc3BlY2lmeSBJbnN0YW5jZVJlcXVpcmVtZW50cyBhbmQgY2Fubm90IGJlIHVzZWQgZm9yIGdyb3VwcyB0aGF0IGRvLlxuICovXG5PbkRlbWFuZEFsbG9jYXRpb25TdHJhdGVneT86IHN0cmluZ1xuLyoqXG4gKiBUaGUgbWluaW11bSBhbW91bnQgb2YgdGhlIEF1dG8gU2NhbGluZyBncm91cCdzIGNhcGFjaXR5IHRoYXQgbXVzdCBiZSBmdWxmaWxsZWQgYnkgT24tRGVtYW5kIEluc3RhbmNlcy4gVGhpcyBiYXNlIHBvcnRpb24gaXMgbGF1bmNoZWQgZmlyc3QgYXMgeW91ciBncm91cCBzY2FsZXMuXG4gKiAgVGhpcyBudW1iZXIgaGFzIHRoZSBzYW1lIHVuaXQgb2YgbWVhc3VyZW1lbnQgYXMgdGhlIGdyb3VwJ3MgZGVzaXJlZCBjYXBhY2l0eS4gSWYgeW91IGNoYW5nZSB0aGUgZGVmYXVsdCB1bml0IG9mIG1lYXN1cmVtZW50IChudW1iZXIgb2YgaW5zdGFuY2VzKSBieSBzcGVjaWZ5aW5nIHdlaWdodGVkIGNhcGFjaXR5IHZhbHVlcyBpbiB5b3VyIGxhdW5jaCB0ZW1wbGF0ZSBvdmVycmlkZXMgbGlzdCwgb3IgYnkgY2hhbmdpbmcgdGhlIGRlZmF1bHQgZGVzaXJlZCBjYXBhY2l0eSB0eXBlIHNldHRpbmcgb2YgdGhlIGdyb3VwLCB5b3UgbXVzdCBzcGVjaWZ5IHRoaXMgbnVtYmVyIHVzaW5nIHRoZSBzYW1lIHVuaXQgb2YgbWVhc3VyZW1lbnQuXG4gKiAgRGVmYXVsdDogMFxuICogICBBbiB1cGRhdGUgdG8gdGhpcyBzZXR0aW5nIG1lYW5zIGEgZ3JhZHVhbCByZXBsYWNlbWVudCBvZiBpbnN0YW5jZXMgdG8gYWRqdXN0IHRoZSBjdXJyZW50IE9uLURlbWFuZCBJbnN0YW5jZSBsZXZlbHMuIFdoZW4gcmVwbGFjaW5nIGluc3RhbmNlcywgQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgbGF1bmNoZXMgbmV3IGluc3RhbmNlcyBiZWZvcmUgdGVybWluYXRpbmcgdGhlIHByZXZpb3VzIG9uZXMuXG4gKi9cbk9uRGVtYW5kQmFzZUNhcGFjaXR5PzogbnVtYmVyXG4vKipcbiAqIENvbnRyb2xzIHRoZSBwZXJjZW50YWdlcyBvZiBPbi1EZW1hbmQgSW5zdGFuY2VzIGFuZCBTcG90IEluc3RhbmNlcyBmb3IgeW91ciBhZGRpdGlvbmFsIGNhcGFjaXR5IGJleW9uZCBgYE9uRGVtYW5kQmFzZUNhcGFjaXR5YGAuIEV4cHJlc3NlZCBhcyBhIG51bWJlciAoZm9yIGV4YW1wbGUsIDIwIHNwZWNpZmllcyAyMCUgT24tRGVtYW5kIEluc3RhbmNlcywgODAlIFNwb3QgSW5zdGFuY2VzKS4gSWYgc2V0IHRvIDEwMCwgb25seSBPbi1EZW1hbmQgSW5zdGFuY2VzIGFyZSB1c2VkLlxuICogIERlZmF1bHQ6IDEwMFxuICogICBBbiB1cGRhdGUgdG8gdGhpcyBzZXR0aW5nIG1lYW5zIGEgZ3JhZHVhbCByZXBsYWNlbWVudCBvZiBpbnN0YW5jZXMgdG8gYWRqdXN0IHRoZSBjdXJyZW50IE9uLURlbWFuZCBhbmQgU3BvdCBJbnN0YW5jZSBsZXZlbHMgZm9yIHlvdXIgYWRkaXRpb25hbCBjYXBhY2l0eSBoaWdoZXIgdGhhbiB0aGUgYmFzZSBjYXBhY2l0eS4gV2hlbiByZXBsYWNpbmcgaW5zdGFuY2VzLCBBbWF6b24gRUMyIEF1dG8gU2NhbGluZyBsYXVuY2hlcyBuZXcgaW5zdGFuY2VzIGJlZm9yZSB0ZXJtaW5hdGluZyB0aGUgcHJldmlvdXMgb25lcy5cbiAqL1xuT25EZW1hbmRQZXJjZW50YWdlQWJvdmVCYXNlQ2FwYWNpdHk/OiBudW1iZXJcbi8qKlxuICogVGhlIG51bWJlciBvZiBTcG90IEluc3RhbmNlIHBvb2xzIGFjcm9zcyB3aGljaCB0byBhbGxvY2F0ZSB5b3VyIFNwb3QgSW5zdGFuY2VzLiBUaGUgU3BvdCBwb29scyBhcmUgZGV0ZXJtaW5lZCBmcm9tIHRoZSBkaWZmZXJlbnQgaW5zdGFuY2UgdHlwZXMgaW4gdGhlIG92ZXJyaWRlcy4gVmFsaWQgb25seSB3aGVuIHRoZSBgYFNwb3RBbGxvY2F0aW9uU3RyYXRlZ3lgYCBpcyBgYGxvd2VzdC1wcmljZWBgLiBWYWx1ZSBtdXN0IGJlIGluIHRoZSByYW5nZSBvZiAx4oCTMjAuXG4gKiAgRGVmYXVsdDogMlxuICovXG5TcG90SW5zdGFuY2VQb29scz86IG51bWJlclxuLyoqXG4gKiBUaGUgYWxsb2NhdGlvbiBzdHJhdGVneSB0byBhcHBseSB0byB5b3VyIFNwb3QgSW5zdGFuY2VzIHdoZW4gdGhleSBhcmUgbGF1bmNoZWQuIFBvc3NpYmxlIGluc3RhbmNlIHR5cGVzIGFyZSBkZXRlcm1pbmVkIGJ5IHRoZSBsYXVuY2ggdGVtcGxhdGUgb3ZlcnJpZGVzIHRoYXQgeW91IHNwZWNpZnkuXG4gKiAgVGhlIGZvbGxvd2luZyBsaXN0cyB0aGUgdmFsaWQgdmFsdWVzOlxuICogICArIGNhcGFjaXR5LW9wdGltaXplZCBSZXF1ZXN0cyBTcG90IEluc3RhbmNlcyB1c2luZyBwb29scyB0aGF0IGFyZSBvcHRpbWFsbHkgY2hvc2VuIGJhc2VkIG9uIHRoZSBhdmFpbGFibGUgU3BvdCBjYXBhY2l0eS4gVGhpcyBzdHJhdGVneSBoYXMgdGhlIGxvd2VzdCByaXNrIG9mIGludGVycnVwdGlvbi4gVG8gZ2l2ZSBjZXJ0YWluIGluc3RhbmNlIHR5cGVzIGEgaGlnaGVyIGNoYW5jZSBvZiBsYXVuY2hpbmcgZmlyc3QsIHVzZSBjYXBhY2l0eS1vcHRpbWl6ZWQtcHJpb3JpdGl6ZWQuICsgY2FwYWNpdHktb3B0aW1pemVkLXByaW9yaXRpemVkIFlvdSBzZXQgdGhlIG9yZGVyIG9mIGluc3RhbmNlIHR5cGVzIGZvciB0aGUgbGF1bmNoIHRlbXBsYXRlIG92ZXJyaWRlcyBmcm9tIGhpZ2hlc3QgdG8gbG93ZXN0IHByaW9yaXR5IChmcm9tIGZpcnN0IHRvIGxhc3QgaW4gdGhlIGxpc3QpLiBBbWF6b24gRUMyIEF1dG8gU2NhbGluZyBob25vcnMgdGhlIGluc3RhbmNlIHR5cGUgcHJpb3JpdGllcyBvbiBhIGJlc3QgZWZmb3J0IGJhc2lzIGJ1dCBvcHRpbWl6ZXMgZm9yIGNhcGFjaXR5IGZpcnN0LiBOb3RlIHRoYXQgaWYgdGhlIE9uLURlbWFuZCBhbGxvY2F0aW9uIHN0cmF0ZWd5IGlzIHNldCB0byBwcmlvcml0aXplZCwgdGhlIHNhbWUgcHJpb3JpdHkgaXMgYXBwbGllZCB3aGVuIGZ1bGZpbGxpbmcgT24tRGVtYW5kIGNhcGFjaXR5LiBUaGlzIGlzIG5vdCBhIHZhbGlkIHZhbHVlIGZvciBBdXRvIFNjYWxpbmcgZ3JvdXBzIHRoYXQgc3BlY2lmeSBJbnN0YW5jZVJlcXVpcmVtZW50cy4gKyBsb3dlc3QtcHJpY2UgUmVxdWVzdHMgU3BvdCBJbnN0YW5jZXMgdXNpbmcgdGhlIGxvd2VzdCBwcmljZWQgcG9vbHMgd2l0aGluIGFuIEF2YWlsYWJpbGl0eSBab25lLCBhY3Jvc3MgdGhlIG51bWJlciBvZiBTcG90IHBvb2xzIHRoYXQgeW91IHNwZWNpZnkgZm9yIHRoZSBTcG90SW5zdGFuY2VQb29scyBwcm9wZXJ0eS4gVG8gZW5zdXJlIHRoYXQgeW91ciBkZXNpcmVkIGNhcGFjaXR5IGlzIG1ldCwgeW91IG1pZ2h0IHJlY2VpdmUgU3BvdCBJbnN0YW5jZXMgZnJvbSBzZXZlcmFsIHBvb2xzLiBUaGlzIGlzIHRoZSBkZWZhdWx0IHZhbHVlLCBidXQgaXQgbWlnaHQgbGVhZCB0byBoaWdoIGludGVycnVwdGlvbiByYXRlcyBiZWNhdXNlIHRoaXMgc3RyYXRlZ3kgb25seSBjb25zaWRlcnMgaW5zdGFuY2UgcHJpY2UgYW5kIG5vdCBhdmFpbGFibGUgY2FwYWNpdHkuICsgcHJpY2UtY2FwYWNpdHktb3B0aW1pemVkIChyZWNvbW1lbmRlZCkgVGhlIHByaWNlIGFuZCBjYXBhY2l0eSBvcHRpbWl6ZWQgYWxsb2NhdGlvbiBzdHJhdGVneSBsb29rcyBhdCBib3RoIHByaWNlIGFuZCBjYXBhY2l0eSB0byBzZWxlY3QgdGhlIFNwb3QgSW5zdGFuY2UgcG9vbHMgdGhhdCBhcmUgdGhlIGxlYXN0IGxpa2VseSB0byBiZSBpbnRlcnJ1cHRlZCBhbmQgaGF2ZSB0aGUgbG93ZXN0IHBvc3NpYmxlIHByaWNlLlxuICovXG5TcG90QWxsb2NhdGlvblN0cmF0ZWd5Pzogc3RyaW5nXG4vKipcbiAqIFRoZSBtYXhpbXVtIHByaWNlIHBlciB1bml0IGhvdXIgdGhhdCB5b3UgYXJlIHdpbGxpbmcgdG8gcGF5IGZvciBhIFNwb3QgSW5zdGFuY2UuIElmIHlvdXIgbWF4aW11bSBwcmljZSBpcyBsb3dlciB0aGFuIHRoZSBTcG90IHByaWNlIGZvciB0aGUgaW5zdGFuY2UgdHlwZXMgdGhhdCB5b3Ugc2VsZWN0ZWQsIHlvdXIgU3BvdCBJbnN0YW5jZXMgYXJlIG5vdCBsYXVuY2hlZC4gV2UgZG8gbm90IHJlY29tbWVuZCBzcGVjaWZ5aW5nIGEgbWF4aW11bSBwcmljZSBiZWNhdXNlIGl0IGNhbiBsZWFkIHRvIGluY3JlYXNlZCBpbnRlcnJ1cHRpb25zLiBXaGVuIFNwb3QgSW5zdGFuY2VzIGxhdW5jaCwgeW91IHBheSB0aGUgY3VycmVudCBTcG90IHByaWNlLiBUbyByZW1vdmUgYSBtYXhpbXVtIHByaWNlIHRoYXQgeW91IHByZXZpb3VzbHkgc2V0LCBpbmNsdWRlIHRoZSBwcm9wZXJ0eSBidXQgc3BlY2lmeSBhbiBlbXB0eSBzdHJpbmcgKFwiXCIpIGZvciB0aGUgdmFsdWUuXG4gKiAgIElmIHlvdSBzcGVjaWZ5IGEgbWF4aW11bSBwcmljZSwgeW91ciBpbnN0YW5jZXMgd2lsbCBiZSBpbnRlcnJ1cHRlZCBtb3JlIGZyZXF1ZW50bHkgdGhhbiBpZiB5b3UgZG8gbm90IHNwZWNpZnkgb25lLlxuICogICBWYWxpZCBSYW5nZTogTWluaW11bSB2YWx1ZSBvZiAwLjAwMVxuICovXG5TcG90TWF4UHJpY2U/OiBzdHJpbmdcbn1cbi8qKlxuICogT25lIG9yIG1vcmUgbGF1bmNoIHRlbXBsYXRlcyBhbmQgdGhlIGluc3RhbmNlIHR5cGVzIChvdmVycmlkZXMpIHRoYXQgYXJlIHVzZWQgdG8gbGF1bmNoIEVDMiBpbnN0YW5jZXMgdG8gZnVsZmlsbCBPbi1EZW1hbmQgYW5kIFNwb3QgY2FwYWNpdGllcy5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBMYXVuY2hUZW1wbGF0ZSB7XG5MYXVuY2hUZW1wbGF0ZVNwZWNpZmljYXRpb246IExhdW5jaFRlbXBsYXRlU3BlY2lmaWNhdGlvbjFcbi8qKlxuICogQW55IHByb3BlcnRpZXMgdGhhdCB5b3Ugc3BlY2lmeSBvdmVycmlkZSB0aGUgc2FtZSBwcm9wZXJ0aWVzIGluIHRoZSBsYXVuY2ggdGVtcGxhdGUuXG4gKi9cbk92ZXJyaWRlcz86IExhdW5jaFRlbXBsYXRlT3ZlcnJpZGVzW11cbn1cbi8qKlxuICogVGhlIGxhdW5jaCB0ZW1wbGF0ZS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBMYXVuY2hUZW1wbGF0ZVNwZWNpZmljYXRpb24xIHtcbi8qKlxuICogVGhlIG5hbWUgb2YgdGhlIGxhdW5jaCB0ZW1wbGF0ZS5cbiAqICBZb3UgbXVzdCBzcGVjaWZ5IHRoZSBgYExhdW5jaFRlbXBsYXRlTmFtZWBgIG9yIHRoZSBgYExhdW5jaFRlbXBsYXRlSURgYCwgYnV0IG5vdCBib3RoLlxuICovXG5MYXVuY2hUZW1wbGF0ZU5hbWU/OiBzdHJpbmdcbi8qKlxuICogVGhlIHZlcnNpb24gbnVtYmVyIG9mIHRoZSBsYXVuY2ggdGVtcGxhdGUuXG4gKiAgU3BlY2lmeWluZyBgYCRMYXRlc3RgYCBvciBgYCREZWZhdWx0YGAgZm9yIHRoZSB0ZW1wbGF0ZSB2ZXJzaW9uIG51bWJlciBpcyBub3Qgc3VwcG9ydGVkLiBIb3dldmVyLCB5b3UgY2FuIHNwZWNpZnkgYGBMYXRlc3RWZXJzaW9uTnVtYmVyYGAgb3IgYGBEZWZhdWx0VmVyc2lvbk51bWJlcmBgIHVzaW5nIHRoZSBgYEZuOjpHZXRBdHRgYCBpbnRyaW5zaWMgZnVuY3Rpb24uIEZvciBtb3JlIGluZm9ybWF0aW9uLCBzZWUgW0ZuOjpHZXRBdHRdKGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9BV1NDbG91ZEZvcm1hdGlvbi9sYXRlc3QvVXNlckd1aWRlL2ludHJpbnNpYy1mdW5jdGlvbi1yZWZlcmVuY2UtZ2V0YXR0Lmh0bWwpLlxuICogICBGb3IgYW4gZXhhbXBsZSBvZiB1c2luZyB0aGUgYGBGbjo6R2V0QXR0YGAgZnVuY3Rpb24sIHNlZSB0aGUgW0V4YW1wbGVzXShodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vQVdTQ2xvdWRGb3JtYXRpb24vbGF0ZXN0L1VzZXJHdWlkZS9hd3MtcmVzb3VyY2UtYXV0b3NjYWxpbmctYXV0b3NjYWxpbmdncm91cC5odG1sI2F3cy1yZXNvdXJjZS1hdXRvc2NhbGluZy1hdXRvc2NhbGluZ2dyb3VwLS1leGFtcGxlcykgc2VjdGlvbiBvZiB0aGUgYGBBV1M6OkF1dG9TY2FsaW5nOjpBdXRvU2NhbGluZ0dyb3VwYGAgcmVzb3VyY2UuXG4gKi9cblZlcnNpb246IHN0cmluZ1xuLyoqXG4gKiBUaGUgSUQgb2YgdGhlIGxhdW5jaCB0ZW1wbGF0ZS5cbiAqICBZb3UgbXVzdCBzcGVjaWZ5IHRoZSBgYExhdW5jaFRlbXBsYXRlSURgYCBvciB0aGUgYGBMYXVuY2hUZW1wbGF0ZU5hbWVgYCwgYnV0IG5vdCBib3RoLlxuICovXG5MYXVuY2hUZW1wbGF0ZUlkPzogc3RyaW5nXG59XG4vKipcbiAqIFVzZSB0aGlzIHN0cnVjdHVyZSB0byBsZXQgQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgZG8gdGhlIGZvbGxvd2luZyB3aGVuIHRoZSBBdXRvIFNjYWxpbmcgZ3JvdXAgaGFzIGEgbWl4ZWQgaW5zdGFuY2VzIHBvbGljeTpcbiAqICAgKyAgT3ZlcnJpZGUgdGhlIGluc3RhbmNlIHR5cGUgdGhhdCBpcyBzcGVjaWZpZWQgaW4gdGhlIGxhdW5jaCB0ZW1wbGF0ZS5cbiAqICAgKyAgVXNlIG11bHRpcGxlIGluc3RhbmNlIHR5cGVzLlxuICogICBcbiAqICBTcGVjaWZ5IHRoZSBpbnN0YW5jZSB0eXBlcyB0aGF0IHlvdSB3YW50LCBvciBkZWZpbmUgeW91ciBpbnN0YW5jZSByZXF1aXJlbWVudHMgaW5zdGVhZCBhbmQgbGV0IEFtYXpvbiBFQzIgQXV0byBTY2FsaW5nIHByb3Zpc2lvbiB0aGUgYXZhaWxhYmxlIGluc3RhbmNlIHR5cGVzIHRoYXQgbWVldCB5b3VyIHJlcXVpcmVtZW50cy4gVGhpcyBjYW4gcHJvdmlkZSBBbWF6b24gRUMyIEF1dG8gU2NhbGluZyB3aXRoIGEgbGFyZ2VyIHNlbGVjdGlvbiBvZiBpbnN0YW5jZSB0eXBlcyB0byBjaG9vc2UgZnJvbSB3aGVuIGZ1bGZpbGxpbmcgU3BvdCBhbmQgT24tRGVtYW5kIGNhcGFjaXRpZXMuIFlvdSBjYW4gdmlldyB3aGljaCBpbnN0YW5jZSB0eXBlcyBhcmUgbWF0Y2hlZCBiZWZvcmUgeW91IGFwcGx5IHRoZSBpbnN0YW5jZSByZXF1aXJlbWVudHMgdG8geW91ciBBdXRvIFNjYWxpbmcgZ3JvdXAuXG4gKiAgQWZ0ZXIgeW91IGRlZmluZSB5b3VyIGluc3RhbmNlIHJlcXVpcmVtZW50cywgeW91IGRvbid0IGhhdmUgdG8ga2VlcCB1cGRhdGluZyB0aGVzZSBzZXR0aW5ncyB0byBnZXQgbmV3IEVDMiBpbnN0YW5jZSB0eXBlcyBhdXRvbWF0aWNhbGx5LiBBbWF6b24gRUMyIEF1dG8gU2NhbGluZyB1c2VzIHRoZSBpbnN0YW5jZSByZXF1aXJlbWVudHMgb2YgdGhlIEF1dG8gU2NhbGluZyBncm91cCB0byBkZXRlcm1pbmUgd2hldGhlciBhIG5ldyBFQzIgaW5zdGFuY2UgdHlwZSBjYW4gYmUgdXNlZC5cbiAqICAgYGBMYXVuY2hUZW1wbGF0ZU92ZXJyaWRlc2BgIGlzIGEgcHJvcGVydHkgb2YgdGhlIFtBV1M6OkF1dG9TY2FsaW5nOjpBdXRvU2NhbGluZ0dyb3VwIExhdW5jaFRlbXBsYXRlXShodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vQVdTQ2xvdWRGb3JtYXRpb24vbGF0ZXN0L1VzZXJHdWlkZS9hd3MtcHJvcGVydGllcy1hdXRvc2NhbGluZy1hdXRvc2NhbGluZ2dyb3VwLWxhdW5jaHRlbXBsYXRlLmh0bWwpIHByb3BlcnR5IHR5cGUuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgTGF1bmNoVGVtcGxhdGVPdmVycmlkZXMge1xuTGF1bmNoVGVtcGxhdGVTcGVjaWZpY2F0aW9uPzogTGF1bmNoVGVtcGxhdGVTcGVjaWZpY2F0aW9uMlxuLyoqXG4gKiBJZiB5b3UgcHJvdmlkZSBhIGxpc3Qgb2YgaW5zdGFuY2UgdHlwZXMgdG8gdXNlLCB5b3UgY2FuIHNwZWNpZnkgdGhlIG51bWJlciBvZiBjYXBhY2l0eSB1bml0cyBwcm92aWRlZCBieSBlYWNoIGluc3RhbmNlIHR5cGUgaW4gdGVybXMgb2YgdmlydHVhbCBDUFVzLCBtZW1vcnksIHN0b3JhZ2UsIHRocm91Z2hwdXQsIG9yIG90aGVyIHJlbGF0aXZlIHBlcmZvcm1hbmNlIGNoYXJhY3RlcmlzdGljLiBXaGVuIGEgU3BvdCBvciBPbi1EZW1hbmQgSW5zdGFuY2UgaXMgbGF1bmNoZWQsIHRoZSBjYXBhY2l0eSB1bml0cyBjb3VudCB0b3dhcmQgdGhlIGRlc2lyZWQgY2FwYWNpdHkuIEFtYXpvbiBFQzIgQXV0byBTY2FsaW5nIGxhdW5jaGVzIGluc3RhbmNlcyB1bnRpbCB0aGUgZGVzaXJlZCBjYXBhY2l0eSBpcyB0b3RhbGx5IGZ1bGZpbGxlZCwgZXZlbiBpZiB0aGlzIHJlc3VsdHMgaW4gYW4gb3ZlcmFnZS4gRm9yIGV4YW1wbGUsIGlmIHRoZXJlIGFyZSB0d28gdW5pdHMgcmVtYWluaW5nIHRvIGZ1bGZpbGwgY2FwYWNpdHksIGFuZCBBbWF6b24gRUMyIEF1dG8gU2NhbGluZyBjYW4gb25seSBsYXVuY2ggYW4gaW5zdGFuY2Ugd2l0aCBhIGBgV2VpZ2h0ZWRDYXBhY2l0eWBgIG9mIGZpdmUgdW5pdHMsIHRoZSBpbnN0YW5jZSBpcyBsYXVuY2hlZCwgYW5kIHRoZSBkZXNpcmVkIGNhcGFjaXR5IGlzIGV4Y2VlZGVkIGJ5IHRocmVlIHVuaXRzLiBGb3IgbW9yZSBpbmZvcm1hdGlvbiwgc2VlIFtDb25maWd1cmUgaW5zdGFuY2Ugd2VpZ2h0aW5nIGZvciBBbWF6b24gRUMyIEF1dG8gU2NhbGluZ10oaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL2F1dG9zY2FsaW5nL2VjMi91c2VyZ3VpZGUvZWMyLWF1dG8tc2NhbGluZy1taXhlZC1pbnN0YW5jZXMtZ3JvdXBzLWluc3RhbmNlLXdlaWdodGluZy5odG1sKSBpbiB0aGUgKkFtYXpvbiBFQzIgQXV0byBTY2FsaW5nIFVzZXIgR3VpZGUqLiBWYWx1ZSBtdXN0IGJlIGluIHRoZSByYW5nZSBvZiAxLTk5OS4gXG4gKiAgSWYgeW91IHNwZWNpZnkgYSB2YWx1ZSBmb3IgYGBXZWlnaHRlZENhcGFjaXR5YGAgZm9yIG9uZSBpbnN0YW5jZSB0eXBlLCB5b3UgbXVzdCBzcGVjaWZ5IGEgdmFsdWUgZm9yIGBgV2VpZ2h0ZWRDYXBhY2l0eWBgIGZvciBhbGwgb2YgdGhlbS5cbiAqICAgRXZlcnkgQXV0byBTY2FsaW5nIGdyb3VwIGhhcyB0aHJlZSBzaXplIHBhcmFtZXRlcnMgKGBgRGVzaXJlZENhcGFjaXR5YGAsIGBgTWF4U2l6ZWBgLCBhbmQgYGBNaW5TaXplYGApLiBVc3VhbGx5LCB5b3Ugc2V0IHRoZXNlIHNpemVzIGJhc2VkIG9uIGEgc3BlY2lmaWMgbnVtYmVyIG9mIGluc3RhbmNlcy4gSG93ZXZlciwgaWYgeW91IGNvbmZpZ3VyZSBhIG1peGVkIGluc3RhbmNlcyBwb2xpY3kgdGhhdCBkZWZpbmVzIHdlaWdodHMgZm9yIHRoZSBpbnN0YW5jZSB0eXBlcywgeW91IG11c3Qgc3BlY2lmeSB0aGVzZSBzaXplcyB3aXRoIHRoZSBzYW1lIHVuaXRzIHRoYXQgeW91IHVzZSBmb3Igd2VpZ2h0aW5nIGluc3RhbmNlcy5cbiAqL1xuV2VpZ2h0ZWRDYXBhY2l0eT86IHN0cmluZ1xuSW5zdGFuY2VSZXF1aXJlbWVudHM/OiBJbnN0YW5jZVJlcXVpcmVtZW50c1xuLyoqXG4gKiBUaGUgaW5zdGFuY2UgdHlwZSwgc3VjaCBhcyBgYG0zLnhsYXJnZWBgLiBZb3UgbXVzdCBzcGVjaWZ5IGFuIGluc3RhbmNlIHR5cGUgdGhhdCBpcyBzdXBwb3J0ZWQgaW4geW91ciByZXF1ZXN0ZWQgUmVnaW9uIGFuZCBBdmFpbGFiaWxpdHkgWm9uZXMuIEZvciBtb3JlIGluZm9ybWF0aW9uLCBzZWUgW0luc3RhbmNlIHR5cGVzXShodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vQVdTRUMyL2xhdGVzdC9Vc2VyR3VpZGUvaW5zdGFuY2UtdHlwZXMuaHRtbCkgaW4gdGhlICpBbWF6b24gRUMyIFVzZXIgR3VpZGUgZm9yIExpbnV4IEluc3RhbmNlcyouXG4gKiAgWW91IGNhbiBzcGVjaWZ5IHVwIHRvIDQwIGluc3RhbmNlIHR5cGVzIHBlciBBdXRvIFNjYWxpbmcgZ3JvdXAuXG4gKi9cbkluc3RhbmNlVHlwZT86IHN0cmluZ1xufVxuLyoqXG4gKiBQcm92aWRlcyBhIGxhdW5jaCB0ZW1wbGF0ZSBmb3IgdGhlIHNwZWNpZmllZCBpbnN0YW5jZSB0eXBlIG9yIHNldCBvZiBpbnN0YW5jZSByZXF1aXJlbWVudHMuIEZvciBleGFtcGxlLCBzb21lIGluc3RhbmNlIHR5cGVzIG1pZ2h0IHJlcXVpcmUgYSBsYXVuY2ggdGVtcGxhdGUgd2l0aCBhIGRpZmZlcmVudCBBTUkuIElmIG5vdCBwcm92aWRlZCwgQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgdXNlcyB0aGUgbGF1bmNoIHRlbXBsYXRlIHRoYXQncyBzcGVjaWZpZWQgaW4gdGhlIGBgTGF1bmNoVGVtcGxhdGVgYCBkZWZpbml0aW9uLiBGb3IgbW9yZSBpbmZvcm1hdGlvbiwgc2VlIFtTcGVjaWZ5aW5nIGEgZGlmZmVyZW50IGxhdW5jaCB0ZW1wbGF0ZSBmb3IgYW4gaW5zdGFuY2UgdHlwZV0oaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL2F1dG9zY2FsaW5nL2VjMi91c2VyZ3VpZGUvZWMyLWF1dG8tc2NhbGluZy1taXhlZC1pbnN0YW5jZXMtZ3JvdXBzLWxhdW5jaC10ZW1wbGF0ZS1vdmVycmlkZXMuaHRtbCkgaW4gdGhlICpBbWF6b24gRUMyIEF1dG8gU2NhbGluZyBVc2VyIEd1aWRlKi4gXG4gKiAgWW91IGNhbiBzcGVjaWZ5IHVwIHRvIDIwIGxhdW5jaCB0ZW1wbGF0ZXMgcGVyIEF1dG8gU2NhbGluZyBncm91cC4gVGhlIGxhdW5jaCB0ZW1wbGF0ZXMgc3BlY2lmaWVkIGluIHRoZSBvdmVycmlkZXMgYW5kIGluIHRoZSBgYExhdW5jaFRlbXBsYXRlYGAgZGVmaW5pdGlvbiBjb3VudCB0b3dhcmRzIHRoaXMgbGltaXQuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgTGF1bmNoVGVtcGxhdGVTcGVjaWZpY2F0aW9uMiB7XG4vKipcbiAqIFRoZSBuYW1lIG9mIHRoZSBsYXVuY2ggdGVtcGxhdGUuXG4gKiAgWW91IG11c3Qgc3BlY2lmeSB0aGUgYGBMYXVuY2hUZW1wbGF0ZU5hbWVgYCBvciB0aGUgYGBMYXVuY2hUZW1wbGF0ZUlEYGAsIGJ1dCBub3QgYm90aC5cbiAqL1xuTGF1bmNoVGVtcGxhdGVOYW1lPzogc3RyaW5nXG4vKipcbiAqIFRoZSB2ZXJzaW9uIG51bWJlciBvZiB0aGUgbGF1bmNoIHRlbXBsYXRlLlxuICogIFNwZWNpZnlpbmcgYGAkTGF0ZXN0YGAgb3IgYGAkRGVmYXVsdGBgIGZvciB0aGUgdGVtcGxhdGUgdmVyc2lvbiBudW1iZXIgaXMgbm90IHN1cHBvcnRlZC4gSG93ZXZlciwgeW91IGNhbiBzcGVjaWZ5IGBgTGF0ZXN0VmVyc2lvbk51bWJlcmBgIG9yIGBgRGVmYXVsdFZlcnNpb25OdW1iZXJgYCB1c2luZyB0aGUgYGBGbjo6R2V0QXR0YGAgaW50cmluc2ljIGZ1bmN0aW9uLiBGb3IgbW9yZSBpbmZvcm1hdGlvbiwgc2VlIFtGbjo6R2V0QXR0XShodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vQVdTQ2xvdWRGb3JtYXRpb24vbGF0ZXN0L1VzZXJHdWlkZS9pbnRyaW5zaWMtZnVuY3Rpb24tcmVmZXJlbmNlLWdldGF0dC5odG1sKS5cbiAqICAgRm9yIGFuIGV4YW1wbGUgb2YgdXNpbmcgdGhlIGBgRm46OkdldEF0dGBgIGZ1bmN0aW9uLCBzZWUgdGhlIFtFeGFtcGxlc10oaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL0FXU0Nsb3VkRm9ybWF0aW9uL2xhdGVzdC9Vc2VyR3VpZGUvYXdzLXJlc291cmNlLWF1dG9zY2FsaW5nLWF1dG9zY2FsaW5nZ3JvdXAuaHRtbCNhd3MtcmVzb3VyY2UtYXV0b3NjYWxpbmctYXV0b3NjYWxpbmdncm91cC0tZXhhbXBsZXMpIHNlY3Rpb24gb2YgdGhlIGBgQVdTOjpBdXRvU2NhbGluZzo6QXV0b1NjYWxpbmdHcm91cGBgIHJlc291cmNlLlxuICovXG5WZXJzaW9uOiBzdHJpbmdcbi8qKlxuICogVGhlIElEIG9mIHRoZSBsYXVuY2ggdGVtcGxhdGUuXG4gKiAgWW91IG11c3Qgc3BlY2lmeSB0aGUgYGBMYXVuY2hUZW1wbGF0ZUlEYGAgb3IgdGhlIGBgTGF1bmNoVGVtcGxhdGVOYW1lYGAsIGJ1dCBub3QgYm90aC5cbiAqL1xuTGF1bmNoVGVtcGxhdGVJZD86IHN0cmluZ1xufVxuLyoqXG4gKiBUaGUgaW5zdGFuY2UgcmVxdWlyZW1lbnRzLiBBbWF6b24gRUMyIEF1dG8gU2NhbGluZyB1c2VzIHlvdXIgc3BlY2lmaWVkIHJlcXVpcmVtZW50cyB0byBpZGVudGlmeSBpbnN0YW5jZSB0eXBlcy4gVGhlbiwgaXQgdXNlcyB5b3VyIE9uLURlbWFuZCBhbmQgU3BvdCBhbGxvY2F0aW9uIHN0cmF0ZWdpZXMgdG8gbGF1bmNoIGluc3RhbmNlcyBmcm9tIHRoZXNlIGluc3RhbmNlIHR5cGVzLlxuICogIFlvdSBjYW4gc3BlY2lmeSB1cCB0byBmb3VyIHNlcGFyYXRlIHNldHMgb2YgaW5zdGFuY2UgcmVxdWlyZW1lbnRzIHBlciBBdXRvIFNjYWxpbmcgZ3JvdXAuIFRoaXMgaXMgdXNlZnVsIGZvciBwcm92aXNpb25pbmcgaW5zdGFuY2VzIGZyb20gZGlmZmVyZW50IEFtYXpvbiBNYWNoaW5lIEltYWdlcyAoQU1JcykgaW4gdGhlIHNhbWUgQXV0byBTY2FsaW5nIGdyb3VwLiBUbyBkbyB0aGlzLCBjcmVhdGUgdGhlIEFNSXMgYW5kIGNyZWF0ZSBhIG5ldyBsYXVuY2ggdGVtcGxhdGUgZm9yIGVhY2ggQU1JLiBUaGVuLCBjcmVhdGUgYSBjb21wYXRpYmxlIHNldCBvZiBpbnN0YW5jZSByZXF1aXJlbWVudHMgZm9yIGVhY2ggbGF1bmNoIHRlbXBsYXRlLiBcbiAqICAgSWYgeW91IHNwZWNpZnkgYGBJbnN0YW5jZVJlcXVpcmVtZW50c2BgLCB5b3UgY2FuJ3Qgc3BlY2lmeSBgYEluc3RhbmNlVHlwZWBgLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIEluc3RhbmNlUmVxdWlyZW1lbnRzIHtcbi8qKlxuICogSW5kaWNhdGVzIHdoZXRoZXIgY3VycmVudCBvciBwcmV2aW91cyBnZW5lcmF0aW9uIGluc3RhbmNlIHR5cGVzIGFyZSBpbmNsdWRlZC5cbiAqICAgKyAgRm9yIGN1cnJlbnQgZ2VuZXJhdGlvbiBpbnN0YW5jZSB0eXBlcywgc3BlY2lmeSBgYGN1cnJlbnRgYC4gVGhlIGN1cnJlbnQgZ2VuZXJhdGlvbiBpbmNsdWRlcyBFQzIgaW5zdGFuY2UgdHlwZXMgY3VycmVudGx5IHJlY29tbWVuZGVkIGZvciB1c2UuIFRoaXMgdHlwaWNhbGx5IGluY2x1ZGVzIHRoZSBsYXRlc3QgdHdvIHRvIHRocmVlIGdlbmVyYXRpb25zIGluIGVhY2ggaW5zdGFuY2UgZmFtaWx5LiBGb3IgbW9yZSBpbmZvcm1hdGlvbiwgc2VlIFtJbnN0YW5jZSB0eXBlc10oaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL0FXU0VDMi9sYXRlc3QvVXNlckd1aWRlL2luc3RhbmNlLXR5cGVzLmh0bWwpIGluIHRoZSAqQW1hem9uIEVDMiBVc2VyIEd1aWRlIGZvciBMaW51eCBJbnN0YW5jZXMqLlxuICogICArICBGb3IgcHJldmlvdXMgZ2VuZXJhdGlvbiBpbnN0YW5jZSB0eXBlcywgc3BlY2lmeSBgYHByZXZpb3VzYGAuXG4gKiAgIFxuICogIERlZmF1bHQ6IEFueSBjdXJyZW50IG9yIHByZXZpb3VzIGdlbmVyYXRpb25cbiAqL1xuSW5zdGFuY2VHZW5lcmF0aW9ucz86IHN0cmluZ1tdXG4vKipcbiAqIExpc3RzIHRoZSBhY2NlbGVyYXRvciB0eXBlcyB0aGF0IG11c3QgYmUgb24gYW4gaW5zdGFuY2UgdHlwZS5cbiAqICAgKyAgRm9yIGluc3RhbmNlIHR5cGVzIHdpdGggR1BVIGFjY2VsZXJhdG9ycywgc3BlY2lmeSBgYGdwdWBgLlxuICogICArICBGb3IgaW5zdGFuY2UgdHlwZXMgd2l0aCBGUEdBIGFjY2VsZXJhdG9ycywgc3BlY2lmeSBgYGZwZ2FgYC5cbiAqICAgKyAgRm9yIGluc3RhbmNlIHR5cGVzIHdpdGggaW5mZXJlbmNlIGFjY2VsZXJhdG9ycywgc3BlY2lmeSBgYGluZmVyZW5jZWBgLlxuICogICBcbiAqICBEZWZhdWx0OiBBbnkgYWNjZWxlcmF0b3IgdHlwZVxuICovXG5BY2NlbGVyYXRvclR5cGVzPzogc3RyaW5nW11cbk1lbW9yeUdpQlBlclZDcHU/OiBNZW1vcnlHaUJQZXJWQ3B1UmVxdWVzdFxuLyoqXG4gKiBJbmRpY2F0ZXMgd2hldGhlciBpbnN0YW5jZSB0eXBlcyBtdXN0IGhhdmUgYWNjZWxlcmF0b3JzIGJ5IHNwZWNpZmljIG1hbnVmYWN0dXJlcnMuXG4gKiAgICsgIEZvciBpbnN0YW5jZSB0eXBlcyB3aXRoIE5WSURJQSBkZXZpY2VzLCBzcGVjaWZ5IGBgbnZpZGlhYGAuXG4gKiAgICsgIEZvciBpbnN0YW5jZSB0eXBlcyB3aXRoIEFNRCBkZXZpY2VzLCBzcGVjaWZ5IGBgYW1kYGAuXG4gKiAgICsgIEZvciBpbnN0YW5jZSB0eXBlcyB3aXRoIEFXUyBkZXZpY2VzLCBzcGVjaWZ5IGBgYW1hem9uLXdlYi1zZXJ2aWNlc2BgLlxuICogICArICBGb3IgaW5zdGFuY2UgdHlwZXMgd2l0aCBYaWxpbnggZGV2aWNlcywgc3BlY2lmeSBgYHhpbGlueGBgLlxuICogICBcbiAqICBEZWZhdWx0OiBBbnkgbWFudWZhY3R1cmVyXG4gKi9cbkFjY2VsZXJhdG9yTWFudWZhY3R1cmVycz86IHN0cmluZ1tdXG5WQ3B1Q291bnQ6IFZDcHVDb3VudFJlcXVlc3Rcbi8qKlxuICogSW5kaWNhdGVzIHdoZXRoZXIgaW5zdGFuY2UgdHlwZXMgd2l0aCBpbnN0YW5jZSBzdG9yZSB2b2x1bWVzIGFyZSBpbmNsdWRlZCwgZXhjbHVkZWQsIG9yIHJlcXVpcmVkLiBGb3IgbW9yZSBpbmZvcm1hdGlvbiwgc2VlIFtBbWF6b24gRUMyIGluc3RhbmNlIHN0b3JlXShodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vQVdTRUMyL2xhdGVzdC9Vc2VyR3VpZGUvSW5zdGFuY2VTdG9yYWdlLmh0bWwpIGluIHRoZSAqQW1hem9uIEVDMiBVc2VyIEd1aWRlIGZvciBMaW51eCBJbnN0YW5jZXMqLlxuICogIERlZmF1bHQ6IGBgaW5jbHVkZWRgYFxuICovXG5Mb2NhbFN0b3JhZ2U/OiBzdHJpbmdcbi8qKlxuICogTGlzdHMgd2hpY2ggc3BlY2lmaWMgQ1BVIG1hbnVmYWN0dXJlcnMgdG8gaW5jbHVkZS5cbiAqICAgKyAgRm9yIGluc3RhbmNlIHR5cGVzIHdpdGggSW50ZWwgQ1BVcywgc3BlY2lmeSBgYGludGVsYGAuXG4gKiAgICsgIEZvciBpbnN0YW5jZSB0eXBlcyB3aXRoIEFNRCBDUFVzLCBzcGVjaWZ5IGBgYW1kYGAuXG4gKiAgICsgIEZvciBpbnN0YW5jZSB0eXBlcyB3aXRoIEFXUyBDUFVzLCBzcGVjaWZ5IGBgYW1hem9uLXdlYi1zZXJ2aWNlc2BgLlxuICogICBcbiAqICAgRG9uJ3QgY29uZnVzZSB0aGUgQ1BVIGhhcmR3YXJlIG1hbnVmYWN0dXJlciB3aXRoIHRoZSBDUFUgaGFyZHdhcmUgYXJjaGl0ZWN0dXJlLiBJbnN0YW5jZXMgd2lsbCBiZSBsYXVuY2hlZCB3aXRoIGEgY29tcGF0aWJsZSBDUFUgYXJjaGl0ZWN0dXJlIGJhc2VkIG9uIHRoZSBBbWF6b24gTWFjaGluZSBJbWFnZSAoQU1JKSB0aGF0IHlvdSBzcGVjaWZ5IGluIHlvdXIgbGF1bmNoIHRlbXBsYXRlLiBcbiAqICAgRGVmYXVsdDogQW55IG1hbnVmYWN0dXJlclxuICovXG5DcHVNYW51ZmFjdHVyZXJzPzogc3RyaW5nW11cbi8qKlxuICogSW5kaWNhdGVzIHdoZXRoZXIgYmFyZSBtZXRhbCBpbnN0YW5jZSB0eXBlcyBhcmUgaW5jbHVkZWQsIGV4Y2x1ZGVkLCBvciByZXF1aXJlZC5cbiAqICBEZWZhdWx0OiBgYGV4Y2x1ZGVkYGBcbiAqL1xuQmFyZU1ldGFsPzogc3RyaW5nXG4vKipcbiAqIEluZGljYXRlcyB3aGV0aGVyIGluc3RhbmNlIHR5cGVzIG11c3QgcHJvdmlkZSBPbi1EZW1hbmQgSW5zdGFuY2UgaGliZXJuYXRpb24gc3VwcG9ydC5cbiAqICBEZWZhdWx0OiBgYGZhbHNlYGBcbiAqL1xuUmVxdWlyZUhpYmVybmF0ZVN1cHBvcnQ/OiBib29sZWFuXG4vKipcbiAqIFtQcmljZSBwcm90ZWN0aW9uXSBUaGUgcHJpY2UgcHJvdGVjdGlvbiB0aHJlc2hvbGQgZm9yIFNwb3QgSW5zdGFuY2VzLCBhcyBhIHBlcmNlbnRhZ2Ugb2YgYW4gaWRlbnRpZmllZCBPbi1EZW1hbmQgcHJpY2UuIFRoZSBpZGVudGlmaWVkIE9uLURlbWFuZCBwcmljZSBpcyB0aGUgcHJpY2Ugb2YgdGhlIGxvd2VzdCBwcmljZWQgY3VycmVudCBnZW5lcmF0aW9uIEMsIE0sIG9yIFIgaW5zdGFuY2UgdHlwZSB3aXRoIHlvdXIgc3BlY2lmaWVkIGF0dHJpYnV0ZXMuIElmIG5vIGN1cnJlbnQgZ2VuZXJhdGlvbiBDLCBNLCBvciBSIGluc3RhbmNlIHR5cGUgbWF0Y2hlcyB5b3VyIGF0dHJpYnV0ZXMsIHRoZW4gdGhlIGlkZW50aWZpZWQgcHJpY2UgaXMgZnJvbSBlaXRoZXIgdGhlIGxvd2VzdCBwcmljZWQgY3VycmVudCBnZW5lcmF0aW9uIGluc3RhbmNlIHR5cGVzIG9yLCBmYWlsaW5nIHRoYXQsIHRoZSBsb3dlc3QgcHJpY2VkIHByZXZpb3VzIGdlbmVyYXRpb24gaW5zdGFuY2UgdHlwZXMgdGhhdCBtYXRjaCB5b3VyIGF0dHJpYnV0ZXMuIFdoZW4gQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgc2VsZWN0cyBpbnN0YW5jZSB0eXBlcyB3aXRoIHlvdXIgYXR0cmlidXRlcywgd2Ugd2lsbCBleGNsdWRlIGluc3RhbmNlIHR5cGVzIHdob3NlIHByaWNlIGV4Y2VlZHMgeW91ciBzcGVjaWZpZWQgdGhyZXNob2xkLlxuICogIFRoZSBwYXJhbWV0ZXIgYWNjZXB0cyBhbiBpbnRlZ2VyLCB3aGljaCBBbWF6b24gRUMyIEF1dG8gU2NhbGluZyBpbnRlcnByZXRzIGFzIGEgcGVyY2VudGFnZS5cbiAqICBJZiB5b3Ugc2V0IGBgRGVzaXJlZENhcGFjaXR5VHlwZWBgIHRvIGBgdmNwdWBgIG9yIGBgbWVtb3J5LW1pYmBgLCB0aGUgcHJpY2UgcHJvdGVjdGlvbiB0aHJlc2hvbGQgaXMgYmFzZWQgb24gdGhlIHBlci12Q1BVIG9yIHBlci1tZW1vcnkgcHJpY2UgaW5zdGVhZCBvZiB0aGUgcGVyIGluc3RhbmNlIHByaWNlLiBcbiAqICAgT25seSBvbmUgb2YgYGBTcG90TWF4UHJpY2VQZXJjZW50YWdlT3Zlckxvd2VzdFByaWNlYGAgb3IgYGBNYXhTcG90UHJpY2VBc1BlcmNlbnRhZ2VPZk9wdGltYWxPbkRlbWFuZFByaWNlYGAgY2FuIGJlIHNwZWNpZmllZC4gSWYgeW91IGRvbid0IHNwZWNpZnkgZWl0aGVyLCBBbWF6b24gRUMyIEF1dG8gU2NhbGluZyB3aWxsIGF1dG9tYXRpY2FsbHkgYXBwbHkgb3B0aW1hbCBwcmljZSBwcm90ZWN0aW9uIHRvIGNvbnNpc3RlbnRseSBzZWxlY3QgZnJvbSBhIHdpZGUgcmFuZ2Ugb2YgaW5zdGFuY2UgdHlwZXMuIFRvIGluZGljYXRlIG5vIHByaWNlIHByb3RlY3Rpb24gdGhyZXNob2xkIGZvciBTcG90IEluc3RhbmNlcywgbWVhbmluZyB5b3Ugd2FudCB0byBjb25zaWRlciBhbGwgaW5zdGFuY2UgdHlwZXMgdGhhdCBtYXRjaCB5b3VyIGF0dHJpYnV0ZXMsIGluY2x1ZGUgb25lIG9mIHRoZXNlIHBhcmFtZXRlcnMgYW5kIHNwZWNpZnkgYSBoaWdoIHZhbHVlLCBzdWNoIGFzIGBgOTk5OTk5YGAuXG4gKi9cbk1heFNwb3RQcmljZUFzUGVyY2VudGFnZU9mT3B0aW1hbE9uRGVtYW5kUHJpY2U/OiBudW1iZXJcbi8qKlxuICogW1ByaWNlIHByb3RlY3Rpb25dIFRoZSBwcmljZSBwcm90ZWN0aW9uIHRocmVzaG9sZCBmb3IgT24tRGVtYW5kIEluc3RhbmNlcywgYXMgYSBwZXJjZW50YWdlIGhpZ2hlciB0aGFuIGFuIGlkZW50aWZpZWQgT24tRGVtYW5kIHByaWNlLiBUaGUgaWRlbnRpZmllZCBPbi1EZW1hbmQgcHJpY2UgaXMgdGhlIHByaWNlIG9mIHRoZSBsb3dlc3QgcHJpY2VkIGN1cnJlbnQgZ2VuZXJhdGlvbiBDLCBNLCBvciBSIGluc3RhbmNlIHR5cGUgd2l0aCB5b3VyIHNwZWNpZmllZCBhdHRyaWJ1dGVzLiBJZiBubyBjdXJyZW50IGdlbmVyYXRpb24gQywgTSwgb3IgUiBpbnN0YW5jZSB0eXBlIG1hdGNoZXMgeW91ciBhdHRyaWJ1dGVzLCB0aGVuIHRoZSBpZGVudGlmaWVkIHByaWNlIGlzIGZyb20gZWl0aGVyIHRoZSBsb3dlc3QgcHJpY2VkIGN1cnJlbnQgZ2VuZXJhdGlvbiBpbnN0YW5jZSB0eXBlcyBvciwgZmFpbGluZyB0aGF0LCB0aGUgbG93ZXN0IHByaWNlZCBwcmV2aW91cyBnZW5lcmF0aW9uIGluc3RhbmNlIHR5cGVzIHRoYXQgbWF0Y2ggeW91ciBhdHRyaWJ1dGVzLiBXaGVuIEFtYXpvbiBFQzIgQXV0byBTY2FsaW5nIHNlbGVjdHMgaW5zdGFuY2UgdHlwZXMgd2l0aCB5b3VyIGF0dHJpYnV0ZXMsIHdlIHdpbGwgZXhjbHVkZSBpbnN0YW5jZSB0eXBlcyB3aG9zZSBwcmljZSBleGNlZWRzIHlvdXIgc3BlY2lmaWVkIHRocmVzaG9sZC4gXG4gKiAgVGhlIHBhcmFtZXRlciBhY2NlcHRzIGFuIGludGVnZXIsIHdoaWNoIEFtYXpvbiBFQzIgQXV0byBTY2FsaW5nIGludGVycHJldHMgYXMgYSBwZXJjZW50YWdlLlxuICogIFRvIHR1cm4gb2ZmIHByaWNlIHByb3RlY3Rpb24sIHNwZWNpZnkgYSBoaWdoIHZhbHVlLCBzdWNoIGFzIGBgOTk5OTk5YGAuIFxuICogIElmIHlvdSBzZXQgYGBEZXNpcmVkQ2FwYWNpdHlUeXBlYGAgdG8gYGB2Y3B1YGAgb3IgYGBtZW1vcnktbWliYGAsIHRoZSBwcmljZSBwcm90ZWN0aW9uIHRocmVzaG9sZCBpcyBhcHBsaWVkIGJhc2VkIG9uIHRoZSBwZXItdkNQVSBvciBwZXItbWVtb3J5IHByaWNlIGluc3RlYWQgb2YgdGhlIHBlciBpbnN0YW5jZSBwcmljZS4gXG4gKiAgRGVmYXVsdDogYGAyMGBgXG4gKi9cbk9uRGVtYW5kTWF4UHJpY2VQZXJjZW50YWdlT3Zlckxvd2VzdFByaWNlPzogbnVtYmVyXG5NZW1vcnlNaUI6IE1lbW9yeU1pQlJlcXVlc3Rcbi8qKlxuICogSW5kaWNhdGVzIHRoZSB0eXBlIG9mIGxvY2FsIHN0b3JhZ2UgdGhhdCBpcyByZXF1aXJlZC5cbiAqICAgKyAgRm9yIGluc3RhbmNlIHR5cGVzIHdpdGggaGFyZCBkaXNrIGRyaXZlIChIREQpIHN0b3JhZ2UsIHNwZWNpZnkgYGBoZGRgYC5cbiAqICAgKyAgRm9yIGluc3RhbmNlIHR5cGVzIHdpdGggc29saWQgc3RhdGUgZHJpdmUgKFNTRCkgc3RvcmFnZSwgc3BlY2lmeSBgYHNzZGBgLlxuICogICBcbiAqICBEZWZhdWx0OiBBbnkgbG9jYWwgc3RvcmFnZSB0eXBlXG4gKi9cbkxvY2FsU3RvcmFnZVR5cGVzPzogc3RyaW5nW11cbk5ldHdvcmtJbnRlcmZhY2VDb3VudD86IE5ldHdvcmtJbnRlcmZhY2VDb3VudFJlcXVlc3Rcbi8qKlxuICogVGhlIGluc3RhbmNlIHR5cGVzIHRvIGV4Y2x1ZGUuIFlvdSBjYW4gdXNlIHN0cmluZ3Mgd2l0aCBvbmUgb3IgbW9yZSB3aWxkIGNhcmRzLCByZXByZXNlbnRlZCBieSBhbiBhc3RlcmlzayAoYGAqYGApLCB0byBleGNsdWRlIGFuIGluc3RhbmNlIGZhbWlseSwgdHlwZSwgc2l6ZSwgb3IgZ2VuZXJhdGlvbi4gVGhlIGZvbGxvd2luZyBhcmUgZXhhbXBsZXM6IGBgbTUuOHhsYXJnZWBgLCBgYGM1Ki4qYGAsIGBgbTVhLipgYCwgYGByKmBgLCBgYCozKmBgLiBcbiAqICBGb3IgZXhhbXBsZSwgaWYgeW91IHNwZWNpZnkgYGBjNSpgYCwgeW91IGFyZSBleGNsdWRpbmcgdGhlIGVudGlyZSBDNSBpbnN0YW5jZSBmYW1pbHksIHdoaWNoIGluY2x1ZGVzIGFsbCBDNWEgYW5kIEM1biBpbnN0YW5jZSB0eXBlcy4gSWYgeW91IHNwZWNpZnkgYGBtNWEuKmBgLCBBbWF6b24gRUMyIEF1dG8gU2NhbGluZyB3aWxsIGV4Y2x1ZGUgYWxsIHRoZSBNNWEgaW5zdGFuY2UgdHlwZXMsIGJ1dCBub3QgdGhlIE01biBpbnN0YW5jZSB0eXBlcy5cbiAqICAgSWYgeW91IHNwZWNpZnkgYGBFeGNsdWRlZEluc3RhbmNlVHlwZXNgYCwgeW91IGNhbid0IHNwZWNpZnkgYGBBbGxvd2VkSW5zdGFuY2VUeXBlc2BgLlxuICogICBEZWZhdWx0OiBObyBleGNsdWRlZCBpbnN0YW5jZSB0eXBlc1xuICovXG5FeGNsdWRlZEluc3RhbmNlVHlwZXM/OiBzdHJpbmdbXVxuLyoqXG4gKiBUaGUgaW5zdGFuY2UgdHlwZXMgdG8gYXBwbHkgeW91ciBzcGVjaWZpZWQgYXR0cmlidXRlcyBhZ2FpbnN0LiBBbGwgb3RoZXIgaW5zdGFuY2UgdHlwZXMgYXJlIGlnbm9yZWQsIGV2ZW4gaWYgdGhleSBtYXRjaCB5b3VyIHNwZWNpZmllZCBhdHRyaWJ1dGVzLlxuICogIFlvdSBjYW4gdXNlIHN0cmluZ3Mgd2l0aCBvbmUgb3IgbW9yZSB3aWxkIGNhcmRzLCByZXByZXNlbnRlZCBieSBhbiBhc3RlcmlzayAoYGAqYGApLCB0byBhbGxvdyBhbiBpbnN0YW5jZSB0eXBlLCBzaXplLCBvciBnZW5lcmF0aW9uLiBUaGUgZm9sbG93aW5nIGFyZSBleGFtcGxlczogYGBtNS44eGxhcmdlYGAsIGBgYzUqLipgYCwgYGBtNWEuKmBgLCBgYHIqYGAsIGBgKjMqYGAuXG4gKiAgRm9yIGV4YW1wbGUsIGlmIHlvdSBzcGVjaWZ5IGBgYzUqYGAsIEFtYXpvbiBFQzIgQXV0byBTY2FsaW5nIHdpbGwgYWxsb3cgdGhlIGVudGlyZSBDNSBpbnN0YW5jZSBmYW1pbHksIHdoaWNoIGluY2x1ZGVzIGFsbCBDNWEgYW5kIEM1biBpbnN0YW5jZSB0eXBlcy4gSWYgeW91IHNwZWNpZnkgYGBtNWEuKmBgLCBBbWF6b24gRUMyIEF1dG8gU2NhbGluZyB3aWxsIGFsbG93IGFsbCB0aGUgTTVhIGluc3RhbmNlIHR5cGVzLCBidXQgbm90IHRoZSBNNW4gaW5zdGFuY2UgdHlwZXMuXG4gKiAgIElmIHlvdSBzcGVjaWZ5IGBgQWxsb3dlZEluc3RhbmNlVHlwZXNgYCwgeW91IGNhbid0IHNwZWNpZnkgYGBFeGNsdWRlZEluc3RhbmNlVHlwZXNgYC5cbiAqICAgRGVmYXVsdDogQWxsIGluc3RhbmNlIHR5cGVzXG4gKi9cbkFsbG93ZWRJbnN0YW5jZVR5cGVzPzogc3RyaW5nW11cbkFjY2VsZXJhdG9yQ291bnQ/OiBBY2NlbGVyYXRvckNvdW50UmVxdWVzdFxuTmV0d29ya0JhbmR3aWR0aEdicHM/OiBOZXR3b3JrQmFuZHdpZHRoR2Jwc1JlcXVlc3RcbkJhc2VsaW5lUGVyZm9ybWFuY2VGYWN0b3JzPzogQmFzZWxpbmVQZXJmb3JtYW5jZUZhY3RvcnNSZXF1ZXN0XG5CYXNlbGluZUVic0JhbmR3aWR0aE1icHM/OiBCYXNlbGluZUVic0JhbmR3aWR0aE1icHNSZXF1ZXN0XG4vKipcbiAqIFtQcmljZSBwcm90ZWN0aW9uXSBUaGUgcHJpY2UgcHJvdGVjdGlvbiB0aHJlc2hvbGQgZm9yIFNwb3QgSW5zdGFuY2VzLCBhcyBhIHBlcmNlbnRhZ2UgaGlnaGVyIHRoYW4gYW4gaWRlbnRpZmllZCBTcG90IHByaWNlLiBUaGUgaWRlbnRpZmllZCBTcG90IHByaWNlIGlzIHRoZSBwcmljZSBvZiB0aGUgbG93ZXN0IHByaWNlZCBjdXJyZW50IGdlbmVyYXRpb24gQywgTSwgb3IgUiBpbnN0YW5jZSB0eXBlIHdpdGggeW91ciBzcGVjaWZpZWQgYXR0cmlidXRlcy4gSWYgbm8gY3VycmVudCBnZW5lcmF0aW9uIEMsIE0sIG9yIFIgaW5zdGFuY2UgdHlwZSBtYXRjaGVzIHlvdXIgYXR0cmlidXRlcywgdGhlbiB0aGUgaWRlbnRpZmllZCBwcmljZSBpcyBmcm9tIGVpdGhlciB0aGUgbG93ZXN0IHByaWNlZCBjdXJyZW50IGdlbmVyYXRpb24gaW5zdGFuY2UgdHlwZXMgb3IsIGZhaWxpbmcgdGhhdCwgdGhlIGxvd2VzdCBwcmljZWQgcHJldmlvdXMgZ2VuZXJhdGlvbiBpbnN0YW5jZSB0eXBlcyB0aGF0IG1hdGNoIHlvdXIgYXR0cmlidXRlcy4gV2hlbiBBbWF6b24gRUMyIEF1dG8gU2NhbGluZyBzZWxlY3RzIGluc3RhbmNlIHR5cGVzIHdpdGggeW91ciBhdHRyaWJ1dGVzLCB3ZSB3aWxsIGV4Y2x1ZGUgaW5zdGFuY2UgdHlwZXMgd2hvc2UgcHJpY2UgZXhjZWVkcyB5b3VyIHNwZWNpZmllZCB0aHJlc2hvbGQuXG4gKiAgVGhlIHBhcmFtZXRlciBhY2NlcHRzIGFuIGludGVnZXIsIHdoaWNoIEFtYXpvbiBFQzIgQXV0byBTY2FsaW5nIGludGVycHJldHMgYXMgYSBwZXJjZW50YWdlLiBcbiAqICBJZiB5b3Ugc2V0IGBgRGVzaXJlZENhcGFjaXR5VHlwZWBgIHRvIGBgdmNwdWBgIG9yIGBgbWVtb3J5LW1pYmBgLCB0aGUgcHJpY2UgcHJvdGVjdGlvbiB0aHJlc2hvbGQgaXMgYmFzZWQgb24gdGhlIHBlci12Q1BVIG9yIHBlci1tZW1vcnkgcHJpY2UgaW5zdGVhZCBvZiB0aGUgcGVyIGluc3RhbmNlIHByaWNlLiBcbiAqICAgT25seSBvbmUgb2YgYGBTcG90TWF4UHJpY2VQZXJjZW50YWdlT3Zlckxvd2VzdFByaWNlYGAgb3IgYGBNYXhTcG90UHJpY2VBc1BlcmNlbnRhZ2VPZk9wdGltYWxPbkRlbWFuZFByaWNlYGAgY2FuIGJlIHNwZWNpZmllZC4gSWYgeW91IGRvbid0IHNwZWNpZnkgZWl0aGVyLCBBbWF6b24gRUMyIEF1dG8gU2NhbGluZyB3aWxsIGF1dG9tYXRpY2FsbHkgYXBwbHkgb3B0aW1hbCBwcmljZSBwcm90ZWN0aW9uIHRvIGNvbnNpc3RlbnRseSBzZWxlY3QgZnJvbSBhIHdpZGUgcmFuZ2Ugb2YgaW5zdGFuY2UgdHlwZXMuIFRvIGluZGljYXRlIG5vIHByaWNlIHByb3RlY3Rpb24gdGhyZXNob2xkIGZvciBTcG90IEluc3RhbmNlcywgbWVhbmluZyB5b3Ugd2FudCB0byBjb25zaWRlciBhbGwgaW5zdGFuY2UgdHlwZXMgdGhhdCBtYXRjaCB5b3VyIGF0dHJpYnV0ZXMsIGluY2x1ZGUgb25lIG9mIHRoZXNlIHBhcmFtZXRlcnMgYW5kIHNwZWNpZnkgYSBoaWdoIHZhbHVlLCBzdWNoIGFzIGBgOTk5OTk5YGAuXG4gKi9cblNwb3RNYXhQcmljZVBlcmNlbnRhZ2VPdmVyTG93ZXN0UHJpY2U/OiBudW1iZXJcbi8qKlxuICogTGlzdHMgdGhlIGFjY2VsZXJhdG9ycyB0aGF0IG11c3QgYmUgb24gYW4gaW5zdGFuY2UgdHlwZS5cbiAqICAgKyAgRm9yIGluc3RhbmNlIHR5cGVzIHdpdGggTlZJRElBIEExMDAgR1BVcywgc3BlY2lmeSBgYGExMDBgYC5cbiAqICAgKyAgRm9yIGluc3RhbmNlIHR5cGVzIHdpdGggTlZJRElBIFYxMDAgR1BVcywgc3BlY2lmeSBgYHYxMDBgYC5cbiAqICAgKyAgRm9yIGluc3RhbmNlIHR5cGVzIHdpdGggTlZJRElBIEs4MCBHUFVzLCBzcGVjaWZ5IGBgazgwYGAuXG4gKiAgICsgIEZvciBpbnN0YW5jZSB0eXBlcyB3aXRoIE5WSURJQSBUNCBHUFVzLCBzcGVjaWZ5IGBgdDRgYC5cbiAqICAgKyAgRm9yIGluc3RhbmNlIHR5cGVzIHdpdGggTlZJRElBIE02MCBHUFVzLCBzcGVjaWZ5IGBgbTYwYGAuXG4gKiAgICsgIEZvciBpbnN0YW5jZSB0eXBlcyB3aXRoIEFNRCBSYWRlb24gUHJvIFY1MjAgR1BVcywgc3BlY2lmeSBgYHJhZGVvbi1wcm8tdjUyMGBgLlxuICogICArICBGb3IgaW5zdGFuY2UgdHlwZXMgd2l0aCBYaWxpbnggVlU5UCBGUEdBcywgc3BlY2lmeSBgYHZ1OXBgYC5cbiAqICAgXG4gKiAgRGVmYXVsdDogQW55IGFjY2VsZXJhdG9yXG4gKi9cbkFjY2VsZXJhdG9yTmFtZXM/OiBzdHJpbmdbXVxuQWNjZWxlcmF0b3JUb3RhbE1lbW9yeU1pQj86IEFjY2VsZXJhdG9yVG90YWxNZW1vcnlNaUJSZXF1ZXN0XG4vKipcbiAqIEluZGljYXRlcyB3aGV0aGVyIGJ1cnN0YWJsZSBwZXJmb3JtYW5jZSBpbnN0YW5jZSB0eXBlcyBhcmUgaW5jbHVkZWQsIGV4Y2x1ZGVkLCBvciByZXF1aXJlZC4gRm9yIG1vcmUgaW5mb3JtYXRpb24sIHNlZSBbQnVyc3RhYmxlIHBlcmZvcm1hbmNlIGluc3RhbmNlc10oaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL0FXU0VDMi9sYXRlc3QvVXNlckd1aWRlL2J1cnN0YWJsZS1wZXJmb3JtYW5jZS1pbnN0YW5jZXMuaHRtbCkgaW4gdGhlICpBbWF6b24gRUMyIFVzZXIgR3VpZGUgZm9yIExpbnV4IEluc3RhbmNlcyouXG4gKiAgRGVmYXVsdDogYGBleGNsdWRlZGBgXG4gKi9cbkJ1cnN0YWJsZVBlcmZvcm1hbmNlPzogc3RyaW5nXG5Ub3RhbExvY2FsU3RvcmFnZUdCPzogVG90YWxMb2NhbFN0b3JhZ2VHQlJlcXVlc3Rcbn1cbi8qKlxuICogVGhlIG1pbmltdW0gYW5kIG1heGltdW0gYW1vdW50IG9mIG1lbW9yeSBwZXIgdkNQVSBmb3IgYW4gaW5zdGFuY2UgdHlwZSwgaW4gR2lCLlxuICogIERlZmF1bHQ6IE5vIG1pbmltdW0gb3IgbWF4aW11bSBsaW1pdHNcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBNZW1vcnlHaUJQZXJWQ3B1UmVxdWVzdCB7XG4vKipcbiAqIFRoZSBtZW1vcnkgbWluaW11bSBpbiBHaUIuXG4gKi9cbk1pbj86IG51bWJlclxuLyoqXG4gKiBUaGUgbWVtb3J5IG1heGltdW0gaW4gR2lCLlxuICovXG5NYXg/OiBudW1iZXJcbn1cbi8qKlxuICogVGhlIG1pbmltdW0gYW5kIG1heGltdW0gbnVtYmVyIG9mIHZDUFVzIGZvciBhbiBpbnN0YW5jZSB0eXBlLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFZDcHVDb3VudFJlcXVlc3Qge1xuLyoqXG4gKiBUaGUgbWluaW11bSBudW1iZXIgb2YgdkNQVXMuXG4gKi9cbk1pbj86IG51bWJlclxuLyoqXG4gKiBUaGUgbWF4aW11bSBudW1iZXIgb2YgdkNQVXMuXG4gKi9cbk1heD86IG51bWJlclxufVxuLyoqXG4gKiBUaGUgbWluaW11bSBhbmQgbWF4aW11bSBpbnN0YW5jZSBtZW1vcnkgc2l6ZSBmb3IgYW4gaW5zdGFuY2UgdHlwZSwgaW4gTWlCLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIE1lbW9yeU1pQlJlcXVlc3Qge1xuLyoqXG4gKiBUaGUgbWVtb3J5IG1pbmltdW0gaW4gTWlCLlxuICovXG5NaW4/OiBudW1iZXJcbi8qKlxuICogVGhlIG1lbW9yeSBtYXhpbXVtIGluIE1pQi5cbiAqL1xuTWF4PzogbnVtYmVyXG59XG4vKipcbiAqIFRoZSBtaW5pbXVtIGFuZCBtYXhpbXVtIG51bWJlciBvZiBuZXR3b3JrIGludGVyZmFjZXMgZm9yIGFuIGluc3RhbmNlIHR5cGUuXG4gKiAgRGVmYXVsdDogTm8gbWluaW11bSBvciBtYXhpbXVtIGxpbWl0c1xuICovXG5leHBvcnQgaW50ZXJmYWNlIE5ldHdvcmtJbnRlcmZhY2VDb3VudFJlcXVlc3Qge1xuLyoqXG4gKiBUaGUgbWluaW11bSBudW1iZXIgb2YgbmV0d29yayBpbnRlcmZhY2VzLlxuICovXG5NaW4/OiBudW1iZXJcbi8qKlxuICogVGhlIG1heGltdW0gbnVtYmVyIG9mIG5ldHdvcmsgaW50ZXJmYWNlcy5cbiAqL1xuTWF4PzogbnVtYmVyXG59XG4vKipcbiAqIFRoZSBtaW5pbXVtIGFuZCBtYXhpbXVtIG51bWJlciBvZiBhY2NlbGVyYXRvcnMgKEdQVXMsIEZQR0FzLCBvciBBV1MgSW5mZXJlbnRpYSBjaGlwcykgZm9yIGFuIGluc3RhbmNlIHR5cGUuXG4gKiAgVG8gZXhjbHVkZSBhY2NlbGVyYXRvci1lbmFibGVkIGluc3RhbmNlIHR5cGVzLCBzZXQgYGBNYXhgYCB0byBgYDBgYC5cbiAqICBEZWZhdWx0OiBObyBtaW5pbXVtIG9yIG1heGltdW0gbGltaXRzXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQWNjZWxlcmF0b3JDb3VudFJlcXVlc3Qge1xuLyoqXG4gKiBUaGUgbWluaW11bSB2YWx1ZS5cbiAqL1xuTWluPzogbnVtYmVyXG4vKipcbiAqIFRoZSBtYXhpbXVtIHZhbHVlLlxuICovXG5NYXg/OiBudW1iZXJcbn1cbi8qKlxuICogVGhlIG1pbmltdW0gYW5kIG1heGltdW0gYW1vdW50IG9mIG5ldHdvcmsgYmFuZHdpZHRoLCBpbiBnaWdhYml0cyBwZXIgc2Vjb25kIChHYnBzKS5cbiAqICBEZWZhdWx0OiBObyBtaW5pbXVtIG9yIG1heGltdW0gbGltaXRzXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgTmV0d29ya0JhbmR3aWR0aEdicHNSZXF1ZXN0IHtcbi8qKlxuICogVGhlIG1pbmltdW0gYW1vdW50IG9mIG5ldHdvcmsgYmFuZHdpZHRoLCBpbiBnaWdhYml0cyBwZXIgc2Vjb25kIChHYnBzKS5cbiAqL1xuTWluPzogbnVtYmVyXG4vKipcbiAqIFRoZSBtYXhpbXVtIGFtb3VudCBvZiBuZXR3b3JrIGJhbmR3aWR0aCwgaW4gZ2lnYWJpdHMgcGVyIHNlY29uZCAoR2JwcykuXG4gKi9cbk1heD86IG51bWJlclxufVxuLyoqXG4gKiBUaGUgYmFzZWxpbmUgcGVyZm9ybWFuY2UgZmFjdG9ycyBmb3IgdGhlIGluc3RhbmNlIHJlcXVpcmVtZW50cy5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBCYXNlbGluZVBlcmZvcm1hbmNlRmFjdG9yc1JlcXVlc3Qge1xuQ3B1PzogQ3B1UGVyZm9ybWFuY2VGYWN0b3JSZXF1ZXN0XG59XG4vKipcbiAqIFRoZSBDUFUgcGVyZm9ybWFuY2UgdG8gY29uc2lkZXIsIHVzaW5nIGFuIGluc3RhbmNlIGZhbWlseSBhcyB0aGUgYmFzZWxpbmUgcmVmZXJlbmNlLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIENwdVBlcmZvcm1hbmNlRmFjdG9yUmVxdWVzdCB7XG5SZWZlcmVuY2VzPzogUGVyZm9ybWFuY2VGYWN0b3JSZWZlcmVuY2VTZXRSZXF1ZXN0XG59XG4vKipcbiAqIFNwZWNpZnkgYW4gaW5zdGFuY2UgZmFtaWx5IHRvIHVzZSBhcyB0aGUgYmFzZWxpbmUgcmVmZXJlbmNlIGZvciBDUFUgcGVyZm9ybWFuY2UuIEFsbCBpbnN0YW5jZSB0eXBlcyB0aGF0IEFsbCBpbnN0YW5jZSB0eXBlcyB0aGF0IG1hdGNoIHlvdXIgc3BlY2lmaWVkIGF0dHJpYnV0ZXMgd2lsbCBiZSBjb21wYXJlZCBhZ2FpbnN0IHRoZSBDUFUgcGVyZm9ybWFuY2Ugb2YgdGhlIHJlZmVyZW5jZWQgaW5zdGFuY2UgZmFtaWx5LCByZWdhcmRsZXNzIG9mIENQVSBtYW51ZmFjdHVyZXIgb3IgYXJjaGl0ZWN0dXJlIGRpZmZlcmVuY2VzLiBcbiAqICAgQ3VycmVudGx5IG9ubHkgb25lIGluc3RhbmNlIGZhbWlseSBjYW4gYmUgc3BlY2lmaWVkIGluIHRoZSBsaXN0LlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFBlcmZvcm1hbmNlRmFjdG9yUmVmZXJlbmNlUmVxdWVzdCB7XG4vKipcbiAqIFRoZSBpbnN0YW5jZSBmYW1pbHkgdG8gdXNlIGFzIGEgYmFzZWxpbmUgcmVmZXJlbmNlLiBcbiAqICAgTWFrZSBzdXJlIHRoYXQgeW91IHNwZWNpZnkgdGhlIGNvcnJlY3QgdmFsdWUgZm9yIHRoZSBpbnN0YW5jZSBmYW1pbHkuIFRoZSBpbnN0YW5jZSBmYW1pbHkgaXMgZXZlcnl0aGluZyBiZWZvcmUgdGhlIHBlcmlvZCAoLikgaW4gdGhlIGluc3RhbmNlIHR5cGUgbmFtZS4gRm9yIGV4YW1wbGUsIGluIHRoZSBpbnN0YW5jZSBgYGM2aS5sYXJnZWBgLCB0aGUgaW5zdGFuY2UgZmFtaWx5IGlzIGBgYzZpYGAsIG5vdCBgYGM2YGAuIEZvciBtb3JlIGluZm9ybWF0aW9uLCBzZWUgW0FtYXpvbiBFQzIgaW5zdGFuY2UgdHlwZSBuYW1pbmcgY29udmVudGlvbnNdKGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9lYzIvbGF0ZXN0L2luc3RhbmNldHlwZXMvaW5zdGFuY2UtdHlwZS1uYW1lcy5odG1sKSBpbiAqQW1hem9uIEVDMiBJbnN0YW5jZSBUeXBlcyouXG4gKiAgIFRoZSBmb2xsb3dpbmcgaW5zdGFuY2UgdHlwZXMgYXJlICpub3Qgc3VwcG9ydGVkKiBmb3IgcGVyZm9ybWFuY2UgcHJvdGVjdGlvbi5cbiAqICAgKyAgIGBgYzFgYCBcbiAqICAgKyAgIGBgZzN8IGczc2BgIFxuICogICArICAgYGBocGM3Z2BgIFxuICogICArICAgYGBtMXwgbTJgYCBcbiAqICAgKyAgIGBgbWFjMSB8IG1hYzIgfCBtYWMyLW0xdWx0cmEgfCBtYWMyLW0yIHwgbWFjMi1tMnByb2BgIFxuICogICArICAgYGBwM2RuIHwgcDRkIHwgcDVgYCBcbiAqICAgKyAgIGBgdDFgYCBcbiAqICAgKyAgIGBgdS0xMnRiMSB8IHUtMTh0YjEgfCB1LTI0dGIxIHwgdS0zdGIxIHwgdS02dGIxIHwgdS05dGIxIHwgdTdpLTEydGIgfCB1N2luLTE2dGIgfCB1N2luLTI0dGIgfCB1N2luLTMydGJgYCBcbiAqICAgXG4gKiAgSWYgeW91IHBlcmZvcm1hbmNlIHByb3RlY3Rpb24gYnkgc3BlY2lmeWluZyBhIHN1cHBvcnRlZCBpbnN0YW5jZSBmYW1pbHksIHRoZSByZXR1cm5lZCBpbnN0YW5jZSB0eXBlcyB3aWxsIGV4Y2x1ZGUgdGhlIHByZWNlZGluZyB1bnN1cHBvcnRlZCBpbnN0YW5jZSBmYW1pbGllcy5cbiAqICBJZiB5b3Ugc3BlY2lmeSBhbiB1bnN1cHBvcnRlZCBpbnN0YW5jZSBmYW1pbHkgYXMgYSB2YWx1ZSBmb3IgYmFzZWxpbmUgcGVyZm9ybWFuY2UsIHRoZSBBUEkgcmV0dXJucyBhbiBlbXB0eSByZXNwb25zZS5cbiAqL1xuSW5zdGFuY2VGYW1pbHk/OiBzdHJpbmdcbn1cbi8qKlxuICogVGhlIG1pbmltdW0gYW5kIG1heGltdW0gYmFzZWxpbmUgYmFuZHdpZHRoIHBlcmZvcm1hbmNlIGZvciBhbiBpbnN0YW5jZSB0eXBlLCBpbiBNYnBzLiBGb3IgbW9yZSBpbmZvcm1hdGlvbiwgc2VlIFtBbWF6b24gRUJT4oCTb3B0aW1pemVkIGluc3RhbmNlc10oaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL0FXU0VDMi9sYXRlc3QvVXNlckd1aWRlL2Vicy1vcHRpbWl6ZWQuaHRtbCkgaW4gdGhlICpBbWF6b24gRUMyIFVzZXIgR3VpZGUgZm9yIExpbnV4IEluc3RhbmNlcyouXG4gKiAgRGVmYXVsdDogTm8gbWluaW11bSBvciBtYXhpbXVtIGxpbWl0c1xuICovXG5leHBvcnQgaW50ZXJmYWNlIEJhc2VsaW5lRWJzQmFuZHdpZHRoTWJwc1JlcXVlc3Qge1xuLyoqXG4gKiBUaGUgbWluaW11bSB2YWx1ZSBpbiBNYnBzLlxuICovXG5NaW4/OiBudW1iZXJcbi8qKlxuICogVGhlIG1heGltdW0gdmFsdWUgaW4gTWJwcy5cbiAqL1xuTWF4PzogbnVtYmVyXG59XG4vKipcbiAqIFRoZSBtaW5pbXVtIGFuZCBtYXhpbXVtIHRvdGFsIG1lbW9yeSBzaXplIGZvciB0aGUgYWNjZWxlcmF0b3JzIG9uIGFuIGluc3RhbmNlIHR5cGUsIGluIE1pQi5cbiAqICBEZWZhdWx0OiBObyBtaW5pbXVtIG9yIG1heGltdW0gbGltaXRzXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQWNjZWxlcmF0b3JUb3RhbE1lbW9yeU1pQlJlcXVlc3Qge1xuLyoqXG4gKiBUaGUgbWVtb3J5IG1pbmltdW0gaW4gTWlCLlxuICovXG5NaW4/OiBudW1iZXJcbi8qKlxuICogVGhlIG1lbW9yeSBtYXhpbXVtIGluIE1pQi5cbiAqL1xuTWF4PzogbnVtYmVyXG59XG4vKipcbiAqIFRoZSBtaW5pbXVtIGFuZCBtYXhpbXVtIHRvdGFsIGxvY2FsIHN0b3JhZ2Ugc2l6ZSBmb3IgYW4gaW5zdGFuY2UgdHlwZSwgaW4gR0IuXG4gKiAgRGVmYXVsdDogTm8gbWluaW11bSBvciBtYXhpbXVtIGxpbWl0c1xuICovXG5leHBvcnQgaW50ZXJmYWNlIFRvdGFsTG9jYWxTdG9yYWdlR0JSZXF1ZXN0IHtcbi8qKlxuICogVGhlIHN0b3JhZ2UgbWluaW11bSBpbiBHQi5cbiAqL1xuTWluPzogbnVtYmVyXG4vKipcbiAqIFRoZSBzdG9yYWdlIG1heGltdW0gaW4gR0IuXG4gKi9cbk1heD86IG51bWJlclxufVxuLyoqXG4gKiBBIHN0cnVjdHVyZSB0aGF0IHNwZWNpZmllcyBhIHRhZyBmb3IgdGhlIGBgVGFnc2BgIHByb3BlcnR5IG9mIFtBV1M6OkF1dG9TY2FsaW5nOjpBdXRvU2NhbGluZ0dyb3VwXShodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vQVdTQ2xvdWRGb3JtYXRpb24vbGF0ZXN0L1VzZXJHdWlkZS9hd3MtcmVzb3VyY2UtYXV0b3NjYWxpbmctYXV0b3NjYWxpbmdncm91cC5odG1sKSByZXNvdXJjZS5cbiAqICBGb3IgbW9yZSBpbmZvcm1hdGlvbiwgc2VlIFtUYWcgQXV0byBTY2FsaW5nIGdyb3VwcyBhbmQgaW5zdGFuY2VzXShodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vYXV0b3NjYWxpbmcvZWMyL3VzZXJndWlkZS9hdXRvc2NhbGluZy10YWdnaW5nLmh0bWwpIGluIHRoZSAqQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgVXNlciBHdWlkZSouIFlvdSBjYW4gZmluZCBhIHNhbXBsZSB0ZW1wbGF0ZSBzbmlwcGV0IGluIHRoZSBbRXhhbXBsZXNdKGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9BV1NDbG91ZEZvcm1hdGlvbi9sYXRlc3QvVXNlckd1aWRlL2F3cy1yZXNvdXJjZS1hdXRvc2NhbGluZy1hdXRvc2NhbGluZ2dyb3VwLmh0bWwjYXdzLXJlc291cmNlLWF1dG9zY2FsaW5nLWF1dG9zY2FsaW5nZ3JvdXAtLWV4YW1wbGVzKSBzZWN0aW9uIG9mIHRoZSBgYEFXUzo6QXV0b1NjYWxpbmc6OkF1dG9TY2FsaW5nR3JvdXBgYCByZXNvdXJjZS5cbiAqICBDbG91ZEZvcm1hdGlvbiBhZGRzIHRoZSBmb2xsb3dpbmcgdGFncyB0byBhbGwgQXV0byBTY2FsaW5nIGdyb3VwcyBhbmQgYXNzb2NpYXRlZCBpbnN0YW5jZXM6IFxuICogICArICBhd3M6Y2xvdWRmb3JtYXRpb246c3RhY2stbmFtZVxuICogICArICBhd3M6Y2xvdWRmb3JtYXRpb246c3RhY2staWRcbiAqICAgKyAgYXdzOmNsb3VkZm9ybWF0aW9uOmxvZ2ljYWwtaWRcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBUYWdQcm9wZXJ0eSB7XG4vKipcbiAqIFRoZSB0YWcgdmFsdWUuXG4gKi9cblZhbHVlOiBzdHJpbmdcbi8qKlxuICogVGhlIHRhZyBrZXkuXG4gKi9cbktleTogc3RyaW5nXG4vKipcbiAqIFNldCB0byBgYHRydWVgYCBpZiB5b3Ugd2FudCBDbG91ZEZvcm1hdGlvbiB0byBjb3B5IHRoZSB0YWcgdG8gRUMyIGluc3RhbmNlcyB0aGF0IGFyZSBsYXVuY2hlZCBhcyBwYXJ0IG9mIHRoZSBBdXRvIFNjYWxpbmcgZ3JvdXAuIFNldCB0byBgYGZhbHNlYGAgaWYgeW91IHdhbnQgdGhlIHRhZyBhdHRhY2hlZCBvbmx5IHRvIHRoZSBBdXRvIFNjYWxpbmcgZ3JvdXAgYW5kIG5vdCBjb3BpZWQgdG8gYW55IGluc3RhbmNlcyBsYXVuY2hlZCBhcyBwYXJ0IG9mIHRoZSBBdXRvIFNjYWxpbmcgZ3JvdXAuXG4gKi9cblByb3BhZ2F0ZUF0TGF1bmNoOiBib29sZWFuXG59XG4vKipcbiAqIEEgc3RydWN0dXJlIHRoYXQgc3BlY2lmaWVzIGFuIEFtYXpvbiBTTlMgbm90aWZpY2F0aW9uIGNvbmZpZ3VyYXRpb24gZm9yIHRoZSBgYE5vdGlmaWNhdGlvbkNvbmZpZ3VyYXRpb25zYGAgcHJvcGVydHkgb2YgdGhlIFtBV1M6OkF1dG9TY2FsaW5nOjpBdXRvU2NhbGluZ0dyb3VwXShodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vQVdTQ2xvdWRGb3JtYXRpb24vbGF0ZXN0L1VzZXJHdWlkZS9hd3MtcmVzb3VyY2UtYXV0b3NjYWxpbmctYXV0b3NjYWxpbmdncm91cC5odG1sKSByZXNvdXJjZS5cbiAqICBGb3IgYW4gZXhhbXBsZSB0ZW1wbGF0ZSBzbmlwcGV0LCBzZWUgW0NvbmZpZ3VyZSBBbWF6b24gRUMyIEF1dG8gU2NhbGluZyByZXNvdXJjZXNdKGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9BV1NDbG91ZEZvcm1hdGlvbi9sYXRlc3QvVXNlckd1aWRlL3F1aWNrcmVmLWVjMi1hdXRvLXNjYWxpbmcuaHRtbCkuXG4gKiAgRm9yIG1vcmUgaW5mb3JtYXRpb24sIHNlZSBbR2V0IEFtYXpvbiBTTlMgbm90aWZpY2F0aW9ucyB3aGVuIHlvdXIgQXV0byBTY2FsaW5nIGdyb3VwIHNjYWxlc10oaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL2F1dG9zY2FsaW5nL2VjMi91c2VyZ3VpZGUvQVNHZXR0aW5nTm90aWZpY2F0aW9ucy5odG1sKSBpbiB0aGUgKkFtYXpvbiBFQzIgQXV0byBTY2FsaW5nIFVzZXIgR3VpZGUqLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIE5vdGlmaWNhdGlvbkNvbmZpZ3VyYXRpb24xIHtcbi8qKlxuICogVGhlIEFtYXpvbiBSZXNvdXJjZSBOYW1lIChBUk4pIG9mIHRoZSBBbWF6b24gU05TIHRvcGljLlxuICovXG5Ub3BpY0FSTjogKHN0cmluZyB8IHN0cmluZ1tdKVxuLyoqXG4gKiBBIGxpc3Qgb2YgZXZlbnQgdHlwZXMgdGhhdCBzZW5kIGEgbm90aWZpY2F0aW9uLiBFdmVudCB0eXBlcyBjYW4gaW5jbHVkZSBhbnkgb2YgdGhlIGZvbGxvd2luZyB0eXBlcy4gXG4gKiAgICpBbGxvd2VkIHZhbHVlcyo6XG4gKiAgICsgICBgYGF1dG9zY2FsaW5nOkVDMl9JTlNUQU5DRV9MQVVOQ0hgYCBcbiAqICAgKyAgIGBgYXV0b3NjYWxpbmc6RUMyX0lOU1RBTkNFX0xBVU5DSF9FUlJPUmBgIFxuICogICArICAgYGBhdXRvc2NhbGluZzpFQzJfSU5TVEFOQ0VfVEVSTUlOQVRFYGAgXG4gKiAgICsgICBgYGF1dG9zY2FsaW5nOkVDMl9JTlNUQU5DRV9URVJNSU5BVEVfRVJST1JgYCBcbiAqICAgKyAgIGBgYXV0b3NjYWxpbmc6VEVTVF9OT1RJRklDQVRJT05gYFxuICovXG5Ob3RpZmljYXRpb25UeXBlcz86IHN0cmluZ1tdXG59XG4vKipcbiAqIFRoZSBpbnN0YW5jZSBjYXBhY2l0eSBkaXN0cmlidXRpb24gYWNyb3NzIEF2YWlsYWJpbGl0eSBab25lcy5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBBdmFpbGFiaWxpdHlab25lRGlzdHJpYnV0aW9uIHtcbi8qKlxuICogSWYgbGF1bmNoZXMgZmFpbCBpbiBhbiBBdmFpbGFiaWxpdHkgWm9uZSwgdGhlIGZvbGxvd2luZyBzdHJhdGVnaWVzIGFyZSBhdmFpbGFibGUuIFRoZSBkZWZhdWx0IGlzIGBgYmFsYW5jZWQtYmVzdC1lZmZvcnRgYC4gXG4gKiAgICsgICBgYGJhbGFuY2VkLW9ubHlgYCAtIElmIGxhdW5jaGVzIGZhaWwgaW4gYW4gQXZhaWxhYmlsaXR5IFpvbmUsIEF1dG8gU2NhbGluZyB3aWxsIGNvbnRpbnVlIHRvIGF0dGVtcHQgdG8gbGF1bmNoIGluIHRoZSB1bmhlYWx0aHkgem9uZSB0byBwcmVzZXJ2ZSBhIGJhbGFuY2VkIGRpc3RyaWJ1dGlvbi5cbiAqICAgKyAgIGBgYmFsYW5jZWQtYmVzdC1lZmZvcnRgYCAtIElmIGxhdW5jaGVzIGZhaWwgaW4gYW4gQXZhaWxhYmlsaXR5IFpvbmUsIEF1dG8gU2NhbGluZyB3aWxsIGF0dGVtcHQgdG8gbGF1bmNoIGluIGFub3RoZXIgaGVhbHRoeSBBdmFpbGFiaWxpdHkgWm9uZSBpbnN0ZWFkLlxuICovXG5DYXBhY2l0eURpc3RyaWJ1dGlvblN0cmF0ZWd5PzogKFwiYmFsYW5jZWQtYmVzdC1lZmZvcnRcIiB8IFwiYmFsYW5jZWQtb25seVwiKVxufVxuLyoqXG4gKiBgYE1ldHJpY3NDb2xsZWN0aW9uYGAgaXMgYSBwcm9wZXJ0eSBvZiB0aGUgW0FXUzo6QXV0b1NjYWxpbmc6OkF1dG9TY2FsaW5nR3JvdXBdKGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9BV1NDbG91ZEZvcm1hdGlvbi9sYXRlc3QvVXNlckd1aWRlL2F3cy1yZXNvdXJjZS1hdXRvc2NhbGluZy1hdXRvc2NhbGluZ2dyb3VwLmh0bWwpIHJlc291cmNlIHRoYXQgZGVzY3JpYmVzIHRoZSBncm91cCBtZXRyaWNzIHRoYXQgYW4gQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgZ3JvdXAgc2VuZHMgdG8gQW1hem9uIENsb3VkV2F0Y2guIFRoZXNlIG1ldHJpY3MgZGVzY3JpYmUgdGhlIGdyb3VwIHJhdGhlciB0aGFuIGFueSBvZiBpdHMgaW5zdGFuY2VzLiBcbiAqICBGb3IgbW9yZSBpbmZvcm1hdGlvbiwgc2VlIFtNb25pdG9yIENsb3VkV2F0Y2ggbWV0cmljcyBmb3IgeW91ciBBdXRvIFNjYWxpbmcgZ3JvdXBzIGFuZCBpbnN0YW5jZXNdKGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9hdXRvc2NhbGluZy9lYzIvdXNlcmd1aWRlL2FzLWluc3RhbmNlLW1vbml0b3JpbmcuaHRtbCkgaW4gdGhlICpBbWF6b24gRUMyIEF1dG8gU2NhbGluZyBVc2VyIEd1aWRlKi4gWW91IGNhbiBmaW5kIGEgc2FtcGxlIHRlbXBsYXRlIHNuaXBwZXQgaW4gdGhlIFtFeGFtcGxlc10oaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL0FXU0Nsb3VkRm9ybWF0aW9uL2xhdGVzdC9Vc2VyR3VpZGUvYXdzLXJlc291cmNlLWF1dG9zY2FsaW5nLWF1dG9zY2FsaW5nZ3JvdXAuaHRtbCNhd3MtcmVzb3VyY2UtYXV0b3NjYWxpbmctYXV0b3NjYWxpbmdncm91cC0tZXhhbXBsZXMpIHNlY3Rpb24gb2YgdGhlIGBgQVdTOjpBdXRvU2NhbGluZzo6QXV0b1NjYWxpbmdHcm91cGBgIHJlc291cmNlLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIE1ldHJpY3NDb2xsZWN0aW9uIHtcbi8qKlxuICogSWRlbnRpZmllcyB0aGUgbWV0cmljcyB0byBlbmFibGUuXG4gKiAgWW91IGNhbiBzcGVjaWZ5IG9uZSBvciBtb3JlIG9mIHRoZSBmb2xsb3dpbmcgbWV0cmljczpcbiAqICAgKyAgIGBgR3JvdXBNaW5TaXplYGAgXG4gKiAgICsgICBgYEdyb3VwTWF4U2l6ZWBgIFxuICogICArICAgYGBHcm91cERlc2lyZWRDYXBhY2l0eWBgIFxuICogICArICAgYGBHcm91cEluU2VydmljZUluc3RhbmNlc2BgIFxuICogICArICAgYGBHcm91cFBlbmRpbmdJbnN0YW5jZXNgYCBcbiAqICAgKyAgIGBgR3JvdXBTdGFuZGJ5SW5zdGFuY2VzYGAgXG4gKiAgICsgICBgYEdyb3VwVGVybWluYXRpbmdJbnN0YW5jZXNgYCBcbiAqICAgKyAgIGBgR3JvdXBUb3RhbEluc3RhbmNlc2BgIFxuICogICArICAgYGBHcm91cEluU2VydmljZUNhcGFjaXR5YGAgXG4gKiAgICsgICBgYEdyb3VwUGVuZGluZ0NhcGFjaXR5YGAgXG4gKiAgICsgICBgYEdyb3VwU3RhbmRieUNhcGFjaXR5YGAgXG4gKiAgICsgICBgYEdyb3VwVGVybWluYXRpbmdDYXBhY2l0eWBgIFxuICogICArICAgYGBHcm91cFRvdGFsQ2FwYWNpdHlgYCBcbiAqICAgKyAgIGBgV2FybVBvb2xEZXNpcmVkQ2FwYWNpdHlgYCBcbiAqICAgKyAgIGBgV2FybVBvb2xXYXJtZWRDYXBhY2l0eWBgIFxuICogICArICAgYGBXYXJtUG9vbFBlbmRpbmdDYXBhY2l0eWBgIFxuICogICArICAgYGBXYXJtUG9vbFRlcm1pbmF0aW5nQ2FwYWNpdHlgYCBcbiAqICAgKyAgIGBgV2FybVBvb2xUb3RhbENhcGFjaXR5YGAgXG4gKiAgICsgICBgYEdyb3VwQW5kV2FybVBvb2xEZXNpcmVkQ2FwYWNpdHlgYCBcbiAqICAgKyAgIGBgR3JvdXBBbmRXYXJtUG9vbFRvdGFsQ2FwYWNpdHlgYCBcbiAqICAgXG4gKiAgSWYgeW91IHNwZWNpZnkgYGBHcmFudWxhcml0eWBgIGFuZCBkb24ndCBzcGVjaWZ5IGFueSBtZXRyaWNzLCBhbGwgbWV0cmljcyBhcmUgZW5hYmxlZC5cbiAqICBGb3IgbW9yZSBpbmZvcm1hdGlvbiwgc2VlIFtBbWF6b24gQ2xvdWRXYXRjaCBtZXRyaWNzIGZvciBBbWF6b24gRUMyIEF1dG8gU2NhbGluZ10oaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL2F1dG9zY2FsaW5nL2VjMi91c2VyZ3VpZGUvZWMyLWF1dG8tc2NhbGluZy1tZXRyaWNzLmh0bWwpIGluIHRoZSAqQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgVXNlciBHdWlkZSouXG4gKi9cbk1ldHJpY3M/OiBzdHJpbmdbXVxuLyoqXG4gKiBUaGUgZnJlcXVlbmN5IGF0IHdoaWNoIEFtYXpvbiBFQzIgQXV0byBTY2FsaW5nIHNlbmRzIGFnZ3JlZ2F0ZWQgZGF0YSB0byBDbG91ZFdhdGNoLiBUaGUgb25seSB2YWxpZCB2YWx1ZSBpcyBgYDFNaW51dGVgYC5cbiAqL1xuR3JhbnVsYXJpdHk6IHN0cmluZ1xufVxuLyoqXG4gKiBBbiBpbnN0YW5jZSBtYWludGVuYW5jZSBwb2xpY3kuIEZvciBtb3JlIGluZm9ybWF0aW9uLCBzZWUgW1NldCBpbnN0YW5jZSBtYWludGVuYW5jZSBwb2xpY3ldKGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9hdXRvc2NhbGluZy9lYzIvdXNlcmd1aWRlL2VjMi1hdXRvLXNjYWxpbmctaW5zdGFuY2UtbWFpbnRlbmFuY2UtcG9saWN5Lmh0bWwpIGluIHRoZSAqQW1hem9uIEVDMiBBdXRvIFNjYWxpbmcgVXNlciBHdWlkZSouXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgSW5zdGFuY2VNYWludGVuYW5jZVBvbGljeSB7XG4vKipcbiAqIFNwZWNpZmllcyB0aGUgdXBwZXIgdGhyZXNob2xkIGFzIGEgcGVyY2VudGFnZSBvZiB0aGUgZGVzaXJlZCBjYXBhY2l0eSBvZiB0aGUgQXV0byBTY2FsaW5nIGdyb3VwLiBJdCByZXByZXNlbnRzIHRoZSBtYXhpbXVtIHBlcmNlbnRhZ2Ugb2YgdGhlIGdyb3VwIHRoYXQgY2FuIGJlIGluIHNlcnZpY2UgYW5kIGhlYWx0aHksIG9yIHBlbmRpbmcsIHRvIHN1cHBvcnQgeW91ciB3b3JrbG9hZCB3aGVuIHJlcGxhY2luZyBpbnN0YW5jZXMuIFZhbHVlIHJhbmdlIGlzIDEwMCB0byAyMDAuIFRvIGNsZWFyIGEgcHJldmlvdXNseSBzZXQgdmFsdWUsIHNwZWNpZnkgYSB2YWx1ZSBvZiBgYC0xYGAuXG4gKiAgQm90aCBgYE1pbkhlYWx0aHlQZXJjZW50YWdlYGAgYW5kIGBgTWF4SGVhbHRoeVBlcmNlbnRhZ2VgYCBtdXN0IGJlIHNwZWNpZmllZCwgYW5kIHRoZSBkaWZmZXJlbmNlIGJldHdlZW4gdGhlbSBjYW5ub3QgYmUgZ3JlYXRlciB0aGFuIDEwMC4gQSBsYXJnZSByYW5nZSBpbmNyZWFzZXMgdGhlIG51bWJlciBvZiBpbnN0YW5jZXMgdGhhdCBjYW4gYmUgcmVwbGFjZWQgYXQgdGhlIHNhbWUgdGltZS5cbiAqL1xuTWF4SGVhbHRoeVBlcmNlbnRhZ2U/OiBudW1iZXJcbi8qKlxuICogU3BlY2lmaWVzIHRoZSBsb3dlciB0aHJlc2hvbGQgYXMgYSBwZXJjZW50YWdlIG9mIHRoZSBkZXNpcmVkIGNhcGFjaXR5IG9mIHRoZSBBdXRvIFNjYWxpbmcgZ3JvdXAuIEl0IHJlcHJlc2VudHMgdGhlIG1pbmltdW0gcGVyY2VudGFnZSBvZiB0aGUgZ3JvdXAgdG8ga2VlcCBpbiBzZXJ2aWNlLCBoZWFsdGh5LCBhbmQgcmVhZHkgdG8gdXNlIHRvIHN1cHBvcnQgeW91ciB3b3JrbG9hZCB3aGVuIHJlcGxhY2luZyBpbnN0YW5jZXMuIFZhbHVlIHJhbmdlIGlzIDAgdG8gMTAwLiBUbyBjbGVhciBhIHByZXZpb3VzbHkgc2V0IHZhbHVlLCBzcGVjaWZ5IGEgdmFsdWUgb2YgYGAtMWBgLlxuICovXG5NaW5IZWFsdGh5UGVyY2VudGFnZT86IG51bWJlclxufVxuLyoqXG4gKiBJZGVudGlmeWluZyBpbmZvcm1hdGlvbiBmb3IgYSB0cmFmZmljIHNvdXJjZS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBUcmFmZmljU291cmNlSWRlbnRpZmllciB7XG4vKipcbiAqIFByb3ZpZGVzIGFkZGl0aW9uYWwgY29udGV4dCBmb3IgdGhlIHZhbHVlIG9mIGBgSWRlbnRpZmllcmBgLlxuICogIFRoZSBmb2xsb3dpbmcgbGlzdHMgdGhlIHZhbGlkIHZhbHVlczpcbiAqICAgKyAgIGBgZWxiYGAgaWYgYGBJZGVudGlmaWVyYGAgaXMgdGhlIG5hbWUgb2YgYSBDbGFzc2ljIExvYWQgQmFsYW5jZXIuXG4gKiAgICsgICBgYGVsYnYyYGAgaWYgYGBJZGVudGlmaWVyYGAgaXMgdGhlIEFSTiBvZiBhbiBBcHBsaWNhdGlvbiBMb2FkIEJhbGFuY2VyLCBHYXRld2F5IExvYWQgQmFsYW5jZXIsIG9yIE5ldHdvcmsgTG9hZCBCYWxhbmNlciB0YXJnZXQgZ3JvdXAuXG4gKiAgICsgICBgYHZwYy1sYXR0aWNlYGAgaWYgYGBJZGVudGlmaWVyYGAgaXMgdGhlIEFSTiBvZiBhIFZQQyBMYXR0aWNlIHRhcmdldCBncm91cC5cbiAqICAgXG4gKiAgUmVxdWlyZWQgaWYgdGhlIGlkZW50aWZpZXIgaXMgdGhlIG5hbWUgb2YgYSBDbGFzc2ljIExvYWQgQmFsYW5jZXIuXG4gKi9cblR5cGU6IHN0cmluZ1xuLyoqXG4gKiBJZGVudGlmaWVzIHRoZSB0cmFmZmljIHNvdXJjZS5cbiAqICBGb3IgQXBwbGljYXRpb24gTG9hZCBCYWxhbmNlcnMsIEdhdGV3YXkgTG9hZCBCYWxhbmNlcnMsIE5ldHdvcmsgTG9hZCBCYWxhbmNlcnMsIGFuZCBWUEMgTGF0dGljZSwgdGhpcyB3aWxsIGJlIHRoZSBBbWF6b24gUmVzb3VyY2UgTmFtZSAoQVJOKSBmb3IgYSB0YXJnZXQgZ3JvdXAgaW4gdGhpcyBhY2NvdW50IGFuZCBSZWdpb24uIEZvciBDbGFzc2ljIExvYWQgQmFsYW5jZXJzLCB0aGlzIHdpbGwgYmUgdGhlIG5hbWUgb2YgdGhlIENsYXNzaWMgTG9hZCBCYWxhbmNlciBpbiB0aGlzIGFjY291bnQgYW5kIFJlZ2lvbi5cbiAqICBGb3IgZXhhbXBsZTogXG4gKiAgICsgIEFwcGxpY2F0aW9uIExvYWQgQmFsYW5jZXIgQVJOOiBgYGFybjphd3M6ZWxhc3RpY2xvYWRiYWxhbmNpbmc6dXMtd2VzdC0yOjEyMzQ1Njc4OTAxMjp0YXJnZXRncm91cC9teS10YXJnZXRzLzEyMzQ1Njc4OTAxMjM0NTZgYCBcbiAqICAgKyAgQ2xhc3NpYyBMb2FkIEJhbGFuY2VyIG5hbWU6IGBgbXktY2xhc3NpYy1sb2FkLWJhbGFuY2VyYGAgXG4gKiAgICsgIFZQQyBMYXR0aWNlIEFSTjogYGBhcm46YXdzOnZwYy1sYXR0aWNlOnVzLXdlc3QtMjoxMjM0NTY3ODkwMTI6dGFyZ2V0Z3JvdXAvdGctMTIzNDU2Nzg5MDEyMzQ1NmBgIFxuICogICBcbiAqICBUbyBnZXQgdGhlIEFSTiBvZiBhIHRhcmdldCBncm91cCBmb3IgYSBBcHBsaWNhdGlvbiBMb2FkIEJhbGFuY2VyLCBHYXRld2F5IExvYWQgQmFsYW5jZXIsIG9yIE5ldHdvcmsgTG9hZCBCYWxhbmNlciwgb3IgdGhlIG5hbWUgb2YgYSBDbGFzc2ljIExvYWQgQmFsYW5jZXIsIHVzZSB0aGUgRWxhc3RpYyBMb2FkIEJhbGFuY2luZyBbRGVzY3JpYmVUYXJnZXRHcm91cHNdKGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9lbGFzdGljbG9hZGJhbGFuY2luZy9sYXRlc3QvQVBJUmVmZXJlbmNlL0FQSV9EZXNjcmliZVRhcmdldEdyb3Vwcy5odG1sKSBhbmQgW0Rlc2NyaWJlTG9hZEJhbGFuY2Vyc10oaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL2VsYXN0aWNsb2FkYmFsYW5jaW5nL2xhdGVzdC9BUElSZWZlcmVuY2UvQVBJX0Rlc2NyaWJlTG9hZEJhbGFuY2Vycy5odG1sKSBBUEkgb3BlcmF0aW9ucy5cbiAqICBUbyBnZXQgdGhlIEFSTiBvZiBhIHRhcmdldCBncm91cCBmb3IgVlBDIExhdHRpY2UsIHVzZSB0aGUgVlBDIExhdHRpY2UgW0dldFRhcmdldEdyb3VwXShodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vdnBjLWxhdHRpY2UvbGF0ZXN0L0FQSVJlZmVyZW5jZS9BUElfR2V0VGFyZ2V0R3JvdXAuaHRtbCkgQVBJIG9wZXJhdGlvbi5cbiAqL1xuSWRlbnRpZmllcjogc3RyaW5nXG59XG4vKipcbiAqIFRoZSBjYXBhY2l0eSByZXNlcnZhdGlvbiBzcGVjaWZpY2F0aW9uLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIENhcGFjaXR5UmVzZXJ2YXRpb25TcGVjaWZpY2F0aW9uIHtcbi8qKlxuICogVGhlIGNhcGFjaXR5IHJlc2VydmF0aW9uIHByZWZlcmVuY2UuIFRoZSBmb2xsb3dpbmcgb3B0aW9ucyBhcmUgYXZhaWxhYmxlOiBcbiAqICAgKyAgIGBgY2FwYWNpdHktcmVzZXJ2YXRpb25zLW9ubHlgYCAtIEF1dG8gU2NhbGluZyB3aWxsIG9ubHkgbGF1bmNoIGluc3RhbmNlcyBpbnRvIGEgQ2FwYWNpdHkgUmVzZXJ2YXRpb24gb3IgQ2FwYWNpdHkgUmVzZXJ2YXRpb24gcmVzb3VyY2UgZ3JvdXAuIElmIGNhcGFjaXR5IGlzbid0IGF2YWlsYWJsZSwgaW5zdGFuY2VzIHdpbGwgZmFpbCB0byBsYXVuY2guXG4gKiAgICsgICBgYGNhcGFjaXR5LXJlc2VydmF0aW9ucy1maXJzdGBgIC0gQXV0byBTY2FsaW5nIHdpbGwgdHJ5IHRvIGxhdW5jaCBpbnN0YW5jZXMgaW50byBhIENhcGFjaXR5IFJlc2VydmF0aW9uIG9yIENhcGFjaXR5IFJlc2VydmF0aW9uIHJlc291cmNlIGdyb3VwIGZpcnN0LiBJZiBjYXBhY2l0eSBpc24ndCBhdmFpbGFibGUsIGluc3RhbmNlcyB3aWxsIHJ1biBpbiBPbi1EZW1hbmQgY2FwYWNpdHkuXG4gKiAgICsgICBgYG5vbmVgYCAtIEF1dG8gU2NhbGluZyB3aWxsIG5vdCBsYXVuY2ggaW5zdGFuY2VzIGludG8gYSBDYXBhY2l0eSBSZXNlcnZhdGlvbi4gSW5zdGFuY2VzIHdpbGwgcnVuIGluIE9uLURlbWFuZCBjYXBhY2l0eS4gXG4gKiAgICsgICBgYGRlZmF1bHRgYCAtIEF1dG8gU2NhbGluZyB1c2VzIHRoZSBDYXBhY2l0eSBSZXNlcnZhdGlvbiBwcmVmZXJlbmNlIGZyb20geW91ciBsYXVuY2ggdGVtcGxhdGUgb3IgYW4gb3BlbiBDYXBhY2l0eSBSZXNlcnZhdGlvbi5cbiAqL1xuQ2FwYWNpdHlSZXNlcnZhdGlvblByZWZlcmVuY2U6IHN0cmluZ1xuQ2FwYWNpdHlSZXNlcnZhdGlvblRhcmdldD86IENhcGFjaXR5UmVzZXJ2YXRpb25UYXJnZXRcbn1cbi8qKlxuICogRGVzY3JpYmVzIGEgdGFyZ2V0IENhcGFjaXR5IFJlc2VydmF0aW9uIG9yIENhcGFjaXR5IFJlc2VydmF0aW9uIHJlc291cmNlIGdyb3VwLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIENhcGFjaXR5UmVzZXJ2YXRpb25UYXJnZXQge1xuQ2FwYWNpdHlSZXNlcnZhdGlvbklkcz86IENhcGFjaXR5UmVzZXJ2YXRpb25JZHNcbkNhcGFjaXR5UmVzZXJ2YXRpb25SZXNvdXJjZUdyb3VwQXJucz86IENhcGFjaXR5UmVzZXJ2YXRpb25SZXNvdXJjZUdyb3VwQXJuc1xufVxuIl19
|
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXdzLWJlZHJvY2stYmx1ZXByaW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiYXdzLWJlZHJvY2stYmx1ZXByaW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIERlZmluaXRpb24gb2YgQVdTOjpCZWRyb2NrOjpCbHVlcHJpbnQgUmVzb3VyY2UgVHlwZVxuICovXG5leHBvcnQgaW50ZXJmYWNlIF9BV1NfQkVEUk9DS19CTFVFUFJJTlQge1xuLyoqXG4gKiBBUk4gb2YgYSBCbHVlcHJpbnRcbiAqL1xuQmx1ZXByaW50QXJuPzogc3RyaW5nXG4vKipcbiAqIE5hbWUgb2YgdGhlIEJsdWVwcmludFxuICovXG5CbHVlcHJpbnROYW1lOiBzdHJpbmdcbi8qKlxuICogQ3JlYXRpb24gdGltZXN0YW1wXG4gKi9cbkNyZWF0aW9uVGltZT86IHN0cmluZ1xuLyoqXG4gKiBMYXN0IG1vZGlmaWVkIHRpbWVzdGFtcFxuICovXG5MYXN0TW9kaWZpZWRUaW1lPzogc3RyaW5nXG4vKipcbiAqIFNjaGVtYSBvZiB0aGUgYmx1ZXByaW50XG4gKi9cblNjaGVtYToge1xuW2s6IHN0cmluZ106IHVua25vd25cbn1cbi8qKlxuICogTW9kYWxpdHkgVHlwZVxuICovXG5UeXBlOiAoXCJET0NVTUVOVFwiIHwgXCJJTUFHRVwiIHwgXCJBVURJT1wiIHwgXCJWSURFT1wiKVxuLyoqXG4gKiBTdGFnZSBvZiB0aGUgQmx1ZXByaW50XG4gKi9cbkJsdWVwcmludFN0YWdlPzogKFwiREVWRUxPUE1FTlRcIiB8IFwiTElWRVwiKVxuLyoqXG4gKiBLTVMga2V5IGlkZW50aWZpZXJcbiAqL1xuS21zS2V5SWQ/OiBzdHJpbmdcbi8qKlxuICogS01TIGVuY3J5cHRpb24gY29udGV4dFxuICovXG5LbXNFbmNyeXB0aW9uQ29udGV4dD86IHtcbi8qKlxuICogVGhpcyBpbnRlcmZhY2Ugd2FzIHJlZmVyZW5jZWQgYnkgYHVuZGVmaW5lZGAncyBKU09OLVNjaGVtYSBkZWZpbml0aW9uXG4gKiB2aWEgdGhlIGBwYXR0ZXJuUHJvcGVydHlgIFwiXi4qJFwiLlxuICovXG5bazogc3RyaW5nXTogc3RyaW5nXG59XG4vKipcbiAqIExpc3Qgb2YgVGFnc1xuICogXG4gKiBAbWluSXRlbXMgMFxuICogQG1heEl0ZW1zIDIwMFxuICovXG5UYWdzPzogVGFnW11cbn1cbi8qKlxuICogRGVmaW5pdGlvbiBvZiB0aGUga2V5L3ZhbHVlIHBhaXIgZm9yIGEgdGFnXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgVGFnIHtcbi8qKlxuICogS2V5IGZvciB0aGUgdGFnXG4gKi9cbktleTogc3RyaW5nXG4vKipcbiAqIFZhbHVlIGZvciB0aGUgdGFnXG4gKi9cblZhbHVlOiBzdHJpbmdcbn1cbiJdfQ==
|
|
@@ -46,7 +46,7 @@ export interface ParametersInCacheKeyAndForwardedToOrigin {
|
|
|
46
46
|
CookiesConfig: CookiesConfig;
|
|
47
47
|
/**
|
|
48
48
|
* A flag that can affect whether the ``Accept-Encoding`` HTTP header is included in the cache key and included in requests that CloudFront sends to the origin.
|
|
49
|
-
* This field is related to the ``EnableAcceptEncodingGzip`` field. If one or both of these fields is ``true
|
|
49
|
+
* This field is related to the ``EnableAcceptEncodingGzip`` field. If one or both of these fields is ``true``*and* the viewer request includes the ``Accept-Encoding`` header, then CloudFront does the following:
|
|
50
50
|
* + Normalizes the value of the viewer's ``Accept-Encoding`` header
|
|
51
51
|
* + Includes the normalized header in the cache key
|
|
52
52
|
* + Includes the normalized header in the request to the origin, if a request is necessary
|
|
@@ -58,7 +58,7 @@ export interface ParametersInCacheKeyAndForwardedToOrigin {
|
|
|
58
58
|
EnableAcceptEncodingBrotli?: boolean;
|
|
59
59
|
/**
|
|
60
60
|
* A flag that can affect whether the ``Accept-Encoding`` HTTP header is included in the cache key and included in requests that CloudFront sends to the origin.
|
|
61
|
-
* This field is related to the ``EnableAcceptEncodingBrotli`` field. If one or both of these fields is ``true
|
|
61
|
+
* This field is related to the ``EnableAcceptEncodingBrotli`` field. If one or both of these fields is ``true``*and* the viewer request includes the ``Accept-Encoding`` header, then CloudFront does the following:
|
|
62
62
|
* + Normalizes the value of the viewer's ``Accept-Encoding`` header
|
|
63
63
|
* + Includes the normalized header in the cache key
|
|
64
64
|
* + Includes the normalized header in the request to the origin, if a request is necessary
|
|
@@ -77,10 +77,10 @@ export interface ParametersInCacheKeyAndForwardedToOrigin {
|
|
|
77
77
|
export interface CookiesConfig {
|
|
78
78
|
/**
|
|
79
79
|
* Determines whether any cookies in viewer requests are included in the cache key and in requests that CloudFront sends to the origin. Valid values are:
|
|
80
|
-
* +
|
|
81
|
-
* +
|
|
82
|
-
* +
|
|
83
|
-
* +
|
|
80
|
+
* + ``none`` – No cookies in viewer requests are included in the cache key or in requests that CloudFront sends to the origin. Even when this field is set to ``none``, any cookies that are listed in an ``OriginRequestPolicy``*are* included in origin requests.
|
|
81
|
+
* + ``whitelist`` – Only the cookies in viewer requests that are listed in the ``CookieNames`` type are included in the cache key and in requests that CloudFront sends to the origin.
|
|
82
|
+
* + ``allExcept`` – All cookies in viewer requests are included in the cache key and in requests that CloudFront sends to the origin, *except* for those that are listed in the ``CookieNames`` type, which are not included.
|
|
83
|
+
* + ``all`` – All cookies in viewer requests are included in the cache key and in requests that CloudFront sends to the origin.
|
|
84
84
|
*/
|
|
85
85
|
CookieBehavior: string;
|
|
86
86
|
/**
|
|
@@ -94,8 +94,8 @@ export interface CookiesConfig {
|
|
|
94
94
|
export interface HeadersConfig {
|
|
95
95
|
/**
|
|
96
96
|
* Determines whether any HTTP headers are included in the cache key and in requests that CloudFront sends to the origin. Valid values are:
|
|
97
|
-
* +
|
|
98
|
-
* +
|
|
97
|
+
* + ``none`` – No HTTP headers are included in the cache key or in requests that CloudFront sends to the origin. Even when this field is set to ``none``, any headers that are listed in an ``OriginRequestPolicy``*are* included in origin requests.
|
|
98
|
+
* + ``whitelist`` – Only the HTTP headers that are listed in the ``Headers`` type are included in the cache key and in requests that CloudFront sends to the origin.
|
|
99
99
|
*/
|
|
100
100
|
HeaderBehavior: string;
|
|
101
101
|
/**
|
|
@@ -109,10 +109,10 @@ export interface HeadersConfig {
|
|
|
109
109
|
export interface QueryStringsConfig {
|
|
110
110
|
/**
|
|
111
111
|
* Determines whether any URL query strings in viewer requests are included in the cache key and in requests that CloudFront sends to the origin. Valid values are:
|
|
112
|
-
* +
|
|
113
|
-
* +
|
|
114
|
-
* +
|
|
115
|
-
* +
|
|
112
|
+
* + ``none`` – No query strings in viewer requests are included in the cache key or in requests that CloudFront sends to the origin. Even when this field is set to ``none``, any query strings that are listed in an ``OriginRequestPolicy``*are* included in origin requests.
|
|
113
|
+
* + ``whitelist`` – Only the query strings in viewer requests that are listed in the ``QueryStringNames`` type are included in the cache key and in requests that CloudFront sends to the origin.
|
|
114
|
+
* + ``allExcept`` – All query strings in viewer requests are included in the cache key and in requests that CloudFront sends to the origin, *except* those that are listed in the ``QueryStringNames`` type, which are not included.
|
|
115
|
+
* + ``all`` – All query strings in viewer requests are included in the cache key and in requests that CloudFront sends to the origin.
|
|
116
116
|
*/
|
|
117
117
|
QueryStringBehavior: string;
|
|
118
118
|
/**
|