#region License Information /* HeuristicLab * Copyright (C) 2002-2019 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.Data.Linq; using System.Linq; using System.Linq.Expressions; using HeuristicLab.Services.Hive.DataAccess.Interfaces; namespace HeuristicLab.Services.Hive.DataAccess.Daos { public class SlaveDao : IGenericDao { private readonly DataContext dataContext; private Table Table { get { return dataContext.GetTable(); } } private IQueryable Entities { get { return Table.OfType(); } } public SlaveDao(DataContext dataContext) { this.dataContext = dataContext; } #region IGenericDao Members public Slave GetById(Guid id) { return GetByIdQuery(dataContext, id); } public IQueryable Get(Expression> predicate) { return Entities.Where(predicate); } public IQueryable GetAll() { return Entities; } public IQueryable GetOnlineSlaves() { return Entities.Where(x => x.SlaveState != SlaveState.Offline); } public Slave Save(Slave entity) { Table.InsertOnSubmit(entity); return entity; } public IEnumerable Save(params Slave[] entities) { return entities.Select(Save).ToList(); } public IEnumerable Save(IEnumerable entities) { return entities.Select(Save).ToList(); } public Slave SaveOrAttach(Slave entity) { if (Table.Contains(entity)) { if (Table.GetOriginalEntityState(entity) == null) { Table.Attach(entity); } } else { Table.InsertOnSubmit(entity); } return entity; } public IEnumerable SaveOrAttach(params Slave[] entities) { return entities.Select(SaveOrAttach).ToList(); } public IEnumerable SaveOrAttach(IEnumerable entities) { return entities.Select(SaveOrAttach).ToList(); } public void Delete(Guid id) { Slave entity = GetById(id); if (entity != null) { Table.DeleteOnSubmit(entity); } } public void Delete(IEnumerable ids) { foreach (var id in ids) { Delete(id); } } public void Delete(Slave entity) { Table.DeleteOnSubmit(entity); } public void Delete(IEnumerable entities) { foreach (var entity in entities) { Delete(entity); } } public bool Exists(Slave entity) { return ExistsQuery(dataContext, entity); } public bool Exists(Guid id) { return GetById(id) != null; } #endregion public bool SlaveHasToShutdownComputer(Guid slaveId) { return dataContext.ExecuteQuery(DowntimeQueryString, slaveId, DateTime.Now, DowntimeType.Shutdown.ToString()).FirstOrDefault() > 0; } public bool SlaveIsAllowedToCalculate(Guid slaveId) { return dataContext.ExecuteQuery(DowntimeQueryString, slaveId, DateTime.Now, DowntimeType.Offline.ToString()).FirstOrDefault() == 0; } #region Compiled queries private static readonly Func GetByIdQuery = CompiledQuery.Compile((DataContext db, Guid slaveId) => (from slave in db.GetTable().OfType() where slave.ResourceId == slaveId select slave).SingleOrDefault()); private static readonly Func ExistsQuery = CompiledQuery.Compile((DataContext db, Slave entity) => db.GetTable().OfType().Contains(entity)); #endregion #region String queries private const string DowntimeQueryString = @" WITH pr AS ( SELECT ResourceId, ParentResourceId FROM [Resource] WHERE ResourceId = {0} UNION ALL SELECT r.ResourceId, r.ParentResourceId FROM [Resource] r JOIN pr ON r.ResourceId = pr.ParentResourceId ) SELECT COUNT(dt.DowntimeId) FROM pr JOIN [Downtime] dt ON pr.ResourceId = dt.ResourceId WHERE {1} BETWEEN dt.StartDate AND dt.EndDate AND dt.DowntimeType = {2} "; #endregion } }