2019-11-11 15:10:08 -05:00
|
|
|
using System;
|
|
|
|
using System.Threading.Tasks;
|
|
|
|
using Aurora.Proto.Sync;
|
|
|
|
using Aurora.Proto.General;
|
|
|
|
using Aurora.Services.PlayerService;
|
|
|
|
|
|
|
|
namespace Aurora.RemoteImpl
|
|
|
|
{
|
|
|
|
public class RemoteSyncServiceImpl : RemoteSyncService.RemoteSyncServiceBase
|
|
|
|
{
|
|
|
|
/// <summary>
|
|
|
|
/// RPC for getting a stream of media syncs
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="request"></param>
|
|
|
|
/// <param name="responseStream"></param>
|
|
|
|
/// <param name="context"></param>
|
|
|
|
/// <returns></returns>
|
|
|
|
public override async Task GetMediaSync(Empty request,
|
|
|
|
Grpc.Core.IServerStreamWriter<Sync> responseStream,
|
|
|
|
Grpc.Core.ServerCallContext context)
|
|
|
|
{
|
2019-11-12 20:09:45 -05:00
|
|
|
bool continueSync = true;
|
|
|
|
string currentId = PlayerService.Instance.CurrentMedia.Id;
|
|
|
|
MediaChangedEventHandler mediaChanged = (sender, e) =>
|
2019-11-11 15:10:08 -05:00
|
|
|
{
|
2019-11-12 20:09:45 -05:00
|
|
|
if (e.NewId != currentId)
|
|
|
|
{
|
|
|
|
continueSync = false;
|
|
|
|
}
|
2019-11-11 15:10:08 -05:00
|
|
|
};
|
|
|
|
|
2019-11-12 20:09:45 -05:00
|
|
|
PlayerService.Instance.MediaChanged += mediaChanged;
|
2019-11-11 15:10:08 -05:00
|
|
|
|
2019-11-12 20:09:45 -05:00
|
|
|
while (continueSync)
|
2019-11-11 15:10:08 -05:00
|
|
|
{
|
|
|
|
float length = PlayerService.Instance.CurrentMediaLength;
|
|
|
|
|
|
|
|
Sync sync = new Sync()
|
|
|
|
{
|
2019-11-29 22:04:55 -05:00
|
|
|
TrackPosition = PlayerService.Instance.CurrentMediaPosition,
|
|
|
|
ServerTimeTicks = Utils.TimeUtils.GetNetworkTime().DateTime.Ticks
|
2019-11-11 15:10:08 -05:00
|
|
|
};
|
|
|
|
await responseStream.WriteAsync(sync);
|
2019-12-04 14:53:49 -08:00
|
|
|
System.Diagnostics.Debug.WriteLine("Sent Sync");
|
2019-11-12 20:09:45 -05:00
|
|
|
await Task.Delay(5000);
|
2019-11-11 15:10:08 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|