#region License Information /* HeuristicLab * Copyright (C) 2002-2008 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 System.Linq; using System.Text; using HeuristicLab.Hive.Contracts.Interfaces; using HeuristicLab.Hive.Contracts.BusinessObjects; using HeuristicLab.Hive.Contracts; using HeuristicLab.Security.Contracts.Interfaces; using HeuristicLab.Hive.Server.Core.InternalInterfaces; using System.ServiceModel; namespace HeuristicLab.Hive.Server.Core { public class ServerConsoleFacade: IServerConsoleFacade { private IClientManager clientManager = ServiceLocator.GetClientManager(); private IJobManager jobManager = ServiceLocator.GetJobManager(); private IHivePermissionManager secMan = ServiceLocator.GetHivePermissionManager(); public Guid sessionID = Guid.Empty; public ServerConsoleFacade() { } public Response Login(string username, string password) { Response resp = new Response(); sessionID = secMan.Login(username, password); if (sessionID == Guid.Empty) { resp.Success = false; resp.StatusMessage = ApplicationConstants.RESPONSE_SERVERCONSOLE_LOGIN_FAILED; } else { resp.Success = true; resp.StatusMessage = ApplicationConstants.RESPONSE_SERVERCONSOLE_LOGIN_SUCCESS; } return resp; } public ResponseList GetAllClients() { secMan.Authorize("AccessClients", sessionID, Guid.Empty); return clientManager.GetAllClients(); } public ResponseList GetAllClientGroups() { //secMan.Authorize("AccessClientGroup", sessionID, Guid.Empty); return clientManager.GetAllClientGroups(); } public ResponseList GetAllUpTimeStatistics() { secMan.Authorize("AccessStatistics", sessionID, Guid.Empty); return clientManager.GetAllUpTimeStatistics(); } public ResponseObject AddClientGroup(ClientGroupDto clientGroup) { secMan.Authorize("AddClientGroup", sessionID, Guid.Empty); return clientManager.AddClientGroup(clientGroup); } public Response AddResourceToGroup(Guid clientGroupId, ResourceDto resource) { secMan.Authorize("AddResource", sessionID, Guid.Empty); return clientManager.AddResourceToGroup(clientGroupId, resource); } public Response DeleteResourceFromGroup(Guid clientGroupId, Guid resourceId) { return clientManager.DeleteResourceFromGroup(clientGroupId, resourceId); } public ResponseList GetAllJobs() { secMan.Authorize("AccessJobs", sessionID, Guid.Empty); return jobManager.GetAllJobs(); } public ResponseObject GetJobById(Guid jobId) { secMan.Authorize("AccessJobs", sessionID, jobId); return jobManager.GetJobById(jobId); } public ResponseObject AddNewJob(SerializedJob job) { secMan.Authorize("AddJob", sessionID, job.JobInfo.Id); return jobManager.AddNewJob(job); } public ResponseObject GetLastJobResultOf(Guid jobId) { secMan.Authorize("AccessJobResults", sessionID, jobId); return jobManager.GetLastJobResultOf(jobId); } public ResponseObject GetLastSerializedJobResultOf(Guid jobId, bool requested) { secMan.Authorize("AccessJobResults", sessionID, jobId); return jobManager.GetLastSerializedJobResultOf(jobId, requested); } public ResponseList GetAllJobResults(Guid jobId) { secMan.Authorize("AccessJobResults", sessionID, jobId); return jobManager.GetAllJobResults(jobId); } public Response RemoveJob(Guid jobId) { secMan.Authorize("RemoveJob", sessionID, jobId); return jobManager.RemoveJob(jobId); } public Response RequestSnapshot(Guid jobId) { secMan.Authorize("AccessJobResults", sessionID, jobId); return jobManager.RequestSnapshot(jobId); } public Response AbortJob(Guid jobId) { secMan.Authorize("AbortJob", sessionID, Guid.Empty); return jobManager.AbortJob(jobId); } public ResponseObject> GetAllGroupsOfResource(Guid resourceId) { secMan.Authorize("AccessUserGroup", sessionID, Guid.Empty); return clientManager.GetAllGroupsOfResource(resourceId); } public Response DeleteClientGroup(Guid clientGroupId) { secMan.Authorize("DeleteClientGroup", sessionID, Guid.Empty); return clientManager.DeleteClientGroup(clientGroupId); } public ResponseList GetAllProjects() { secMan.Authorize("AccessProjects", sessionID, Guid.Empty); return jobManager.GetAllProjects(); } public Response CreateProject(ProjectDto project) { secMan.Authorize("CreateProjects", sessionID, Guid.Empty); return jobManager.CreateProject(project); } public Response ChangeProject(ProjectDto project) { secMan.Authorize("ChangeProjects", sessionID, Guid.Empty); return jobManager.ChangeProject(project); } public Response DeleteProject(Guid projectId) { secMan.Authorize("DeleteProjects", sessionID, projectId); return jobManager.DeleteProject(projectId); } public ResponseList GetJobsByProject(Guid projectId) { secMan.Authorize("AccessJobs", sessionID, Guid.Empty); return jobManager.GetJobsByProject(projectId); } public ResponseList GetUptimeCalendarForResource(Guid guid) { return clientManager.GetUptimeCalendarForResource(guid); } public Response SetUptimeCalendarForResource(Guid guid, IEnumerable appointments, bool isForced) { return clientManager.SetUptimeCalendarForResource(guid, appointments, isForced); } public ResponseObject AddJobWithGroupStrings(SerializedJob job, IEnumerable resources) { return jobManager.AddJobWithGroupStrings(job, resources); } } }