#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.Text; using HeuristicLab.Hive.Contracts.BusinessObjects; using HeuristicLab.DataAccess.Interfaces; using System.IO; namespace HeuristicLab.Hive.Server.DataAccess { public interface IJobAdapter: IDataAdapter { /// /// Gets all subjobs of the specified job /// /// ICollection GetAllSubjobs(JobDto job); /// /// Gets all Jobs with the specified state /// /// ICollection GetJobsByState(State state); /// /// Finds a job with the specified criterias /// /// all jobs with the specified state /// all jobs which require less or equal cores /// all jobs which require less or equal memory /// all jobs that can be calculated by that resource /// ICollection FindJobs(State state, int cores, int memory, Guid resourceId); /// /// Gets all jobs of the client /// /// /// ICollection GetJobsOf(ClientDto client); /// /// Gets all active jobs of the client /// /// /// ICollection GetActiveJobsOf(ClientDto client); /// /// Gets all jobs of the user /// /// /// ICollection GetJobsOf(Guid userId); /// /// Gets all jobs of the project /// /// /// ICollection GetJobsByProject(Guid projectId); /// /// Gets the computable job with the secified jobId /// /// /// SerializedJob GetSerializedJob(Guid jobId); /// /// Gets a stream object for the large serialized job data /// /// /// Stream GetSerializedJobStream(Guid jobId, bool useExistingConnection); /// /// Saves or update the computable job /// /// void UpdateSerializedJob(SerializedJob job); } }