Page MenuHomePhabricator

[web/lib/keyserver] avoid out of sync `updatesCurrentAsOf` between client and keyserver
ClosedPublic

Authored by kamil on Nov 28 2023, 7:39 AM.
Tags
None
Referenced Files
Unknown Object (File)
Sun, Jan 5, 7:50 PM
Unknown Object (File)
Sun, Jan 5, 1:39 AM
Unknown Object (File)
Sun, Dec 22, 8:38 AM
Unknown Object (File)
Sun, Dec 22, 8:38 AM
Unknown Object (File)
Sun, Dec 22, 8:38 AM
Unknown Object (File)
Sun, Dec 22, 8:38 AM
Unknown Object (File)
Sun, Dec 22, 8:38 AM
Unknown Object (File)
Sun, Dec 22, 8:38 AM
Subscribers

Details

Summary

This is fix to issue described in: ENG-5906.

In D9948 I started to persist updatesCurrentAsOf.
I also updated setInitialReduxState action to rely on rehydrated data when it's a staff user.
What I missed is updating currentAsOfPromise, which for updatesCurrentAsOf was using server time here.
This means that after reloading the app, the client (staff) has its own updatesCurrentAsOf from the previously received update (previous session) while the keyserver has newer updatesCurrentAsOf created while returning the initial state version.
This causes this condition to be true, and as a result was causing FULL_STATE_SYNC here which on prod kills the socket because of the amount of data to transfer.

This diff should make updatesCurrentAsOf synced between client and server.

This also fixes issue described here. Previously, when updatesCurrentAsOf was just started to be persisted, it gets rehydrated with undefined/0 value, this means after loading app all updates were started to be fetched. Right now if updatesCurrentAsOf is 0 we fetch everything in InitialReduxStateResponder and set updatesCurrentAsOf as serverTime.

This is only for staff, for standard users everything should work as previously.

Test Plan
  1. Reload app and make sure that there is no FULL_STATE_SYNC.
  2. Make sure updates work properly.
  3. Make sure updatesCurrentAsOf has correct value.
  4. Make sure policies logic (which is related to updatesCurrentAsOf value) works.

Diff Detail

Repository
rCOMM Comm
Lint
No Lint Coverage
Unit
No Test Coverage

Event Timeline

kamil held this revision as a draft.
kamil published this revision for review.Nov 28 2023, 8:02 AM
kamil added inline comments.
keyserver/src/responders/redux-state-responders.js
144–147

this might cause returning part of the data twice, here in responder and then via updates, but it was discussed in ENG-5316

web/redux/redux-setup.js
129–135

this can be removed, now in setInitialReduxState payload we get the proper value for both staff/non-staff users, which is persisted updatesCurrentAsOf on client or server time

web/types/redux-types.js
52

same as in D9949, it's safe to modify this

inka requested changes to this revision.Nov 29 2023, 2:11 AM

Doesn't this result in updates being sent for data that was already sent in initial redux state?

web/redux/initial-state-gate.js
46–48 ↗(On Diff #33948)

getInitialReduxState is already refactored for multiple keyservers. You have to select all updatesCurrentAsOf. You probably want to write a selector similar to cookiesSelector. Then in getInitialReduxState you have to use the correct updatesCurrentAsOf in every request

This revision now requires changes to proceed.Nov 29 2023, 2:11 AM

support multiple keyserver

web/redux/initial-state-gate.js
46–48 ↗(On Diff #33948)

good catch, I missed it, thanks

This revision is now accepted and ready to land.Nov 29 2023, 4:49 AM

Doesn't this result in updates being sent for data that was already sent in initial redux state?

It was explained in previous comments, sorry