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)}
}