Page MenuHomePhabricator

[native] create Tunnelbroker session
ClosedPublic

Authored by kamil on Oct 26 2023, 9:14 AM.
Tags
None
Referenced Files
Unknown Object (File)
Mon, Dec 30, 1:22 AM
Unknown Object (File)
Sat, Dec 28, 12:43 PM
Unknown Object (File)
Thu, Dec 26, 5:12 AM
Unknown Object (File)
Wed, Dec 25, 7:20 PM
Unknown Object (File)
Fri, Dec 20, 9:05 PM
Unknown Object (File)
Fri, Dec 20, 5:50 PM
Unknown Object (File)
Sun, Dec 15, 4:02 PM
Unknown Object (File)
Sun, Dec 15, 5:50 AM
Subscribers

Details

Summary

Create a diff that gathers the necessary data to establish a proper socket connection and begins to use the context.

Depends on D9609

Test Plan

Use mock credentials (credentials that I manually added to Identity as a valid user) and verify if a session was created.

Screenshot 2023-10-26 at 18.12.54.png (40×690 px, 12 KB)

Diff Detail

Repository
rCOMM Comm
Branch
tunnelbroker
Lint
No Lint Coverage
Unit
No Test Coverage

Event Timeline

kamil held this revision as a draft.
kamil published this revision for review.Oct 27 2023, 5:38 AM
native/utils/tunnelbroker-utils.js
3 ↗(On Diff #32453)

We generally prefer import * as React from 'react

native/root.react.js
282 ↗(On Diff #32453)

Is createTunnelbrokerSocket the same between native and web? If yes why aren't we using it directly in the TunnelbrokerProvider?

native/utils/tunnelbroker-utils.js
15–20 ↗(On Diff #32453)

Could you explain why there is a difference between native and web when it comes to the init message?

address review

native/root.react.js
282 ↗(On Diff #32453)

I wanted to follow the pattern from keyserver <> client socket when you have a separate function for this which can act differently, but actually, it makes sense to put this code in TunnelbrokerProvider

native/utils/tunnelbroker-utils.js
3 ↗(On Diff #32453)

right, my IDE automatically adds import React from 'react'; and forgot to change it

15–20 ↗(On Diff #32453)

On the web deviceID is in redux, on native it's in SQLite, this is the only difference (despite deviceType which is obvious).

This difference leads to different code needed to retrieve deviceID and as an effect different ways of creating ConnectionInitializationMessage

native/utils/tunnelbroker-utils.js
15–20 ↗(On Diff #32453)

Are we going to be moving the deviceID to SQLite on web? Will we be able to just have one logic for both platforms? If yes than we should probably add a note to the task about this.

native/utils/tunnelbroker-utils.js
15–20 ↗(On Diff #32453)

I don't think so, it's actually more than just <where to store> deviceID.

DeviceID is strongly related to the olm's account - we have olm on native in C++ while on the web this is NPM package, so I think as soon as this looks like this we have differences here. It is better to continue retrieving deviceID from JS olm version which is the source of truth than moving this to SQLite.

This revision is now accepted and ready to land.Nov 2 2023, 9:00 AM
This revision was automatically updated to reflect the committed changes.