From f9fb16908d26841ea33e91db2795771d77064b0a Mon Sep 17 00:00:00 2001 From: Dhirender Singh Date: Mon, 21 Oct 2024 16:10:46 +0200 Subject: [PATCH] fix(connector): only provider should update connector --- .../BusinessLogic/ConnectorsBusinessLogic.cs | 10 +++++----- .../Models/ConnectorUpdateInformation.cs | 2 +- .../Repositories/ConnectorsRepository.cs | 2 +- .../BusinessLogic/ConnectorsBusinessLogicTests.cs | 14 +++++++------- 4 files changed, 14 insertions(+), 14 deletions(-) diff --git a/src/administration/Administration.Service/BusinessLogic/ConnectorsBusinessLogic.cs b/src/administration/Administration.Service/BusinessLogic/ConnectorsBusinessLogic.cs index 9918e87408..1745d1c098 100644 --- a/src/administration/Administration.Service/BusinessLogic/ConnectorsBusinessLogic.cs +++ b/src/administration/Administration.Service/BusinessLogic/ConnectorsBusinessLogic.cs @@ -400,7 +400,7 @@ private async Task UpdateConnectorUrlInternal(Guid connectorId, ConnectorUpdateR if (connector == null) { - throw NotFoundException.Create(AdministrationConnectorErrors.CONNECTOR_NOT_FOUND, new ErrorParameter[] { new("connectorId", connectorId.ToString()) }); + throw NotFoundException.Create(AdministrationConnectorErrors.CONNECTOR_NOT_FOUND, [new("connectorId", connectorId.ToString())]); } if (connector.ConnectorUrl == data.ConnectorUrl) @@ -408,14 +408,14 @@ private async Task UpdateConnectorUrlInternal(Guid connectorId, ConnectorUpdateR return; } - if (!connector.IsHostCompany) + if (!connector.IsProviderCompany) { - throw ForbiddenException.Create(AdministrationConnectorErrors.CONNECTOR_NOT_HOST_COMPANY, new ErrorParameter[] { new("companyId", _identityData.CompanyId.ToString()) }); + throw ForbiddenException.Create(AdministrationConnectorErrors.CONNECTOR_NOT_PROVIDER_COMPANY, [new("companyId", _identityData.CompanyId.ToString()), new("connectorId", connectorId.ToString())]); } if (connector.Status == ConnectorStatusId.INACTIVE) { - throw ConflictException.Create(AdministrationConnectorErrors.CONNECTOR_CONFLICT_INACTIVE_STATE, new ErrorParameter[] { new("connectorId", connectorId.ToString()), new("connectorStatusId", ConnectorStatusId.INACTIVE.ToString()) }); + throw ConflictException.Create(AdministrationConnectorErrors.CONNECTOR_CONFLICT_INACTIVE_STATE, [new("connectorId", connectorId.ToString()), new("connectorStatusId", ConnectorStatusId.INACTIVE.ToString())]); } var bpn = connector.Type == ConnectorTypeId.CONNECTOR_AS_A_SERVICE @@ -425,7 +425,7 @@ private async Task UpdateConnectorUrlInternal(Guid connectorId, ConnectorUpdateR .ConfigureAwait(ConfigureAwaitOptions.None); if (string.IsNullOrWhiteSpace(bpn)) { - throw ConflictException.Create(AdministrationConnectorErrors.CONNECTOR_CONFLICT_SET_BPN, new ErrorParameter[] { new("companyId", _identityData.CompanyId.ToString()) }); + throw ConflictException.Create(AdministrationConnectorErrors.CONNECTOR_CONFLICT_SET_BPN, [new("companyId", _identityData.CompanyId.ToString())]); } connectorsRepository.AttachAndModifyConnector(connectorId, null, con => diff --git a/src/portalbackend/PortalBackend.DBAccess/Models/ConnectorUpdateInformation.cs b/src/portalbackend/PortalBackend.DBAccess/Models/ConnectorUpdateInformation.cs index 66b78c4b16..47a70263c7 100644 --- a/src/portalbackend/PortalBackend.DBAccess/Models/ConnectorUpdateInformation.cs +++ b/src/portalbackend/PortalBackend.DBAccess/Models/ConnectorUpdateInformation.cs @@ -28,6 +28,6 @@ namespace Org.Eclipse.TractusX.Portal.Backend.PortalBackend.DBAccess.Models; public record ConnectorUpdateInformation( ConnectorStatusId Status, ConnectorTypeId Type, - bool IsHostCompany, + bool IsProviderCompany, string ConnectorUrl, string? Bpn); diff --git a/src/portalbackend/PortalBackend.DBAccess/Repositories/ConnectorsRepository.cs b/src/portalbackend/PortalBackend.DBAccess/Repositories/ConnectorsRepository.cs index 67f8eaf7ad..3b270a6797 100644 --- a/src/portalbackend/PortalBackend.DBAccess/Repositories/ConnectorsRepository.cs +++ b/src/portalbackend/PortalBackend.DBAccess/Repositories/ConnectorsRepository.cs @@ -190,7 +190,7 @@ public Connector AttachAndModifyConnector(Guid connectorId, Action? i .Select(c => new ConnectorUpdateInformation( c.StatusId, c.TypeId, - c.HostId == companyId, + c.ProviderId == companyId, c.ConnectorUrl, c.Provider!.BusinessPartnerNumber )) diff --git a/tests/administration/Administration.Service.Tests/BusinessLogic/ConnectorsBusinessLogicTests.cs b/tests/administration/Administration.Service.Tests/BusinessLogic/ConnectorsBusinessLogicTests.cs index f1c55d916d..9f99848f60 100644 --- a/tests/administration/Administration.Service.Tests/BusinessLogic/ConnectorsBusinessLogicTests.cs +++ b/tests/administration/Administration.Service.Tests/BusinessLogic/ConnectorsBusinessLogicTests.cs @@ -1001,13 +1001,13 @@ public async Task UpdateConnectorUrl_WithSameUrlAsStored_ReturnsWithoutDoing() } [Fact] - public async Task UpdateConnectorUrl_WithUserNotOfHostCompany_ThrowsForbiddenException() + public async Task UpdateConnectorUrl_WithUserNotOfProviderCompany_ThrowsForbiddenException() { // Arrange var connectorId = Guid.NewGuid(); var data = _fixture.Build() .With(x => x.ConnectorUrl, "https://old.de") - .With(x => x.IsHostCompany, false) + .With(x => x.IsProviderCompany, false) .Create(); A.CallTo(() => _connectorsRepository.GetConnectorUpdateInformation(connectorId, _identity.CompanyId)) .Returns(data); @@ -1017,7 +1017,7 @@ public async Task UpdateConnectorUrl_WithUserNotOfHostCompany_ThrowsForbiddenExc // Assert var ex = await Assert.ThrowsAsync(Act); - ex.Message.Should().Be(AdministrationConnectorErrors.CONNECTOR_NOT_HOST_COMPANY.ToString()); + ex.Message.Should().Be(AdministrationConnectorErrors.CONNECTOR_NOT_PROVIDER_COMPANY.ToString()); } [Fact] @@ -1027,7 +1027,7 @@ public async Task UpdateConnectorUrl_WithInactiveConnector_ThrowsConflictExcepti var connectorId = Guid.NewGuid(); var data = _fixture.Build() .With(x => x.ConnectorUrl, "https://old.de") - .With(x => x.IsHostCompany, true) + .With(x => x.IsProviderCompany, true) .With(x => x.Status, ConnectorStatusId.INACTIVE) .Create(); A.CallTo(() => _connectorsRepository.GetConnectorUpdateInformation(connectorId, _identity.CompanyId)) @@ -1048,7 +1048,7 @@ public async Task UpdateConnectorUrl_WithBpnNotSet_ThrowsConflictException() var connectorId = Guid.NewGuid(); var data = _fixture.Build() .With(x => x.ConnectorUrl, "https://old.de") - .With(x => x.IsHostCompany, true) + .With(x => x.IsProviderCompany, true) .With(x => x.Status, ConnectorStatusId.ACTIVE) .With(x => x.Type, ConnectorTypeId.CONNECTOR_AS_A_SERVICE) .With(x => x.Bpn, default(string?)) @@ -1071,7 +1071,7 @@ public async Task UpdateConnectorUrl_WithCompanyBpnNotSet_ThrowsConflictExceptio var connectorId = Guid.NewGuid(); var data = _fixture.Build() .With(x => x.ConnectorUrl, "https://old.de") - .With(x => x.IsHostCompany, true) + .With(x => x.IsProviderCompany, true) .With(x => x.Status, ConnectorStatusId.ACTIVE) .With(x => x.Type, ConnectorTypeId.COMPANY_CONNECTOR) .With(x => x.Bpn, "BPNL123456789") @@ -1099,7 +1099,7 @@ public async Task UpdateConnectorUrl_WithValidData_CallsExpected() .Create(); var data = _fixture.Build() .With(x => x.ConnectorUrl, "https://old.de") - .With(x => x.IsHostCompany, true) + .With(x => x.IsProviderCompany, true) .With(x => x.Status, ConnectorStatusId.ACTIVE) .With(x => x.Type, ConnectorTypeId.CONNECTOR_AS_A_SERVICE) .With(x => x.Bpn, "BPNL123456789")