General
business-level description:
- A particular set of government services and processez is provided by
agencies in different sectors reporting to different ministries, that have
their own (very large) private networks. Dozens of MSHs in various
sectors, with some MSHs serving dozens or hundreds of parties. In total
a few thousand parties.
Topology:
- Within a sector, agencies communicate via an
intermediary. There is never any Endpoint to Endpoint communication. The
intermediary is also the connection to agencies in other sectors (via
their sector intermediary). Each intermediary knows whether the
addressed To/PartyId is connected to itself (two hops) or is connected to some
other sector hub (more than two hops).
Routing
function:
- some intermediaries are also Endpoints (sector hubs, hosting sector
services). They inspect the eb:Service to determine if they
provide this service themselves (possibly on behalf of many different
organizations), or need to forward the message to a separate
MSH.
- when (not delivering locally but) forwarding,
forwarding is based on ebMS header content: eb:To/eb:PartyId.
Communication
constraints:
- Branches are not
addressable. Can only push, or pull. The branches only use One-way / Push MEPs
for invoking the servers. Need to pull the "Signals".
- Sometimes a business partner is first connected as an
Endpoint to an intermediary, then later a Intermediary is inserted. This
should not require any changes at the Endpoints other than changing the URL
and TLS details.
An intermediary should
not have to know if the MSH it is connecting to is the Endpoint for the
message, or an Intermediary that forwards it.
- PartyIds may move from one Endpoint MSH to another.
Only the closest intermediary should have to take action to account for that
change. No other intermediary or Endpoint should need to know (as they will
still receive messages from, and send to, the same
intermediary).
- Some intermediaries are also