AccessPointLabelAddCommand.cs 1.1 KB

123456789101112131415161718192021222324252627
  1. using Microsoft.Extensions.DependencyInjection;
  2. using RackPeek.Domain.Resources.AccessPoints;
  3. using RackPeek.Domain.UseCases.Labels;
  4. using Spectre.Console;
  5. using Spectre.Console.Cli;
  6. namespace Shared.Rcl.Commands.AccessPoints.Labels;
  7. public class AccessPointLabelAddSettings : AccessPointNameSettings
  8. {
  9. [CommandOption("--key <KEY>")] public string Key { get; set; } = default!;
  10. [CommandOption("--value <VALUE>")] public string Value { get; set; } = default!;
  11. }
  12. public class AccessPointLabelAddCommand(IServiceProvider serviceProvider) : AsyncCommand<AccessPointLabelAddSettings>
  13. {
  14. public override async Task<int> ExecuteAsync(CommandContext context, AccessPointLabelAddSettings settings,
  15. CancellationToken cancellationToken)
  16. {
  17. using IServiceScope scope = serviceProvider.CreateScope();
  18. IAddLabelUseCase<AccessPoint> useCase =
  19. scope.ServiceProvider.GetRequiredService<IAddLabelUseCase<AccessPoint>>();
  20. await useCase.ExecuteAsync(settings.Name, settings.Key, settings.Value);
  21. AnsiConsole.MarkupLine($"[green]Label '{settings.Key}' added to '{settings.Name}'.[/]");
  22. return 0;
  23. }
  24. }