mirror of
				https://bitbucket.org/Ioncannon/project-meteor-server.git
				synced 2025-05-20 08:26:59 -04:00 
			
		
		
		
	
		
			
				
	
	
		
			88 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			88 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| /*
 | |
| ===========================================================================
 | |
| Copyright (C) 2015-2019 Project Meteor Dev Team
 | |
| 
 | |
| This file is part of Project Meteor Server.
 | |
| 
 | |
| Project Meteor Server is free software: you can redistribute it and/or modify
 | |
| it under the terms of the GNU Affero General Public License as published by
 | |
| the Free Software Foundation, either version 3 of the License, or
 | |
| (at your option) any later version.
 | |
| 
 | |
| Project Meteor 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 Affero General Public License for more details.
 | |
| 
 | |
| You should have received a copy of the GNU Affero General Public License
 | |
| along with Project Meteor Server. If not, see <https:www.gnu.org/licenses/>.
 | |
| ===========================================================================
 | |
| */
 | |
| 
 | |
| using System;
 | |
| using System.Diagnostics;
 | |
| using System.Threading;
 | |
| 
 | |
| using MySql.Data.MySqlClient;
 | |
| using NLog;
 | |
| 
 | |
| namespace Meteor.Lobby
 | |
| {
 | |
|     class Program
 | |
|     {
 | |
|         public static Logger Log;
 | |
| 
 | |
|         static void Main(string[] args)
 | |
|         {
 | |
| 
 | |
|             // set up logging
 | |
|             Log = LogManager.GetCurrentClassLogger();
 | |
| #if DEBUG
 | |
|             TextWriterTraceListener myWriter = new TextWriterTraceListener(System.Console.Out);
 | |
|             Debug.Listeners.Add(myWriter);
 | |
| #endif
 | |
|             Log.Info("==================================");
 | |
|             Log.Info("Project Meteor: Lobby Server");
 | |
|             Log.Info("Version: 0.1");            
 | |
|             Log.Info("==================================");
 | |
| 
 | |
|             bool startServer = true;
 | |
| 
 | |
|             //Load Config
 | |
|             ConfigConstants.Load();
 | |
|             ConfigConstants.ApplyLaunchArgs(args);
 | |
|             
 | |
|             //Test DB Connection
 | |
|             Program.Log.Info("Testing DB connection to \"{0}\"... ", ConfigConstants.DATABASE_HOST);
 | |
|             using (MySqlConnection conn = new MySqlConnection(String.Format("Server={0}; Port={1}; Database={2}; UID={3}; Password={4}", ConfigConstants.DATABASE_HOST, ConfigConstants.DATABASE_PORT, ConfigConstants.DATABASE_NAME, ConfigConstants.DATABASE_USERNAME, ConfigConstants.DATABASE_PASSWORD)))
 | |
|             {
 | |
|                 try
 | |
|                 {
 | |
|                     conn.Open();
 | |
|                     conn.Close();
 | |
| 
 | |
|                     Program.Log.Info("Connection ok.");
 | |
|                 }
 | |
|                 catch (MySqlException e)
 | |
|                 {
 | |
|                     Program.Log.Error(e.ToString());                  
 | |
|                     startServer = false; 
 | |
|                 }
 | |
|             }
 | |
| 
 | |
|             //Start Server if A-OK
 | |
|             if (startServer)
 | |
|             {
 | |
|                 Server server = new Server();
 | |
|                 server.StartServer();
 | |
|                 while (true) Thread.Sleep(10000);
 | |
|             }
 | |
| 
 | |
|             Program.Log.Info("Press any key to continue...");
 | |
|             Console.ReadKey();
 | |
|         }
 | |
| 
 | |
|     
 | |
|     }
 | |
| }
 |