- From: Hoekstra, Rinke (ELS-AMS) <r.hoekstra@elsevier.com>
- Date: Mon, 10 Oct 2022 07:03:39 +0000
- To: Gregg Kellogg <gregg@greggkellogg.net>
- CC: "public-json-ld@w3.org" <public-json-ld@w3.org>
- Message-ID: <CO1PR08MB6514BAF33322FB029D85FC32E3209@CO1PR08MB6514.namprd08.prod.outlook.com>
Hi Gregg, Thank you very much for your answer. I agree with you that JSON-LD processing is already quite complex, but had hoped that there would be a bit of wiggle room. The expansion against @base or @vocab is one of the aspects that I see our developers struggle with, while the nesting of @type is not seen as being "creative". Ah well, there are trade-offs everywhere. Best, Rinke -- Rinke Hoekstra Lead Architect – Knowledge Industry Director of Elsevier’s Discovery Lab ELSEVIER - Amsterdam r.hoekstra@elsevier.com<mailto:r.hoekstra@elsevier.com> Emails can arrive at all hours, but at Elsevier we respect your personal time. Feel free to respond to this email during your normal working hours. From: Gregg Kellogg <gregg@greggkellogg.net> Date: Thursday, 6 October 2022 at 22:22 To: Hoekstra, Rinke (ELS-AMS) <r.hoekstra@elsevier.com> Cc: public-json-ld@w3.org <public-json-ld@w3.org> Subject: Re: Why is node embedding not allowed for @type values (in the rdf:type - sense) *** External email: use caution *** On Oct 6, 2022, at 1:44 AM, Hoekstra, Rinke (ELS-AMS) <r.hoekstra@elsevier.com<mailto:r.hoekstra@elsevier.com>> wrote: Hi All, I stumbled upon a restriction on the allowed values for the @type keyword in a node object when specifying the rdf:type for a resource in JSON-LD. I would expect [4] to be equivalent to [5], but where [4] is allowed, [5] is syntactically incorrect. (NB: the Python rdflib library does not complain; but jsonld.js and pyLD do) It looks like embedding [1] (node objects as property values) is not allowed in this case, even though this is not explicitly mentioned in the section on embedding.. This is also not made clear in the section on specifying the type [2] (it just gives examples of using an IRI string as value, or an array of such strings, or a term defined in the active context). Both sections are non-normative (which may explain things), and the restriction is only made clear in the JSON-LD grammar [3] for node objects: If the node object<https://nam11.safelinks.protection.outlook.com/?url=https%3A%2F%2Fwww.w3.org%2FTR%2Fjson-ld11%2F%23dfn-node-object&data=05%7C01%7Cr.hoekstra%40elsevier.com%7C886239854ee54e0eaf8608daa7d84ccd%7C9274ee3f94254109a27f9fb15c10675d%7C0%7C0%7C638006845476700224%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C1000%7C%7C%7C&sdata=tbk2Nv91RHey2KBqLWEpPQYOHV%2BEfkEGsVAKaZQMRfI%3D&reserved=0> contains the @type key, its value MUST be either an IRI reference<https://nam11.safelinks.protection.outlook.com/?url=https%3A%2F%2Ftools.ietf.org%2Fhtml%2Frfc3987%23section-1.3&data=05%7C01%7Cr.hoekstra%40elsevier.com%7C886239854ee54e0eaf8608daa7d84ccd%7C9274ee3f94254109a27f9fb15c10675d%7C0%7C0%7C638006845476856446%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C1000%7C%7C%7C&sdata=1YUM8Nvst4wY10dlUN7L7A4g2N0vZzmm22XzHDTCBHU%3D&reserved=0>, a compact IRI<https://nam11.safelinks.protection.outlook.com/?url=https%3A%2F%2Fwww.w3.org%2FTR%2Fjson-ld11%2F%23dfn-compact-iri&data=05%7C01%7Cr.hoekstra%40elsevier.com%7C886239854ee54e0eaf8608daa7d84ccd%7C9274ee3f94254109a27f9fb15c10675d%7C0%7C0%7C638006845476856446%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C1000%7C%7C%7C&sdata=MldoxeB5z%2Bv0nksr7Kt8tQPcmfX0pOfJB4JaKWKv248%3D&reserved=0> (including blank node identifiers<https://nam11.safelinks.protection.outlook.com/?url=https%3A%2F%2Fwww.w3.org%2FTR%2Frdf11-concepts%2F%23dfn-blank-node-identifier&data=05%7C01%7Cr.hoekstra%40elsevier.com%7C886239854ee54e0eaf8608daa7d84ccd%7C9274ee3f94254109a27f9fb15c10675d%7C0%7C0%7C638006845476856446%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C1000%7C%7C%7C&sdata=uCxK4hvJfDmD%2BzOiUYn6OPZdETsAXktsNUh935nHj3o%3D&reserved=0>), a term<https://nam11.safelinks.protection.outlook.com/?url=https%3A%2F%2Fwww.w3.org%2FTR%2Fjson-ld11%2F%23dfn-term&data=05%7C01%7Cr.hoekstra%40elsevier.com%7C886239854ee54e0eaf8608daa7d84ccd%7C9274ee3f94254109a27f9fb15c10675d%7C0%7C0%7C638006845476856446%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C1000%7C%7C%7C&sdata=9GOLhXwPUsxmyPyyxzItu8b8DgsaGnbdKdFSCvB7pJ4%3D&reserved=0> defined in the active context<https://nam11.safelinks.protection.outlook.com/?url=https%3A%2F%2Fwww.w3.org%2FTR%2Fjson-ld11%2F%23dfn-active-context&data=05%7C01%7Cr.hoekstra%40elsevier.com%7C886239854ee54e0eaf8608daa7d84ccd%7C9274ee3f94254109a27f9fb15c10675d%7C0%7C0%7C638006845476856446%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C1000%7C%7C%7C&sdata=%2Fe88PKeboqo8%2Fb2Hhdge8RKgkOWMmL5j7VFHhg%2Bbfdc%3D&reserved=0> expanding into an IRI<https://nam11.safelinks.protection.outlook.com/?url=https%3A%2F%2Ftools.ietf.org%2Fhtml%2Frfc3987%23section-2&data=05%7C01%7Cr.hoekstra%40elsevier.com%7C886239854ee54e0eaf8608daa7d84ccd%7C9274ee3f94254109a27f9fb15c10675d%7C0%7C0%7C638006845476856446%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C1000%7C%7C%7C&sdata=bhqZOnnIphwP7d9D242mGlT9xOAcGr7FEiJ6WUqJISg%3D&reserved=0>, or an array<https://nam11.safelinks.protection.outlook.com/?url=https%3A%2F%2Finfra.spec.whatwg.org%2F%23list&data=05%7C01%7Cr.hoekstra%40elsevier.com%7C886239854ee54e0eaf8608daa7d84ccd%7C9274ee3f94254109a27f9fb15c10675d%7C0%7C0%7C638006845476856446%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C1000%7C%7C%7C&sdata=BwSZG7fbqc%2B5s1jXL1nNyCsu9x63s5uaOHNcakdAXxw%3D&reserved=0> of any of these. See § 3.5 Specifying the Type<https://nam11.safelinks.protection.outlook.com/?url=https%3A%2F%2Fwww.w3.org%2FTR%2Fjson-ld11%2F%23specifying-the-type&data=05%7C01%7Cr.hoekstra%40elsevier.com%7C886239854ee54e0eaf8608daa7d84ccd%7C9274ee3f94254109a27f9fb15c10675d%7C0%7C0%7C638006845476856446%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C1000%7C%7C%7C&sdata=7whl61PYkP0%2Bxi8eQFAZs5Cv2DLQQ503ADNBE%2BfUfwY%3D&reserved=0> for further discussion on @type values. My main question is: why this restriction? It is perfectly normal in RDF to have nesting for the rdf:type property (e.g. relate to a class that is itself a subclass of another class). As you note, the value space for @type is described in the normative text, with the informative text being more about how and why to use @type, rather than the motivations for restricting its value space. This is mainly because the string values of @type have specific expansion characteristics that allow relative values to be interpreted either vocabulary-relative or document-relative. The though was that if people wanted to be more creative in their use of types, they could do this using “rdf:type”. The JSON-LD API discusses more details of processing @type during expansion in steps 11 and 13.4.4 of the Expansion Algorithm (https://www.w3.org/TR/json-ld11-api/#algorithm-3<https://nam11.safelinks.protection.outlook.com/?url=https%3A%2F%2Fwww.w3.org%2FTR%2Fjson-ld11-api%2F%23algorithm-3&data=05%7C01%7Cr.hoekstra%40elsevier.com%7C886239854ee54e0eaf8608daa7d84ccd%7C9274ee3f94254109a27f9fb15c10675d%7C0%7C0%7C638006845476856446%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C1000%7C%7C%7C&sdata=X7ltqr3mN5kEAR6mDnNzOx8nCBE2lJ6J5tGWmGErtvw%3D&reserved=0>). Note the specific language on raising an error if the value of @type isn’t a string or array of strings in 13.4.4.1: > 13.4.4.1) If value is neither a string<https://nam11.safelinks.protection.outlook.com/?url=https%3A%2F%2Finfra.spec.whatwg.org%2F%23javascript-string&data=05%7C01%7Cr.hoekstra%40elsevier.com%7C886239854ee54e0eaf8608daa7d84ccd%7C9274ee3f94254109a27f9fb15c10675d%7C0%7C0%7C638006845476856446%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C1000%7C%7C%7C&sdata=PcK0nqeSYTWYqmhwB1HO90fSf7WF%2BNEmDAF%2B7VLfzR0%3D&reserved=0> nor an array<https://nam11.safelinks.protection.outlook.com/?url=https%3A%2F%2Finfra.spec.whatwg.org%2F%23list&data=05%7C01%7Cr.hoekstra%40elsevier.com%7C886239854ee54e0eaf8608daa7d84ccd%7C9274ee3f94254109a27f9fb15c10675d%7C0%7C0%7C638006845476856446%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C1000%7C%7C%7C&sdata=BwSZG7fbqc%2B5s1jXL1nNyCsu9x63s5uaOHNcakdAXxw%3D&reserved=0> of strings<https://nam11.safelinks.protection.outlook.com/?url=https%3A%2F%2Finfra.spec.whatwg.org%2F%23javascript-string&data=05%7C01%7Cr.hoekstra%40elsevier.com%7C886239854ee54e0eaf8608daa7d84ccd%7C9274ee3f94254109a27f9fb15c10675d%7C0%7C0%7C638006845476856446%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C1000%7C%7C%7C&sdata=PcK0nqeSYTWYqmhwB1HO90fSf7WF%2BNEmDAF%2B7VLfzR0%3D&reserved=0>, an invalid type value<https://nam11.safelinks.protection.outlook.com/?url=https%3A%2F%2Fwww.w3.org%2FTR%2Fjson-ld11-api%2F%23dom-jsonlderrorcode-invalid-type-value&data=05%7C01%7Cr.hoekstra%40elsevier.com%7C886239854ee54e0eaf8608daa7d84ccd%7C9274ee3f94254109a27f9fb15c10675d%7C0%7C0%7C638006845476856446%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C1000%7C%7C%7C&sdata=cv08bajGNbNTtren0XIoEN5%2Bjq7fmzrVd0mijJdWoQw%3D&reserved=0> error has been detected and processing is aborted. ... One reason I can think of is that the value for @type should never be a Literal; that makes sense, so any string value for the @type key will have to be interpreted as an IRI. However, disallowing for embedded node objects, seems overly restrictive to me, and I'm inclined to see this as a bug in the spec. I can work around this by mapping a custom "type" entry in a context to rdf:type, but I'd much rather use the built-in @type for consistency. That’s the right way to do it. JSON-LD expansion is complex enough without furhter complicating its processing model, at least IMHO. Gregg Could someone explain the reasoning behind this? Thanks, Rinke [1] https://www.w3.org/TR/json-ld11/#embedding<https://nam11.safelinks.protection.outlook.com/?url=https%3A%2F%2Fwww.w3.org%2FTR%2Fjson-ld11%2F%23embedding&data=05%7C01%7Cr.hoekstra%40elsevier.com%7C886239854ee54e0eaf8608daa7d84ccd%7C9274ee3f94254109a27f9fb15c10675d%7C0%7C0%7C638006845477012744%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C1000%7C%7C%7C&sdata=SHEdvgvMW4kt5eJQiiXZlLfGwiJvaLCG1rMqkhOxQ9Q%3D&reserved=0> [2] https://www.w3.org/TR/json-ld11/#specifying-the-type<https://nam11.safelinks.protection.outlook.com/?url=https%3A%2F%2Fwww.w3.org%2FTR%2Fjson-ld11%2F%23specifying-the-type&data=05%7C01%7Cr.hoekstra%40elsevier.com%7C886239854ee54e0eaf8608daa7d84ccd%7C9274ee3f94254109a27f9fb15c10675d%7C0%7C0%7C638006845477012744%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C1000%7C%7C%7C&sdata=BztwDXCYKoPhM13tOjafiB6IH249lknjkoUh684qUY8%3D&reserved=0> [3] https://www.w3.org/TR/json-ld11/#node-objects<https://nam11.safelinks.protection.outlook.com/?url=https%3A%2F%2Fwww.w3.org%2FTR%2Fjson-ld11%2F%23node-objects&data=05%7C01%7Cr.hoekstra%40elsevier.com%7C886239854ee54e0eaf8608daa7d84ccd%7C9274ee3f94254109a27f9fb15c10675d%7C0%7C0%7C638006845477012744%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C1000%7C%7C%7C&sdata=CZIJj2ScH3w9I1jqWVhmFsIf2H2LnC%2FMfNG4iCa%2BDuc%3D&reserved=0> [4] https://tinyurl.com/2jx8e6r4<https://nam11.safelinks.protection.outlook.com/?url=https%3A%2F%2Ftinyurl.com%2F2jx8e6r4&data=05%7C01%7Cr.hoekstra%40elsevier.com%7C886239854ee54e0eaf8608daa7d84ccd%7C9274ee3f94254109a27f9fb15c10675d%7C0%7C0%7C638006845477012744%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C1000%7C%7C%7C&sdata=gjrdXneNqRG%2FWjwptjPrfmsWJpak603Kq6MrQOZojKk%3D&reserved=0> [5] https://tinyurl.com/mr3t75zn<https://nam11.safelinks.protection.outlook.com/?url=https%3A%2F%2Ftinyurl.com%2Fmr3t75zn&data=05%7C01%7Cr.hoekstra%40elsevier.com%7C886239854ee54e0eaf8608daa7d84ccd%7C9274ee3f94254109a27f9fb15c10675d%7C0%7C0%7C638006845477012744%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C1000%7C%7C%7C&sdata=O5n7ZshLgEUOqzVHAl0xH8DkZutDrPlhhDBS9iHRz84%3D&reserved=0> -- Rinke Hoekstra Lead Architect – Knowledge Industry Director of Elsevier’s Discovery Lab ELSEVIER - Amsterdam r.hoekstra@elsevier.com<mailto:r.hoekstra@elsevier.com> Emails can arrive at all hours, but at Elsevier we respect your personal time. Feel free to respond to this email during your normal working hours. ________________________________ Elsevier B.V. Registered Office: Radarweg 29, 1043 NX Amsterdam, The Netherlands, Registration No. 33158992, Registered in The Netherlands. ________________________________ Elsevier B.V. Registered Office: Radarweg 29, 1043 NX Amsterdam, The Netherlands, Registration No. 33158992, Registered in The Netherlands.
Received on Monday, 10 October 2022 07:03:58 UTC