| 123456789101112131415161718192021222324252627282930313233343536373839404142434445 |
- using Microsoft.Extensions.DependencyInjection;
- using RackPeek.Domain.Resources.Services.UseCases;
- using Spectre.Console;
- using Spectre.Console.Cli;
- namespace Shared.Rcl.Commands.Services;
- public class ServiceDescribeCommand(
- IServiceProvider serviceProvider
- ) : AsyncCommand<ServiceNameSettings>
- {
- public override async Task<int> ExecuteAsync(
- CommandContext context,
- ServiceNameSettings settings,
- CancellationToken cancellationToken)
- {
- using var scope = serviceProvider.CreateScope();
- var useCase = scope.ServiceProvider.GetRequiredService<DescribeServiceUseCase>();
- var service = await useCase.ExecuteAsync(settings.Name);
- var grid = new Grid()
- .AddColumn(new GridColumn().NoWrap())
- .AddColumn(new GridColumn().NoWrap())
- .AddColumn(new GridColumn().NoWrap())
- .AddColumn(new GridColumn().NoWrap())
- .AddColumn(new GridColumn().NoWrap())
- .AddColumn(new GridColumn().NoWrap());
- grid.AddRow("Name:", service.Name);
- grid.AddRow("Ip:", service.Ip ?? "Unknown");
- grid.AddRow("Port:", service.Port?.ToString() ?? "Unknown");
- grid.AddRow("Protocol:", service.Protocol ?? "Unknown");
- grid.AddRow("Url:", service.Url ?? "Unknown");
- grid.AddRow("Runs On:",
- ServicesFormatExtensions.FormatRunsOn(service.RunsOnSystemHost, service.RunsOnPhysicalHost));
- AnsiConsole.Write(
- new Panel(grid)
- .Header("Service")
- .Border(BoxBorder.Rounded));
- return 0;
- }
- }
|