Re: [sipcore] Adam Roach's Discuss on draft-ietf-sipcore-sip-push-21: (with DISCUSS and COMMENT) - the COMMENT issues

Christer Holmberg <christer.holmberg@ericsson.com> Wed, 09 January 2019 18:50 UTC

Return-Path: <christer.holmberg@ericsson.com>
X-Original-To: sipcore@ietfa.amsl.com
Delivered-To: sipcore@ietfa.amsl.com
Received: from localhost (localhost [127.0.0.1]) by ietfa.amsl.com (Postfix) with ESMTP id BF933130F4D for <sipcore@ietfa.amsl.com>; Wed, 9 Jan 2019 10:50:24 -0800 (PST)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -8.854
X-Spam-Level:
X-Spam-Status: No, score=-8.854 tagged_above=-999 required=5 tests=[BAYES_00=-1.9, DKIMWL_WL_HIGH=-4.553, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, RCVD_IN_DNSWL_MED=-2.3, SPF_PASS=-0.001] autolearn=unavailable autolearn_force=no
Authentication-Results: ietfa.amsl.com (amavisd-new); dkim=pass (1024-bit key) header.d=ericsson.com header.b=SotYjeus; dkim=pass (1024-bit key) header.d=ericsson.com header.b=HyfTY+Lr
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 l_cZL-xbaJXw for <sipcore@ietfa.amsl.com>; Wed, 9 Jan 2019 10:50:23 -0800 (PST)
Received: from sessmg22.ericsson.net (sessmg22.ericsson.net [193.180.251.58]) (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 3918B130FFF for <sipcore@ietf.org>; Wed, 9 Jan 2019 10:50:12 -0800 (PST)
DKIM-Signature: v=1; a=rsa-sha256; d=ericsson.com; s=mailgw201801; c=relaxed/relaxed; q=dns/txt; i=@ericsson.com; t=1547059809; x=1549651809; h=From:Sender:Reply-To:Subject:Date:Message-ID:To:CC:MIME-Version:Content-Type: Content-Transfer-Encoding:Content-ID:Content-Description:Resent-Date:Resent-From: Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:In-Reply-To:References:List-Id: List-Help:List-Unsubscribe:List-Subscribe:List-Post:List-Owner:List-Archive; bh=ef/Gc/fbCFn34n+NiEeekdx08MaXPwCroHeZTyPL/CY=; b=SotYjeuskxJXibeHc7t/EJejh9ZNB1CkzHpMPXMflHqefDhBCqSIeh9HD5bVge7b rodeMZBAC0dYVZkOlPq3NzI/e3L7Tbu9GtQ5UDf9BoYvsrQfvDeOwWEA5HihagcN Ii2s2vZT39Ln5/UQaBOmzFo2aMqXcWKjCAbuehDNejg=;
X-AuditID: c1b4fb3a-5c9c29e00000672c-4b-5c3642614e01
Received: from ESESSMB501.ericsson.se (Unknown_Domain [153.88.183.119]) by sessmg22.ericsson.net (Symantec Mail Security) with SMTP id F2.0E.26412.162463C5; Wed, 9 Jan 2019 19:50:09 +0100 (CET)
Received: from ESESBMR502.ericsson.se (153.88.183.134) by ESESSMB501.ericsson.se (153.88.183.189) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.1466.3; Wed, 9 Jan 2019 19:49:03 +0100
Received: from ESESBMB503.ericsson.se (153.88.183.170) by ESESBMR502.ericsson.se (153.88.183.134) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.1466.3; Wed, 9 Jan 2019 19:49:03 +0100
Received: from EUR01-DB5-obe.outbound.protection.outlook.com (153.88.183.157) by ESESBMB503.ericsson.se (153.88.183.170) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.1466.3 via Frontend Transport; Wed, 9 Jan 2019 19:49:03 +0100
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ericsson.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=ef/Gc/fbCFn34n+NiEeekdx08MaXPwCroHeZTyPL/CY=; b=HyfTY+Lr0bpLBiBHoI/40hsVHnIFTSqCSSq6kcsvJEE1ogi+JZPv647gDAa0HiT/12iA031pdWd5l3vWf8TTR/MtaPjCB9v7P6Nt4Ho1d6bkk5yybbwPNGLfH6918dyNMxUtfxJdTCgDiFdT5QyK4FVb8znj1f+t0UL8OghfUFU=
Received: from HE1PR07MB3161.eurprd07.prod.outlook.com (10.170.245.23) by HE1PR07MB3066.eurprd07.prod.outlook.com (10.170.244.152) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.1516.9; Wed, 9 Jan 2019 18:49:01 +0000
Received: from HE1PR07MB3161.eurprd07.prod.outlook.com ([fe80::852a:3f04:e342:cf55]) by HE1PR07MB3161.eurprd07.prod.outlook.com ([fe80::852a:3f04:e342:cf55%3]) with mapi id 15.20.1516.010; Wed, 9 Jan 2019 18:49:01 +0000
From: Christer Holmberg <christer.holmberg@ericsson.com>
To: Adam Roach <adam@nostrum.com>, The IESG <iesg@ietf.org>
CC: "draft-ietf-sipcore-sip-push@ietf.org" <draft-ietf-sipcore-sip-push@ietf.org>, Brian Rosen <br@brianrosen.net>, "sipcore-chairs@ietf.org" <sipcore-chairs@ietf.org>, "br@brianrosen.net" <br@brianrosen.net>, "sipcore@ietf.org" <sipcore@ietf.org>
Thread-Topic: Adam Roach's Discuss on draft-ietf-sipcore-sip-push-21: (with DISCUSS and COMMENT) - the COMMENT issues
Thread-Index: AdSoM/058h69J+LUTn2Y/3kLvufFsQ==
Date: Wed, 09 Jan 2019 18:49:01 +0000
Message-ID: <HE1PR07MB316134C6285D94AC5CC0D3E3938B0@HE1PR07MB3161.eurprd07.prod.outlook.com>
Accept-Language: en-US
Content-Language: en-US
X-MS-Has-Attach:
X-MS-TNEF-Correlator:
authentication-results: spf=none (sender IP is ) smtp.mailfrom=christer.holmberg@ericsson.com;
x-originating-ip: [192.176.1.75]
x-ms-publictraffictype: Email
x-microsoft-exchange-diagnostics: 1; HE1PR07MB3066; 6:yZIVIl7FlgJUMVB3A4KdrlWdsDn45M1gV3VaHv2ryNIdG7IBgxZ083vrUaeLluUHk75aEbol8spmww050t7VQrgywzSTiUGYXuzJ8c4IkGx6vscnqV9LYyjOoldBUo9RaEyEwxYV83GnvilUfQARcs3k6A2QGaqKaFGipn9GCrmCn1kVPQa9YofESbuFEie/3K8CZXcusgT7aCB79pAHu4zN4QCTtVXJ1txNRpGuOOL7nRv3tu9/tQbygxeDNVrdH1X9LP8xkSyaahQxiXedI4TgGRhYdI01MNo4460GxE8O3TwzNMLg06NLaZ3FIvYU8q6xnWTG4hzuJ28MH9OGGSczYx98bPRdiLIOh1G9lySUTD69ifAB4Rjaaun6DmA5Q8r4nQHB4PesVQhE3CgQoX9aDYXceW+fX4XjGMyW9P+2uZwGC915r+dFtxsc4Ty0Q9b9qaXgfO4ay3nllfrSQQ==; 5:eB2RGcwviAT9Itw5/7nvoh3QMrVDbzlyNhjjuoBzq18rUASRvrLgUyC+2T312MaEK02s/y6eBklfnGyKvJvBpN2XrY7WyqPxi/9odQgnwadWsZa9fC8lvRLX9tTRi28nR+fkFBZ9ToSDWALfQSI1IRq0Z5EwgZ+HikmET5K1xtM1/IgI5cieUZ+ZytRtk/5SBLwICtcJ2Ekwk8cmKbFBog==; 7:XNz/8kancaYzhxuAFsvw+xpiExL7OBrLMdYNYZQJDeQaaEswu8qWHygCDaf+GTqU0SPY/79sJm4ihgaL9wYLx/g54YuNveRlT+pxN6dazmqlhPoVaf/qR/cij2910AkoM7hpN/k/6uINYyxcCvy1Vw==
x-ms-exchange-antispam-srfa-diagnostics: SOS;
x-ms-office365-filtering-correlation-id: 27b0aaba-ddd5-4aff-f050-08d676631f2d
x-microsoft-antispam: BCL:0; PCL:0; RULEID:(2390118)(7020095)(4652040)(8989299)(4534185)(4627221)(201703031133081)(201702281549075)(8990200)(5600109)(711020)(2017052603328)(7153060)(7193020); SRVR:HE1PR07MB3066;
x-ms-traffictypediagnostic: HE1PR07MB3066:
x-microsoft-antispam-prvs: <HE1PR07MB3066C5E1F723994FF2EDE20B938B0@HE1PR07MB3066.eurprd07.prod.outlook.com>
x-exchange-antispam-report-cfa-test: BCL:0; PCL:0; RULEID:(8211001083)(3230021)(908002)(999002)(5005026)(6040522)(8220060)(2401047)(8121501046)(93006095)(93001095)(3231475)(944501520)(52105112)(10201501046)(3002001)(6041310)(201703131423095)(201702281528075)(20161123555045)(201703061421075)(201703061406153)(20161123558120)(20161123560045)(20161123562045)(20161123564045)(201708071742011)(7699051)(76991095); SRVR:HE1PR07MB3066; BCL:0; PCL:0; RULEID:; SRVR:HE1PR07MB3066;
x-forefront-prvs: 0912297777
x-forefront-antispam-report: SFV:NSPM; SFS:(10009020)(979002)(39860400002)(366004)(376002)(136003)(396003)(346002)(50854003)(189003)(199004)(26005)(5660300001)(86362001)(105586002)(478600001)(3846002)(102836004)(186003)(66066001)(6116002)(106356001)(476003)(81156014)(81166006)(8676002)(71190400001)(71200400001)(4744004)(55016002)(6246003)(4326008)(53936002)(256004)(25786009)(97736004)(8936002)(14444005)(110136005)(9686003)(229853002)(7696005)(33656002)(305945005)(486006)(6436002)(54906003)(551934003)(316002)(74316002)(7736002)(2906002)(68736007)(6506007)(99286004)(44832011)(14454004)(969003)(989001)(999001)(1009001)(1019001); DIR:OUT; SFP:1101; SCL:1; SRVR:HE1PR07MB3066; H:HE1PR07MB3161.eurprd07.prod.outlook.com; FPR:; SPF:None; LANG:en; PTR:InfoNoRecords; MX:1; A:1;
received-spf: None (protection.outlook.com: ericsson.com does not designate permitted sender hosts)
x-ms-exchange-senderadcheck: 1
x-microsoft-antispam-message-info: BO2Cgve4QGKFjGW/oHq6DjQz6WmAirMLDiVdoHtDAVBPUOUagIvsZve2UKnkQWLHqZOBhRKW5vLn2Tm5YOrmZYIjwOQbw+y2pnsymxeZLBq0MAqRJWb/y7V0fheWACV5ItfHZUxFWSI+9Eug8MJeZHSjZ1/CGEeQG3tkBsfSpTVGyumSE/18/6pSsDdNS7KgFjpJ2bfhS4O2GHHTEU3MXBZVvmLby3bKDDTySLgCwD3aenza2kp2SdOJf3CmTRpfR3b3JwmEJZ7NCUT4Lr4I/CbgKlB2wRSUBD9vxqgiZDALhKOffCCFoAOXvkjXCnmB
spamdiagnosticoutput: 1:99
spamdiagnosticmetadata: NSPM
Content-Type: text/plain; charset="utf-8"
Content-Transfer-Encoding: base64
MIME-Version: 1.0
X-MS-Exchange-CrossTenant-Network-Message-Id: 27b0aaba-ddd5-4aff-f050-08d676631f2d
X-MS-Exchange-CrossTenant-originalarrivaltime: 09 Jan 2019 18:49:01.4766 (UTC)
X-MS-Exchange-CrossTenant-fromentityheader: Hosted
X-MS-Exchange-CrossTenant-id: 92e84ceb-fbfd-47ab-be52-080c6b87953f
X-MS-Exchange-Transport-CrossTenantHeadersStamped: HE1PR07MB3066
X-OriginatorOrg: ericsson.com
X-Brightmail-Tracker: H4sIAAAAAAAAA02SbUhTURjHOzt321UcnN00H7VIpx/S0KWJrJIo+5B9MKwIIkZ2yYsuncru 0pQ+iNKLb7Q035alqVBZYqmliWEOwzTQrIaplPm2VCSjYVm6ldu16Nv///x/53mBQ2Pmttib 1qToOV0Km6yQuFKVJ9oygtmoCPWOmjlfVaetVqqaGS+TqHKs90WqitVrWFVkvY1VS8vNkn2S 6PHvNml0ff1PUbTx6TQVi0+6RsZzyZp0Tqfce9o18ffYCE5bKEXn80YTslF2McpHLjSQcKh+ b5XmI1eaIT0IxuabJIJZQnDnRT/6ZwZKzGLB1Img6uWs01DEgKHvYyF2NGNIsQjGrXKBmkAw +2VelI9oWkJUUGDf7mDcyR54lduHHQwmNgQW+6Tz8UaSDjOLjq4OKAPK228iQYdAiSHHWadI AMxODYscWkbUMGK65NSIbIIf/Q+cGhNPGJ2uFgnXEajvHMSC9oC5KbtY4FnoaviEHbsB8YWu R0cFZAu8qS5wngwkRworCzlSIQiGr6Wl631ioKjKLhWg1whqftWtDwsCe1stJegk+GAZFQvQ EIZJY9N6sBla8qokQmATg2F1WGxASuN/mxvXtsIkEJo61st+cL1gQmp0Hi2HvsppqgZRDciD 53hemxAWFsLpNGd4PjUlJIXTN6O1j9PdurK7HXV/3m9ChEYKN1m4MkLNiNl0PlNrQkBjhbss y2etJItnM7M4XWqc7lwyx5uQD00pPGWrjFzNkARWzyVxXBqn+5uKaBfvbHSk7Fbz2cOJpsG0 h8tal4TYyy1WpuBCZE9Mq9nmHuplLql73NHce6BIO8Q3MhtuKBuLNOTtsr8lyKX3ebK/tixw 57OlWfmVe4sVF49HFT4JvLo1t2vq4PLKlL4wz+AnTSozxVCVA3jXNnlAnEd5hdeptvC7777J LepjGVGHzG4hCopPZEODsI5n/wCc74sONAMAAA==
Archived-At: <https://mailarchive.ietf.org/arch/msg/sipcore/7xHp0FeWpdYTMjCKygfQbOiYc4Y>
Subject: Re: [sipcore] Adam Roach's Discuss on draft-ietf-sipcore-sip-push-21: (with DISCUSS and COMMENT) - the COMMENT issues
X-BeenThere: sipcore@ietf.org
X-Mailman-Version: 2.1.29
Precedence: list
List-Id: SIP Core Working Group <sipcore.ietf.org>
List-Unsubscribe: <https://www.ietf.org/mailman/options/sipcore>, <mailto:sipcore-request@ietf.org?subject=unsubscribe>
List-Archive: <https://mailarchive.ietf.org/arch/browse/sipcore/>
List-Post: <mailto:sipcore@ietf.org>
List-Help: <mailto:sipcore-request@ietf.org?subject=help>
List-Subscribe: <https://www.ietf.org/mailman/listinfo/sipcore>, <mailto:sipcore-request@ietf.org?subject=subscribe>
X-List-Received-Date: Wed, 09 Jan 2019 18:50:25 -0000

Hi,

In this reply I will address the COMMENT issues.

----------------------------------------------------------------------
COMMENT:
----------------------------------------------------------------------

>Figure 1:
>
> This diagram includes both a ladder diagram and an example REGISTER message.
> While both of these are useful at this point in the document, neither of them is an "Architecture," and they're really two different things. 
> I suggest breaking this into two Figures, entitled "Typical Information Flow" and "Example REGISTER Message" (or similar), respectively.

I can do that, but one of the WGLC/AD comments said that it should be clear that the Example REGISTER message shows an example of the REGISTER message in the flow. 

---------------------------------------------------------------------------

§4.1:

>>  As long as the UA wants to receive push notifications (requested by  
>> the proxy), the UA MUST include a pn-provider, pn-prid and a pn-param  
>> (if required for the specific PNS provider) SIP URI parameter in each  
>> binding-refresh REGISTER request.
>
> Please be clear that these parameters appear in the Contact URI.

I will clarify that.

---------------------------------------------------------------------------

§5.2:

>>  In order to request push notifications towards a SIP UA that will  
>> trigger the UA to send binding-refresh SIP REGISTER requests, the SIP  
>> proxy needs to have information about when a registration will  
>> expire.  The proxy needs to be able to retrieve the information from  
>> the registrar using some mechanism.  Such mechanisms are outside the  
>> scope of this document, but could be implemented e.g., using the  
>> SIPregistration event package mechanism [RFC3680].
>
> Nit: "SIP registration"

Will fix.

> This mechanism seems to be predicated on an architecture in which the proxy must be on the traffic path. Although it's problematic 
> from a "what proxies are expected to do" perspective, it seems like the proxy could glean this information from the 200 response to 
> the REGISTER request. (I mean, the proxy is already reading parameters out of the contact header field, so the behavior of acting on 
> registration information is already assumed). The proxy would, of course, need to run its own timers, but that seems to be a pretty 
> minor requirement, given everything else involved here.

One way to implement the "retrieve the information from the registrar" could of course be using own timers. But, I don't think we should specify such behavior.

Also, in some cases the proxy might be co-located with the "home proxy", or some other network node,  where the interface with the registrar already exists.

---------------------------------------------------------------------------

§5.3.1:

> This is a major comment, and one that has a sufficient impact on interop that I had a long debate with myself about whether it should be a DISCUSS. Please take it very seriously.
>
>  Otherwise, if the pn-provider SIP URI parameter identifies a type of  
> PNS that the proxy does not support, or if the REGISTER request does  
> not contain all additional information required for the specific type  
> of PNS, the proxy MUST either forward the request (e.g., if the proxy  
> knows that another proxy that will receive the REGISTER request  
> supports the type of PNS)...
>
> How would the proxy know this?

"Local configuration"

> Features like suppressing PNS behavior when a "sip.pns" feature capability is present in the REGISTER imply that the various nodes 
> in the network discover capabilities of their neighbors automatically (which is consistent with the way SIP does features), while this 
> provision seems to require provisioned knowledge. This is going to be operationally very confusing.
>
> At the very least, the document needs to call out how this "knowledge" is obtained. In the more general sense, since a client cannot 
> rely on the proxy supporting *any* kind of PNS, the use of 555 in the way specified here is at best an optimization -- and, since the configured 
> information can conflict with actual reality, it's an optimization that can actually break things unless extreme care is exercised. (e.g., if the proxy 
> is configured to "know" that the next proxy cannot provide push service, but this knowledge is wrong, then the network is unnecessarily broken.)
>
> My rather strong recommendation is to remove this code, and let the client rely on the lack of indication of support in the response indicate that the feature is not supported.

I would like to keep the code, because there are cases where one wants the register to be rejected (rather than accepted, but without indication of supported PNS) if the PNS is not supported.

Also, there are already deployments of 555, so I'd prefer to keep it, as it doesn't break anything.

Regarding a proxy knowing what other proxies support, I agree it could be clarified. We could even make it more clear that sending of 555 the default behavior. Something like:

"...the proxy SHOULD send a SIP 555 (Push Notification Service Not Supported)
response to the REGISTER request, unless the proxy knows (based on local configuration)
that another proxy that will receive the REGISTER request supports the type of PNS, 
in which case it MAY forward the request." 

I would even be ok to remove the text about the proxy knowing. Because, as I indicated in my reply to Paul, I don't think there will be multiple proxies in the path handling push (if there are, the REGISTER can be forwarded as an implementation feature).

---------------------------------------------------------------------------

§5.3.1:

>  o  if the proxy received a 'sip.pnsreg' media feature tag in the
>     REGISTER request, the proxy SHOULD include a 'sip.pnsreg' feature-
>     capability indicator with an indicator value bigger than 120 in
>     the response, unless the proxy always want to request push
>
> Nit: "...wants..."

Will fix.

---------------------------------------------------------------------------

§5.3.2:

>  If the contact of the REGISTER request does not match  the 
> Request-URI of the SIP request to be forwarded, or if the contact  was 
> not present in the REGISTER response, the proxy MUST reject the  SIP 
> request with a 404 (Not Found) response.
>
> This seems to be a very strong requirement ("MUST") when, e.g., many or most networks may want to return a 480 instead of a 
> 404. I think what you want to say is something like "...MUST reject the SIP request. Response codes of either
> 404 (Not Found) or 480 (Temporarily Unavailable) are RECOMMENDED, but other appropriate codes may be used as well."

I will modify as suggested.

---------------------------------------------------------------------------

§5.3.2:

>  The reason the proxy needs to wait for the REGISTER response before  
> forwarding the SIP request is to make sure that the REGISTER request  
> has been accepted by the registrar, and that the UA which initiated
>
> Nit: "...the UA that initiated..."

Will fix.

---------------------------------------------------------------------------

§5.3.2:

>  In case of non-2xx response to the REGISTER request, the proxy MUST  
> reject the SIP request with a 404 (Not Found) response.
>
>  If the push notification request fails (see PNS-specific  
> documentation for details), the proxy MUST reject the SIP request  
> with a 480 (Temporarily Unavailable) response.
>
>  If the proxy does not receive the REGISTER request from the UA within  
> a given time after the proxy has requested the push notification, the  
> proxy MUST reject the request with a 480 (Temporarily Unavailable)  
> response.  The time value is set based on local policy.
>
> As above, this seems way too restrictive in terms of mandating specific error codes. 
> It may well be the case that a network would want to treat these situations identically from 
> the perspective of the calling party.

I will do the same modification as earlier.

---------------------------------------------------------------------------

§5.3.2:

>  Otherwise the
>  proxy MUST reject the SIP request with a 480 (Temporarily
>  Unavailable) response.
>
> Same comment as above.

Same fix.

---------------------------------------------------------------------------

§6.1.1:

>  When the UA sends in initial request for a dialog, or a 2xx response
>
> Nit: "...sends an initial request..."

Will fix.

>  purr' SIP URI parameter in the Contact header of the request or
>
> Nit: "...Contact header field..."

Will fix.

>  NOTE: As the 'pn-purr' SIP URI parameter only applies to a give  
> dialog, the UA needs to include a 'pn-purr' parameter in the Contact
>
> Nit: "...given dialog..."

Will fix.

>  dialog, the UA needs to include a 'pn-purr' parameter in the Contact  
> header of the request or response for each dialog in which the UA is
>
> Nit: "...Contact header field..."

Will fix.

---------------------------------------------------------------------------

§6.1.1:

>  The UA MUST include a parameter value identical to the the  last 
> 'sip.pnspurr' feature-capability indicator that it received in a  
> REGISTER response.
>
> This is incredibly confusing, as the "sip.pnspurr" indicator has not been mentioned in the document so far. Please revise as something along the lines of:
>
>  The UA MUST include a parameter value identical to the the last  
> 'sip.pnspurr' feature-capability indicator (see Section 6.2.1) that it  
> received in a REGISTER response.
>
> Alternately, reverse the order of sections 6.1 and 6.2 so that the PURR concept is properly introduced before protocol procedures are defined for it.

