| 12345678910111213141516171819202122232425262728293031323334353637 |
- using RackPeek.Domain.Helpers;
- using RackPeek.Domain.Resources.Models;
- using RackPeek.Domain.Resources.SystemResources;
- namespace RackPeek.Domain.Resources.Hardware.AccessPoints;
- public class RenameAccessPointUseCase(IHardwareRepository repository, ISystemRepository systemRepo, IResourceRepository resourceRepo) : IUseCase
- {
- public async Task ExecuteAsync(string originalName, string newName)
- {
- originalName = Normalize.SystemName(originalName);
- ThrowIfInvalid.ResourceName(originalName);
-
- newName = Normalize.SystemName(newName);
- ThrowIfInvalid.ResourceName(newName);
- var existingResourceKind = await resourceRepo.GetResourceKindAsync(newName);
- if (!string.IsNullOrEmpty(existingResourceKind))
- throw new ConflictException($"{existingResourceKind} resource '{newName}' already exists.");
-
- var original = await repository.GetByNameAsync(originalName) as AccessPoint;
- if (original == null)
- {
- throw new NotFoundException($"Resource '{originalName}' not found.");
- }
- original.Name = newName;
- await repository.UpdateAsync(original);
-
- var children = await systemRepo.GetByPhysicalHostAsync(originalName);
- foreach (var child in children)
- {
- child.RunsOn = newName;
- await systemRepo.UpdateAsync(child);
- }
- }
- }
|