commit
2050eb7bb2
|
@ -817,7 +817,6 @@ namespace Emby.Server.Implementations.Connect
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private readonly SemaphoreSlim _connectImageSemaphore = new SemaphoreSlim(5, 5);
|
|
||||||
private async Task RefreshAuthorizations(List<ServerUserAuthorizationResponse> list, bool refreshImages)
|
private async Task RefreshAuthorizations(List<ServerUserAuthorizationResponse> list, bool refreshImages)
|
||||||
{
|
{
|
||||||
var users = _userManager.Users.ToList();
|
var users = _userManager.Users.ToList();
|
||||||
|
@ -992,7 +991,7 @@ namespace Emby.Server.Implementations.Connect
|
||||||
|
|
||||||
if (changed)
|
if (changed)
|
||||||
{
|
{
|
||||||
await _providerManager.SaveImage(user, imageUrl, _connectImageSemaphore, ImageType.Primary, null, CancellationToken.None).ConfigureAwait(false);
|
await _providerManager.SaveImage(user, imageUrl, null, ImageType.Primary, null, CancellationToken.None).ConfigureAwait(false);
|
||||||
|
|
||||||
await user.RefreshMetadata(new MetadataRefreshOptions(_fileSystem)
|
await user.RefreshMetadata(new MetadataRefreshOptions(_fileSystem)
|
||||||
{
|
{
|
||||||
|
|
|
@ -1650,7 +1650,7 @@ namespace Emby.Server.Implementations.LiveTv.EmbyTV
|
||||||
{
|
{
|
||||||
var image = program.GetImageInfo(ImageType.Primary, 0);
|
var image = program.GetImageInfo(ImageType.Primary, 0);
|
||||||
|
|
||||||
if (image != null)
|
if (image != null && program.IsMovie)
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
|
|
|
@ -39,7 +39,7 @@ namespace Emby.Server.Implementations.Security
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private readonly ConcurrentDictionary<Guid, DateTime> _updateRecords = new ConcurrentDictionary<Guid, DateTime>();
|
private readonly ConcurrentDictionary<Guid, FeatureRegInfo> _updateRecords = new ConcurrentDictionary<Guid, FeatureRegInfo>();
|
||||||
private readonly object _fileLock = new object();
|
private readonly object _fileLock = new object();
|
||||||
private string _regKey;
|
private string _regKey;
|
||||||
|
|
||||||
|
@ -52,7 +52,7 @@ namespace Emby.Server.Implementations.Security
|
||||||
Load();
|
Load();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void SetUpdateRecord(Guid key, DateTime value)
|
private void SetUpdateRecord(Guid key, FeatureRegInfo value)
|
||||||
{
|
{
|
||||||
_updateRecords.AddOrUpdate(key, value, (k, v) => value);
|
_updateRecords.AddOrUpdate(key, value, (k, v) => value);
|
||||||
}
|
}
|
||||||
|
@ -62,10 +62,14 @@ namespace Emby.Server.Implementations.Security
|
||||||
return new Guid(_cryptographyProvider.ComputeMD5(Encoding.Unicode.GetBytes(featureId)));
|
return new Guid(_cryptographyProvider.ComputeMD5(Encoding.Unicode.GetBytes(featureId)));
|
||||||
}
|
}
|
||||||
|
|
||||||
public void AddRegCheck(string featureId)
|
public void AddRegCheck(string featureId, DateTime expirationDate)
|
||||||
{
|
{
|
||||||
var key = GetKey(featureId);
|
var key = GetKey(featureId);
|
||||||
var value = DateTime.UtcNow;
|
var value = new FeatureRegInfo
|
||||||
|
{
|
||||||
|
ExpirationDate = expirationDate,
|
||||||
|
LastChecked = DateTime.UtcNow
|
||||||
|
};
|
||||||
|
|
||||||
SetUpdateRecord(key, value);
|
SetUpdateRecord(key, value);
|
||||||
Save();
|
Save();
|
||||||
|
@ -74,21 +78,26 @@ namespace Emby.Server.Implementations.Security
|
||||||
public void RemoveRegCheck(string featureId)
|
public void RemoveRegCheck(string featureId)
|
||||||
{
|
{
|
||||||
var key = GetKey(featureId);
|
var key = GetKey(featureId);
|
||||||
DateTime val;
|
FeatureRegInfo val;
|
||||||
|
|
||||||
_updateRecords.TryRemove(key, out val);
|
_updateRecords.TryRemove(key, out val);
|
||||||
|
|
||||||
Save();
|
Save();
|
||||||
}
|
}
|
||||||
|
|
||||||
public DateTime LastChecked(string featureId)
|
public FeatureRegInfo GetRegInfo(string featureId)
|
||||||
{
|
{
|
||||||
var key = GetKey(featureId);
|
var key = GetKey(featureId);
|
||||||
DateTime last;
|
FeatureRegInfo info = null;
|
||||||
_updateRecords.TryGetValue(key, out last);
|
_updateRecords.TryGetValue(key, out info);
|
||||||
|
|
||||||
|
if (info == null)
|
||||||
|
{
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
// guard agains people just putting a large number in the file
|
// guard agains people just putting a large number in the file
|
||||||
return last < DateTime.UtcNow ? last : DateTime.MinValue;
|
return info.LastChecked < DateTime.UtcNow ? info : null;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void Load()
|
private void Load()
|
||||||
|
@ -105,7 +114,7 @@ namespace Emby.Server.Implementations.Security
|
||||||
{
|
{
|
||||||
lock (_fileLock)
|
lock (_fileLock)
|
||||||
{
|
{
|
||||||
_fileSystem.WriteAllBytes(licenseFile, new byte[] {});
|
_fileSystem.WriteAllBytes(licenseFile, new byte[] { });
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
catch (IOException)
|
catch (IOException)
|
||||||
|
@ -139,7 +148,23 @@ namespace Emby.Server.Implementations.Security
|
||||||
Guid feat;
|
Guid feat;
|
||||||
if (Guid.TryParse(line, out feat))
|
if (Guid.TryParse(line, out feat))
|
||||||
{
|
{
|
||||||
SetUpdateRecord(feat, new DateTime(Convert.ToInt64(contents[i + 1])));
|
var lineParts = contents[i + 1].Split(new[] { '|' }, StringSplitOptions.RemoveEmptyEntries);
|
||||||
|
|
||||||
|
long ticks;
|
||||||
|
if (long.TryParse(lineParts[0], out ticks))
|
||||||
|
{
|
||||||
|
var info = new FeatureRegInfo
|
||||||
|
{
|
||||||
|
LastChecked = new DateTime(ticks)
|
||||||
|
};
|
||||||
|
|
||||||
|
if (lineParts.Length > 1 && long.TryParse(lineParts[1], out ticks))
|
||||||
|
{
|
||||||
|
info.ExpirationDate = new DateTime(ticks);
|
||||||
|
}
|
||||||
|
|
||||||
|
SetUpdateRecord(feat, info);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -160,7 +185,11 @@ namespace Emby.Server.Implementations.Security
|
||||||
.ToList())
|
.ToList())
|
||||||
{
|
{
|
||||||
lines.Add(pair.Key.ToString());
|
lines.Add(pair.Key.ToString());
|
||||||
lines.Add(pair.Value.Ticks.ToString(CultureInfo.InvariantCulture));
|
|
||||||
|
var dateLine = pair.Value.LastChecked.Ticks.ToString(CultureInfo.InvariantCulture) + "|" +
|
||||||
|
pair.Value.ExpirationDate.Ticks.ToString(CultureInfo.InvariantCulture);
|
||||||
|
|
||||||
|
lines.Add(dateLine);
|
||||||
}
|
}
|
||||||
|
|
||||||
var licenseFile = Filename;
|
var licenseFile = Filename;
|
||||||
|
@ -171,4 +200,15 @@ namespace Emby.Server.Implementations.Security
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
internal class FeatureRegInfo
|
||||||
|
{
|
||||||
|
public DateTime ExpirationDate { get; set; }
|
||||||
|
public DateTime LastChecked { get; set; }
|
||||||
|
|
||||||
|
public FeatureRegInfo()
|
||||||
|
{
|
||||||
|
ExpirationDate = DateTime.MinValue;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -245,18 +245,29 @@ namespace Emby.Server.Implementations.Security
|
||||||
string mb2Equivalent = null,
|
string mb2Equivalent = null,
|
||||||
string version = null)
|
string version = null)
|
||||||
{
|
{
|
||||||
var lastChecked = LicenseFile.LastChecked(feature);
|
var regInfo = LicenseFile.GetRegInfo(feature);
|
||||||
|
var lastChecked = regInfo == null ? DateTime.MinValue : regInfo.LastChecked;
|
||||||
|
var expDate = regInfo == null ? DateTime.MinValue : regInfo.ExpirationDate;
|
||||||
|
|
||||||
|
var maxCacheDays = 14;
|
||||||
|
var nextCheckDate = new [] { expDate, lastChecked.AddDays(maxCacheDays) }.Min();
|
||||||
|
|
||||||
|
if (nextCheckDate > DateTime.UtcNow.AddDays(maxCacheDays))
|
||||||
|
{
|
||||||
|
nextCheckDate = DateTime.MinValue;
|
||||||
|
}
|
||||||
|
|
||||||
//check the reg file first to alleviate strain on the MB admin server - must actually check in every 30 days tho
|
//check the reg file first to alleviate strain on the MB admin server - must actually check in every 30 days tho
|
||||||
var reg = new RegRecord
|
var reg = new RegRecord
|
||||||
{
|
{
|
||||||
// Cache the result for up to a week
|
// Cache the result for up to a week
|
||||||
registered = lastChecked > DateTime.UtcNow.AddDays(-7)
|
registered = regInfo != null && nextCheckDate >= DateTime.UtcNow && expDate >= DateTime.UtcNow,
|
||||||
|
expDate = expDate
|
||||||
};
|
};
|
||||||
|
|
||||||
var success = reg.registered;
|
var success = reg.registered;
|
||||||
|
|
||||||
if (!(lastChecked > DateTime.UtcNow.AddDays(-1)))
|
if (!(lastChecked > DateTime.UtcNow.AddDays(-1)) || !reg.registered)
|
||||||
{
|
{
|
||||||
var data = new Dictionary<string, string>
|
var data = new Dictionary<string, string>
|
||||||
{
|
{
|
||||||
|
@ -291,7 +302,7 @@ namespace Emby.Server.Implementations.Security
|
||||||
|
|
||||||
if (reg.registered)
|
if (reg.registered)
|
||||||
{
|
{
|
||||||
LicenseFile.AddRegCheck(feature);
|
LicenseFile.AddRegCheck(feature, reg.expDate);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
|
|
@ -820,6 +820,17 @@ namespace Emby.Server.Implementations.Session
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (info.Item != null)
|
||||||
|
{
|
||||||
|
var msString = info.PositionTicks.HasValue ? (info.PositionTicks.Value / 10000).ToString(CultureInfo.InvariantCulture) : "unknown";
|
||||||
|
|
||||||
|
_logger.Info("Playback stopped reported by app {0} {1} playing {2}. Stopped at {3} ms",
|
||||||
|
session.Client,
|
||||||
|
session.ApplicationVersion,
|
||||||
|
info.Item.Name,
|
||||||
|
msString);
|
||||||
|
}
|
||||||
|
|
||||||
RemoveNowPlayingItem(session);
|
RemoveNowPlayingItem(session);
|
||||||
|
|
||||||
var users = GetUsers(session);
|
var users = GetUsers(session);
|
||||||
|
@ -874,7 +885,7 @@ namespace Emby.Server.Implementations.Session
|
||||||
{
|
{
|
||||||
playedToCompletion = _userDataManager.UpdatePlayState(item, data, positionTicks.Value);
|
playedToCompletion = _userDataManager.UpdatePlayState(item, data, positionTicks.Value);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
// If the client isn't able to report this, then we'll just have to make an assumption
|
// If the client isn't able to report this, then we'll just have to make an assumption
|
||||||
data.PlayCount++;
|
data.PlayCount++;
|
||||||
|
@ -973,7 +984,7 @@ namespace Emby.Server.Implementations.Session
|
||||||
var subItems = await TranslateItemForPlayback(itemId, user).ConfigureAwait(false);
|
var subItems = await TranslateItemForPlayback(itemId, user).ConfigureAwait(false);
|
||||||
list.AddRange(subItems);
|
list.AddRange(subItems);
|
||||||
}
|
}
|
||||||
|
|
||||||
items = list
|
items = list
|
||||||
.Where(i => i.LocationType != LocationType.Virtual)
|
.Where(i => i.LocationType != LocationType.Virtual)
|
||||||
.ToList();
|
.ToList();
|
||||||
|
|
Loading…
Reference in New Issue
Block a user