Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

The ability to authenticate as a user and connect to a Space can be implemented manually using calls to our API Functions.

However, in ~90% of cases that should be unnecessary. Instead all of that can be managed through the Cavrnus Spatial Connector object.

In this example, we will start with a basic single-user scene:

image-20240208-185029.pngImage Removed

To get started on making this a multi-user experience, you want to first select Cavrnus->Setup Scene for Cavrnus.

image-20240208-191200.pngImage Removed

This will add the Cavrnus Spatial Connector. This object will allow you to configure how users will authenticate and join spaces. It will also spawn a Cavrnus UI Canvas object to display UI under.

Note: There is nothing special about the Cavrnus UI Canvas. It is simply a way for the Cavrnus Spatial Connector to display UI on the screen. If you wish to spawn the UI under your own Canvas (say, for spatial XR) simply select your Canvas and hit Cavrnus->Spawn Cavrnus UI in Selected Canvas. This will redirect the Cavrnus Spatial Connector to use that, and clean up the old Cavrnus UI Canvas.

The Cavrnus Spatial Connector

The first thing to configure inside the Cavrnus Spatial Connector is your company’s URL. By signing up for Cavrnus you should have your own domain which contains all of your accounts and Spaces. Simply type it in.

image-20240208-192504.pngImage Removed

Authentication

Next, you need to decide how you want people to join your experience. You can choose to have them join as Guests or Members.

Guest Logic is only available on the Cavrnus Dev Servers at the moment. It is coming to production shortly as described here.

As with any Unreal plugin, adding the Cavrnus Spatial Connector is a simple 3 step process:

Image Added

My Server:

This is the domain you registered with Cavrnus when you configured your account. Enter your company’s URL in this field. (e.g. “CompanyName.cavrn.us” )

Authentication Method:

Specify whether Guests can join a space anonymously using a hyperlink, or if a login is required by an authorized team member in your domain.

AuthenticationMethod.pngImage Added

Guests can join automatically with no authentication.

However, they

This is recommended for delivering an experience to a wide audience, without the need for creating and managing a large number of temporary accounts.

  • Guests can only join spaces which

you
  • have

specifically configured to be available
  • been configured to allow guests to join. (See

Creating and Managing Spaces).

  • Guests can only access a Space through a hyperlink that has been provided to them.

These accounts also
  • These “guest accounts” can be used by multiple people simultaneously, but they do have a limited lifespan and will be deleted after

. This is recommended for delivering an experience to a wide audience who don’t want to bother creating and managing accounts.

To have your user automatically join as a Guest, select Guest Join Automatic. Then choose a name for that user. This is the fastest & easiest way of getting someone into Cavrnus.

image-20240208-195124.pngImage Removed

You can also allow a Guest to configure their own Name. Selecting Guest Join Manual will spawn a menu under whichever Canvas you are configured to use. This is just a simple menu to type your Name and Join. You can re-do this menu in your own style and have the Cavrnus Spatial Connector spawn yours instead.

image-20240208-194215.pngImage Removed

Members have accounts on your domain which you or they can create and manage. These accounts will persist, and can be given access to specific Spaces individually. This methodology is recommended for controlling access to private or sensitive information.

We give you the option to execute a Member login automatically by adding their email and password to the project. This option is useful
  • the duration expires.

Guest Login Method: Select a method to identify the Guest user with a name while in the Space.

GuestLoginMethod.pngImage Added

By selecting “Enter Name Below”, you can specify a name directly that will apply to all guests in the Space.

image-20240417-171440.pngImage Added

Select “Prompt to Enter Name” to trigger a prompt when the Guest first enters the space. Note that this requires a Blueprint Widget to be selected as the prompt that will display. A default widget is provided with the Cavrnus Plugin files, but you can also create your own custom design.

image-20240417-171817.pngImage Added
Note

Guest Login is only available on the Cavrnus Dev Servers at the moment. It is coming to production shortly as described above.

Members are authorized users who have login credential on your domain. This method is recommended for controlling access to private or sensitive information.

