IServerPluginCallbacks: Difference between revisions
| TomEdwards (talk | contribs) No edit summary | m (Setting bug notice hidetested=1 param on page where the bug might not need tested in param specified) | ||
| (5 intermediate revisions by 3 users not shown) | |||
| Line 1: | Line 1: | ||
| {{toc-right}} | {{toc-right}} | ||
| '''<code>IServerPluginCallbacks</code>''' is the [[interface]] used by [[server  | '''<code>IServerPluginCallbacks</code>''' is the [[interface]] used by [[server plugins]] to hook game events. It is typically used in conjunction with <code>[[IGameEventListener2]]</code>. | ||
| See [[Server Plugins#Coding]] for implementation details. | See [[Server Plugins#Coding]] for implementation details. | ||
| Line 12: | Line 12: | ||
| : Called when the plugin is loaded by the engine. This can happen either on initialization or when being re-loaded after being unloaded. The two parameters provide the interface factories that the plugin needs to operate. Returns false on error. | : Called when the plugin is loaded by the engine. This can happen either on initialization or when being re-loaded after being unloaded. The two parameters provide the interface factories that the plugin needs to operate. Returns false on error. | ||
| ; <code>void UnLoad()</code> | ; <code>void UnLoad()</code> | ||
| : Called when a plugin is unloaded, use this to disable any asynchronous tasks and remove any callbacks you have registered with the engine (for example a game events listener). | : Called when a plugin is unloaded, use this to disable any asynchronous tasks and remove any callbacks you have registered with the engine (for example a game events listener). Additionally, this function will be called if false is returned by Load(). | ||
| ; <code>void Pause()</code> | ; <code>void Pause()</code> | ||
| : Called when the operation of the plugin is paused (i.e it will stop receiving callbacks but should not be unloaded). | : Called when the operation of the plugin is paused (i.e it will stop receiving callbacks but should not be unloaded). | ||
| ; <code>void UnPause()</code> | ; <code>void UnPause()</code> | ||
| : Called when a plugin is brought out of the paused state. You should re-enable any asynchronous events your plugin uses in this call | : Called when a plugin is brought out of the paused state. You should re-enable any asynchronous events your plugin uses in this call | ||
| ; <code>[[char]]* GetPluginDescription()</code> | ; <code>const [[char]] *GetPluginDescription()</code> | ||
| : This function should return a friendly string describing your plugin. Typically this would be its name and the author. | : This function should return a friendly string describing your plugin. Typically this would be its name and the author. | ||
| === Server events === | === Server events === | ||
| ; <code>void LevelInit(char* pMapName)</code> | ; <code>void LevelInit(char const *pMapName)</code> | ||
| : Called on level (map) startup, it is the first function called as a server enters a new level. | : Called on level (map) startup, it is the first function called as a server enters a new level. | ||
| ; <code>void ServerActivate([[edict_t]] *pEdictList, [[int]] edictCount, int clientMax)</code> | ; <code>void ServerActivate([[edict_t]] *pEdictList, [[int]] edictCount, int clientMax)</code> | ||
| Line 37: | Line 37: | ||
| === Clients === | === Clients === | ||
| ; <code>[[#Related constructs|PLUGIN_RESULT]] ClientConnect(bool *bAllowConnect, [[edict_t]] *pEntity, char *pszName, char *pszAddress, char *reject, int maxrejectlen)</code> | ; <code>[[#Related constructs|PLUGIN_RESULT]] ClientConnect(bool *bAllowConnect, [[edict_t]] *pEntity, const char *pszName, const char *pszAddress, char *reject, int maxrejectlen)</code> | ||
| : Called when a client initially connects to a server. Set bAllowConnect to false to stop this user from connecting. | : Called when a client initially connects to a server. Set bAllowConnect to false to stop this user from connecting. | ||
| ; <code>void ClientPutInServer(edict_t *pEntity, char const *playername)</code> | ; <code>void ClientPutInServer(edict_t *pEntity, char const *playername)</code> | ||
| Line 44: | Line 44: | ||
| : Called after a client is fully spawned and configured by the Mod. Use this call to change any player specific settings. | : Called after a client is fully spawned and configured by the Mod. Use this call to change any player specific settings. | ||
| ; <code>void ClientDisconnect(edict_t *pEntity)</code> | ; <code>void ClientDisconnect(edict_t *pEntity)</code> | ||
| : Called when a client disconnects from the server. {{bug|If a client disconnects very quickly after connecting, this function will not be called.}} | : Called when a client disconnects from the server. {{bug|hidetested=1|If a client disconnects very quickly after connecting, this function will not be called.}} | ||
| ; <code>void SetCommandClient(int index)</code> | ; <code>void SetCommandClient(int index)</code> | ||
| : Called by the ConVar code to let you keep track of which client is entering a ConCommand. Use this index in ConCommands if you want to see who is running the command. As ConVar commands don't have an edict associated with them when they run you can use this index to look up the entity that is running the command.  The index is one less than the entity index. | : Called by the ConVar code to let you keep track of which client is entering a ConCommand. Use this index in ConCommands if you want to see who is running the command. As ConVar commands don't have an edict associated with them when they run you can use this index to look up the entity that is running the command.  The index is one less than the entity index. | ||
| Line 61: | Line 61: | ||
| :: Keep going; no change | :: Keep going; no change | ||
| :; <code>PLUGIN_OVERRIDE</code> | :; <code>PLUGIN_OVERRIDE</code> | ||
| :: Run the game's function, but use our return value instead ( | :: Run the game's function, but use our return value instead (Note: This is in reference to arguments passed by reference, such as ClientConnect's bool *bAllowConnect) | ||
| :; <code>PLUGIN_STOP</code> | :; <code>PLUGIN_STOP</code> | ||
| :: Don't run the game's function at all | :: Don't run the game's function at all | ||
| Line 71: | Line 71: | ||
| ==== CreateMessage() ==== | ==== CreateMessage() ==== | ||
| ; <code>void CreateMessage( edict_t *pEntity, DIALOG_TYPE type, KeyValues *data, IServerPluginCallbacks *plugin )</code> | |||
| This function displays the in-game messages you are probably used to seeing on servers. It can create either simple announcements, or menus from which a choice must be made with one of the number keys. | This function displays the in-game messages you are probably used to seeing on servers. It can create either simple announcements, or menus from which a choice must be made with one of the number keys. | ||
| {{bug|Weapon selection commands count as numbers even if the player has re-assigned them to totally different keys. Be aware that popping up a menu can cause great frustration both through confusion and the blocking of input.}} | {{bug|hidetested=1|Weapon selection commands count as numbers even if the player has re-assigned them to totally different keys. Be aware that popping up a menu can cause great frustration both through confusion and the blocking of input.}} | ||
| The function's arguments are: | The function's arguments are: | ||
| ; <code>edict_t *pEntity</code> | ; <code>edict_t *pEntity</code> | ||
| :  | : Player to send message to | ||
| ; <code>DIALOG_TYPE type</code> | ; <code>DIALOG_TYPE type</code> | ||
| : One of: | : One of: | ||
| Line 110: | Line 112: | ||
| ; <code>IServerPluginCallbacks *plugin</code> | ; <code>IServerPluginCallbacks *plugin</code> | ||
| : {{confirm|The plugin you are calling from}} | : {{confirm|The plugin you are calling from}} | ||
| ==== StartQueryCvarValue() ==== | |||
| <code>QueryCvarCookie_t StartQueryCvarValue( edict_t *pEntity, const char *pName )</code> | |||
| Call this to find out the value of a cvar on the client. | |||
| It is an asynchronous query, and it will call <code>IServerPluginCallbacks::OnQueryCvarValueFinished</code> when the value comes in from the client. | |||
| Store the return value if you want to match this specific query to the <code>OnQueryCvarValueFinished</code> call. | |||
| Returns <code>InvalidQueryCvarCookie</code> if the entity if invalid. | |||
| The function's arguments are: | |||
| ; <code>edict_t *pEntity</code> | |||
| : Player to send message to | |||
| ; <code>const char *pName</code> | |||
| : Cvar name | |||
| ==== Other functions ==== | ==== Other functions ==== | ||
| ; <code>void ClientCommand( edict_t *pEntity, const char *cmd )</code> | ; <code>void ClientCommand( edict_t *pEntity, const char *cmd )</code> | ||
| : Attempt to run a command on the client.  In some games, only Commands marked FCVAR_SERVER_CAN_EXECUTE can be executed this way. | |||
| == See also == | == See also == | ||
Latest revision as of 07:14, 20 May 2025
IServerPluginCallbacks is the interface used by server plugins to hook game events. It is typically used in conjunction with IGameEventListener2.
See Server Plugins#Coding for implementation details.
Functions
Plugin state
- bool Load(CreateInterfaceFn interfaceFactory, CreateInterfaceFn gameServerFactory)
- Called when the plugin is loaded by the engine. This can happen either on initialization or when being re-loaded after being unloaded. The two parameters provide the interface factories that the plugin needs to operate. Returns false on error.
- void UnLoad()
- Called when a plugin is unloaded, use this to disable any asynchronous tasks and remove any callbacks you have registered with the engine (for example a game events listener). Additionally, this function will be called if false is returned by Load().
- void Pause()
- Called when the operation of the plugin is paused (i.e it will stop receiving callbacks but should not be unloaded).
- void UnPause()
- Called when a plugin is brought out of the paused state. You should re-enable any asynchronous events your plugin uses in this call
- const char *GetPluginDescription()
- This function should return a friendly string describing your plugin. Typically this would be its name and the author.
Server events
- void LevelInit(char const *pMapName)
- Called on level (map) startup, it is the first function called as a server enters a new level.
- void ServerActivate(edict_t *pEdictList, int edictCount, int clientMax)
- This is called when the server successfully enters a new level, this will happen after the LevelInit call. This call provides pointers to the list of edicts created on the server and the maxplayer count of the server.
- void GameFrame(bool simulating)
- Called once per server frame. Server performance is very sensitive to the execution time of this function so keep anything you do in this function to a minimum.
- void LevelShutdown()
- Called when a server is changing to a new level or is being shutdown. Remove any map specific allocations in this call. This can be called multiple times during a map change.
- void OnQueryCvarValueFinished( QueryCvarCookie_t iCookie, edict_t *pPlayerEntity, EQueryCvarValueStatus eStatus, char *pCvarName, char *pCvarValue )
- Called when a query from IServerPluginHelpers::StartQueryCvarValue()finishes.iCookieis the value requested.
- void OnEdictAllocated(edict_t *edict)
- void OnEdictAllocated(const edict_t *edict)
Clients
- PLUGIN_RESULT ClientConnect(bool *bAllowConnect, edict_t *pEntity, const char *pszName, const char *pszAddress, char *reject, int maxrejectlen)
- Called when a client initially connects to a server. Set bAllowConnect to false to stop this user from connecting.
- void ClientPutInServer(edict_t *pEntity, char const *playername)
- Called when a client spawns into a server. This is called before the server spawn function.
- void ClientActive(edict_t *pEntity)
- Called after a client is fully spawned and configured by the Mod. Use this call to change any player specific settings.
- void ClientDisconnect(edict_t *pEntity)
- Called when a client disconnects from the server.  Bug:If a client disconnects very quickly after connecting, this function will not be called. Bug:If a client disconnects very quickly after connecting, this function will not be called.
- void SetCommandClient(int index)
- Called by the ConVar code to let you keep track of which client is entering a ConCommand. Use this index in ConCommands if you want to see who is running the command. As ConVar commands don't have an edict associated with them when they run you can use this index to look up the entity that is running the command. The index is one less than the entity index.
- void ClientSettingsChanged(edict_t *pEdict)
- Called when player specific cvars about a player change (for example the users name). Use this function to control what operations a user is allowed to perform to their settings (for example limiting usernames).
- PLUGIN_RESULT ClientCommand(edict_t *pEntity, const CCommand &args)
- Called when a remote client enters a command into the console. This should be used to provide commands to clients (and ConCommand used to implement server side only commands).
- PLUGIN_RESULT NetworkIDValidated(const char *pszUserName, const char *pszNetworkID)
- Called when the server retrieves a clients network ID (i.e Steam ID). Note that a clients network ID is not set on connect, you must wait for this callback before a users network ID is valid. The client name is passed into this function, you need to search the currently connected players to find the associated edict pointer. Note that the clients name can change between connect and id validation, you should use the entity index to track specific players. Note also that this function is NOT called for the local user when running a listen/non-dedicated server.
Related constructs
- PLUGIN_RESULT
- One of:
- PLUGIN_CONTINUE
- Keep going; no change
- PLUGIN_OVERRIDE
- Run the game's function, but use our return value instead (Note: This is in reference to arguments passed by reference, such as ClientConnect's bool *bAllowConnect)
- PLUGIN_STOP
- Don't run the game's function at all
 
- QueryCvarCookie_t
- CreateInterfaceFn
- EQueryCvarValueStatus
IServerPluginHelpers
CreateMessage()
- void CreateMessage( edict_t *pEntity, DIALOG_TYPE type, KeyValues *data, IServerPluginCallbacks *plugin )
This function displays the in-game messages you are probably used to seeing on servers. It can create either simple announcements, or menus from which a choice must be made with one of the number keys.
 Bug:Weapon selection commands count as numbers even if the player has re-assigned them to totally different keys. Be aware that popping up a menu can cause great frustration both through confusion and the blocking of input.
Bug:Weapon selection commands count as numbers even if the player has re-assigned them to totally different keys. Be aware that popping up a menu can cause great frustration both through confusion and the blocking of input.The function's arguments are:
- edict_t *pEntity
- Player to send message to
- DIALOG_TYPE type
- One of:
- DIALOG_MSG
- A plain and simple message
- DIALOG_MENU
- An options menu. If you use this, add sub keys (Todo: Called what?) todatacontaining:- string command
- Client command to run if this item is selected
- string msg
- Option text
 
 - DIALOG_TEXT
- A rich text message (Todo: What format? HTML?)
- DIALOG_ENTRY
- An entry box (Todo: What does this look like?)
- DIALOG_ASKCONNECT
- Ask the client to connect to a specified IP address. Only the "time" and "title" keys are used.
 
- KeyValues *data
- Raw data to send to the client. Can contain the following keys:
- string title
- The title text to display at the top of the message
- string msg
- The body of the message
- color color
- The color to display the message in; white by default
- int level
- The priority of the message, where 0 is highest (only one message can be displayed at any one time)
- int time
- Number of seconds the message should stay active. Min 10, max 200.
 
- IServerPluginCallbacks *plugin
 Confirm:The plugin you are calling from Confirm:The plugin you are calling from
StartQueryCvarValue()
QueryCvarCookie_t StartQueryCvarValue( edict_t *pEntity, const char *pName )
Call this to find out the value of a cvar on the client.
It is an asynchronous query, and it will call IServerPluginCallbacks::OnQueryCvarValueFinished when the value comes in from the client.
Store the return value if you want to match this specific query to the OnQueryCvarValueFinished call.
Returns InvalidQueryCvarCookie if the entity if invalid.
The function's arguments are:
- edict_t *pEntity
- Player to send message to
- const char *pName
- Cvar name
Other functions
- void ClientCommand( edict_t *pEntity, const char *cmd )
- Attempt to run a command on the client. In some games, only Commands marked FCVAR_SERVER_CAN_EXECUTE can be executed this way.