Description
Following up from #1074, if you attempt to PATCH a node's identity profile for say a cert rotation:
PATCH /api/v1/identities/{iid}
{
"profile": { "cert": "..." }
}
This will update a raw string / JSON column in the identities
table and be broadcasted on the blockchain + IPFS. This profile is then fed to each FireFly who passes it to the FFDX plugin:
firefly/internal/dataexchange/ffdx/ffdx.go
Lines 343 to 348 in fd542c0
So if the profile omits an id
, then it will PUT /api/v1/peers
rather than PUT /api/v1/peers/{id}
. This will error depending on your DX implementation. If your FireFly is then restarted, the namespace will be stuck initializing
due to the errors for example:
[2024-01-23T04:06:03.482Z] DEBUG ==> PUT https://some-dx:3000/api/v1/peers/ breq=KqvrqLx4 dx=https pid=1
[2024-01-23T04:06:03.484Z] ERROR <== PUT https://some-dx:3000/api/v1/peers/ [404] (1.93ms) breq=KqvrqLx4 dx=https pid=1
And so, we need to 1) put protections on the PATCH profile to ensure all the data is either always provided or better yet it JSON patches (or some other merge strategy) the profile with the existing one, 2) determine if a namespace should stay in initializing or not if one of the DX peers cannot be added.