- From: ☮ elf Pavlik ☮ <perpetual-tripper@wwelves.org>
- Date: Mon, 06 Oct 2014 13:39:30 +0200
- To: Markus Lanthaler <markus.lanthaler@gmx.net>, public-socialweb@w3.org, 'Linked JSON' <public-linked-json@w3.org>
On 10/06/2014 12:43 PM, Markus Lanthaler wrote:
> Hi Pavlik,
>
> On 4 Okt 2014 at 13:50, ☮ elf Pavlik ☮ wrote:
>> ActivityStreams defines (unless it recently changed) UrlTemplate and
>> ParametersObject in https://github.com/jasnell/w3c-socialwg-
>> activitystreams/blob/54deeb6d6aa742ffe4e1d6c6e09cb84cdf3123b4/activitystr
>> eams2- actions.html#L1035
>>
>> where we can see that as:parameters takes *an object* (not sure about an
>> array of objects here...)
>
> Let's discuss as specific example from the document you reference above:
>
> "review": {
> "objectType": "UrlTemplate",
> "template": "http://example.org/notes/{noteid}",
> "parameters": {
> "noteid": {
> "type": "nonNegativeInteger",
> "totalDigits": 5
> }
> }
> }
>
>
>> I can't yet clearly explain possible issues with using object keys this
>> way. To my understanding in JSON-LD object keys always map to
>> *predicates* which limits them to IRIs (no blank nodes or literal values
>> unless serializing Generalized RDF) which can make difference here.
>
> In JSON-LD "object keys", as you call them, don't always have to map to predicates. In the example above, "noteid" *probably* shows such a use case. It represents/describes the variable "noteid" in the URL template. Hydra makes this a bit more explicit (hydra:variable) but you can also handle the AS way of doing it with JSON-LD, but it won't result in meaningful RDF. The trick is to use a feature called "Data Indexing" [1]. Simply speaking, it allows you to add index data in a similar way as language maps do but with the difference that the index has no meaning at all. It is simply a string token that would be lost when converting to RDF. It survives all JSON-LD transformations (expansion/compaction etc.) though.
>
> Does this answer your question?
Thanks Markus! It does help me to understand it much better, I hope :)
While in as:UrlTemplate we may actually prefer that parameters do NOT
map to predicates, in as:Object we would probably prefer that actions do
map to predicates. So new pattern with array solves possible issue with
previous pattern with an object:
https://github.com/jasnell/w3c-socialwg-activitystreams/issues/17
I try to think if we can extract some kind of 'rule of thumb' here for
potential JSON-LD Best Practices document.
Received on Monday, 6 October 2014 11:41:44 UTC