Edgio

Blackout

Blackout allows specific live linear programming to be blacked out to predefined sets of viewers (aka audiences). Instead of standard programming, blacked out viewers will view slate, a different live channel, on-demand content, or content sourced from a different Live Slicer. Use this capability to prevent the infringement of broadcasting rights.
The following sample scenarios illustrate common use cases:
  1. Scenario #1:
    A national broadcaster’s live channel contains a live sporting event. However, a local broadcaster has superior rights to this event.
    Solution: Blackout may be used to limit the distribution of this sporting event to the local broadcaster.
  2. Scenario #2:
    A movie or TV show that has not been licensed for distribution over the Internet has been scheduled in a live channel.
    Solution: Blackout may be used to prevent the distribution of this restricted content over the Internet.

How Does It Work?

Apply blackout to programs as needed. Blacked out viewers will stream alternate content.
Card

Blackout Notification

At the start of a program that requires blackout, an ID (i.e., blackout_id) must be sent to the Live Slicer. This ID should identify a rule that has been associated with the live channel. This rule identifies an audience (i.e., a grouping of viewers) and whether the regularly scheduled program or alternate content will be streamed to those viewers.

Streaming Request

A viewer requests a live channel’s programming through a custom media player. The response sent to the media player is a URL that varies according to whether blackout is applicable. Blackout will be applied when all of the following conditions are true:
  1. Blackout ID: A blackout ID has been defined for the requested programming.
  2. Live Channel: The live channel has been configured to apply one or more blackout rules for the blackout ID associated with the requested programming.
  3. Viewer: The viewer satisfies the criteria defined within the audience for the aforementioned blackout rule(s). This criteria consists of location information (i.e., zip code, DMA, or country), IP address, and/or device.
If all of the above conditions are true, then the first applicable blackout rule determines the alternate content that will be streamed to the viewer. Otherwise, the regularly scheduled program will be streamed to the viewer.
Blackout is applied on a per program basis. If a blackout ID is not provided with the channel’s next scheduled program, then all viewers will be allowed to play it back. Otherwise, the above workflow determines the type of content that each viewer will stream.
The above workflow is illustrated here.
Blackout Workflow

Setup

Setting up blackout requires:
  1. Defining one or more audiences.
  2. Defining one or more blackout rules.
  3. Setting up blackout on the desired live channel.
  4. Setting up a media player.
  5. Sending a blackout notification to the Live Slicer.

Audiences

An audience identifies viewers that will be blacked out via one or more of the following criteria:
  • IP address: Specify an IP address (IPv4) or subnet (CIDR notation).
  • Zip code: Specify a 5-digit United States zip code.
  • Designated market area (DMA): Specify a United States DMA by its ID. Request Nielsen DMA data.
  • Device: Specify a name or description for the desired device. Values defined within the Devices option will be compared against the value defined for the repl.cbdevice playback URL parameter.
  • Country: Specify a two-character country code (ISO 3166). Country codes are automatically capitalized. View a list of country codes.
Country codes are automatically capitalized.
View a list of country codes.
A viewer’s location (i.e., zip code, DMA, and country) is either automatically determined by IP address or manually defined in the playback request.
Learn more.
Factors, such as proxy services, VPNs, and the nature of geolocation technology, may result in an inaccurate assessment of a viewer’s zip code or DMA when calculating location information by IP address. In turn, this may incorrectly allow viewers access to content that should have been blacked out. Therefore, it is strongly recommended to utilize a device’s location services to identify a viewer’s location and then submit this information when a media player requests a stream.
Learn more.

Match Option

The Match option determines whether a viewer must meet any, all, or none of the specified criteria in order to qualify as a member of the current audience.
  • Any: This match condition requires that a viewer satisfy at least one entry within one or more categories.
    Example:
    If an audience has been configured to match on zip codes, country codes, and DMAs, a viewer will qualify for membership when the request originates within one of the specified zip codes, country codes, or DMAs.
  • All: This match condition requires that a viewer satisfy at least one entry within each category that has been defined.
    Example:
    If an audience has been configured to match on zip codes, country codes, and DMAs, then a viewer will only qualify for membership when the request originates within one of the specified zip codes, country codes, and DMAs. If the request does not satisfy all of the defined categories, then it will not qualify for membership.
  • None: This match condition requires that a viewer not satisfy any entries within the categories that have been defined.
    Example:
    If an audience has been configured to match on zip codes, country codes, and DMAs, then a viewer will only qualify for membership when the request does not originate within any of the specified zip codes, country codes, and DMAs. If the request satisfies any of the defined categories, then it will not qualify for membership.

