Page MenuHomePhabricator

Add identity platform details to aux user store
ClosedPublic

Authored by marcin on Jun 4 2024, 1:18 AM.
Tags
None
Referenced Files
Unknown Object (File)
Sun, Jan 19, 10:27 PM
Unknown Object (File)
Sun, Jan 19, 10:27 PM
Unknown Object (File)
Sun, Jan 19, 10:27 PM
Unknown Object (File)
Sun, Jan 19, 10:27 PM
Unknown Object (File)
Sun, Jan 19, 10:27 PM
Unknown Object (File)
Sun, Jan 19, 10:27 PM
Unknown Object (File)
Sun, Jan 19, 10:27 PM
Unknown Object (File)
Sun, Jan 19, 7:28 AM
Subscribers

Details

Summary

This differential add identity platform details to aux user store and reducer

Test Plan

Flow. running reducer jest test.

Diff Detail

Repository
rCOMM Comm
Branch
arcpatch-D12283
Lint
No Lint Coverage
Unit
No Test Coverage

Event Timeline

marcin requested review of this revision.Jun 4 2024, 1:34 AM
lib/flow-typed/npm/tcomb_v3.x.x.js
122

I assume you tested and confirmed that tcomb can actually support this, yeah?

lib/types/identity-service-types.js
333–336

Why isn't this read-only?

lib/flow-typed/npm/tcomb_v3.x.x.js
122

Further diffs in this stack use enums.of validator for array of numbers when returning identity response to JS. Additionally without this change flow complained when I used enums.of for array of numbers and after this change it was fixed. Do you think we need additional validation for this change?

lib/types/identity-service-types.js
333–336

Clearly my oversight.

Make identity platform details type readonly

Those types are totally wrong. We need mapping from device id to platform details. Interestingly reducer worked as expected - it put map into the SQLite.

lib/flow-typed/npm/tcomb_v3.x.x.js
122

If later diffs use this validator and it works, then I think that is sufficient for testing

Fix types. Use a map of [deviceID]: IdentityPlatformDetails

kamil added inline comments.
lib/types/aux-user-types.js
13 ↗(On Diff #40984)

worth noting that all keys in this map are values in the devices array in RawDeviceList above - wondering if there is a better way to type this structure

This revision is now accepted and ready to land.Jun 6 2024, 1:23 AM
lib/types/aux-user-types.js
13 ↗(On Diff #40984)

I talked to @bartek about this and he would rather leave this type as it is. His reasons are:

  1. platofrmDetails property would need to be optional anyway since we can have device in device list for which we don't have platformDetails.
  2. In most cases we will only need the device list so having to do a map() each time we fetch data from aux_users would be less convenient.