GameSession - stingray.GameSession object reference - Stingray Lua API Reference

stingray.GameSession object reference

Description

The GameSession object is responsible for replicating and synchronizing game objects between the peers that participate in a networked game session.

You get a new game session by calling Network.create_game_session().

To the GameSession, a game object is just a table of fields (keys and values) identified by an ID. When you create a game object, you become its owner, and you get back an ID that you can use to manipulate the object. As owner, you can change the values of the object fields. The changes you make get replicated to all other peers. If you delete the object, that too gets replicated.

Game objects can have different types. Each type has its own set of keys and values, which you define in the .network_config data file.

Typically, game objects represent something in the game world, such as units, physical bodies, etc., but the GameSession layer does not care about that. It is the responsibility of the user to move data back and forth between the network game objects and the real world entities. The GameSession is responsible only for notifying other peers about changes to the state of the fields in the game objects.

Ownership of game objects can be moved between peers in the session. This can be used to set up network load balancing, or to get a better fidelity of the play experience (the owner of an object does not have to worry about lag or synchronization problems when interacting with it).

When a remote node has created, destroyed or migrated a game object, you get notified by a callback to the callback object that you provided to Network.update(). See the Network.update() description for details.

Replay Sessions

In development builds, you can replay a network game session by calling the Network.create_replay_session() function, and passing that function a network log file created during a previous game session. In a replay session, the GameSession object functions exactly as it did in the original game session -- it responds to all of the network events stored in the log file as if they were just executed by connected clients -- and you can call the same functions to control the game session. However, since the network events are all recorded, you can test and re-test exactly the same sequence of actions carried out by the remote peers. This may help you diagnose problems with your networked games.

The main difference between a regular game session and a replay session is that in a regular game session the network callback object is not notified of your own changes; however, in a replay session, the network callback object receives callback notifications of all game object changes, regardless of which peer initiated the action.

In addition, the synchronization state for peers does not exist in replay sessions, since you are only observing and not transmitting yourself.

Note that this feature is experimental.

Setting up a replay session

To create a replay session:

  1. Set up your game's settings.ini file to record network activity to a log file. For example:
network = {
log = "%APPDATA%\\Company\\Project\\network_dumps\\network-%DATE%-%TIME%-%RANDOM%.ndp"
}
  1. Create a log by playing through a regular networked game session.

  2. After closing the session, call Network.create_replay_session(log_filename) to create a replay session based on the events recorded in the network log file.

  3. Play through the replay session, calling Network.update() every frame as usual.

  4. When you are done, close the replay session by calling Network.shutdown_replay_session() instead of Network.shutdown_game_session().

Host

Functions that can be called by the game session host.

Parameters

self :

stingray.GameSession

Specifies the object instance that this function will act on.

You may use the colon : calling syntax to call this function on an instance of this object. If you do so, you must omit this parameter. For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.

peer_id :

string

The ID of the peer you want to add to the session.

Returns
This function does not return any values.

Only the session host can add peers.

Parameters

self :

stingray.GameSession

Specifies the object instance that this function will act on.

You may use the colon : calling syntax to call this function on an instance of this object. If you do so, you must omit this parameter. For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.
Returns
This function does not return any values.

You can only call this on a session that was just created, and that has no other peers in it. The host of the session is the only one that can add peers to or remove peers from the session.

When you call this function, you automatically also join the session.

Parameters

self :

stingray.GameSession

Specifies the object instance that this function will act on.

You may use the colon : calling syntax to call this function on an instance of this object. If you do so, you must omit this parameter. For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.

peer_id :

string

The ID of the peer you want to remove from the session.

callback_object :

table

An object that will be notified through a callback function for each game object owned by the removed peer that is destroyed when the peer is removed.

Returns
This function does not return any values.

Only the session host can remove peers.

Removing a peer may cause game objects owned by that peer to be destroyed. For each destroyed game object, the following function is called on the callback object you pass to this function.

  • game_object_destroyed(id, destroyer_id)

Notifies you that the game object identified by id was destroyed by peer destroyer_id.

This is the same as the game_object_destroyed() callback function that can be invoked by Network.update(), so you may be able to use the same callback object you provide to the Network.update() function when you call GameSession.remove_peer().

Parameters

self :

