Re: [dnssd] WGLC for draft-ietf-dnssd-srp / review

Esko Dijk <esko.dijk@iotconsultancy.nl> Thu, 19 August 2021 11:04 UTC

Return-Path: <esko.dijk@iotconsultancy.nl>
X-Original-To: dnssd@ietfa.amsl.com
Delivered-To: dnssd@ietfa.amsl.com
Received: from localhost (localhost [127.0.0.1]) by ietfa.amsl.com (Postfix) with ESMTP id B27863A0A09 for <dnssd@ietfa.amsl.com>; Thu, 19 Aug 2021 04:04:56 -0700 (PDT)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -2.1
X-Spam-Level:
X-Spam-Status: No, score=-2.1 tagged_above=-999 required=5 tests=[BAYES_00=-1.9, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, DKIM_VALID_EF=-0.1, HTML_MESSAGE=0.001, RCVD_IN_MSPIKE_H2=-0.001, SPF_PASS=-0.001, URIBL_BLOCKED=0.001] autolearn=ham autolearn_force=no
Authentication-Results: ietfa.amsl.com (amavisd-new); dkim=pass (1024-bit key) header.d=iotconsultancy.nl
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 fBCCiujgSaO1 for <dnssd@ietfa.amsl.com>; Thu, 19 Aug 2021 04:04:50 -0700 (PDT)
Received: from EUR01-VE1-obe.outbound.protection.outlook.com (mail-eopbgr140139.outbound.protection.outlook.com [40.107.14.139]) (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 B57A83A0A03 for <dnssd@ietf.org>; Thu, 19 Aug 2021 04:04:48 -0700 (PDT)
ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=RINWWSDHROTbr2qmHqRarx8qYiNSaMDHDmYQPGEpVc2bqBD/Kg44ui5eGUcgS7QI+riic1nD4P5TBO1S+xpmn+w3n5Lm3bphZt8hVZsCVqq93AI/UsLqaPt8ladAVe/Hg9SWACbhtWsLs0CKClA1WXSrfgkqLkVRQNOAO76TilidxUwff+CluXKTxCusboukW2Pj2bwcI7OS9ZCjxV68Fat3y4frouU/PZFUVO8YtTQVEewlQlGsGPYZupVs0r9FGpAAl94+9ZV9KivPS53mYi+UIyntmfmgwbPObGIvCPWufQ9Dcc2lDo7xKrmSCycasADBygv7jZ0YhNsUKz7S6Q==
ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=zzftw/UL23QHa1LGV3ywkn0ohPj+UHD60olGSqhKD6U=; b=lMdHba5m5FPJ3N1bJRvcmVL7jE7xQfKqZtVdOFxUTXN/ojU5qJDTITphBAq3pqwOH87MzscnvtIfxBOH9bhYsGp/mSkSsDF2R+rvZ+xTfJjqL4GNrogBuBdMnaYiQve2uxqEr0JBlq2BBKiLbkAMAfql/tB32VO2XR5eeusiVrORBMDetPRd/n+3JqvG4XJRsAgjqMfW2j+PoE9gm6FJxl+VeLSH+4fbDNuGvkVECKQW5oOzunk9kpWak/oLB5bkYIR8RtIoJ18DQA5ZAI5k+m8TIQmLBx/1KRR6Kx8d0am36uPknFxF1SEGrTFYnE2ELxLenlM2JhAUcM4M8VX2Ew==
ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=iotconsultancy.nl; dmarc=pass action=none header.from=iotconsultancy.nl; dkim=pass header.d=iotconsultancy.nl; arc=none
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=iotconsultancy.nl; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=zzftw/UL23QHa1LGV3ywkn0ohPj+UHD60olGSqhKD6U=; b=FT1D/HEoQ65itu9cAtDE0r3bk7G8lsE65n/ZwK7ROmzFZJ9jHpaB+VeOEQpsZsMkN5JguoJFav8SS8Y4Icq03v/lWbNWHIyW8YkIHUiPTCVbf9BjlgrDm3aLL4Tm8fq/mN/YtwuORssuvLnVS/JhbZChPuV17Wt0HAwps6VL/T0=
Received: from AM8P190MB0979.EURP190.PROD.OUTLOOK.COM (2603:10a6:20b:1d3::8) by AM9P190MB1075.EURP190.PROD.OUTLOOK.COM (2603:10a6:20b:265::21) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.4415.16; Thu, 19 Aug 2021 11:04:45 +0000
Received: from AM8P190MB0979.EURP190.PROD.OUTLOOK.COM ([fe80::44fa:5ced:a434:f7e8]) by AM8P190MB0979.EURP190.PROD.OUTLOOK.COM ([fe80::44fa:5ced:a434:f7e8%9]) with mapi id 15.20.4436.019; Thu, 19 Aug 2021 11:04:45 +0000
From: Esko Dijk <esko.dijk@iotconsultancy.nl>
To: DNSSD <dnssd@ietf.org>
CC: Ted Lemon <mellon@fugue.com>
Thread-Topic: [dnssd] WGLC for draft-ietf-dnssd-srp / review
Thread-Index: AdeU1hR5DMbuavatScqtDGs87zCR8g==
Date: Thu, 19 Aug 2021 11:04:45 +0000
Message-ID: <AM8P190MB0979F1E05706056DC1B950E5FDC09@AM8P190MB0979.EURP190.PROD.OUTLOOK.COM>
Accept-Language: en-US
Content-Language: en-US
X-MS-Has-Attach:
X-MS-TNEF-Correlator:
authentication-results: ietf.org; dkim=none (message not signed) header.d=none; ietf.org; dmarc=none action=none header.from=iotconsultancy.nl;
x-ms-publictraffictype: Email
x-ms-office365-filtering-correlation-id: e0823b1a-4eed-49e7-6df5-08d963012754
x-ms-traffictypediagnostic: AM9P190MB1075:
x-microsoft-antispam-prvs: <AM9P190MB107557A7D152399DF47CC2A1FDC09@AM9P190MB1075.EURP190.PROD.OUTLOOK.COM>
x-ms-oob-tlc-oobclassifiers: OLM:10000;
x-ms-exchange-senderadcheck: 1
x-ms-exchange-antispam-relay: 0
x-microsoft-antispam: BCL:0;
x-microsoft-antispam-message-info: jIPKrMb9MZeavX2yPX3xQMburV17WUW2poZTuswSMpxqjygZsQCasexHcmKwSayVlDJ/CHg2VXIwBoYNrOMaT3Zzumv4UVqPC+HecAv9rD85KL3NQpXaFahB/YXQBZd6pL9KduZtEaVwcxDSspcEV0Y/brNIbApGGvD97UEiluUMduLkx6kWL5Jm+MRKh+BrsPn9Se+BXtv21zVp7SqHj4jtE7RkoGOpzDUryKueX4HwpjMnDNZmjldzH5IXPisRu84C8NwFZgkHHYZerpyZZcX/yzYiGOP7suiTp5BeyeboyDYnMlJswmoqxgPKr6W4LHV9j3DBueFgrN5zBwxxbzOWfi3Zaf6wm66cxxtU6ISeSsPK6D6GzeaJEogkfeG5K3hSeG1wlfQ7JuoOKM5m+DnGk43qo07tWUz+1K9u3w+RY82xnbKsOH9u4Q/HlZJ45VsrgYYkP41RlsdnqtXCHTeIoN/MiIlfQdR2IsZbKbhMl/eY16bCKDQbzrY3lBFvGE1lAt7J2ns1f2SI/ghPokH7x+zMgweYErrJAY8nxyU3AASHEjJMlctarP9UgIohMAFs3WKxOIz8Yr15vtSCAwnpVOq6DwTcCgHLoyzMyQ3YR3Y5vy4s1U91eemzYohDnxgl33G244HqcXm4XDwnNCuKcul4M408wgvRGqo783gCK4G8WoNoJsXrfu3q6WBKYEwP1lI0OCei6SL9eWvmmg==
x-forefront-antispam-report: CIP:255.255.255.255; CTRY:; LANG:en; SCL:1; SRV:; IPV:NLI; SFV:NSPM; H:AM8P190MB0979.EURP190.PROD.OUTLOOK.COM; PTR:; CAT:NONE; SFS:(376002)(346002)(136003)(366004)(39830400003)(396003)(66946007)(66476007)(4001150100001)(9686003)(76116006)(52536014)(33656002)(66556008)(55016002)(66446008)(9326002)(8936002)(186003)(8676002)(86362001)(83380400001)(6916009)(64756008)(38100700002)(122000001)(6506007)(38070700005)(53546011)(7696005)(2906002)(30864003)(71200400001)(316002)(44832011)(5660300002)(4326008)(478600001); DIR:OUT; SFP:1102;
x-ms-exchange-antispam-messagedata-chunkcount: 1
x-ms-exchange-antispam-messagedata-0: F318/dBpYNaCPL+zZtXg4CP1ZIhp+SbYSEfiF2hzHq21mFCE8xLI4oqMgB7e747E59eru/Me1fBR0+JwzGWhTDaAnl9mIEq3Ll7Pw4u50JHmRTiGIb6X2tkd5uOwigRpwAbGv5oYtmYx2Z8daggwwjpc4Oz7lpGlo11EY1hcEo5qK/gbMbkI4dMFljkQSIUmZ8zY21BQN+ex/jL1WOIQgrNNbc7HmytR8rbVsKv7rZsRlp+z9XR01lY5sWfWOACGtwoZd/LqIuRXFgB07sqsJEynFgGfjmgh7ZB5lg/zeWmhZTXshAsvRTHsANRm9EHbAt8Bmn3T/A1ishiDWvk85OhaROqt5aYqlXSw/XaPPGqJr/myDzYH4IKtqB9T8isUmp9TrfdvW14ipiU/5XLZ06th+Qu/QvXF1TR5cJkBt/OufeO7Cb0ptkgwnRyze3U4p2kPO+1DWAhTxSpbIDCMcGE+kvU4C/Bj743D0Fn2lzp8WJZUbr8tCCdUeDjb6dy8BGiV1uUTolX7cFgcZAU80+yLm4t9MAL/glKdu0kyeuHrVgiqvp74qrvZvM/g/yNAWyfAa1iJ3sIAZA0BMiJZsVoWdVyerOO6++7sRuFWlytGzIsCvP72MrIoVgEF7fbIg2w4eQBcGlqO1exmVxBcTtEoXXwLvathRPTstMGL1Icfr6JhP85nEZyMLqBHmH3fanD0jiIEYbexy4Xr1/hhXzNUevW5Vi7oiFdgqAzkcTW/Nlgigj1PU1I8VN2qDFHa1mx7ZbZI6+DfsOqEHk3I7v21PG0iwRoVm3ltuFb663MQgWSoa4Cn14Ewa+dr/fp3vC9uqxN/dtfvftF24p/C035s3hCrVbiiMOh1z4kxkmWe33+CBJtrUprLh5akAhxia8hfaTH8aRkYtS89zj4OsySw5pj4gOrLPfLXtqFqY8g32noYyw/W6UhGlQGdyvDPxOGO+Uog9NlLnGinoKSJMRwOAnsOTLHt6kN4OlBEHFmhMCzS/dl/HaTDUh0AjXpC0tJuruTSw+dreYh2u9QKlK+Pa47Q9GMfymrigBduP4LGzNx4NE0k3vZqJNfmytIAtDi5wg/+W9oQDmNIiJ1ghmR+j7jlRHNK66k2JfmL5PZ4S6mae5ibDNjULgfhSfgve69+LUkOrbnIr3M6OoMRIR9pX7/6j/nOE7g1njJbzq9HgDAYjsokNwOJqnkkvgxt+3c7oA2hZoBh4OLBqOUboiYS+8BPATW7caW5k0HSpT7HLjIMVHHneb2daWjxXGlUQprFumPljhqB3cR8LeHJ23p2/ZWsenjza0KCjqIE9bLsQSY5D+3RmNP5aUVdkUipKHdemV1D25WOptMlfE6AO0LuYsxSjv5VF7BdYk1tW7I=
x-ms-exchange-transport-forked: True
Content-Type: multipart/alternative; boundary="_000_AM8P190MB0979F1E05706056DC1B950E5FDC09AM8P190MB0979EURP_"
MIME-Version: 1.0
X-OriginatorOrg: iotconsultancy.nl
X-MS-Exchange-CrossTenant-AuthAs: Internal
X-MS-Exchange-CrossTenant-AuthSource: AM8P190MB0979.EURP190.PROD.OUTLOOK.COM
X-MS-Exchange-CrossTenant-Network-Message-Id: e0823b1a-4eed-49e7-6df5-08d963012754
X-MS-Exchange-CrossTenant-originalarrivaltime: 19 Aug 2021 11:04:45.4761 (UTC)
X-MS-Exchange-CrossTenant-fromentityheader: Hosted
X-MS-Exchange-CrossTenant-id: 58bbf628-15d2-46bc-820b-863b6774d44b
X-MS-Exchange-CrossTenant-mailboxtype: HOSTED
X-MS-Exchange-CrossTenant-userprincipalname: C7mE22waEuxvXOVwMVJ9zd5ri+8xBTRZcbLr94plNcUPe0ATOIiBqxpmDUF8rARZfvhcDv6W36FhE3xSfoT6TR1xKDEM+FIH9VxErqVIT58=
X-MS-Exchange-Transport-CrossTenantHeadersStamped: AM9P190MB1075
Archived-At: <https://mailarchive.ietf.org/arch/msg/dnssd/M_gQBXGSnG-Jt3IEw8pj8_ishRw>
Subject: Re: [dnssd] WGLC for draft-ietf-dnssd-srp / review
X-BeenThere: dnssd@ietf.org
X-Mailman-Version: 2.1.29
Precedence: list
List-Id: "Discussion of extensions to DNS-based service discovery for routed networks." <dnssd.ietf.org>
List-Unsubscribe: <https://www.ietf.org/mailman/options/dnssd>, <mailto:dnssd-request@ietf.org?subject=unsubscribe>
List-Archive: <https://mailarchive.ietf.org/arch/browse/dnssd/>
List-Post: <mailto:dnssd@ietf.org>
List-Help: <mailto:dnssd-request@ietf.org?subject=help>
List-Subscribe: <https://www.ietf.org/mailman/listinfo/dnssd>, <mailto:dnssd-request@ietf.org?subject=subscribe>
X-List-Received-Date: Thu, 19 Aug 2021 11:04:57 -0000

Hello,

Here my response to the WGLC for draft-ietf-dnssd-srp accompanied by review comments for the draft.
In summary, I believe the document apart from Section 5 is ready to be published after the review comments are addressed: as these comments are mostly on editorial issues, text location and resolving potential unclarities. The SRP protocol overall looks useful, solid and well-described.

The specific part of Section 5 on Sleep Proxy has had less work it seems, as a few of my original -04 review comments are still open and I don’t see how this function could lead to interoperable implementations. To resolve this, possible actions are:

  1.  Move the Sleep Proxy definition/details out of this draft, into a separate one. This could progress SRP in the best way.
  2.  Add more details on the Sleep Proxy, to a fully interoperable implementation becomes possible.
  3.  Keep current Section 5 text (only minor additions/changes/fixes), and add a sentence saying that more details can be defined in a future document (e.g. after implementations have been tested – clients vs servers of different parties)
Related question: are any implementations using Sleep Proxy?

Best regards
Esko

Detailed review comments list:

*** Abstract
802.11 (Wi-Fi) and 802.15.4 (IoT) networks
-> add 'IEEE' so "IEEE 802.11 (Wi-Fi) and 802.15.4 (IoT) networks"
As an editorial comment, in general the abstract should not contain more details than the main text.
So typically one would see back these terms again in an introduction.

*** 2.2.1
"RFC 6763 describes the details of what each of these types of updates contains"
-> not everything contained in these updates is explained in RFC 6763. Specifically, the "Key RR" is not in that RFC. Another RFC ref can be added here that defines Key RR as definitive source of information.

*** 2.2.3.1
"SRP clients are allowed to send updates to the generic domain "default.service.arpa""
-> In section 2.1.* it looks as if only constrained hosts can do this. Can full-featured hosts also do this? If not we can say "Constrained-Node SRP clients are ..."   If yes, then I would expect section 2.1.1 to mention this use for the full-featured hosts.

*** 2.2.5.1
duplicated sentence "This key pair MUST be unique to the device."

*** 2.2.5.4
Does the statement here imply that this draft formally updates RFC 2782?
(Question to the WG. Maybe not: since the update only applies in SRP context not for SRV records in general. But maybe yes: RFC 2782 says "Unless and until permitted by future standards action, name compression is not to be used for this field." which would make it proper to refer to the SRP draft as such future action.)

*** 2.2.5.5.2
"update that deletes the PTR record whose target is the service instance name."
-> This looks like a single PTR record. Prior section 2.2.1 mentions that the service instance name may be referred to by multiple PTR records.  So in case of multiple, it is not required to have multiple instructions to delete these multiple PTR records?
(I.e. there's no risk of lingering PTR records that would point to a service instance that's deleted?)

*** 2.3 title
[Nit] -> may give the impression that all SRP server behavior is specified in here.
Somewhere in 2.3 / 2.3.* it could mention that more normative behavior is specified in other sections too, like Sections 3 and 4.

*** 2.3.1
Grammar to be fixed: "Each instruction consists some combination"

*** 2.3.1.1
"if the Service Discovery update is an "Add to an RRSet" instruction, the Service Description Instruction does not match if"
-> for me unclear, see separate mail thread on this section.

*** 2.3.1.2
[Nit] Bullet:
"*  Service Descriptions Instructions do not modify any other RRs."
-> best rephrased to
 "*  no RR updates other than the ones defined above."

That would fit better in the style of the previous bullet points in the list.

*** 2.3.1.3
"If a link-scope address or IPv4 autoconfiguration address is provided by the SRP client, the
  SRP server MUST treat this as if no address records were received; that is, the Host Description is not valid."
-> This seems rather strict. If the client provides 1 routable IP address and 1 link-local address, couldn't the SRP server just ignore the link-local address?
This might have some benefits for future/backwards compatibility , in case of future cases where link-local addresses are to be used for some reason. (If only for debug/diagnostic purposes)
I agree that if the client sends only link-local address(es) then the SRP server treats it as if no address records were received.

*** 2.3.2
[Nit] "must have that Host Description instruction as the target of its SRV record"
-> could rephrase to "MUST have the hostname of that Host Description Instruction as the target of its SRV record"  to be more precise.
Similar comments can be given for the remainder of the section text that talks about instructions pointing to instructions.  (It's more like names in instructions being equal to names that are used in other instructions)
(not sure if MUST or must is desired here by the way)

"For example, a DNS update that contains an RRset
   Add to a Service Name and an RRset Add to a Service Instance Name,
   where the Service Name does not reference the Service Instance Name,
   is not a valid SRP update message"
-> 'RRset Add' refers probably to the "Add To An RRset" semantics of RFC 2136? If so it would be good to use that exact same naming "Add To An RRset" including the quotes here.
With present text I'm wondering if I missed something in the DNS specs that's called "RRset Add".

*** 2.3.3
"If any existing KEY record corresponding to a
   KEY record in the SRP Update does not match the KEY same record in
   the SRP Update "
-> grammar issue. 'match the KEY same record'    And a bit confusing: can a KEY record in an update correspond to a stored KEY record but not match at the same time?
  Perhaps the 'name' concept should be introduced here to clarify. (Presumably the server will check if an existing Service Instance Name or existing Hostname is stored and look up the associated KEY for that.)

"KEY record updates omitted from Service Description update are
   processed as if they had been explicitly present: every Service
   Description that is updated MUST, after the update, have a KEY RR,
   and it must be the same KEY RR that is present in the Host
   Description to which the Service Description refers."
-> Can we replace here 'Service Description update' by 'Service Description Instruction' ?
E.g.
"KEY record updates omitted from Service Description Instructions are
   processed as if they had been explicitly present: every Service
   Description that is updated through a Service Description Instruction MUST, after the update, have a KEY RR,
   and it must be the same KEY RR that is present in the Host
   Description Instruction to which the Service Description Instruction refers."

"Otherwise, the server validates the SRP Update using SIG(0) on the
   public key in the KEY record of the Host Description update."
-> what about:
"Otherwise, the server validates the SRP Update using SIG(0) against the
   public key in the KEY record of the Host Description Instruction."

(Using 'Instruction' and 'validates X against Y' instead of 'validations X on Y' )

*** 3
"SRP update servers MUST check"
->"SRP servers MUST check"

*** 4.1
[Nit] " MUST be removed at the same time-it is never valid for a service"
-> " MUST be removed at the same time -- it is never valid for a service " or
-> " MUST be removed at the same time: it is never valid for a service "

3rd paragraph mentions that a SRP is by default configured with a 2 hour Lease limit and 14-day KEY retaining time limit; and then it says that constrained devices may negotiate longer leases. This looks incorrect, as leases beyond configured upper limits won't be given by the server.
Probably something else is meant here with 'negotiate'? For example if one configures 'default values' for Lease and Key-Lease in the server, the serve may extend to these default values if the client asks for something shorter. If the client asks for something longer than the 'default values', the server grants the longer values up to a hard limit that is also configured in the server.

*** 5 Sleep Proxy
The introduction text should clarify whether Sleep Proxy support for an SRP server is OPTIONAL or MANDATORY.
Also to make more clear that for clients the use of this function is optional/OPTIONAL. (The last paragraph says so for constrained hosts, but nothing for the full-featured hosts.)

In relation to above, the same questions from my review of -04 of 2020-10-13 still apply:
- How would a service’s host know that the server is capable to do this? If it doesn't know then it cannot trust the mechanism to work and go to sleep.
- Or, is there a way for the SRP server to reject an update with EDNS(0) OWNER option such that the service’s host knows not to use it again?

[Nit] "Another use of SRP is for devices that sleep to reduce power consumption"
-> ideally it should mention somewhere that the device that sleeps is an SRP client. Otherwise the statement is a bit too generic. E.g.
"Another use of SRP is for SRP client devices that sleep to reduce power consumption, while being able to offer registered service(s) without interruption."

"the device includes an EDNS(0) OWNER Option [I-D.cheshire-edns0-owner-option]"
-> the reference here is Informational; how can this be? To implement the sleep proxy function it is normative to include the option.

"When the DNS server receives a TCP SYN or UDP packet addressed to"
-> "When the Sleep Proxy receives a TCP SYN or UDP packet addressed to"
(see also below comment)

"the Sleep Proxy must be on the same link"
-> the term "Sleep Proxy" is not introduced. In the prior text when it says "should set up a proxy" the name could be formally introduced e.g. "should set up a Sleep Proxy" or "should set up a proxy, called the Sleep Proxy, "

Overall, I miss some details about what the Sleep Proxy does once it receives a TCP SYN or UDP packet and it has woken up the sleepy device. Does it then stop the ARP/ND proxying for the sleepy device right away? And when would it again resume proxying?
What does the proxy do with the receive TCP SYN or UDP packet, discard or forward to the woken sleepy device? (After how much waiting time?)

*** 6.1
"Service Discovery Protocol servers"
-> is this term defined? Should we say SRP servers here?

"a promise made by the registration protocol"
-> "a promise made by the service registration protocol"

"replacing all or part of the service registration information with information provided by an SRP client"
-> the "SRP client" mentioned here I think should be "DNS client". Because the case mentioned looked like an authenticated (non-SRP) DNS client making DNS updates to records that were added by an SRP client.

*** 7 "Privacy Considerations"
This text mentions the requirements for TLS. Perhaps the TLS bits are better placed in Section 6, and Section 7 if needed can refer back to that. To me TLS seems one of the key ingredients to secure the protocol so I'd expect to read something / most-things about this in Section 6.   (Maybe I'm wrong here in case TLS can't provide the authentication - since in some deployments the client may have no trust anchor of the domain installed a priori, so it can't authenticate the SRP server even when TLS is used.)

*** 9.2
"Availability of DNS Service Discovery Service Registration Protocol
   Service for a given domain is advertised using the
   "_dnssd-srp._tcp.<domain>."  SRV record gives the target host and
   port where DNSSD Service Registration Service is provided for the
   named domain."

-> seems like a grammar issue here. Was this meant as a single sentence, or as 2 sentences separated by a dot before the "SRV record" text?
E.g. I could interpret as "using the X SRV record which gives the Y" or as "using the X name. The SRV record gives the Y".
Similar point for 9.3.





From: David Schinazi <dschinazi.ietf@gmail.com>
Sent: Monday, August 16, 2021 20:09
To: Esko Dijk <esko.dijk@iotconsultancy.nl>
Cc: DNSSD <dnssd@ietf.org>
Subject: Re: [dnssd] WGLC for draft-ietf-dnssd-srp

Hi Esko,

That's reasonable, we can wait a few more days for you to review.

David

On Sun, Aug 15, 2021 at 1:37 PM Esko Dijk <esko.dijk@iotconsultancy.nl<mailto:esko.dijk@iotconsultancy.nl>> wrote:
Hello David,

Due to holiday I missed this last call. Having reviewed an earlier version I would like to check if the issues are solved now; and can answer the question by Tuesday or Wednesday if that’s ok. (Instead of today)

Best regards
Esko

From: dnssd <dnssd-bounces@ietf.org<mailto:dnssd-bounces@ietf.org>> On Behalf Of David Schinazi
Sent: Wednesday, July 28, 2021 23:57
To: DNSSD <dnssd@ietf.org<mailto:dnssd@ietf.org>>
Subject: [dnssd] WGLC for draft-ietf-dnssd-srp

Hi DNSSD enthusiasts,

This email starts an official Working Group Last Call for draft-ietf-dnssd-srp. This call asks whether we believe the document is ready for publication. As such we are asking two questions:

1) if you believe this document is not ready to publish, please speak up now

2) if you have read the document and think it is ready, please say so as well

For this call to succeed, we'll need statements of explicit support from people who have read the draft. Please send statements in either direction as responses to this email. This call will be open until 2021-08-15 23:59 UTC.

Thanks,
David