mirror of
https://github.com/Prowlarr/Prowlarr.git
synced 2025-09-17 17:14:18 +02:00

* Custom Script: Add Movie_Path * Add Emby Update Support * Notifications: Maybe add Kodi / XBMC Update Support
149 lines
4.4 KiB
C#
149 lines
4.4 KiB
C#
using System;
|
|
using System.Collections.Generic;
|
|
using System.Linq;
|
|
using NLog;
|
|
using NzbDrone.Core.Notifications.Xbmc.Model;
|
|
using NzbDrone.Core.Tv;
|
|
|
|
namespace NzbDrone.Core.Notifications.Xbmc
|
|
{
|
|
public class JsonApiProvider : IApiProvider
|
|
{
|
|
private readonly IXbmcJsonApiProxy _proxy;
|
|
private readonly Logger _logger;
|
|
|
|
public JsonApiProvider(IXbmcJsonApiProxy proxy, Logger logger)
|
|
{
|
|
_proxy = proxy;
|
|
_logger = logger;
|
|
}
|
|
|
|
public bool CanHandle(XbmcVersion version)
|
|
{
|
|
return version >= new XbmcVersion(5);
|
|
}
|
|
|
|
public void Notify(XbmcSettings settings, string title, string message)
|
|
{
|
|
_proxy.Notify(settings, title, message);
|
|
}
|
|
|
|
public void Update(XbmcSettings settings, Series series)
|
|
{
|
|
if (!settings.AlwaysUpdate)
|
|
{
|
|
_logger.Debug("Determining if there are any active players on XBMC host: {0}", settings.Address);
|
|
var activePlayers = _proxy.GetActivePlayers(settings);
|
|
|
|
if (activePlayers.Any(a => a.Type.Equals("video")))
|
|
{
|
|
_logger.Debug("Video is currently playing, skipping library update");
|
|
return;
|
|
}
|
|
}
|
|
|
|
UpdateLibrary(settings, series);
|
|
}
|
|
|
|
public void UpdateMovie(XbmcSettings settings, Movie movie)
|
|
{
|
|
if (!settings.AlwaysUpdate)
|
|
{
|
|
_logger.Debug("Determining if there are any active players on XBMC host: {0}", settings.Address);
|
|
var activePlayers = _proxy.GetActivePlayers(settings);
|
|
|
|
if (activePlayers.Any(a => a.Type.Equals("video")))
|
|
{
|
|
_logger.Debug("Video is currently playing, skipping library update");
|
|
return;
|
|
}
|
|
}
|
|
|
|
UpdateMovieLibrary(settings, movie);
|
|
}
|
|
|
|
|
|
public void Clean(XbmcSettings settings)
|
|
{
|
|
_proxy.CleanLibrary(settings);
|
|
}
|
|
|
|
public List<ActivePlayer> GetActivePlayers(XbmcSettings settings)
|
|
{
|
|
return _proxy.GetActivePlayers(settings);
|
|
}
|
|
|
|
public string GetSeriesPath(XbmcSettings settings, Series series)
|
|
{
|
|
var allSeries = _proxy.GetSeries(settings);
|
|
|
|
if (!allSeries.Any())
|
|
{
|
|
_logger.Debug("No TV shows returned from XBMC");
|
|
return null;
|
|
}
|
|
|
|
var matchingSeries = allSeries.FirstOrDefault(s =>
|
|
{
|
|
var tvdbId = 0;
|
|
int.TryParse(s.ImdbNumber, out tvdbId);
|
|
|
|
return tvdbId == series.TvdbId || s.Label == series.Title;
|
|
});
|
|
|
|
if (matchingSeries != null) return matchingSeries.File;
|
|
|
|
return null;
|
|
}
|
|
|
|
private void UpdateLibrary(XbmcSettings settings, Series series)
|
|
{
|
|
try
|
|
{
|
|
var seriesPath = GetSeriesPath(settings, series);
|
|
|
|
if (seriesPath != null)
|
|
{
|
|
_logger.Debug("Updating series {0} (Path: {1}) on XBMC host: {2}", series, seriesPath, settings.Address);
|
|
}
|
|
|
|
else
|
|
{
|
|
_logger.Debug("Series {0} doesn't exist on XBMC host: {1}, Updating Entire Library", series,
|
|
settings.Address);
|
|
}
|
|
|
|
var response = _proxy.UpdateLibrary(settings, seriesPath);
|
|
|
|
if (!response.Equals("OK", StringComparison.InvariantCultureIgnoreCase))
|
|
{
|
|
_logger.Debug("Failed to update library for: {0}", settings.Address);
|
|
}
|
|
}
|
|
|
|
catch (Exception ex)
|
|
{
|
|
_logger.Debug(ex, ex.Message);
|
|
}
|
|
}
|
|
|
|
private void UpdateMovieLibrary(XbmcSettings settings, Movie movie)
|
|
{
|
|
try
|
|
{
|
|
var response = _proxy.UpdateLibrary(settings, null);
|
|
|
|
if (!response.Equals("OK", StringComparison.InvariantCultureIgnoreCase))
|
|
{
|
|
_logger.Debug("Failed to update library for: {0}", settings.Address);
|
|
}
|
|
}
|
|
|
|
catch (Exception ex)
|
|
{
|
|
_logger.Debug(ex, ex.Message);
|
|
}
|
|
}
|
|
}
|
|
}
|