/* * Copyright (c) 2009 Craig Sutherland * * Permission is hereby granted, free of charge, to any person * obtaining a copy of this software and associated documentation * files (the "Software"), to deal in the Software without * restriction, including without limitation the rights to use, * copy, modify, merge, publish, distribute, sublicense, and/or sell * copies of the Software, and to permit persons to whom the * Software is furnished to do so, subject to the following * conditions: * * The above copyright notice and this permission notice shall be * included in all copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR * OTHER DEALINGS IN THE SOFTWARE. */ using System; using System.Collections.Generic; using System.Linq; using System.Text; using ThoughtWorks.CruiseControl.Remote; using ThoughtWorks.CruiseControl.Remote.Messages; using NLog; namespace FastForward.Cache { public class RemotingServer : MarshalByRefObject, IMessageProcessor { #region Private fields private CacheEngine engine; private Logger logger; #endregion #region Constructors /// /// Initialise the remoting interface. /// /// public RemotingServer(Logger logger, CacheEngine engine) { this.logger = logger; this.engine = engine; } #endregion #region Public methods #region ProcessMessage() /// /// Processes a message. /// /// The action to use. /// The request message in an XML format. /// The response message in an XML format. public virtual string ProcessMessage(string action, string message) { // Convert into a request, because we need to work with some of the data values var request = XmlConversionUtil.ConvertXmlToRequest(message); var response = ProcessMessage(action, request); return response.ToString(); } /// /// Processes a message. /// /// The action to use. /// The request message. /// The response message. public virtual Response ProcessMessage(string action, ServerRequest message) { Response response = new Response(); try { // Pass the message onto the remote server logger.Debug("{0} action received", action); response = engine.ProcessMessage(action, message); } catch (Exception error) { // Return the error logger.ErrorException("Unable to process message " + action, error); response.Result = ResponseResult.Failure; response.ErrorMessages.Add( new ErrorMessage("Unable to process: " + error.Message)); } return response; } #endregion #region InitializeLifetimeService() /// /// Initialise the lifetime service. /// /// public override object InitializeLifetimeService() { return null; } #endregion #endregion } }