- The persistent storage of
refresh_token
s allows long-lived sessions when authenticated with Google login
- Fixed the back button (the history states were being mismanaged)
- Inline creation and editing of container and XHTML content in content layout mode
- ACL access modes sent as
Link
response headers and accessible in the client-side XSLT stylesheets using theacl:mode
function - Results of queries that use
forClass
type after a new instance was created are banned from Varnish cache endpoint
URL param can be used to override the SPARQL endpoint that the fallbackDESCRIBE
query gets executed against- XML literals in SPARQL updates get canonicalized before reaching the SPARQL endpoint
- Content model uses
rdf:Seq
andrdf:_1
,rdf:_2
... properties instead ofrdf:List
andrdf:first
/rdf:rest
- SPARQL updates submitted to the Graph Store via the
PATCH
method now have to use the default graph context, theGRAPH
keyword is disallowed - Fixed caching of delegated WebID agents, eliminating an unnecessary request with each authentication
- Multiple
Link
headers combined into a single one with concatenated values
--fragment
parameter to CLI scripts that can be used to specify the fragment ID of the resource paired with the document (defaults to UUID)ENABLE_LINKED_DATA_PROXY
env parameter that allows disabling the Linked Data proxy/browser (enabled by default)
- Fixed double
On-Behalf-Of
header value when both WebID and OIDC agent contexts were delegated - Fixed Linked Data proxy fallback to a local
DESCRIBE
query when the external URL does not dereference - Fixed IP address check in the setup script
- Jena upgraded to 4.5.0
- Fuseki Docker image upgraded to 4.5.0
- Saxon-JS upgraded to 2.4
key()
lookups enabled in client-side XSLT as HTML page mutations do not break indexes anymore (fixed in 5036)
- Spanish UI localization
- Reconciliation of OIDC accounts with existing agents by email address
- Document tree widget
- New
/clear
endpoint which is used to clear ontologies from memory - Second nginx port which has WebID client certificate authentication always enabled
--proxy
parameter to CLI scripts
- Variables in SPARQL query and update strings whose values are injected now start with
$
instead of?
, for example$this
- CSV and RDF imports write data directly to the backend Graph Store
- Only namespace, signup, OAuth2 login, WebID profiles and public keys can be public in admin apps, nothing else (hardcoded in the admin authorization query)
- When graph URI not explicitly specified, the Graph Store always returns
201 Created
(even if the graph existed) - Fuseki image upgraded to 4.3.2
- Interactivity to the graph SVG layout
- Notifications to the requesting agent when its access request is granted (requires email server)
- JSON-LD export option for documents
append-content
CLI script that appends content resources to documentcreate-file
CLI script automatically recognizes the MIME type of the file being uploaded- Linked Data browser functionality in graph layout mode
- Javadoc comments
- The setup script requirements relaxed to make it easier to run on MacOS
- Fixed CSV imports
- Linked Data browser now supports relative URIs
- Upgraded Java from 11 to 17
- A built-in HTTP API constraint does not allow
PUT
on documents without the document description in request body - A built-in HTTP API constraint does not allow to
DELETE
the root document - A built-in HTTP API constraint does not allow to
DELETE
orPUT
the the app owner's and secretary's WebID documents - Shell script interpreter line
- Dydra-specific code
- Ability to copy (fork) RDF data into the local dataspace
- Block-based content layout (
ldh:ContentList
mode) and editor - Login with Google (OpenID Connect)
- Ability to load JSON-LD data from
<script>
elements in HTML - Namespace endpoint, which is an in-memory SPARQL endpoint over the app's ontology
- The HTTP CRUD API is now Graph Store Protocol, not Linked Data Templates
- HTML documents are hydrated HTML fragments over AJAX
- XSLT stylesheets now load constraints and constructors using SPARQL over the namespace endpoint
- The URIs of ontology terms are not relative to the app's base URI anymore
- Additional assertions added to external ontology terms instead of subclassing them
- Every UI state generates a distinct URL which is loaded consistently on both server- and client-side
- Upgraded Jena to 4.3.2
- Upgraded Saxon-JS to 2.3
- Upgraded Fuseki, Varnish and nginx Docker images
- Linked Data Templates support (still supported by Processor)
- HTTP smoke tests for SPARQL endpoint and Graph Store
- HTTP test for RDF import without mapping query
add-data.sh
CLI script which POSTs RDF data to URLExceptionMapper
constructors with injection in order to align with Processor- An option to override request URI using the
?uri=
URL param, implemented inApplicationFilter
Dispatcher
as the new "entrypoint" JAX-RS resource which routes betweenResourceBase
(if app is not empty) andProxyResourceBase
(if app is empty)- Missing XML namespace definitions to client-side XSLT stylesheets
$output-json-ld
parameter inxhtml:Script
template which outputs the RDF document as JSON-LD in the<script>
element
select-labelled
query in the end-user dataset to include a default graph patternspin:query
property is now optional forapl:RDFImport
- Entrypoint script logic to load agent metadata only when
$LOAD_DATASETS
is true - Injecting
Optional<Application>
,Optional<Service>
,Optional<Ontology>
instead ofApplication
,Service
,Ontology
- Using
javax.inject.Provider<>
for injection into providers that are not in the request scope - If no application matches request URI,
NotFoundException
is not thrown anymore --Optional.empty()
is used as application instead - Auth filters skipped if the matched application is not an instance of
lapp:EndUserApplication
orlapp:AdminApplication
- Simplified
ResourceBase::describe
by removing the?uri=
indirection logic
- Proxy injections from injection factory binders
- varnish-admin service that proxy-caches the fuseki-admin triplestore
purge_backend_cache
function to the HTTP test runner script run.shpurge_backend_cache
calls to clear proxy caches before each HTTP scriptBackendInvalidationFilter
response filter with backend proxy cache invalidation heuristics- Basic environment variable documentation to README
- Upgraded Processor and Web-Client to the latest versions
- Upgraded Saxon-JS to 2.1
- End-user and admin Services passed to import
Executor
instead ofDatasetAccessor
- Defined HTTP method -> ACL mode mapping as the
AuthorizationFilter.ACCESS_MODES
map
- Unused Docker mounts from linkeddatahub service
ban()
calls fromResourceBase
-- now handled by theBackendInvalidationFilter
apl:baseUri
as a static XSLT stylesheet param
bs2:PropertyControl
XSLT mode can handle multiple RDF types on a resource- Replaced error alerts with inline HTML warning blocks
- Refactored
bs2:SignUp
template to make it more extensible
ORDER BY
inapl:ResultCounts
mode in client.xsl
$request_base
parameter support in scripts allows to use a base URI for HTTP requests which is different from the RDF dataset base URI. Useful when multiple LDH instances on different domains or port numbers are backed by the same dataset. E.g. one with WebID-TLS auth enabled and the other without.- Dydra-specific
QuadStoreClient
andGraphStoreClient
with support for asynchonous GSP requests
- Ontology classes that used to be in the
ns:
namespace (${base}ns#
) moved tonsds:
(${base}ns/domain/system#
) - Ontology classes that used to be in the
def:
namespace (${base}def#
) moved tonsdd:
(${base}ns/domain/default#
) python
usages replaced withpython2
in CLI scripts- Mounting only
ssl/owner/public.pem
instead of the wholessl/owner
folder which includes the private key
- Expensive join with the provenance graph from the
laclt:ConstructAgentItem
query. As a result,dct:created
value is not included in agent's description. - Unnecessary methods from the
Import
Java interface. Passing arguments directly toImportListener
instead