This repository has been archived on 2021-12-05. You can view files and clone it, but cannot push or open issues or pull requests.
envoy/src/main/java/envoy/server/Startup.java

85 lines
2.6 KiB
Java
Raw Normal View History

package envoy.server;
2020-06-11 11:45:17 +02:00
import java.io.File;
import java.io.IOException;
2020-06-11 11:45:17 +02:00
import java.util.HashMap;
import java.util.Set;
2020-06-11 11:45:17 +02:00
import java.util.logging.Level;
import com.jenkov.nioserver.Server;
2020-06-11 11:45:17 +02:00
import envoy.data.Config;
import envoy.data.ConfigItem;
import envoy.server.data.PersistenceManager;
import envoy.server.net.ConnectionManager;
import envoy.server.net.ObjectMessageProcessor;
import envoy.server.net.ObjectMessageReader;
2020-06-11 11:45:17 +02:00
import envoy.server.processors.*;
import envoy.util.EnvoyLog;
/**
2019-12-30 15:15:25 +01:00
* Starts the server.<br>
* <br>
* Project: <strong>envoy-server-standalone</strong><br>
* File: <strong>Startup.java</strong><br>
* Created: <strong>24.12.2019</strong><br>
2019-12-30 15:15:25 +01:00
*
* @author Kai S. K. Engelbart
* @since Envoy Server Standalone v0.1-alpha
*/
public class Startup {
2020-06-11 11:45:17 +02:00
/**
* Initializes the logger with a new config instance.
*
* @since Envoy Server Standalone v0.1-beta
*/
private static void initLogging() {
final var items = new HashMap<String, ConfigItem<?>>();
items.put("homeDirectory",
new ConfigItem<>("homeDirectory", "h", File::new, new File(System.getProperty("user.home"), ".envoy-server"), true));
items.put("fileLevelBarrier", new ConfigItem<>("fileLevelBarrier", "fb", Level::parse, Level.WARNING, true));
items.put("consoleLevelBarrier", new ConfigItem<>("consoleLevelBarrier", "cb", Level::parse, Level.FINEST, true));
2020-06-11 11:45:17 +02:00
final var config = new Config();
config.load(items);
EnvoyLog.initialize(config);
2020-06-11 12:08:51 +02:00
EnvoyLog.attach("envoy");
2020-06-11 11:45:17 +02:00
}
2019-12-30 15:15:25 +01:00
/**
* Starts the server.
*
* @param args the run configuration. Currently unused.
* @throws IOException if the server crashes
* @since Envoy Server Standalone v0.1-alpha
*/
public static void main(String[] args) throws IOException {
2020-06-11 11:45:17 +02:00
initLogging();
Server server = new Server(8080, ObjectMessageReader::new,
new ObjectMessageProcessor(Set.of(new LoginCredentialProcessor(),
new MessageProcessor(),
new GroupCreationProcessor(),
new MessageStatusChangeProcessor(),
new UserStatusChangeProcessor(),
new IDGeneratorRequestProcessor(),
new ContactSearchProcessor(),
new ContactOperationProcessor())));
// Initialize the current message ID
PersistenceManager persistenceManager = PersistenceManager.getInstance();
if (persistenceManager.getConfigItemByID("currentMessageId") == null)
2020-06-11 11:45:17 +02:00
persistenceManager.addConfigItem(new envoy.server.data.ConfigItem("currentMessageId", "0"));
server.start();
server.getSocketProcessor().registerSocketIdListener(ConnectionManager.getInstance());
2020-02-07 10:02:40 +01:00
System.out.println("Press the return key to stop the server...");
System.in.read();
2020-03-14 15:08:58 +01:00
System.out.println("Stopped");
System.exit(0);
}
}