Inherit active secret when exchanging

This commit is contained in:
freddygv 2022-08-03 17:32:53 -05:00
parent 60d6e28c97
commit 8067890787
2 changed files with 11 additions and 5 deletions

View File

@ -265,6 +265,9 @@ func (s *Store) peeringSecretsWriteTxn(tx WriteTxn, req *pbpeering.PeeringSecret
}
case pbpeering.PeeringSecretsWriteRequest_OPERATION_EXCHANGESECRET:
// Avoid invalidating existing active secrets when exchanging establishment secret for pending.
secret.Stream.ActiveSecretID = existing.GetStream().GetActiveSecretID()
// When exchanging an establishment secret we invalidate the existing establishment secret.
if existingEstablishment := existing.GetEstablishment().GetSecretID(); existingEstablishment != "" {
toDelete = append(toDelete, existingEstablishment)

View File

@ -484,7 +484,8 @@ func TestStore_PeeringSecretsWrite(t *testing.T) {
Secrets: &pbpeering.PeeringSecrets{
PeerID: testFooPeerID,
Stream: &pbpeering.PeeringSecrets_Stream{
PendingSecretID: testSecretOne,
ActiveSecretID: testSecretOne,
PendingSecretID: testSecretTwo,
},
},
},
@ -493,8 +494,8 @@ func TestStore_PeeringSecretsWrite(t *testing.T) {
Secrets: &pbpeering.PeeringSecrets{
PeerID: testFooPeerID,
Stream: &pbpeering.PeeringSecrets_Stream{
// Two replaces One
PendingSecretID: testSecretTwo,
// Three replaces two
PendingSecretID: testSecretThree,
},
},
Operation: pbpeering.PeeringSecretsWriteRequest_OPERATION_EXCHANGESECRET,
@ -502,10 +503,12 @@ func TestStore_PeeringSecretsWrite(t *testing.T) {
expect: &pbpeering.PeeringSecrets{
PeerID: testFooPeerID,
Stream: &pbpeering.PeeringSecrets_Stream{
PendingSecretID: testSecretTwo,
// Active secret is not deleted until the new pending secret is promoted
ActiveSecretID: testSecretOne,
PendingSecretID: testSecretThree,
},
},
expectUUIDs: []string{testSecretTwo},
expectUUIDs: []string{testSecretOne, testSecretThree},
},
{
name: "promote pending secret and delete active",