#region License Information /* HeuristicLab * Copyright (C) 2002-2010 Heuristic and Evolutionary Algorithms Laboratory (HEAL) * * This file is part of HeuristicLab. * * HeuristicLab 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. * * HeuristicLab 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 HeuristicLab. If not, see . */ #endregion using System; using System.Collections.Generic; using HeuristicLab.Common; using HeuristicLab.Services.Hive.Common; using HeuristicLab.Services.Hive.Common.DataTransfer; using HeuristicLab.Services.Hive.Common.ServiceContracts; namespace HeuristicLab.Clients.Hive.Slave { /// /// WcfService class is implemented as a Singleton and works as a communication Layer with the Server /// public class WcfService : MarshalByRefObject { private static WcfService instance; /// /// Getter for the Instance of the WcfService /// /// the Instance of the WcfService class public static WcfService Instance { get { if (instance == null) { instance = new WcfService(); ServiceLocator.Instance.Username = "hiveslave"; ServiceLocator.Instance.Password = "hiveslave"; } return instance; } } public DateTime ConnectedSince { get; private set; } public NetworkEnum.WcfConnState ConnState { get; private set; } public event EventHandler Connected; private void OnConnected() { var handler = Connected; if (handler != null) handler(this, EventArgs.Empty); } public event EventHandler> ExceptionOccured; private void OnExceptionOccured(Exception e) { var handler = ExceptionOccured; if (handler != null) handler(this, new EventArgs(e)); } /// /// Constructor /// private WcfService() { ConnState = NetworkEnum.WcfConnState.Disconnected; } /// /// Connects with the Server, registers the events and fires the Connected (and quiet possibly the ConnectionRestored) Event. /// public void Connect(HeuristicLab.Services.Hive.Common.DataTransfer.Slave slaveInfo) { CallHiveService(service => { ConnState = NetworkEnum.WcfConnState.Connected; ConnectedSince = DateTime.Now; service.Hello(slaveInfo); OnConnected(); }); } /// /// Disconnects the Slave from the Server /// public void Disconnect() { CallHiveService(service => { service.GoodBye(ConfigManager.Instance.GetClientInfo().Id); ConnState = NetworkEnum.WcfConnState.Disconnected; }); } /// /// Network communication Error Handler - Every network error gets logged and the connection switches to faulted state /// /// The Exception private void HandleNetworkError(Exception e) { ConnState = NetworkEnum.WcfConnState.Failed; OnExceptionOccured(e); } /// /// Get a Job from the Server /// public Job GetJob(Guid jobId) { return CallHiveService(s => s.GetJob(jobId)); } public JobData GetJobData(Guid jobId) { return CallHiveService(s => s.GetJobData(jobId)); } public void UpdateJob(Job job) { CallHiveService(s => s.UpdateJob(job)); } /// /// used on pause or if job finished to upload the job results /// /// /// public void UpdateJobData(Job job, JobData jobData, Guid slaveId) { CallHiveService(service => { JobState before = job.State; job.SetState(JobState.Transferring, slaveId, ""); service.UpdateJob(job); service.UpdateJobData(job, jobData); job.SetState(before, slaveId, ""); service.UpdateJob(job); }); } public List SendHeartbeat(Heartbeat heartbeat) { return CallHiveService(s => s.Heartbeat(heartbeat)); } public IEnumerable GetPluginDatas(List pluginIds) { return CallHiveService(s => s.GetPluginDatas(pluginIds)); } public IEnumerable GetPlugins() { return CallHiveService(s => s.GetPlugins()); } public Guid AddChildJob(Guid parentJobId, Job job, JobData jobData) { return CallHiveService(s => s.AddChildJob(parentJobId, job, jobData)); } public IEnumerable GetChildJobs(Guid? parentJobId) { return CallHiveService(service => { IEnumerable msg = service.GetLightweightChildJobs(parentJobId, false, false); List jobs = new List(); foreach (LightweightJob ljob in msg) jobs.Add(service.GetJobData(ljob.Id)); return jobs; }); } public void DeleteChildJobs(Guid jobId) { CallHiveService(s => s.DeleteChildJobs(jobId)); } public void CallHiveService(Action call) { try { ServiceLocator.Instance.CallHiveService(call); } catch (Exception ex) { HandleNetworkError(ex); } } private T CallHiveService(Func call) { try { return ServiceLocator.Instance.CallHiveService(call); } catch (Exception ex) { HandleNetworkError(ex); return default(T); } } } }