stingray.GameSession

Specifies the object instance that this function will act on.

You may use the colon : calling syntax to call this function on an instance of this object. If you do so, you must omit this parameter. For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.
Returns
This function does not return any values.

Host migration

Functions that involve changes to the host.

Parameters

self :

stingray.GameSession

Specifies the object instance that this function will act on.

You may use the colon : calling syntax to call this function on an instance of this object. If you do so, you must omit this parameter. For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.
Returns
This function does not return any values.

Note that unlike leave(), which attempts to inform the host that the peer is leaving the session, this call will leave the session without informing the host. Since it is intended to be called when there is a host error, there is no point in informing the host that we are leaving.

Note that just like with leave(), calling disconnect_from_host() is a request to be disconnected. The disconnect doesn't happen immediately, but during the next network update.

Parameters

self :

stingray.GameSession

Specifies the object instance that this function will act on.

You may use the colon : calling syntax to call this function on an instance of this object. If you do so, you must omit this parameter. For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.
Returns

boolean

Returns true if an error has occurred communicating with the session host, or false otherwise.

You should handle the error either by calling disconnect_from_host() to shut down your game session, or by calling migrate_game_session_host() on one of the peers to have that peer assume the role as host.

Parameters

self :

stingray.GameSession

Specifies the object instance that this function will act on.

You may use the colon : calling syntax to call this function on an instance of this object. If you do so, you must omit this parameter. For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.
Returns
This function does not return any values.

You are only allowed to call this if the communcation with the current host is broken: i.e. if host_error() returns true.

In a session with multiple peers, only one of the peers should call migrate_game_session_host(), since a session cannot have multiple hosts. The recommended way of solving this is to have all peers compare their peer ID, which is accessible through Network.peer_id(), to the list of all peers in the session, which is accessible through GameSession.peers(). The peer with the lowest peer ID should then call migrate_game_session_host() to assume the role of host.

Game objects

Functions that involve creating and managing game objects.

Parameters

self :

stingray.GameSession

Specifies the object instance that this function will act on.

You may use the colon : calling syntax to call this function on an instance of this object. If you do so, you must omit this parameter. For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.

type :

string

The type of game object to create, as configured in the .network_config data file.

fields :

table

A table that contains starting values for the new object's data fields.

Returns

integer

A unique ID for the newly created game object.

The fields table provides starting values for the data fields maintained by the game object. The members that you can set up in this table are determined by the fields you have configured for this type of game object in the .network_config data file. For example:

myGameObject = stingray.GameSession.create_game_object(mySession, "enemy", { position = Vector3(0,0,0), hitpoints = 50 } )
Parameters

self :

stingray.GameSession

Specifies the object instance that this function will act on.

You may use the colon : calling syntax to call this function on an instance of this object. If you do so, you must omit this parameter. For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.

object_id :

integer

The ID of the game object to destroy.

Returns
This function does not return any values.

This function can only be called by the peer that owns the game object.

Parameters

self :

stingray.GameSession

Specifies the object instance that this function will act on.

You may use the colon : calling syntax to call this function on an instance of this object. If you do so, you must omit this parameter. For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.

object_id :

integer

The ID of the game object to test.

Returns

boolean

Returns true if an object with the specified ID exists in the session, or false otherwise.

Parameters

self :

stingray.GameSession

Specifies the object instance that this function will act on.

You may use the colon : calling syntax to call this function on an instance of this object. If you do so, you must omit this parameter. For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.

object_id :

integer

The ID of the game object whose value will be retrieved.

field :

string

The name of the field whose value you want to retrieve.

Returns

any

The value currently stored in the specified field of the game object. The type of this value depends on the data type configured for the field in the .network_config data file.

Parameters

self :

stingray.GameSession

Specifies the object instance that this function will act on.

You may use the colon : calling syntax to call this function on an instance of this object. If you do so, you must omit this parameter. For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.

object_id :

integer

The ID of the game object to test.

object_type :

string

The type of game object, as set up in the .network_config data file.

Returns

boolean

Returns true if the game object is an instance of the specified type, or false otherwise.

Note that the comparison is done internally rather than providing direct access to the object's type, since the type is stored internally using a hashed value.

Parameters

self :

stingray.GameSession

Specifies the object instance that this function will act on.