I will take a look.

---------------------------------------------------------------------------


§6.1.1:

>  NOTE: As the 'pn-purr' SIP URI parameter only applies to a give  
> dialog, the UA needs to include a 'pn-purr' parameter in the Contact  
> header of the request or response for each dialog in which the UA is  
> willing to receive push notifications triggered by incoming mid-  
> dialog requests.
>
> Similar to the above, this is a very confusing introduction of the "pn-purr" URI parameter.

Same fix.

---------------------------------------------------------------------------

§6.2.2:

>  Contact header field with a PURR value that the proxy has generated  
> Section 6.2.2, the proxy MUST add a Record-Route header to the  
> request, to insert itself in the dialog route [RFC3261].
>
> This "Section 6.2.2" makes the sentence impossible to read. Is it intended to be in parentheses?

Correct. Will fix.

---------------------------------------------------------------------------

§6.2.3:

>  As described in Section 5.3.2, while waiting for the push  
> notification request to succeed, and the associated REGISTER request  
> to arrive from the SIP UA, the proxy needs to take into consideration  
> that the transaction associated with the NOTIFY request will  
> eventually time out at the sender of the request (UAC), and the  
> sender will consider the transaction a failure.
>
> I think this needs some discussion about the impact of the error codes selected by the proxy on the dialog and its usages. For example:
>
> * If the proxy sends a 404 to prevent a transaction timeout, it will destroy the
>  dialog and all of its usages
>
> * If the proxy sends a 480 to prevent a transaction timeout, it will destroy the
>  usage, but not other usages in the dialog (if any)
>
> * If the proxy sends a 504 to prevent a transaction timeout, it will keep the
>  dialog and the usage alive, and allow the client to re-try at a later time.
>  Simply allowing the transaction to time out will have the same effect, albeit
>  with more message retransmissions.
>
> Pointing to RFC 5057 might be useful here.

