{
  "version": "2.0",
  "service": "API for AWS Elemental MediaConnect",
  "operations": {
    "AddFlowOutputs": "Adds outputs to an existing flow. You can create up to 50 outputs per flow.",
    "AddFlowSources": "Adds Sources to flow",
    "AddFlowVpcInterfaces": "Adds VPC interfaces to flow",
    "CreateFlow": "Creates a new flow. The request must include one source. The request optionally can include outputs (up to 50) and entitlements (up to 50).",
    "DeleteFlow": "Deletes a flow. Before you can delete a flow, you must stop the flow.",
    "DescribeFlow": "Displays the details of a flow. The response includes the flow ARN, name, and Availability Zone, as well as details about the source, outputs, and entitlements.",
    "GrantFlowEntitlements": "Grants entitlements to an existing flow.",
    "ListEntitlements": "Displays a list of all entitlements that have been granted to this account. This request returns 20 results per page.",
    "ListFlows": "Displays a list of flows that are associated with this account. This request returns a paginated result.",
    "ListTagsForResource": "List all tags on an AWS Elemental MediaConnect resource",
    "RemoveFlowOutput": "Removes an output from an existing flow. This request can be made only on an output that does not have an entitlement associated with it. If the output has an entitlement, you must revoke the entitlement instead. When an entitlement is revoked from a flow, the service automatically removes the associated output.",
    "RemoveFlowSource": "Removes a source from an existing flow. This request can be made only if there is more than one source on the flow.",
    "RemoveFlowVpcInterface": "Removes a VPC Interface from an existing flow. This request can be made only on a VPC interface that does not have a Source or Output associated with it. If the VPC interface is referenced by a Source or Output, you must first delete or update the Source or Output to no longer reference the VPC interface.",
    "RevokeFlowEntitlement": "Revokes an entitlement from a flow. Once an entitlement is revoked, the content becomes unavailable to the subscriber and the associated output is removed.",
    "StartFlow": "Starts a flow.",
    "StopFlow": "Stops a flow.",
    "TagResource": "Associates the specified tags to a resource with the specified resourceArn. If existing tags on a resource are not specified in the request parameters, they are not changed. When a resource is deleted, the tags associated with that resource are deleted as well.",
    "UntagResource": "Deletes specified tags from a resource.",
    "UpdateFlow": "Updates flow",
    "UpdateFlowEntitlement": "You can change an entitlement's description, subscribers, and encryption. If you change the subscribers, the service will remove the outputs that are are used by the subscribers that are removed.",
    "UpdateFlowOutput": "Updates an existing flow output.",
    "UpdateFlowSource": "Updates the source of a flow."
  },
  "shapes": {
    "AddFlowOutputs420Exception": {
      "base": "Exception raised by AWS Elemental MediaConnect. See the error message and documentation for the operation for more information on the cause of this exception.",
      "refs": {}
    },
    "AddFlowOutputsRequest": {
      "base": "Adds outputs to an existing flow. You can create up to 50 outputs per flow.",
      "refs": {}
    },
    "AddFlowOutputsResponse": {
      "base": "The result of a successful AddOutput request. The response includes the details of the newly added outputs.",
      "refs": {}
    },
    "AddFlowSourcesRequest": {
      "base": "Adds sources to an existing flow.",
      "refs": {}
    },
    "AddFlowSourcesResponse": {
      "base": "The result of a successful AddFlowSources request. The response includes the details of the newly added sources.",
      "refs": {}
    },
    "AddFlowVpcInterfacesRequest": {
      "base": "Adds VPC interfaces to an existing flow.",
      "refs": {}
    },
    "AddFlowVpcInterfacesResponse": {
      "base": "The result of a successful AddFlowVpcInterfaces request. The response includes the details of the newly added VPC interfaces.",
      "refs": {}
    },
    "AddOutputRequest": {
      "base": "The output that you want to add to this flow.",
      "refs": {
        "__listOfAddOutputRequest$member": null
      }
    },
    "Algorithm": {
      "base": null,
      "refs": {
        "Encryption$Algorithm": "The type of algorithm that is used for the encryption (such as aes128, aes192, or aes256).",
        "UpdateEncryption$Algorithm": "The type of algorithm that is used for the encryption (such as aes128, aes192, or aes256)."
      }
    },
    "BadRequestException": {
      "base": "Exception raised by AWS Elemental MediaConnect. See the error message and documentation for the operation for more information on the cause of this exception.",
      "refs": {}
    },
    "CreateFlow420Exception": {
      "base": "Exception raised by AWS Elemental MediaConnect. See the error message and documentation for the operation for more information on the cause of this exception.",
      "refs": {}
    },
    "CreateFlowRequest": {
      "base": "Creates a new flow. The request must include one source. The request optionally can include outputs (up to 50) and one entitlement.",
      "refs": {}
    },
    "CreateFlowResponse": {
      "base": "The result of a successful CreateFlow request.",
      "refs": {}
    },
    "DeleteFlowResponse": {
      "base": "The result of a successful DeleteFlow request.",
      "refs": {}
    },
    "DescribeFlowResponse": {
      "base": "The result of a successful DescribeFlow request.",
      "refs": {}
    },
    "Encryption": {
      "base": "Information about the encryption of the flow.",
      "refs": {
        "AddOutputRequest$Encryption": "The type of key used for the encryption. If no keyType is provided, the service will use the default setting (static-key).",
        "Entitlement$Encryption": "The type of encryption that will be used on the output that is associated with this entitlement.",
        "GrantEntitlementRequest$Encryption": "The type of encryption that will be used on the output that is associated with this entitlement.",
        "Output$Encryption": "The type of key used for the encryption. If no keyType is provided, the service will use the default setting (static-key).",
        "SetSourceRequest$Decryption": "The type of encryption that is used on the content ingested from this source.",
        "Source$Decryption": "The type of encryption that is used on the content ingested from this source."
      }
    },
    "Entitlement": {
      "base": "The settings for a flow entitlement.",
      "refs": {
        "UpdateFlowEntitlementResponse$Entitlement": null,
        "__listOfEntitlement$member": null
      }
    },
    "EntitlementStatus": {
      "base": null,
      "refs": {
        "Entitlement$EntitlementStatus": "An indication of whether the entitlement is enabled.",
        "GrantEntitlementRequest$EntitlementStatus": "An indication of whether the new entitlement should be enabled or disabled as soon as it is created. If you don\u2019t specify the entitlementStatus field in your request, MediaConnect sets it to ENABLED.",
        "UpdateFlowEntitlementRequest$EntitlementStatus": "An indication of whether you want to enable the entitlement to allow access, or disable it to stop streaming content to the subscriber\u2019s flow temporarily. If you don\u2019t specify the entitlementStatus field in your request, MediaConnect leaves the value unchanged."
      }
    },
    "FailoverConfig": {
      "base": "The settings for source failover",
      "refs": {
        "CreateFlowRequest$SourceFailoverConfig": null,
        "Flow$SourceFailoverConfig": null
      }
    },
    "Flow": {
      "base": "The settings for a flow, including its source, outputs, and entitlements.",
      "refs": {
        "CreateFlowResponse$Flow": null,
        "DescribeFlowResponse$Flow": null,
        "UpdateFlowResponse$Flow": null
      }
    },
    "ForbiddenException": {
      "base": "Exception raised by AWS Elemental MediaConnect. See the error message and documentation for the operation for more information on the cause of this exception.",
      "refs": {}
    },
    "GrantEntitlementRequest": {
      "base": "The entitlements that you want to grant on a flow.",
      "refs": {
        "__listOfGrantEntitlementRequest$member": null
      }
    },
    "GrantFlowEntitlements420Exception": {
      "base": "Exception raised by AWS Elemental MediaConnect. See the error message and documentation for the operation for more information on the cause of this exception.",
      "refs": {}
    },
    "GrantFlowEntitlementsRequest": {
      "base": "Grants an entitlement on a flow.",
      "refs": {}
    },
    "GrantFlowEntitlementsResponse": {
      "base": "The entitlements that were just granted.",
      "refs": {}
    },
    "InternalServerErrorException": {
      "base": "Exception raised by AWS Elemental MediaConnect. See the error message and documentation for the operation for more information on the cause of this exception.",
      "refs": {}
    },
    "KeyType": {
      "base": null,
      "refs": {
        "Encryption$KeyType": "The type of key that is used for the encryption. If no keyType is provided, the service will use the default setting (static-key).",
        "UpdateEncryption$KeyType": "The type of key that is used for the encryption. If no keyType is provided, the service will use the default setting (static-key)."
      }
    },
    "ListEntitlementsResponse": {
      "base": "The result of a successful ListEntitlements request. The response includes the ARN of each entitlement, the name of the associated flow, and the NextToken to use in a subsequent ListEntitlements request.",
      "refs": {}
    },
    "ListFlowsResponse": {
      "base": "The result of a successful ListFlows request. The response includes flow summaries and the NextToken to use in a subsequent ListFlows request.",
      "refs": {}
    },
    "ListTagsForResourceResponse": {
      "base": "The tags for the resource.",
      "refs": {}
    },
    "ListedEntitlement": {
      "base": "An entitlement that has been granted to you from other AWS accounts.",
      "refs": {
        "__listOfListedEntitlement$member": null
      }
    },
    "ListedFlow": {
      "base": "Provides a summary of a flow, including its ARN, Availability Zone, and source type.",
      "refs": {
        "__listOfListedFlow$member": null
      }
    },
    "Messages": {
      "base": "Messages that provide the state of the flow.",
      "refs": {
        "DescribeFlowResponse$Messages": null
      }
    },
    "NotFoundException": {
      "base": "Exception raised by AWS Elemental MediaConnect. See the error message and documentation for the operation for more information on the cause of this exception.",
      "refs": {}
    },
    "Output": {
      "base": "The settings for an output.",
      "refs": {
        "UpdateFlowOutputResponse$Output": null,
        "__listOfOutput$member": null
      }
    },
    "Protocol": {
      "base": null,
      "refs": {
        "AddOutputRequest$Protocol": "The protocol to use for the output.",
        "SetSourceRequest$Protocol": "The protocol that is used by the source.",
        "Transport$Protocol": "The protocol that is used by the source or output.",
        "UpdateFlowOutputRequest$Protocol": "The protocol to use for the output.",
        "UpdateFlowSourceRequest$Protocol": "The protocol that is used by the source."
      }
    },
    "RemoveFlowOutputResponse": {
      "base": "The result of a successful RemoveFlowOutput request including the flow ARN and the output ARN that was removed.",
      "refs": {}
    },
    "RemoveFlowSourceResponse": {
      "base": "The result of a successful RemoveFlowSource request including the flow ARN and the source ARN that was removed.",
      "refs": {}
    },
    "RemoveFlowVpcInterfaceResponse": {
      "base": "The result of a successful RemoveFlowVpcInterface request including the flow ARN and the VPC interface name that was removed.",
      "refs": {}
    },
    "ResponseError": {
      "base": "Exception raised by AWS Elemental MediaConnect. See the error message and documentation for the operation for more information on the cause of this exception.",
      "refs": {}
    },
    "RevokeFlowEntitlementResponse": {
      "base": "The result of a successful RevokeFlowEntitlement request. The response includes the ARN of the flow that was updated and the ARN of the entitlement that was revoked.",
      "refs": {}
    },
    "ServiceUnavailableException": {
      "base": "Exception raised by AWS Elemental MediaConnect. See the error message and documentation for the operation for more information on the cause of this exception.",
      "refs": {}
    },
    "SetSourceRequest": {
      "base": "The settings for the source of the flow.",
      "refs": {
        "CreateFlowRequest$Source": null,
        "__listOfSetSourceRequest$member": null
      }
    },
    "Source": {
      "base": "The settings for the source of the flow.",
      "refs": {
        "Flow$Source": null,
        "UpdateFlowSourceResponse$Source": "The settings for the source of the flow.",
        "__listOfSource$member": null
      }
    },
    "SourceType": {
      "base": null,
      "refs": {
        "ListedFlow$SourceType": "The type of source. This value is either owned (originated somewhere other than an AWS Elemental MediaConnect flow owned by another AWS account) or entitled (originated at an AWS Elemental MediaConnect flow owned by another AWS account)."
      }
    },
    "StartFlowResponse": {
      "base": "The result of a successful StartFlow request.",
      "refs": {}
    },
    "State": {
      "base": null,
      "refs": {
        "FailoverConfig$State": null,
        "UpdateFailoverConfig$State": null
      }
    },
    "Status": {
      "base": null,
      "refs": {
        "DeleteFlowResponse$Status": "The status of the flow when the DeleteFlow process begins.",
        "Flow$Status": "The current status of the flow.",
        "ListedFlow$Status": "The current status of the flow.",
        "StartFlowResponse$Status": "The status of the flow when the StartFlow process begins.",
        "StopFlowResponse$Status": "The status of the flow when the StopFlow process begins."
      }
    },
    "StopFlowResponse": {
      "base": "The result of a successful StopFlow request.",
      "refs": {}
    },
    "TagResourceRequest": {
      "base": "The tags to add to the resource. Tag keys can have a maximum character length of 128 characters, and tag values can have a maximum length of 256 characters.",
      "refs": {}
    },
    "TooManyRequestsException": {
      "base": "Exception raised by AWS Elemental MediaConnect. See the error message and documentation for the operation for more information on the cause of this exception.",
      "refs": {}
    },
    "Transport": {
      "base": "Attributes related to the transport stream that are used in a source or output.",
      "refs": {
        "Output$Transport": "Attributes related to the transport stream that are used in the output.",
        "Source$Transport": "Attributes related to the transport stream that are used in the source."
      }
    },
    "UpdateEncryption": {
      "base": "Information about the encryption of the flow.",
      "refs": {
        "UpdateFlowEntitlementRequest$Encryption": "The type of encryption that will be used on the output associated with this entitlement.",
        "UpdateFlowOutputRequest$Encryption": "The type of key used for the encryption. If no keyType is provided, the service will use the default setting (static-key).",
        "UpdateFlowSourceRequest$Decryption": "The type of encryption used on the content ingested from this source."
      }
    },
    "UpdateFailoverConfig": {
      "base": "The settings for source failover",
      "refs": {
        "UpdateFlowRequest$SourceFailoverConfig": null
      }
    },
    "UpdateFlowEntitlementRequest": {
      "base": "The updates that you want to make to a specific entitlement.",
      "refs": {}
    },
    "UpdateFlowEntitlementResponse": {
      "base": "The result of a successful UpdateFlowEntitlement request. The response includes the ARN of the flow that was updated and the updated entitlement configuration.",
      "refs": {}
    },
    "UpdateFlowOutputRequest": {
      "base": "The updates that you want to make to an existing output of an existing flow.",
      "refs": {}
    },
    "UpdateFlowOutputResponse": {
      "base": "The result of a successful UpdateFlowOutput request including the flow ARN and the updated output.",
      "refs": {}
    },
    "UpdateFlowRequest": {
      "base": "Updates an existing flow.",
      "refs": {}
    },
    "UpdateFlowResponse": {
      "base": "Updates an existing flow.",
      "refs": {}
    },
    "UpdateFlowSourceRequest": {
      "base": "The settings for the updated source of the flow.",
      "refs": {}
    },
    "UpdateFlowSourceResponse": {
      "base": "The result of a successful UpdateFlowSource request. The response includes the ARN of the flow that was updated and the updated source configuration.",
      "refs": {}
    },
    "VpcInterface": {
      "base": "The settings for a VPC Source.",
      "refs": {
        "__listOfVpcInterface$member": null
      }
    },
    "VpcInterfaceAttachment": {
      "base": "The settings for attaching a VPC interface to an output.",
      "refs": {
        "AddOutputRequest$VpcInterfaceAttachment": "The name of the VPC interface attachment to use for this output.",
        "Output$VpcInterfaceAttachment": "The name of the VPC interface attachment to use for this output.",
        "UpdateFlowOutputRequest$VpcInterfaceAttachment": "The name of the VPC interface attachment to use for this output."
      }
    },
    "VpcInterfaceRequest": {
      "base": "Desired VPC Interface for a Flow",
      "refs": {
        "__listOfVpcInterfaceRequest$member": null
      }
    },
    "__integer": {
      "base": null,
      "refs": {
        "AddOutputRequest$Port": "The port to use when content is distributed to this output.",
        "Entitlement$DataTransferSubscriberFeePercent": "Percentage from 0-100 of the data transfer cost to be billed to the subscriber.",
        "FailoverConfig$RecoveryWindow": "Search window time to look for dash-7 packets",
        "GrantEntitlementRequest$DataTransferSubscriberFeePercent": "Percentage from 0-100 of the data transfer cost to be billed to the subscriber.",
        "ListedEntitlement$DataTransferSubscriberFeePercent": "Percentage from 0-100 of the data transfer cost to be billed to the subscriber.",
        "Output$DataTransferSubscriberFeePercent": "Percentage from 0-100 of the data transfer cost to be billed to the subscriber.",
        "Output$Port": "The port to use when content is distributed to this output.",
        "SetSourceRequest$IngestPort": "The port that the flow will be listening on for incoming content.",
        "Source$DataTransferSubscriberFeePercent": "Percentage from 0-100 of the data transfer cost to be billed to the subscriber.",
        "Source$IngestPort": "The port that the flow will be listening on for incoming content.",
        "UpdateFailoverConfig$RecoveryWindow": "Recovery window time to look for dash-7 packets",
        "UpdateFlowOutputRequest$Port": "The port to use when content is distributed to this output.",
        "UpdateFlowSourceRequest$IngestPort": "The port that the flow will be listening on for incoming content.",
        "AddOutputRequest$MaxLatency": "The maximum latency in milliseconds for Zixi-based streams.",
        "AddOutputRequest$SmoothingLatency": "The smoothing latency in milliseconds for RIST, RTP, and RTP-FEC streams.",
        "SetSourceRequest$MaxBitrate": "The smoothing max bitrate for RIST, RTP, and RTP-FEC streams.",
        "SetSourceRequest$MaxLatency": "The maximum latency in milliseconds. This parameter applies only to RIST-based and Zixi-based streams.",
        "Transport$MaxBitrate": "The smoothing max bitrate for RIST, RTP, and RTP-FEC streams.",
        "Transport$MaxLatency": "The maximum latency in milliseconds. This parameter applies only to RIST-based and Zixi-based streams.",
        "Transport$SmoothingLatency": "The smoothing latency in milliseconds for RIST, RTP, and RTP-FEC streams.",
        "UpdateFlowOutputRequest$MaxLatency": "The maximum latency in milliseconds for Zixi-based streams.",
        "UpdateFlowOutputRequest$SmoothingLatency": "The smoothing latency in milliseconds for RIST, RTP, and RTP-FEC streams.",
        "UpdateFlowSourceRequest$MaxBitrate": "The smoothing max bitrate for RIST, RTP, and RTP-FEC streams.",
        "UpdateFlowSourceRequest$MaxLatency": "The maximum latency in milliseconds. This parameter applies only to RIST-based and Zixi-based streams."
      }
    },
    "__listOfAddOutputRequest": {
      "base": null,
      "refs": {
        "AddFlowOutputsRequest$Outputs": "A list of outputs that you want to add.",
        "CreateFlowRequest$Outputs": "The outputs that you want to add to this flow."
      }
    },
    "__listOfEntitlement": {
      "base": null,
      "refs": {
        "Flow$Entitlements": "The entitlements in this flow.",
        "GrantFlowEntitlementsResponse$Entitlements": "The entitlements that were just granted."
      }
    },
    "__listOfGrantEntitlementRequest": {
      "base": null,
      "refs": {
        "CreateFlowRequest$Entitlements": "The entitlements that you want to grant on a flow.",
        "GrantFlowEntitlementsRequest$Entitlements": "The list of entitlements that you want to grant."
      }
    },
    "__listOfListedEntitlement": {
      "base": null,
      "refs": {
        "ListEntitlementsResponse$Entitlements": "A list of entitlements that have been granted to you from other AWS accounts."
      }
    },
    "__listOfListedFlow": {
      "base": null,
      "refs": {
        "ListFlowsResponse$Flows": "A list of flow summaries."
      }
    },
    "__listOfOutput": {
      "base": null,
      "refs": {
        "AddFlowOutputsResponse$Outputs": "The details of the newly added outputs.",
        "Flow$Outputs": "The outputs in this flow."
      }
    },
    "__listOfSetSourceRequest": {
      "base": null,
      "refs": {
        "AddFlowSourcesRequest$Sources": "A list of sources that you want to add.",
        "CreateFlowRequest$Sources": null
      }
    },
    "__listOfSource": {
      "base": null,
      "refs": {
        "AddFlowSourcesResponse$Sources": "The details of the newly added sources.",
        "Flow$Sources": null
      }
    },
    "__listOfVpcInterface": {
      "base": null,
      "refs": {
        "AddFlowVpcInterfacesResponse$VpcInterfaces": "The details of the newly added VPC interfaces.",
        "Flow$VpcInterfaces": "The VPC Interfaces for this flow."
      }
    },
    "__listOfVpcInterfaceRequest": {
      "base": null,
      "refs": {
        "AddFlowVpcInterfacesRequest$VpcInterfaces": "A list of VPC interfaces that you want to add.",
        "CreateFlowRequest$VpcInterfaces": "The VPC interfaces you want on the flow."
      }
    },
    "__listOf__string": {
      "base": null,
      "refs": {
        "AddOutputRequest$CidrAllowList": "The range of IP addresses that should be allowed to initiate output requests to this flow. These IP addresses should be in the form of a Classless Inter-Domain Routing (CIDR) block; for example, 10.0.0.0/16.",
        "Entitlement$Subscribers": "The AWS account IDs that you want to share your content with. The receiving accounts (subscribers) will be allowed to create their own flow using your content as the source.",
        "GrantEntitlementRequest$Subscribers": "The AWS account IDs that you want to share your content with. The receiving accounts (subscribers) will be allowed to create their own flows using your content as the source.",
        "Messages$Errors": "A list of errors that might have been generated from processes on this flow.",
        "RemoveFlowVpcInterfaceResponse$NonDeletedNetworkInterfaceIds": "IDs of network interfaces associated with the removed VPC interface that Media Connect was unable to remove.",
        "Transport$CidrAllowList": "The range of IP addresses that should be allowed to initiate output requests to this flow. These IP addresses should be in the form of a Classless Inter-Domain Routing (CIDR) block; for example, 10.0.0.0/16.",
        "UpdateFlowEntitlementRequest$Subscribers": "The AWS account IDs that you want to share your content with. The receiving accounts (subscribers) will be allowed to create their own flow using your content as the source.",
        "UpdateFlowOutputRequest$CidrAllowList": "The range of IP addresses that should be allowed to initiate output requests to this flow. These IP addresses should be in the form of a Classless Inter-Domain Routing (CIDR) block; for example, 10.0.0.0/16.",
        "VpcInterface$NetworkInterfaceIds": "IDs of the network interfaces created in customer's account by MediaConnect.",
        "VpcInterface$SecurityGroupIds": "Security Group IDs to be used on ENI.",
        "VpcInterfaceRequest$SecurityGroupIds": "Security Group IDs to be used on ENI."
      }
    },
    "__mapOf__string": {
      "base": null,
      "refs": {
        "ListTagsForResourceResponse$Tags": "A map from tag keys to values. Tag keys can have a maximum character length of 128 characters, and tag values can have a maximum length of 256 characters.",
        "TagResourceRequest$Tags": "A map from tag keys to values. Tag keys can have a maximum character length of 128 characters, and tag values can have a maximum length of 256 characters."
      }
    },
    "__string": {
      "base": null,
      "refs": {
        "AddFlowOutputsResponse$FlowArn": "The ARN of the flow that these outputs were added to.",
        "AddFlowSourcesResponse$FlowArn": "The ARN of the flow that these sources were added to.",
        "AddFlowVpcInterfacesResponse$FlowArn": "The ARN of the flow that these VPC interfaces were added to.",
        "AddOutputRequest$Description": "A description of the output. This description appears only on the AWS Elemental MediaConnect console and will not be seen by the end user.",
        "AddOutputRequest$Destination": "The IP address from which video will be sent to output destinations.",
        "AddOutputRequest$Name": "The name of the output. This value must be unique within the current flow.",
        "AddOutputRequest$RemoteId": "The remote ID for the Zixi-pull output stream.",
        "AddOutputRequest$StreamId": "The stream ID that you want to use for this transport. This parameter applies only to Zixi-based streams.",
        "CreateFlowRequest$AvailabilityZone": "The Availability Zone that you want to create the flow in. These options are limited to the Availability Zones within the current AWS Region.",
        "CreateFlowRequest$Name": "The name of the flow.",
        "DeleteFlowResponse$FlowArn": "The ARN of the flow that was deleted.",
        "Encryption$ConstantInitializationVector": "A 128-bit, 16-byte hex value represented by a 32-character string, to be used with the key for encrypting content. This parameter is not valid for static key encryption.",
        "Encryption$DeviceId": "The value of one of the devices that you configured with your digital rights management (DRM) platform key provider. This parameter is required for SPEKE encryption and is not valid for static key encryption.",
        "Encryption$Region": "The AWS Region that the API Gateway proxy endpoint was created in. This parameter is required for SPEKE encryption and is not valid for static key encryption.",
        "Encryption$ResourceId": "An identifier for the content. The service sends this value to the key server to identify the current endpoint. The resource ID is also known as the content ID. This parameter is required for SPEKE encryption and is not valid for static key encryption.",
        "Encryption$RoleArn": "The ARN of the role that you created during setup (when you set up AWS Elemental MediaConnect as a trusted entity).",
        "Encryption$SecretArn": "The ARN of the secret that you created in AWS Secrets Manager to store the encryption key. This parameter is required for static key encryption and is not valid for SPEKE encryption.",
        "Encryption$Url": "The URL from the API Gateway proxy that you set up to talk to your key server. This parameter is required for SPEKE encryption and is not valid for static key encryption.",
        "Entitlement$Description": "A description of the entitlement.",
        "Entitlement$EntitlementArn": "The ARN of the entitlement.",
        "Entitlement$Name": "The name of the entitlement.",
        "Flow$AvailabilityZone": "The Availability Zone that you want to create the flow in. These options are limited to the Availability Zones within the current AWS.",
        "Flow$Description": "A description of the flow. This value is not used or seen outside of the current AWS Elemental MediaConnect account.",
        "Flow$EgressIp": "The IP address from which video will be sent to output destinations.",
        "Flow$FlowArn": "The Amazon Resource Name (ARN), a unique identifier for any AWS resource, of the flow.",
        "Flow$Name": "The name of the flow.",
        "GrantEntitlementRequest$Description": "A description of the entitlement. This description appears only on the AWS Elemental MediaConnect console and will not be seen by the subscriber or end user.",
        "GrantEntitlementRequest$Name": "The name of the entitlement. This value must be unique within the current flow.",
        "GrantFlowEntitlementsResponse$FlowArn": "The ARN of the flow that these entitlements were granted to.",
        "ListEntitlementsResponse$NextToken": "The token that identifies which batch of results that you want to see. For example, you submit a ListEntitlements request with MaxResults set at 5. The service returns the first batch of results (up to 5) and a NextToken value. To see the next batch of results, you can submit the ListEntitlements request a second time and specify the NextToken value.",
        "ListFlowsResponse$NextToken": "The token that identifies which batch of results that you want to see. For example, you submit a ListFlows request with MaxResults set at 5. The service returns the first batch of results (up to 5) and a NextToken value. To see the next batch of results, you can submit the ListFlows request a second time and specify the NextToken value.",
        "ListedEntitlement$EntitlementArn": "The ARN of the entitlement.",
        "ListedEntitlement$EntitlementName": "The name of the entitlement.",
        "ListedFlow$AvailabilityZone": "The Availability Zone that the flow was created in.",
        "ListedFlow$Description": "A description of the flow.",
        "ListedFlow$FlowArn": "The ARN of the flow.",
        "ListedFlow$Name": "The name of the flow.",
        "Output$Description": "A description of the output.",
        "Output$Destination": "The address where you want to send the output.",
        "Output$EntitlementArn": "The ARN of the entitlement on the originator''s flow. This value is relevant only on entitled flows.",
        "Output$MediaLiveInputArn": "The input ARN of the AWS Elemental MediaLive channel. This parameter is relevant only for outputs that were added by creating a MediaLive input.",
        "Output$Name": "The name of the output. This value must be unique within the current flow.",
        "Output$OutputArn": "The ARN of the output.",
        "RemoveFlowOutputResponse$FlowArn": "The ARN of the flow that is associated with the output you removed.",
        "RemoveFlowOutputResponse$OutputArn": "The ARN of the output that was removed.",
        "RemoveFlowSourceResponse$FlowArn": "The ARN of the flow that is associated with the source you removed.",
        "RemoveFlowSourceResponse$SourceArn": "The ARN of the source that was removed.",
        "RemoveFlowVpcInterfaceResponse$FlowArn": "The ARN of the flow that is associated with the VPC interface you removed.",
        "RemoveFlowVpcInterfaceResponse$VpcInterfaceName": "The name of the VPC interface that was removed.",
        "ResponseError$Message": "The error message returned by AWS Elemental MediaConnect.",
        "RevokeFlowEntitlementResponse$EntitlementArn": "The ARN of the entitlement that was revoked.",
        "RevokeFlowEntitlementResponse$FlowArn": "The ARN of the flow that the entitlement was revoked from.",
        "SetSourceRequest$Description": "A description for the source. This value is not used or seen outside of the current AWS Elemental MediaConnect account.",
        "SetSourceRequest$EntitlementArn": "The ARN of the entitlement that allows you to subscribe to this flow. The entitlement is set by the flow originator, and the ARN is generated as part of the originator's flow.",
        "SetSourceRequest$Name": "The name of the source.",
        "SetSourceRequest$StreamId": "The stream ID that you want to use for this transport. This parameter applies only to Zixi-based streams.",
        "SetSourceRequest$VpcInterfaceName": "The name of the VPC interface to use for this source.",
        "SetSourceRequest$WhitelistCidr": "The range of IP addresses that should be allowed to contribute content to your source. These IP addresses should be in the form of a Classless Inter-Domain Routing (CIDR) block; for example, 10.0.0.0/16.",
        "Source$Description": "A description for the source. This value is not used or seen outside of the current AWS Elemental MediaConnect account.",
        "Source$EntitlementArn": "The ARN of the entitlement that allows you to subscribe to content that comes from another AWS account. The entitlement is set by the content originator and the ARN is generated as part of the originator's flow.",
        "Source$IngestIp": "The IP address that the flow will be listening on for incoming content.",
        "Source$Name": "The name of the source.",
        "Source$SourceArn": "The ARN of the source.",
        "Source$VpcInterfaceName": "The name of the VPC Interface this Source is configured with.",
        "Source$WhitelistCidr": "The range of IP addresses that should be allowed to contribute content to your source. These IP addresses should be in the form of a Classless Inter-Domain Routing (CIDR) block; for example, 10.0.0.0/16.",
        "StartFlowResponse$FlowArn": "The ARN of the flow that you started.",
        "StopFlowResponse$FlowArn": "The ARN of the flow that you stopped.",
        "Transport$RemoteId": "The remote ID for the Zixi-pull stream.",
        "Transport$StreamId": "The stream ID that you want to use for this transport. This parameter applies only to Zixi-based streams.",
        "UpdateEncryption$ConstantInitializationVector": "A 128-bit, 16-byte hex value represented by a 32-character string, to be used with the key for encrypting content. This parameter is not valid for static key encryption.",
        "UpdateEncryption$DeviceId": "The value of one of the devices that you configured with your digital rights management (DRM) platform key provider. This parameter is required for SPEKE encryption and is not valid for static key encryption.",
        "UpdateEncryption$Region": "The AWS Region that the API Gateway proxy endpoint was created in. This parameter is required for SPEKE encryption and is not valid for static key encryption.",
        "UpdateEncryption$ResourceId": "An identifier for the content. The service sends this value to the key server to identify the current endpoint. The resource ID is also known as the content ID. This parameter is required for SPEKE encryption and is not valid for static key encryption.",
        "UpdateEncryption$RoleArn": "The ARN of the role that you created during setup (when you set up AWS Elemental MediaConnect as a trusted entity).",
        "UpdateEncryption$SecretArn": "The ARN of the secret that you created in AWS Secrets Manager to store the encryption key. This parameter is required for static key encryption and is not valid for SPEKE encryption.",
        "UpdateEncryption$Url": "The URL from the API Gateway proxy that you set up to talk to your key server. This parameter is required for SPEKE encryption and is not valid for static key encryption.",
        "UpdateFlowEntitlementRequest$Description": "A description of the entitlement. This description appears only on the AWS Elemental MediaConnect console and will not be seen by the subscriber or end user.",
        "UpdateFlowEntitlementResponse$FlowArn": "The ARN of the flow that this entitlement was granted on.",
        "UpdateFlowOutputRequest$Description": "A description of the output. This description appears only on the AWS Elemental MediaConnect console and will not be seen by the end user.",
        "UpdateFlowOutputRequest$Destination": "The IP address where you want to send the output.",
        "UpdateFlowOutputRequest$RemoteId": "The remote ID for the Zixi-pull stream.",
        "UpdateFlowOutputRequest$StreamId": "The stream ID that you want to use for this transport. This parameter applies only to Zixi-based streams.",
        "UpdateFlowOutputResponse$FlowArn": "The ARN of the flow that is associated with the updated output.",
        "UpdateFlowSourceRequest$Description": "A description for the source. This value is not used or seen outside of the current AWS Elemental MediaConnect account.",
        "UpdateFlowSourceRequest$EntitlementArn": "The ARN of the entitlement that allows you to subscribe to this flow. The entitlement is set by the flow originator, and the ARN is generated as part of the originator's flow.",
        "UpdateFlowSourceRequest$StreamId": "The stream ID that you want to use for this transport. This parameter applies only to Zixi-based streams.",
        "UpdateFlowSourceRequest$VpcInterfaceName": "The name of the VPC Interface to configure this Source with.",
        "UpdateFlowSourceRequest$WhitelistCidr": "The range of IP addresses that should be allowed to contribute content to your source. These IP addresses should be in the form of a Classless Inter-Domain Routing (CIDR) block; for example, 10.0.0.0/16.",
        "UpdateFlowSourceResponse$FlowArn": "The ARN of the flow that you want to update.",
        "VpcInterface$Name": "Immutable and has to be a unique against other VpcInterfaces in this Flow",
        "VpcInterface$RoleArn": "Role Arn MediaConnect can assumes to create ENIs in customer's account",
        "VpcInterface$SubnetId": "Subnet must be in the AZ of the Flow",
        "VpcInterfaceAttachment$VpcInterfaceName": "The name of the VPC interface to use for this output.",
        "VpcInterfaceRequest$Name": "The name of the VPC Interface. This value must be unique within the current flow.",
        "VpcInterfaceRequest$RoleArn": "Role Arn MediaConnect can assumes to create ENIs in customer's account",
        "VpcInterfaceRequest$SubnetId": "Subnet must be in the AZ of the Flow",
        "__listOf__string$member": null,
        "__mapOf__string$member": null
      }
    }
  }
}