Invoked when a match is created as a result of the match create function and sets up the initial state of a match. This will be called once at match start.
Parameters
Name
Default
Description
ctxtableREQUIRED
The context object represents information about the match and server for information purposes.
paramstableREQUIRED
Optional arbitrary second argument passed to match_create(), or nil if none was used. This can be matched users or any other data you'd like to pass into this function.
Returns
Name
Description
statetable
The initial in-memory state of the match. May be any non-nil Lua term, or nil to end the match.
tick_ratenumber
Tick rate representing the desired number of match_loop() calls per second. Must be between 1 and 60, inclusive.
labelstring
A string label that can be used to filter matches in listing operations. Must be between 0 and 2048 bytes long. This is used in match listing to filter matches.
Executed when one or more users have successfully completed the match join process after their match_join_attempt() returns true. When their presences are sent to this function the users are ready to receive match data messages and can be targets for the dispatcher's broadcast_message() function.
Parameters
Name
Default
Description
ctxtableREQUIRED
The context object represents information about the match and server for information purposes.
dispatchertableREQUIRED
Exposes useful functions to the match, and may be used by the server to send messages to the participants of the match.
ticknumberREQUIRED
Tick is the current match tick number, starts at 0 and increments after every match_loop call. Does not increment with calls to match_join_attempt, match_join, or match_leave, match_terminate, or match_signal.
statetableREQUIRED
The current in-memory match state, may be any Lua term except nil.
presencestableREQUIRED
A list of users that have successfully completed the match join process.
Returns
Name
Description
statetable
An (optionally) updated state. May be any non-nil Lua term, or nil to end the match.
1
2
3
4
5
6
7
8
9
10
11
12
13
localfunctionmatch_join(context,dispatcher,tick,state,presences)-- Presences format:-- {-- {-- user_id = "user unique ID",-- session_id = "session ID of the user's current connection",-- username = "user's unique username",-- node = "name of the Nakama node the user is connected to"-- },-- ...-- }returnstateend
Executed when a user attempts to join the match using the client's match join operation. Match join attempt can be used to prevent more players from joining after a match has started or disallow the user for any other game specific reason.
Parameters
Name
Default
Description
ctxtableREQUIRED
The context object represents information about the match and server for information purposes.
dispatchertableREQUIRED
Exposes useful functions to the match, and may be used by the server to send messages to the participants of the match.
ticknumberREQUIRED
Tick is the current match tick number, starts at 0 and increments after every match_loop call. Does not increment with calls to match_join_attempt, match_join, or match_leave, match_terminate, or match_signal.
statetableREQUIRED
The current in-memory match state, may be any Lua term except nil.
presencetableREQUIRED
The user attempting to join the match.
metadatatableREQUIRED
Arbitrary key-value pairs (both as 'strings') received from the client as part of the join request.
Returns
Name
Description
statetable
An (optionally) updated state. May be any non-nil Lua term, or nil to end the match.
acceptedbool
True if the join attempt should be allowed, False otherwise.
reject_messagestring
If the join attempt should be rejected, an optional string rejection reason can be returned to the client.
1
2
3
4
5
6
7
8
9
10
localfunctionmatch_join_attempt(context,dispatcher,tick,state,presence,metadata)-- Presence format:-- {-- user_id = "user unique ID",-- session_id = "session ID of the user's current connection",-- username = "user's unique username",-- node = "name of the Nakama node the user is connected to"-- }returnstate,trueend
Executed when one or more users have left the match for any reason including connection loss.
Parameters
Name
Default
Description
ctxtableREQUIRED
The context object represents information about the match and server for information purposes.
dispatchertableREQUIRED
Exposes useful functions to the match, and may be used by the server to send messages to the participants of the match.
ticknumberREQUIRED
Tick is the current match tick number, starts at 0 and increments after every match_loop call. Does not increment with calls to match_join_attempt, match_join, or match_leave, match_terminate, or match_signal.
statetableREQUIRED
The current in-memory match state, may be any Lua term except nil.
presencestableREQUIRED
A list of users that have left the match.
Returns
Name
Description
statetable
An (optionally) updated state. May be any non-nil Lua term, or nil to end the match.
Executed on an interval based on the tick rate returned by match_init. Each tick the match loop is run which can process messages received from clients and apply changes to the match state before the next tick. It can also dispatch messages to one or more connected opponents. To send messages back to the opponents in the match you can keep track of them in the game state and use the dispatcher object to send messages to subsets of the users or all of them.
Parameters
Name
Default
Description
ctxtableREQUIRED
The context object represents information about the match and server for information purposes.
dispatchertableREQUIRED
Exposes useful functions to the match, and may be used by the server to send messages to the participants of the match.
ticknumberREQUIRED
Tick is the current match tick number, starts at 0 and increments after every match_loop call. Does not increment with calls to match_join_attempt, match_join, or match_leave, match_terminate, or match_signal.
statetableREQUIRED
The current in-memory match state, may be any Lua term except nil.
messagestableREQUIRED
A list of data messages received from users between the previous and current tick.
Returns
Name
Description
statetable
An (optionally) updated state. May be any non-nil Lua term, or nil to end the match.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
localfunctionmatch_loop(context,dispatcher,tick,state,messages)-- Messages format:-- {-- {-- sender = {-- user_id = "user unique ID",-- session_id = "session ID of the user's current connection",-- username = "user's unique username",-- node = "name of the Nakama node the user is connected to"-- },-- op_code = 1, -- numeric op code set by the sender.-- data = "any string data set by the sender" -- may be nil.-- },-- ...-- }returnstateend
Called when the match handler receives a runtime signal. Match signals allow the match handler to be sent a reservation signal to mark a user ID or session ID into the match state ahead of their join attempt and eventual join flow. This is useful to apply reservations to a matchmaking system with Nakama's matchmaker or match listings APIs.
Parameters
Name
Default
Description
ctxtableREQUIRED
The context object represents information about the match and server for information purposes.
dispatchertableREQUIRED
Exposes useful functions to the match, and may be used by the server to send messages to the participants of the match.
ticknumberREQUIRED
Tick is the current match tick number, starts at 0 and increments after every match_loop call. Does not increment with calls to match_join_attempt, match_join, or match_leave, match_terminate, or match_signal.
statetableREQUIRED
The current in-memory match state, may be any Lua term except nil.
datastringREQUIRED
An arbitrary input supplied by the runtime caller of the signal.
Returns
Name
Description
statetable
An (optionally) updated state. May be any non-nil Lua term, or nil to end the match.
datastring
Arbitrary data to return to the runtime caller of the signal. May be a string or null.
Called when the server begins a graceful shutdown process. Will not be called if graceful shutdown is disabled. The match should attempt to complete any processing before the given number of seconds elapses, and optionally send a message to clients to inform them the server is shutting down. When the grace period expires the match will be forcefully closed if it is still running, clients will be disconnected, and the server will shut down.
Parameters
Name
Default
Description
ctxtableREQUIRED
The context object represents information about the match and server for information purposes.
dispatchertableREQUIRED
Exposes useful functions to the match, and may be used by the server to send messages to the participants of the match.
ticknumberREQUIRED
Tick is the current match tick number, starts at 0 and increments after every match_loop call. Does not increment with calls to match_join_attempt, match_join, or match_leave, match_terminate, or match_signal.
statetableREQUIRED
The current in-memory match state, may be any Lua term except nil.
grace_secondsnumberREQUIRED
The number of seconds provided to complete a graceful termination before a match is forcefully closed.
Returns
Name
Description
statetable
An (optionally) updated state. May be any non-nil Lua term, or nil to end the match.