Integrate NLog for centralized logging, replacing Console calls across CLI tasks. Add LoggingService helper for setup and logger retrieval. Update project dependencies.
This commit is contained in:
@@ -1,11 +1,14 @@
|
||||
using System.Text;
|
||||
using FsToolbox.Cli.Helper;
|
||||
using FsToolbox.Cli.Tasks;
|
||||
using NLog;
|
||||
|
||||
namespace FsToolbox.Cli
|
||||
{
|
||||
public partial class CustomTasks
|
||||
{
|
||||
private static readonly Logger Logger = LoggingService.GetLogger<CustomTasks>();
|
||||
|
||||
#region Public Method CheckAldiMembershipsAsync
|
||||
|
||||
/// <summary>
|
||||
@@ -20,7 +23,7 @@ namespace FsToolbox.Cli
|
||||
var stores = await RegionTasks.GetStoresInRegionAsync(httpClient, 139);
|
||||
var activeAldis = stores.Where(x => x.CooperationStatus == RegionTasks.CooperationStatus.Cooperating && x.Name.Contains("ALDI", StringComparison.CurrentCultureIgnoreCase)).ToList();
|
||||
|
||||
Console.WriteLine("Found " + activeAldis.Count + " active ALDI stores in region Siegen.");
|
||||
Logger.Info("Found {ActiveCount} active ALDI stores in region Siegen.", activeAldis.Count);
|
||||
|
||||
var aldiMembers = new List<AldiMember>();
|
||||
|
||||
@@ -28,7 +31,7 @@ namespace FsToolbox.Cli
|
||||
foreach (var activeAldi in activeAldis)
|
||||
{
|
||||
Thread.Sleep(200);
|
||||
Console.WriteLine("Checking members for store: " + activeAldi.Name);
|
||||
Logger.Info("Checking members for store: {Store}", activeAldi.Name);
|
||||
|
||||
var members = await StoreTasks.GetStoreMembersAsync(httpClient, activeAldi.Id);
|
||||
var activeMembers = members.Where(x => x is { Verified: StoreTasks.VerifiedStatus.Verified, Team_Active: StoreTasks.TeamActiveStatus.Active }).ToList();
|
||||
@@ -43,8 +46,8 @@ namespace FsToolbox.Cli
|
||||
var multipleMemberships = grouped.Where(g => g.Count() > 2).OrderByDescending(g => g.Count()).ToList();
|
||||
|
||||
|
||||
Console.WriteLine($"Users with more than two ALDI store memberships: {multipleMemberships.Count}");
|
||||
Console.WriteLine($"Saving data to file.");
|
||||
Logger.Info("Users with more than two ALDI store memberships: {Count}", multipleMemberships.Count);
|
||||
Logger.Info("Saving data to file.");
|
||||
|
||||
var sb = new StringBuilder();
|
||||
sb.AppendLine("ALDI Store Memberships Report");
|
||||
@@ -94,26 +97,26 @@ namespace FsToolbox.Cli
|
||||
|
||||
if (toConfirm.Count != 0)
|
||||
{
|
||||
toConfirm.ForEach(x => Console.WriteLine($"Slot found: {x.Name} on {x.Date}"));
|
||||
toConfirm.ForEach(x => Logger.Info("Slot found: {Name} on {Date}", x.Name, x.Date));
|
||||
}
|
||||
else
|
||||
{
|
||||
Console.Write("No unconfirmed slots found.");
|
||||
Logger.Info("No unconfirmed slots found.");
|
||||
return;
|
||||
}
|
||||
|
||||
// Confirm question
|
||||
Console.Write("Confirm all unconfirmed slots? (y/n) (Enter for default): ");
|
||||
Logger.Info("Confirm all unconfirmed slots? (y/n) (Enter for default): ");
|
||||
var input = Console.ReadLine();
|
||||
if (string.IsNullOrEmpty(input) || input.Equals("y", StringComparison.OrdinalIgnoreCase))
|
||||
{
|
||||
Console.WriteLine("Confirming unconfirmed slots...");
|
||||
Logger.Info("Confirming unconfirmed slots...");
|
||||
|
||||
// Confirm the unconfirmed slots
|
||||
foreach (var confirmEntry in toConfirm)
|
||||
await StoreTasks.PatchPickupAsync(httpClient, 52170, confirmEntry.Date, confirmEntry.User);
|
||||
|
||||
Console.WriteLine("done.");
|
||||
Logger.Info("Done confirming slots.");
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user