Security News
Bun 1.2 Released with 90% Node.js Compatibility and Built-in S3 Object Support
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.
ldn-inbox-server
Advanced tools
An experimental LDN inbox server for Event Notification messages.
yarn add ldn-inbox-server
Create required directories
mkdir config inbox public
Start the server:
npx ldn-inbox-server start-server --port 8000
Send a demonstration Event Notifications message:
curl -X POST -H 'Content-Type: application/ld+json' --data-binary '@examples/offer.jsonld' http://localhost:8000/inbox/
Start an inbox handler with a demo handler (that creates an Accept
message in the ./outbox
).
npx ldn-inbox-server handler @inbox -hn ./handler/accept_notification_handler.js
Start an outbox handler that send the notifications that are available outbox:
npx ldn-inbox-server handler @outbox -hn ./handler/send_notification_handler.js
LOG4JS
: log4js logging levelLDN_SERVER_HOST
: LDN inbox hostLDN_SERVER_PORT
: LDN inbox portLDN_SERVER_INBOX_URL
: LDN inbox url (path)LDN_SERVER_INBOX_PATH
: LDN inbox pathLDN_SERVER_ERROR_PATH
: LDN error pathLDN_SERVER_OUTBOX_PATH
: LDN outbox pathLDN_SERVER_PUBLIC_PATH
: public (HTML) pathLDN_SERVER_JSON_SCHEMA
: notification JSON validation schemaLDN_SERVER_BASEURL
: baseurl of the LDN inbox serverLDN_SERVER_INBOX_GLOB
: glob of files to process in inbox directoryLDN_SERVER_HAS_PUBLIC_INBOX
: if true, then public read access is allowed on the inboxLDN_SERVER_HAS_WRITABLE_INBOX
: if true, then public write access is allowed on the inboxLDN_SERVER_LOCKDIR
: directory to store optional lock files for handlerInstead of a single inbox, multiple inboxes can be configured by adding a JSON configuration file to the installation. The JSON file should contain a registry
entry with contains an array of inbox configuration. An example:
{
"registry": [
{ "path": "inbox/.*" ,
"with": {
"url": "inbox/",
"inbox": "./inbox",
"inboxPublic": 1,
"inboxWritable": 1,
"schema": "./config/schema1.json"
}},
{ "path": "inbox2/.*" ,
"with": {
"url": "inbox2/",
"inbox": "./inbox2",
"inboxPublic": 1,
"inboxWritable": 0,
"schema": "./config/schema2.json"
}}
]
}
Server extensions are possible by providing custom inbox and notification handlers. E.g.
npx ldn-inbox-server handler @inbox -hn handler/my_handler.js
Or, in JavaScript:
const { handle_inbox } = require('ldn-inbox-handler');
main();
async function main() {
await handle_inbox('./inbox', {
'inbox': './inbox',
'outbox': './outbox',
'public': './public',
'error': './error',
'batch_size': 5,
'glob': '^.*\\.jsonld$',
'config': './config/inbox_config.json',
'notification_handler': 'handler/my_handler.js'
});
}
with my_handler.js
:
async function handle({path,options}) {
//...
return { path, options, success: true };
}
module.exports = { handle };
A handler can be started on any directory. E.g. a workflow might be:
A handler that creates for an incoming notification an Accept
notification in the @outbox
.
A handler that updates an event log with the incoming notification.
Requires configuration properties:
log
: the path to the event log (starting from the public
directory)dir
: the path to a container to store the events (starting from the public
directory)The log
and dir
path may contain a @artifact(:strip)?@
directive to fill in the
path of the current artifact. The :strip
filter is used to strip an artifact path of a file extension. E.g. path/artifact.html
becomes path/artifact
when using a :strip
.
A handler that accepts a notifiction when it matches one or more JSON paths
Requires configuration properties:
OR
.
AND
.A single matcher needs two properties:
The json path matches when one of:
A handler/multi_notification_handler.js
is available to start multiple handler for each notification messages. The handlers to start are specified in a configuration file that can be passed via the config
parameter of an handle_inbox
. For the commmand line tool bin/ldn-inbox-server
the default location of such config file is config/inbox_config.json
when processing an @inbox
, and config/outbox_config.json
when processing an @outbox
.
The multi handler requires a configuration file with properties notification_handler.multi.handlers
which is an array of array. Each outer array defines a workflow: a list of handlers that should be executed sequentially on a notification until one handler returns a success=false
response or the last handler returns a success=true
response, or a handler returns break=true
(which will skip all other steps in a workflow). The multi handler is successful when at least one workflow could be completed with success.
Each handler is defined by a hash containing as id
property the path to the handler and optionally other property keys that will be passed to the handlers in the config
section.
Optionally when a fallback
handler is defined as option it will be attempted when a handler in a sequence returns a false
response.
A handler that sets the fallback
for a workflow sequence.
A handler to Offer
an event log to a memento server.
Requires configuration properties:
actor
: the LDN+AS2 actor
to use in a notificationtarget
: the LDN+AS2 target
to use in a notificationA handler to send notification that live in the @outbox
via the LDN protocol to the LDN target
.
If the environoment DEMO_MODE=NO_NOTIFICATIONS
is set, no real notifications will be sent.
A handler that accepts any notification with a type that matches one of the anyOf
types.
A handler that validates the incoming notification and checks if the object
or context
contains an artifact that is part of the public
resources. See 'Artifact support' below.
Generates the following options keys:
A hander that validates the incoming notification and checks if the object
or context
contains an event log that is part of the public
resources.
Generates the following options keys:
This code base contains Event Notifications support for Data Node artifacts. See the examples
in public/artifacts-example
. Move this directory tp public/artifacts
to get a running example.
.meta
file with the X-Artifact
header set to true
to be recognized by the software as an artifactLink-Template
header in the .meta
fileconfig/inbox_config.json
and config/outbox_config.json
define the location of the possible event logs for the artifactReturns a LOG4JS logger instance.
Resolve the url and return the textual body.
Return the result of fetch(url,options)
(tries many times untill the server responds).
Send to url
the payload uptionally a fetch
can be provided in the options.
Move a file from an oldPath to a newPath .
Parse the path into a JSON document (or return null when failed).
Generate a uuid URN.
Generate a ISO8601 date time string.
Parse a path containing .json
| .jsonld
| .json5
| .yaml
| .yml
into a
JavaScript object.
FAQs
A demonstration Event Notifications Inbox server
We found that ldn-inbox-server demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.
Security News
Biden's executive order pushes for AI-driven cybersecurity, software supply chain transparency, and stronger protections for federal and open source systems.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.