// Kyoo - A portable and vast media library solution. // Copyright (c) Kyoo. // // See AUTHORS.md and LICENSE file in the project root for full license information. // // Kyoo 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 // any later version. // // Kyoo 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 Kyoo. If not, see . using System; using System.Collections.Generic; using System.Linq; using System.Linq.Expressions; using System.Threading.Tasks; using Kyoo.Abstractions.Controllers; using Kyoo.Abstractions.Models; using Kyoo.Database; using Microsoft.EntityFrameworkCore; namespace Kyoo.Core.Controllers { /// /// A local repository to handle providers. /// public class ProviderRepository : LocalRepository, IProviderRepository { /// /// The database handle /// private readonly DatabaseContext _database; /// /// Create a new . /// /// The database handle public ProviderRepository(DatabaseContext database) : base(database) { _database = database; } /// protected override Expression> DefaultSort => x => x.Slug; /// public override async Task> Search(string query) { return await _database.Providers .Where(_database.Like(x => x.Name, $"%{query}%")) .OrderBy(DefaultSort) .Take(20) .ToListAsync(); } /// public override async Task Create(Provider obj) { await base.Create(obj); _database.Entry(obj).State = EntityState.Added; await _database.SaveChangesAsync("Trying to insert a duplicated provider " + $"(slug {obj.Slug} already exists)."); return obj; } /// public override async Task Delete(Provider obj) { if (obj == null) throw new ArgumentNullException(nameof(obj)); _database.Entry(obj).State = EntityState.Deleted; await _database.SaveChangesAsync(); } /// public Task> GetMetadataID(Expression> where = null, Sort sort = default, Pagination limit = default) where T : class, IMetadata { return ApplyFilters(_database.MetadataIds() .Include(y => y.Provider), x => _database.MetadataIds().FirstOrDefaultAsync(y => y.ResourceID == x), x => x.ResourceID, where, sort, limit); } } }