| 12345678910111213141516171819202122232425262728293031323334353637383940 |
- using Microsoft.Extensions.DependencyInjection;
- using RackPeek.Domain.Resources.AccessPoints;
- using RackPeek.Domain.UseCases;
- using Spectre.Console;
- using Spectre.Console.Cli;
- namespace Shared.Rcl.Commands.AccessPoints;
- public class AccessPointDescribeCommand(
- IServiceProvider serviceProvider
- ) : AsyncCommand<AccessPointNameSettings> {
- public override async Task<int> ExecuteAsync(
- CommandContext context,
- AccessPointNameSettings settings,
- CancellationToken cancellationToken) {
- using IServiceScope scope = serviceProvider.CreateScope();
- IGetResourceByNameUseCase<AccessPoint> useCase =
- scope.ServiceProvider.GetRequiredService<IGetResourceByNameUseCase<AccessPoint>>();
- AccessPoint ap = await useCase.ExecuteAsync(settings.Name);
- Grid grid = new Grid()
- .AddColumn(new GridColumn().NoWrap())
- .AddColumn(new GridColumn().NoWrap());
- grid.AddRow("Name:", ap.Name);
- grid.AddRow("Model:", ap.Model ?? "Unknown");
- grid.AddRow("Speed (Gbps):", ap.Speed?.ToString() ?? "Unknown");
- if (ap.Labels.Count > 0)
- grid.AddRow("Labels:", string.Join(", ", ap.Labels.Select(kvp => $"{kvp.Key}: {kvp.Value}")));
- AnsiConsole.Write(
- new Panel(grid)
- .Header("Access Point")
- .Border(BoxBorder.Rounded));
- return 0;
- }
- }
|