Is there a way to say that all clients know about this object, so only post changes, not that it exists?

(I’m new to Coherence and only used it for about 2 days)

In my game, I have doors, gates and a variety of other objects that can change their state, but have a default state in the game. I.e. there may be thousands of these in game. I.e. what I’m looking for is that the server would be completely unaware of the object when it is loaded in its default state. However, if a player opens a door, I want that state to be propagated between all clients who come into that area. And once the door is closed, I want to delete its state from the server, while keeping the object.

I.e. there is no reason to keep thousands of door states, light states, power up positions, etc shared on the server, when no one needs it. These objects always exist, but just have a state that can temporarily change away from default.

You might consider not using CoherenceSync on these objects individually, and instead use category managers. Like a door manager which does have a CoherenceSync but has no renderable. The manager would know about all the doors and could have synced booleans for the state of the door. So to open a door a client sends a command to the manager to open door X the authority over the manager then changes the state of door X to open and that is replicated to the clients and the door opens.

This has the advantage of significantly reducing the number of sync objects but still supports tons of doors with infrequent updates.

There’s only one gotcha to what you are imagining, Dan.

Having state that only one player knows about, whatever that is, means that as soon as that player is gone information about that state also disappears, because no one had it noted down.
So it really depends on the type of game, session length etc. but in general, having a door that I (player 1) open but don’t tell anyone (not even the Replication Server!) means that that door is not really networked, but more of an offline object.

Said this, whether you want to make it an independent network entity (with its own CoherenceSync) or list its state in a manager (like Cary suggests) that’s a step two in the discussion :slight_smile:

Happy to discuss more about this, if you share more details about the gameplay and session structure! Love these conversations that border between tech and design :slight_smile: