Blaze The Cat
Member
This is Utility.
It's simply a server management tool that gives added functionality for play on your server. It's nothing absolutely huge, but it can definitely make games a little more bearable, especially unmanaged ones.
Player Commands
util <parameter> - This will list the commands and variables in Utility. If there is no parameter, it will give you a line by line list. If your parameter is "short" it will give you a short-form list. If you enter a command or a variable as the parameter, it will give you help on that command/variable.
callvote <command> [parameter] <reason> - This will allow you to call a vote to perform a specified command in the server's console. By default, you have kick, exitlevel, timelimit, pointlimit, and map. Exitlevel does not take in a [parameter] and thus it becomes a <reason> instead.
vote <yes/no> - This will let you vote on the currently started vote. There is no reverse after voting, so please be decisive.
showvotecmds - This will list the currently available commands you can call a vote for. An asterisk next to a command means anyone can start a vote for that command. Unstarred commands can only be called for by a server or admin player.
afk - This only works in Co-Op, and will set your player character into AFK mode, freezing you in place, turning you transparent, and counting you as "exiting" for purposes of level completion. It also has a split-screen counterpart, afk2
ignore <node/name> - This lets you ignore chat from a specified node or player name. This works locally to you and does not inform the other player. A dedicated server may not ignore players. If that node becomes no longer valid (i.e. the player left the game) the ignore is cleared for you.
unignore <node/name> - Works the same as ignore but in reverse, as expected.
utilversion - Shows you what version of Utility you are using.
updatename - This is a helper command for updating the dedicated server's name. Because server variables do not properly sync for whatever reason, I had to make a workaround. The name should update on its own, but this is here in the event of a problem.
Admin Commands
sayadmin <msg> - Lets you send a message that only admins can hear. This includes Terminal permissions FULLCONTROL, PLAYERMANAGE, the vanilla admin, and the host. Cool Kids Club unite.
votepermission <command> [allow/deny] - This will enable you to deny or allow certain commands from unprivileged players. Not supplying alloy/deny will show you the current setting. You may also set these permissions with their respective console variables, explained later.
silence <node/name> <seconds> - Allows you to silence a user for a specified period of time. A silenced user cannot use regular chat or team-based chat, but can still privately message other players. Other players can mitigate private messages by ignoring the offending player if they see fit.
unsilence <node/name> - The same as silence, except in reverse.
gametype <mode> - This will let you change the gametype. You will be sent to the first available map for the specified gametype. Your options are: coop, race, competition, match, teammatch, tag, hideandseek, ctf.
csay <message> - This replaces the old and no longer working csay command. It simply takes your message and performs a 5-second notice.
notice <seconds> <message> [delay] - Unlike the old behavior of the csay command, this will put screen messages in a line-up one after the other. This will send a notice for the number of seconds specified, from 1-30, using your message. If a delay is used, your notice will be delayed for that amount of time first, THEN be displayed. If you specify the number of seconds to be zero, specify a message to clear the current list of notices with <message> as the reason to do so.
changesky <node/name> - Allows you to change the current sky for everyone.
changemus <node/name> - Allows you to change the current music for everyone.
Server Commands
dediname <string> - Lets the dedicated server get a name. By default, they are named "Server" so feel free to change that if you wish. A lot better than "Player 1" I hope.
Console Variables
These are all server/admin only.
util_minvoters <1-8> Default: 2 - Lets you define the minimum amount of players needed before a vote can occur. A server or admin always bypasses this limitation.
util_votecmd_<command> <Yes/No> Default: Yes - Replace <command> with a vote command to control whether that command can be publicly controlled or not.
util_vote_time <10-300> Default: 30 - Determines how long a vote should be held up for
util_vote_delay <0-61356675> Default: 300 - This specifies the delay in which a player is able to start another vote after theirs finished, in seconds. All players join with a 30-second delay to prevent rejoin-voting.
util_vote_specvote <Yes/No> Default: Yes - This specifies if spectators count as voters or not. Set this to no if you don't want spectators calling votes or participating in votes. Admins and the server can always call a vote, but cannot participate in a vote of this rule is in place.
util_coop_exittime <0-30> Default: 0 - This allows you to set a time limit until which the level is auto-exited, in minutes. Applies to Co-Op only. An indicator will show at the bottom of the screen once one minute remains. Changing this limit is not retroactive; setting this to 5 minutes after 6 minutes have passed will not end the level.
util_spam_time <0-30> Default: 3 AND util_spam_num <0-30> Default: 5 - These two are partner variables that determine the time frame and number of messages to check, respectively. If the player speaks a certain number of messages in shorter than the specified time, the player gets a 60-second silence. The server is not accounted for in spam prevention.
util_spam_repeats <Yes/No> Default: Yes - When enabled, this will prevent players from saying the same message repeatedly.
Other Notes
Chat is slightly revamped. It should be much easier to see team chat, and far easier to differentiate private messages. The /me chat macro works anywhere now except csay and notice. Unfortunately, csay got broken in the process, so I made a notice command to replace it. The csay is replaced for legacy reasons, simply performing a 5-second notice.
If Terminal is added with this Lua, it will see it and use its symbol system. In addition, players with PLAYERMANAGE and FULLCONTROL permissions (@ or higher) can use all admin-only commands as well, alongside the vanilla admin. No need to use the do command.
You don't need quotation marks for messages since it will concatenate all your arguments for you. This excludes notice, as it has an argument that follows.
If you're looking for cheats, sorry. Utility will never contain any form of Terminal-style cheating.
Anyway, here's hoping you enjoy it. Special thanks to all who helped test this.
Supporters and Co-Authors section is for people who have at least helped in various ways;
It's simply a server management tool that gives added functionality for play on your server. It's nothing absolutely huge, but it can definitely make games a little more bearable, especially unmanaged ones.
Player Commands
util <parameter> - This will list the commands and variables in Utility. If there is no parameter, it will give you a line by line list. If your parameter is "short" it will give you a short-form list. If you enter a command or a variable as the parameter, it will give you help on that command/variable.
callvote <command> [parameter] <reason> - This will allow you to call a vote to perform a specified command in the server's console. By default, you have kick, exitlevel, timelimit, pointlimit, and map. Exitlevel does not take in a [parameter] and thus it becomes a <reason> instead.
vote <yes/no> - This will let you vote on the currently started vote. There is no reverse after voting, so please be decisive.
showvotecmds - This will list the currently available commands you can call a vote for. An asterisk next to a command means anyone can start a vote for that command. Unstarred commands can only be called for by a server or admin player.
afk - This only works in Co-Op, and will set your player character into AFK mode, freezing you in place, turning you transparent, and counting you as "exiting" for purposes of level completion. It also has a split-screen counterpart, afk2
ignore <node/name> - This lets you ignore chat from a specified node or player name. This works locally to you and does not inform the other player. A dedicated server may not ignore players. If that node becomes no longer valid (i.e. the player left the game) the ignore is cleared for you.
unignore <node/name> - Works the same as ignore but in reverse, as expected.
utilversion - Shows you what version of Utility you are using.
updatename - This is a helper command for updating the dedicated server's name. Because server variables do not properly sync for whatever reason, I had to make a workaround. The name should update on its own, but this is here in the event of a problem.
Admin Commands
sayadmin <msg> - Lets you send a message that only admins can hear. This includes Terminal permissions FULLCONTROL, PLAYERMANAGE, the vanilla admin, and the host. Cool Kids Club unite.
votepermission <command> [allow/deny] - This will enable you to deny or allow certain commands from unprivileged players. Not supplying alloy/deny will show you the current setting. You may also set these permissions with their respective console variables, explained later.
silence <node/name> <seconds> - Allows you to silence a user for a specified period of time. A silenced user cannot use regular chat or team-based chat, but can still privately message other players. Other players can mitigate private messages by ignoring the offending player if they see fit.
unsilence <node/name> - The same as silence, except in reverse.
gametype <mode> - This will let you change the gametype. You will be sent to the first available map for the specified gametype. Your options are: coop, race, competition, match, teammatch, tag, hideandseek, ctf.
csay <message> - This replaces the old and no longer working csay command. It simply takes your message and performs a 5-second notice.
notice <seconds> <message> [delay] - Unlike the old behavior of the csay command, this will put screen messages in a line-up one after the other. This will send a notice for the number of seconds specified, from 1-30, using your message. If a delay is used, your notice will be delayed for that amount of time first, THEN be displayed. If you specify the number of seconds to be zero, specify a message to clear the current list of notices with <message> as the reason to do so.
changesky <node/name> - Allows you to change the current sky for everyone.
changemus <node/name> - Allows you to change the current music for everyone.
Server Commands
dediname <string> - Lets the dedicated server get a name. By default, they are named "Server" so feel free to change that if you wish. A lot better than "Player 1" I hope.
Console Variables
These are all server/admin only.
util_minvoters <1-8> Default: 2 - Lets you define the minimum amount of players needed before a vote can occur. A server or admin always bypasses this limitation.
util_votecmd_<command> <Yes/No> Default: Yes - Replace <command> with a vote command to control whether that command can be publicly controlled or not.
util_vote_time <10-300> Default: 30 - Determines how long a vote should be held up for
util_vote_delay <0-61356675> Default: 300 - This specifies the delay in which a player is able to start another vote after theirs finished, in seconds. All players join with a 30-second delay to prevent rejoin-voting.
util_vote_specvote <Yes/No> Default: Yes - This specifies if spectators count as voters or not. Set this to no if you don't want spectators calling votes or participating in votes. Admins and the server can always call a vote, but cannot participate in a vote of this rule is in place.
util_coop_exittime <0-30> Default: 0 - This allows you to set a time limit until which the level is auto-exited, in minutes. Applies to Co-Op only. An indicator will show at the bottom of the screen once one minute remains. Changing this limit is not retroactive; setting this to 5 minutes after 6 minutes have passed will not end the level.
util_spam_time <0-30> Default: 3 AND util_spam_num <0-30> Default: 5 - These two are partner variables that determine the time frame and number of messages to check, respectively. If the player speaks a certain number of messages in shorter than the specified time, the player gets a 60-second silence. The server is not accounted for in spam prevention.
util_spam_repeats <Yes/No> Default: Yes - When enabled, this will prevent players from saying the same message repeatedly.
Other Notes
Chat is slightly revamped. It should be much easier to see team chat, and far easier to differentiate private messages. The /me chat macro works anywhere now except csay and notice. Unfortunately, csay got broken in the process, so I made a notice command to replace it. The csay is replaced for legacy reasons, simply performing a 5-second notice.
If Terminal is added with this Lua, it will see it and use its symbol system. In addition, players with PLAYERMANAGE and FULLCONTROL permissions (@ or higher) can use all admin-only commands as well, alongside the vanilla admin. No need to use the do command.
You don't need quotation marks for messages since it will concatenate all your arguments for you. This excludes notice, as it has an argument that follows.
If you're looking for cheats, sorry. Utility will never contain any form of Terminal-style cheating.
Anyway, here's hoping you enjoy it. Special thanks to all who helped test this.
Supporters and Co-Authors section is for people who have at least helped in various ways;
- Kitoko - Script co-author.
- NotablyPrettyCrazy - Helped a lot with script crash-testing.
- RedEnchilada - For borrowing the GetSymbol function from Terminal because it's not defined in the global table.
- SpectrumUK - Also helps with testing by hosting the script and reporting problems.
Attachments
Last edited: