Added active/inactive and running/stopped statuses to the server list command.

Thanks to the suggestion from "oldman,j" via MSM's UserVoice.
This commit is contained in:
Marcus Whybrow 2012-07-15 18:29:04 +01:00
parent 1d38b80eb6
commit b280bebf37

View File

@ -265,7 +265,7 @@ world_deactivate() {
# config information for that server # config information for that server
# $1: The name of the server # $1: The name of the server
server_get_id() { server_get_id() {
for ((i=0; i<$num_servers; i++)); do for ((i=0; i<$NUM_SERVERS; i++)); do
if [[ "${SERVER_NAME[$i]}" == "$1" ]]; then if [[ "${SERVER_NAME[$i]}" == "$1" ]]; then
echo "$i" echo "$i"
return 0 return 0
@ -675,8 +675,31 @@ jargroup_rename() {
# Echos a list of servers in the SETTINGS_SERVER_STORAGE_PATH # Echos a list of servers in the SETTINGS_SERVER_STORAGE_PATH
server_list() { server_list() {
if [ -d "$SETTINGS_SERVER_STORAGE_PATH" ]; then if [ "$NUM_SERVERS" -gt 0 ]; then
ls -1 "$SETTINGS_SERVER_STORAGE_PATH" for ((server=0; server<$NUM_SERVERS; server++)); do
if "${SERVER_ACTIVE[$server]}"; then
echo -n "[ ACTIVE ] "
else
echo -n "[INACTIVE] "
fi
echo -n "\"${SERVER_NAME[$server]}\" "
if "${SERVER_ACTIVE[$server]}"; then
if server_is_running "$server"; then
echo "is running. Everything is OK."
else
echo "is stopped. Server is down!"
fi
else
if server_is_running "$server"; then
echo "is running. It should not be running!"
else
echo "is stopped. Everything is OK."
fi
fi
done
else else
echo "[There are no servers]" echo "[There are no servers]"
fi fi
@ -1069,7 +1092,7 @@ manager_stop_all_servers() {
# For all running servers issue the stop warning # For all running servers issue the stop warning
local max_countdown=0 local max_countdown=0
for ((server=0; server<${num_servers}; server++)); do for ((server=0; server<${NUM_SERVERS}; server++)); do
if server_is_running "$server"; then if server_is_running "$server"; then
any_running="true" any_running="true"
was_running[$server]="true" was_running[$server]="true"
@ -1118,7 +1141,7 @@ manager_stop_all_servers() {
# Each second check all server, to see if its their time to # Each second check all server, to see if its their time to
# stop. If so issue the stop command, and don't hang. # stop. If so issue the stop command, and don't hang.
for ((server=0; server<${num_servers}; server++)); do for ((server=0; server<${NUM_SERVERS}; server++)); do
if server_is_running "$server"; then if server_is_running "$server"; then
stop_tick="$(( ${max_countdown} - ${SERVER_STOP_DELAY[$server]} ))" stop_tick="$(( ${max_countdown} - ${SERVER_STOP_DELAY[$server]} ))"
if [[ "$stop_tick" == "$tick" ]]; then if [[ "$stop_tick" == "$tick" ]]; then
@ -1140,7 +1163,7 @@ manager_stop_all_servers() {
echo "Now." echo "Now."
# Finally check all servers have stopped # Finally check all servers have stopped
for ((server=0; server<${num_servers}; server++)); do for ((server=0; server<${NUM_SERVERS}; server++)); do
if "${was_running[$server]}"; then if "${was_running[$server]}"; then
echo -n "Ensuring server \"${SERVER_NAME[$server]}\" has stopped... " echo -n "Ensuring server \"${SERVER_NAME[$server]}\" has stopped... "
server_wait_for_stop "$server" server_wait_for_stop "$server"
@ -1160,7 +1183,7 @@ manager_stop_all_servers_now() {
local any_running="false" local any_running="false"
# Stop all servers at the same time # Stop all servers at the same time
for ((server=0; server<${num_servers}; server++)); do for ((server=0; server<${NUM_SERVERS}; server++)); do
if server_is_running "$server"; then if server_is_running "$server"; then
was_running[$server]="true" was_running[$server]="true"
any_running="true" any_running="true"
@ -1174,7 +1197,7 @@ manager_stop_all_servers_now() {
if "$any_running"; then if "$any_running"; then
# Ensure all the servers have stopped # Ensure all the servers have stopped
for ((server=0; server<${num_servers}; server++)); do for ((server=0; server<${NUM_SERVERS}; server++)); do
if "${was_running[$server]}"; then if "${was_running[$server]}"; then
echo -n "Ensuring server \"${SERVER_NAME[$server]}\" has stopped... " echo -n "Ensuring server \"${SERVER_NAME[$server]}\" has stopped... "
server_wait_for_stop "$server" server_wait_for_stop "$server"
@ -1198,7 +1221,7 @@ manager_property() {
# Starts all servers # Starts all servers
command_start() { command_start() {
# Required start option, for debian init.d scripts # Required start option, for debian init.d scripts
for ((server=0; server<${num_servers}; server++)); do for ((server=0; server<${NUM_SERVERS}; server++)); do
# Only starts active servers # Only starts active servers
if "${SERVER_ACTIVE[$server]}"; then if "${SERVER_ACTIVE[$server]}"; then
if server_is_running "$server"; then if server_is_running "$server"; then
@ -2189,7 +2212,7 @@ server_init() {
SERVER_NUM_WORLDS[$1]=0 SERVER_NUM_WORLDS[$1]=0
# Start world id's for this server's worlds at the end of the array # Start world id's for this server's worlds at the end of the array
local id="$num_worlds" local id="$NUM_WORLDS"
# Record the index at which worlds for this server start # Record the index at which worlds for this server start
SERVER_WORLD_OFFSET[$1]="$id" SERVER_WORLD_OFFSET[$1]="$id"
@ -2208,7 +2231,7 @@ server_init() {
fi fi
id="$(($id+1))" id="$(($id+1))"
num_worlds="$id" NUM_WORLDS="$id"
done < <(find "${SERVER_WORLD_STORAGE_PATH[$1]}" -mindepth 1 -maxdepth 1 -type d -print0) done < <(find "${SERVER_WORLD_STORAGE_PATH[$1]}" -mindepth 1 -maxdepth 1 -type d -print0)
fi fi
@ -2226,7 +2249,7 @@ server_init() {
fi fi
id="$(($id+1))" id="$(($id+1))"
num_worlds="$id" NUM_WORLDS="$id"
done < <(find "${SERVER_WORLD_STORAGE_INACTIVE_PATH[$1]}" -mindepth 1 -maxdepth 1 -type d -print0) done < <(find "${SERVER_WORLD_STORAGE_INACTIVE_PATH[$1]}" -mindepth 1 -maxdepth 1 -type d -print0)
fi fi
@ -2356,8 +2379,8 @@ init() {
register_settings register_settings
load_conf load_conf
num_worlds=0 NUM_WORLDS=0
num_servers=0 NUM_SERVERS=0
if [ -d "$SETTINGS_SERVER_STORAGE_PATH" ]; then if [ -d "$SETTINGS_SERVER_STORAGE_PATH" ]; then
local id=0 local id=0
@ -2365,7 +2388,7 @@ init() {
local name="$(basename "$path")" local name="$(basename "$path")"
server_init "$id" "$name" server_init "$id" "$name"
id="$(($id+1))" id="$(($id+1))"
num_servers="$id" NUM_SERVERS="$id"
done < <(find "$SETTINGS_SERVER_STORAGE_PATH" -mindepth 1 -maxdepth 1 -type d -print0) done < <(find "$SETTINGS_SERVER_STORAGE_PATH" -mindepth 1 -maxdepth 1 -type d -print0)
fi fi
} }
@ -2373,7 +2396,7 @@ init() {
# Called if the script is interrupted before exiting naturally # Called if the script is interrupted before exiting naturally
interrupt() { interrupt() {
local exit_message="false" local exit_message="false"
for ((i=0; $i<$num_servers; i++)); do for ((i=0; $i<$NUM_SERVERS; i++)); do
if [[ "${STOP_COUNTDOWN[$i]}" == "true" ]] && server_is_running "$i"; then if [[ "${STOP_COUNTDOWN[$i]}" == "true" ]] && server_is_running "$i"; then
if [[ "$exit_message" == "false" ]]; then if [[ "$exit_message" == "false" ]]; then
echo -e "\nInterrupted..." echo -e "\nInterrupted..."
@ -2601,7 +2624,7 @@ call_command() {
# This code block calls the handler for all possible servers and # This code block calls the handler for all possible servers and
# all possible worlds. # all possible worlds.
if [[ "$sid" == "server:all" ]] && [[ "$wid" == "world:all" ]]; then if [[ "$sid" == "server:all" ]] && [[ "$wid" == "world:all" ]]; then
for ((j=0; j<$num_worlds; j++)); do for ((j=0; j<$NUM_WORLDS; j++)); do
# Replace server and world id placeholders with actual id's # Replace server and world id placeholders with actual id's
local replaced_args local replaced_args
for k in ${!args[@]}; do for k in ${!args[@]}; do
@ -2620,7 +2643,7 @@ call_command() {
# This calls the handler for all possible servers, and preserves # This calls the handler for all possible servers, and preserves
# all other arguments. # all other arguments.
if [[ "$sid" == "server:all" ]]; then if [[ "$sid" == "server:all" ]]; then
for ((j=0; j<$num_servers; j++)); do for ((j=0; j<$NUM_SERVERS; j++)); do
local replaced_args local replaced_args
for k in ${!args[@]}; do for k in ${!args[@]}; do
replaced_args[$k]="${args[$k]//server\:all/$j}" replaced_args[$k]="${args[$k]//server\:all/$j}"