. . . . "Returns key-value facts for display on a project page (a gen:Project, which is also a gen:Space): its description, start date, end date, project lead(s), and admins. Description and dates are read from the project's latest non-invalidated definition nanopub. Project leads are the validated holders of the project-lead role (gen:hasRole .../projectLeadRole) and admins are the validated admins (npa:hasRoleType gen:AdminRole) of the project, both resolved via the spaces repository. Each property occupies one row; the Value column is a multi-value cell so properties with several values (multiple leads or admins) list them all in a single row. Both columns use the '_noheader' convention so the redundant header row is dropped." . . . "Get project info" . . "prefix rdf: \nprefix rdfs: \nprefix dct: \nprefix schema: \nprefix foaf: \nprefix np: \nprefix npa: \nprefix npx: \nprefix gen: \n\nselect distinct ?Property_noheader ?Property_label ?Value_multi_val_noheader ?Value_label_multi where {\n values ?_resource_multi_iri {}\n graph npa:graph {\n ?np npx:introduces ?_resource_multi_iri ; npa:hasValidSignatureForPublicKeyHash ?pubkey ; np:hasAssertion ?a .\n filter not exists { ?inv npx:invalidates ?np ; npa:hasValidSignatureForPublicKeyHash ?pubkey . }\n }\n graph ?a { ?_resource_multi_iri a gen:Project }\n\n optional {\n select (group_concat(distinct ?descEsc; separator=\"\\n\") as ?descVal) where {\n values ?_resource_multi_iri {}\n graph npa:graph {\n ?npd npx:introduces ?_resource_multi_iri ; npa:hasValidSignatureForPublicKeyHash ?pkd ; np:hasAssertion ?ad .\n filter not exists { ?invd npx:invalidates ?npd ; npa:hasValidSignatureForPublicKeyHash ?pkd . }\n }\n graph ?ad { ?_resource_multi_iri dct:description ?desc . }\n bind(replace(replace(str(?desc), \"\\\\\\\\\", \"\\\\\\\\\\\\\\\\\"), \"[\\r\\n]+\", \"\\\\\\\\n\") as ?descEsc)\n } having (count(?desc) > 0)\n }\n\n optional {\n select (group_concat(distinct substr(str(?sd), 1, 10); separator=\"\\n\") as ?startVal) where {\n values ?_resource_multi_iri {}\n graph npa:graph {\n ?nps npx:introduces ?_resource_multi_iri ; npa:hasValidSignatureForPublicKeyHash ?pks ; np:hasAssertion ?asd .\n filter not exists { ?invs npx:invalidates ?nps ; npa:hasValidSignatureForPublicKeyHash ?pks . }\n }\n graph ?asd { ?_resource_multi_iri schema:startDate ?sd . }\n } having (count(?sd) > 0)\n }\n\n optional {\n select (group_concat(distinct substr(str(?ed), 1, 10); separator=\"\\n\") as ?endVal) where {\n values ?_resource_multi_iri {}\n graph npa:graph {\n ?npe npx:introduces ?_resource_multi_iri ; npa:hasValidSignatureForPublicKeyHash ?pke ; np:hasAssertion ?aed .\n filter not exists { ?inve npx:invalidates ?npe ; npa:hasValidSignatureForPublicKeyHash ?pke . }\n }\n graph ?aed { ?_resource_multi_iri schema:endDate ?ed . }\n } having (count(?ed) > 0)\n }\n\n optional {\n select (group_concat(?lead2; separator=\"\\n\") as ?leadVal) (group_concat(?leadName; separator=\"\\n\") as ?leadLabel) where {\n select distinct ?lead2 ?leadName where {\n values ?_resource_multi_iri {}\n service {\n graph npa:graph { npa:hasCurrentSpaceState ?g . }\n graph ?g { ?ri a gen:RoleInstantiation ; npa:forSpace ?_resource_multi_iri ; gen:hasRole ; npa:forAgent ?lead . }\n optional { graph ?g { ?lead foaf:name ?leadName0 . } }\n }\n bind(coalesce(?leadName0, str(?lead)) as ?leadName)\n bind(str(?lead) as ?lead2)\n }\n } having (count(?lead2) > 0)\n }\n\n optional {\n select (group_concat(?admin2; separator=\"\\n\") as ?adminVal) (group_concat(?adminName; separator=\"\\n\") as ?adminLabel) where {\n select distinct ?admin2 ?adminName where {\n values ?_resource_multi_iri {}\n service {\n graph npa:graph { npa:hasCurrentSpaceState ?g . }\n graph ?g { ?ri2 a gen:RoleInstantiation ; npa:forSpace ?_resource_multi_iri ; npa:hasRoleType gen:AdminRole ; npa:forAgent ?admin . }\n optional { graph ?g { ?admin foaf:name ?adminName0 . } }\n }\n bind(coalesce(?adminName0, str(?admin)) as ?adminName)\n bind(str(?admin) as ?admin2)\n }\n } having (count(?admin2) > 0)\n }\n\n values (?key ?Property_noheader ?Property_label) {\n ('Description' dct:description 'Description:')\n ('StartDate' schema:startDate 'Start Date:')\n ('EndDate' schema:endDate 'End Date:')\n ('Lead' gen:hasProjectLead 'Project Lead:')\n ('Admins' gen:hasAdmin 'Admins:')\n }\n bind(if(?key='Description', ?descVal, if(?key='StartDate', ?startVal, if(?key='EndDate', ?endVal, if(?key='Lead', ?leadVal, ?adminVal)))) as ?Value_multi_val_noheader)\n filter(bound(?Value_multi_val_noheader))\n bind(if(?key='Lead', ?leadLabel, if(?key='Admins', ?adminLabel, '')) as ?Value_label_multi)\n}\norder by (if(?key='Description', 1, if(?key='StartDate', 2, if(?key='EndDate', 3, if(?key='Lead', 4, 5)))))" . . "Tobias Kuhn" . "2026-06-30T11:31:06Z"^^ . . . . "Get project info" . . . . . . "RSA" . "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCwUtewGCpT5vIfXYE1bmf/Uqu1ojqnWdYxv+ySO80ul8Gu7m8KoyPAwuvaPj0lvPtHrg000qMmkxzKhYknEjq8v7EerxZNYp5B3/3+5ZpuWOYAs78UnQVjbHSmDdmryr4D4VvvNIiUmd0yxci47dTFUj4DvfHnGd6hVe5+goqdcwIDAQAB" . "lMCHB/rdM9XsV+2AZmjUVVngDA3GCqyUyl5vilNPsTvXFYRAWwtu1RtRNQGLm77DQpTa8SSvYLyrBscErMIMlUoYayXdM251o9yCLEz8u1d3b/9EHStQw1SbC2iFpjANxRdqzBFUvilqH4LgoaDIHYp3aWCWRFKSytqePrK5M5U=" . . .