Octopus.Script exported 2024-11-26 by andrescolodrero belongs to ‘SQL Server’ category.
Deploy a SQL Agent Job for SSIS Ispac Deployment. Requires SMO to be installed on the machine where this step will be run.
Parameters
When steps based on the template are included in a project’s deployment process, the parameters below can be set.
Server Name
SSIS_ServerName =
null
Folder Name
SSIS_FolderName =
Folder Name of the deployed package
Project Name
SSIS_ProjectName =
null
Catalog Name
SSIS_CatalogName = SSISDB
By default SSISDB
Environment Name
SSIS_EnvironmentName =
null
Package Name
SSIS_PackageName =
Complete name of the package to execute, without dtsx extension
Job Name
SSIS_JobName =
Name of the SQL Job
Job Step Name
SSIS_JobStepName =
null
Job Schedule Name
SSIS_JobSheduleName =
null
Job Execution Frequency
SSIS_JobExecutionFrequency = Daily
Frequency of execution Only supported: OneTime Daily AutoStart
Job Frequency Interval
SSIS_JobFrequencyInterval = 1
Depends of Job Execution Frequency. For now only works with Days Example: 1 -> Recurs every 1 Day 2 -> Recurs every 2 Weeks
Job Execution Time Hour
SSIS_JobExecutionTimeHour =
Hour of the day to execute the job
Job Execution Time Minute
SSIS_JobExecutionTimeMinute =
Minutes of the day to execute the job
Job Category
SSIS_JobCategory =
null
Script body
Steps based on this template will execute the following PowerShell script.
Function Format-OctopusArgument
{
<#
.SYNOPSIS
Converts boolean values to boolean types
.DESCRIPTION
Converts boolean values to boolean types
.PARAMETER Value
The value to convert
.EXAMPLE
Format-OctopusArgument "true"
#>
Param(
[string]$Value
)
$Value = $Value.Trim()
# There must be a better way to do this
Switch -Wildcard ($Value)
{
"True"
{ Return $True
}
"False"
{ Return $False
}
"#{*}"
{ Return $null
}
Default
{ Return $Value
}
}
}
Function Get-SSISCommand
{
<#
.SYNOPSIS
Format the SSIS Command that execute the package.
Only valid for now for Project Deployment ($typecommand = '/ISSERVER "\')
.DESCRIPTION
Return a string with the correct format to execute a Project Package Deploy (Step).
The SSIS Command can be built by paramaters (ServerName, CatalogName, ProjectName, FolderName, Package and Environment)
@TO-DO:
But most of the cases need an ending string that could be the same for most of the deployments.
I will keep this as a Octopus Parameter by now.
#>
Param($ServerName, $CatalogName, $FolderName, $ProjectName, $PackageName, $EnvironmentName)
process {
$environmentid = Get-EnvironmentId -ServerName $ServerName -EnvironmentName $EnvironmentName -PackageName $PackageName -ProjectName $ProjectName
write-host "The Environmemnt Id found for $EnvironmentName is $environmentid"
$slash = '\'
$quotes = '"'
$typecommand = '/ISSERVER "\'
$environmentCommand = '\"" /ENVREFERENCE ' + $environmentid.ToString()
$packagep = $slash + $CatalogName + $slash + $FolderName + $slash + $ProjectName + $slash + $PackageName + '.dtsx' + $slash
$servertype = '" /SERVER "\"'
$commandoptions = ' /Par "\"$ServerOption::LOGGING_LEVEL(Int16)\"";1 /Par "\"$ServerOption::SYNCHRONIZED(Boolean)\"";True /CALLERINFO SQLAGENT /REPORTING E'
}
end {
return $typecommand + $quotes + $packagep + $quotes + $servertype + $ServerName + $environmentCommand + $commandoptions
}
}
Function Get-EnvironmentId
{
<#
.SYNOPSIS
Get the ID of the Environment by Name of Environment
.DESCRIPTION
ProjectDeploy Packages use Enviroments for variables previously deployed for the package.
To be able to format the SSIS Command, we will need the Environment ID
.PARAMETER ServerName
.PARAMETER CatalogName
.PARAMETER FolderName
.PARAMETER ProjectName
.PARAMETER PackageName
.PARAMETER EnvironmentName
#>
Param($ServerName, $EnvironmentName,$PackageName, $ProjectName)
$query = "SELECT er.reference_id
FROM [SSISDB].[internal].[folders] AS f
JOIN [SSISDB].[internal].[projects] AS p
ON f.folder_id = p.folder_id
JOIN [SSISDB].[internal].[environment_references] AS er
ON p.project_id = er.project_id
where f.name = '$FolderName'
and er.environment_name = '$EnvironmentName'
and p.name = '$ProjectName'"
$EnvironmentId = Invoke-Sqlcmd -Query $query -ServerInstance $ServerName -Verbose
return $EnvironmentId.reference_id
}
Function Add-Job
{
<#
.SYNOPSIS
Add a new type of Job in SQL Agent Job
.DESCRIPTION
The function will remove an existing Job with same name (SQL SMO Job doesnt contains update function)
and it will return as GlobalVariable the JOb Object.
.PARAMETER JobName
.PARAMETER ServerName
.PARAMETER EnvironmentName
.PARAMETER JobStepName
.PARAMETER JobStepCommand
#>
param($JobName, $ServerName, $EnvironmentName, $JobsStepName, $JobStepCommand, $JobCategory )
try
{
$server = New-Object Microsoft.SqlServer.Management.Smo.Server($ServerName)
$server.exe
$server.JobServer.HostLoginName
$existingjob = $server.Jobserver.Jobs|where-object {$_.Name -like $JobName}
if ($existingjob)
{
Write-Host "|- Dropping Job [$JobName]..." -NoNewline
$existingjob.drop()
Write-Host "|- Done" -ForegroundColor Green
}
$job = New-Object Microsoft.SqlServer.Management.SMO.Agent.Job($server.JobServer, $jobName)
#$job.DropIfExists() only for sqlserver 2016
$job.Create()
$job.OwnerLoginName = "sa"
$job.Category = $JobCategory
$job.ApplyToTargetServer($server.Name)
}
catch
{
write-host "####### Error Adding a job" -ForegroundColor Red
write-host $_.Exception.Message
}
#Instead of creating a class and return a Job, lets settup a global variable. Return statament doenst return all script output
$Global:newjob = $job
}
Function Add-JobStep
{
<#
.SYNOPSIS
Add a job step to a Job
.DESCRIPTION
The function will remove an existing Job with same name (SQL SMO Job doesnt contains update function)
and it will return as GlobalVariable t
he JOb Object.
.PARAMETER Job
.PARAMETER JobStepName
.PARAMETER JobStepCommand
#>
param($job, $JobStepName, $CommandJob )
try
{
$jobStep = New-Object Microsoft.SqlServer.Management.Smo.Agent.JobStep($job, $JobStepName)
$jobStep.Subsystem = [Microsoft.SqlServer.Management.Smo.Agent.AgentSubSystem]::SSIS
$jobStep.Command = $CommandJob
$jobStep.Create()
}
catch
{
write-host "######### Error adding a job step" -ForegroundColor Red
write-host $_.Exception.Message
}
}
Function Add-JobSchedule
{
# ToDO: Add more types of frequenct: Weekly, Monthly
param($job, $JobScheduleName,$JobExecutionFrequency, $FrecuencyInterval, $startHour, $startMinutes)
try
{
$name = $job.Name
$SQLJobSchedule = New-Object -TypeName Microsoft.SqlServer.Management.SMO.Agent.JobSchedule($job, $JobScheduleName)
switch ($JobExecutionFrequency) {
"Daily" {
$result = [Microsoft.SqlServer.Management.SMO.Agent.FrequencyTypes]::Daily
$subdayTypes = [Microsoft.SqlServer.Management.SMO.Agent.FrequencySubDayTypes]::Hour
}
"OneTime" {
$result = [Microsoft.SqlServer.Management.SMO.Agent.FrequencyTypes]::OneTime
$subdayTypes = [Microsoft.SqlServer.Management.SMO.Agent.FrequencySubDayTypes]::Once
}
"AutoStart" {
$result = [Microsoft.SqlServer.Management.SMO.Agent.FrequencyTypes]::AutoStart
}
default {
$result = [Microsoft.SqlServer.Management.SMO.Agent.FrequencyTypes]::Daily
}
}
$SQLJobSchedule.FrequencyTypes = $result
# Setup Frequency Interval
$SQLJobSchedule.FrequencyInterval = $FrecuencyInterval
# Job Start
$timeofday = New-TimeSpan -hours $startHour -minutes $startMinutes
$SQLJobSchedule.ActiveStartTimeOfDay = $timeofday
#Activate the Job
$SQLJobSchedule.ActiveStartDate = Get-Date
$SQLJobSchedule.Create()
}
catch
{
Write-Host "Error" -ForegroundColor Red
write-host "Exception Type: $($_.Exception.GetType().FullName)" -ForegroundColor Red
write-host "Exception Message: $($_.Exception.Message)" -ForegroundColor Red
$error[0]|format-list -force
}
}
Function Set-SQLJob
{
#Get-Octopus Variables
Write-Host "Collecting Octopus Variables"
$ServerName = Format-OctopusArgument -Value $OctopusParameters["SSIS_ServerName"]
$FolderName = Format-OctopusArgument -Value $OctopusParameters["SSIS_FolderName"]
$ProjectName = Format-OctopusArgument -Value $OctopusParameters["SSIS_ProjectName"]
$CatalogName = Format-OctopusArgument -Value $OctopusParameters["SSIS_CatalogName"]
$EnvironmentName = Format-OctopusArgument -Value $OctopusParameters["SSIS_EnvironmentName"]
$PackageName = Format-OctopusArgument -Value $OctopusParameters["SSIS_PackageName"]
$JobName = Format-OctopusArgument -Value $OctopusParameters["SSIS_JobName"]
$JobCategory = Format-OctopusArgument -Value $OctopusParameters["SSIS_JobCategory"]
$JobStepName = Format-OctopusArgument -Value $OctopusParameters["SSIS_JobStepName"]
$JobScheduleName = Format-OctopusArgument -Value $OctopusParameters["SSIS_JobScheduleName"]
$JobExecutionFrequency = Format-OctopusArgument -Value $OctopusParameters["SSIS_JobExecutionFrequency"]
$JobFrequencyInterval = Format-OctopusArgument -Value $OctopusParameters["SSIS_JobFrequencyInterval"]
$JobExecutionTimeHour = Format-OctopusArgument -Value $OctopusParameters["SSIS_JobExecutionTimeHour"]
$JobExecutionTimeMinute = Format-OctopusArgument -Value $OctopusParameters["SSIS_JobExecutionTimeMinute"]
# FrecuencyType is hardcoded
#Getting Module sqlserver if possible.
$Module = get-module -ListAvailable -name sqlserver
if ($Module.Name -eq 'sqlserver') {
write-host "Importing Module SqlServer"
Import-Module sqlserver -DisableNameChecking
} else {
write-host "Importing Module sqlps"
import-module sqlps -Verbose -DisableNameChecking
}
#First step is to generate the command execution for Job Step.
$JobStepCommand = Get-SSISCommand -ServerName $ServerName -CatalogName $CatalogName -FolderName $FolderName -ProjectName $ProjectName -PackageName $PackageName -EnvironmentName $EnvironmentName -Verbose
write-Host "Command found to deploy Step is "
write-Host $JobStepCommand
write-Host "STARTING DEPLOYMENT "
write-Host "|- Start Adding the Job $JobName"
Add-Job -JobName $JobName -ServerName $ServerName -EnvironmentName $EnvironmentName -JobsStepName $JobStepName -JobStepCommand $JobStepCommandmand
write-Host "|- $JobName Added to $ServerName"
write-Host "|--- Start Adding the JobStep $JobStepName to Job $JobName"
Add-JobStep -JobStepName $JobStepName -CommandJob $JobStepCommand -Job $Global:newjob
write-Host "|--- $JobStepName added to Job $JobName"
write-Host "|---- Start Adding JobShedule $JobScheduleName JobStep $JobName"
Add-JobSchedule -job $Global:newjob -JobScheduleName $JobScheduleName -JobExecutionFrequency $JobExecutionFrequency -FrecuencyInterval $JobFrequencyInterval -startHour $JobExecutionTimeHour -startMinutes $JobExecutionTimeMinute
write-Host "|---- $JobStepName added to Job $JobName"
}
Write-Host "Starting deployment of SQL Job"
Set-SQLJob
Write-Host "Finishing Install"
Provided under the Apache License version 2.0.
To use this template in Octopus Deploy, copy the JSON below and paste it into the Library → Step templates → Import dialog.
{
"Id": "f69ea863-ab61-4c58-bcbe-a133450113c9",
"Name": "SSIS - Deploy SQL Agent Job",
"Description": "Deploy a SQL Agent Job for SSIS Ispac Deployment. Requires SMO to be installed on the machine where this step will be run. ",
"Version": 10,
"ExportedAt": "2018-17-04T10:59:08.819Z",
"ActionType": "Octopus.Script",
"Author": "andrescolodrero",
"Parameters": [
{
"Id": "44a2fa3c-3117-450b-8004-ebdbfd2362e9",
"Name": "SSIS_ServerName",
"Label": "Server Name",
"HelpText": null,
"DefaultValue": "",
"DisplaySettings": {
"Octopus.ControlType": "SingleLineText"
},
"Links": {}
},
{
"Id": "ae040e98-f686-4f44-ad80-8939fbd902e4",
"Name": "SSIS_FolderName",
"Label": "Folder Name",
"HelpText": "Folder Name of the deployed package",
"DefaultValue": "",
"DisplaySettings": {
"Octopus.ControlType": "SingleLineText"
},
"Links": {}
},
{
"Id": "3e755e91-afb5-46c3-ad61-47bf80ac88b8",
"Name": "SSIS_ProjectName",
"Label": "Project Name",
"HelpText": null,
"DefaultValue": "",
"DisplaySettings": {
"Octopus.ControlType": "SingleLineText"
},
"Links": {}
},
{
"Id": "21dc0b13-7db0-4c99-b512-53dbfad55893",
"Name": "SSIS_CatalogName",
"Label": "Catalog Name",
"HelpText": "By default SSISDB",
"DefaultValue": "SSISDB",
"DisplaySettings": {
"Octopus.ControlType": "SingleLineText"
},
"Links": {}
},
{
"Id": "eb197ae7-99e1-41a2-aee4-5b379fdb349c",
"Name": "SSIS_EnvironmentName",
"Label": "Environment Name",
"HelpText": null,
"DefaultValue": "",
"DisplaySettings": {
"Octopus.ControlType": "SingleLineText"
},
"Links": {}
},
{
"Id": "94f97e01-d04c-4696-ad0a-e170a21ecd87",
"Name": "SSIS_PackageName",
"Label": "Package Name",
"HelpText": "Complete name of the package to execute, without dtsx extension",
"DefaultValue": "",
"DisplaySettings": {
"Octopus.ControlType": "SingleLineText"
},
"Links": {}
},
{
"Id": "cb138aa6-2f51-4ebd-b744-9b0d17535ea1",
"Name": "SSIS_JobName",
"Label": "Job Name",
"HelpText": "Name of the SQL Job",
"DefaultValue": "",
"DisplaySettings": {
"Octopus.ControlType": "SingleLineText"
},
"Links": {}
},
{
"Id": "458225af-7d11-4f98-b984-2fe02e66996e",
"Name": "SSIS_JobStepName",
"Label": "Job Step Name",
"HelpText": null,
"DefaultValue": "",
"DisplaySettings": {
"Octopus.ControlType": "SingleLineText"
},
"Links": {}
},
{
"Id": "07d85895-e548-4f54-a403-25cc53fa1a88",
"Name": "SSIS_JobSheduleName",
"Label": "Job Schedule Name",
"HelpText": null,
"DefaultValue": "",
"DisplaySettings": {
"Octopus.ControlType": "SingleLineText"
},
"Links": {}
},
{
"Id": "023f21b1-7757-42f2-8b69-e9a95deb7bae",
"Name": "SSIS_JobExecutionFrequency",
"Label": "Job Execution Frequency",
"HelpText": "Frequency of execution\nOnly supported:\nOneTime\nDaily\nAutoStart",
"DefaultValue": "Daily",
"DisplaySettings": {
"Octopus.ControlType": "Select",
"Octopus.SelectOptions": "AutoStart\nDaily\nOneTime"
},
"Links": {}
},
{
"Id": "25efa439-5490-4ed4-a70f-7b514bd18446",
"Name": "SSIS_JobFrequencyInterval",
"Label": "Job Frequency Interval",
"HelpText": "Depends of Job Execution Frequency.\nFor now only works with Days\nExample:\n1 -> Recurs every 1 Day\n2 -> Recurs every 2 Weeks",
"DefaultValue": "1",
"DisplaySettings": {
"Octopus.ControlType": "SingleLineText"
},
"Links": {}
},
{
"Id": "50b3ab13-8635-4631-a247-092792364902",
"Name": "SSIS_JobExecutionTimeHour",
"Label": "Job Execution Time Hour",
"HelpText": "Hour of the day to execute the job",
"DefaultValue": "",
"DisplaySettings": {
"Octopus.ControlType": "SingleLineText"
},
"Links": {}
},
{
"Id": "4d57dc4e-8717-4f05-bdad-0f16cc9b566d",
"Name": "SSIS_JobExecutionTimeMinute",
"Label": "Job Execution Time Minute",
"HelpText": "Minutes of the day to execute the job",
"DefaultValue": "",
"DisplaySettings": {
"Octopus.ControlType": "SingleLineText"
},
"Links": {}
},
{
"Id": "7a4c18db-51c3-48e7-ab04-b4f084dde3de",
"Name": "SSIS_JobCategory",
"Label": "Job Category",
"HelpText": null,
"DefaultValue": "",
"DisplaySettings": {
"Octopus.ControlType": "SingleLineText"
},
"Links": {}
}
],
"Properties": {
"Octopus.Action.Script.Syntax": "PowerShell",
"Octopus.Action.Script.ScriptSource": "Inline",
"Octopus.Action.Script.ScriptBody": "Function Format-OctopusArgument\n{\n\n <#\n .SYNOPSIS\n Converts boolean values to boolean types\n\n .DESCRIPTION\n Converts boolean values to boolean types\n\n .PARAMETER Value\n The value to convert\n\n .EXAMPLE\n Format-OctopusArgument \"true\"\n #>\n Param(\n [string]$Value\n )\n\n $Value = $Value.Trim()\n\n # There must be a better way to do this\n Switch -Wildcard ($Value)\n {\n\n \"True\"\n { Return $True\n }\n \"False\"\n { Return $False\n }\n \"#{*}\"\n { Return $null\n }\n Default\n { Return $Value\n }\n }\n}\n\n\nFunction Get-SSISCommand\n{\n\n <#\n .SYNOPSIS\n Format the SSIS Command that execute the package.\n Only valid for now for Project Deployment ($typecommand = '/ISSERVER \"\\')\n\n .DESCRIPTION\n Return a string with the correct format to execute a Project Package Deploy (Step).\n The SSIS Command can be built by paramaters (ServerName, CatalogName, ProjectName, FolderName, Package and Environment)\n @TO-DO:\n But most of the cases need an ending string that could be the same for most of the deployments.\n I will keep this as a Octopus Parameter by now.\n\n\n #>\n\n Param($ServerName, $CatalogName, $FolderName, $ProjectName, $PackageName, $EnvironmentName)\n process {\n $environmentid = Get-EnvironmentId -ServerName $ServerName -EnvironmentName $EnvironmentName -PackageName $PackageName -ProjectName $ProjectName\n write-host \"The Environmemnt Id found for $EnvironmentName is $environmentid\"\n $slash = '\\'\n $quotes = '\"'\n $typecommand = '/ISSERVER \"\\'\n $environmentCommand = '\\\"\" /ENVREFERENCE ' + $environmentid.ToString()\n $packagep = $slash + $CatalogName + $slash + $FolderName + $slash + $ProjectName + $slash + $PackageName + '.dtsx' + $slash\n $servertype = '\" /SERVER \"\\\"'\n $commandoptions = ' /Par \"\\\"$ServerOption::LOGGING_LEVEL(Int16)\\\"\";1 /Par \"\\\"$ServerOption::SYNCHRONIZED(Boolean)\\\"\";True /CALLERINFO SQLAGENT /REPORTING E'\n }\n end {\n return $typecommand + $quotes + $packagep + $quotes + $servertype + $ServerName + $environmentCommand + $commandoptions\n }\n\n}\n\nFunction Get-EnvironmentId\n{\n <#\n .SYNOPSIS\n Get the ID of the Environment by Name of Environment\n\n .DESCRIPTION\n ProjectDeploy Packages use Enviroments for variables previously deployed for the package.\n To be able to format the SSIS Command, we will need the Environment ID\n\n .PARAMETER ServerName\n .PARAMETER CatalogName\n .PARAMETER FolderName\n .PARAMETER ProjectName\n .PARAMETER PackageName\n .PARAMETER EnvironmentName\n #>\n\n Param($ServerName, $EnvironmentName,$PackageName, $ProjectName)\n\n\n $query = \"SELECT er.reference_id\n FROM [SSISDB].[internal].[folders] AS f\n JOIN [SSISDB].[internal].[projects] AS p\n ON f.folder_id = p.folder_id\n JOIN [SSISDB].[internal].[environment_references] AS er\n ON p.project_id = er.project_id\n where f.name = '$FolderName'\n\t\t\t\t\t\tand er.environment_name = '$EnvironmentName'\n\t\t\t\t\t\t and p.name = '$ProjectName'\"\n\n $EnvironmentId = Invoke-Sqlcmd -Query $query -ServerInstance $ServerName -Verbose\n\n return $EnvironmentId.reference_id\n}\n\nFunction Add-Job\n{\n <#\n .SYNOPSIS\n Add a new type of Job in SQL Agent Job\n\n .DESCRIPTION\n The function will remove an existing Job with same name (SQL SMO Job doesnt contains update function)\n and it will return as GlobalVariable the JOb Object.\n\n .PARAMETER JobName\n .PARAMETER ServerName\n .PARAMETER EnvironmentName\n .PARAMETER JobStepName\n .PARAMETER JobStepCommand\n #>\n\n param($JobName, $ServerName, $EnvironmentName, $JobsStepName, $JobStepCommand, $JobCategory )\n try\n {\n $server = New-Object Microsoft.SqlServer.Management.Smo.Server($ServerName)\n $server.exe\n $server.JobServer.HostLoginName\n $existingjob = $server.Jobserver.Jobs|where-object {$_.Name -like $JobName}\n if ($existingjob)\n {\n Write-Host \"|- Dropping Job [$JobName]...\" -NoNewline\n $existingjob.drop()\n Write-Host \"|- Done\" -ForegroundColor Green\n }\n\n $job = New-Object Microsoft.SqlServer.Management.SMO.Agent.Job($server.JobServer, $jobName)\n #$job.DropIfExists() only for sqlserver 2016\n $job.Create()\n $job.OwnerLoginName = \"sa\"\n $job.Category = $JobCategory\n $job.ApplyToTargetServer($server.Name)\n\n\n }\n catch\n {\n write-host \"####### Error Adding a job\" -ForegroundColor Red\n write-host $_.Exception.Message\n }\n #Instead of creating a class and return a Job, lets settup a global variable. Return statament doenst return all script output\n $Global:newjob = $job\n\n}\n\nFunction Add-JobStep\n{\n <#\n .SYNOPSIS\n Add a job step to a Job\n\n .DESCRIPTION\n The function will remove an existing Job with same name (SQL SMO Job doesnt contains update function)\n and it will return as GlobalVariable t\n he JOb Object.\n .PARAMETER Job\n .PARAMETER JobStepName\n .PARAMETER JobStepCommand\n #>\n param($job, $JobStepName, $CommandJob )\n try\n {\n $jobStep = New-Object Microsoft.SqlServer.Management.Smo.Agent.JobStep($job, $JobStepName)\n $jobStep.Subsystem = [Microsoft.SqlServer.Management.Smo.Agent.AgentSubSystem]::SSIS\n\n $jobStep.Command = $CommandJob\n $jobStep.Create()\n }\n catch\n {\n write-host \"######### Error adding a job step\" -ForegroundColor Red\n write-host $_.Exception.Message\n }\n\n\n}\n\nFunction Add-JobSchedule\n{\n # ToDO: Add more types of frequenct: Weekly, Monthly\n param($job, $JobScheduleName,$JobExecutionFrequency, $FrecuencyInterval, $startHour, $startMinutes)\n try\n {\n $name = $job.Name\n $SQLJobSchedule = New-Object -TypeName Microsoft.SqlServer.Management.SMO.Agent.JobSchedule($job, $JobScheduleName)\n\n switch ($JobExecutionFrequency) {\n \"Daily\" {\n $result = [Microsoft.SqlServer.Management.SMO.Agent.FrequencyTypes]::Daily\n $subdayTypes = [Microsoft.SqlServer.Management.SMO.Agent.FrequencySubDayTypes]::Hour\n }\n \"OneTime\" {\n $result = [Microsoft.SqlServer.Management.SMO.Agent.FrequencyTypes]::OneTime\n $subdayTypes = [Microsoft.SqlServer.Management.SMO.Agent.FrequencySubDayTypes]::Once\n }\n \"AutoStart\" {\n $result = [Microsoft.SqlServer.Management.SMO.Agent.FrequencyTypes]::AutoStart\n }\n default {\n $result = [Microsoft.SqlServer.Management.SMO.Agent.FrequencyTypes]::Daily\n }\n }\n\n\n $SQLJobSchedule.FrequencyTypes = $result\n # Setup Frequency Interval\n $SQLJobSchedule.FrequencyInterval = $FrecuencyInterval\n\n\n\n # Job Start\n $timeofday = New-TimeSpan -hours $startHour -minutes $startMinutes\n $SQLJobSchedule.ActiveStartTimeOfDay = $timeofday\n #Activate the Job\n $SQLJobSchedule.ActiveStartDate = Get-Date\n $SQLJobSchedule.Create()\n }\n catch\n {\n Write-Host \"Error\" -ForegroundColor Red\n write-host \"Exception Type: $($_.Exception.GetType().FullName)\" -ForegroundColor Red\n write-host \"Exception Message: $($_.Exception.Message)\" -ForegroundColor Red\n $error[0]|format-list -force\n\n }\n\n}\n\nFunction Set-SQLJob\n{\n #Get-Octopus Variables\n Write-Host \"Collecting Octopus Variables\"\n\n $ServerName = Format-OctopusArgument -Value $OctopusParameters[\"SSIS_ServerName\"]\n $FolderName = Format-OctopusArgument -Value $OctopusParameters[\"SSIS_FolderName\"]\n $ProjectName = Format-OctopusArgument -Value $OctopusParameters[\"SSIS_ProjectName\"]\n $CatalogName = Format-OctopusArgument -Value $OctopusParameters[\"SSIS_CatalogName\"]\n $EnvironmentName = Format-OctopusArgument -Value $OctopusParameters[\"SSIS_EnvironmentName\"]\n $PackageName = Format-OctopusArgument -Value $OctopusParameters[\"SSIS_PackageName\"]\n $JobName = Format-OctopusArgument -Value $OctopusParameters[\"SSIS_JobName\"]\n $JobCategory = Format-OctopusArgument -Value $OctopusParameters[\"SSIS_JobCategory\"]\n $JobStepName = Format-OctopusArgument -Value $OctopusParameters[\"SSIS_JobStepName\"]\n $JobScheduleName = Format-OctopusArgument -Value $OctopusParameters[\"SSIS_JobScheduleName\"]\n $JobExecutionFrequency = Format-OctopusArgument -Value $OctopusParameters[\"SSIS_JobExecutionFrequency\"]\n $JobFrequencyInterval = Format-OctopusArgument -Value $OctopusParameters[\"SSIS_JobFrequencyInterval\"]\n $JobExecutionTimeHour = Format-OctopusArgument -Value $OctopusParameters[\"SSIS_JobExecutionTimeHour\"]\n $JobExecutionTimeMinute = Format-OctopusArgument -Value $OctopusParameters[\"SSIS_JobExecutionTimeMinute\"]\n\n\n # FrecuencyType is hardcoded\n\n #Getting Module sqlserver if possible.\n $Module = get-module -ListAvailable -name sqlserver\n if ($Module.Name -eq 'sqlserver') {\n write-host \"Importing Module SqlServer\"\n Import-Module sqlserver -DisableNameChecking\n } else {\n write-host \"Importing Module sqlps\"\n import-module sqlps -Verbose -DisableNameChecking\n }\n\n #First step is to generate the command execution for Job Step.\n $JobStepCommand = Get-SSISCommand -ServerName $ServerName -CatalogName $CatalogName -FolderName $FolderName -ProjectName $ProjectName -PackageName $PackageName -EnvironmentName $EnvironmentName -Verbose\n\n write-Host \"Command found to deploy Step is \"\n write-Host $JobStepCommand\n write-Host \"STARTING DEPLOYMENT \"\n write-Host \"|- Start Adding the Job $JobName\"\n Add-Job -JobName $JobName -ServerName $ServerName -EnvironmentName $EnvironmentName -JobsStepName $JobStepName -JobStepCommand $JobStepCommandmand\n write-Host \"|- $JobName Added to $ServerName\"\n\n write-Host \"|--- Start Adding the JobStep $JobStepName to Job $JobName\"\n Add-JobStep -JobStepName $JobStepName -CommandJob $JobStepCommand -Job $Global:newjob\n write-Host \"|--- $JobStepName added to Job $JobName\"\n\n write-Host \"|---- Start Adding JobShedule $JobScheduleName JobStep $JobName\"\n Add-JobSchedule -job $Global:newjob -JobScheduleName $JobScheduleName -JobExecutionFrequency $JobExecutionFrequency -FrecuencyInterval $JobFrequencyInterval -startHour $JobExecutionTimeHour -startMinutes $JobExecutionTimeMinute\n write-Host \"|---- $JobStepName added to Job $JobName\"\n}\n\nWrite-Host \"Starting deployment of SQL Job\"\n\n\nSet-SQLJob\n\n\nWrite-Host \"Finishing Install\"\n"
},
"Category": "SQL Server",
"HistoryUrl": "https://github.com/OctopusDeploy/Library/commits/master/step-templates//opt/buildagent/work/75443764cd38076d/step-templates/ssis-deploy-sqlagentjob.json",
"Website": "/step-templates/f69ea863-ab61-4c58-bcbe-a133450113c9",
"Logo": "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",
"$Meta": {
"Type": "ActionTemplate"
}
}
Page updated on Invalid Date