1
0
mirror of https://github.com/Sonarr/Sonarr.git synced 2024-11-01 08:22:35 +01:00
Sonarr/NzbDrone.Core/Datastore/BasicRepository.cs

157 lines
3.8 KiB
C#
Raw Normal View History

2013-03-24 05:16:00 +01:00
using System;
using System.Collections.Generic;
using System.Data;
2013-02-05 05:07:07 +01:00
using System.Linq;
2013-03-24 05:16:00 +01:00
using System.Linq.Expressions;
2013-03-25 04:51:32 +01:00
using Marr.Data;
using Marr.Data.QGen;
2013-02-05 05:07:07 +01:00
namespace NzbDrone.Core.Datastore
{
2013-03-02 19:25:39 +01:00
public interface IBasicRepository<TModel> where TModel : ModelBase, new()
2013-02-05 05:07:07 +01:00
{
2013-02-19 07:56:02 +01:00
IEnumerable<TModel> All();
2013-02-23 20:38:25 +01:00
int Count();
TModel Get(int id);
TModel SingleOrDefault();
2013-02-19 07:56:02 +01:00
TModel Insert(TModel model);
TModel Update(TModel model);
2013-03-24 05:16:00 +01:00
TModel Upsert(TModel model);
void Delete(int id);
void Delete(TModel model);
2013-03-24 05:16:00 +01:00
void InsertMany(IList<TModel> model);
void UpdateMany(IList<TModel> model);
void DeleteMany(List<TModel> model);
2013-02-23 20:38:25 +01:00
void Purge();
2013-03-02 19:25:39 +01:00
bool HasItems();
2013-03-24 05:16:00 +01:00
void DeleteMany(IEnumerable<int> ids);
void UpdateFields<TKey>(TModel model, Expression<Func<TModel, TKey>> onlyFields);
2013-02-05 05:07:07 +01:00
}
public class BasicRepository<TModel> : IBasicRepository<TModel> where TModel : ModelBase, new()
2013-02-05 05:07:07 +01:00
{
2013-03-25 04:51:32 +01:00
private readonly IDataMapper _dataMapper;
2013-03-25 04:51:32 +01:00
public BasicRepository(IDatabase database)
2013-02-05 05:07:07 +01:00
{
2013-03-25 04:51:32 +01:00
_dataMapper = database.DataMapper;
2013-02-05 05:07:07 +01:00
}
2013-03-25 04:51:32 +01:00
protected QueryBuilder<TModel> Queryable()
2013-02-05 05:07:07 +01:00
{
2013-03-25 04:51:32 +01:00
return _dataMapper.Query<TModel>();
2013-02-05 05:07:07 +01:00
}
2013-03-25 04:51:32 +01:00
public IEnumerable<TModel> All()
2013-02-23 20:38:25 +01:00
{
2013-03-25 04:51:32 +01:00
return _dataMapper.Query<TModel>().ToList();
}
2013-03-25 04:51:32 +01:00
public int Count()
{
2013-03-25 04:51:32 +01:00
return _dataMapper.Query<TModel>().Count();
2013-02-23 20:38:25 +01:00
}
public TModel Get(int id)
2013-02-05 05:07:07 +01:00
{
2013-03-25 08:36:22 +01:00
return _dataMapper.Query<TModel>().Single(c => c.Id == id);
2013-02-05 05:07:07 +01:00
}
public TModel SingleOrDefault()
{
2013-03-24 05:16:00 +01:00
return All().Single();
}
2013-02-19 07:56:02 +01:00
public TModel Insert(TModel model)
2013-02-05 05:07:07 +01:00
{
2013-03-24 20:56:51 +01:00
if (model.Id != 0)
{
throw new InvalidOperationException("Can't insert model with existing ID");
}
2013-03-25 04:51:32 +01:00
var id = _dataMapper.Insert(model);
2013-03-24 05:16:00 +01:00
return model;
2013-02-05 05:07:07 +01:00
}
public TModel Update(TModel model)
{
2013-03-24 20:56:51 +01:00
if (model.Id == 0)
{
throw new InvalidOperationException("Can't update model with ID 0");
}
2013-03-25 04:51:32 +01:00
_dataMapper.Update(model, c => c.Id == model.Id);
2013-03-24 05:16:00 +01:00
return model;
}
2013-03-24 05:16:00 +01:00
public void Delete(TModel model)
{
2013-03-25 04:51:32 +01:00
_dataMapper.Delete<TModel>(c => c.Id == model.Id);
}
2013-03-24 05:16:00 +01:00
public void InsertMany(IList<TModel> models)
{
2013-03-25 04:51:32 +01:00
foreach (var model in models)
{
Insert(model);
}
}
2013-03-24 05:16:00 +01:00
public void UpdateMany(IList<TModel> models)
{
2013-03-25 04:51:32 +01:00
foreach (var model in models)
{
Update(model);
}
}
2013-03-24 05:16:00 +01:00
public void DeleteMany(List<TModel> models)
{
2013-03-25 04:51:32 +01:00
models.ForEach(Delete);
}
2013-03-24 05:16:00 +01:00
public TModel Upsert(TModel model)
{
if (model.Id == 0)
2013-02-23 20:38:25 +01:00
{
2013-03-25 04:51:32 +01:00
Insert(model);
2013-03-24 05:16:00 +01:00
return model;
2013-02-23 20:38:25 +01:00
}
2013-03-25 04:51:32 +01:00
Update(model);
2013-03-24 05:16:00 +01:00
return model;
}
public void Delete(int id)
2013-02-05 05:07:07 +01:00
{
2013-03-25 04:51:32 +01:00
_dataMapper.Delete<TModel>(c => c.Id == id);
2013-02-05 05:07:07 +01:00
}
2013-02-23 20:38:25 +01:00
public void DeleteMany(IEnumerable<int> ids)
{
2013-03-25 04:51:32 +01:00
ids.ToList().ForEach(Delete);
2013-02-23 20:38:25 +01:00
}
public void Purge()
{
2013-03-25 04:51:32 +01:00
_dataMapper.Delete<TModel>(c => c.Id > -1);
2013-02-23 20:38:25 +01:00
}
2013-03-02 19:25:39 +01:00
public bool HasItems()
{
2013-03-24 05:16:00 +01:00
return Count() > 0;
}
public void UpdateFields<TKey>(TModel model, Expression<Func<TModel, TKey>> onlyFields)
2013-03-24 05:16:00 +01:00
{
if (model.Id == 0)
{
throw new InvalidOperationException("Attempted to updated model without ID");
}
2013-03-25 08:36:22 +01:00
// _database.UpdateOnly(model, onlyFields, m => m.Id == model.Id);
2013-03-02 19:25:39 +01:00
}
2013-02-05 05:07:07 +01:00
}
}