Member accounts are persistent, and can either be given access to all Spaces, or to specific Spaces individually. When selecting “Join as Member”, there are two options for entering login credentials.

image-20240417-174056.pngImage Added

Member Login Method: Select a method to identify the user as a Member with login credentials to verify access permissions to a Space.

Select “Prompt Member to Login” to trigger a prompt when the team member first enters the space. Note that this requires a Blueprint Widget to be selected as the prompt that will display. A default widget is provided with the Cavrnus Plugin files, but you can also create your own custom design.

image-20240417-174142.pngImage Added

This method is useful for automated testing and for delivering bespoke applications to specific individuals. However,

it

be mindful as this involves adding your password in plain text to your project

so be mindful when, say, committing these credentials

.

image-20240417-174447.pngImage Added

Note

Remember to delete login credentials from the CSC component when committing a project to a public

git repo.image-20240208-194735.pngImage Removed

The more common way of getting Members into your Application is by spawning a Login Menu with Login Manual. This lets them type in their own credentials and log in as themselves. As before, you can redo the Login Menu as you see fit and spawn your version instead.

image-20240208-194940.pngImage Removed

We also give you the option to save your Authentication Token locally on your device.

image-20240208-210529.pngImage RemovedJoining a Space

Git repo! If you accidentally push your login password to a public Git, be sure to change your password immediately.

Space Join Method:

If you have not yet created a Space for your users to join,

you can find the steps to do so here: Create a Cavrnus Space using the Web Console

create one now.

Once a User is authenticated, you can immediately place them inside a pre-defined Space. To do this, select Automatic as your Space Join Method. You must then get the ID of the Space you wish them to join.

This ID can be

fetched in the Web Console

copied by clicking

the “…” next to your Space and Copying the ID.
image-20240223-101515.pngImage Removed
image-20240223-101503.pngImage Removed

on the Join ID at the bottom of the Space thumbnail in the Spaces section of the Cavrnus Management Console.

image-20240417-175826.pngImage Added

You can then Paste

it

the Join ID into the given field.

image-20240208-211216.pngImage Removed
image-20240417-175940.pngImage Added

Alternatively you can simply present Users with a list of all the spaces they are currently allowed to join and let them pick one.

As before, you can customize this UI as you see fit.image-20240208-211355.pngImage Removed

Select “Spaces List” to trigger a prompt when the team member first enters the space. Note that this requires a Blueprint Widget to be selected as the prompt that will display. A default widget is provided with the Cavrnus Plugin files, but you can also create your own custom design.

image-20240417-180006.pngImage Added

Info

Note: A Cavrnus Space will often be filled with Properties pointing to specific paths within your application. Therefore, allowing users to just open any Space could result in them bringing down a Journal that is meant to be for a different application.

Example: One of your users has access to a Car Configurator Application which connects to the “Car Config” Space. They also have access to a Conference Room Application. Allowing them to join the “Car Config” Space from the Conference Room Application would give them a bunch of car-related Properties which their Application wouldn’t know what to do with

.

Space UI

Once your users connect to a Space they may want to see some menus appear. The Cavrnus Spatial Connector allows you to specify which UI to show both while the Space is Loading and once it is ready. We provide a few defaults (a Loading graphic, a Users Menu, and a Voice/Video Menu). You can modify/replace these and add your own at will. Loading Menus will, of course, be destroyed once the Space is connected

.

image-20240208-212150.pngImage Removed

Avatars and Co-Presence:

Avatars in Cavrnus are driven by the same Properties logic that governs the rest of the Space. As such, any Avatar you want to use will need to,

Avatar properties are synchronized the same way in a Cavrnus Space as any other asset. Therefor a pawn or character must, at a minimum, have a SyncTransform

script

component on it

or some other way of Binding/handling the “transform” Property to show

to synchronize the User’s movement. The Unique Container Name can be left blank

though,

because it will be automatically filled in by

our systems

the Cavrnus system for each individual user when spawned.

These

In addition to position, avatars can also send & receive

any

other custom properties

you want (

:

  • User Color

,
  • Left Elbow Transform

, etc).image-20240208-212804.pngImage Removed

