Re: [regext] Fwd: New Version Notification for draft-gould-regext-rdap-redacted-00.txt

"Gould, James" <jgould@verisign.com> Fri, 16 July 2021 10:56 UTC

Return-Path: <jgould@verisign.com>
X-Original-To: regext@ietfa.amsl.com
Delivered-To: regext@ietfa.amsl.com
Received: from localhost (localhost [127.0.0.1]) by ietfa.amsl.com (Postfix) with ESMTP id 4BD093A3217 for <regext@ietfa.amsl.com>; Fri, 16 Jul 2021 03:56:34 -0700 (PDT)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -1.988
X-Spam-Level:
X-Spam-Status: No, score=-1.988 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, HTTPS_HTTP_MISMATCH=0.1, SPF_HELO_NONE=0.001, SPF_PASS=-0.001, T_FILL_THIS_FORM_SHORT=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=verisign.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 qoWDdoCS-HKW for <regext@ietfa.amsl.com>; Fri, 16 Jul 2021 03:56:26 -0700 (PDT)
Received: from mail3.verisign.com (mail3.verisign.com [72.13.63.32]) (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 7D89C3A3215 for <regext@ietf.org>; Fri, 16 Jul 2021 03:56:26 -0700 (PDT)
DKIM-Signature: v=1; a=rsa-sha256; c=simple/simple; d=verisign.com; l=82684; q=dns/txt; s=VRSN; t=1626432986; h=from:to:cc:subject:date:message-id:mime-version; bh=8wl1PvcmXOw9sxV7W/de+I2ujBkUp5zVZSCNaPohINc=; b=QtSQH7FvUDb8D6Vhmx8oonKX1rmSiSdSEq7+hBFceYC4SXrds2D5vPY2 Sr4lzYFaL5NpXbMwBVYMpg5pzlcZx+yxXVx5B0dc+RlEm3VjuD+A7DyEO 6ns+Fus3+IHyp15qSMmXa6AZDCroIK7Qc9q8QQU7xovwUQkUC3+jUqlCi jYkqbrgwVy9X+UVGUSaV8+I3cLbpOB9aUeRxvtmHEokimCpw+HItzGdSQ hFSPfll9X5cjAkqX/86+R9zhL3OY+DSShnesr4ft+AmXQHLqvPr3UytUq Z/lh9PM2J59Qt17x5F85HoBGqs2aYN4IV+QRJVLagFfwySktYK27KFtQF w==;
IronPort-SDR: ZJ4Z8yVJIVA+874M121XMg1/uZ6cNrqJ9Jbkk1XFRR5aSREqwovYo+1IPaBXTLkJNulnBLA5TK BeSlcrIsWsqDrAi2OylPrLJmDdwiwIAC37jPyfJTeG3hmHhT+SdVUJ5dzeehxFqiAYUIBTnZzU y3z/1LGi0gSCkkclyUhaXTeqoX1YAKbPkfNuXO8mpWZYWjPZBbo/V3N0vVkDCPm7K13efknv3b ia+4liS91O72Y38VuAaegH9XUox6zvgodNmqHAQmyjPtjtKi/4PhMRkfiDbU+2gLW1s6wYowBq NEM=
IronPort-HdrOrdr: A9a23:HL6EpKtluBcdhzcjJMPP+SAZ7skDq9V00zEX/kB9WHVpm6uj5q WTdZUgpH3JYVkqOE3I9ervBEDiexzhHPdOiOEs1NyZLWrbUQWTTb1K3M/NzzrtACXi+uMY/r cIScRDIey1KVRhl8717E2bH8ZI+rO62ZHtoevF1X9iQUVRdqd6425CZzqzCEFsWwVcP5Y/Ga ed4sYvnVGdRUg=
X-IronPort-AV: E=Sophos;i="5.84,244,1620691200"; d="png'150?scan'150,208,217,150";a="8784873"
Received: from BRN1WNEX01.vcorp.ad.vrsn.com (10.173.153.48) by BRN1WNEX02.vcorp.ad.vrsn.com (10.173.153.49) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2242.12; Fri, 16 Jul 2021 06:56:22 -0400
Received: from BRN1WNEX01.vcorp.ad.vrsn.com ([fe80::a89b:32d6:b967:337d]) by BRN1WNEX01.vcorp.ad.vrsn.com ([fe80::a89b:32d6:b967:337d%4]) with mapi id 15.01.2242.012; Fri, 16 Jul 2021 06:56:22 -0400
From: "Gould, James" <jgould@verisign.com>
To: "mario.loffredo@iit.cnr.it" <mario.loffredo@iit.cnr.it>
CC: "regext@ietf.org" <regext@ietf.org>
Thread-Topic: Re: [regext] Fwd: New Version Notification for draft-gould-regext-rdap-redacted-00.txt
Thread-Index: AQHXejE2V1aCWdSsXEOb/hr72StW3A==
Date: Fri, 16 Jul 2021 10:56:22 +0000
Message-ID: <827AF158-675F-437A-A0F4-9B632892BA16@verisign.com>
Accept-Language: en-US
Content-Language: en-US
X-MS-Has-Attach: yes
X-MS-TNEF-Correlator:
user-agent: Microsoft-MacOutlook/16.47.21031401
x-originating-ip: [10.170.148.18]
Content-Type: multipart/related; boundary="_005_827AF158675F437AA0F49B632892BA16verisigncom_"; type="multipart/alternative"
MIME-Version: 1.0
Archived-At: <https://mailarchive.ietf.org/arch/msg/regext/NzmRpilXGTOv2hMnmdPgnPHueL0>
Subject: Re: [regext] Fwd: New Version Notification for draft-gould-regext-rdap-redacted-00.txt
X-BeenThere: regext@ietf.org
X-Mailman-Version: 2.1.29
Precedence: list
List-Id: Registration Protocols Extensions <regext.ietf.org>
List-Unsubscribe: <https://www.ietf.org/mailman/options/regext>, <mailto:regext-request@ietf.org?subject=unsubscribe>
List-Archive: <https://mailarchive.ietf.org/arch/browse/regext/>
List-Post: <mailto:regext@ietf.org>
List-Help: <mailto:regext-request@ietf.org?subject=help>
List-Subscribe: <https://www.ietf.org/mailman/listinfo/regext>, <mailto:regext-request@ietf.org?subject=subscribe>
X-List-Received-Date: Fri, 16 Jul 2021 10:56:34 -0000

Mario,

I provide responses embedded below with a JG2 prefix.

--

JG

[cid:image001.png@01D77A0F.AF56ABF0]

James Gould
Fellow Engineer
jgould@Verisign.com<applewebdata://13890C55-AAE8-4BF3-A6CE-B4BA42740803/jgould@Verisign.com>

703-948-3271
12061 Bluemont Way
Reston, VA 20190

Verisign.com<http://verisigninc.com/>

From: Mario Loffredo <mario.loffredo@iit.cnr.it>
Date: Friday, July 16, 2021 at 3:56 AM
To: James Gould <jgould@verisign.com>
Cc: "regext@ietf.org" <regext@ietf.org>
Subject: [EXTERNAL] Re: [regext] Fwd: New Version Notification for draft-gould-regext-rdap-redacted-00.txt


Hi James,

please find my replies below.
Il 15/07/2021 19:40, Gould, James ha scritto:
Mario,

My responses are embedded below.

--

JG

[cid:image002.png@01D77A0F.AF56ABF0]

James Gould
Fellow Engineer
jgould@Verisign.com<applewebdata://13890C55-AAE8-4BF3-A6CE-B4BA42740803/jgould@Verisign.com>

703-948-3271
12061 Bluemont Way
Reston, VA 20190

Verisign.com<http://secure-web.cisco.com/11V8HZGNXCwVH0Y4yV8VW9bm0e2IM1d3xYq7E4pvU3UfBDV58X77rXsyRZ5JFKrA1h8frY7uqsM5w89qNqBurK5D8MvVPE_pTo0iU4-g5xzkuWaCxDxtdSTwfy-X5V24fuk0PH_KzlO4-6aaEQ48IYhEy66JWrn2teYjUJEjZ7eLa7UNVb-atyVyyRc3PkW4fKFTFc5LjrZ_donH57MCm9prsuKtA5T5IjvCcQYkB4qdbFn-YTuBiIwbakh3jlEsZfBoVLQFntkZpPMOMVEEbVA/http%3A%2F%2Fverisigninc.com%2F>

From: Mario Loffredo <mario.loffredo@iit.cnr.it><mailto:mario.loffredo@iit.cnr.it>
Date: Thursday, July 15, 2021 at 5:31 AM
To: James Gould <jgould@verisign.com><mailto:jgould@verisign.com>
Cc: "regext@ietf.org"<mailto:regext@ietf.org> <regext@ietf.org><mailto:regext@ietf.org>
Subject: [EXTERNAL] Fwd: [regext] New Version Notification for draft-gould-regext-rdap-redacted-00.txt


Hi James,

please find my comments below prefixed by [ML].


-------- Messaggio Inoltrato --------
Oggetto:

Re: [regext] New Version Notification for draft-gould-regext-rdap-redacted-00.txt

Data:

Wed, 14 Jul 2021 14:06:47 +0000

Mittente:

Gould, James <jgould=40verisign.com@dmarc.ietf.org><mailto:jgould=40verisign.com@dmarc.ietf.org>

A:

mario.loffredo@iit.cnr.it<mailto:mario.loffredo@iit.cnr.it> <mario.loffredo@iit.cnr.it><mailto:mario.loffredo@iit.cnr.it>, marc.blanchet@viagenie.ca<mailto:marc.blanchet@viagenie.ca> <marc.blanchet@viagenie.ca><mailto:marc.blanchet@viagenie.ca>

CC:

regext@ietf.org<mailto:regext@ietf.org> <regext@ietf.org><mailto:regext@ietf.org>



Mario,

Thank you for your review and feedback. I provide replies to your feedback embedded below.

--

 JG







James Gould

Fellow Engineer

jgould@Verisign.com<mailto:jgould@Verisign.com> <applewebdata://13890C55-AAE8-4BF3-A6CE-B4BA42740803/jgould@Verisign.com><mailto:applewebdata://13890C55-AAE8-4BF3-A6CE-B4BA42740803/jgould@Verisign.com>



703-948-3271

12061 Bluemont Way

Reston, VA 20190



Verisign.com <http://verisigninc.com/><http://secure-web.cisco.com/1AwKlvS6mjX9gmbKA1esca1gF6gxkHG4Hoq0dLgqeXboqam0LCBCpr8v4YeIi-PL4RHebdkRdmVtjkdl7oEzPIEggNkSHF2MjHGUBV30M8XyMTqLJBjKRIU5jN3-fYZRQliPDXzrDOAhkH4i0BW_HjO9j1PRk_MfBQWzDucjLLtB3U_2AeOEIEBGBQzU6x-Z_zCDwlsvcPJ6eCukHyjxYhuMecKPAfiDTlb04zEM-Zkj10uizRdyIj69BBkvs3XUz/http%3A%2F%2Fverisigninc.com%2F>



On 7/14/21, 3:58 AM, "Mario Loffredo" <mario.loffredo@iit.cnr.it><mailto:mario.loffredo@iit.cnr.it> wrote:



    Hi all,



    Il 12/07/2021 13:26, Gould, James ha scritto:

    > Marc,

    >

    > Thank you for the quick review and feedback.  Below are responses to your early comments:

    >

    >      - would be good to include specific text about jscontact, so when we switch to it, this document does not need rev.

    >

    > Agreed, that was thought about while drafting, but we initially left it out.  I'm confident that the extension will work with JSContact, but some text would help for clarity.



    I guess it will work even better than with jCard! JSContact is more     object-oriented than jCard and the json path expressions are simpler     since maps are mostly used to represent collections (e.g.



    "$.entities[?(@.roles[0]=='registrant')].jscard.phones.voice.phone"<mailto:$.entities[?(@.roles[0]=='registrant')].jscard.phones.voice.phone>     instead of     "$.entities[?(@.roles[0]=='registrant')].vcardArray[1][?(@[1].type=='voice')]"<mailto:$.entities[?(@.roles[0]=='registrant')].vcardArray[1][?(@[1].type=='voice')]>)



JG - Yes, JSContact is much easier to express via JSONPath, since there is no dependency on the use of JSON arrays.



    Here in the following a first feedback from my side about the document:



    - if, as it seems, the "name" property is unique in the "redacted"     array, I would prefer to define "redacted" as a map where the "name"     value is the map key. In theory, every RDAP information can be redacted     but, in practice, the number of RDAP properties usually redacted is     limited. If the possible "name" values were standardized, il would be     easier for RDAP clients implementers to check and pick a property inside     the collection of redacted properties.



JG - Agreed, it would be ideal for the "name" property to unique and easy to key off of by the client.  The JSONPath expression provides the technical reference, while the "name" property can represent the logical reference.  We didn't want to go down the IANA registry route in draft-gould-regext-rdap-redacted, but if we add a RDAP JSON Values type for the redaction reason, we could also add an RDAP JSON Values type of the redaction name.  The question would be whether all "name" property values would need to be registered in the RDAP JSON Values registry.  If that is not the case, then we would need change the "name" member to be a JSON object with the "description" and "type" members used for registered and unregistered values in RFC 9083.



    - another possible pre-defined value for "pathLang" might be     "jsonpointer" as an alternative syntax to indentify a value within a     JSON doc.



JG - I don't believe JSON Pointer will work for RDAP based on the need for the conditional expressions (e.g., "$.entities[?(@.roles[0]=='registrant')]"<mailto:$.entities[?(@.roles[0]=='registrant')]>).  Do you see a way that JSON Pointer could be used for RDAP?  I would only add it if it will work for RDAP.



[ML] - I think it depends on whether the "jsonpath" is meant as a way to identify a generic RDAP response field or a specific field in the current RDAP response. Surely, unlike JSONPointer, JSONPath allows to select a field nested in an array regardless of the position. Therefore, it is able to represent multiple cases through the same respresentations. However, an RDAP profile might use conventions (e.g. the registrant is always the first entity in the array of entities associated to a domain) making the use of JSONPath filters redundant. In additon, there are cases where JSONPointer can be used straightforwardly: for example, a entity lookup response using JSContact :-) . Anyway, I agree with you that JSONPath fits better than JSONPointer.
JG – Our initial intention was to use JSONPointer, but it was clear early on that it would not meet the needs for RDAP responses.  My recommendation is to stick with JSONPath and if someone sees and can show that JSONPointer is a viable expression language for RDAP redaction, then we can make it a pre-defined option.
[ML] - Agreed.




