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.
koreografeye
Advanced tools
A minimal orchestrator and policy executor component for the Mellon Researcher Pod project
Koreografeye is a choreography engine for linked data services using Notation3 (N3) rule engines such as EYE.
Koreografeye was created to facilitate automated processes against Solid pods. Our main use case is monitoring the LDN Inbox of Solid Pods for new notifications and running scripts when new data arrives.
Create a project directory.
mkdir demo
cd demo
Add the koreografeye
dependency (and solid-bashlib
in case you want to monitor private Solid resources).
npm install koreografeye
npm install solid-bashlib
Create input, output and rules directories.
mkdir input output rules
Copy a version of config.jsonld
to this directory
wget https://raw.githubusercontent.com/eyereasoner/Koreografeye/main/config.jsonld
Put a demo.jsonld
AS2 notification in the input
directory.
{
"@context": [
"https://www.w3.org/ns/activitystreams",
"https://purl.org/coar/notify"
],
"id": "urn:uuid:0370c0fb-bb78-4a9b-87f5-bed307a509dd",
"type": "Offer",
"actor": {
"id": "https://mypod.org/profile/card#me",
"name": "Freddy Test",
"type": "Person"
},
"object": "https://research-organisation.org/repository/preprint/201203/421/"
}
Create a demo.n3
N3 rule file in the rules
directory.
@prefix ex: <http://example.org/> .
@prefix as: <https://www.w3.org/ns/activitystreams#> .
@prefix pol: <https://www.example.org/ns/policy#> .
@prefix fno: <https://w3id.org/function/ontology#> .
{
# pol:mainSubject defines the top level identifier of the notification
[ pol:mainSubject ?id ] .
# if we get an offer
?id a as:Offer .
?id as:actor ?actor .
}
=>
{
# Send an accept notification to an LDN inbox
ex:MySendNotificationDemo pol:policy [
a fno:Execution ;
fno:executes ex:sendNotification ;
ex:to <http://httpbin.org/post> ;
ex:notification [
a as:Accept ;
as:inReplyTo ?id ;
as:actor <http://my.service.edu/profile/card#me> ;
as:object ?id
]
] .
}.
The orch
command will take the input data and use the N3 rules to decide what to do with the data. No actions are taken yet. These will be done by the pol
command.
npx orch --info --keep --in input --out output rules/*
The processed notifications will end up in the output
directory
The pol
command will take the output of the orch
command and execute the requested
policies defined with the N3 rules.
npx pol --info --keep --in output
The result will be an AS2 that is send to the http://httpbin.org/post
address.
Using Koreografeye plugins you can experiment with:
Check the Git repository https://github.com/eyereasoner/Koreografeye for more examples.
We use the Bashlib to monitor remote Solid LDN inboxes for new notification.
E.g. move the contents of your inbox to the input
directory.
npx sld mv https://yourpod.org/inbox/ input/
This assumes you have an authenticated Bashlib session. Use the bashlib auth create-token
command to create a token for the CSS Solid pod.
One can also use JavaScript to execute the orch
and pol
commands:
const {
parseAsN3Store,
readText,
topGraphIds,
storeAddPredicate,
makeComponentsManager,
executePolicies
} = require('koreografeye');
main();
async function main() {
const inputData = './input/demo.jsonld';
const inputRules = './rules/demo.n3';
// Read the input graph as an N3 store
const store = await parseAsN3Store(inputData);
// Read the N3 rules as an array of strings
const rules = [readText(inputRules)];
// Discover the main subjects of the graph
const topIds = topGraphIds(store);
// Add some extra metadata to the store
storeAddPredicate(store, 'https://www.example.org/ns/policy#mainSubject',topIds[0]);
storeAddPredicate(store, 'https://www.example.org/ns/policy#origin', inputData);
// Load the components we need for reasoning
const manager = await makeComponentsManager('./config.jsonld','.');
// Get a reasoner
const reasoner = await manager.instantiate('urn:koreografeye:reasonerInstance');
// Execute the reasoner (orch)
const resultStore = await reasoner.reason(store, rules);
// Execute the policies (pol)
const numOfErrors = await executePolicies(manager, resultStore);
console.log(`found ${numOfErrors} errors`);
}
Run this code with:
node demo.js
Run the orchstrator with one or more N3 rule files on an input directory of notifications.
bin/orch [options] rule [rule ...]
Options:
Run a policy executor on one of the output files of the orchestrator
bin/pol [options]
Options:
FAQs
A Solid choreography / orchestrator agent with a reasoning component
The npm package koreografeye receives a total of 53 weekly downloads. As such, koreografeye popularity was classified as not popular.
We found that koreografeye demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 3 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.