To use a customized Avatar, simply drag & drop it into the Cavrnus Spatial Connector.

image-20240208-213138.pngImage Removed

To send your Co-Presence to other users, select the Local User’s rig and hit Cavrnus->Set Selected Object As Local User.

image-20240208-213238.pngImage Removed

This will automatically add a CavrnusLocalUserFlag to your character and a SyncTransform component to send your position across the wire. As with remote avatars you can send and receive as many custom properties as you would like. However, ensure that the Property Names match between the Local Rig and the Remote Avatar. If you are sending a property named “position” and their Remote User Avatar is listening for one named “transform”, you’re gonna have a bad time.

Spawnable Objects

If you want to spawn prefabs into your Scene at runtime, you will need to add them
  • Right hand socket

  • Laser state/color

  • and more …

Default Pawn Class

Just as any Unreal Engine project, you can define different pawns for the local and remote users. The local avatar is defined in the standard location in Unreal Editor, the Default Pawn Class in the GameMode.

To synchronize a user’s local position to display in other team member’s views, the local player pawn must have a SyncTransform_Character component to post it’s transform matrix to the Journal.

image-20240417-204117.pngImage Added

In the image above, the default BP_CavrnusPawn blueprint has been derived to create a custom character pawn. The SyncTransform_Character component is inherited from the parent and can be uniquely configured. Other Cavrnus components include the SyncLaserComponent, SyncPawnColor, and the NameTagWidget components, which appears above the character in the viewport. Each of these are necessary for synchronizing specific properties in the character, and are available in the Cavrnus Spatial Connector plugin folder.

Remote Avatar Class

The Remote Avatar Class is assigned in the CavrnusSpatialConnector instance placed in the level. This can use the same Character blueprint as the local user, or use a custom pawn.

image-20240417-180508.pngImage Added

Space UI

The Cavrnus Spatial Connector gives you complete control to customize the UI, both while the Space is Loading and once it is ready. The CSC plugin files include several default widgets to get you started, either to use directly or as a template to create your own:

  • Loading Screen graphic

  • Users Menu

  • Voice/Video Controls Menu

Info

Spawned menus, such as Loading Screens, will spawn at startup and will then be destroyed once the Space is connected.

image-20240417-205912.pngImage Added

Spawnable Objects

Blueprints can be spawned into the Scene at runtime to further customize the Cavrnus experience. These can be added to the Spawnable Objects list at the bottom of the

Cavrnus Spatial Connector. We offer a shortcut for this where you can right-click on the Prefab and select Cavrnus->Make Selection Spawnable.

CavrnusSpatialConnector instance.

image-20240208-235757.pngImage Modified

The Unique Id is what is stored in the Journal as the thing being spawned.

In theory, this means you could make changes to a prefab that already has Journal entries spawning its ID. This would mean anyone running with the new version of the application would see the new prefab get spawned in place of the old one.image-20240209-010253.pngImage Removed

Next Steps

At this point, hitting Play in Unity should Authenticate the user and place them in a Space, with all of the relevant UI being spawned in with them!

Now you can start synchronizing the various things inside your project!

You can do this by adding our

The use-case is that objects placed in the scene with this unique identifier can be swapped out with new, modified blueprints. The properties stored in the Journal would then be applied to this new blueprint as though it were the original.

image-20240417-210308.pngImage Added

ON THIS PAGE

Table of Contents
minLevel1
maxLevel2
outlinefalse
stylenone
typelist
printabletrue

Tip

Next Steps

Your level is now connected to a Cavrnus Space. If you run Play-In-Editor, the level will load into that space and you will be able to see the connection in the Session Analyzer. You’ll have Voice & Video capability, and see a user list with all of the other users in the Space. However, in the Session Analyzer you will only see the user logged in. You won’t see any property updates associated with your level.

Next, we will add No-Code Collaboration Components to automatically synchronize an object's Properties. That way they can be synchronized across multiple connections.

Alternatively, you can read up on more advanced techniques in our Developer Guide, or make calls directly using our API Reference.