Fixed: Radarr not loading with an invalid sort key.

pull/2512/merge v0.2.0.1067
Leonardo Galli 7 years ago
parent b593c9272e
commit 30796388b0

@ -259,7 +259,7 @@ namespace NzbDrone.Core.Datastore
protected virtual SortBuilder<TModel> GetPagedQuery(QueryBuilder<TModel> query, PagingSpec<TModel> pagingSpec) protected virtual SortBuilder<TModel> GetPagedQuery(QueryBuilder<TModel> query, PagingSpec<TModel> pagingSpec)
{ {
return query.Where(pagingSpec.FilterExpression) return query.Where(pagingSpec.FilterExpression)
.OrderBy(pagingSpec.OrderByClause(), pagingSpec.ToSortDirection()); .OrderBy(pagingSpec.OrderByClause(x => x.Id), pagingSpec.ToSortDirection());
} }
protected void ModelCreated(TModel model) protected void ModelCreated(TModel model)

@ -6,10 +6,22 @@ namespace NzbDrone.Core.Datastore.Extensions
{ {
public static class PagingSpecExtensions public static class PagingSpecExtensions
{ {
public static Expression<Func<TModel, object>> OrderByClause<TModel>(this PagingSpec<TModel> pagingSpec) public static Expression<Func<TModel, object>> OrderByClause<TModel>(this PagingSpec<TModel> pagingSpec, Expression<Func<TModel, object>> defaultExpression = null)
{
try
{ {
return CreateExpression<TModel>(pagingSpec.SortKey); return CreateExpression<TModel>(pagingSpec.SortKey);
} }
catch
{
if (defaultExpression == null)
{
return x => x;
}
return defaultExpression;
}
}
public static int PagingOffset<TModel>(this PagingSpec<TModel> pagingSpec) public static int PagingOffset<TModel>(this PagingSpec<TModel> pagingSpec)
{ {

@ -161,7 +161,7 @@ namespace NzbDrone.Core.Movies
{ {
return Query.Where(pagingSpec.FilterExpression) return Query.Where(pagingSpec.FilterExpression)
.AndWhere(m => m.MovieFileId == 0) .AndWhere(m => m.MovieFileId == 0)
.OrderBy(pagingSpec.OrderByClause(), pagingSpec.ToSortDirection()) .OrderBy(pagingSpec.OrderByClause(x => x.SortTitle), pagingSpec.ToSortDirection())
.Skip(pagingSpec.PagingOffset()) .Skip(pagingSpec.PagingOffset())
.Take(pagingSpec.PageSize); .Take(pagingSpec.PageSize);
} }
@ -179,7 +179,7 @@ namespace NzbDrone.Core.Movies
return Query.Where(pagingSpec.FilterExpression) return Query.Where(pagingSpec.FilterExpression)
.AndWhere(m => m.MovieFileId != 0) .AndWhere(m => m.MovieFileId != 0)
.AndWhere(BuildQualityCutoffWhereClause(qualitiesBelowCutoff)) .AndWhere(BuildQualityCutoffWhereClause(qualitiesBelowCutoff))
.OrderBy(pagingSpec.OrderByClause(), pagingSpec.ToSortDirection()) .OrderBy(pagingSpec.OrderByClause(x => x.SortTitle), pagingSpec.ToSortDirection())
.Skip(pagingSpec.PagingOffset()) .Skip(pagingSpec.PagingOffset())
.Take(pagingSpec.PageSize); .Take(pagingSpec.PageSize);
} }

Loading…
Cancel
Save