Dear Patrick,
Thanks for your careful review and comments. Please find my feedbacks below. 
Some of the text will be updated in the next version.

Regards,


Linlin Zhou
 
From: Patrick Mevzek
Date: 2017-12-27 14:02
To: regext
Subject: [regext] My review of draft-ietf-regext-org and 
draft-ietf-regext-org-ext
Hello authors,
 
Please find my review of your two drafts.
I do not think they are ready for WG last call yet.
 
=================================================================================
draft-ietf-regext-org
=================================================================================
 
* Abstract: "provisioning and management of organization object"
I would says objects in plural is more logical.

[Linlin] Yes, it will be modified to "provisioning and management of 
organization objects".

* 1. Introduction
Same remark about the plural.

[Linlin] Change to "such as registrars, resellers, DNS service operators, or 
privacy proxyies".
 
"There are many domain entities" : maybe drop domain here?
Like: There are many entities 

[Linlin] Ok.
 
Also I have mixed feelings on "These kind of entities have not been formally
   defined in EPP"
This is not true for registrar, for example, it is clearly defined in RFC3375.
 
So you will need to rephrase your paragraph.

[Linlin] How aboult change the text to "These kind of entities have not been 
formally defined as an object in EPP".
 
* 3) I do not understand "can be viewed and modified by the sponsoring client 
or the server."
Why do you specify "or the server." ?
The fact that the registry can view the data seem quite obvious but what
are you trying to infer by speaking about server modifications?
I think it would be far simpler to just remove "or the server."

"This section describes each attribute type in detail."
You can remove "type" I think.
 
[Linlin]  This section tries to be consistent with RFC5733. You can find "An 
EPP contact object has attributes and associated values that can be viewed and 
modified by the sponsoring client or the server. This section describes each 
attribute type in detail." in section 2 of RFC5733.

* 3.1
"Organization identifiers are character strings with a specific
   minimum length, a specified maximum length, and a specified format.
   Organization identifiers use the "clIDType" client identifier syntax
   described in [RFC5730]."
 
The clIDType in RFC5730 specifies a minimum and maximum length but no format,
just that it is a token. So the sentence is kind of wrong.

[Linlin] This part of words also tries to be consistent with RFC5731, RFC5732 
and RFC5733. I guess that token is a formatted string that removes the spaces, 
tabs , line breaks.
 
* 3.2
This does not seem clear enough to me.
I have to wait for further examples down below to better understand this
But did not found enough examples or further explanations,
so all of this is confusing to me.

* 3.2.1
"Its corresponding element is <org:type> with an
   "roleStatus" attribute."
=> a instead of an I think

[Linlin] Yes. 

In fact the whole of 3.2 / 3.2.1 / 3.2.2 feels very complicated and not clear 
to me.

[Linlin] I'll try to add an example like this,

S: <org:role> 
S: <org:type roleStatus="ok">registrar</org:type> 
S: <org:roleid>1362</org:roleid> 
S: </org:role>

* 3.3 what does this section has to do with the rest of the document?
[Linlin] We intend to explain that an organization would have one or more 
contacts. So this section specifies the contact identifier formats.

* 3.4
"terminated: The organization has been terminated MUST NOT be
      linked."
=> and is missing before MUST NOT?

[Linlin]  I think this should be "The organization which has been terminated 
MUST NOT be linked."
 
* 3.6 "the parent identifier is
   not defined for the top level reseller, namely the registrar of the
   registry."
I am not absolutely sure that registrars would be happy to be depicted as 
just resellers of the registry, and also I am not sure what this sentence
adds to the protocol.

[Linlin] We are trying to say that registrar, N-tier reseller and reseller 
customer are three types of organization in reseller business model. Only 
N-tier reseller and reseller cutomer could have a parent ID.
 
* also in section 3 somewhere you should speak about timestamps
since you have crDate, etc.
See ยง2.4.  Dates and Times for example in RFC5731.
[Linlin] Ok.
 
* 4.1
"EPP provides two commands" 
It is instead 3 if you add the <transfer> case, so you should rephrase that
paragraph.
[Linlin] I'll reconsider the text and udpate in the next version.
 
* 4.1.2
"A <org:status> element"
Only one status available here?
If multiple allowed, you have to fix this sentence and the associated XML 
schema.
[Linlin] I think multiple statuses are allowed. A maxOccurs attribute will be 
added in the "status" element.

