Re: [secdir] secdir review of draft-ietf-simple-msrp-sessmatch

Ted Hardie <ted.ietf@gmail.com> Tue, 29 June 2010 17:37 UTC

Return-Path: <ted.ietf@gmail.com>
X-Original-To: secdir@core3.amsl.com
Delivered-To: secdir@core3.amsl.com
Received: from localhost (localhost [127.0.0.1]) by core3.amsl.com (Postfix) with ESMTP id 166133A699C; Tue, 29 Jun 2010 10:37:17 -0700 (PDT)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -0.958
X-Spam-Level:
X-Spam-Status: No, score=-0.958 tagged_above=-999 required=5 tests=[AWL=1.641, BAYES_00=-2.599]
Received: from mail.ietf.org ([64.170.98.32]) by localhost (core3.amsl.com [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id HwDhQTXrZYq5; Tue, 29 Jun 2010 10:37:14 -0700 (PDT)
Received: from mail-pw0-f44.google.com (mail-pw0-f44.google.com [209.85.160.44]) by core3.amsl.com (Postfix) with ESMTP id B852E3A6817; Tue, 29 Jun 2010 10:37:14 -0700 (PDT)
Received: by pwj2 with SMTP id 2so241615pwj.31 for <multiple recipients>; Tue, 29 Jun 2010 10:37:22 -0700 (PDT)
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=gamma; h=domainkey-signature:mime-version:received:received:in-reply-to :references:date:message-id:subject:from:to:cc:content-type :content-transfer-encoding; bh=cFfjERd7VbMuwkNp9PpYKjhXOIAuROOQhAnjmwTg6h8=; b=Y6qKSFNQEeFE7b1lxOk0Ven/PD6Zq233jPOXWscN74AK0HL5+vs8+qb5+4W/jIf2Lk 34ADn+yx2Fa9juXsLe/CNzpZkK5HPvKxtoTXYFYtxbMUs9eGWNYWPpROpfCrdaQ5EaM3 /PVHfZl570Xf+m3UCO32sF4ryLnk0QjJzRrcw=
DomainKey-Signature: a=rsa-sha1; c=nofws; d=gmail.com; s=gamma; h=mime-version:in-reply-to:references:date:message-id:subject:from:to :cc:content-type:content-transfer-encoding; b=XjXKX5l5AyS5JeyD6bogqFw4gZty05yu7L9fYL5cjltsAGOhRGkV0PLS48WnyPvxmu 4zCNQNrNGxtAKBovVPiOPc272d8DhCSqHfSS60+CAneeJJioP51PuhpD/kWGKO5fkNot MYyQHrC6BnUeXs5vO3W6Asc35HV3YGzzllZBI=
MIME-Version: 1.0
Received: by 10.142.2.22 with SMTP id 22mr8570352wfb.13.1277833041903; Tue, 29 Jun 2010 10:37:21 -0700 (PDT)
Received: by 10.142.254.11 with HTTP; Tue, 29 Jun 2010 10:37:21 -0700 (PDT)
In-Reply-To: <FF84A09F50A6DC48ACB6714F4666CC7468A54B9BC4@ESESSCMS0354.eemea.ericsson.se>
References: <5A638DC0-41CF-4C0C-B00D-6793C43FB708@bbn.com> <AANLkTikyh2zkQgfnPNgW5orxXvP5fOw7KnpW03V_XFJJ@mail.gmail.com> <FF84A09F50A6DC48ACB6714F4666CC7468A54B9BC4@ESESSCMS0354.eemea.ericsson.se>
Date: Tue, 29 Jun 2010 10:37:21 -0700
Message-ID: <AANLkTilx4YtoejdifMC06s46xXXp6QmIOgbT5VVzJcdE@mail.gmail.com>
From: Ted Hardie <ted.ietf@gmail.com>
To: Christer Holmberg <christer.holmberg@ericsson.com>
Content-Type: text/plain; charset="ISO-8859-1"
Content-Transfer-Encoding: quoted-printable
X-Mailman-Approved-At: Wed, 30 Jun 2010 08:31:41 -0700
Cc: "draft-ietf-simple-msrp-sessmatch@tools.ietf.org" <draft-ietf-simple-msrp-sessmatch@tools.ietf.org>, The IETF <ietf@ietf.org>, "iesg@ietf.org" <iesg@ietf.org>, "secdir@ietf.org" <secdir@ietf.org>
Subject: Re: [secdir] secdir review of draft-ietf-simple-msrp-sessmatch
X-BeenThere: secdir@ietf.org
X-Mailman-Version: 2.1.9
Precedence: list
List-Id: Security Area Directorate <secdir.ietf.org>
List-Unsubscribe: <https://www.ietf.org/mailman/listinfo/secdir>, <mailto:secdir-request@ietf.org?subject=unsubscribe>
List-Archive: <http://www.ietf.org/mail-archive/web/secdir>
List-Post: <mailto:secdir@ietf.org>
List-Help: <mailto:secdir-request@ietf.org?subject=help>
List-Subscribe: <https://www.ietf.org/mailman/listinfo/secdir>, <mailto:secdir-request@ietf.org?subject=subscribe>
X-List-Received-Date: Tue, 29 Jun 2010 17:37:17 -0000

In-line.

On Tue, Jun 29, 2010 at 8:41 AM, Christer Holmberg
<christer.holmberg@ericsson.com> wrote:
>
> Hi Ted,
>
>>I join Richard in believing that this document makes changes
>>beyond that which could be understood as "updating" the MSRP
>>URI scheme processing.
>>
>>To highlight one particular aspect, RFC 4975 does not require
>>session-ids to be present, a fact noted both in the ABNF and
>>in this text:
>>
>>4. The session-id part is compared as case sensitive.  A URI without
>>   a session-id part is never equivalent to one that includes one.
>>
>>A matching scheme which relies on a URI section which is not
>>guaranteed to be present has some interesting problems ahead
>>of it. If this effectively makes their use mandatory, that
>>requires a change to the fundamental ABNF and text.
>
> An MSRP URI in an SDP offer or answer for an MSRP session MUST include a session-id part, so I believe the comment is >based on incorrect assumptions.

This is not indicated in the URI matching sectio


>
> Section 6 of RFC 4975 says:
>
>   "The session-id part identifies a particular session of the participant. The absence of the session-id
>   part indicates a reference to an MSRP host device, but does not refer to a particular session at that device."
>

The full section from which that quote is taken is:

   The MSRP URI authority field identifies a participant in a particular
   MSRP session.  If the authority field contains a numeric IP address,
   it MUST also contain a port.  The session-id part identifies a
   particular session of the participant.  The absence of the session-id
   part indicates a reference to an MSRP host device, but does not refer
   to a particular session at that device.  A particular value of
   session-id is only meaningful in the context of the associated
   authority; thus, the authority component can be thought of as
   identifying the "authority" governing a namespace for the session-id.

This proposal changes the concept of a namespace authority present
in the URI matching section of RFC 4975.  I am sorry if my wry reference
to this in my previous message was hard to follow; I should have known better.
To be more plain, this proposal fundamentally changes the matching semantics
of the URI set out in RFC 4975, by requiring a match on only a portion of the
URI.  At a bare minimum, this would require noting a normative update to
section 6 and 6.1 of RFC 4975, which this draft does not do.  In
reality, this is unlikely
to be sufficient, as URI matching semantics do not generally have the concept
of ignoring the authority in providing a match (at least in my reading
of the RFC
3986 "ladder of comparison" text).  That means you'd have to special case
the MSRP matching semantics, rather than have the URI be parsed and compared
using a standard library.

Creating a new URI scheme without re-using authority may be a better approach;
this would require more work, but it is cleaner than this appears to be.

>
>>I also note that the security considerations, in addition to
>>having some fairly disingenuous language about the impact of
>>this change, seems to fail to mention MSRPS URIs and what, if
>>any, impact this would have on them.
>
> There are no impacts to MSRPS URIs. I assumed it would be implicitly understood since MSRPS URIs are not mentioned in the draft.
>
> However, we could explicitly make it clear by modifying the first sentences of section 5:
>
>      "The change of session matching procedure does not impact the format of MSRP URIs,
>        disregarding if the "msrp" scheme or the "msrps" scheme is used.
>        However, MSRP endpoints can only check that the session-id part of the MSRP URI..."
>

This doesn't seem to me to actually work, based on Richard's comments,
unless what
you mean to say is "if MSRPS is in use, nothing in this draft can be
used".  That gives
you different matching semantics for MSRPS (authority must be present
and must be
matched using TLS semantics) vs MSRP (only session-id is checked)
which is at the very least
a violation of the principle of least surprise (no other foo over TLS
protocol works that way
that I know of ).

regards,

Ted
>
> Regards,
>
> Christer
>
>
>
>> On Mon, Jun 14, 2010 at 10:21 AM, Richard L. Barnes
>> <rbarnes@bbn.com> wrote:
>> > I have reviewed this document as part of the security directorate's
>> > ongoing effort to review all IETF documents being processed by the
>> > IESG.  These comments were written primarily for the benefit of the
>> > security area directors.  Document editors and WG chairs
>> should treat
>> > these comments just like any other last call comments.
>> >
>> > This document changes the URI matching algorithm used in
>> MSRP.  MSRP
>> > sessions are typically initiated using SDP bodies in SIP.
>> These SDP
>> > bodies contain MSRP URIs that the peers use to contact each other.
>> > When one peer receives a request to initiate a session, he verifies
>> > that the URI being requested is one that he initiated in
>> SDP, thereby
>> > using the URI as a shared secret to authenticate that the
>> originator
>> > of the session actually received the SDP body in question.
>> >
>> > According to the current SDP specification, this comparison is
>> > performed over the whole URI; this document restricts the
>> comparison
>> > to the "session-id" component, omitting the host, port, and
>> transport components.
>> >  The goal of the document is to facilitate a certain class of
>> > man-in-the-middle attack, namely to allow a signaling
>> intermediary to
>> > insert a media intermediary.  The restriction on the URI
>> comparison is
>> > needed in order for the media intermediary not to have to
>> modify URIs
>> > in MSRP packets to reflect the modifications to URIs in SDP bodies
>> > performed to redirect traffic through the media intermediary.
>> >
>> > I have a few significant reservations about this document:
>> >
>> > This extension makes it more difficult for MSRP entities to secure
>> > their communications against attackers in the signaling path.  The
>> > current model provides a basic integrity protection, in
>> that signaling
>> > intermediaries cannot redirect traffic to an arbitrary third party;
>> > they must at least advise the third party about how to modify MSRP
>> > packets.  The proposed modification would remove even this cost.
>> > Moreover, it raises the cost of providing integrity protection to
>> > messages, since Alice must now employ both integrity and
>> > confidentiality protections on an end-to-end basis; if her messages
>> > are only integrity-protected, then a proxy can remove the
>> integrity protection and redirect traffic without it being
>> observable to Alice.
>> >
>> > The document needs to clarify what the impacts are for
>> authentication
>> > in secure modes of MSRP.  In particular:
>> > -- The distinction between "self-signed" and "public"
>> certificates is
>> > inappropriate.  The proper distinction is between the name-based
>> > authentication in Section 14.2 of RFC 4975 and the
>> fingerprint-based
>> > authentication in Section 14.4. -- In either case, changing
>> the host
>> > name need not result in an authentication failure, since the media
>> > intermediary can simply authenticate as itself to both endpoints,
>> > having changed the respective MSRP URIs appropriately.
>> > -- There is currently no requirement that a endpoint
>> identity in the
>> > To-Path URI matches the endpoint identity authenticated at the TLS
>> > layer, because these two are required to be the same.  This
>> document
>> > changes that assumption, and should note that these two
>> identities can differ.
>> > The document also precludes any name-based multiplexing, where a
>> > single MSRP process (single IP address and port) directs
>> requests to
>> > different virtual recipients based on the domain name in
>> the To-Path
>> > header.  (In analogy to Host-based multiplexing in HTTP,
>> which is very
>> > widely deployed.)  Since with this extension, the domain in the
>> > To-Path is completely unpredictable from the recipient's
>> perspective, it is useless to the recipient.
>> >
>> > The document has no backward-compatibility.  MSRP
>> implementations that
>> > do not support this extension will not be able to receive MSRP
>> > sessions from implementations that do.   In that regard,  this
>> > document seems more like an new version of MSRP rather than
>> an update.
>> >
>> >
>> >
>> >
>> >
>> >
>> >
>> >
>> > _______________________________________________
>> > Ietf mailing list
>> > Ietf@ietf.org
>> > https://www.ietf.org/mailman/listinfo/ietf
>> >
>>