2023-02-18 20:12:36 +00:00
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
using System.Linq;
|
|
|
|
|
using Microsoft.EntityFrameworkCore;
|
|
|
|
|
using Microsoft.Extensions.DependencyInjection;
|
2023-02-22 16:21:48 +00:00
|
|
|
|
using Microsoft.Extensions.Logging;
|
2023-02-18 20:12:36 +00:00
|
|
|
|
using Pal.Client.Database;
|
|
|
|
|
|
|
|
|
|
namespace Pal.Client.Floors.Tasks
|
|
|
|
|
{
|
2023-02-22 16:21:48 +00:00
|
|
|
|
internal sealed class MarkLocalSeen : DbTask<MarkLocalSeen>
|
2023-02-18 20:12:36 +00:00
|
|
|
|
{
|
|
|
|
|
private readonly MemoryTerritory _territory;
|
|
|
|
|
private readonly IReadOnlyList<PersistentLocation> _locations;
|
|
|
|
|
|
2023-02-22 16:21:48 +00:00
|
|
|
|
public MarkLocalSeen(IServiceScopeFactory serviceScopeFactory, MemoryTerritory territory,
|
2023-02-18 20:12:36 +00:00
|
|
|
|
IReadOnlyList<PersistentLocation> locations)
|
|
|
|
|
: base(serviceScopeFactory)
|
|
|
|
|
{
|
|
|
|
|
_territory = territory;
|
|
|
|
|
_locations = locations;
|
|
|
|
|
}
|
|
|
|
|
|
2023-02-22 16:21:48 +00:00
|
|
|
|
protected override void Run(PalClientContext dbContext, ILogger<MarkLocalSeen> logger)
|
2023-02-18 20:12:36 +00:00
|
|
|
|
{
|
|
|
|
|
lock (_territory.LockObj)
|
|
|
|
|
{
|
2023-02-22 16:21:48 +00:00
|
|
|
|
logger.LogInformation("Marking {Count} locations as seen locally in territory {Territory}", _locations.Count,
|
|
|
|
|
_territory.TerritoryType);
|
2023-02-26 16:54:15 +00:00
|
|
|
|
List<int> localIds = _locations.Select(l => l.LocalId).Where(x => x != null).Cast<int>().ToList();
|
2023-02-18 20:12:36 +00:00
|
|
|
|
dbContext.Locations
|
2023-02-26 16:54:15 +00:00
|
|
|
|
.Where(loc => localIds.Contains(loc.LocalId))
|
2023-02-18 20:12:36 +00:00
|
|
|
|
.ExecuteUpdate(loc => loc.SetProperty(l => l.Seen, true));
|
|
|
|
|
dbContext.SaveChanges();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|