You may use the colon : calling syntax to call this function on an instance of this object. If you do so, you must omit this parameter. For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.

object_id :

integer

The ID of the game object to test.

Returns

boolean

Returns true if this peer is the owner of the game object, or false otherwise.

Parameters

self :

stingray.GameSession

Specifies the object instance that this function will act on.

You may use the colon : calling syntax to call this function on an instance of this object. If you do so, you must omit this parameter. For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.

object_id :

integer

The ID of the game object to test.

Returns

string

The peer ID of the peer that owns the game object.

Parameters

self :

stingray.GameSession

Specifies the object instance that this function will act on.

You may use the colon : calling syntax to call this function on an instance of this object. If you do so, you must omit this parameter. For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.

object_id :

integer

The ID of the game object to migrate to a new owner.

new_peer_id :

string

The peer ID of the new owner.

callback_object :

table

An object that will be notified through a callback function when the game object is migrated, if you are either the current owner or the new owner of the game object.

Returns
This function does not return any values.

This function can only be called by the host of the game session.

If you are the current owner or the new owner of the game object, the callback object you provide to this function will get notified immediately by invoking one of the following callbacks:

  • game_object_migrated_to_me(id, old_owner_id)

Notifies you that you have now become the owner of the game object identified by id. The old_owner_id parameter identifies the peer that previously owned the game object.

  • game_object_migrated_away(id, new_owner_id)

Notifies you that you are no longer the owner of the game object identified by id. The new_owner_id parameter identifies the peer that now owns the game object.

In any case, the previous owner and the new owner will be notified of the migration during the next call to Network.update().

Parameters

self :

stingray.GameSession

Specifies the object instance that this function will act on.

You may use the colon : calling syntax to call this function on an instance of this object. If you do so, you must omit this parameter. For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.

peer_id :

string

The peer ID of the peer.

Returns

integer[]

A table that contains the IDs of all game objects owned by the peer.

The [] notation indicates that this type is an array: a table in which the keys of the members are sequential integers, and the value of each element is an instance of the type shown.
Parameters

self :

stingray.GameSession

Specifies the object instance that this function will act on.

You may use the colon : calling syntax to call this function on an instance of this object. If you do so, you must omit this parameter. For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.

object_id :

integer

The ID of the game object whose value will be set.

field :

string

The name of the field whose value you want to set.

value :

any

The value to store in the specified field of the game object. The type of this value depends on the data type configured for the field in the .network_config data file.

Returns
This function does not return any values.

This function can only be called by the peer that owns the game object.

Parameters

self :

stingray.GameSession

Specifies the object instance that this function will act on.

You may use the colon : calling syntax to call this function on an instance of this object. If you do so, you must omit this parameter. For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.

object_id :

integer

The ID of the game object whose priority will be set.

peer_id :

string

The peer ID of the peer.

priority :

number

The new priority to set for the game object.

Returns
This function does not return any values.

Note that this requires the Quality of Service (QoS) system to be enabled for the networking system. See Network.enable_qos().

Parameters

self :

stingray.GameSession

Specifies the object instance that this function will act on.

You may use the colon : calling syntax to call this function on an instance of this object. If you do so, you must omit this parameter. For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.
Returns

stingray.UnitSynchronizer

The UnitSynchronizer for this session, if any.

You can use this object to aid in synchronizing object creation, movement, and removal. See the UnitSynchronizer description for details.

Peers

Functions for finding other peers in the session.

Parameters

self :

stingray.GameSession

Specifies the object instance that this function will act on.

You may use the colon : calling syntax to call this function on an instance of this object. If you do so, you must omit this parameter. For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.
Returns

string[]

A table that contains the IDs of all other peers in the session.

The [] notation indicates that this type is an array: a table in which the keys of the members are sequential integers, and the value of each element is an instance of the type shown.
Parameters

self :

stingray.GameSession

Specifies the object instance that this function will act on.

You may use the colon : calling syntax to call this function on an instance of this object. If you do so, you must omit this parameter. For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.
Returns

string[]

A table that contains the IDs of all peers in the session.

The [] notation indicates that this type is an array: a table in which the keys of the members are sequential integers, and the value of each element is an instance of the type shown.
Parameters

self :

stingray.GameSession

