//
// Startup.cs
//
// Copyright (c) František Boháček. All rights reserved.
// Licensed under the MIT license. See LICENSE file in the project root for full license information.
using System.Diagnostics;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Logging;
using NosSmooth.ChatCommands;
using NosSmooth.Core.Client;
using NosSmooth.Core.Extensions;
using NosSmooth.Data.NOSFiles;
using NosSmooth.Data.NOSFiles.Extensions;
using NosSmooth.Extensions.Pathfinding.Extensions;
using NosSmooth.Extensions.SharedBinding.Extensions;
using NosSmooth.LocalBinding;
using NosSmooth.LocalBinding.Extensions;
using NosSmooth.LocalBinding.Hooks;
using NosSmooth.LocalClient;
using NosSmooth.LocalClient.Extensions;
using NosSmooth.PacketSerializer.Extensions;
using NosSmooth.PacketSerializer.Packets;
using Remora.Commands.Extensions;
using WalkCommands.Commands;
namespace WalkCommands;
///
/// Startup class of WalkCommands.
///
public class Startup
{
private IServiceProvider BuildServices()
{
var collection = new ServiceCollection()
.AddLocalClient()
.AddManagedNostaleCore()
.ShareNosSmooth()
// hook pet and player walk to
// recognize user action's and
// disable walking in case user
// decides to walk.
.ConfigureHooks(h => h
.HookPetWalk()
.HookPlayerWalk())
.AddNostaleDataFiles()
.AddNostalePathfinding()
.AddScoped()
.AddScoped()
.AddSingleton()
.Configure(o => o.AllowIntercept = true)
.AddNostaleChatCommands()
.AddLogging
(
b =>
{
b.ClearProviders();
b.AddConsole();
b.SetMinimumLevel(LogLevel.Debug);
}
);
collection.AddCommandTree()
.WithCommandGroup()
.WithCommandGroup();
return collection.BuildServiceProvider();
}
///
/// Run the MoveToMiniland.
///
/// A task that may or may not have succeeded.
public async Task RunAsync()
{
var provider = BuildServices();
var bindingManager = provider.GetRequiredService();
var logger = provider.GetRequiredService>();
var initializeResult = bindingManager.Initialize();
if (!initializeResult.IsSuccess)
{
logger.LogError($"Could not initialize NosBindingManager.");
logger.LogResultError(initializeResult);
}
if (!bindingManager.IsModulePresent() || !bindingManager.IsModulePresent()
|| !bindingManager.IsModulePresent())
{
logger.LogError
(
"At least one of: periodic, packet receive, packet send has not been loaded correctly, the bot may not be used at all. Aborting"
);
return;
}
var packetTypesRepository = provider.GetRequiredService();
var packetAddResult = packetTypesRepository.AddDefaultPackets();
if (!packetAddResult.IsSuccess)
{
logger.LogError("Could not initialize default packet serializers correctly");
logger.LogResultError(packetAddResult);
}
var dataManager = provider.GetRequiredService();
var dataResult = dataManager.Initialize();
if (!dataResult.IsSuccess)
{
logger.LogError("Could not initialize the nostale data files");
logger.LogResultError(dataResult);
}
var mainCancellation = provider.GetRequiredService();
var client = provider.GetRequiredService();
await client.RunAsync(mainCancellation.Token);
}
}