/* * Copyright (c) Contributors, http://opensimulator.org/ * See CONTRIBUTORS.TXT for a full list of copyright holders. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are met: * * Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * * Neither the name of the OpenSim Project nor the * names of its contributors may be used to endorse or promote products * derived from this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE * DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ using System; using System.IO; using System.Reflection; using OpenMetaverse; using log4net; using log4net.Config; using OpenSim.Framework; using OpenSim.Framework.Communications.Cache; using OpenSim.Framework.Console; using OpenSim.Framework.Servers; namespace OpenSim.Grid.MessagingServer { /// /// public class OpenMessage_Main : BaseOpenSimServer, conscmd_callback { private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType); private MessageServerConfig Cfg; private MessageService msgsvc; // private UUID m_lastCreatedUser = UUID.Random(); public static void Main(string[] args) { XmlConfigurator.Configure(); m_log.Info("[SERVER]: Launching MessagingServer..."); OpenMessage_Main messageserver = new OpenMessage_Main(); messageserver.Startup(); messageserver.Work(); } private OpenMessage_Main() { m_console = new ConsoleBase("Messaging", this); MainConsole.Instance = m_console; } private void Work() { m_console.Notice("Enter help for a list of commands\n"); while (true) { m_console.Prompt(); } } private void registerWithUserServer() { if (msgsvc.registerWithUserServer()) { m_log.Info("[SERVER]: Starting HTTP process"); m_httpServer = new BaseHttpServer(Cfg.HttpPort); m_httpServer.AddXmlRPCHandler("login_to_simulator", msgsvc.UserLoggedOn); m_httpServer.AddXmlRPCHandler("logout_of_simulator", msgsvc.UserLoggedOff); m_httpServer.AddXmlRPCHandler("get_presence_info_bulk", msgsvc.GetPresenceInfoBulk); m_httpServer.AddXmlRPCHandler("region_startup", msgsvc.RegionStartup); m_httpServer.AddXmlRPCHandler("region_shutdown", msgsvc.RegionShutdown); m_httpServer.AddXmlRPCHandler("agent_location", msgsvc.AgentLocation); m_httpServer.AddXmlRPCHandler("agent_leaving", msgsvc.AgentLeaving); m_httpServer.Start(); m_log.Info("[SERVER]: Userserver registration was successful"); } else { m_log.Error("[STARTUP]: Unable to connect to User Server"); } } private void deregisterFromUserServer() { msgsvc.deregisterWithUserServer(); if (m_httpServer != null) { // try a completely fresh registration, with fresh handlers, too m_httpServer.Stop(); m_httpServer = null; } m_console.Notice("[SERVER]: Deregistered from userserver."); } protected override void StartupSpecific() { Cfg = new MessageServerConfig("MESSAGING SERVER", (Path.Combine(Util.configDir(), "MessagingServer_Config.xml"))); msgsvc = new MessageService(Cfg); registerWithUserServer(); m_log.Info("[SERVER]: Messageserver 0.5 - Startup complete"); } public void do_create(string what) { switch (what) { case "user": try { //userID = //m_userManager.AddUserProfile(tempfirstname, templastname, tempMD5Passwd, regX, regY); } catch (Exception ex) { m_console.Error("[SERVER]: Error creating user: {0}", ex.ToString()); } try { //RestObjectPoster.BeginPostObject(m_userManager._config.InventoryUrl + "CreateInventory/", //userID.Guid); } catch (Exception ex) { m_console.Error("[SERVER]: Error creating inventory for user: {0}", ex.ToString()); } // m_lastCreatedUser = userID; break; } } public override void RunCmd(string cmd, string[] cmdparams) { base.RunCmd(cmd, cmdparams); switch (cmd) { case "clear-cache": int entries = msgsvc.ClearRegionCache(); m_console.Notice("Region cache cleared! Cleared " + entries.ToString() + " entries"); break; case "register": deregisterFromUserServer(); registerWithUserServer(); break; } } protected override void ShowHelp(string[] helpArgs) { base.ShowHelp(helpArgs); m_console.Notice("clear-cache - Clears region cache. Should be done when regions change position. The region cache gets stale after a while."); m_console.Notice("register - (Re-)registers with user-server. This might be necessary if the userserver crashed/restarted"); } protected override void ShutdownSpecific() { msgsvc.deregisterWithUserServer(); } } }