| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128 | 
							- using System;
 
- using System.Collections.Generic;
 
- using System.Linq;
 
- using System.Threading;
 
- using System.Threading.Tasks;
 
- using Jellyfin.Database.Implementations;
 
- using Jellyfin.Database.Implementations.Entities;
 
- using MediaBrowser.Controller.Drawing;
 
- using MediaBrowser.Controller.Persistence;
 
- using MediaBrowser.Model.Entities;
 
- using Microsoft.EntityFrameworkCore;
 
- namespace Jellyfin.Server.Implementations.Item;
 
- /// <summary>
 
- /// The Chapter manager.
 
- /// </summary>
 
- public class ChapterRepository : IChapterRepository
 
- {
 
-     private readonly IDbContextFactory<JellyfinDbContext> _dbProvider;
 
-     private readonly IImageProcessor _imageProcessor;
 
-     /// <summary>
 
-     /// Initializes a new instance of the <see cref="ChapterRepository"/> class.
 
-     /// </summary>
 
-     /// <param name="dbProvider">The EFCore provider.</param>
 
-     /// <param name="imageProcessor">The Image Processor.</param>
 
-     public ChapterRepository(IDbContextFactory<JellyfinDbContext> dbProvider, IImageProcessor imageProcessor)
 
-     {
 
-         _dbProvider = dbProvider;
 
-         _imageProcessor = imageProcessor;
 
-     }
 
-     /// <inheritdoc />
 
-     public ChapterInfo? GetChapter(Guid baseItemId, int index)
 
-     {
 
-         using var context = _dbProvider.CreateDbContext();
 
-         var chapter = context.Chapters.AsNoTracking()
 
-             .Select(e => new
 
-             {
 
-                 chapter = e,
 
-                 baseItemPath = e.Item.Path
 
-             })
 
-             .FirstOrDefault(e => e.chapter.ItemId.Equals(baseItemId) && e.chapter.ChapterIndex == index);
 
-         if (chapter is not null)
 
-         {
 
-             return Map(chapter.chapter, chapter.baseItemPath!);
 
-         }
 
-         return null;
 
-     }
 
-     /// <inheritdoc />
 
-     public IReadOnlyList<ChapterInfo> GetChapters(Guid baseItemId)
 
-     {
 
-         using var context = _dbProvider.CreateDbContext();
 
-         return context.Chapters.AsNoTracking().Where(e => e.ItemId.Equals(baseItemId))
 
-             .Select(e => new
 
-             {
 
-                 chapter = e,
 
-                 baseItemPath = e.Item.Path
 
-             })
 
-             .AsEnumerable()
 
-             .Select(e => Map(e.chapter, e.baseItemPath!))
 
-             .ToArray();
 
-     }
 
-     /// <inheritdoc />
 
-     public void SaveChapters(Guid itemId, IReadOnlyList<ChapterInfo> chapters)
 
-     {
 
-         using var context = _dbProvider.CreateDbContext();
 
-         using (var transaction = context.Database.BeginTransaction())
 
-         {
 
-             context.Chapters.Where(e => e.ItemId.Equals(itemId)).ExecuteDelete();
 
-             for (var i = 0; i < chapters.Count; i++)
 
-             {
 
-                 var chapter = chapters[i];
 
-                 context.Chapters.Add(Map(chapter, i, itemId));
 
-             }
 
-             context.SaveChanges();
 
-             transaction.Commit();
 
-         }
 
-     }
 
-     /// <inheritdoc />
 
-     public async Task DeleteChaptersAsync(Guid itemId, CancellationToken cancellationToken)
 
-     {
 
-         var dbContext = await _dbProvider.CreateDbContextAsync(cancellationToken).ConfigureAwait(false);
 
-         await using (dbContext.ConfigureAwait(false))
 
-         {
 
-             await dbContext.Chapters.Where(c => c.ItemId.Equals(itemId)).ExecuteDeleteAsync(cancellationToken).ConfigureAwait(false);
 
-             await dbContext.SaveChangesAsync(cancellationToken).ConfigureAwait(false);
 
-         }
 
-     }
 
-     private Chapter Map(ChapterInfo chapterInfo, int index, Guid itemId)
 
-     {
 
-         return new Chapter()
 
-         {
 
-             ChapterIndex = index,
 
-             StartPositionTicks = chapterInfo.StartPositionTicks,
 
-             ImageDateModified = chapterInfo.ImageDateModified,
 
-             ImagePath = chapterInfo.ImagePath,
 
-             ItemId = itemId,
 
-             Name = chapterInfo.Name,
 
-             Item = null!
 
-         };
 
-     }
 
-     private ChapterInfo Map(Chapter chapterInfo, string baseItemPath)
 
-     {
 
-         var chapterEntity = new ChapterInfo()
 
-         {
 
-             StartPositionTicks = chapterInfo.StartPositionTicks,
 
-             ImageDateModified = chapterInfo.ImageDateModified.GetValueOrDefault(),
 
-             ImagePath = chapterInfo.ImagePath,
 
-             Name = chapterInfo.Name,
 
-         };
 
-         if (!string.IsNullOrEmpty(chapterInfo.ImagePath))
 
-         {
 
-             chapterEntity.ImageTag = _imageProcessor.GetImageCacheTag(baseItemPath, chapterEntity.ImageDateModified);
 
-         }
 
-         return chapterEntity;
 
-     }
 
- }
 
 
  |