Perhaps saying something like:

"When the proxy rejects a mid-dialog request, it needs to select a response code that
only impacts the transaction associated with the request. See [RFC50579] for more
information."
 
---------------------------------------------------------------------------

§8.7:

>    Parameter value characters that are not part of pvalue needs to be
>    escaped, as defined in RFC 3261.
>
> Nit: "...need to be escaped..."

Will fix.

---------------------------------------------------------------------------

§9:

>  When a new value is registered to the PNS Sub-registry, a reference  
> to a specification which describes the usage of the PNS associated
>
> Nit: "...specification that describes..."

Will fix.

---------------------------------------------------------------------------

§§10-12:

> Nit: It seems like these should all be subsections of section 9.

The idea was that the PNS registrations are in separate main sections, as they could even be in a separate document.

---------------------------------------------------------------------------

§10:

>  The Topic consists of the Bundle ID, which uniquelly identifies an  
> appliciation, and a service value that identifies a service
>
>Nit: "uniquely"
> Nit: "application"

Will fix.

---------------------------------------------------------------------------

§10:

>  Example: pn-param = DEF123GHIJ.com.yourcompany.yourexampleapp.voip
>
> Please use an RFC 2026 domain for this example; e.g.:
>
>  Example: pn-param = DEF123GHIJ.com.example.yourexampleapp.voip

Will fix as suggested.

---------------------------------------------------------------------------

§11:

>  [RFC8292] defines a mechanism which allows a proxy to identity itself
>
> Nit: "...mechanism that allows..."

Will fix.

Regards,

Christer