-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathmellon-scenario.bs
331 lines (258 loc) · 16.3 KB
/
mellon-scenario.bs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
<pre class='metadata'>
Title: Mellon Orchestrator use cases
Shortname: orchestrator
Level: 2
Status: DREAM
Editor: Patrick Hochstenbach, [IDLab - Ghent University](https://knows.idlab.ugent.be), patrick.hochstenbach@ugent.be
Editor: Ruben Dedecker, [IDLab - Ghent University](https://knows.idlab.ugent.be), ruben.dedecker@ugent.be
Markup Shorthands: markdown yes
Abstract: TODO
</pre>
# Mellon Orchestrator use cases
# Glossary
Copied from [Orchestrator for a decentralized Digital Heritage Network](https://erfgoedpod.github.io/orchestrator/):
: <dfn export>Actor</dfn>
:: A entity (person, application or service) that participates in the network.
: <dfn export>Human Agent</dfn>
:: A person that operates directly as an [=Actor=] on the network.
: <dfn export>Autonomous Agent</dfn>
:: An intelligent software instance that operates on an [=Actor=]'s behalf but without any interference of that [=Actor=].
: <dfn export>Maintainer</dfn>
:: A [=Human Agent=] that can manually perform actions (see [[#actions]]) on the network using a [=Dashboard=] application.
:: Usually a person employed by an organisation (e.g., a Cultural Heritage Institution) to maintain data and datasets owned by that organisation.
: <dfn export>Data Pod</dfn>
:: As defined by [[solid-protocol]], a <a href="https://solidproject.org/TR/protocol#data-pod">Data Pod</a> is a place for storing documents, with mechanisms for controlling who can access what.
: <dfn>Inbox</dfn>
:: An [[!LDP]] resource where others can POST Linked Data Notifications [[!LDN]] in order to notify the actor of a change an artefact's lifecycle.
: <dfn>Artefact Lifecycle Event Log</dfn>
:: An HTTP resource served by an actor (e.g., as a resource in the [=Data Pod=]) that represents a log of lifecycle events that artefacts known by the actor were involved in..
:: Artefacts are considered known when they reside in the actor's [=Data Pod=] or if the actor has been made aware via [[!LDN]].
: <dfn export>Service Hub</dfn>
:: An [=Actor=] that provides a service to other actors in the network. It is a <a href="https://solidproject.org/TR/protocol#solid-app">Solid app</a> and serves an [=Inbox=].
: <dfn export>Policy</dfn>
:: A set of machine-readable business rules that instruct the [=Orchestrator=] on what actions to take in response to a trigger such as incoming notifications, perceived changes in the data, or manual invocation by an [=Actor=].
: <dfn export>Dashboard</dfn>
:: A user application and <a href="https://solidproject.org/TR/protocol#solid-app">Solid app</a> that enables users to interact with the contents of the [=Data Pod=], the [=Orchestrator=], or other [=Actors=] in the Digital Heritage Network.
New added terminology:
: <dfn export>Artefact</dfn>
:: An HTTP resource on a [=Data Pod=] that the subject of (Scholarly) Communication (e.g. a publication,
a review, a nanopublication, a dataset)
: <dfn export>Orchestrator</dfn>
:: An Orchestrator is an [=Autonomous Agent=] dedicated to an [=Actor=] that hosts a [=Data Pod=] with associated
[=Inbox=] and [=Artefact Lifecycle Event Log=]. It interprets and executes business rules described in a [=Policy=].
The Orchestrator watches the [=Inbox=] for possible triggers, records the actions it takes to the to the
[=Artefact Lifecycle Event Log=], and communications with other Actors.
: <dfn export>App</dfn>
:: An App is an [=Autonomous Agent=] dedicated to an [=Actor=] that hosts a [=Data Pod=]. The App can write to the
[=Data Pod=] unsupervised by the [=Human Agent=] and is not limited to the [=Inbox=] or [=Artefact Lifecycle Event Log=].
Issue: Need a better name for the App
# Difference between the Dashboard, App and Orchestrator
In the following discussion three agents communicate with the **Data Pod** with different privileges: the **Orchestrator**,
the **Dashboard** and the **App**. While in real applications these agents could overlap or might not be required at all (in
some cases), in this document they are treated as separate entities to help the discussion. Some reasons why
these Actors could be treated as separate entities:
- privileges needed to access the **Data Pod**
- requirements needed to receive direct feedback from a **Human Agent**
- requirements needed to permanently be **online**
- requirements needed to understand the **Scholarly Communication Notification protocol** and **Policies**
With this regard:
: App
:: The App is a headless Autonomous Agent that doesn't need a Human Agent to execute write operations on the Data Pod.
It is a trusted application for the Maintainer <s>that could in principle update any artifact on the Data Pod</s>. This application
could run as a background service on the computer of the maintainer and be online as long as the computer is connected
to a network.
: Dashboard
:: The Dashboard is an Agent that responds to feedback from an Human Agent. Typically this Dashboard runs in a browser
can be in an online or offline modus when a browser is running on the computer of the maintainer with one of the browser
tabs opened with the dashboard application.
: Orchestrator
:: The Orchestrator is an Autonomous Agent that can read the (Scholarly) **Inbox** of the **Data Pod** and append to
the **Artefact Lifecycle Event Log**. Guided by policies expressed as business rules, the **Orchestrator** also communicates with the Scholar Community network using
the **Scholarly Communication Notification protocol** implementing **Policies**.
<img src="images/mellon-orchestrator-solar.svg" width="40%">
The three Actors can be seen as a mini solar system with the **Data Pod** as the Sun. The **App** is a fully trusted agent that runs very near to
the data pod (in level of trust). The **Orchestrator** has very limited access rights to the data pod. The main
task of the Orchestrator is to update the event log and execute policies in order to talk the Scholarly Communication Notification
protocol (read/send messages from/to the corrrect Service Hubs).
The **Dashboard** sits in between, it has control over the **Data Pod** but might (always) need user input to update the pod.
Communication between the App/DashBoard and the Orchestrator happens via the Data Pod's Inbox.
The networks below demonstrates the CRUD privileges imagined for the different actors in this document. The first
network demonstrates a typical Solid setup where the Dashboard is a single page application that has direct access
to the Data Pod and the App is more a background process running in the same computer as the Maintainer.
<div><img src="images/mellon-crud-app.svg" width="80%"></div>
<i>CRUD operations in case the DashBoard is single-page application and the App a background task</i>
Issue: Are the Rules and Inbox necesearily part of the Data Pod or can they exist as separate resources?
The second network demonstrates a more classic setup with a browser Dashboard controlled by a server App which uses a
Data Pod as backend storage.
<div><img src="images/mellon-crud.svg" width="80%"></div>
<i>CRUD operations in case the Dashoard and App is a classic client/server application</i>
# Communication between Data Pod and Scholarly Community network
A2 Notifications can be sent from the researcher environment to **Service Hub** environments.
For instance, in case of a request to review an artefact that resides in the **Data Pod**, an
appropriate notification can be sent to a review **Service Hub**. The **Service Hub** can respond,
for example, accepting or rejecting the review request, and, in the latter case, to relay
the result of the review.
The **Orchestrator** sends notifications in response to triggers that result from the execution of
Policies - implemented as business rules - that are associated with the **Data Pod**. The **Orchestrator**
receives notifications in response to the ones it sent. The **Orchestrator** records information
contained in both outgoing and incoming notifications in the **Artefact Lifecycle Event Log**.
The AS2 notifications are regarded as a high-level approach to automatically coordinate the distributed
execution of the crucial functions of scholarly communication. The notifications merely ensure that the
respective functions are in effect executed as prescribed by Policies, but do not attempt to
automate the actual fullfilment of the function itself. For instance, when an `Offer` is sent to a Review Service
we don't envision that message contains all the steps to fully automate the submission process.
It could contain enough metadata for simple workflows. In general out of band communication
could be needed to perform all required steps.
All AS2 notifications are send to all **Actors** in the network in the form of [Linked Data Notifications](https://www.w3.org/TR/ldn/).
In this use case document we use 5 types AS2 notifications in line with the
[COAR Notify](https://notify.coar-repositories.org/patterns/) project.
: **Offer**
:: The `Offer` notification is used when one system offers one of its resources to
an other system to conduct some activity.
: **Undo**
:: The `Undo` notification is used to retract an offer made in a previous notification.
: **Accept**
:: The `Accept` notification is a response to an `Offer` made in a previous notification.
It indicates that the offer is accepted.
: **Reject**
:: The `Reject` notificaion is a response to an `Offer` made in a previous notification.
It indicates that the offer is rejected.
: **Announce**
:: The `Announce` notification is used to announce the outcome of an activity: typically
to announce the availability of a new (scholarly) artefact.
# Data Pod sends notifications to a Service Hub
Let's provide two examples how AS2 notifications can be sent out of the researcher environment
and generate some communication patterns out of these examples.
## Maintainer Announces a (finished) artefact in the Data Pod
<img src="images/mellon-scenario-1.svg" width="80%">
- The **Maintainer** decides, after a lot of work, that one artefact on the **Data Pod** is ready enter the scholarly realm
- The **Maintainer** uses the **Dashboard** to send an `Announce` Notification to the (Scholarly) **Inbox** of the **Data Pod**
- The **Orchestrator** polls the (Scholarly) **Inbox** of the **Data Pod** and discovers the `Announce` from the **Maintainer**
- We assume that the **Orchestrator** has capabilities to filter out all trusted notifications from the **Inbox** (validation,
signatures, shape matching, etc etc)
- The **Orchestrator** updates the **Lifecycle Event Log**
- The **Orchestrator** has a list of **Policies** what to do when a new `Announce` of a specific type arrives and
sends one or more AS2 notifications to one or more **Service Hubs** accordingly
Issue: This all assumes that the ServiceHub service doesn't send a 4** (for any reason, metadata, privileges, etc)
Issue: We need to determine what is required for an Orchestrator to be able to understand in which phase of an
artefact lifecycle it is dealing with. Also we will need some kind of typology for an artefact type itself,
eg paper, dataset, software, etc.
## Maintainer Offers an artefact in the Data Pod to a Service Hub
<img src="images/mellon-scenario-2.svg" width="80%">
- The **Maintainer** decides to send one artefact to an **Certificaton Service** to request a review
Issue: Herbert: This would typically be triggered by a notification sent from the Orchestrator to the Inbox
as a result of the execution of the Policy "once an artefact has entered the scholarly realm it should be certified".
The Maintainer can then decide whether or not to request review and where. I think it would be good to add this
to the pic as it nicely connects to the previous cases + illustrates policy
- The **Maintainer** prepares in the **Dashboard** the required metadata and sends an `Offer` Notification
to the (Scholarly) **Inbox** of the **Data Pod**
- The **Orchestrator** polls the (Scholarly) **Inbox** of the **Data Pod** and discovers the `Offer` from the **Maintainer**
- The **Orchestrator** updates the **Lifecycle Event Log**
- The **Orchestrator** sends the `Offer` to the **Certification Service**
- With `@id` the network location of the event log `https://bob.pod.org/events/cb7b1aed`
## Possible Policies
Possible policies that can be available for these use cases (using a pseudo policy language).
<div class="example">
The pseudo policy language used there tries to match new Notifications to a Shape , constructing
this shape with new properties, under specific conditions
```
<SHAPE>
<PROPERTIES>
when
<CONDITIONS>
```
</div>
Add only `Announce` and `Accept` notifications from the **Maintainer** to the **Event Log**
<div class="example">
```
mellon:AppendScholarlyRecord
a EventResource
a AppendResource
when
a Notification
isFrom(Maintainer)
inSet(Announce,Accept)
isOfType(Article,Review,Dataset)
```
</div>
Forward every `Announce` from the **Maintainer** to the institutional **Registation Service**
and **Archiving Service**
<div class="example">
```
mellon:ForwardToCatalog
a Notification
rdfs:label "Register at my library catalog"
target:
id: http://my.institution.org
ldp:inbox: http://my.institution.org/inbox
type: System
when
a Notification
isFrom(Maintainer)
inSet(Announce)
mellon:ForwardToArchive
a Notification
rdfs:label "Add to our archive"
target:
id: http://dataforever.edu
ldp:inbox: http://dataforever.edu/submission/new/inbox
type: System
when
a Notification
isFrom(Maintainer)
inSet(Announce)
```
</div>
Forward a notification from a **Maintainer** with a `cc` (e.g. an Offer) to an external *Service Hubs*.
<div class="example">
```
mellon:ForwardCC
a Notification
rdfs:label "Forward messages with a cc"
target:
id: @cc
when
a Notification
isFrom(Maintainer)
has(cc)
notEqual(cc,Maintainer)
```
</div>
## Orchestrator side effects
Based on the **Policies**:
- <s>The **Orchestrator** polls the **Inbox** for new notifications</s>
- The **Orchestrator** matches every new notificaton against the **Policies**
- This will result in zero or more matched policy shapes
- When the Shape matches an `mellon:EventLogRecord` then a new EventLog is created
- When the Shape matches an `mellon:ForwardMessage` then a new AS2 notification is sent.
# Service Hub sends notifications to Data Pod
## Service Hub Announces a new resource about an artefact in the Data Pod
### Service Hub Announce is a response to a previous Offer
For example, a **Maintainer** request that a journal reviews on of the publications
that can be found on the **Data Pod**. In a previous step an `Offer` was sent to
to journal as **Certification Service**. In response to the `offer` the journal sends
an `Announce` to the (Scholarly) **Inbox** of the **Data Pod**.
<img src="images/mellon-scenario-3.svg" width="80%">
- The **Orchestrator** finds in the (Scholarly) **Inbox** of the **Data Pod** an `Announce` notification
- The `Announce` contains an `inReplyTo` property to a previous `Offer`
- The **Orchestrator** validates the `Offer` against the **Event Log**
- The **Orchestrator** updates the **Lifecycle Event Log** with the AS2 notification
Issue: Is this a verbatim copy of the AS2 notification or a processed version?
### Service Hub Announce is standalone
For example, an overlay journal adds an article it found in an **Data Pod**, via the WebID
of the author, the journals sends an `Announce` notification to the (Scholarly) **Inbox**
of the **Data Pod**.
<img src="images/mellon-scenario-4.svg" width="80%">
- The **Orchestrator** finds in the (Scholarly) **Inbox** of the **Data Pod** an `Announce` notification
- The `Announce` doens't an `inReplyTo` property to a previous `Offer`
- The **Orchestrator** ignores the notification but does not remove it from the **Inbox** because
it pertains to the URI of a scholarly artefact in the **Data Pod**.
- The **Maintainer** finds via the **Dashboard** the standalone `Announce` in the (Scholarly) **Inbox**
- The **Maintainer** sends an `Accept` with an `inReplyTo` to the `Announce` to the (Scholarly) **Inbox**
- The **Orchestrator** finds both the old `Announce` notification and new `Accept` notification
- The **Orchestrator** has a **Policy** that when both notifications match, they can be written
to the **Lifecycle Event Log**
## Possible Policies
# Acknowledgement
We thank Herbert Van de Sompel, [DANS + Ghent University](https://dans.knaw.nl/nl/), hvdsomp@gmail.com
for the valuable input during this project.