On 08/06/2022 09:22, Martynas Jusevičius wrote:
On Tue, Jun 7, 2022 at 9:15 PM Andy Seaborne <[email protected]> wrote:
On 07/06/2022 10:47, Martynas Jusevičius wrote:
Hi,
I have implemented PATCH method for the Graph Store Protocol:
https://www.w3.org/TR/sparql11-http-rdf-update/#http-patch
The PATCH is applied to a named graph. I am missing this bit however:
" If a SPARQL 1.1 Update request is used as the RDF payload for a
PATCH request that makes changes to more than one graph or the graph
it modifies is not the one indicated, it would be prudent for the
server to respond with a 422 Unprocessable Entity status."
I read that in the context of GSP resource naming.
?graph=<uri>
and so the update does not name a graph - it'll look like the default
graph in the update.
So look for GRAPH in the update.
Thanks, that makes sense. GRAPH is also easy to check.
But then I need to forward the update to a triplestore that does not
support PATCH.
It's the GSP naming that matters.
Which means I would need to wrap INSERT/DELETE/WHERE templates into
GRAPH <uri> { }.
WITH <iri> DELETE {} INSERT {} WHERE {}
Also: USING. And protocol.
Is there some builder code that can help with that?
Have you looked at UpdateBuilder?
What would be the way to make sure that an update only affects a
single specific graph?
A dataset of one graph and no others. c.f. DatasetGraphOne but for a
single named graph and read-only dft graph.
Or a dataset which yields read-only graphs except for the target graph.
Or analyse the update - no GRAPH in templates if the target comes from
the URL.
Martynas
atomgraph.com