- it seems to me that the document assumes that the role used to     identify the redacted entity within the array of entities should be in     the first position of "roles" array. Maybe such assumption should be     added somewhere in the document.

JG - That is the convention, but if there are multiple roles, the server could choose to use a different role value reference.  There is the option for a contact to serve multiple roles ("registrant", " administrative", "technical", "billing"), but it's unclear whether that is actually used.  If the multi-role contact is redacted by role, then it will add complexity from a redaction perspective, but it can be done.  In the end, I believe this will come down to a implementation consideration item.

[ML] - Generally, an entity is redacted without regard to the role but based on other conditions: whether the entity represents an individual or not, whether the entity have expressed the explicit consent for publishing or not. At least for ccTLDs, it is normal that an entity is both the registrant and the amministrative contact linked to a domain.



JG – Redaction based on whether the contact is an individual or provides consent does make sense, but the ICANN draft policy differentiates the redacted fields based on role.  For ccTLDs if a contact is both the registrant and administrative contact for a domain, does the RDAP response include a single entity with two roles instead of including two entities each with a single role?  If redaction is dependent on role, it would be simpler for the server and the client to return two entities each with a single role and with a different set of redacted fields.

[ML] - I can speak on behalf of .it. Our RDAP server returns only one entity with two roles. After all, the protocol has been designed to consider that and it seems to me an efficient soultion. In my opinion, it would be more logical and correct that, if the redacted properties were based on roles and an entity has more roles, the redacted properties of the entity should be the union of the redacted properties per each role. Otherwise, there might be a risk to result in a privacy violation.

