Presence
Share state between users with Realtime Presence.
Let's explore how to implement Realtime Presence to track state between multiple users.
Usage#
You can use the Supabase client libraries to track Presence state between users.
Initialize the client#
Go to your Supabase project's API Settings and grab the URL
and anon
public API key.
Sync and track state#
Listen to the sync
, join
, and leave
events triggered whenever any client joins or leaves the channel or changes their slice of state:
Sending state#
You can send state to all subscribers using track()
:
A client will receive state from any other client that is subscribed to the same topic (in this case room_01
). It will also automatically trigger its own sync
and join
event handlers.
Stop tracking#
You can stop tracking presence using the untrack()
method. This will trigger the sync
and leave
event handlers.
Presence options#
You can pass configuration options while initializing the Supabase Client.
Presence key#
By default, Presence will generate a unique UUIDv1
key on the server to track a client channel's state. If you prefer, you can provide a custom key when creating the channel. This key should be unique among clients.