Set Up a Basic Audience

  1. Navigate to the Audiences page (Live Channels > Audiences).
  2. Click + Create Audience.
  3. In the Audience Name option, type the name by which this audience will be identified.
  4. Under the Type option, verify that the Single mode has been selected.
    The Multiple mode allows you to create a group of audiences.
    Learn more.
  5. Click Create & Edit.
  6. In the Match option, select whether a viewer will qualify for membership when the request matches any, all, or none of the specified criteria.
    Learn more.
  7. Add the desired IP addresses, zip codes, designated market areas (DMAs), devices, and/or country codes.
    • Click + under the desired category.
    • Type one or more entries. Multiple entries should be separated by a comma (e.g., 90405,90503,90210).
    • Click Add.
    • Repeat these steps for each desired category.
  8. Click Save to update the audience configuration with these changes.

Grouping Audiences

Multiple audiences may be grouped together, allowing you to apply a blackout rule to multiple audiences.
Sample Scenario
You have created an audience for each major metropolitan area in a state. However, you would like to apply a blackout to the entire state. You can accomplish this by creating a superaudience that groups together metropolitan-specific audiences for that state.
To Set Up a Superaudience
  1. Navigate to the Audiences page (Live Channels > Audiences).
  2. Click + Create Audience.
  3. In the Audience Name option, type the name by which this audience will be identified.
  4. Under the Type option, verify that the Multiple mode has been selected.
  5. Click Create & Edit.
  6. In the Match option, select whether a viewer will qualify for membership when the request matches any, all, or none of the specified audiences.
    Learn more.
  7. Add each desired audience by selecting it from the Available Audiences list and then clicking >.
  8. Click Save to update the audience configuration with these changes.

Blackout Rules

A blackout rule defines when and how a blackout will be applied to blacked-out content. Specifically, it:
  • Identifies viewers via an audience or superaudience.
  • Determines the alternate content that will be streamed to blacked-out viewers. This alternate content may consist of:
    • Slate: Conditional blackout slate will be streamed.
    • Channel: Content sourced from an alternate live channel.
    • Asset: On-demand content from the CMS library.
    • Slicer: Media processed by an alternate Live Slicer.

Create a Blackout Rule

  1. Navigate to the Audiences page (Live Channels > Audiences).
  2. Click + Create Rule.
  3. In the Rule Name option, type the name by which this blackout rule will be identified.
  4. Click Create & Edit.
  5. From the Alternate Content Type option, choose the type of source for the alternate content that will be streamed to blacked-out viewers:
    • Slate: Indicates that conditional blackout slate will be streamed.
    • Channel: Indicates that content sourced from an alternate live channel will be streamed. Set the Alternate Content ID option to the desired channel ID or external ID.
      To find a live channel ID:
      1. From the CMS, click the Live Channels tab.
      2. Select the desired live channel. Basic options and live channel information will be displayed on the Details tab.
      3. Find the live channel’s system-defined ID under the GUID label.
    • Asset: Indicates that on-demand content from the CMS library will be streamed. Set the Alternate Content ID option to the asset ID or external ID for the desired CMS asset.
      To find an asset ID:
      1. Navigate to the CMS library by clicking the Content tab.
      2. Select the desired asset
      3. The asset ID corresponding to the asset selected in the previous step is listed under the GUID label.
    • Slicer: Indicates that media processed by an alternate Live Slicer will be streamed. Set the Alternate Content ID option to the ID for the desired Live Slicer.
      A Live Slicer’s ID is defined by the slicerID parameter within its configuration file.
  6. Use the Loop option to determine whether alternate content will be looped.
    This option must remain enabled when broadcasting slate.
    Disabling this option will broadcast slate when alternate content is shorter than the scheduled program.
  7. Optional: From the External ID option, type the external ID by which this blackout rule will be identified.
  8. Click + Add Audience to display the Select Audience dialog box.
  9. From the Available Audiences list, select the desired audience or superaudience and then click Select.
  10. Click Save to apply your changes to the blackout rule.

Live Channel

Set up a blackout configuration on a live channel by:
  1. Identifying when blackout should be triggered via a blackout ID.
  2. Associating blackout logic with the above blackout ID by adding blackout rules to it.

