-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathVehicleInfoService.cs
101 lines (85 loc) · 3.62 KB
/
VehicleInfoService.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
using System.Collections.Generic;
using PoliceMP.Client.Services.Interfaces;
using PoliceMP.Core.Client.Communications.Interfaces;
using PoliceMP.Core.Shared;
using PoliceMP.Shared.Constants;
using PoliceMP.Shared.Models;
using System.Threading.Tasks;
namespace PoliceMP.Client.Services
{
public class VehicleInfoService : IVehicleInfoService
{
private readonly IClientCommunicationsManager _comms;
private readonly ILogger<VehicleInfo> _logger;
private readonly IVehicleInfoCacheService _vehicleInfoCacheService;
public VehicleInfoService(IClientCommunicationsManager comms,
ILogger<VehicleInfo> logger,
IVehicleInfoCacheService vehicleInfoCacheService)
{
_comms = comms;
_logger = logger;
_vehicleInfoCacheService = vehicleInfoCacheService;
}
public async Task<VehicleInfo> GetByNetworkId(int networkId, string plate, int ownerPedNetworkId = -1)
{
var cachedVehicleInfo = _vehicleInfoCacheService.GetByNetworkId(networkId);
if (cachedVehicleInfo != null) return cachedVehicleInfo;
_logger.Trace($"Retrieving VehicleInfo for NetworkId {networkId} and plate {plate}");
var vehicleInfo = await _comms
.Request<VehicleInfo>(ServerEvents.GetVehicleInfoByNetworkId,
networkId,
plate,
ownerPedNetworkId);
if (vehicleInfo == null)
{
_logger.Trace($"Failed to get VehicleInfo for NetworkId {networkId}");
return null;
}
_logger.Trace($"Successfully got VehicleInfo for NetworkId {networkId}");
_vehicleInfoCacheService.Cache(vehicleInfo);
return vehicleInfo;
}
public async Task<bool> UpdateMarkers(int networkId, string plate, List<string> markers)
{
if (!_vehicleInfoCacheService.RemoveCache(networkId))
{
_logger.Error("An error occurred trying to remove the cache.");
return false;
}
var updatedVehicleMarkers =
await _comms.Request<bool>(ServerEvents.UpdateVehicleInfoMarkers, networkId, markers);
if (!updatedVehicleMarkers)
{
_logger.Error("An error occurred updating the vehicle markers.");
return false;
}
var newVehicleInfo = await GetByNetworkId(networkId, plate);
return newVehicleInfo != null;
}
public async Task<bool> UpdateExpiredMarkers(int networkId, string plate, bool taxExpired, bool motExpired,
bool insuranceExpired)
{
if (!_vehicleInfoCacheService.RemoveCache(networkId))
{
_logger.Error("An error occurred trying to remove the cache.");
return false;
}
_logger.Debug($"Requesting Update of Markers: {taxExpired} - {motExpired} - {insuranceExpired}");
var boolList = new List<bool>
{
taxExpired,
motExpired,
insuranceExpired
};
var updatedExpiredMarkers = await _comms.Request<bool>(ServerEvents.UpdatedVehicleExpiredMarkers, networkId,
boolList);
if (!updatedExpiredMarkers)
{
_logger.Error("An error occurred updated the expired markers!");
return false;
}
var newVehicleInfo = await GetByNetworkId(networkId, plate);
return newVehicleInfo != null;
}
}
}