Skip to content
Snippets Groups Projects
Status.java 2.91 KiB
Newer Older
Zoey76's avatar
Zoey76 committed
/*
Zoey76's avatar
Zoey76 committed
 * Copyright © 2004-2024 L2J Server
Zoey76's avatar
Zoey76 committed
 * 
 * This file is part of L2J Server.
 * 
 * L2J Server is free software: you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 * 
 * L2J Server is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
 * General Public License for more details.
 * 
 * You should have received a copy of the GNU General Public License
 * along with this program. If not, see <http://www.gnu.org/licenses/>.
 */
package com.l2jserver.loginserver.status;

Zoey76's avatar
Zoey76 committed
import static com.l2jserver.loginserver.config.Configuration.telnet;

Zoey76's avatar
Zoey76 committed
import java.io.IOException;
import java.net.ServerSocket;
import java.net.Socket;
import java.util.LinkedList;
import java.util.List;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import com.l2jserver.commons.util.Util;

public class Status extends Thread {
	
	private static final Logger LOG = LoggerFactory.getLogger(Status.class);
	
	private final ServerSocket statusServerSocket;
	
	private final int _uptime;
	
	private String _statusPw;
	
	private final List<LoginStatusThread> _loginStatus;
	
	public Status() throws IOException {
		super("Status");
Zoey76's avatar
Zoey76 committed
		_statusPw = telnet().getPassword();
Zoey76's avatar
Zoey76 committed
		
		if (_statusPw == null) {
			_statusPw = Util.randomPassword(10);
			LOG.info("Server's Telnet function has no password defined!");
			LOG.info("A password has been automatically created!");
			LOG.info("Password has been set to: {}", _statusPw);
		}
		
Zoey76's avatar
Zoey76 committed
		statusServerSocket = new ServerSocket(telnet().getPort());
Zoey76's avatar
Zoey76 committed
		_uptime = (int) System.currentTimeMillis();
		_loginStatus = new LinkedList<>();
Zoey76's avatar
Zoey76 committed
		LOG.info("Telnet server started successfully, listening on port {}.", telnet().getPort());
Zoey76's avatar
Zoey76 committed
	}
	
	@Override
	public void run() {
		setPriority(Thread.MAX_PRIORITY);
		
		while (!isInterrupted()) {
			try {
				Socket connection = statusServerSocket.accept();
				LoginStatusThread lst = new LoginStatusThread(connection, _uptime, _statusPw);
				if (lst.isAlive()) {
					_loginStatus.add(lst);
				}
				
				if (isInterrupted()) {
					try {
						statusServerSocket.close();
					} catch (Exception ex) {
						LOG.warn("There has been an error closing status server socket!", ex);
					}
					break;
				}
			} catch (Exception ex1) {
				if (isInterrupted()) {
					try {
						statusServerSocket.close();
					} catch (Exception ex2) {
						LOG.warn("There has been an error closing status server socket!", ex2);
					}
					break;
				}
			}
		}
	}
	
	public void sendMessageToTelnets(String msg) {
		for (LoginStatusThread ls : _loginStatus) {
			if (!ls.isInterrupted()) {
				ls.printToTelnet(msg);
			}
		}
	}
}