Configure Blackout on a Live Channel

  1. Navigate to the Audiences page (Live Channels > Audiences).
  2. Perform either of the following:
    • Create a live channel by clicking + Create Channel, assigning it a name, and then clicking Create & Edit.
    • Select an existing live channel.
  3. Click the Blackout tab.
  4. Associate a blackout ID and blackout rules with the live channel.
    • Click + Add Blackout ID.
    • In the Blackout ID option, type the blackout ID that identifies programming that should be blacked out. Learn how to tag programming with a blackout ID.
    • In the Description option, type a brief description for this blackout configuration.
    • In the Rules option, select a blackout rule that identifies the audience and the alternate content that should be streamed when programming has been tagged with the above blackout ID. Click >.
    • Repeat the previous step as needed.
    • Click Done when you have added all of the desired blackout rules.
    • Repeat the previous step for each desired blackout ID.
  5. Click Save to update the live channel configuration with these changes.

Set up a Media Player

Standard programming will be broadcast to all users unless blackout is invoked in the playback URL.
Set up a media player to leverage blackouts as needed by including the following query string parameter in the playback URL: repl=aboi
Use a test player URL to quickly test your blackout configuration.
Sample Playback URL:
https://content.uplynk.com/player5/6ZpnSRiEmjj3fMdnzDaV00sc.html?repl=aboi

Set a Viewer’s Location or Device

By default, a viewer’s location is determined by IP address. However, a viewer’s device provides more accurate location information. Therefore, it is strongly recommended to override automatic location detection by including location information derived from the playback device. This information may then be set on the playback session by assigning it a DMA, zip code, and/or an IP address. Any applicable blackout zones will be assigned to the playback session based on this information.
Set a viewer’s location or device by passing one or more of the following query string parameters to the playback URL:
TypeParameterDescription
Country Coderepl.cbcc={Country Code}Overrides automatic location detection and assigns the country code to the viewer’s playback session.
Replace Country Code with the desired country code as defined here.
Devicerepl.cbdevice={Device Name}Defines the name or description of the device used for the viewer’s playback session.
Replace {Device Name} with the name or a brief description of the desired device. This value will be compared against the devices defined within applicable audience configurations.
DMArepl.cbdma={DMA ID}Overrides automatic location detection and assigns a DMA to the viewer’s playback session.
Replace {DMA ID} with the ID of the desired DMA.
Request Nielsen DMA data.
IP Addressrepl.cbip={IP Address}Overrides automatic location detection and assigns an IP address to the viewer’s playback session.
Replace {IP Address} with the desired IP address (IPv4) or subnet (CIDR notation).
Zip Coderepl.cbzip={Zip Code}Overrides automatic location detection and assigns a zip code to the viewer’s playback session.
Replace {Zip Code} with the desired 5 digit United States zip code.
Sample playback URL:
https://content.uplynk.com/player5/6ZpnSRiEmjj3fMdnzDaV00sc.html?repl=aboi&repl.cbdma=803&repl.cbzip=90405

Live Linear Programming

An alternative method for triggering blackout is via a SCTE-35 message. Please contact support for more information.
Blackout may be applied to a program or an asset within a live channel. The method for applying blackout varies according to whether it is being applied to a program or an asset. However, both methods require a blackout ID (i.e., blackout_id) to be associated with the program or asset. This ID identifies the logic through which blackout will be applied. Specifically, a live channel’s configuration associates a blackout ID with one or more blackout rules. Each of these blackout rules define the set of viewers that will be blacked out via an audience and the alternate content that will be streamed instead of the regularly scheduled program.
The first applicable blackout rule determines the alternate content that will be streamed.

Apply Blackout to a Program

Setting up blackout for use with a program requires assigning it a blackout ID. Set a blackout ID at the start of a program via the content_start method. This method accepts the meta request body parameter which allows metadata to be associated with the program being initiated. In this case, the blackout_id metadata field should be set to the desired blackout ID.
Example:
1POST /content_start HTTP/1.1
2
3{
4 "meta": {
5 "blackout_id": "br1"
6 },
7 "start_timecode": "00:15:21;09",
8 "title": "Title",
9 "external_id": "1A"
10 }

Apply Blackout to an Asset

Blackout is only enforced on live channels. Therefore, blackout will only be applied to on-demand content when a viewer streams it via a live channel.
Blackout may only be applied to assets that have been assigned a blackout ID (i.e., blackout_id). No further configuration is required once this ID has been defined.

Assign a Blackout ID to an Asset

  1. From the Content tab, select the desired asset.
  2. Click + Metadata.
  3. In the Enter a key name option, type "blackout_id".
  4. Click Add.
  5. Set the new blackout_id metadata field to the desired blackout ID.
  6. Click Save.

Tutorial

Learn how to set up Blackout and apply it to live linear channel programming.
Prerequisites:
  • Live Slicer
  • Live linear channel (CMS)
Key Steps:
  1. Create an audience.
  2. Create a blackout rule.
  3. Prepare a live channel for blackout.
  4. Set up a media player.
  5. Apply Blackout to programming.