"   Example <info> response for "Example Registrar Inc." registrar object
   with registrar identifier "1362":"
Maybe instead to be more inline with the rest of the document:
   Example <info> response for "Example Registrar Inc." organization object
   with organization identifier "1362":
 
And then below the example has:
<org:id>registrar1362</org:id>
So the text above should probably more be:
with organization identifier "registrar1362"
 
 
Same kind of changes for the later examples which follow a similar introducing
sentence.

[Linlin] Yes, that's more clear to readers.
 
* 4.2.
Why don't you count the renew command as one transform command?
(even if you speak about it further down)
[Linlin] In section 4.2.3, "Renewal semantics do not apply to organization 
objects, so there is no mapping defined for the EPP <renew> command.". So there 
are no <transfer> or <renew> commands included in the document.
 
* 4.2.1
A <org:status> element
Same remark/question as above in 4.1.2
 
"A <org:crDate> element that contains the date and time of
      organization-object creation."
=> organization object instead of organization-object

[Linlin] Fine. 
 
* 4.2.5
I have the same issue as above related to your handling of status.
You again seem to imply it can appear once, and hence be handled through <chg>
However rereading 3.4 it seems totally legit for me for example to have
clientLinkProhibited
clientUpdateProhibited
clientDeleteProhibited
if the sponsoring registrar so wish.
 
So you either need to specify somewhere that only one status value can exist
at any time (and then you will have multiple other problems) or you will
need to update all your documents as reviewed earlier to allow multiple
status values at the same time, and then also change it to be handled through
add/rem and not with chg.
 
[Linlin] Yes, same here. I'll change the xml schema in this part.

You also have a "bullet" problem as your document renders as:
o
 
      *  A <org:name> 
 
So, something missing after the o, or an indentation problem.

[Linlin] o is needless here. I'll remove it.
 
Your example is not clear, with:
<org:status>ok</org:status>
since in 3.4 you say that the ok value is put or removed by the server
(implying it is not handled by the client).

 
* 7.3
"The entity object instance represents a third-party who
      could help to register a domain without exposing their private
      information."
 
This is not clear, what does "their" reference in this sentence?
 
[Linlin] Change to "The entity object instance represents a third-party who 
could help to register a domain without exposing the registrants' private 
information."
 
* 8 Implementation status
 
Net::DRI implements a previous version of your drafts. If interested I could 
try to update it so that you can add it there. Please let me know what you 
think and if you do reference it please use the software name instead of my own 
personal name.

[Linlin] Thank you. That would be so good if you can update your 
implementation. I'll update the information in the document. So please let me 
know if you have completed.
 
=================================================================================
draft-ietf-regext-org-ext
=================================================================================
 
* The abstract seem wrong: "this
   extended mapping is applied to provide additional features required
   for the provisioning of organizations."
This document deals with "linking" specific organization IDs to other objects,
not provisioning it. It seems a sentence copied from the other document but
it has no sense here. On the contrary you should more specifically link to the
other document to clearly explain how they interoperate.
[Linlin] I think it is better to remove the second sentence.
 
* A organization mapping object defined in
=> An organization

[Linlin] Yes.
 
* 4.1.2 "However, additional elements are
   defined for the <info> response."
=> you should specify if this is for domain, host or contact since just in the 
previous
sentence you took care to specify that you do not add anything to the domain 
contact and host
info commands.

[Linlin] Ok.
 
* 4.1.2 "if the object has data associated with this
   extension and based on its service policy."
Do you mean *registry* service policy? The its seem to refer to the object.

[Linlin] Or change to "the server policy"?
 
* 4.1.2 "A <orgext:id> element that contains"
This is not consistent where the example below where you have 2 elements.
So the text should say something like "One or more <orgext:id> element..."
The related schema is also wrong since you have minOccurs=0
It is doubly inconsistent since having no id at all makes an empty extension
so no use; and on the contrary you want to have more than one.
So please make text, example and schema consistent from each other.
 
Are you sure in fact that the schema is correct? Does the role attribute
really apply to the id element, I am not sure this is what I read from the 
schema,
there it seems to apply to the outermost enclosing element.
You should have a look in RFC5730 for example on how domain:contact are defined
in a domain:create or domain:info

