Re: [Hls-interest] HLS Content Steering v1.0b1 preliminary specification

Roger Pantos <rpantos@apple.com> Tue, 02 March 2021 20:09 UTC

Return-Path: <rpantos@apple.com>
X-Original-To: hls-interest@ietfa.amsl.com
Delivered-To: hls-interest@ietfa.amsl.com
Received: from localhost (localhost [127.0.0.1]) by ietfa.amsl.com (Postfix) with ESMTP id E67AE3A0EEE; Tue, 2 Mar 2021 12:09:53 -0800 (PST)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -2.336
X-Spam-Level:
X-Spam-Status: No, score=-2.336 tagged_above=-999 required=5 tests=[BAYES_00=-1.9, DKIMWL_WL_HIGH=-0.248, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, DKIM_VALID_EF=-0.1, HTML_MESSAGE=0.001, SPF_HELO_NONE=0.001, SPF_PASS=-0.001, T_REMOTE_IMAGE=0.01, URIBL_BLOCKED=0.001] autolearn=ham autolearn_force=no
Authentication-Results: ietfa.amsl.com (amavisd-new); dkim=pass (2048-bit key) header.d=apple.com
Received: from mail.ietf.org ([4.31.198.44]) by localhost (ietfa.amsl.com [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id 6kx8mXaYp452; Tue, 2 Mar 2021 12:09:50 -0800 (PST)
Received: from rn-mailsvcp-ppex-lapp44.apple.com (rn-mailsvcp-ppex-lapp44.rno.apple.com [17.179.253.48]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ietfa.amsl.com (Postfix) with ESMTPS id 22E6F3A0EEA; Tue, 2 Mar 2021 12:09:50 -0800 (PST)
Received: from pps.filterd (rn-mailsvcp-ppex-lapp44.rno.apple.com [127.0.0.1]) by rn-mailsvcp-ppex-lapp44.rno.apple.com (8.16.0.43/8.16.0.43) with SMTP id 122K7w3I025333; Tue, 2 Mar 2021 12:09:49 -0800
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=apple.com; h=from : message-id : content-type : mime-version : subject : date : in-reply-to : cc : to : references; s=20180706; bh=NREkY0qxv+cA56lRlg4HJZE5m9olZLjj5I/T8Bjp+Ik=; b=piXHGrZAydL2NoU0/7Np+dC5MPRa0Qx1sS+azlUXizdT45Yv2wQ219JLTj7fJ4tPPvo7 Oep7MU5CLnWvvHG5o9irZ5IzpSXnN0U6zlfoYamC54am12lhFpLuHY25g1QXG3aQrybv 2RqrQQm9mY6kxql7WRcg8idYW5FZg3dDD2f5TJj2frTN6cBkOz8HDkiMY+po6hqQh6Kp anBs7t8pkhYY9inqhCXQW9XQbwOZ1aPJqX5vc1+aj9XiWcqF2KnZb8ZIBeHZZqzMqzg5 534r3KSK4yxw7/7beuIGKfhE1jiiumZqNuwqee4LVG2Ik43v1E2GGP/BJ6xVTCz8Uq2W Hw==
Received: from rn-mailsvcp-mta-lapp03.rno.apple.com (rn-mailsvcp-mta-lapp03.rno.apple.com [10.225.203.151]) by rn-mailsvcp-ppex-lapp44.rno.apple.com with ESMTP id 36yjfbrbdw-2 (version=TLSv1.2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128 verify=NO); Tue, 02 Mar 2021 12:09:49 -0800
Received: from rn-mailsvcp-mmp-lapp04.rno.apple.com (rn-mailsvcp-mmp-lapp04.rno.apple.com [17.179.253.17]) by rn-mailsvcp-mta-lapp03.rno.apple.com (Oracle Communications Messaging Server 8.1.0.7.20201203 64bit (built Dec 3 2020)) with ESMTPS id <0QPC00345YOD5A60@rn-mailsvcp-mta-lapp03.rno.apple.com>; Tue, 02 Mar 2021 12:09:49 -0800 (PST)
Received: from process_milters-daemon.rn-mailsvcp-mmp-lapp04.rno.apple.com by rn-mailsvcp-mmp-lapp04.rno.apple.com (Oracle Communications Messaging Server 8.1.0.7.20201203 64bit (built Dec 3 2020)) id <0QPC00500YBYZW00@rn-mailsvcp-mmp-lapp04.rno.apple.com>; Tue, 02 Mar 2021 12:09:49 -0800 (PST)
X-Va-A:
X-Va-T-CD: 81ca60fce39c2560b6c4a7e5841f9b8f
X-Va-E-CD: 4335616a6ac305163c7e0e056e870746
X-Va-R-CD: 3fe25e5da9104b0db2fa21b8031c261a
X-Va-CD: 0
X-Va-ID: 03f82e51-f733-48b3-882c-ab666a58b66c
X-V-A:
X-V-T-CD: 81ca60fce39c2560b6c4a7e5841f9b8f
X-V-E-CD: 4335616a6ac305163c7e0e056e870746
X-V-R-CD: 3fe25e5da9104b0db2fa21b8031c261a
X-V-CD: 0
X-V-ID: 7b033e16-74f0-41ad-9a01-97ff4516faef
X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10434:6.0.369, 18.0.761 definitions=2021-03-02_08:2021-03-01, 2021-03-02 signatures=0
Received: from smtpclient.apple (unknown [17.150.219.127]) by rn-mailsvcp-mmp-lapp04.rno.apple.com (Oracle Communications Messaging Server 8.1.0.7.20201203 64bit (built Dec 3 2020)) with ESMTPSA id <0QPC00VKSYOCP600@rn-mailsvcp-mmp-lapp04.rno.apple.com>; Tue, 02 Mar 2021 12:09:49 -0800 (PST)
From: Roger Pantos <rpantos@apple.com>
Message-id: <543EF7B9-7BE1-4592-8AE2-4CF825B0DF22@apple.com>
Content-type: multipart/alternative; boundary="Apple-Mail=_1C19BFF7-7971-4F07-8657-7285F1E32C27"
MIME-version: 1.0 (Mac OS X Mail 14.0 \(3654.80.0.2.43\))
Date: Tue, 02 Mar 2021 12:09:48 -0800
In-reply-to: <76CAB652-C64F-4AF1-86E1-FC7457DD48E9@akamai.com>
Cc: http-live-streaming-review <http-live-streaming-review@group.apple.com>, "hls-interest@ietf.org" <hls-interest@ietf.org>
To: "Law, Will" <wilaw=40akamai.com@dmarc.ietf.org>
References: <1F29DDD8-27B8-45B9-918F-6A45E906F4F4@apple.com> <CAAqSTpn7F3LsQCYf5CYLSfh-e-ig3HjVoYP6exxSqGTodYHqdw@mail.gmail.com> <4F54439A-A5AD-4687-9097-AF07FA1FB19D@apple.com> <C24E53B3-AB50-485F-A0F7-D4512742D2B5@apple.com> <3DA545F7-EC5B-4DFE-B8AC-A753B20DAD46@akamai.com> <47FD1F28-BB2C-4B42-863B-025272E2BDDA@apple.com> <76CAB652-C64F-4AF1-86E1-FC7457DD48E9@akamai.com>
X-Mailer: Apple Mail (2.3654.80.0.2.43)
X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10434:6.0.369, 18.0.761 definitions=2021-03-02_08:2021-03-01, 2021-03-02 signatures=0
Archived-At: <https://mailarchive.ietf.org/arch/msg/hls-interest/K-dtdfGGhogzB_RkNv7YtLgBUsA>
Subject: Re: [Hls-interest] HLS Content Steering v1.0b1 preliminary specification
X-BeenThere: hls-interest@ietf.org
X-Mailman-Version: 2.1.29
Precedence: list
List-Id: "Discussions about HTTP Live Streaming \(HLS\)." <hls-interest.ietf.org>
List-Unsubscribe: <https://www.ietf.org/mailman/options/hls-interest>, <mailto:hls-interest-request@ietf.org?subject=unsubscribe>
List-Archive: <https://mailarchive.ietf.org/arch/browse/hls-interest/>
List-Post: <mailto:hls-interest@ietf.org>
List-Help: <mailto:hls-interest-request@ietf.org?subject=help>
List-Subscribe: <https://www.ietf.org/mailman/listinfo/hls-interest>, <mailto:hls-interest-request@ietf.org?subject=subscribe>
X-List-Received-Date: Tue, 02 Mar 2021 20:09:54 -0000

I don’t think it needs to be a very common case at all.

First, some number of providers will simply use static steering manifests —basically using content steering as a better-defined version of the duplicate STREAM-INF tags we have now. In those cases, whether the master playlist contains relative or absolute URLs, it’s pretty simple to put a version of the static manifest on each pathway (with that pathway as #1) and have the master playlist from that pathway point to it.

The next step is standing up an active steering server that can dynamically change the steering to respond to network impairment or load or time of day or whatever. In those cases what’s in the master playlist must agree with the current view of the steering server for that client. Most providers that serve static master playlists through multiple CDNs already have some version of this: when they provide the master playlist URL to the client they dynamically pick the one that’s on the CDN they like at the moment. What’s left is to make sure that the steering server response agrees with that choice (at least initially); there are various techniques available to do that. Dynamic master playlist generators should be fairly straightforward to keep in sync. 

Even in cases where, as you say, a static master playlist against a particular CDN is cached on a different CDN / server, there is generally one master playlist per CDN per asset. At playback time the client conspires with the backend to choose which master playlist to use, based on current conditions. The only new requirement here is that the master playlist that is chosen agree with the steering server’s current view of the world.

If the master playlist contains the wrong initial choice (one that triggers an immediate pathway switch) then it will switch over as soon as the steering manifest comes back. Clients in general are already well-versed at canceling pending requests against the previous variant stream when they switch. As for discarding content received from the default pathway, I don’t see a reason to do that. If the default pathway manages to cough up enough data to use before the steering server tells it to switch, why not use it? 

I do agree that it’s worth emphasizing the importance of having the master playlist agree with the first manifest response in the spec.

Regarding the suggestion to require serialization, I think I’d like to hear from a few people who actually want that behavior before considering it. Every option we add increases client complexity and chips away at interoperability.


Roger.

> On Mar 1, 2021, at 12:53 PM, Law, Will <wilaw=40akamai.com@dmarc.ietf.org> wrote:
> 
> “In the case where it does not, the steering response will race with the media playlist / segment requests and cause an immediate pathway reselection. There’s a bit of inefficiency there due to the extra round trip and canceled requests, so I would encourage providers to take care to avoid hitting that case.”
> But that use case is likely to be a very common use case. A distributor prepares a master playlist in January, populates it with a default CDN, caches it with a long TTL across many CDNs and then uses steering manifests for the remainder of the year to ensure that their users receive good quality. Relatively few Content Distributors prepare per-user dynamic playlists – it’s mostly static playlists or dynamic playlists from SSAI vendors. The SSAI vendors are not currently set up to integrate steering. The elegance of the current design is that it decouples steering from playlist/ SSAI manifest generation which is practical and flexible. It just needs some careful definition to avoid undesirable player behavior.
>  
> My concern is that many players will not cancel requests for media playlists/segments that are underway (aside from the inefficiency for those that do). They will then end up loading the media playlist and the first segment from a poorly performing CDN (one that could be down completely) before switching on the second and subsequent requests to the steered source.  This will result in poor start-up performance, two cold hits against CDNs, lack of prefetch and likely an increase in start-up-induced rebuffering. 
>  
> Suggestion #1
> To resolve this , an option would be to add language to the Player Behavior section indicating that after the player loads the steering manifest in parallel with the default media playlists, if the steering manifest indicates the different pathway to what has already been loaded, then the player MUST cancel any requests underway and if those requests have already completed, MUST NOT render any content to the user obtained from the default pathway. Another version of this would allow the player to load the default media playlists but not proceed with any segment/init loading until the pathway choice had been validated by the steering manifest.  This would not result in much VST decline at all since the load time of the steering manifests is likely to be close to that of the media playlists and they would both be retrieved in parallel.
>  
> Suggestion #2
> There are many providers (for example long VOD content providers as well as live stream providers) who want the discretion of being able to trade-off the VST increase of a forced steering load with the QoE quality benefits that might result from that . A 200ms increase in VST may be worth having the player make a steering requests from a highly performing regional CDN. They also want the certainty of this  player behavior across the ecosystem. To accommodate this , a new attribute could be added to the #EXT-X-CONTENT-STEERING  description, perhaps something like:
>  
> #EXT-X-CONTENT-STEERING:SERVER-URI="https://example.com/steering?video=00001 <https://urldefense.com/v3/__https:/example.com/steering?video=00001&session=123__;!!GjvTz_vk!E3AorzSNM8BjAiM9Qaz2_XmVx2NyOl_J1ZzrkyQCOBZuw0Khr__44qtYzaA4$>",PATHWAY-ID="My-Great-CDN",FORCE
>  
> to indicate that the player must resolve the steering manifest before loading any other content? If it’s absent, then players should be constrained by the requirements suggested in #1.
>  
> Cheers
> Will
>  
>  
>  
> From: Roger Pantos <rpantos=40apple.com@dmarc.ietf.org>
> Date: Monday, March 1, 2021 at 10:00 AM
> To: "Law, Will" <wilaw@akamai.com>
> Cc: http-live-streaming-review <http-live-streaming-review@group.apple.com>, "hls-interest@ietf.org" <hls-interest@ietf.org>
> Subject: Re: [Hls-interest] HLS Content Steering v1.0b1 preliminary specification
>  
> Hello Will, response inline:
> 
> 
>> On Feb 26, 2021, at 3:38 PM, Law, Will <wilaw=40akamai.com@dmarc.ietf.org <mailto:wilaw=40akamai.com@dmarc.ietf.org>> wrote:
>>  
>> Another question on this new proposal: can the spec clarify whether the client is required to request the steering manifest and resolve the pathways beforeit loads any media playlists? Given the playlist below
>>  
>> #EXTM3U
>> #EXT-X-CONTENT-STEERING:SERVER-URI="https://example.com/steering?video=00001 <https://urldefense.com/v3/__https:/example.com/steering?video=00001&session=123__;!!GjvTz_vk!E3AorzSNM8BjAiM9Qaz2_XmVx2NyOl_J1ZzrkyQCOBZuw0Khr__44qtYzaA4$>",PATHWAY-ID="My-Great-CDN"
>> #EXT-X-STEERING-TEMPLATE:ID="1",PREFIX="https://a.example.com/video <https://urldefense.com/v3/__https:/a.example.com/video__;!!GjvTz_vk!E3AorzSNM8BjAiM9Qaz2_XmVx2NyOl_J1ZzrkyQCOBZuw0Khr__44mqwdeF4$>"
>> #EXT-X-STREAM-INF:BANDWIDTH=200000,STEERING="1"
>> https://a.example.com/video/my-movie/mid/index.m3u8 <https://urldefense.com/v3/__https:/a.example.com/video/my-movie/mid/index.m3u8__;!!GjvTz_vk!E3AorzSNM8BjAiM9Qaz2_XmVx2NyOl_J1ZzrkyQCOBZuw0Khr__44hforWWE$>
>> #EXT-X-STREAM-INF:BANDWIDTH=400000,STEERING="1"
>> https://a.example.com/video/my-movie/high/index.m3u8 <https://urldefense.com/v3/__https:/a.example.com/video/my-movie/high/index.m3u8__;!!GjvTz_vk!E3AorzSNM8BjAiM9Qaz2_XmVx2NyOl_J1ZzrkyQCOBZuw0Khr__44mfpy4iP$>
>>  
>> a client could start by immediately loading https://a.example.com/video/my-movie/mid/index.m3u8 <https://urldefense.com/v3/__https:/a.example.com/video/my-movie/mid/index.m3u8__;!!GjvTz_vk!E6fhAAQPxWo-bK7LlqHUAnZeDNBMn6k4o5KNy7XbzzP0fc3IYkli5nNSh8WI$>, and then resolving the steering manifest in the background after it had built up a few seconds of playback buffer. Players would be tempted to do this as it would provide a lower VST (by one RTT and whatever processing time there is on the steering server). This would be a bad outcome for two reasons a) For QoE as there could potentially be two cold hits against CDNs in the first 10s of playback   - one for the default and the second as the new pathway kicks in and b) if you are trying to move away from an underperforming default pathway your startup sequence would continue to be pinned against it.
>>  
>> The current version of the steering draft is ambiguous. It says “When the player needs to poll for Pathway updates,", but does not dictate when this should happen with respect to conventional start-up.
>>  
>> Suggestion is that if the player understands steering, it MUST resolve the steering manifest prior to loading any media playlist.
>  
> We tried to make this clear in the Player Behavior section:
>  
> 1. When playing a Master Playlist with an EXT-X-CONTENT-STEERING tag, load the Steering Manifest in parallel with the media playlist and segments requests, composed using the default values of the EXT-X-DEFINE tags.
>  
> In other words what we expect is that the player will begin loading the media using the steering path expressed directly in the master playlist. As Daniel mentioned in his reply, to do otherwise would insert an extra round trip into the startup phase of playback.
>  
> We expect that the dominant case will be that whoever hands out the master playlist to the player — be it dynamically generated, or a static master playlist with relative media playlists selected on a particular CDN — will do so in agreement with its steering server, providing a master playlist that describes the currently-preferred pathway. In the case where it does not, the steering response will race with the media playlist / segment requests and cause an immediate pathway reselection. There’s a bit of inefficiency there due to the extra round trip and canceled requests, so I would encourage providers to take care to avoid hitting that case.
>  
> Note that having _HLS_pathway or some other indication of master playlist origin in the steering manifest request can assist the steering server in keeping the client on its current pathway.
>  
>  
> Roger.
> 
> 
>>  
>> -Will
>>  
>>  
>>  
>>  
>>  
>>  
>>  
>>  
>>  
>>  
>>  
>>  
>> From: Roger Pantos <rpantos=40apple.com@dmarc.ietf.org <mailto:rpantos=40apple.com@dmarc.ietf.org>>
>> Date: Friday, February 26, 2021 at 9:42 AM
>> To: "hls-interest@ietf.org <mailto:hls-interest@ietf.org>" <hls-interest@ietf.org <mailto:hls-interest@ietf.org>>
>> Cc: http-live-streaming-review <http-live-streaming-review@group.apple.com <mailto:http-live-streaming-review@group.apple.com>>
>> Subject: Re: [Hls-interest] HLS Content Steering v1.0b1 preliminary specification
>>  
>> One objection we’ve heard to the approach below is that it requires the master playlist to be customized on a per-pathway basis. To address that we’re tweaking the proposal slightly: we're making the PATHWAY-ID attribute optional. If it is not present in the master playlist, the client will omit the _HLS_pathway query parameter from the steering manifest request until it obtains its first steering manifest.
>>  
>> (There are other ways for providers to communicate the initial pathway to the steering server. For instance, the SERVER-URI could be relative to the master playlist; each pathway could HTTP-redirect it to the actual steering server along with an origin identifier.)
>>  
>> Here are two examples of the current approach. The first one uses absolute URLs in the master playlist, as you might have with a dynamically-generated master playlist that knows the current pathway when the playlist is produced. The second uses relative URLs, as you might have for a static master playlist that is the same on all pathways.
>>  
>> In both cases the content is available here:
>>  
>> On the first CDN at -
>>  
>> https://a.example.com/video/my-movie/master.m3u8 <https://urldefense.com/v3/__https:/a.example.com/video/my-movie/master.m3u8__;!!GjvTz_vk!E3AorzSNM8BjAiM9Qaz2_XmVx2NyOl_J1ZzrkyQCOBZuw0Khr__44qV1Gx_j$>
>>  
>> and on the second CDN at -
>>  
>> https://b.example.com/backup-video/my-movie/master.m3u8 <https://urldefense.com/v3/__https:/b.example.com/backup-video/my-movie/master.m3u8__;!!GjvTz_vk!E3AorzSNM8BjAiM9Qaz2_XmVx2NyOl_J1ZzrkyQCOBZuw0Khr__44llkyj51$>
>>  
>> -----
>>  
>> Absolute URIs (master playlist URI https://a.example.com/video/my-movie/master.m3u8 <https://urldefense.com/v3/__https:/a.example.com/video/my-movie/master.m3u8__;!!GjvTz_vk!E3AorzSNM8BjAiM9Qaz2_XmVx2NyOl_J1ZzrkyQCOBZuw0Khr__44qV1Gx_j$>)
>>  
>> #EXTM3U
>> #EXT-X-CONTENT-STEERING:SERVER-URI="https://example.com/steering?video=00001 <https://urldefense.com/v3/__https:/example.com/steering?video=00001&session=123__;!!GjvTz_vk!E3AorzSNM8BjAiM9Qaz2_XmVx2NyOl_J1ZzrkyQCOBZuw0Khr__44qtYzaA4$>",PATHWAY-ID="My-Great-CDN"
>> #EXT-X-STEERING-TEMPLATE:ID="1",PREFIX="https://a.example.com/video <https://urldefense.com/v3/__https:/a.example.com/video__;!!GjvTz_vk!E3AorzSNM8BjAiM9Qaz2_XmVx2NyOl_J1ZzrkyQCOBZuw0Khr__44mqwdeF4$>"
>> #EXT-X-STREAM-INF:BANDWIDTH=200000,STEERING="1"
>> https://a.example.com/video/my-movie/mid/index.m3u8 <https://urldefense.com/v3/__https:/a.example.com/video/my-movie/mid/index.m3u8__;!!GjvTz_vk!E3AorzSNM8BjAiM9Qaz2_XmVx2NyOl_J1ZzrkyQCOBZuw0Khr__44hforWWE$>
>> #EXT-X-STREAM-INF:BANDWIDTH=400000,STEERING="1"
>> https://a.example.com/video/my-movie/high/index.m3u8 <https://urldefense.com/v3/__https:/a.example.com/video/my-movie/high/index.m3u8__;!!GjvTz_vk!E3AorzSNM8BjAiM9Qaz2_XmVx2NyOl_J1ZzrkyQCOBZuw0Khr__44mfpy4iP$>
>>  
>> The client requests 
>>  
>> https://example.com/steering?video=00001&_HLS_pathway=“My-Great-CDN <https://urldefense.com/v3/__https:/a.example.com/steering?video=00001&_HLS_pathway=**BMy-Great-CDN__;4oCc!!GjvTz_vk!E3AorzSNM8BjAiM9Qaz2_XmVx2NyOl_J1ZzrkyQCOBZuw0Khr__44h1w5BH2$>"
>>  
>> And gets back this steering manifest:
>>  
>> {
>>   "VERSION": 0,
>>   "TTL": 300,
>>   "RELOAD-URI": "https://example.com/steering?video=00001&session=123 <https://urldefense.com/v3/__https:/example.com/steering?video=00001&session=123__;!!GjvTz_vk!E3AorzSNM8BjAiM9Qaz2_XmVx2NyOl_J1ZzrkyQCOBZuw0Khr__44qtYzaA4$>",
>>   "PATHWAYS": [
>>     {
>>       "ID": "My-Great-CDN",
>>       "TEMPLATES": {
>>         "1" : {
>>           "PREFIX": "https://a.example.com/video <https://urldefense.com/v3/__https:/a.example.com/video__;!!GjvTz_vk!E3AorzSNM8BjAiM9Qaz2_XmVx2NyOl_J1ZzrkyQCOBZuw0Khr__44mqwdeF4$>"
>>         }
>>       }
>>     },
>>     {
>>       "ID": "My-Backup-CDN",
>>       "TEMPLATES": {
>>         "1" : {
>>           "PREFIX": "https://b.example.com/backup-video <https://urldefense.com/v3/__https:/b.example.com/backup-video__;!!GjvTz_vk!E3AorzSNM8BjAiM9Qaz2_XmVx2NyOl_J1ZzrkyQCOBZuw0Khr__44gKCaDMb$>"
>>         }
>>       }
>>     }
>>   ]
>> ]
>>  
>>  
>> -----
>>  
>> Relative URIs (master playlist URI https://a.example.com/video/my-movie/master.m3u8 <https://urldefense.com/v3/__https:/a.example.com/video/my-movie/master.m3u8__;!!GjvTz_vk!E3AorzSNM8BjAiM9Qaz2_XmVx2NyOl_J1ZzrkyQCOBZuw0Khr__44qV1Gx_j$>)
>>  
>> #EXTM3U
>> #EXT-X-CONTENT-STEERING:SERVER-URI="https://example.com/steering?video=00001 <https://urldefense.com/v3/__https:/example.com/steering?video=00001&session=123__;!!GjvTz_vk!E3AorzSNM8BjAiM9Qaz2_XmVx2NyOl_J1ZzrkyQCOBZuw0Khr__44qtYzaA4$>"
>> #EXT-X-STEERING-TEMPLATE:ID="1",PREFIX=""
>> #EXT-X-STREAM-INF:BANDWIDTH=200000,STEERING="1"
>> /mid/index.m3u8
>> #EXT-X-STREAM-INF:BANDWIDTH=400000,STEERING="1"
>> /high/index.m3u8
>>  
>> In this case PREFIX=“” indicates that the steerable part is the entire (relative) URI. So after the client receives the steering manifest (same as above), if it has to switch to My-Backup-CDN it will just prepend its PREFIX to the steerable part of each URL to produce:
>>  
>> https://b.example.com/backup-video <https://urldefense.com/v3/__https:/b.example.com/backup-video__;!!GjvTz_vk!E3AorzSNM8BjAiM9Qaz2_XmVx2NyOl_J1ZzrkyQCOBZuw0Khr__44gKCaDMb$>/mid/index.m3u8
>>  
>> https://b.example.com/backup-video <https://urldefense.com/v3/__https:/b.example.com/backup-video__;!!GjvTz_vk!E3AorzSNM8BjAiM9Qaz2_XmVx2NyOl_J1ZzrkyQCOBZuw0Khr__44gKCaDMb$>/high/index.m3u8
>>  
>> Unless anybody spots any other major flaws in this approach, we’ll plan to update the preliminary spec and send out another version.
>>  
>>  
>> Roger.
>> 
>> 
>> 
>>> On Feb 19, 2021, at 7:07 PM, Roger Pantos <rpantos@apple.com <mailto:rpantos@apple.com>> wrote:
>>>  
>>>  
>>> 
>>> 
>>> 
>>>> On Feb 17, 2021, at 1:46 PM, Pieter-Jan Speelmans <pieter-jan.speelmans@theoplayer.com <mailto:pieter-jan.speelmans@theoplayer.com>> wrote:
>>>>  
>>>> Hi all 
>>>>  
>>>> I am pretty concerned about the backwards compatibility problems when attempting to use this in combination with older devices. It will force services to either provide two playlists, one with and one without EXT-X-DEFINE with client-side detection of the maximum version supported by the client. While this will not be an issue for up to date Apple devices, this will definitely be an issue for out of date devices but also most smart TVs, Chromecasts, Airplay implementations by those other than Apple (f.e. on LG), ...
>>>  
>>> Well, we’re still early enough that we could consider changing the format. I’m not particularly moved by the hardship of supporting EXT-X-DEFINE — anybody who is implementing content steering is going to have to do at least that much work in their m3u8 parsing anyway — but I acknowledge that requiring content vendors to provide a different master playlists for old, un-updated clients is a non-trivial burden.
>>>  
>>> What if we took the following approach instead?
>>>  
>>> First, add a new STEERING attribute to regular EXT-X-STREAM and MEDIA tags:
>>> 
>>> #EXT-X-STREAM-INF:BANDWIDTH=200000,STEERING=“1”
>>> https://a.example.com/video/mid/index.m3u8 <https://urldefense.com/v3/__https:/a.example.com/video/mid/index.m3u8__;!!GjvTz_vk!E3AorzSNM8BjAiM9Qaz2_XmVx2NyOl_J1ZzrkyQCOBZuw0Khr__44myYNLnQ$>
>>> 
>>> #EXT-X-STREAM-INF:BANDWIDTH=400000,STEERING=“1”
>>> https://a.example.com/video/high/index.m3u8 <https://urldefense.com/v3/__https:/a.example.com/video/high/index.m3u8__;!!GjvTz_vk!E3AorzSNM8BjAiM9Qaz2_XmVx2NyOl_J1ZzrkyQCOBZuw0Khr__44j6ekA61$>
>>> 
>>> This links the variants (and renditions) to a steering template definition:
>>> 
>>> #EXT-X-STEERING-TEMPLATE:ID=“1”,PREFIX="https://a.example.com/video <https://urldefense.com/v3/__https:/a.example.com/video__;!!GjvTz_vk!E3AorzSNM8BjAiM9Qaz2_XmVx2NyOl_J1ZzrkyQCOBZuw0Khr__44mqwdeF4$>”
>>> 
>>> #EXT-X-CONTENT-STEERING:SERVER-URI="/steering?video=00001",PATHWAY-ID="My-Great-CDN"
>>> 
>>> The manifest would change a bit:
>>> 
>>> {
>>>    "VERSION": 0
>>>    "TTL": 300,
>>>    "RELOAD-URI": "https://example.com/steering?video=00001&session=123 <https://urldefense.com/v3/__https:/example.com/steering?video=00001&session=123__;!!GjvTz_vk!E3AorzSNM8BjAiM9Qaz2_XmVx2NyOl_J1ZzrkyQCOBZuw0Khr__44qtYzaA4$>",
>>>    "PATHWAYS": [
>>>        {
>>> "ID": "My-Great-CDN",
>>> "TEMPLATES": {
>>>   "1" : { 
>>> “PREFIX”: "https://a.example.com/video <https://urldefense.com/v3/__https:/a.example.com/video__;!!GjvTz_vk!E3AorzSNM8BjAiM9Qaz2_XmVx2NyOl_J1ZzrkyQCOBZuw0Khr__44mqwdeF4$>" 
>>>   }
>>> }
>>>        },
>>>        {
>>> "ID": "My-Backup-CDN",
>>> "TEMPLATES": {
>>>   "1" : { 
>>> “PREFIX”: "https://b.example.com/backup-video <https://urldefense.com/v3/__https:/b.example.com/backup-video__;!!GjvTz_vk!E3AorzSNM8BjAiM9Qaz2_XmVx2NyOl_J1ZzrkyQCOBZuw0Khr__44gKCaDMb$>" 
>>>   }
>>> }
>>>        }
>>>    ]
>>> }
>>>  
>>> The client would load and play the master playlist as usual. When it parsed the EXT-X-STREAM-INF and EXT-X-MEDIA tags it would see the STEERING attribute and verify that there is a corresponding EXT-X-STEERING-TEMPLATE and that the PREFIX of the steering template matches the start of the URI (fatal error if either check fails). It would store away the remainder of the URI as the “steerable part.”
>>> 
>>> When it loaded the manifest it would check that each pathway had an object in its TEMPLATES object for each STEERING-TEMPLATE (matching the key to the ID). (If it did not, steering would be disabled.)
>>>  
>>> To switch pathways it would concatenate the PREFIX from the TEMPLATES object with the steerable part of each URI. After that, everything would behave the same way.
>>>  
>>> This approach isn’t as flexible as general variable substitution. But I think that it would still cover the majority of the substitution use cases (and I’d be interested to hear about those that it doesn’t).
>>>  
>>>  
>>> Roger.
>>> 
>>> 
>>> 
>>>>  
>>>> My personal opinion is that the value of backwards compatibility would warrant the drawbacks I currently see. 
>>>>  
>>>> Best regards,
>>>> Pieter-Jan
>>>>  
>>>>  
>>>> Pieter-Jan Speelmans
>>>> CTO
>>>> 
>>>> THEO Technologies NV
>>>> w | www.theoplayer.com <https://urldefense.com/v3/__http:/www.theoplayer.com/__;!!GjvTz_vk!E3AorzSNM8BjAiM9Qaz2_XmVx2NyOl_J1ZzrkyQCOBZuw0Khr__44kRAt7LO$>
>>>> Philipssite 5, Bus 1. 3001 Leuven, Belgium
>>>>  <https://urldefense.com/v3/__https:/d2oj23ymxjbl3l.cloudfront.net/__;!!GjvTz_vk!E3AorzSNM8BjAiM9Qaz2_XmVx2NyOl_J1ZzrkyQCOBZuw0Khr__44uAXLPbU$>
>>>> Leuven (Belgium) - New York (US) - Singapore (SG) - Barcelona (ES)
>>>> BTW: BE 0847.829.290, RPR: Leuven
>>>>  
>>>> 
>>>> On Wed, Feb 17, 2021 at 9:57 PM Roger Pantos <rpantos=40apple.com@dmarc.ietf.org <mailto:40apple.com@dmarc.ietf.org>> wrote:
>>>>> Hello hls-interest,
>>>>> 
>>>>> As discussed on the call today, here is the preliminary specification for the new Content Steering feature. We are converging on the final design for 1.0, so please take a look at it when you can and tell us what you think. 
>>>>> 
>>>>> You can send feedback to this list, or to http-live-streaming-review@group.apple.com <mailto:http-live-streaming-review@group.apple.com> if you want it to go directly to us.
>>>>> 
>>>>> 
>>>>> 
>>>>> 
>>>>> regards,
>>>>> 
>>>>> Roger Pantos
>>>>> Apple Inc.-- 
>>>>> Hls-interest mailing list
>>>>> Hls-interest@ietf.org <mailto:Hls-interest@ietf.org>
>>>>> https://www.ietf.org/mailman/listinfo/hls-interest <https://urldefense.com/v3/__https:/www.ietf.org/mailman/listinfo/hls-interest__;!!GjvTz_vk!E3AorzSNM8BjAiM9Qaz2_XmVx2NyOl_J1ZzrkyQCOBZuw0Khr__44nsxABxl$>
>>>>  
>>>> Legal Notice 
>>>> You can find the latest terms and policies of THEO Technologies under www.theoplayer.com/terms <https://urldefense.com/v3/__http:/www.theoplayer.com/terms__;!!GjvTz_vk!E3AorzSNM8BjAiM9Qaz2_XmVx2NyOl_J1ZzrkyQCOBZuw0Khr__44hw7Mpir$> including our "GENERAL TERMS AND CONDITIONS". In the absence of a signed agreement between you and THEO Technologies, by replying to this email these terms apply to the relevant transaction between us.   
>>>> The contents of this email message and any attachments are intended solely for the addressee(s) and contain CONFIDENTIAL and/or privileged information and are legally protected from disclosure. If you are not the intended recipient of this message, please immediately alert the sender by reply email and then delete this message including any attachments and you are hereby notified that any use, dissemination, copying, or storage of this message or its attachments is strictly prohibited. 
>>>> Full security of emails over the internet cannot be ensured. Despite our efforts it is your responsibility to provide for your protection.
>>>> Global HQ: THEO Technologies NV, Philipssite 5 bus 1, 3001 Heverlee, Belgium - BE 0847.829.290 - CEO: Steven Tielemans
>>> 
>>>  
>> 
>>  
>> -- 
>> Hls-interest mailing list
>> Hls-interest@ietf.org <mailto:Hls-interest@ietf.org>
>> https://www.ietf.org/mailman/listinfo/hls-interest <https://urldefense.com/v3/__https:/www.ietf.org/mailman/listinfo/hls-interest__;!!GjvTz_vk!E6fhAAQPxWo-bK7LlqHUAnZeDNBMn6k4o5KNy7XbzzP0fc3IYkli5sLzi3jM$>
> 
> 
> -- 
> Hls-interest mailing list
> Hls-interest@ietf.org <mailto:Hls-interest@ietf.org>
> https://www.ietf.org/mailman/listinfo/hls-interest <https://www.ietf.org/mailman/listinfo/hls-interest>