FHIR Data Sharing analysis
The content on this page is based on the https://docs.google.com/document/d/1H3bhO2zhL2SuyIEU6RukPIea7h1pdQDHOQs1eeCSw7Q/edit . In particular this diagram of a decision tree:
We propose here an alternative decision mechanism to the above, based on the recognition that there are at least these independent dimensions, namely:
interactive v non-interactive
payload structure & semantics - bundle, message, collection, …
communication semantics - CRUD v transactional micro-service v querying v messaging
presentation /rendering - e.g. FHIR document v resource
In an initial attempt to separate these, we posit a 2-D decision table:
Business need | Protocol type | Interactive | Non-interactive | Applies to content |
---|---|---|---|---|
Generic data read/write
| CRUD
| FHIR REST | low volume -> FHIR REST ‘multi-CRUD’ possible | Resource-based |
Aggregated data exchange
| Business object
| FHIR Document API |
| FHIR document |
Business-level service
| Transactional service
| FHIR Operation(s)
| FHIR Operation(s) |
|
Querying
| Query service
| FHIR REST search | ?applications | Bundle (= set of Resource instances) |
Messaging i/f or system
| Messaging
| n/a | FHIR messaging
| all |
Here:
Protocol type is mode of communication, i.e. class of service interface;
Interactive / non-interactive are specific communication scenarios that can use various protocols to achieve different things;
The last column attempts to indicate which content types each row may apply to;
PK: pointed out the ‘version v end-point’ question.
We assume that:
‘FHIR document’ is a kind of content structure; requires Composition Resource; all have same behaviour;
a ‘message’ is not a content type as such, but a protocol-specific container (i.e. envelope) in the usual fashion into which the content of interest is put; header contains addressing info +/- some workflow processing;
CommunicationRequest is assumed to be a particular kind of content corresponding to a particular kind of interaction (LM: human-mediated authenticator needed)