Please correct me if I misunderstood the content of section 2.7.4 of RDAP response profile for gTLDs and I'm giving a wrong example:

if the Organization information MUST be omitted for administrative but not for registrant entities, if an entity is both registrant and administrative, the Organization information MUST not be returned anyway.

At least when the same database object is used for different roles, it's easy to implement that.



JG2 – Thanks, that is good to know and does make sense.  The assumption in the draft is the use of role-based redaction, but I believe that the multiple role approach will work as well.  We’ll consider the multiple role approach as well to ensure that both are effectively handled.  Let us know if you see any issues.



 - there is a typo in the json path expression of  "Registrant Street"

JG - What typo do you see in the JSON Path expression of "Registrant Street".  I tested the "Registrant Street" JSONPath expression "$.entities[?(@.roles[0]=='registrant')].vcardArray[1][?(@[0]=='adr')][3][:3]"<mailto:$.entities[?(@.roles[0]=='registrant')].vcardArray[1][?(@[0]=='adr')][3][:3]> against the unredacted RDAP response, with the result being:

[

  "",

  "Suite 1235",

  "4321 Rue Somewhere"

]

[ML] - Understood. You considered both extended address and post office box as street components. I have always considered the street information made up only by the third ADR component beacuse RFC6350 recommends not to use the first two components to increase interoperability (see below). That being said, I admit that your JSONPath is able to cover any street representation.

       Unlike the use in RFC8977, a JSONPath expression is allowed to select an array of values in order to communicate that all the values are redacted.



       "Experience with vCard 3 has shown that the first two components

      (post office box and extended address) are plagued with many

      interoperability issues.  To ensure maximal interoperability,

      their values SHOULD be empty." (RFC6350 section 6.3.1)



