Re: [straw] WGLC: for draft-ietf-straw-b2bua-taxonomy-00

Paul Kyzivat <pkyzivat@alum.mit.edu> Tue, 22 January 2013 17:35 UTC

Return-Path: <pkyzivat@alum.mit.edu>
X-Original-To: straw@ietfa.amsl.com
Delivered-To: straw@ietfa.amsl.com
Received: from localhost (localhost [127.0.0.1]) by ietfa.amsl.com (Postfix) with ESMTP id 3F1F121F89BA for <straw@ietfa.amsl.com>; Tue, 22 Jan 2013 09:35:50 -0800 (PST)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -0.437
X-Spam-Level:
X-Spam-Status: No, score=-0.437 tagged_above=-999 required=5 tests=[BAYES_00=-2.599, FH_RELAY_NODNS=1.451, HELO_MISMATCH_NET=0.611, RDNS_NONE=0.1]
Received: from mail.ietf.org ([64.170.98.30]) by localhost (ietfa.amsl.com [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id k06NjPUS8IhB for <straw@ietfa.amsl.com>; Tue, 22 Jan 2013 09:35:49 -0800 (PST)
Received: from qmta03.westchester.pa.mail.comcast.net (qmta03.westchester.pa.mail.comcast.net [IPv6:2001:558:fe14:43:76:96:62:32]) by ietfa.amsl.com (Postfix) with ESMTP id 30D9021F891C for <straw@ietf.org>; Tue, 22 Jan 2013 09:35:49 -0800 (PST)
Received: from omta23.westchester.pa.mail.comcast.net ([76.96.62.74]) by qmta03.westchester.pa.mail.comcast.net with comcast id qz8W1k0031c6gX8535boM6; Tue, 22 Jan 2013 17:35:48 +0000
Received: from Paul-Kyzivats-MacBook-Pro.local ([50.138.229.164]) by omta23.westchester.pa.mail.comcast.net with comcast id r5bn1k00g3ZTu2S3j5bnzy; Tue, 22 Jan 2013 17:35:48 +0000
Message-ID: <50FECDF3.5020500@alum.mit.edu>
Date: Tue, 22 Jan 2013 12:35:47 -0500
From: Paul Kyzivat <pkyzivat@alum.mit.edu>
User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.7; rv:17.0) Gecko/20130107 Thunderbird/17.0.2
MIME-Version: 1.0
To: Hadriel Kaplan <HKaplan@acmepacket.com>
References: <CCDA9C9B.64B1%vpascual@acmepacket.com> <50BFD464.6090204@alum.mit.edu> <DDF3B4DF-5B13-4C54-8D82-9AA2BFE7A228@acmepacket.com>
In-Reply-To: <DDF3B4DF-5B13-4C54-8D82-9AA2BFE7A228@acmepacket.com>
Content-Type: text/plain; charset="ISO-8859-1"; format="flowed"
Content-Transfer-Encoding: 7bit
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=comcast.net; s=q20121106; t=1358876148; bh=TIIbe1NCxKlvJf9VGQo2j8JNBliJdLIVXHgn290rr4Y=; h=Received:Received:Message-ID:Date:From:MIME-Version:To:Subject: Content-Type; b=IXk5iQ37jOm3/+mV8VS0DPckaMFcSHEGPF4wJgHotnNr9RRPivPn8mhzrg/8hHDEj C2ynJ/t10tEltcBiHuDQw7Osz3Bkf/O2YbDBoFvpAeUUrCuhabE0gTm7r4THGyBYHY YGTHAmpDBZAKJdUuBxSRGuhtXDO9f+MjRCiF6R8f1VFNhAe7D/EY6B+kuEa01kPxVs kQAFmUv533ii/wiYti64quHkvzjw0eUG2lstKN04BM717Necd/WGVzTrH4yd2LuCXa jVYKMSGxBKjpdRn2C4H8bpa44ls3sg1c3RNqPMzjthtZYP3RH1yuSMoNGA+MvIIuDA RrIguLSP2TQDA==
Cc: Victor Pascual <vpascual@acmepacket.com>, "<straw@ietf.org>" <straw@ietf.org>, Christer Holmberg <christer.holmberg@ericsson.com>
Subject: Re: [straw] WGLC: for draft-ietf-straw-b2bua-taxonomy-00
X-BeenThere: straw@ietf.org
X-Mailman-Version: 2.1.12
Precedence: list
List-Id: "Sip Traversal Required for Applications to Work \(STRAW\) working group discussion list" <straw.ietf.org>
List-Unsubscribe: <https://www.ietf.org/mailman/options/straw>, <mailto:straw-request@ietf.org?subject=unsubscribe>
List-Archive: <http://www.ietf.org/mail-archive/web/straw>
List-Post: <mailto:straw@ietf.org>
List-Help: <mailto:straw-request@ietf.org?subject=help>
List-Subscribe: <https://www.ietf.org/mailman/listinfo/straw>, <mailto:straw-request@ietf.org?subject=subscribe>
X-List-Received-Date: Tue, 22 Jan 2013 17:35:50 -0000

Sorry for the belated reply. I set it aside for the holidays and forgot 
to get back to it. Comments inline.

On 12/21/12 4:45 PM, Hadriel Kaplan wrote:
> Hi Paul,
> thanks for reviewing the draft!
> Comments/actions inline...
>
> On Dec 5, 2012, at 6:10 PM, Paul Kyzivat <pkyzivat@alum.mit.edu> wrote:
>
>> I've only been looking at changes in this for awhile. Now that we are at WGLC I actually carefully read through it again. I have more comments than I thought I would.
>>
>> Section 3:

[snip]

>>
>>    Likewise, a one-armed
>>    third-party call control transcoder as described in section 3.1 of
>>    [RFC5369] is not a B2BUA; whereas an inline transcoder based on
>>    [RFC5370] is a B2BUA.
>>
>> IMO this is very subjective. There clearly *is* a distinction between the two cases, but that doesn't necessarily mean they aren't both B2BUAs. It would be very helpful to have both types of transcoders included so that it is possible to contrast the differences between the two.
>>
>> I think the problem here is that we don't have clear criteria for what to include and what to exclude. In this case I think the key distinction is whether or not the transcoder is on the signaling path between the caller and the UA that represents the callee. (Interestingly, that is also true of a conference focus, and for a UA that splits a multimedia call, sending the different media to different devices.) So maybe that is the criterion that matters. If so, it would be helpful to explicitly state this and ensure that the decisions are all made based on this.
>
> Right, exactly - it goes back to the debate we've had in the WG about whether a server acting as a UAS for multiple sessions (ie, is the target of them) is a "B2BUA" in the sense that we want to cover it with this doc, or not.
>
> I don't believe there's been resolution on that, has there?

No, I don't think there has. We have use cases that are topologically 
very similar that some seem to want to classify differently.

E.g. the 3rd party transcoder looks remarkably like a click-to-talk 3pcc 
controller.

IMO this indicates that we haven't yet found the key distinctions.

>> Section 3.1.1:
>>
>> As I brought up at the Atlanta meeting, a Proxy-B2BUA that generates in-dialog messages will need to "make room" in the progression of CSeq values for the messages it generates. This means, once it generates a message, that CSeq values will differ on the two "sides". The b2bua then must modify CSeq values to perform the mapping.
>>
>> (A Proxy-B2BUA that only generates a BYE message probably segments the session at that time, no longer forwarding messages, and so won't need to update CSeq values. But it will still need to know what CSeq value it can use for the BYE, so it will need to keep state.)
>>
>> This is a fairly significant issue, and IMO should be mentioned explicitly.
>
> Right, Brett Tate had brought this up as well, when the draft used to describe that a Proxy-B2BUA might send UPDATEs for session refresh/liveness.  So I deleted the sentence that said so, in order to avoid having to explain what all such a Proxy-B2BUA might need to do.
> But I'll put it in, as you've pointed out it's unavoidable.  :)

OK. Thanks.

>> Section 3.1.2:
>>
>> I have always considered that there is a major distinction between those b2buas that replace the Contact with one of their own, and those that leave the Contact and use Record-Route to stay in the call.
>>
>> For example, one that replaces the contact can potentially use callee-caps to represent its capabilities/features, while the other kind must use Proxy-Feature to identify itself. The Proxy-Feature draft danced all around this, pretending it was only talking about proxies when in fact we all know it was intending to cover B2BUAs. If it had been able to reference this draft then having that distinction available could have been important.
>
> What textual changes do you want made to the draft for the above?

I don't know. Does anyone else think this distinction is of any 
significance?

ISTM that if you *don't* replace the contact then you are really wish to 
be a proxy, but can't live with the limitations of proxies.

If you *do* replace the contact, then you are standing up and saying "I 
admit that I am a UA and claim all the capabilities and responsibilities 
that implies".

>> Section 3.2:
>>
>>    Such a B2BUA may or may not replace the
>>    Contact URI, modify or remove all Via and Record-Route headers,
>>    modify the To and From header fields, etc.
>>
>> I think you are saying that any of the Media-plane roles is compatible with any of the Signaling-plane roles. I wish you would say it explicitly.
>>
>> This would then mean that we could describe every B2BUA by naming both its signaling role and its media role.
>
> That as not my intention - I think any media-plane B2BUA has to modify the SDP, so the intention was that media-plane B2BUAs are a superset-of/go-beyond the SDP-modifying signaling level.

I need to think about this more.
It doesn't appear to me to fit a hierarchy very well.
It seems more two-dimensional, though not all combinations may apply.

>> Section 3.2.1:
>>
>>    Such a role may only
>>    support UDP or only TCP or both, as well as other transport types or
>>    not.
>>
>> Should these be different roles?
>
> Should what be different roles?  I'm confused by what you're referring to.

My point is that a Media-plane B2BUA may be classified into one of the 
sub-roles (relay, aware, termination, or bypass) independently for each 
media type.

You don't mention bypass here. If it uses bypass for all media types, 
then it is a Signaling-plane B2BUA.

So these sub-types are useful, but you can't always classify a server 
into just one of them.

>> What does it mean to *not* support some transport type? Does it mean that it is a signaling-only B2BUA wrt that media? Or that it blocks that media?
>> (ISTM blocking the media is a signaling-only function - a variant on the SDP-Modifying Signaling-only role.)
>
> In practice I've only ever seen such devices block TCP media (or even just fail calls with TCP-based media).  But I guess one could do a hybrid.  Does it matter though?  I mean if there's some new TCP-based media mechanism coming out of MMUSIC, that needs to say something about B2BUAs, can't they just say "Media-relay B2BUAs as defined in [RFCXXXX] need to support TCP and do X for our new mechanism to work"?

We shouldn't be using TCP as an example here, because there are 
*already* TCP-based mechanisms in SDP. So lets use something newer, like 
SCTP - e.g. in draft-ietf-mmusic-sctp-sdp-nn.

I'm suggesting that the description needs to be more like:

"A media-plane B2BUA (as defined in [RFCXXXX]) MUST apply one of 
media-plane roles (relay, aware, termination, or bypass) to this protocol."

We would want every draft that defines a new <proto> to include similar 
language.

	Thanks,
	Paul