Page MenuHomePhabricator

[keyserver] Tunnelbroker integration - Adding Tunnelbroker publisher and connector
Needs RevisionPublic

Authored by max on Mar 1 2023, 6:43 AM.
Tags
None
Referenced Files
F3832757: D6923.diff
Sun, Jan 19, 5:59 PM
Unknown Object (File)
Fri, Jan 10, 8:50 AM
Unknown Object (File)
Fri, Jan 10, 8:50 AM
Unknown Object (File)
Tue, Jan 7, 11:14 AM
Unknown Object (File)
Sun, Jan 5, 1:51 PM
Unknown Object (File)
Thu, Jan 2, 1:11 AM
Unknown Object (File)
Thu, Jan 2, 1:08 AM
Unknown Object (File)
Tue, Dec 31, 9:18 AM
Subscribers

Details

Reviewers
ashoat
atul
Summary

This diff adds a singleton class for a publisher in the Tunnelbroker client integration into the Tunnelbroker. The publisher class uses connect() method to make a connection to the Tunnelbroker for the publisher. This approach is inspired by our Redis approach with the changes that we are connecting to the Tunnelbroker ahead of time (on server start) instead of on publishing like in the Redis implementation. I think it's a good way to make a connection ahead of time, but this can be changed if reviewers think otherwise.

Linear task: ENG-2613

Test Plan
  1. Start the tunnelbroker instance by running cd services/tunnelbroker && cargo run.
  2. Connect to the tunnelbroker messages stream by the gRPC client with the deviceID A.
  3. Add a simple publish to the keyserver.js:
import { tunnelbrokerPublisher } from './socket/tunnelbroker.js';
...
tunnelbrokerPublisher.publish('A','Some test data');
  1. Start the keyserver using the cd keyserver && yarn dev.
  2. The expected result is that the message is published and delivered to the gRPC client which is connected as a deviceID A.

Diff Detail

Repository
rCOMM Comm
Branch
tb-add-publisher
Lint
No Lint Coverage
Unit
No Test Coverage

Event Timeline

max held this revision as a draft.
max published this revision for review.Mar 1 2023, 6:55 AM
max edited the summary of this revision. (Show Details)
max edited the test plan for this revision. (Show Details)
max added reviewers: ashoat, atul.
ashoat requested changes to this revision.Mar 1 2023, 8:29 PM
ashoat added inline comments.
keyserver/src/keyserver.js
174

Why aren't we awaiting this?

Is this call necessary here if lazily initialize and apply my suggestion on line 27 of tunnelbroker.js below?

keyserver/src/socket/tunnelbroker.js
11
17

What does this return; statement do?

27

Wouldn't we want to await this and skip the return on the next line?

This revision now requires changes to proceed.Mar 1 2023, 8:29 PM

Thought about this a bit more. We need to make sure that we don't accidentally initialize two tbClientBinding, but TunnelbrokerPublisher.connect is an async function, which makes this difficult to guarantee.

@atul had a similar problem recently with initializing Olm, which also is an async function. I think there are two ways forward here:

  1. What @atul did in D6901: force every thread to wait for connect to complete before starting up. This requires an await to make sure the connect completes before anything attempts to call publish (which could trigger a race with a second connect).
  2. What I suggested in this comment on D6897: you could assign the promise to a variable, and then whenever a second connect attempt comes in, see if the promise variable is already set, and if it is just return that.

Option 1 is probably simpler, and will be the easiest way to unblock this work.