Page MenuHomePhabricator

[client-backup] implement API call to get BackupID
ClosedPublic

Authored by kamil on Aug 29 2023, 2:15 AM.
Tags
None
Referenced Files
Unknown Object (File)
Sat, Jan 11, 6:48 PM
Unknown Object (File)
Fri, Jan 10, 3:29 AM
Unknown Object (File)
Thu, Jan 9, 10:18 PM
Unknown Object (File)
Thu, Jan 9, 10:12 PM
Unknown Object (File)
Thu, Jan 9, 1:56 PM
Unknown Object (File)
Mon, Jan 6, 2:12 AM
Unknown Object (File)
Mon, Jan 6, 2:12 AM
Unknown Object (File)
Mon, Jan 6, 2:12 AM
Subscribers

Details

Summary

Call without auth to get latest BackupID.

Depends on D8993

Test Plan

Call this with mock data and verify it's lastly uploaded backupID

Diff Detail

Repository
rCOMM Comm
Branch
client-backup
Lint
No Lint Coverage
Unit
No Test Coverage

Event Timeline

kamil held this revision as a draft.
kamil added inline comments.
native/backup/api.js
74 ↗(On Diff #30473)

it was generated and sent as string do we can be confident is decodable

kamil published this revision for review.Aug 29 2023, 3:17 AM
native/backup/api.js
58 ↗(On Diff #30473)

Why isn't this one authenticated?

native/backup/api.js
58 ↗(On Diff #30473)

Both "backups/latest/" endpoints (one for fetching backupID and one for fetching user keys) will be used in the primary device restoration flow.
When the primary device restores from backup we only know username and password (or eth equivalent) that user put in. But to authenticate with the identity service we need to first download userKeys and decrypt them. So we can't require authorisation for backupID and userKeys.

After decrypting userKeys the device can authenticate with the identity service. Then it can download the userData (which requires authentication).

72–75 ↗(On Diff #30473)

I might be missing something but isn't there just like response.json() method?

use json()

native/backup/api.js
72–75 ↗(On Diff #30473)

right! updating

This revision is now accepted and ready to land.Aug 29 2023, 9:08 AM