Skip to content
Snippets Groups Projects
Select Git revision
  • 3bd106a1ff0ca19f814ec41ed38029051b19cb04
  • master default protected
  • gitkeep
  • dev protected
  • Issue/2583-treeBug
  • Hotfix/2504-formGen
  • Issue/2309-docs
  • Issue/2462-removeTraces
  • Hotfix/2459-EncodingPath
  • Hotfix/2452-linkedDeletion
  • Issue/1792-newMetadataStructure
  • Hotfix/2384-guestsAndLinked
  • v2.8.14-Hotfix2365
  • Hotfix/2365-targetClassWorks
  • Hotfix/2371-fixGitLabinRCV
  • Fix/xxxx-activateGitlab
  • Test/xxxx-enablingGitLab
  • Issue/2349-gitlabHttps
  • Issue/2287-guestRole
  • Hotfix/2296-selectedValuesNotReturned
  • Issue/2102-gitLabResTypeRCV
  • v2.11.5
  • v2.11.4
  • v2.11.3
  • v2.11.2
  • v2.11.1
  • v2.11.0
  • v2.10.3
  • v2.10.2
  • v2.10.1
  • v2.10.0
  • v2.9.4
  • v2.9.3
  • v2.9.2
  • v2.9.1
  • v2.9.0
  • v2.8.16
  • v2.8.15
  • v2.8.14
  • v2.8.13
  • v2.8.12
41 results

Tree.csproj

Blame
  • Code owners
    Assign users and groups as approvers for specific file changes. Learn more.
    DatabaseModel.cs 3.11 KiB
    using Coscine.Database.DataModel;
    using Coscine.Database.Util;
    using Microsoft.EntityFrameworkCore;
    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Linq.Expressions;
    using LinqKit;
    
    namespace Coscine.Database.Models
    {
        public abstract class DatabaseModel<T> where T : class
        {
            public abstract Expression<Func<T, Guid>> GetIdFromObject();
    
            public abstract void SetObjectId(T databaseObject, Guid id);
    
            public abstract Microsoft.EntityFrameworkCore.DbSet<T> GetITableFromDatabase(CoscineDB db);
    
    
            // GetById utilizes the Expression functionality since Linq2Sql does not support method calls
            // This is therefore a workaround for getting the Id parameter
            public virtual T GetById(Guid id)
            {
                Expression<Func<T, Guid>> expression = GetIdFromObject();
                return DatabaseConnection.ConnectToDatabase((db) =>
                {
                    return
                        (from tableEntry in GetITableFromDatabase(db).AsExpandable()
                         where expression.Invoke(tableEntry) == id
                         select tableEntry).FirstOrDefault();
                });
            }
    
            public virtual T GetWhere(Expression<Func<T, bool>> whereClause)
            {
                return DatabaseConnection.ConnectToDatabase((db) =>
                {
                    return
                        (from tableEntry in GetITableFromDatabase(db).AsExpandable()
                         where whereClause.Invoke(tableEntry)
                         select tableEntry).FirstOrDefault();
                });
            }
    
            public virtual IEnumerable<T> GetAll()
            {
                return DatabaseConnection.ConnectToDatabase((db) =>
                {
                    return
                        (from tableEntry in GetITableFromDatabase(db)
                         select tableEntry).ToList();
                });
            }
    
            public virtual IEnumerable<T> GetAllWhere(Expression<Func<T, bool>> whereClause)
            {
                return DatabaseConnection.ConnectToDatabase((db) =>
                {
                    return
                        (from tableEntry in GetITableFromDatabase(db).AsExpandable()
                         where whereClause.Invoke(tableEntry)
                         select tableEntry).ToList();
                });
            }
    
            public virtual int Update(T databaseObject)
            {
                return DatabaseConnection.ConnectToDatabase((db) =>
                {
                    return (int) db.Update(databaseObject).State;
                });
            }
    
            public virtual int Insert(T databaseObject)
            {
                if (GetIdFromObject().Compile()(databaseObject) == new Guid("00000000-0000-0000-0000-000000000000"))
                {
                    SetObjectId(databaseObject, Guid.NewGuid());
                }
    
                return DatabaseConnection.ConnectToDatabase((db) =>
                {
                    return db.Insert(databaseObject);
                });
            }
    
            public virtual int Delete(T databaseObject)
            {
                return DatabaseConnection.ConnectToDatabase((db) =>
                {
                    return db.Delete(databaseObject);
                });
            }
        }
    }