mirror of
https://github.com/jellyfin/jellyfin.git
synced 2025-07-09 03:04:24 -04:00
Merge branch 'master' of https://github.com/MediaBrowser/MediaBrowser
This commit is contained in:
commit
c6de61d7bd
@ -11,6 +11,7 @@ using MediaBrowser.Model.Querying;
|
|||||||
using ServiceStack.ServiceHost;
|
using ServiceStack.ServiceHost;
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
|
using System.IO;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using System.Threading;
|
using System.Threading;
|
||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
@ -100,16 +101,24 @@ namespace MediaBrowser.Api
|
|||||||
[Api(Description = "Refreshes metadata for an item")]
|
[Api(Description = "Refreshes metadata for an item")]
|
||||||
public class RefreshItem : IReturnVoid
|
public class RefreshItem : IReturnVoid
|
||||||
{
|
{
|
||||||
[ApiMember(Name = "Forced", Description = "Indicates if a normal or forced refresh should occur.", IsRequired = true, DataType = "bool", ParameterType = "query", Verb = "POST")]
|
[ApiMember(Name = "Forced", Description = "Indicates if a normal or forced refresh should occur.", IsRequired = false, DataType = "bool", ParameterType = "query", Verb = "POST")]
|
||||||
public bool Forced { get; set; }
|
public bool Forced { get; set; }
|
||||||
|
|
||||||
[ApiMember(Name = "Recursive", Description = "Indicates if the refresh should occur recursively.", IsRequired = true, DataType = "bool", ParameterType = "query", Verb = "POST")]
|
[ApiMember(Name = "Recursive", Description = "Indicates if the refresh should occur recursively.", IsRequired = false, DataType = "bool", ParameterType = "query", Verb = "POST")]
|
||||||
public bool Recursive { get; set; }
|
public bool Recursive { get; set; }
|
||||||
|
|
||||||
[ApiMember(Name = "Id", Description = "Item Id", IsRequired = true, DataType = "string", ParameterType = "path", Verb = "POST")]
|
[ApiMember(Name = "Id", Description = "Item Id", IsRequired = true, DataType = "string", ParameterType = "path", Verb = "POST")]
|
||||||
public string Id { get; set; }
|
public string Id { get; set; }
|
||||||
}
|
}
|
||||||
|
|
||||||
|
[Route("/Items/{Id}", "DELETE")]
|
||||||
|
[Api(Description = "Deletes an item from the library and file system")]
|
||||||
|
public class DeleteItem : IReturnVoid
|
||||||
|
{
|
||||||
|
[ApiMember(Name = "Id", Description = "Item Id", IsRequired = true, DataType = "string", ParameterType = "path", Verb = "DELETE")]
|
||||||
|
public string Id { get; set; }
|
||||||
|
}
|
||||||
|
|
||||||
[Route("/Items/Counts", "GET")]
|
[Route("/Items/Counts", "GET")]
|
||||||
[Api(Description = "Gets counts of various item types")]
|
[Api(Description = "Gets counts of various item types")]
|
||||||
public class GetItemCounts : IReturn<ItemCounts>
|
public class GetItemCounts : IReturn<ItemCounts>
|
||||||
@ -223,9 +232,66 @@ namespace MediaBrowser.Api
|
|||||||
/// Posts the specified request.
|
/// Posts the specified request.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
/// <param name="request">The request.</param>
|
/// <param name="request">The request.</param>
|
||||||
public void Post(RefreshLibrary request)
|
public async void Post(RefreshLibrary request)
|
||||||
{
|
{
|
||||||
_libraryManager.ValidateMediaLibrary(new Progress<double>(), CancellationToken.None);
|
try
|
||||||
|
{
|
||||||
|
await _libraryManager.ValidateMediaLibrary(new Progress<double>(), CancellationToken.None).ConfigureAwait(false);
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
Logger.ErrorException("Error refreshing library", ex);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Deletes the specified request.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="request">The request.</param>
|
||||||
|
public async void Delete(DeleteItem request)
|
||||||
|
{
|
||||||
|
var item = DtoBuilder.GetItemByClientId(request.Id, _userManager, _libraryManager);
|
||||||
|
|
||||||
|
var parent = item.Parent;
|
||||||
|
|
||||||
|
if (item.LocationType == LocationType.FileSystem)
|
||||||
|
{
|
||||||
|
if (Directory.Exists(item.Path))
|
||||||
|
{
|
||||||
|
Directory.Delete(item.Path, true);
|
||||||
|
}
|
||||||
|
else if (File.Exists(item.Path))
|
||||||
|
{
|
||||||
|
File.Delete(item.Path);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (parent != null)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
await parent.ValidateChildren(new Progress<double>(), CancellationToken.None).ConfigureAwait(false);
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
Logger.ErrorException("Error refreshing item", ex);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (parent != null)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
await parent.RemoveChild(item, CancellationToken.None).ConfigureAwait(false);
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
Logger.ErrorException("Error removing item", ex);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
throw new InvalidOperationException("Don't know how to delete " + item.Name);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -322,19 +388,26 @@ namespace MediaBrowser.Api
|
|||||||
/// Posts the specified request.
|
/// Posts the specified request.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
/// <param name="request">The request.</param>
|
/// <param name="request">The request.</param>
|
||||||
public void Post(RefreshItem request)
|
public async void Post(RefreshItem request)
|
||||||
{
|
{
|
||||||
var item = DtoBuilder.GetItemByClientId(request.Id, _userManager, _libraryManager);
|
var item = DtoBuilder.GetItemByClientId(request.Id, _userManager, _libraryManager);
|
||||||
|
|
||||||
var folder = item as Folder;
|
var folder = item as Folder;
|
||||||
|
|
||||||
|
try
|
||||||
|
{
|
||||||
if (folder != null)
|
if (folder != null)
|
||||||
{
|
{
|
||||||
folder.ValidateChildren(new Progress<double>(), CancellationToken.None, request.Recursive, request.Forced);
|
await folder.ValidateChildren(new Progress<double>(), CancellationToken.None, request.Recursive, request.Forced).ConfigureAwait(false);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
item.RefreshMetadata(CancellationToken.None, forceRefresh: request.Forced);
|
await item.RefreshMetadata(CancellationToken.None, forceRefresh: request.Forced).ConfigureAwait(false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
Logger.ErrorException("Error refreshing library", ex);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -211,7 +211,7 @@ namespace MediaBrowser.Api.Playback
|
|||||||
/// <returns>MediaStream.</returns>
|
/// <returns>MediaStream.</returns>
|
||||||
private MediaStream GetMediaStream(IEnumerable<MediaStream> allStream, int? desiredIndex, MediaStreamType type, bool returnFirstIfNoIndex = true)
|
private MediaStream GetMediaStream(IEnumerable<MediaStream> allStream, int? desiredIndex, MediaStreamType type, bool returnFirstIfNoIndex = true)
|
||||||
{
|
{
|
||||||
var streams = allStream.Where(s => s.Type == type).ToList();
|
var streams = allStream.Where(s => s.Type == type).OrderBy(i => i.Index).ToList();
|
||||||
|
|
||||||
if (desiredIndex.HasValue)
|
if (desiredIndex.HasValue)
|
||||||
{
|
{
|
||||||
|
@ -161,19 +161,19 @@ namespace MediaBrowser.Common.Implementations.HttpClientManager
|
|||||||
|
|
||||||
options.CancellationToken.ThrowIfCancellationRequested();
|
options.CancellationToken.ThrowIfCancellationRequested();
|
||||||
|
|
||||||
var message = GetHttpRequestMessage(options);
|
using (var message = GetHttpRequestMessage(options))
|
||||||
|
{
|
||||||
//if (options.EnableResponseCache && cachedInfo != null)
|
if (options.EnableResponseCache && cachedInfo != null)
|
||||||
//{
|
{
|
||||||
// if (!string.IsNullOrEmpty(cachedInfo.Etag))
|
if (!string.IsNullOrEmpty(cachedInfo.Etag))
|
||||||
// {
|
{
|
||||||
// message.Headers.Add("If-None-Match", cachedInfo.Etag);
|
message.Headers.Add("If-None-Match", cachedInfo.Etag);
|
||||||
// }
|
}
|
||||||
// else if (cachedInfo.LastModified.HasValue)
|
else if (cachedInfo.LastModified.HasValue)
|
||||||
// {
|
{
|
||||||
// message.Headers.IfModifiedSince = new DateTimeOffset(cachedInfo.LastModified.Value);
|
message.Headers.IfModifiedSince = new DateTimeOffset(cachedInfo.LastModified.Value);
|
||||||
// }
|
}
|
||||||
//}
|
}
|
||||||
|
|
||||||
if (options.ResourcePool != null)
|
if (options.ResourcePool != null)
|
||||||
{
|
{
|
||||||
@ -248,6 +248,8 @@ namespace MediaBrowser.Common.Implementations.HttpClientManager
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Performs a GET request and returns the resulting stream
|
/// Performs a GET request and returns the resulting stream
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
@ -56,6 +56,30 @@ namespace MediaBrowser.Controller.Providers.MediaInfo
|
|||||||
ImageCache = new FileSystemRepository(Kernel.Instance.FFMpegManager.AudioImagesDataPath);
|
ImageCache = new FileSystemRepository(Kernel.Instance.FFMpegManager.AudioImagesDataPath);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets a value indicating whether [refresh on version change].
|
||||||
|
/// </summary>
|
||||||
|
/// <value><c>true</c> if [refresh on version change]; otherwise, <c>false</c>.</value>
|
||||||
|
protected override bool RefreshOnVersionChange
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets the provider version.
|
||||||
|
/// </summary>
|
||||||
|
/// <value>The provider version.</value>
|
||||||
|
protected override string ProviderVersion
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
return "1";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Supportses the specified item.
|
/// Supportses the specified item.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
@ -150,17 +174,17 @@ namespace MediaBrowser.Controller.Providers.MediaInfo
|
|||||||
{
|
{
|
||||||
semaphore.Release();
|
semaphore.Release();
|
||||||
}
|
}
|
||||||
|
|
||||||
// Image is already in the cache
|
|
||||||
item.PrimaryImagePath = path;
|
|
||||||
|
|
||||||
await _libraryManager.UpdateItem(item, cancellationToken).ConfigureAwait(false);
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
semaphore.Release();
|
semaphore.Release();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Image is already in the cache
|
||||||
|
item.PrimaryImagePath = path;
|
||||||
|
|
||||||
|
await _libraryManager.UpdateItem(item, cancellationToken).ConfigureAwait(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
|
@ -423,19 +423,6 @@ namespace MediaBrowser.Server.Implementations.Providers
|
|||||||
dataToSave.Position = 0;
|
dataToSave.Position = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!(dataToSave is MemoryStream || dataToSave is FileStream))
|
|
||||||
{
|
|
||||||
var ms = new MemoryStream();
|
|
||||||
|
|
||||||
using (dataToSave)
|
|
||||||
{
|
|
||||||
await dataToSave.CopyToAsync(ms).ConfigureAwait(false);
|
|
||||||
}
|
|
||||||
|
|
||||||
ms.Position = 0;
|
|
||||||
dataToSave = ms;
|
|
||||||
}
|
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
using (dataToSave)
|
using (dataToSave)
|
||||||
|
@ -220,6 +220,11 @@ namespace MediaBrowser.Server.Implementations.Session
|
|||||||
data.PlayCount++;
|
data.PlayCount++;
|
||||||
data.LastPlayedDate = DateTime.UtcNow;
|
data.LastPlayedDate = DateTime.UtcNow;
|
||||||
|
|
||||||
|
if (!(item is Video))
|
||||||
|
{
|
||||||
|
data.Played = true;
|
||||||
|
}
|
||||||
|
|
||||||
await _userDataRepository.SaveUserData(user.Id, key, data, CancellationToken.None).ConfigureAwait(false);
|
await _userDataRepository.SaveUserData(user.Id, key, data, CancellationToken.None).ConfigureAwait(false);
|
||||||
|
|
||||||
// Nothing to save here
|
// Nothing to save here
|
||||||
|
Loading…
x
Reference in New Issue
Block a user