@prefix this: . @prefix sub: . @prefix np: . @prefix grlc: . @prefix dct: . @prefix npx: . @prefix xsd: . @prefix rdfs: . @prefix orcid: . @prefix prov: . @prefix foaf: . sub:Head { this: a np:Nanopublication; np:hasAssertion sub:assertion; np:hasProvenance sub:provenance; np:hasPublicationInfo sub:pubinfo . } sub:assertion { sub:list-sub-spaces a grlc:grlc-query; dct:description "Lists the sub-spaces of a given space ref (space IRI + root definition) with their type and a link to the source nanopublication. Type and label come from each sub-space's root-definition assertion; sub-spaces whose definitions are all retracted or otherwise invalidated are filtered out. Ordered alphabetically by label. Pass the ref's root nanopub (root_np); the query resolves the ref via npa:rootNanopub and scopes the sub-space edges by the ref-level npa:hasSubSpace (subject = the ref), so it shows only that one ref's sub-spaces rather than merging all refs claiming the IRI. Ref-scoped variant of list-sub-spaces (which is IRI-keyed via npa:hasSubSpace on the space IRI)."; dct:license ; rdfs:label "List sub-spaces of a space (ref-scoped)"; grlc:endpoint ; grlc:sparql """prefix np: prefix npx: prefix npa: prefix gen: prefix rdfs: select ?subspace ?subspace_label ?type ?np (\"^\" as ?np_label) where { { select ?subspace (sample(?label) as ?subspace_label) (coalesce(sample(?typeName), \"\") as ?type) (sample(?rootNp) as ?np) where { values ?_root_np_multi_iri {} graph npa:spacesGraph { ?spaceRef npa:rootNanopub ?_root_np_multi_iri . } graph npa:graph { npa:thisRepo npa:hasCurrentSpaceState ?g . } graph ?g { ?spaceRef npa:hasSubSpace ?subspaceRef . } graph npa:spacesGraph { ?subspaceRef npa:spaceIri ?subspace ; npa:rootNanopub ?rootNp . } graph ?ag { ?subspace a gen:Space ; rdfs:label ?label . optional { ?subspace a ?typeIri . filter(?typeIri != gen:Space) } } graph npa:graph { ?defNp np:hasAssertion ?ag ; npa:hasValidSignatureForPublicKey ?pubkey . filter not exists { ?inv npx:invalidates ?defNp ; npa:hasValidSignatureForPublicKey ?pubkey . } } bind(if(bound(?typeIri), strafter(str(?typeIri), \"terms/\"), \"\") as ?typeName) } group by ?subspace } } order by lcase(str(?subspace_label))""" . } sub:provenance { sub:assertion prov:wasAttributedTo orcid:0000-0002-1267-0234 . } sub:pubinfo { orcid:0000-0002-1267-0234 foaf:name "Tobias Kuhn" . this: dct:created "2026-06-17T06:44:57Z"^^xsd:dateTime; dct:creator orcid:0000-0002-1267-0234; dct:license ; npx:embeds sub:list-sub-spaces . sub:sig npx:hasAlgorithm "RSA"; npx:hasPublicKey "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCwUtewGCpT5vIfXYE1bmf/Uqu1ojqnWdYxv+ySO80ul8Gu7m8KoyPAwuvaPj0lvPtHrg000qMmkxzKhYknEjq8v7EerxZNYp5B3/3+5ZpuWOYAs78UnQVjbHSmDdmryr4D4VvvNIiUmd0yxci47dTFUj4DvfHnGd6hVe5+goqdcwIDAQAB"; npx:hasSignature "lY1hpf1dDFz08y3qt90+fr3m15EqdW3WkTshjjKAj1+kU3miKcRdVxi7JNZtnPA2tyMMMmGviIhNqpwLVenvt52i0LvHw95WfvVRkLHNqLp7HUT0vzwwIY8AxqsjP7cHGLd4T9CW1j/7tBYMxcqjVPl6Jjf9X4Bg+VF+1DakgAM="; npx:hasSignatureTarget this:; npx:signedBy orcid:0000-0002-1267-0234 . }