Introduction

Blackout is designed to limit the distribution of restricted content, such as sporting events, movies, and other types of licensed content. Instead of the regularly scheduled program, content from an alternate source will be broadcast to blacked out viewers.
This functionality is handled on the server, eliminating the need for special client-side code or SDKs.
Blackout provides the means to:
  • Replace restricted content as needed.
  • Tailor the set of blacked out viewers to meet your business needs.
  • Easily define alternate programming for blacked out viewers.

Step 1: Create an Audience

A blackout zone defines a region by zip code, market (DMA), or IP address/subnet. This blackout zone may then be leveraged when defining how Blackout may be applied to a live linear channel.
  1. Sign in to the CMS.
  2. Navigate to the Audiences page (Live Channels > Audiences).
  3. Click + Create Audience.
  4. In the Audience Name option, type “Los Angeles.”
  5. Under the Type option, verify that the Single mode has been selected.
  6. Click Create & Edit.
  7. From the Match option, select Any.
  8. Add a DMA by clicking + under the DMAs section.
  9. Type “803.” This ID corresponds to the Los Angeles market.
  10. Click Add to add the Los Angeles market to the audience.
  11. Click Save to update the audience configuration with these changes.

Step 2: Define a Blackout Rule

Defining a blackout rule does not automatically apply Blackout to a live linear channel. Blackout must be enabled on a per program or asset basis.
A blackout rule identifies viewers that should be blacked out and the alternate content that will be streamed to them.
  1. Navigate to the Rules page (Live Channels > Rules).
  2. Click + Create Rule.
  3. In the Rule Name option, type Blackout LA Rule.
  4. Click Create & Edit.
  5. From the Alternate Content Type option, select “slate.”
  6. Click + Add Audience to display the Select Audience dialog box.
  7. From the Available Audiences list, select “Los Angeles” and then click Select.
  8. Click Save to apply your changes to the blackout rule.

Step 3: Prepare a Live Channel for Blackout

Setting up Blackout on a live channel requires defining when and how blackout is applied by assigning it a blackout ID and rule.
  1. Navigate to the Live Channels page.
  2. Select the desired live channel.
  3. Click the Blackout tab.
  4. Click + Add Blackout ID.
  5. In the Blackout ID option, type LA-Sports.
  6. In the Description option, type Los Angeles Sports.
  7. From the Rules option, select Blackout LA Rule and then click >.
  8. Click Done.
  9. Click Save to apply your changes to the live channel.

Step 4: Set up a Media Player

The enforcement of Blackout is only possible when a media player loads the Blackout replacement plugin. Load this plugin by adding “repl=aboi” as a query string to the playback URL.
Example:
The following sample URL corresponds to a test player:
https://content.uplynk.com/player5/6ZpnSRiEmjj3fMdnzDaV00sc.html?repl=aboi
Test players are solely meant to provide an easy way to demo content or test playback. They should not be used for production traffic.
Modify the playback URL defined within your media player to include the following query string parameter: repl=aboi

Step 5: Apply Blackout to Programming

Blackout may only be applied to live linear channel programming that has been assigned a blackout rule ID. One method for assigning a blackout rule ID is to set the blackout_id metadata field to the desired blackout ID. This tutorial leverages the content_start method to start a new program in the live linear channel and apply this metadata field to it.
  1. Submit the following curl request to assign the “LA-Sports” blackout rule to a new program called “Los Angeles Home Game”:
    1curl --data '{"meta":{"blackout_id":"LA-Sports"},"title":"Los Angeles Home Game"}'
    2 http://localhost:65009/content_start
  2. Verify that the Live Slicer is now generating a new asset by performing the following steps:
    • From the Content tab, verify that the asset currently being generated is called “Los Angeles Home Game” and then select it.
    • Verify that this asset contains a blackout_id metadata field set to LA-Sports.
  3. Verify that Blackout is currently being applied to the live linear channel.
    • DMA Override: If you are not testing from Los Angeles, override the test player’s DMA to the Los Angeles market by appending the following query string parameter to the playback URL launched in the Step 4: Setting up a Media Player section: repl.cbdma=803
      • Sample playback URL:
        https://content.uplynk.com/player5/6ZpnSRiEmjj3fMdnzDaV00sc.html?repl=aboi&repl.cbdma=803
    • Wait 30 to 60 seconds and then verify that the media player now streams slate.
Finished!
You have successfully applied Blackout to specific programming within a live linear channel. This configuration will force viewers in Los Angeles to view slate during each time slot for which the asset defined in step 5 has been scheduled in that live linear channel.