[Linlin] To be more explicit, I'll add some text like "One or more <orgext:id> 
element is allowed..." and remove minOccurs=0.
 
* 4.2.1 You should specify if you speak about domain, contact or host objects.
You have the same problem I think than in 4.1.2. The schema (maybe wrong, see 
same
remark above) seems to allow only one id element, is this really what you want?

[Lilin] Please find the feedback above.
 
* 4.2.4 I was not sure to understand what you say in:
"the handling of the assigned organization is dependent
   on the organization roles and server policy." can you elaborate?
Also you speak about "an assigned organization" so you do not consider more 
than one?

[Linlin] In the previous reseller draft, we wrote like this "but after a 
successful transfer of an object with an assigned reseller, the server SHOULD 
clear the assigned reseller value." We consider that after a transfer, the 
object may not be linkde with this reseller. So we change the text a little in 
org draft. Whether to link with a organization, you should take org role and 
server policy into consideration. 
 
* 4.2.5 I am not sure to understand the difference between add+rem and chg, 
except that
it seems you allow only one id per type, hence the chg case. If that is so,
please explicitely say so, even before in the document. If not, please explain 
the difference
between doing an add or rem and doing a chg.
In light of what I reiterated above, please specify what is happening if there
are already more than one id attached to the object, and even more if there are 
more
than one per role.
[Linlin] From my understanding, you can have multiple ids with different roles 
and it is more reansonable to have one id per role. What do you think?
 
The schema specification for update has the same problem as above regarding
the cardinality of the id element and the position of the role attribute. Please
double check that. Explain what minOccurs=0 could do as this could result into
an empty <add> or empty <rem> or empty <chg>
 
* 6 Internationalization Considerations
 
I do not understand this section. How does this document add anything related
to this from what is already in core EPP? You seem to have copied what is there
which does not add value.
 
This sentence has a problem also:
"As an extension of the EPP domain name mapping, the elements, element
   content described in this document MUST inherit..."

[Linlin] It should be "the elements and element content".  This section is 
copied from org draft, we will discuss if it is possible to remove it.
 
* 8 Implementation status
 
Net::DRI implements a previous version of your drafts. If interested I could 
try to update it so that you can add it there. Please let me know what you 
think and if you do reference it please use the software name instead of my own 
personal name.

[Linlin] That would be great. Thank you again.
 
Other generic points:
- please specify what is happening if the client uses a value for the role 
attribute that is not supported by server policy, how should it react?
- same if client uses an organization ID during create/update that does not 
exist at registry side
- in the schema the role value is just an XML token whereas in your text you 
refer to section 7.3 of the other document for the list of values. I expect the 
XML schema to also reflect that. You should probably define it in the schema of 
the "org" element and have the XML schema in the "orgext" document refer to the 
one in the "org" document. Like EPP has "epp" and "eppcom" schema, and "eppcom" 
is refered from various domain/host/contact XML schema.
- "Organization Extension", and associated "orgext" short name do not seem 
specific enough
for me. Maybe you could try to find something more precise? In fact same 
problem for the other document.
- maybe explain if organization ID are global inside the registry or per 
registrar; so what happens if registrar X creates an orgnization and registrar 
Y uses it for domains it manages.
[Linlin] Thanks for the generic comments. We will have some discussion and give 
some more clear explanation in the document.
 
===================================================================
comments related to both
===================================================================
 
I am more than a little fuzy about your "role" uses.
When you create an organization you specify a role,
and then when you create/update a domain to add an organization you again 
specifcy a role.
Are they the same or different? Why do they need to be repeated?
 
This whole idea of "role" will need to be seriously improved in both documents.
 
 [Linlin] Actually the two role have the same value referring to section 7.3 in 
draft-ietf-regext-org. I think we need add some words in the org-ext draft to 
explain that you should go to org draft to find the role values. 
S: <org:role> 
S: <org:type roleStatus="ok">registrar</org:type> 
S: <org:roleid>1362</org:roleid> 
S: </org:role>

 S: <orgext:id role="reseller">myreseller</orgext:id>
-- 
  Patrick Mevzek
 
_______________________________________________
regext mailing list
regext@ietf.org
https://www.ietf.org/mailman/listinfo/regext
_______________________________________________
regext mailing list
regext@ietf.org
https://www.ietf.org/mailman/listinfo/regext

Reply via email to