Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

SqlScript, SqlScriptQuery: Add support for disable variables parameter #1578

Merged
7 changes: 7 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,13 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
- Now support to authenticate using both NetBIOS domain and Fully Qualified
Domain Name (FQDN) ([issue #1223](https://github.com/dsccommunity/SqlServerDsc/issues/1223)).

### Added

- SqlScript
- Added the DisableVariables parameter ([issue #1422](https://github.com/dsccommunity/SqlServerDsc/issues/1422))
- SqlScriptQuery
- Added the DisableVariables parameter ([issue #1422](https://github.com/dsccommunity/SqlServerDsc/issues/1422))

## [14.0.0] - 2020-06-12

### Remove
Expand Down
93 changes: 60 additions & 33 deletions source/DSCResources/DSC_SqlScript/DSC_SqlScript.psm1
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,10 @@ $script:localizedData = Get-LocalizedData -DefaultUICulture 'en-US'
Use a Windows PowerShell array to specify multiple variables and their values. For more information how to use this,
please go to the help documentation for [Invoke-Sqlcmd](https://technet.microsoft.com/en-us/library/mt683370.aspx).

.PARAMETER DisableVariables
Specifies, as a boolean, whether or not PowerShell will ignore sqlcmd scripting variables that share a format such as $(variable_name).
For more information how to use this, please go to the help documentation for [Invoke-Sqlcmd](https://technet.microsoft.com/en-us/library/mt683370.aspx)")]

.PARAMETER QueryTimeout
Specifies, as an integer, the number of seconds after which the T-SQL script execution will time out.
In some SQL Server versions there is a bug in Invoke-Sqlcmd where the normal default value 0 (no timeout) is not respected and the default value is incorrectly set to 30 seconds.
Expand Down Expand Up @@ -85,19 +89,24 @@ function Get-TargetResource

[Parameter()]
[System.String[]]
$Variable
$Variable,

[Parameter()]
[System.Boolean]
$DisableVariables
)

$serverInstance = ConvertTo-ServerInstanceName -InstanceName $InstanceName -ServerName $ServerName

$invokeParameters = @{
ServerInstance = $serverInstance
InputFile = $GetFilePath
Credential = $Credential
Variable = $Variable
QueryTimeout = $QueryTimeout
Verbose = $VerbosePreference
ErrorAction = 'Stop'
ServerInstance = $serverInstance
InputFile = $GetFilePath
Credential = $Credential
Variable = $Variable
DisableVariables = $DisableVariables
QueryTimeout = $QueryTimeout
Verbose = $VerbosePreference
ErrorAction = 'Stop'
}

Write-Verbose -Message (
Expand All @@ -109,15 +118,16 @@ function Get-TargetResource
$getResult = Out-String -InputObject $result

$returnValue = @{
ServerName = [System.String] $ServerName
InstanceName = [System.String] $InstanceName
SetFilePath = [System.String] $SetFilePath
GetFilePath = [System.String] $GetFilePath
TestFilePath = [System.String] $TestFilePath
Credential = [System.Object] $Credential
QueryTimeout = [System.UInt32] $QueryTimeout
Variable = [System.String[]] $Variable
GetResult = [System.String[]] $getResult
ServerName = [System.String] $ServerName
InstanceName = [System.String] $InstanceName
SetFilePath = [System.String] $SetFilePath
GetFilePath = [System.String] $GetFilePath
TestFilePath = [System.String] $TestFilePath
Credential = [System.Object] $Credential
QueryTimeout = [System.UInt32] $QueryTimeout
Variable = [System.String[]] $Variable
DisableVariables = [System.Boolean] $DisableVariables
GetResult = [System.String[]] $getResult
}

return $returnValue
Expand Down Expand Up @@ -164,6 +174,10 @@ function Get-TargetResource
Specifies, as a string array, a Invoke-Sqlcmd scripting variable for use in the Invoke-Sqlcmd script, and sets a value for the variable.
Use a Windows PowerShell array to specify multiple variables and their values. For more information how to use this,
please go to the help documentation for [Invoke-Sqlcmd](https://technet.microsoft.com/en-us/library/mt683370.aspx).

.PARAMETER DisableVariables
Specifies, as a boolean, whether or not PowerShell will ignore sqlcmd scripting variables that share a format such as $(variable_name).
For more information how to use this, please go to the help documentation for [Invoke-Sqlcmd](https://technet.microsoft.com/en-us/library/mt683370.aspx)")]
#>
function Set-TargetResource
{
Expand Down Expand Up @@ -202,7 +216,11 @@ function Set-TargetResource

[Parameter()]
[System.String[]]
$Variable
$Variable,

[Parameter()]
[System.Boolean]
$DisableVariables
)

$serverInstance = ConvertTo-ServerInstanceName -InstanceName $InstanceName -ServerName $ServerName
Expand All @@ -212,13 +230,14 @@ function Set-TargetResource
)

$invokeParameters = @{
ServerInstance = $serverInstance
InputFile = $SetFilePath
Credential = $Credential
Variable = $Variable
QueryTimeout = $QueryTimeout
Verbose = $VerbosePreference
ErrorAction = 'Stop'
ServerInstance = $serverInstance
InputFile = $SetFilePath
Credential = $Credential
Variable = $Variable
DisableVariables = $DisableVariables
QueryTimeout = $QueryTimeout
Verbose = $VerbosePreference
ErrorAction = 'Stop'
}

Invoke-SqlScript @invokeParameters
Expand Down Expand Up @@ -266,6 +285,9 @@ function Set-TargetResource
Use a Windows PowerShell array to specify multiple variables and their values. For more information how to use this,
please go to the help documentation for [Invoke-Sqlcmd](https://technet.microsoft.com/en-us/library/mt683370.aspx).

.PARAMETER DisableVariables
Specifies, as a boolean, whether or not PowerShell will ignore sqlcmd scripting variables that share a format such as $(variable_name).
For more information how to use this, please go to the help documentation for [Invoke-Sqlcmd](https://technet.microsoft.com/en-us/library/mt683370.aspx).
#>
function Test-TargetResource
{
Expand Down Expand Up @@ -305,7 +327,11 @@ function Test-TargetResource

[Parameter()]
[System.String[]]
$Variable
$Variable,

[Parameter()]
[System.Boolean]
$DisableVariables
)

Write-Verbose -Message (
Expand All @@ -315,13 +341,14 @@ function Test-TargetResource
$serverInstance = ConvertTo-ServerInstanceName -InstanceName $InstanceName -ServerName $ServerName

$invokeParameters = @{
ServerInstance = $serverInstance
InputFile = $TestFilePath
Credential = $Credential
Variable = $Variable
QueryTimeout = $QueryTimeout
Verbose = $VerbosePreference
ErrorAction = 'Stop'
ServerInstance = $serverInstance
InputFile = $TestFilePath
Credential = $Credential
Variable = $Variable
DisableVariables = $DisableVariables
QueryTimeout = $QueryTimeout
Verbose = $VerbosePreference
ErrorAction = 'Stop'
}

$result = $null
Expand Down
1 change: 1 addition & 0 deletions source/DSCResources/DSC_SqlScript/DSC_SqlScript.schema.mof
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ class DSC_SqlScript : OMI_BaseResource
[Write, Description("Specifies the host name of the SQL Server to be configured. Default value is $env:COMPUTERNAME.")] String ServerName;
[Write, EmbeddedInstance("MSFT_Credential"), Description("The credentials to authenticate with, using SQL Authentication. To authenticate using Windows Authentication assign the credentials to the built-in parameter 'PsDscRunAsCredential'. If neither of the parameters 'Credential' and 'PsDscRunAsCredential' are assigned, then the SYSTEM account will be used to authenticate using Windows Authentication.")] String Credential;
[Write, Description("Specifies, as a string array, a scripting variable for use in the sql script, and sets a value for the variable. Use an array to specify multiple variables and their values. For more information how to use this, please go to the help documentation for [Invoke-Sqlcmd](https://technet.microsoft.com/en-us/library/mt683370.aspx)")] String Variable[];
[Write, Description("Specifies, as a boolean, whether or not PowerShell will ignore sqlcmd scripting variables that share a format such as $(variable_name). For more information how to use this, please go to the help documentation for [Invoke-Sqlcmd](https://technet.microsoft.com/en-us/library/mt683370.aspx)")] Boolean DisableVariables;
[Write, Description("Specifies, as an integer, the number of seconds after which the T-SQL script execution will time out. In some SQL Server versions there is a bug in Invoke-Sqlcmd where the normal default value 0 (no timeout) is not respected and the default value is incorrectly set to 30 seconds.")] UInt32 QueryTimeout;
[Read, Description("Returns the result from the T-SQL script provided in the parameter 'GetFilePath' when cmdlet Get-DscConfiguration is run.")] String GetResult[];
};
94 changes: 61 additions & 33 deletions source/DSCResources/DSC_SqlScriptQuery/DSC_SqlScriptQuery.psm1
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,10 @@ $script:localizedData = Get-LocalizedData -DefaultUICulture 'en-US'
Use a Windows PowerShell array to specify multiple variables and their values. For more information how to use this,
please go to the help documentation for [Invoke-Sqlcmd](https://technet.microsoft.com/en-us/library/mt683370.aspx).

.PARAMETER DisableVariables
Specifies, as a boolean, whether or not PowerShell will ignore sqlcmd scripting variables that share a format such as $(variable_name).
For more information how to use this, please go to the help documentation for [Invoke-Sqlcmd](https://technet.microsoft.com/en-us/library/mt683370.aspx).

.PARAMETER QueryTimeout
Specifies, as an integer, the number of seconds after which the T-SQL script execution will time out.
In some SQL Server versions there is a bug in Invoke-Sqlcmd where the normal default value 0 (no timeout) is not respected and the default value is incorrectly set to 30 seconds.
Expand Down Expand Up @@ -85,7 +89,11 @@ function Get-TargetResource

[Parameter()]
[System.String[]]
$Variable
$Variable,

[Parameter()]
[System.Boolean]
$DisableVariables
)

Write-Verbose -Message (
Expand All @@ -95,29 +103,31 @@ function Get-TargetResource
$serverInstance = ConvertTo-ServerInstanceName -InstanceName $InstanceName -ServerName $ServerName

$invokeParameters = @{
Query = $GetQuery
ServerInstance = $serverInstance
Credential = $Credential
Variable = $Variable
QueryTimeout = $QueryTimeout
Verbose = $VerbosePreference
ErrorAction = 'Stop'
Query = $GetQuery
ServerInstance = $serverInstance
Credential = $Credential
Variable = $Variable
DisableVariables = $DisableVariables
QueryTimeout = $QueryTimeout
Verbose = $VerbosePreference
ErrorAction = 'Stop'
}

$result = Invoke-SqlScript @invokeParameters

$getResult = Out-String -InputObject $result

$returnValue = @{
ServerName = [System.String] $ServerName
InstanceName = [System.String] $InstanceName
GetQuery = [System.String] $GetQuery
TestQuery = [System.String] $TestQuery
SetQuery = [System.String] $SetQuery
Credential = [System.Object] $Credential
QueryTimeout = [System.UInt32] $QueryTimeout
Variable = [System.String[]] $Variable
GetResult = [System.String[]] $getResult
ServerName = [System.String] $ServerName
InstanceName = [System.String] $InstanceName
GetQuery = [System.String] $GetQuery
TestQuery = [System.String] $TestQuery
SetQuery = [System.String] $SetQuery
Credential = [System.Object] $Credential
QueryTimeout = [System.UInt32] $QueryTimeout
Variable = [System.String[]] $Variable
DisableVariables = [System.Boolean] $DisableVariables
GetResult = [System.String[]] $getResult
}

return $returnValue
Expand Down Expand Up @@ -164,6 +174,10 @@ function Get-TargetResource
Specifies, as a string array, a Invoke-Sqlcmd scripting variable for use in the Invoke-Sqlcmd script, and sets a value for the variable.
Use a Windows PowerShell array to specify multiple variables and their values. For more information how to use this,
please go to the help documentation for [Invoke-Sqlcmd](https://technet.microsoft.com/en-us/library/mt683370.aspx).

.PARAMETER DisableVariables
Specifies, as a boolean, whether or not PowerShell will ignore sqlcmd scripting variables that share a format such as $(variable_name).
For more information how to use this, please go to the help documentation for [Invoke-Sqlcmd](https://technet.microsoft.com/en-us/library/mt683370.aspx)")]
#>
function Set-TargetResource
{
Expand Down Expand Up @@ -202,7 +216,11 @@ function Set-TargetResource

[Parameter()]
[System.String[]]
$Variable
$Variable,

[Parameter()]
[System.Boolean]
$DisableVariables
)

Write-Verbose -Message (
Expand All @@ -212,13 +230,14 @@ function Set-TargetResource
$serverInstance = ConvertTo-ServerInstanceName -InstanceName $InstanceName -ServerName $ServerName

$invokeParameters = @{
Query = $SetQuery
ServerInstance = $serverInstance
Credential = $Credential
Variable = $Variable
QueryTimeout = $QueryTimeout
Verbose = $VerbosePreference
ErrorAction = 'Stop'
Query = $SetQuery
ServerInstance = $serverInstance
Credential = $Credential
Variable = $Variable
DisableVariables = $DisableVariables
QueryTimeout = $QueryTimeout
Verbose = $VerbosePreference
ErrorAction = 'Stop'
}

Invoke-SqlScript @invokeParameters
Expand Down Expand Up @@ -266,6 +285,10 @@ function Set-TargetResource
Use a Windows PowerShell array to specify multiple variables and their values. For more information how to use this,
please go to the help documentation for [Invoke-Sqlcmd](https://technet.microsoft.com/en-us/library/mt683370.aspx).

.PARAMETER DisableVariables
Specifies, as a boolean, whether or not PowerShell will ignore sqlcmd scripting variables that share a format such as $(variable_name).
For more information how to use this, please go to the help documentation for [Invoke-Sqlcmd](https://technet.microsoft.com/en-us/library/mt683370.aspx)")]

#>
function Test-TargetResource
{
Expand Down Expand Up @@ -305,7 +328,11 @@ function Test-TargetResource

[Parameter()]
[System.String[]]
$Variable
$Variable,

[Parameter()]
[System.Boolean]
$DisableVariables
)

Write-Verbose -Message (
Expand All @@ -315,13 +342,14 @@ function Test-TargetResource
$serverInstance = ConvertTo-ServerInstanceName -InstanceName $InstanceName -ServerName $ServerName

$invokeParameters = @{
Query = $TestQuery
ServerInstance = $serverInstance
Credential = $Credential
Variable = $Variable
QueryTimeout = $QueryTimeout
Verbose = $VerbosePreference
ErrorAction = 'Stop'
Query = $TestQuery
ServerInstance = $serverInstance
Credential = $Credential
Variable = $Variable
DisableVariables = $DisableVariables
QueryTimeout = $QueryTimeout
Verbose = $VerbosePreference
ErrorAction = 'Stop'
}

$result = $null
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ class DSC_SqlScriptQuery : OMI_BaseResource
[Write, Description("Specifies the host name of the SQL Server to be configured. Default value is $env:COMPUTERNAME.")] String ServerName;
[Write, EmbeddedInstance("MSFT_Credential"), Description("The credentials to authenticate with, using SQL Authentication. To authenticate using Windows Authentication, assign the credentials to the built-in parameter 'PsDscRunAsCredential'. If neither of the parameters 'Credential' and 'PsDscRunAsCredential' are assigned then the SYSTEM account will be used to authenticate using Windows Authentication.")] String Credential;
[Write, Description("Specifies, as a string array, a scripting variable for use in the sql script, and sets a value for the variable. Use a Windows PowerShell array to specify multiple variables and their values. For more information how to use this, please go to the help documentation for [Invoke-Sqlcmd](https://technet.microsoft.com/en-us/library/mt683370.aspx)")] String Variable[];
[Write, Description("Specifies, as a boolean, whether or not PowerShell will ignore sqlcmd scripting variables that share a format such as $(variable_name). For more information how to use this, please go to the help documentation for [Invoke-Sqlcmd](https://technet.microsoft.com/en-us/library/mt683370.aspx)")] Boolean DisableVariables;
[Write, Description("Specifies, as an integer, the number of seconds after which the T-SQL script execution will time out. In some SQL Server versions there is a bug in Invoke-Sqlcmd where the normal default value 0 (no timeout) is not respected and the default value is incorrectly set to 30 seconds.")] UInt32 QueryTimeout;
[Read, Description("Returns the result from the T-SQL script provided in the parameter 'GetQuery' when cmdlet Get-DscConfiguration is run.")] String GetResult[];
};
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
<#
.DESCRIPTION
This example shows how to run SQL script with disabled variables.
#>

Configuration Example
{
param
(
[Parameter(Mandatory = $true)]
[System.Management.Automation.PSCredential]
$SqlCredential
)

Import-DscResource -ModuleName 'SqlServerDsc'

Node localhost
{
SqlScript 'RunWithDisabledVariables'
{
ServerName = 'localhost'
InstanceName = 'SQL2016'
Credential = $SqlCredential

SetFilePath = 'C:\DSCTemp\SQLScripts\Set-RunSQLScript.sql'
TestFilePath = 'C:\DSCTemp\SQLScripts\Test-RunSQLScript.sql'
GetFilePath = 'C:\DSCTemp\SQLScripts\Get-RunSQLScript.sql'
DisableVariables = $true
}
}
}
Loading