Skip to content

SSL Site for Multiuser XR

Charles Forman edited this page Apr 23, 2020 · 6 revisions

SSL Site for Multiuser XR

We need to create a hosted secure service to negotiate a connection between Shot Generator as a host, and the VR headset or AR client phone. The other benefit of this system is that multiple users will be able to manipulate a scene in other locations or even other countries! Currently, we do a direct connection with a self-signed certificate. This gives a nasty warning, and is kinda janky.

Screen Shot 2020-04-22 at 11 19 11 PM

Server setup:

link.wonderunit.com: heroku server running peerjs-server

Static Host

stbr.link s3 static site that serves: index.html / xrclient.js

Flow:

User wants to use XR to edit a scene...

  1. User clicks the VR button in Shot Generator (it will not connect without clicking the button)
  2. Shot Generator will generate an ID: 4 digit alphanumeric (Example: 9h5b)
  3. Shot Generator will connect to link.wonderunit.com via PeerJS and connect to the ID
  4. If the ID is already in use (There is another host is there, very very unlikely), it will generate and connect to a new ID.
  5. Shot Generator will display the link to the XR session: https://stbr.link/9h5b
  6. Wait for the XR client to connect...

User puts on VR headset...

  1. User clicks on browser
  2. Types in URL: stbr.link/9h5b (defaults to https)
  3. Javascript xrclient loads
  4. JS client gets the ID from the URL: 9h5b
  5. JS client connects to link.wonderunit.com via PeerJS and connect to the ID
  6. If the host is not there, show information: a page that explains there is no host, what to do (press the button, check internet)
  7. If the host is there, they are connected Peer to Peer
  8. JS client gets information from the host to see if it can still connect (how many clients can be in there?)
  9. User clicks "Enter VR"

User wants to enter AR on their phone...

  1. User opens chrome on android phone (for now)
  2. Types in URL: stbr.link/9h5b (defaults to https)
  3. ... same as above ...
  4. User clicks "Enter AR"

Remote Collaboration

Main Storyboarder owner will open Shot Generator and click the VR button. This will produce a link. They can send this link to another person over chat/zoom/email/fb and that person can join the VR scene in their VR Headset or Phone! Or if they don't have those, they can just watch the Control Center.

Usability

It sucks having to always type in a new ID in the headset. So once the ID is assigned, Storyboarder will reuse that ID. This way, you can bookmark the link on your Quest or Phone.

Security Concerns

When you are connected to VR, if someone has your ID, they can connect to your scene. Therefore, if you didn't want anyone to connect to your scene for your future sessions, you can change the ID in Shot Generator. It will generate a new ID and make a new connection. Also, you can set your ID's length in the preferences. We default to 4 digits:

  • 4 digit alphanumeric: (26+10)^4 = 1 in 1,679,616 uniqueness
  • 5: 1 in 60,466,176
  • 6: 1 in 2,176,782,336
  • 7: 1 in 78,364,164,096

The more digits, the more security through obscurity. When Shot Generator is closed, or if the VR button is never clicked, no one can connect to your host.

You can also set in preferences to refresh the ID every time you click the VR button.

Clone this wiki locally