Specifies the object instance that this function will act on.

You may use the colon : calling syntax to call this function on an instance of this object. If you do so, you must omit this parameter. For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.
Returns

string[]

A table that contains the IDs of all synchronized peers.

The [] notation indicates that this type is an array: a table in which the keys of the members are sequential integers, and the value of each element is an instance of the type shown.
Parameters

self :

stingray.GameSession

Specifies the object instance that this function will act on.

You may use the colon : calling syntax to call this function on an instance of this object. If you do so, you must omit this parameter. For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.
Returns

string[]

A table that contains the IDs of peers in the initial process of synchronizing their game objects.

The [] notation indicates that this type is an array: a table in which the keys of the members are sequential integers, and the value of each element is an instance of the type shown.

Note that when each peer completes its initial synchronization, all other peers will receive a callback through the callback object provided to Network.update().

In a replay session, this function always returns an empty list, since synchronization does not occur. See the GameSession description for details on replay sessions.

Session control

Functions for joining and leaving game sessions.

Parameters

self :

stingray.GameSession

Specifies the object instance that this function will act on.

You may use the colon : calling syntax to call this function on an instance of this object. If you do so, you must omit this parameter. For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.
Returns

string?

The ID of a peer with a broken connection if any, or nil.

The ? notation indicates that this type is optional: there may be zero or one instances of it.

Can be called only by the session host. If the connection to a peer has become broken, this function will return that peer's ID. The session host should respond by removing the peer from the session, after destroying or migrating its objects.

If all connections are good, the function will return nil.

If there is more than one broken connection, you will need to call this function repeatedly in order to detect them all.

In a replay session, this function always returns nil, since broken connection states are not recorded in the network log. See the GameSession description for details on replay sessions.

Parameters

self :

stingray.GameSession

Specifies the object instance that this function will act on.

You may use the colon : calling syntax to call this function on an instance of this object. If you do so, you must omit this parameter. For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.
Returns

string

The peer ID of the session host

Parameters

self :

stingray.GameSession

Specifies the object instance that this function will act on.

You may use the colon : calling syntax to call this function on an instance of this object. If you do so, you must omit this parameter. For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.
Returns

boolean

Returns true if the peer calling this function is connected to the session, or false otherwise.

If this function returns false, you have been removed from the session because of a bad connection or because the session host has kicked you out. In either case, you should shut down the session.

In a replay session, this function always returns true, since there is always a session. See the GameSession description for details on replay sessions.

Parameters

self :

stingray.GameSession

Specifies the object instance that this function will act on.

You may use the colon : calling syntax to call this function on an instance of this object. If you do so, you must omit this parameter. For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.
Returns
This function does not return any values.

After calling this, you should wait until in_session() returns false before shutting down the session. This ensures that all other peers are informed that you have left the session.

Parameters

self :

stingray.GameSession

Specifies the object instance that this function will act on.

You may use the colon : calling syntax to call this function on an instance of this object. If you do so, you must omit this parameter. For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.
Returns

string?

The ID of a peer who has requested to leave the session, or nil.

The ? notation indicates that this type is optional: there may be zero or one instances of it.

Can be called only by the session host. The session host should respond by removing the peer from the session after destroying or migrating its objects.

If no peers want to leave, the function will return nil.

If more than one peer wants to leave, you will need to call this function repeatedly in order to detect them all.

In a replay session, this function always returns nil, since leave requests are not recorded in the network log. See the GameSession description for details on replay sessions.

Settings

Functions that involve creating and managing game objects.

Parameters

self :

stingray.GameSession

Specifies the object instance that this function will act on.

You may use the colon : calling syntax to call this function on an instance of this object. If you do so, you must omit this parameter. For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.

time :

number

The interpolation compensation threshold, in seconds.

Returns
This function does not return any values.

A higher value will be more tolerant of missing updates, but will be more delayed relative to the point of view of a game object's owner.

The default value is 0.015.

Parameters

self :

stingray.GameSession

Specifies the object instance that this function will act on.

You may use the colon : calling syntax to call this function on an instance of this object. If you do so, you must omit this parameter. For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.

time :

number

The new update interval, in seconds.

Returns
This function does not return any values.

A short interval will find spikes, but will change rapidly.

The default is 1.