JG – I was unsure whether the street would logically match just the third ADR component of the ADR-value or the first three ADR components.  In the end, I viewed the first three ADR components as being related to the street address (post office box, the extended address – apartment or suite number, street address), but if the street address is only the third ADR component, the example in the draft can be updated.  RFC 9083 does include a reference to the second ADR component with “Suite 1234”, which is what was also used in draft-gould-regext-rdap-redacted.  If the intent was to redact the street address, should “Suite 1234” not be also redacted even if RFC 6350 recommends for it to be empty?
 [ML] For sure, it should. As I wrote in my previous reply, it is better to consider also unrecommended cases so the JSONPath selecting the first three ADR components as street information is preferrable.

JG2 – Great, we’ll keep the street redaction example covering the first three ADR components.







[ML] - Another feedback about implementing this extension in search responses. Provided that this is not the .it case where searches are allowed only to users legitimated to see the full contact information, I wonder how RDAP servers permiiting searches more or less publicly might implement it.

       Returning the list of all the redacted JSON values included in the response seems to me inefficient. On the other hand, relying on the JSONPath capability to select a result set, it would be wrong to use a single generic JSONPath expression

      (e.g. use "$.domainSearchResults[*].entities[?(@.roles[0]=='registrant')].vcardArray[1][?(@[0]=='email')]"<mailto:$.domainSearchResults[*].entities[?(@.roles[0]=='registrant')].vcardArray[1][?(@[0]=='email')]> to communicate that the emails of all domains' registrants are redacted) because, in general, the same property in different results could be either redacted or unredacted.

       Do you think the document should address this topic and how?



JG – The extension is targeted for lookups over searches, since searches would be too complex.  We can add something to the draft to specify that the extension applies to RDAP lookup responses and not search responses.  Does that make sense to you?
[ML] - Yes, it does.

JG2 – The draft will be updated for this.





    Best,

    Mario

>
> - I really would like to have an IANA registry for the « reason » property. Because this would be potentially displayed to the user, and to avoid having all variations of the same reason in different words. A registry of reserved words would also facilitate translation in multiple languages.
>
> We had a desire to stay away from needing to setup an IANA registry for redaction. I view the reason property as not a good candidate for an IANA registry, since it's meant to be a human readable informational value that includes normative language not to be used as a client processing dependency. This is a good discussion item.
>
> Thanks,
>
-- Dr. Mario Loffredo
Technological Unit “Digital Innovation”
Institute of Informatics and Telematics (IIT)
National Research Council (CNR)
via G. Moruzzi 1, I-56124 PISA, Italy
Phone: +39.0503153497
Web: http://secure-web.cisco.com/1F-PFooJyrWLg51lyW_I49Zvwy3moYXof6OwGqaZON9_0DcwS-s4HC3KttHlW4-GTU-3j7eTkRexCFzAuK9qR5TFk1Va8rwSoh15OdINxFIShnToELNciLpmFWsMNghBtzhTGEfz81tSFv-8jpnVkIF56EAcX0m47l_U0xLdYxjWxvkBykLE6XGyZkw-IHz_8LfdHOV6Ja-dDltW2jsD7CdSMhuy3B4g2ihEL5ekGFFizXUM5jM8rQrdTICQAhGxBqTHe6CwiveYGEUunTsQJxA/http%3A%2F%2Fwww.iit.cnr.it%2Fmario.loffredo


_______________________________________________
regext mailing list
regext@ietf.org<mailto:regext@ietf.org>
https://www.ietf.org/mailman/listinfo/regext<https://secure-web.cisco.com/1KSounj1EI0mAuJ5HeObfyLj0PmjQaZ4MvzHpbjQfIsuIUCHOG5lUy9Wi1aoZ2pV114_EkwQv8n5wAGpR5rCOc-aLnkCzWfKDA7jmK1dQuhJIR2PclRd1U7I1LmlUUveLwM9A37iFrBM79cRZfv427hTQRpUNnVB2ZC_DQbFy48OKWRBcJixbykLLbL0AYqxHLzVw36kDRsfVwe-fy80BWMiqXYYjd12-yze4FgAGumlG6YGATEuEFqK7eFyytXPV/https%3A%2F%2Fwww.ietf.org%2Fmailman%2Flistinfo%2Fregext>



_______________________________________________

regext mailing list

regext@ietf.org<mailto:regext@ietf.org>

https://www.ietf.org/mailman/listinfo/regext<https://secure-web.cisco.com/1v3VpW3nP3bJHUEecbk43YkaiYaUg17A_BLVyy_pbCzbPbOUayVl5DQyeXMu_rK2UF1ygz66cmPq6TzkGALoFP1W1vFQUNhRXzgTI2BGdIUPTFLlWs2yyLezPNDKpsWNNuzarfxUsLVZZ1yrBd6lzm0ZT1h2MpPIOUuazVO-uzjCoLHXEfQme8NWoySoUKewSzPSD4XBZG4s2ftljTCN-8RDCatJU0VPNAGMQRq_LGpICWnQmgvTuFbemq3PFxOXV3IuIJZDm9ZRTPzxJHQnEGw/https%3A%2F%2Fwww.ietf.org%2Fmailman%2Flistinfo%2Fregext>

--

Dr. Mario Loffredo

Technological Unit “Digital Innovation”

Institute of Informatics and Telematics (IIT)

National Research Council (CNR)

via G. Moruzzi 1, I-56124 PISA, Italy

Phone: +39.0503153497

Web: http://www.iit.cnr.it/mario.loffredo<http://secure-web.cisco.com/1er9Ghy6yNoDflZC7OBzrPTNYfSJY3ctni1dtwVLT54-b0ymXYyVfCWbeYx_HfuzCw_t_WFYfjtdhwU3Kgc2Z3vrhVr8_AcfD2f_XIXMnCH6VQUwLBhQfz5C3vAt1480iB2kjVXuZEoabuii3cxi2T_T0zGA4qlXFONYeZ6zpDNXdGIly9hXHLNkLcgt5JBTpq2aae4QNOXs69ECUT3VA7Gf304VGqJSWfzfBAiO0hdwDnbVl76p1Z4wRPwMIiSdI-bNuk955eOeqE8pLHb7mvw/http%3A%2F%2Fwww.iit.cnr.it%2Fmario.loffredo>