mirror of
https://github.com/TES3MP/openmw-tes3mp.git
synced 2025-01-28 18:45:33 +00:00
317 lines
10 KiB
C++
317 lines
10 KiB
C++
#ifndef OPENMW_SERVERAPI_HPP
|
|
#define OPENMW_SERVERAPI_HPP
|
|
|
|
#include "../Types.hpp"
|
|
|
|
#define SERVERAPI \
|
|
{"LogMessage", ServerFunctions::LogMessage},\
|
|
{"LogAppend", ServerFunctions::LogAppend},\
|
|
\
|
|
{"StopServer", ServerFunctions::StopServer},\
|
|
\
|
|
{"Kick", ServerFunctions::Kick},\
|
|
{"BanAddress", ServerFunctions::BanAddress},\
|
|
{"UnbanAddress", ServerFunctions::UnbanAddress},\
|
|
\
|
|
{"DoesFilePathExist", ServerFunctions::DoesFilePathExist},\
|
|
{"GetCaseInsensitiveFilename", ServerFunctions::GetCaseInsensitiveFilename},\
|
|
{"GetDataPath", ServerFunctions::GetDataPath},\
|
|
{"GetMillisecondsSinceServerStart", ServerFunctions::GetMillisecondsSinceServerStart},\
|
|
{"GetOperatingSystemType", ServerFunctions::GetOperatingSystemType},\
|
|
{"GetArchitectureType", ServerFunctions::GetArchitectureType},\
|
|
{"GetServerVersion", ServerFunctions::GetServerVersion},\
|
|
{"GetProtocolVersion", ServerFunctions::GetProtocolVersion},\
|
|
{"GetAvgPing", ServerFunctions::GetAvgPing},\
|
|
{"GetIP", ServerFunctions::GetIP},\
|
|
{"GetMaxPlayers", ServerFunctions::GetMaxPlayers},\
|
|
{"GetPort", ServerFunctions::GetPort},\
|
|
{"HasPassword", ServerFunctions::HasPassword},\
|
|
{"GetDataFileEnforcementState", ServerFunctions::GetDataFileEnforcementState},\
|
|
{"GetScriptErrorIgnoringState", ServerFunctions::GetScriptErrorIgnoringState},\
|
|
\
|
|
{"SetGameMode", ServerFunctions::SetGameMode},\
|
|
{"SetHostname", ServerFunctions::SetHostname},\
|
|
{"SetServerPassword", ServerFunctions::SetServerPassword},\
|
|
{"SetDataFileEnforcementState", ServerFunctions::SetDataFileEnforcementState},\
|
|
{"SetScriptErrorIgnoringState", ServerFunctions::SetScriptErrorIgnoringState},\
|
|
{"SetRuleString", ServerFunctions::SetRuleString},\
|
|
{"SetRuleValue", ServerFunctions::SetRuleValue},\
|
|
\
|
|
{"AddDataFileRequirement", ServerFunctions::AddDataFileRequirement},\
|
|
\
|
|
{"DoesFileExist", ServerFunctions::DoesFileExist},\
|
|
{"GetModDir", ServerFunctions::GetModDir},\
|
|
{"GetPluginEnforcementState", ServerFunctions::GetPluginEnforcementState},\
|
|
{"SetPluginEnforcementState", ServerFunctions::SetPluginEnforcementState},\
|
|
{"AddPluginHash", ServerFunctions::AddPluginHash}
|
|
|
|
class ServerFunctions
|
|
{
|
|
public:
|
|
|
|
/**
|
|
* \brief Write a log message with its own timestamp.
|
|
*
|
|
* It will have "[Script]:" prepended to it so as to mark it as a script-generated log message.
|
|
*
|
|
* \param level The logging level used (0 for LOG_VERBOSE, 1 for LOG_INFO, 2 for LOG_WARN,
|
|
* 3 for LOG_ERROR, 4 for LOG_FATAL).
|
|
* \param message The message logged.
|
|
* \return void
|
|
*/
|
|
static void LogMessage(unsigned short level, const char *message) noexcept;
|
|
|
|
/**
|
|
* \brief Write a log message without its own timestamp.
|
|
*
|
|
* It will have "[Script]:" prepended to it so as to mark it as a script-generated log message.
|
|
*
|
|
* \param level The logging level used (0 for LOG_VERBOSE, 1 for LOG_INFO, 2 for LOG_WARN,
|
|
* 3 for LOG_ERROR, 4 for LOG_FATAL).
|
|
* \param message The message logged.
|
|
* \return void
|
|
*/
|
|
static void LogAppend(unsigned short level, const char *message) noexcept;
|
|
|
|
/**
|
|
* \brief Shut down the server.
|
|
*
|
|
* \param code The shutdown code.
|
|
* \return void
|
|
*/
|
|
static void StopServer(int code) noexcept;
|
|
|
|
/**
|
|
* \brief Kick a certain player from the server.
|
|
*
|
|
* \param pid The player ID.
|
|
* \return void
|
|
*/
|
|
static void Kick(unsigned short pid) noexcept;
|
|
|
|
/**
|
|
* \brief Ban a certain IP address from the server.
|
|
*
|
|
* \param ipAddress The IP address.
|
|
* \return void
|
|
*/
|
|
static void BanAddress(const char *ipAddress) noexcept;
|
|
|
|
/**
|
|
* \brief Unban a certain IP address from the server.
|
|
*
|
|
* \param ipAddress The IP address.
|
|
* \return void
|
|
*/
|
|
static void UnbanAddress(const char *ipAddress) noexcept;
|
|
|
|
/**
|
|
* \brief Check whether a certain file path exists.
|
|
*
|
|
* This will be a case sensitive check on case sensitive filesystems.
|
|
*
|
|
* Whenever you want to enforce case insensitivity, use GetCaseInsensitiveFilename() instead.
|
|
*
|
|
* \return Whether the file exists or not.
|
|
*/
|
|
static bool DoesFilePathExist(const char *filePath) noexcept;
|
|
|
|
/**
|
|
* \brief Get the first filename in a folder that has a case insensitive match with the filename
|
|
* argument.
|
|
*
|
|
* This is used to retain case insensitivity when opening data files on Linux.
|
|
*
|
|
* \return The filename that matches.
|
|
*/
|
|
static const char *GetCaseInsensitiveFilename(const char *folderPath, const char *filename) noexcept;
|
|
|
|
/**
|
|
* \brief Get the path of the server's data folder.
|
|
*
|
|
* \return The data path.
|
|
*/
|
|
static const char *GetDataPath() noexcept;
|
|
|
|
/**
|
|
* \brief Get the milliseconds elapsed since the server was started.
|
|
*
|
|
* \return The time since the server's startup in milliseconds.
|
|
*/
|
|
static unsigned int GetMillisecondsSinceServerStart() noexcept;
|
|
|
|
/**
|
|
* \brief Get the type of the operating system used by the server.
|
|
*
|
|
* Note: Currently, the type can be "Windows", "Linux", "OS X" or "Unknown OS".
|
|
*
|
|
* \return The type of the operating system.
|
|
*/
|
|
static const char *GetOperatingSystemType() noexcept;
|
|
|
|
/**
|
|
* \brief Get the architecture type used by the server.
|
|
*
|
|
* Note: Currently, the type can be "64-bit", "32-bit", "ARMv#" or "Unknown architecture".
|
|
*
|
|
* \return The architecture type.
|
|
*/
|
|
static const char *GetArchitectureType() noexcept;
|
|
|
|
/**
|
|
* \brief Get the TES3MP version of the server.
|
|
*
|
|
* \return The server version.
|
|
*/
|
|
static const char *GetServerVersion() noexcept;
|
|
|
|
/**
|
|
* \brief Get the protocol version of the server.
|
|
*
|
|
* \return The protocol version.
|
|
*/
|
|
static const char *GetProtocolVersion() noexcept;
|
|
|
|
/**
|
|
* \brief Get the average ping of a certain player.
|
|
*
|
|
* \param pid The player ID.
|
|
* \return The average ping.
|
|
*/
|
|
static int GetAvgPing(unsigned short pid) noexcept;
|
|
|
|
/**
|
|
* \brief Get the IP address of a certain player.
|
|
*
|
|
* \param pid The player ID.
|
|
* \return The IP address.
|
|
*/
|
|
static const char* GetIP(unsigned short pid) noexcept;
|
|
|
|
/**
|
|
* \brief Get the port used by the server.
|
|
*
|
|
* \return The port.
|
|
*/
|
|
static unsigned short GetPort() noexcept;
|
|
|
|
/**
|
|
* \brief Get the maximum number of players.
|
|
*
|
|
* \return Max players
|
|
*/
|
|
static unsigned int GetMaxPlayers() noexcept;
|
|
|
|
/**
|
|
* \brief Checking if the server requires a password to connect.
|
|
*
|
|
* @return
|
|
*/
|
|
static bool HasPassword() noexcept;
|
|
|
|
/**
|
|
* \brief Get the data file enforcement state of the server.
|
|
*
|
|
* If true, clients are required to use the same data files as set for the server.
|
|
*
|
|
* \return The enforcement state.
|
|
*/
|
|
static bool GetDataFileEnforcementState() noexcept;
|
|
|
|
/**
|
|
* \brief Get the script error ignoring state of the server.
|
|
*
|
|
* If true, script errors will not crash the server.
|
|
*
|
|
* \return The script error ignoring state.
|
|
*/
|
|
static bool GetScriptErrorIgnoringState() noexcept;
|
|
|
|
/**
|
|
* \brief Set the game mode of the server, as displayed in the server browser.
|
|
*
|
|
* \param name The new game mode.
|
|
* \return void
|
|
*/
|
|
static void SetGameMode(const char* gameMode) noexcept;
|
|
|
|
/**
|
|
* \brief Set the name of the server, as displayed in the server browser.
|
|
*
|
|
* \param name The new name.
|
|
* \return void
|
|
*/
|
|
static void SetHostname(const char* name) noexcept;
|
|
|
|
/**
|
|
* \brief Set the password required to join the server.
|
|
*
|
|
* \param password The password.
|
|
* \return void
|
|
*/
|
|
static void SetServerPassword(const char *password) noexcept;
|
|
|
|
/**
|
|
* \brief Set the data file enforcement state of the server.
|
|
*
|
|
* If true, clients are required to use the same data files as set for the server.
|
|
*
|
|
* \param state The new enforcement state.
|
|
* \return void
|
|
*/
|
|
static void SetDataFileEnforcementState(bool state) noexcept;
|
|
|
|
/**
|
|
* \brief Set whether script errors should be ignored or not.
|
|
*
|
|
* If true, script errors will not crash the server, but could have any number
|
|
* of unforeseen consequences, which is why this is a highly experimental
|
|
* setting.
|
|
*
|
|
* \param state The new script error ignoring state.
|
|
* \return void
|
|
*/
|
|
static void SetScriptErrorIgnoringState(bool state) noexcept;
|
|
|
|
/**
|
|
* \brief Set a rule string for the server details displayed in the server browser.
|
|
*
|
|
* \param key The name of the rule.
|
|
* \param value The string value of the rule.
|
|
* \return void
|
|
*/
|
|
static void SetRuleString(const char *key, const char *value) noexcept;
|
|
|
|
/**
|
|
* \brief Set a rule value for the server details displayed in the server browser.
|
|
*
|
|
* \param key The name of the rule.
|
|
* \param value The numerical value of the rule.
|
|
* \return void
|
|
*/
|
|
static void SetRuleValue(const char *key, double value) noexcept;
|
|
|
|
/**
|
|
* \brief Add a data file and a corresponding CRC32 checksum to the data file loadout
|
|
* that connecting clients need to match.
|
|
*
|
|
* It can be used multiple times to set multiple checksums for the same data file.
|
|
*
|
|
* Note: If an empty string is provided for the checksum, a checksum will not be
|
|
* required for that data file.
|
|
*
|
|
* @param dataFilename The filename of the data file.
|
|
* @param checksumString A string with the CRC32 checksum required.
|
|
*/
|
|
static void AddDataFileRequirement(const char *dataFilename, const char *checksumString) noexcept;
|
|
|
|
// All methods below are deprecated versions of methods from above
|
|
|
|
static bool DoesFileExist(const char *filePath) noexcept;
|
|
static const char *GetModDir() noexcept;
|
|
static bool GetPluginEnforcementState() noexcept;
|
|
static void SetPluginEnforcementState(bool state) noexcept;
|
|
static void AddPluginHash(const char *pluginName, const char *checksumString) noexcept;
|
|
};
|
|
|
|
#endif //OPENMW_SERVERAPI_HPP
|