mirror of
https://github.com/jellyfin/jellyfin.git
synced 2025-04-24 14:08:44 -04:00
sync updates
This commit is contained in:
parent
e6ea26e3de
commit
046a1de253
13 changed files with 173 additions and 12 deletions
|
@ -130,6 +130,7 @@
|
||||||
<Compile Include="SearchService.cs" />
|
<Compile Include="SearchService.cs" />
|
||||||
<Compile Include="Session\SessionsService.cs" />
|
<Compile Include="Session\SessionsService.cs" />
|
||||||
<Compile Include="SimilarItemsHelper.cs" />
|
<Compile Include="SimilarItemsHelper.cs" />
|
||||||
|
<Compile Include="Sync\SyncJobsWebSocketListener.cs" />
|
||||||
<Compile Include="Sync\SyncService.cs" />
|
<Compile Include="Sync\SyncService.cs" />
|
||||||
<Compile Include="System\ActivityLogService.cs" />
|
<Compile Include="System\ActivityLogService.cs" />
|
||||||
<Compile Include="System\ActivityLogWebSocketListener.cs" />
|
<Compile Include="System\ActivityLogWebSocketListener.cs" />
|
||||||
|
|
|
@ -1,5 +1,4 @@
|
||||||
using MediaBrowser.Common.Net;
|
using MediaBrowser.Controller.Library;
|
||||||
using MediaBrowser.Controller.Library;
|
|
||||||
using MediaBrowser.Controller.Net;
|
using MediaBrowser.Controller.Net;
|
||||||
using MediaBrowser.Controller.Session;
|
using MediaBrowser.Controller.Session;
|
||||||
using MediaBrowser.Model.Logging;
|
using MediaBrowser.Model.Logging;
|
||||||
|
|
101
MediaBrowser.Api/Sync/SyncJobsWebSocketListener.cs
Normal file
101
MediaBrowser.Api/Sync/SyncJobsWebSocketListener.cs
Normal file
|
@ -0,0 +1,101 @@
|
||||||
|
using MediaBrowser.Controller.Net;
|
||||||
|
using MediaBrowser.Controller.Sync;
|
||||||
|
using MediaBrowser.Model.Logging;
|
||||||
|
using MediaBrowser.Model.Sync;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
|
||||||
|
namespace MediaBrowser.Api.Sync
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// Class SessionInfoWebSocketListener
|
||||||
|
/// </summary>
|
||||||
|
class SyncJobsWebSocketListener : BasePeriodicWebSocketListener<IEnumerable<SyncJob>, WebSocketListenerState>
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// Gets the name.
|
||||||
|
/// </summary>
|
||||||
|
/// <value>The name.</value>
|
||||||
|
protected override string Name
|
||||||
|
{
|
||||||
|
get { return "SyncJobs"; }
|
||||||
|
}
|
||||||
|
|
||||||
|
private readonly ISyncManager _syncManager;
|
||||||
|
private string _userId;
|
||||||
|
private string _targetId;
|
||||||
|
|
||||||
|
public SyncJobsWebSocketListener(ILogger logger, ISyncManager syncManager)
|
||||||
|
: base(logger)
|
||||||
|
{
|
||||||
|
_syncManager = syncManager;
|
||||||
|
_syncManager.SyncJobCancelled += _syncManager_SyncJobCancelled;
|
||||||
|
_syncManager.SyncJobCreated += _syncManager_SyncJobCreated;
|
||||||
|
_syncManager.SyncJobUpdated += _syncManager_SyncJobUpdated;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected override void ParseMessageParams(string[] values)
|
||||||
|
{
|
||||||
|
base.ParseMessageParams(values);
|
||||||
|
|
||||||
|
if (values.Length > 0)
|
||||||
|
{
|
||||||
|
_userId = values[0];
|
||||||
|
}
|
||||||
|
|
||||||
|
if (values.Length > 1)
|
||||||
|
{
|
||||||
|
_targetId = values[1];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void _syncManager_SyncJobUpdated(object sender, Model.Events.GenericEventArgs<SyncJob> e)
|
||||||
|
{
|
||||||
|
SendData(false);
|
||||||
|
}
|
||||||
|
|
||||||
|
void _syncManager_SyncJobCreated(object sender, Model.Events.GenericEventArgs<SyncJobCreationResult> e)
|
||||||
|
{
|
||||||
|
SendData(true);
|
||||||
|
}
|
||||||
|
|
||||||
|
void _syncManager_SyncJobCancelled(object sender, Model.Events.GenericEventArgs<SyncJob> e)
|
||||||
|
{
|
||||||
|
SendData(true);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Gets the data to send.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="state">The state.</param>
|
||||||
|
/// <returns>Task{SystemInfo}.</returns>
|
||||||
|
protected override async Task<IEnumerable<SyncJob>> GetDataToSend(WebSocketListenerState state)
|
||||||
|
{
|
||||||
|
var jobs = await _syncManager.GetJobs(new SyncJobQuery
|
||||||
|
{
|
||||||
|
UserId = _userId,
|
||||||
|
TargetId = _targetId
|
||||||
|
|
||||||
|
}).ConfigureAwait(false);
|
||||||
|
|
||||||
|
return jobs.Items;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected override bool SendOnTimer
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
protected override void Dispose(bool dispose)
|
||||||
|
{
|
||||||
|
_syncManager.SyncJobCancelled -= _syncManager_SyncJobCancelled;
|
||||||
|
_syncManager.SyncJobCreated -= _syncManager_SyncJobCreated;
|
||||||
|
_syncManager.SyncJobUpdated -= _syncManager_SyncJobUpdated;
|
||||||
|
|
||||||
|
base.Dispose(dispose);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -93,6 +93,11 @@ namespace MediaBrowser.Controller.Net
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected virtual void ParseMessageParams(string[] values)
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Starts sending messages over a web socket
|
/// Starts sending messages over a web socket
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
@ -104,6 +109,11 @@ namespace MediaBrowser.Controller.Net
|
||||||
var dueTimeMs = long.Parse(vals[0], UsCulture);
|
var dueTimeMs = long.Parse(vals[0], UsCulture);
|
||||||
var periodMs = long.Parse(vals[1], UsCulture);
|
var periodMs = long.Parse(vals[1], UsCulture);
|
||||||
|
|
||||||
|
if (vals.Length > 2)
|
||||||
|
{
|
||||||
|
ParseMessageParams(vals.Skip(2).ToArray());
|
||||||
|
}
|
||||||
|
|
||||||
var cancellationTokenSource = new CancellationTokenSource();
|
var cancellationTokenSource = new CancellationTokenSource();
|
||||||
|
|
||||||
Logger.Info("{1} Begin transmitting over websocket to {0}", message.Connection.RemoteEndPoint, GetType().Name);
|
Logger.Info("{1} Begin transmitting over websocket to {0}", message.Connection.RemoteEndPoint, GetType().Name);
|
||||||
|
|
|
@ -893,6 +893,22 @@ namespace MediaBrowser.Model.ApiClient
|
||||||
/// <param name="keepExistingAuth">if set to <c>true</c> [keep existing authentication].</param>
|
/// <param name="keepExistingAuth">if set to <c>true</c> [keep existing authentication].</param>
|
||||||
void ChangeServerLocation(string address, bool keepExistingAuth = false);
|
void ChangeServerLocation(string address, bool keepExistingAuth = false);
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Starts the receiving synchronize jobs updates.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="intervalMs">The interval ms.</param>
|
||||||
|
/// <param name="userId">The user identifier.</param>
|
||||||
|
/// <param name="targetId">The target identifier.</param>
|
||||||
|
/// <returns>Task.</returns>
|
||||||
|
Task StartReceivingSyncJobsUpdates(int intervalMs, string userId, string targetId);
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Stops the receiving synchronize jobs updates.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="intervalMs">The interval ms.</param>
|
||||||
|
/// <returns>Task.</returns>
|
||||||
|
Task StopReceivingSyncJobsUpdates(int intervalMs);
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Starts the receiving session updates.
|
/// Starts the receiving session updates.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
|
|
@ -7,6 +7,7 @@ using MediaBrowser.Model.Sync;
|
||||||
using MediaBrowser.Model.Tasks;
|
using MediaBrowser.Model.Tasks;
|
||||||
using MediaBrowser.Model.Updates;
|
using MediaBrowser.Model.Updates;
|
||||||
using System;
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
|
||||||
namespace MediaBrowser.Model.ApiClient
|
namespace MediaBrowser.Model.ApiClient
|
||||||
{
|
{
|
||||||
|
@ -139,5 +140,9 @@ namespace MediaBrowser.Model.ApiClient
|
||||||
/// Occurs when [synchronize job cancelled].
|
/// Occurs when [synchronize job cancelled].
|
||||||
/// </summary>
|
/// </summary>
|
||||||
event EventHandler<GenericEventArgs<SyncJob>> SyncJobCancelled;
|
event EventHandler<GenericEventArgs<SyncJob>> SyncJobCancelled;
|
||||||
|
/// <summary>
|
||||||
|
/// Occurs when [synchronize jobs updated].
|
||||||
|
/// </summary>
|
||||||
|
event EventHandler<GenericEventArgs<List<SyncJob>>> SyncJobsUpdated;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -16,6 +16,11 @@ namespace MediaBrowser.Model.Sync
|
||||||
/// <value>The device identifier.</value>
|
/// <value>The device identifier.</value>
|
||||||
public string TargetId { get; set; }
|
public string TargetId { get; set; }
|
||||||
/// <summary>
|
/// <summary>
|
||||||
|
/// Gets or sets the name of the target.
|
||||||
|
/// </summary>
|
||||||
|
/// <value>The name of the target.</value>
|
||||||
|
public string TargetName { get; set; }
|
||||||
|
/// <summary>
|
||||||
/// Gets or sets the quality.
|
/// Gets or sets the quality.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
/// <value>The quality.</value>
|
/// <value>The quality.</value>
|
||||||
|
|
|
@ -144,7 +144,7 @@ namespace MediaBrowser.Server.Implementations.Sync
|
||||||
return UpdateJobStatus(job, result.Items.ToList());
|
return UpdateJobStatus(job, result.Items.ToList());
|
||||||
}
|
}
|
||||||
|
|
||||||
private Task UpdateJobStatus(SyncJob job, List<SyncJobItem> jobItems)
|
private async Task UpdateJobStatus(SyncJob job, List<SyncJobItem> jobItems)
|
||||||
{
|
{
|
||||||
job.ItemCount = jobItems.Count;
|
job.ItemCount = jobItems.Count;
|
||||||
|
|
||||||
|
@ -204,7 +204,9 @@ namespace MediaBrowser.Server.Implementations.Sync
|
||||||
job.Status = SyncJobStatus.Transferring;
|
job.Status = SyncJobStatus.Transferring;
|
||||||
}
|
}
|
||||||
|
|
||||||
return _syncRepo.Update(job);
|
await _syncRepo.Update(job).ConfigureAwait(false);
|
||||||
|
|
||||||
|
((SyncManager)_syncManager).OnSyncJobUpdated(job);
|
||||||
}
|
}
|
||||||
|
|
||||||
public async Task<IEnumerable<BaseItem>> GetItemsForSync(SyncCategory? category, string parentId, IEnumerable<string> itemIds, User user, bool unwatchedOnly)
|
public async Task<IEnumerable<BaseItem>> GetItemsForSync(SyncCategory? category, string parentId, IEnumerable<string> itemIds, User user, bool unwatchedOnly)
|
||||||
|
|
|
@ -174,7 +174,7 @@ namespace MediaBrowser.Server.Implementations.Sync
|
||||||
return returnResult;
|
return returnResult;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Task UpdateJob(SyncJob job)
|
public async Task UpdateJob(SyncJob job)
|
||||||
{
|
{
|
||||||
// Get fresh from the db and only update the fields that are supported to be changed.
|
// Get fresh from the db and only update the fields that are supported to be changed.
|
||||||
var instance = _repo.GetJob(job.Id);
|
var instance = _repo.GetJob(job.Id);
|
||||||
|
@ -185,7 +185,21 @@ namespace MediaBrowser.Server.Implementations.Sync
|
||||||
instance.SyncNewContent = job.SyncNewContent;
|
instance.SyncNewContent = job.SyncNewContent;
|
||||||
instance.ItemLimit = job.ItemLimit;
|
instance.ItemLimit = job.ItemLimit;
|
||||||
|
|
||||||
return _repo.Update(instance);
|
await _repo.Update(instance).ConfigureAwait(false);
|
||||||
|
|
||||||
|
OnSyncJobUpdated(instance);
|
||||||
|
}
|
||||||
|
|
||||||
|
internal void OnSyncJobUpdated(SyncJob job)
|
||||||
|
{
|
||||||
|
if (SyncJobUpdated != null)
|
||||||
|
{
|
||||||
|
EventHelper.FireEventIfNotNull(SyncJobUpdated, this, new GenericEventArgs<SyncJob>
|
||||||
|
{
|
||||||
|
Argument = job
|
||||||
|
|
||||||
|
}, _logger);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public async Task<QueryResult<SyncJob>> GetJobs(SyncJobQuery query)
|
public async Task<QueryResult<SyncJob>> GetJobs(SyncJobQuery query)
|
||||||
|
@ -202,6 +216,14 @@ namespace MediaBrowser.Server.Implementations.Sync
|
||||||
|
|
||||||
private async Task FillMetadata(SyncJob job)
|
private async Task FillMetadata(SyncJob job)
|
||||||
{
|
{
|
||||||
|
var target = GetSyncTargets(job.UserId)
|
||||||
|
.FirstOrDefault(i => string.Equals(i.Id, job.TargetId, StringComparison.OrdinalIgnoreCase));
|
||||||
|
|
||||||
|
if (target != null)
|
||||||
|
{
|
||||||
|
job.TargetName = target.Name;
|
||||||
|
}
|
||||||
|
|
||||||
var item = job.RequestedItemIds
|
var item = job.RequestedItemIds
|
||||||
.Select(_libraryManager.GetItemById)
|
.Select(_libraryManager.GetItemById)
|
||||||
.FirstOrDefault(i => i != null);
|
.FirstOrDefault(i => i != null);
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
<package xmlns="http://schemas.microsoft.com/packaging/2011/08/nuspec.xsd">
|
<package xmlns="http://schemas.microsoft.com/packaging/2011/08/nuspec.xsd">
|
||||||
<metadata>
|
<metadata>
|
||||||
<id>MediaBrowser.Common.Internal</id>
|
<id>MediaBrowser.Common.Internal</id>
|
||||||
<version>3.0.556</version>
|
<version>3.0.559</version>
|
||||||
<title>MediaBrowser.Common.Internal</title>
|
<title>MediaBrowser.Common.Internal</title>
|
||||||
<authors>Luke</authors>
|
<authors>Luke</authors>
|
||||||
<owners>ebr,Luke,scottisafool</owners>
|
<owners>ebr,Luke,scottisafool</owners>
|
||||||
|
@ -12,7 +12,7 @@
|
||||||
<description>Contains common components shared by Media Browser Theater and Media Browser Server. Not intended for plugin developer consumption.</description>
|
<description>Contains common components shared by Media Browser Theater and Media Browser Server. Not intended for plugin developer consumption.</description>
|
||||||
<copyright>Copyright © Media Browser 2013</copyright>
|
<copyright>Copyright © Media Browser 2013</copyright>
|
||||||
<dependencies>
|
<dependencies>
|
||||||
<dependency id="MediaBrowser.Common" version="3.0.556" />
|
<dependency id="MediaBrowser.Common" version="3.0.559" />
|
||||||
<dependency id="NLog" version="3.1.0.0" />
|
<dependency id="NLog" version="3.1.0.0" />
|
||||||
<dependency id="SimpleInjector" version="2.6.1" />
|
<dependency id="SimpleInjector" version="2.6.1" />
|
||||||
</dependencies>
|
</dependencies>
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
<package xmlns="http://schemas.microsoft.com/packaging/2011/08/nuspec.xsd">
|
<package xmlns="http://schemas.microsoft.com/packaging/2011/08/nuspec.xsd">
|
||||||
<metadata>
|
<metadata>
|
||||||
<id>MediaBrowser.Common</id>
|
<id>MediaBrowser.Common</id>
|
||||||
<version>3.0.556</version>
|
<version>3.0.559</version>
|
||||||
<title>MediaBrowser.Common</title>
|
<title>MediaBrowser.Common</title>
|
||||||
<authors>Media Browser Team</authors>
|
<authors>Media Browser Team</authors>
|
||||||
<owners>ebr,Luke,scottisafool</owners>
|
<owners>ebr,Luke,scottisafool</owners>
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
<package xmlns="http://schemas.microsoft.com/packaging/2011/08/nuspec.xsd">
|
<package xmlns="http://schemas.microsoft.com/packaging/2011/08/nuspec.xsd">
|
||||||
<metadata>
|
<metadata>
|
||||||
<id>MediaBrowser.Model.Signed</id>
|
<id>MediaBrowser.Model.Signed</id>
|
||||||
<version>3.0.556</version>
|
<version>3.0.559</version>
|
||||||
<title>MediaBrowser.Model - Signed Edition</title>
|
<title>MediaBrowser.Model - Signed Edition</title>
|
||||||
<authors>Media Browser Team</authors>
|
<authors>Media Browser Team</authors>
|
||||||
<owners>ebr,Luke,scottisafool</owners>
|
<owners>ebr,Luke,scottisafool</owners>
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
<package xmlns="http://schemas.microsoft.com/packaging/2010/07/nuspec.xsd">
|
<package xmlns="http://schemas.microsoft.com/packaging/2010/07/nuspec.xsd">
|
||||||
<metadata>
|
<metadata>
|
||||||
<id>MediaBrowser.Server.Core</id>
|
<id>MediaBrowser.Server.Core</id>
|
||||||
<version>3.0.556</version>
|
<version>3.0.559</version>
|
||||||
<title>Media Browser.Server.Core</title>
|
<title>Media Browser.Server.Core</title>
|
||||||
<authors>Media Browser Team</authors>
|
<authors>Media Browser Team</authors>
|
||||||
<owners>ebr,Luke,scottisafool</owners>
|
<owners>ebr,Luke,scottisafool</owners>
|
||||||
|
@ -12,7 +12,7 @@
|
||||||
<description>Contains core components required to build plugins for Media Browser Server.</description>
|
<description>Contains core components required to build plugins for Media Browser Server.</description>
|
||||||
<copyright>Copyright © Media Browser 2013</copyright>
|
<copyright>Copyright © Media Browser 2013</copyright>
|
||||||
<dependencies>
|
<dependencies>
|
||||||
<dependency id="MediaBrowser.Common" version="3.0.556" />
|
<dependency id="MediaBrowser.Common" version="3.0.559" />
|
||||||
</dependencies>
|
</dependencies>
|
||||||
</metadata>
|
</metadata>
|
||||||
<files>
|
<files>
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue