functions/public/Add-DiscoveryRegistrationSql.ps1
function Add-DiscoveryRegistrationSql { [CmdletBinding()] param ( $discoveryPostBody, $connectionString ) if ($null -eq $discoveryPostBody.isHidden){ $discoveryPostBody.isHidden = $true } if ($null -eq $discoveryPostBody.iconTxt){ $discoveryPostBody.iconTxt = "" } $query = "DECLARE @InsertBuildNumberTXT nvarchar(100) = '' DECLARE @InsertListBuildNumberTXT nvarchar(50) = '' DECLARE @UpdateBuildNumberTXT nvarchar(100) = '' DECLARE @InsertOrUpdateService varchar(max) = '' IF EXISTS (SELECT * FROM sys.columns WHERE name = 'BuildNumberTXT' AND OBJECT_ID = OBJECT_ID('CatalystAdmin.DiscoveryServiceBASE')) BEGIN SET @InsertBuildNumberTXT = ',''' + @BuildNumberTXT + ''''; SET @InsertListBuildNumberTXT = ',[BuildNumberTXT]'; SET @UpdateBuildNumberTXT = ',BuildNumberTXT = ''' + @BuildNumberTXT + ''''; END IF EXISTS ( SELECT * FROM [CatalystAdmin].[DiscoveryServiceBASE] WHERE ServiceNM = @ServiceNM AND ServiceVersion = @ServiceVersion ) BEGIN SET @InsertOrUpdateService = ' UPDATE [CatalystAdmin].[DiscoveryServiceBASE] SET [ServiceUrl] = ''' + @ServiceUrl + ''', DiscoveryTypeCD = ''' + @DiscoveryTypeCD + ''', HiddenFLG = ' + CAST(@HiddenFLG AS NVARCHAR(1)) + ', FriendlyNM = ''' + @FriendlyNM + ''', IconTXT = ''' + @IconTXT + ''', DescriptionTXT = ''' + @DescriptionTXT + '''' + @UpdateBuildNumberTXT + ' WHERE ServiceNM = ''' + @ServiceNM + ''' AND ServiceVersion = ' + CAST(@ServiceVersion AS NVARCHAR(1)) + ';' END ELSE BEGIN SET @InsertOrUpdateService = ' INSERT INTO [CatalystAdmin].[DiscoveryServiceBASE] ([ServiceNM], [ServiceUrl], [ServiceVersion], [DiscoveryTypeCD], [HiddenFLG], [FriendlyNM], [IconTXT], [DescriptionTXT]' + @InsertListBuildNumberTXT + ' ) VALUES (''' + @ServiceNM + ''',''' + @ServiceUrl + ''',' + CAST(@ServiceVersion AS NVARCHAR(20)) + ',''' + @DiscoveryTypeCD + ''',' + CAST(@HiddenFLG AS NVARCHAR(1)) + ',''' + @FriendlyNM + ''',''' + @IconTXT + ''',''' + @DescriptionTXT + '''' + @InsertBuildNumberTXT + ' );' END EXEC(@InsertOrUpdateService);" Invoke-Sql -connectionString $connectionString -sql $query ` -parameters @{ServiceNM=$($discoveryPostBody.serviceName);` ServiceVersion=$($discoveryPostBody.serviceVersion);` ServiceUrl=$($discoveryPostBody.serviceUrl);` DiscoveryTypeCD=$($discoveryPostBody.discoveryType);` FriendlyNM=$($discoveryPostBody.friendlyName);` DescriptionTXT=$($discoveryPostBody.description);` BuildNumberTXT=$($discoveryPostBody.buildVersion);` HiddenFLG=$($discoveryPostBody.isHidden);` IconTXT=$($discoveryPostBody.iconTxt)} } |