mirror of
https://git.do.srb2.org/STJr/SRB2.git
synced 2024-11-21 20:11:12 +00:00
Merge branch 'add-auto-kick-idle-players' into 'next'
Add auto-kick for inactive players See merge request STJr/SRB2!2148
This commit is contained in:
commit
5fc7a5c2da
7 changed files with 52 additions and 2 deletions
|
@ -607,6 +607,7 @@ typedef struct player_s
|
||||||
|
|
||||||
tic_t jointime; // Timer when player joins game to change skin/color
|
tic_t jointime; // Timer when player joins game to change skin/color
|
||||||
tic_t quittime; // Time elapsed since user disconnected, zero if connected
|
tic_t quittime; // Time elapsed since user disconnected, zero if connected
|
||||||
|
tic_t lastinputtime; // the last tic the player has made any input
|
||||||
#ifdef HWRENDER
|
#ifdef HWRENDER
|
||||||
fixed_t fovadd; // adjust FOV for hw rendering
|
fixed_t fovadd; // adjust FOV for hw rendering
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -3713,6 +3713,7 @@ static int lib_gAddPlayer(lua_State *L)
|
||||||
|
|
||||||
newplayer->jointime = 0;
|
newplayer->jointime = 0;
|
||||||
newplayer->quittime = 0;
|
newplayer->quittime = 0;
|
||||||
|
newplayer->lastinputtime = 0;
|
||||||
|
|
||||||
// Read the skin argument (defaults to Sonic)
|
// Read the skin argument (defaults to Sonic)
|
||||||
if (!lua_isnoneornil(L, 1))
|
if (!lua_isnoneornil(L, 1))
|
||||||
|
|
|
@ -223,6 +223,7 @@ enum player_e
|
||||||
player_blocked,
|
player_blocked,
|
||||||
player_jointime,
|
player_jointime,
|
||||||
player_quittime,
|
player_quittime,
|
||||||
|
player_lastinputtime,
|
||||||
player_ping,
|
player_ping,
|
||||||
#ifdef HWRENDER
|
#ifdef HWRENDER
|
||||||
player_fovadd,
|
player_fovadd,
|
||||||
|
@ -371,6 +372,7 @@ static const char *const player_opt[] = {
|
||||||
"blocked",
|
"blocked",
|
||||||
"jointime",
|
"jointime",
|
||||||
"quittime",
|
"quittime",
|
||||||
|
"lastinputtime",
|
||||||
"ping",
|
"ping",
|
||||||
#ifdef HWRENDER
|
#ifdef HWRENDER
|
||||||
"fovadd",
|
"fovadd",
|
||||||
|
@ -826,6 +828,9 @@ static int player_get(lua_State *L)
|
||||||
case player_quittime:
|
case player_quittime:
|
||||||
lua_pushinteger(L, plr->quittime);
|
lua_pushinteger(L, plr->quittime);
|
||||||
break;
|
break;
|
||||||
|
case player_lastinputtime:
|
||||||
|
lua_pushinteger(L, plr->lastinputtime);
|
||||||
|
break;
|
||||||
case player_ping:
|
case player_ping:
|
||||||
lua_pushinteger(L, playerpingtable[plr - players]);
|
lua_pushinteger(L, playerpingtable[plr - players]);
|
||||||
break;
|
break;
|
||||||
|
@ -1349,6 +1354,9 @@ static int player_set(lua_State *L)
|
||||||
case player_quittime:
|
case player_quittime:
|
||||||
plr->quittime = (tic_t)luaL_checkinteger(L, 3);
|
plr->quittime = (tic_t)luaL_checkinteger(L, 3);
|
||||||
break;
|
break;
|
||||||
|
case player_lastinputtime:
|
||||||
|
plr->lastinputtime = (tic_t)luaL_checkinteger(L, 3);
|
||||||
|
break;
|
||||||
#ifdef HWRENDER
|
#ifdef HWRENDER
|
||||||
case player_fovadd:
|
case player_fovadd:
|
||||||
plr->fovadd = luaL_checkfixed(L, 3);
|
plr->fovadd = luaL_checkfixed(L, 3);
|
||||||
|
|
|
@ -113,6 +113,7 @@ consvar_t cv_blamecfail = CVAR_INIT ("blamecfail", "Off", CV_SAVE|CV_NETVAR, CV_
|
||||||
static CV_PossibleValue_t playbackspeed_cons_t[] = {{1, "MIN"}, {10, "MAX"}, {0, NULL}};
|
static CV_PossibleValue_t playbackspeed_cons_t[] = {{1, "MIN"}, {10, "MAX"}, {0, NULL}};
|
||||||
consvar_t cv_playbackspeed = CVAR_INIT ("playbackspeed", "1", 0, playbackspeed_cons_t, NULL);
|
consvar_t cv_playbackspeed = CVAR_INIT ("playbackspeed", "1", 0, playbackspeed_cons_t, NULL);
|
||||||
|
|
||||||
|
consvar_t cv_idletime = CVAR_INIT ("idletime", "0", CV_SAVE, CV_Unsigned, NULL);
|
||||||
consvar_t cv_dedicatedidletime = CVAR_INIT ("dedicatedidletime", "10", CV_SAVE, CV_Unsigned, NULL);
|
consvar_t cv_dedicatedidletime = CVAR_INIT ("dedicatedidletime", "10", CV_SAVE, CV_Unsigned, NULL);
|
||||||
|
|
||||||
void ResetNode(INT32 node)
|
void ResetNode(INT32 node)
|
||||||
|
@ -226,6 +227,7 @@ static void Got_AddPlayer(UINT8 **p, INT32 playernum)
|
||||||
|
|
||||||
newplayer->jointime = 0;
|
newplayer->jointime = 0;
|
||||||
newplayer->quittime = 0;
|
newplayer->quittime = 0;
|
||||||
|
newplayer->lastinputtime = 0;
|
||||||
|
|
||||||
READSTRINGN(*p, player_names[newplayernum], MAXPLAYERNAME);
|
READSTRINGN(*p, player_names[newplayernum], MAXPLAYERNAME);
|
||||||
|
|
||||||
|
@ -492,6 +494,10 @@ static void Got_KickCmd(UINT8 **p, INT32 playernum)
|
||||||
HU_AddChatText(va("\x82*%s has been banned (%s)", player_names[pnum], reason), false);
|
HU_AddChatText(va("\x82*%s has been banned (%s)", player_names[pnum], reason), false);
|
||||||
kickreason = KR_BAN;
|
kickreason = KR_BAN;
|
||||||
break;
|
break;
|
||||||
|
case KICK_MSG_IDLE:
|
||||||
|
HU_AddChatText(va("\x82*%s has left the game (Inactive for too long)", player_names[pnum]), false);
|
||||||
|
kickreason = KR_TIMEOUT;
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (pnum == consoleplayer)
|
if (pnum == consoleplayer)
|
||||||
|
@ -507,6 +513,8 @@ static void Got_KickCmd(UINT8 **p, INT32 playernum)
|
||||||
M_StartMessage(M_GetText("Server closed connection\n(synch failure)\nPress ESC\n"), NULL, MM_NOTHING);
|
M_StartMessage(M_GetText("Server closed connection\n(synch failure)\nPress ESC\n"), NULL, MM_NOTHING);
|
||||||
else if (msg == KICK_MSG_PING_HIGH)
|
else if (msg == KICK_MSG_PING_HIGH)
|
||||||
M_StartMessage(M_GetText("Server closed connection\n(Broke ping limit)\nPress ESC\n"), NULL, MM_NOTHING);
|
M_StartMessage(M_GetText("Server closed connection\n(Broke ping limit)\nPress ESC\n"), NULL, MM_NOTHING);
|
||||||
|
else if (msg == KICK_MSG_IDLE)
|
||||||
|
M_StartMessage(M_GetText("Server closed connection\n(Inactive for too long)\nPress ESC\n"), NULL, MM_NOTHING);
|
||||||
else if (msg == KICK_MSG_BANNED)
|
else if (msg == KICK_MSG_BANNED)
|
||||||
M_StartMessage(M_GetText("You have been banned by the server\n\nPress ESC\n"), NULL, MM_NOTHING);
|
M_StartMessage(M_GetText("You have been banned by the server\n\nPress ESC\n"), NULL, MM_NOTHING);
|
||||||
else if (msg == KICK_MSG_CUSTOM_KICK)
|
else if (msg == KICK_MSG_CUSTOM_KICK)
|
||||||
|
@ -1267,6 +1275,32 @@ static void UpdatePingTable(void)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void IdleUpdate(void)
|
||||||
|
{
|
||||||
|
INT32 i;
|
||||||
|
if (!server || !netgame)
|
||||||
|
return;
|
||||||
|
|
||||||
|
for (i = 1; i < MAXPLAYERS; i++)
|
||||||
|
{
|
||||||
|
if (cv_idletime.value && playeringame[i] && playernode[i] != UINT8_MAX && !players[i].quittime && !players[i].spectator && !players[i].bot && !IsPlayerAdmin(i) && i != serverplayer)
|
||||||
|
{
|
||||||
|
if (players[i].cmd.forwardmove || players[i].cmd.sidemove || players[i].cmd.buttons)
|
||||||
|
players[i].lastinputtime = 0;
|
||||||
|
else
|
||||||
|
players[i].lastinputtime++;
|
||||||
|
|
||||||
|
if (players[i].lastinputtime > (tic_t)cv_idletime.value * TICRATE * 60)
|
||||||
|
{
|
||||||
|
players[i].lastinputtime = 0;
|
||||||
|
SendKick(i, KICK_MSG_IDLE | KICK_MSG_KEEP_BODY);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
players[i].lastinputtime = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Handle timeouts to prevent definitive freezes from happenning
|
// Handle timeouts to prevent definitive freezes from happenning
|
||||||
static void HandleNodeTimeouts(void)
|
static void HandleNodeTimeouts(void)
|
||||||
{
|
{
|
||||||
|
@ -1299,6 +1333,8 @@ void NetKeepAlive(void)
|
||||||
|
|
||||||
GetPackets();
|
GetPackets();
|
||||||
|
|
||||||
|
IdleUpdate();
|
||||||
|
|
||||||
#ifdef MASTERSERVER
|
#ifdef MASTERSERVER
|
||||||
MasterClient_Ticker();
|
MasterClient_Ticker();
|
||||||
#endif
|
#endif
|
||||||
|
@ -1419,6 +1455,8 @@ void NetUpdate(void)
|
||||||
|
|
||||||
GetPackets(); // get packet from client or from server
|
GetPackets(); // get packet from client or from server
|
||||||
|
|
||||||
|
IdleUpdate();
|
||||||
|
|
||||||
// The client sends the command after receiving from the server
|
// The client sends the command after receiving from the server
|
||||||
// The server sends it before because this is better in single player
|
// The server sends it before because this is better in single player
|
||||||
|
|
||||||
|
|
|
@ -48,7 +48,7 @@ typedef enum
|
||||||
KR_TIMEOUT = 4, //Connection Timeout
|
KR_TIMEOUT = 4, //Connection Timeout
|
||||||
KR_BAN = 5, //Banned by server
|
KR_BAN = 5, //Banned by server
|
||||||
KR_LEAVE = 6, //Quit the game
|
KR_LEAVE = 6, //Quit the game
|
||||||
|
KR_IDLE = 7, //Remained still for too long
|
||||||
} kickreason_t;
|
} kickreason_t;
|
||||||
|
|
||||||
/* the max number of name changes in some time period */
|
/* the max number of name changes in some time period */
|
||||||
|
@ -73,7 +73,7 @@ extern UINT32 realpingtable[MAXPLAYERS];
|
||||||
extern UINT32 playerpingtable[MAXPLAYERS];
|
extern UINT32 playerpingtable[MAXPLAYERS];
|
||||||
extern tic_t servermaxping;
|
extern tic_t servermaxping;
|
||||||
|
|
||||||
extern consvar_t cv_netticbuffer, cv_resynchattempts, cv_blamecfail, cv_playbackspeed, cv_dedicatedidletime;
|
extern consvar_t cv_netticbuffer, cv_resynchattempts, cv_blamecfail, cv_playbackspeed, cv_idletime, cv_dedicatedidletime;
|
||||||
|
|
||||||
// Used in d_net, the only dependence
|
// Used in d_net, the only dependence
|
||||||
void D_ClientServerInit(void);
|
void D_ClientServerInit(void);
|
||||||
|
|
|
@ -601,6 +601,7 @@ void D_RegisterServerCommands(void)
|
||||||
CV_RegisterVar(&cv_showjoinaddress);
|
CV_RegisterVar(&cv_showjoinaddress);
|
||||||
CV_RegisterVar(&cv_blamecfail);
|
CV_RegisterVar(&cv_blamecfail);
|
||||||
CV_RegisterVar(&cv_dedicatedidletime);
|
CV_RegisterVar(&cv_dedicatedidletime);
|
||||||
|
CV_RegisterVar(&cv_idletime);
|
||||||
|
|
||||||
COM_AddCommand("ping", Command_Ping_f, COM_LUA);
|
COM_AddCommand("ping", Command_Ping_f, COM_LUA);
|
||||||
CV_RegisterVar(&cv_nettimeout);
|
CV_RegisterVar(&cv_nettimeout);
|
||||||
|
|
|
@ -331,6 +331,7 @@ typedef struct
|
||||||
#define KICK_MSG_PING_HIGH 6
|
#define KICK_MSG_PING_HIGH 6
|
||||||
#define KICK_MSG_CUSTOM_KICK 7
|
#define KICK_MSG_CUSTOM_KICK 7
|
||||||
#define KICK_MSG_CUSTOM_BAN 8
|
#define KICK_MSG_CUSTOM_BAN 8
|
||||||
|
#define KICK_MSG_IDLE 9
|
||||||
#define KICK_MSG_KEEP_BODY 0x80
|
#define KICK_MSG_KEEP_BODY 0x80
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
Loading…
Reference in a new issue