mirror of
https://github.com/corda/corda.git
synced 2025-01-18 18:56:28 +00:00
01728e5a47
* Network map client - WIP * Java doc and doc for doc site * remove javax.ws dependency * NetworkParameter -> NetworkParameters * move network map client to node * Fix jetty test dependencies * NetworkParameter -> NetworkParameters * Address PR issues * Address PR issues and unit test fix * Address PR issues
3.4 KiB
3.4 KiB
Network Map
Protocol Design
The node info publishing protocol:
- Create a
NodeInfo
object, and sign it to create aSignedData<NodeInfo>
object. TODO: We will need list of signatures inSignedData
to support multiple node identities in the future. - Serialise the signed data and POST the data to the network map server.
- The network map server validates the signature and acknowledges the registration with a HTTP 200 response, it will return HTTP 400 "Bad Request" if the data failed validation or if the public key wasn't registered with the network.
- The network map server will sign and distribute the new network map periodically.
Node side network map update protocol:
- The Corda node will query the network map service periodically according to the
Expires
attribute in the HTTP header. - The network map service returns a signed
NetworkMap
object, containing list of node info hashes and the network parameters hashes. - The node updates its local copy of
NodeInfos
if it is different from the newly downloadedNetworkMap
.
Network Map service REST API:
Request method | Path | Description |
---|---|---|
POST | /api/network-map/publish | Publish new NodeInfo to the network map service, the legal identity in NodeInfo must match with the identity registered with the doorman. |
GET | /api/network-map | Retrieve NetworkMap from the server, the NetworkMap object contains list of node info hashes and NetworkParameters hash. |
GET | /api/network-map/node-info/{hash} | Retrieve NodeInfo object with the same hash. |
GET | /api/network-map/parameters/{hash} | Retrieve NetworkParameters object with the same hash. |
TODO: Access control of the network map will be added in the future.