<aside> đź’¬ This document is open for commenting.
</aside>
Shards communicate with each other a lot, during transaction execution and rebalancing. This communication requires authorization, because we don’t want for some other canisters or clients to be able to intervine into the protocol. This authorization has to be as efficient as possible, working without making additional inter-canister calls.
One solution would be to introduce some kind of collection, where all known shards are stored. Each shard would maintain a copy of such a collection and each time it receives an inter-canister call, it would look through this collection in order to identify the caller. This would solve the problem, but this solution has limitations:
union-db
, because of its “eventual” nature - there are no locks or mutexes, everything just happens when it’s ready, taking as much time as it needs to take. Having such an authorization list would mean, that we would have to stop processing new transactions, until the list is synchronized completely, each time a new shard is deployed.Technical details of this solution were also discussed here:
There is a better solution to this problem. Each shard has a ECDSA key pair and we could use these keys to build certificate chains! This public key and the principal of the root shard will be our root certificate. When a shard deploys another shard, it will also sign the public key and principal of the new shard with its own certificate, adding one more link to the chain. Then it will supply this data into the new shard as an initialization parameter.
When a shard makes a request to another shard, it will attach its whole certificate chain to that request. The verifier shard will validate three things:
These three checks is enough to be sure, that the remote caller is indeed a shard from the same database as the verifier shard.
<aside> 📖 We don’t need to sign the request itself, because it is already signed by our principal and this signature is checked automatically by the IC. But signing a request with this key would be useful, if we want to extend our database beyound the IC.
</aside>