Downloads:
32,847
Downloads of v 1.0.9-alpha2:
438
Last Update:
26 May 2015
Package Maintainer(s):
Software Author(s):
- SEEK Ltd.
Tags:
admin dsc- Software Specific:
- Software Site
- Software License
- Package Specific:
- Package outdated?
- Package broken?
- Contact Maintainers
- Contact Site Admins
- Software Vendor?
- Report Abuse
- Download
SEEK DSC Software
This is a prerelease version of SEEK DSC Software.
- 1
- 2
- 3
1.0.9-alpha2 | Updated: 26 May 2015
- Software Specific:
- Software Site
- Software License
- Package Specific:
- Package outdated?
- Package broken?
- Contact Maintainers
- Contact Site Admins
- Software Vendor?
- Report Abuse
- Download
Downloads:
32,847
Downloads of v 1.0.9-alpha2:
438
Maintainer(s):
Software Author(s):
- SEEK Ltd.
SEEK DSC Software 1.0.9-alpha2
This is a prerelease version of SEEK DSC Software.
Legal Disclaimer: Neither this package nor Chocolatey Software, Inc. are affiliated with or endorsed by SEEK Ltd. The inclusion of SEEK Ltd. trademark(s), if any, upon this webpage is solely to identify SEEK Ltd. goods or services and not for commercial purposes.
- 1
- 2
- 3
Some Checks Have Failed or Are Not Yet Complete
Not All Tests Have Passed
Validation Testing Unknown
Verification Testing Unknown
Scan Testing Successful:
No detections found in any package files
Deployment Method: Individual Install, Upgrade, & Uninstall
To install SEEK DSC Software, run the following command from the command line or from PowerShell:
To upgrade SEEK DSC Software, run the following command from the command line or from PowerShell:
To uninstall SEEK DSC Software, run the following command from the command line or from PowerShell:
Deployment Method:
This applies to both open source and commercial editions of Chocolatey.
1. Enter Your Internal Repository Url
(this should look similar to https://community.chocolatey.org/api/v2/)
2. Setup Your Environment
1. Ensure you are set for organizational deployment
Please see the organizational deployment guide
2. Get the package into your environment
Option 1: Cached Package (Unreliable, Requires Internet - Same As Community)-
Open Source or Commercial:
- Proxy Repository - Create a proxy nuget repository on Nexus, Artifactory Pro, or a proxy Chocolatey repository on ProGet. Point your upstream to https://community.chocolatey.org/api/v2/. Packages cache on first access automatically. Make sure your choco clients are using your proxy repository as a source and NOT the default community repository. See source command for more information.
- You can also just download the package and push it to a repository Download
-
Open Source
-
Download the package:
Download - Follow manual internalization instructions
-
-
Package Internalizer (C4B)
-
Run: (additional options)
choco download seek-dsc-software --internalize --version=1.0.9-alpha2 --pre --source=https://community.chocolatey.org/api/v2/
-
For package and dependencies run:
choco push --source="'INTERNAL REPO URL'"
- Automate package internalization
-
Run: (additional options)
3. Copy Your Script
choco upgrade seek-dsc-software -y --source="'INTERNAL REPO URL'" --version="'1.0.9-alpha2'" --prerelease [other options]
See options you can pass to upgrade.
See best practices for scripting.
Add this to a PowerShell script or use a Batch script with tools and in places where you are calling directly to Chocolatey. If you are integrating, keep in mind enhanced exit codes.
If you do use a PowerShell script, use the following to ensure bad exit codes are shown as failures:
choco upgrade seek-dsc-software -y --source="'INTERNAL REPO URL'" --version="'1.0.9-alpha2'" --prerelease
$exitCode = $LASTEXITCODE
Write-Verbose "Exit code was $exitCode"
$validExitCodes = @(0, 1605, 1614, 1641, 3010)
if ($validExitCodes -contains $exitCode) {
Exit 0
}
Exit $exitCode
- name: Install seek-dsc-software
win_chocolatey:
name: seek-dsc-software
version: '1.0.9-alpha2'
source: INTERNAL REPO URL
state: present
allow_prerelease: yes
See docs at https://docs.ansible.com/ansible/latest/modules/win_chocolatey_module.html.
chocolatey_package 'seek-dsc-software' do
action :install
source 'INTERNAL REPO URL'
version '1.0.9-alpha2'
options '--prerelease'
end
See docs at https://docs.chef.io/resource_chocolatey_package.html.
cChocoPackageInstaller seek-dsc-software
{
Name = "seek-dsc-software"
Version = "1.0.9-alpha2"
Source = "INTERNAL REPO URL"
chocoParams = "--prerelease"
}
Requires cChoco DSC Resource. See docs at https://github.com/chocolatey/cChoco.
package { 'seek-dsc-software':
ensure => '1.0.9-alpha2',
install_options => ['--prerelease'],
provider => 'chocolatey',
source => 'INTERNAL REPO URL',
}
Requires Puppet Chocolatey Provider module. See docs at https://forge.puppet.com/puppetlabs/chocolatey.
4. If applicable - Chocolatey configuration/installation
See infrastructure management matrix for Chocolatey configuration elements and examples.
This package was approved as a trusted package on 26 May 2015.
Custom DSC Resources for installing and uninstalling software packages and updates
data LocalizedData
{
# culture="en-US"
# TODO: Support WhatIf
ConvertFrom-StringData @'
InvalidIdentifyingNumber=The specified IdentifyingNumber ({0}) is not a valid Guid
InvalidPath=The specified Path ({0}) is not in a valid format. Valid formats are local paths, UNC, and HTTP
NeedsMoreInfo=Either Name or ProductId is required
InvalidBinaryType=The specified Path ({0}) does not appear to specify an EXE or MSI file and as such is not supported
CouldNotOpenLog=The specified LogPath ({0}) could not be opened
CouldNotStartProcess=The process {0} could not be started
UnexpectedReturnCode=The return code {0} was not expected. Configuration is likely not correct
PathDoesNotExist=The given Path ({0}) could not be found
CouldNotOpenDestFile=Could not open the file {0} for writing
CouldNotGetHttpStream=Could not get the HTTP stream for file {0}
ErrorCopyingDataToFile=Encountered error while writing the contents of {0} to {1}
PackageConfigurationComplete=Package configuration finished
PackageConfigurationStarting=Package configuration starting
InstalledPackage=Installed package
UninstalledPackage=Uninstalled package
NoChangeRequired=Package found in desired state, no action required
RemoveExistingLogFile=Remove existing log file
CreateLogFile=Create log file
MountSharePath=Mount share to get media
DownloadHTTPFile=Download the media over HTTP
StartingProcessMessage=Starting process {0} with arguments {1}
RemoveDownloadedFile=Remove the downloaded file
PackageInstalled=Package has been installed
PackageUninstalled=Package has been uninstalled
MachineRequiresReboot=The machine requires a reboot
PackageDoesNotAppearInstalled=The package {0} is not installed
PackageAppearsInstalled=The package {0} is already installed
PostValidationError=Package from {0} was installed, but the specified ProductId and/or Name does not match package details
'@
}
$Debug = $false
Function Trace-Message
{
param([string] $Message)
if($Debug)
{
Write-Verbose $Message
}
}
$CacheLocation = "$env:ProgramData\Microsoft\Windows\PowerShell\Configuration\BuiltinProvCache\MSFT_PackageResource"
Function Throw-InvalidArgumentException
{
param(
[string] $Message,
[string] $ParamName
)
$exception = new-object System.ArgumentException $Message,$ParamName
$errorRecord = New-Object System.Management.Automation.ErrorRecord $exception,$ParamName,"InvalidArgument",$null
throw $errorRecord
}
Function Throw-TerminatingError
{
param(
[string] $Message,
[System.Management.Automation.ErrorRecord] $ErrorRecord
)
$exception = new-object "System.InvalidOperationException" $Message,$ErrorRecord.Exception
$errorRecord = New-Object System.Management.Automation.ErrorRecord $exception,"MachineStateIncorrect","InvalidOperation",$null
throw $errorRecord
}
Function Validate-StandardArguments
{
param(
$Path,
$ProductId,
$Name
)
Trace-Message "Validate-StandardArguments, Path was $Path"
$uri = $null
try
{
$uri = [uri] $Path
}
catch
{
Throw-InvalidArgumentException ($LocalizedData.InvalidPath -f $Path) "Path"
}
if($uri.Scheme -ne "file" -and $uri.Scheme -ne "http")
{
Throw-InvalidArgumentException ($LocalizedData.InvalidPath -f $Path) "Path"
}
$pathExt = [System.IO.Path]::GetExtension($Path)
Trace-Message "The path extension was $pathExt"
if(-not @(".msi",".exe") -contains $pathExt.ToLower())
{
Throw-InvalidArgumentException ($LocalizedData.InvalidBinaryType -f $Path) "Path"
}
$identifyingNumber = $null
if(-not $Name -and -not $ProductId)
{
#It's a tossup here which argument to blame, so just pick ProductId to encourage customers to use the most efficient version
Throw-InvalidArgumentException ($LocalizedData.NeedsMoreInfo -f $Path) "ProductId"
}
elseif($ProductId)
{
try
{
Trace-Message "Parsing $ProductId as an identifyingNumber"
$identifyingNumber = "{{{0}}}" -f [Guid]::Parse($ProductId).ToString().ToUpper()
Trace-Message "Parsed $ProductId as $identifyingNumber"
}
catch
{
Throw-InvalidArgumentException ($LocalizedData.InvalidIdentifyingNumber -f $ProductId) $ProductId
}
}
return $uri, $identifyingNumber
}
Function Get-ProductEntry
{
param
(
[string] $Name,
[string] $IdentifyingNumber
)
$uninstallKey = "HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall"
$uninstallKeyWow64 = "HKLM:\SOFTWARE\Wow6432Node\Microsoft\Windows\CurrentVersion\Uninstall"
if($IdentifyingNumber)
{
$keyLocation = "$uninstallKey\$identifyingNumber"
$item = Get-Item $keyLocation -EA SilentlyContinue
if(-not $item)
{
$keyLocation = "$uninstallKeyWow64\$identifyingNumber"
$item = Get-Item $keyLocation -EA SilentlyContinue
}
return $item
}
foreach($item in (Get-ChildItem -EA Ignore $uninstallKey, $uninstallKeyWow64))
{
if($Name -eq (Get-LocalizableRegKeyValue $item "DisplayName"))
{
return $item
}
}
return $null
}
function Test-TargetResource
{
param
(
[ValidateSet("Present", "Absent")]
[string] $Ensure = "Present",
[parameter(Mandatory = $true)]
[AllowEmptyString()]
[string] $Name,
[parameter(Mandatory = $true)]
[ValidateNotNullOrEmpty()]
[string] $Path,
[parameter(Mandatory = $true)]
[AllowEmptyString()]
[string] $ProductId,
[string] $Arguments,
[pscredential] $Credential,
[int[]] $ReturnCode,
[string] $LogPath
)
$uri, $identifyingNumber = Validate-StandardArguments $Path $ProductId $Name
$product = Get-ProductEntry $Name $identifyingNumber
Trace-Message "Ensure is $Ensure"
Trace-Message "product is $product"
Trace-Message ("product as boolean is {0}" -f [boolean]$product)
$res = ($product -ne $null -and $Ensure -eq "Present") -or ($product -eq $null -and $Ensure -eq "Absent")
if ($product -ne $null)
{
$name = Get-LocalizableRegKeyValue $product "DisplayName"
Write-Verbose ($LocalizedData.PackageAppearsInstalled -f $name)
}
else
{
$displayName = $null
if($Name)
{
$displayName = $Name
}
else
{
$displayName = $ProductId
}
Write-Verbose ($LocalizedData.PackageDoesNotAppearInstalled -f $displayName)
}
return $res
}
function Get-LocalizableRegKeyValue
{
param(
[object] $RegKey,
[string] $ValueName
)
$res = $RegKey.GetValue("{0}_Localized" -f $ValueName)
if(-not $res)
{
$res = $RegKey.GetValue($ValueName)
}
return $res
}
function Get-TargetResource
{
param
(
[parameter(Mandatory = $true)]
[AllowEmptyString()]
[string] $Name,
[parameter(Mandatory = $true)]
[ValidateNotNullOrEmpty()]
[string] $Path,
[parameter(Mandatory = $true)]
[AllowEmptyString()]
[string] $ProductId
)
#If the user gave the ProductId then it was passed through to $identifyingNumber
$uri, $identifyingNumber = Validate-StandardArguments $Path $ProductId $Name
$localMsi = $uri.IsFile -and -not $uri.IsUnc
$product = Get-ProductEntry $Name $identifyingNumber
if(-not $product)
{
return @{
Ensure = "Absent"
Name = $Name
ProductId = $identifyingNumber
Installed = $false
}
}
#$identifyingNumber can still be null here (e.g. remote MSI with Name specified, local EXE)
#If the user gave a ProductId just pass it through, otherwise fill it from the product
if(-not $identifyingNumber)
{
$identifyingNumber = Split-Path -Leaf $product.Name
}
$date = $product.GetValue("InstallDate")
if($date)
{
try
{
$date = "{0:d}" -f [DateTime]::ParseExact($date, "yyyyMMdd",[System.Globalization.CultureInfo]::CurrentCulture).Date
}
catch
{
$date = $null
}
}
$publisher = Get-LocalizableRegKeyValue $product "Publisher"
$size = $product.GetValue("EstimatedSize")
if($size)
{
$size = $size/1024
}
$version = $product.GetValue("DisplayVersion")
$description = $product.GetValue("Comments")
$name = Get-LocalizableRegKeyValue $product "DisplayName"
return @{
Ensure = "Present"
Name = $name
Path = $Path
InstalledOn = $date
ProductId = $identifyingNumber
Size = $size
Installed = $true
Version = $version
PackageDescription = $description
Publisher = $publisher
}
}
function Set-TargetResource
{
[CmdletBinding(SupportsShouldProcess=$true)]
param
(
[ValidateSet("Present", "Absent")]
[string] $Ensure = "Present",
[parameter(Mandatory = $true)]
[AllowEmptyString()]
[string] $Name,
[parameter(Mandatory = $true)]
[ValidateNotNullOrEmpty()]
[string] $Path,
[parameter(Mandatory = $true)]
[AllowEmptyString()]
[string] $ProductId,
[string] $Arguments,
[pscredential] $Credential,
[int[]] $ReturnCode,
[string] $LogPath
)
$ErrorActionPreference = "Stop"
if((Test-TargetResource -Ensure $Ensure -Name $Name -Path $Path -ProductId $ProductId))
{
return
}
$uri, $identifyingNumber = Validate-StandardArguments $Path $ProductId $Name
#Path gets overwritten in the download code path. Retain the user's original Path in case the install succeeded
#but the named package wasn't present on the system afterward so we can give a better message
$OrigPath = $Path
Write-Verbose $LocalizedData.PackageConfigurationStarting
if(-not $ReturnCode)
{
$ReturnCode = @(0)
}
$logStream = $null
$psdrive = $null
$downloadedFileName = $null
try
{
$fileExtension = [System.IO.Path]::GetExtension($Path).ToLower()
if($LogPath)
{
try
{
if($fileExtension -eq ".msi")
{
#We want to pre-verify the path exists and is writable ahead of time
#even in the MSI case, as detecting WHY the MSI log doesn't exist would
#be rather problematic for the user
if((Test-Path $LogPath) -and $PSCmdlet.ShouldProcess($LocalizedData.RemoveExistingLogFile,$null,$null))
{
rm $LogPath
}
if($PSCmdlet.ShouldProcess($LocalizedData.CreateLogFile, $null, $null))
{
New-Item -Type File $LogPath | Out-Null
}
}
elseif($PSCmdlet.ShouldProcess($LocalizedData.CreateLogFile, $null, $null))
{
$logStream = new-object "System.IO.StreamWriter" $LogPath,$false
}
}
catch
{
Throw-TerminatingError ($LocalizedData.CouldNotOpenLog -f $LogPath) $_
}
}
#Download or mount file as necessary
if(-not ($fileExtension -eq ".msi" -and $Ensure -eq "Absent"))
{
if($uri.IsUnc -and $PSCmdlet.ShouldProcess($LocalizedData.MountSharePath, $null, $null))
{
$psdriveArgs = @{Name=([guid]::NewGuid());PSProvider="FileSystem";Root=(Split-Path $uri.LocalPath)}
if($Credential)
{
#We need to optionally include these and then splat the hash otherwise
#we pass a null for Credential which causes the cmdlet to pop a dialog up
$psdriveArgs["Credential"] = $Credential
}
$psdrive = New-PSDrive @psdriveArgs
$Path = Join-Path $psdrive.Root (Split-Path -Leaf $uri.LocalPath) #Necessary?
}
elseif($uri.Scheme -eq "http" -and $Ensure -eq "Present" -and $PSCmdlet.ShouldProcess($LocalizedData.DownloadHTTPFile, $null, $null))
{
if(-not (Test-Path -PathType Container $CacheLocation))
{
mkdir $CacheLocation | Out-Null
}
$destName = Join-Path $CacheLocation (Split-Path -Leaf $uri.LocalPath)
Trace-Message "Need to download file from HTTP, destination will be $destName"
Add-Type -AssemblyName System.Net.Http | Out-Null
$client = New-Object System.Net.Http.HttpClient
$outStream = $null
$httpStream = $null
try
{
try
{
Trace-Message "Going to create the destination file"
$outStream = New-Object System.IO.FileStream $destName, "Create"
Trace-Message "Created the destination file"
}
catch
{
#Should never happen since we own the cache directory
Throw-TerminatingError ($LocalizedData.CouldNotOpenDestFile -f $destName) $_
}
try
{
Trace-Message "Going to create the HTTP stream"
$task = $client.GetStreamAsync($uri)
$task.Wait()
$httpStream = $task.Result
Trace-Message "Got the HTTP stream"
}
catch
{
Trace-Message ("Error: " + ($_ | Out-String))
Throw-TerminatingError ($LocalizedData.CouldNotGetHttpStream -f $Path) $_
}
try
{
Trace-Message "Copying the HTTP stream to the disk"
$httpStream.CopyTo($outStream)
Trace-Message "Copied the HTTP stream to the disk"
}
catch
{
Throw-TerminatingError ($LocalizedData.ErrorCopyingDataToFile -f $Path,$destName) $_
}
}
finally
{
if($outStream)
{
$outStream.Dispose()
}
if($httpStream)
{
$httpStream.Dispose()
}
}
$Path = $downloadedFileName = $destName
}
}
#At this point the Path ought to be valid unless it's an MSI uninstall case
if(-not (Test-Path -PathType Leaf $Path) -and -not ($Ensure -eq "Absent" -and $fileExtension -eq ".msi"))
{
Throw-TerminatingError ($LocalizedData.PathDoesNotExist -f $Path)
}
$startInfo = New-Object System.Diagnostics.ProcessStartInfo
$startInfo.UseShellExecute = $false #Necessary for I/O redirection and just generally a good idea
$process = New-Object System.Diagnostics.Process
$process.StartInfo = $startInfo
$errLogPath = $LogPath + ".err" #Concept only, will never touch disk
if($fileExtension -eq ".msi")
{
$startInfo.FileName = "$env:windir\system32\msiexec.exe"
if($Ensure -eq "Present")
{
$startInfo.Arguments = '/i "{0}"' -f $Path
}
else
{
$product = Get-ProductEntry $Name $identifyingNumber
$id = Split-Path -Leaf $product.Name #We may have used the Name earlier, now we need the actual ID
$startInfo.Arguments = ("/x{0}" -f $id)
}
if($LogPath)
{
$startInfo.Arguments += ' /log "{0}"' -f $LogPath
}
$startInfo.Arguments += " /quiet"
if($Arguments)
{
$startInfo.Arguments += " " + $Arguments
}
}
else #EXE
{
Trace-Message "The binary is an EXE"
$startInfo.FileName = $Path
$startInfo.Arguments = $Arguments
if($LogPath)
{
Trace-Message "User has requested logging, need to attach event handlers to the process"
$startInfo.RedirectStandardError = $true
$startInfo.RedirectStandardOutput = $true
Register-ObjectEvent -InputObject $process -EventName "OutputDataReceived" -SourceIdentifier $LogPath
Register-ObjectEvent -InputObject $process -EventName "ErrorDataReceived" -SourceIdentifier $errLogPath
}
}
Trace-Message ("Starting {0} with {1}" -f $startInfo.FileName, $startInfo.Arguments)
if($PSCmdlet.ShouldProcess(($LocalizedData.StartingProcessMessage -f $startInfo.FileName, $startInfo.Arguments), $null, $null))
{
try
{
$process.Start() | Out-Null
}
catch
{
Throw-TerminatingError ($LocalizedData.CouldNotStartProcess -f $Path) $_
}
if($logStream) #Identical to $fileExtension -eq ".exe" -and $logPath
{
$process.BeginOutputReadLine();
$process.BeginErrorReadLine();
}
$process.WaitForExit()
if($logStream)
{
#We have to re-mux these since they appear to us as different streams
#The underlying Win32 APIs prevent this problem, as would constructing a script
#on the fly and executing it, but the former is highly problematic from PowerShell
#and the latter doesn't let us get the return code for UI-based EXEs
$outputEvents = Get-Event -SourceIdentifier $LogPath
$errorEvents = Get-Event -SourceIdentifier $errLogPath
$masterEvents = @() + $outputEvents + $errorEvents
$masterEvents = $masterEvents | Sort-Object -Property TimeGenerated
foreach($event in $masterEvents)
{
$logStream.Write($event.SourceEventArgs.Data);
}
Remove-Event -SourceIdentifier $LogPath
Remove-Event -SourceIdentifier $errLogPath
}
$exitCode = $process.ExitCode
if(-not ($ReturnCode -contains $exitCode))
{
Throw-TerminatingError ($LocalizedData.UnexpectedReturnCode -f $exitCode.ToString())
}
}
}
finally
{
if($psdrive)
{
Remove-PSDrive -Force $psdrive
}
if($logStream)
{
$logStream.Dispose()
}
}
if($downloadedFileName -and $PSCmdlet.ShouldProcess($LocalizedData.RemoveDownloadedFile, $null, $null))
{
#This is deliberately not in the Finally block. We want to leave the downloaded file on disk
#in the error case as a debugging aid for the user
rm $downloadedFileName
}
$operationString = $LocalizedData.PackageUninstalled
if($Ensure -eq "Present")
{
$operationString = $LocalizedData.PackageInstalled
}
if($Ensure -eq "Present")
{
#We can't do Test-TargetResource directly here because that would write spurious verbose entries
$productEntry = Get-ProductEntry $Name $identifyingNumber
if(-not $productEntry)
{
Throw-TerminatingError ($LocalizedData.PostValidationError -f $OrigPath)
}
}
Write-Verbose $operationString
Write-Verbose $LocalizedData.PackageConfigurationComplete
}
Export-ModuleMember -function Get-TargetResource, Set-TargetResource, Test-TargetResource
function Get-TargetResource
{
[CmdletBinding()]
[OutputType([System.Collections.Hashtable])]
param
(
[parameter(Mandatory = $true)]
[System.String]
$Update,
[parameter(Mandatory = $true)]
[System.String]
$Kb
)
if (Test-UpdateInstalled($Kb))
{
return @{Update = $Update; Kb = $Kb; Ensure = "Present"}
}
return @{Update = $Update; Kb = $Kb; Ensure = "Absent"}
}
function Set-TargetResource
{
[CmdletBinding()]
param
(
[parameter(Mandatory = $true)]
[System.String]
$Update,
[parameter(Mandatory = $true)]
[System.String]
$Kb,
[ValidateSet("Present","Absent")]
[System.String]
$Ensure = "Present"
)
$installed = Test-UpdateInstalled($Kb)
if(($Ensure -eq "Present") -and ($installed -eq $false))
{
Install-Update -Update $Update
}
elseif (($Ensure -eq "Absent") -and ($installed -eq $true))
{
Uninstall-Update -Update $Update
}
}
function Test-TargetResource
{
[CmdletBinding()]
[OutputType([System.Boolean])]
param
(
[parameter(Mandatory = $true)]
[System.String]
$Update,
[parameter(Mandatory = $true)]
[System.String]
$Kb,
[ValidateSet("Present","Absent")]
[System.String]
$Ensure = "Present"
)
$installed = Test-UpdateInstalled($Kb)
if ($Ensure -eq "Present")
{
return $installed
}
else
{
return !$installed
}
}
function Test-UpdateInstalled
{
[CmdletBinding()]
[OutputType([System.Boolean])]
param
(
[parameter(Mandatory = $true)]
[System.String]
$Kb
)
$installed = Get-HotFix | Select-Object HotFixID | Select-String -Pattern $Kb -SimpleMatch -Quiet
return ($installed -eq $true)
}
function Install-Update
{
[CmdletBinding()]
param
(
[parameter(Mandatory = $true)]
[System.String]
$Update
)
Invoke-WindowsUpdateStandaloneInstaller -Update $Update
}
function Uninstall-Update
{
[CmdletBinding()]
param
(
[parameter(Mandatory = $true)]
[System.String]
$Update
)
Invoke-WindowsUpdateStandaloneInstaller -Update $Update -Uninstall
}
function Invoke-WindowsUpdateStandaloneInstaller
{
[CmdletBinding()]
param
(
[parameter(Mandatory = $true)]
[System.String]
$Update,
[switch]
$Uninstall = $false
)
$updateFile = Get-UpdateFile -Update $Update
$updateArgs = @($updateFile, '/quiet', '/norestart')
if($Uninstall)
{
$updateArgs = ,'/uninstall' + $updateArgs
}
Start-Process "${env:WINDIR}\system32\wusa.exe" -ArgumentList $updateArgs -Wait
}
# Downloads the update file if necssary and returns path of local file
function Get-UpdateFile
{
[OutputType([System.String])]
[CmdletBinding()]
param
(
[parameter(Mandatory = $true)]
[System.String]
$Update
)
Write-Verbose "Update: ${Update}"
$uri = $Update -as [System.URI]
if(!$uri.IsFile)
{
# download remote file
$updateFile = Join-Path $env:TEMP $uri.Segments[-1]
Invoke-WebRequest $uri -OutFile $updateFile
return $updateFile
}
return $Update
}
Export-ModuleMember -Function *-TargetResource
try
{
$DSCResourcesRoot = Join-Path $env:ProgramFiles "WindowsPowerShell\Modules"
$DSCResourceTarget = Join-Path $env:chocolateyPackageFolder "lib"
Get-ChildItem $DSCResourceTarget | Foreach-Object { cmd /c rmdir "$DSCResourcesRoot\$_" }
} catch {
throw $_.Exception
}
Log in or click on link to see number of positives.
In cases where actual malware is found, the packages are subject to removal. Software sometimes has false positives. Moderators do not necessarily validate the safety of the underlying software, only that a package retrieves software from the official distribution point and/or validate embedded software against official distribution point (where distribution rights allow redistribution).
Chocolatey Pro provides runtime protection from possible malware.
Add to Builder | Version | Downloads | Last Updated | Status |
---|---|---|---|---|
SEEK DSC Software 2.0.0.20230301-alpha9 | 102 | Tuesday, January 3, 2023 | Exempted | |
SEEK DSC Software 2.0.0-alpha9 | 551 | Thursday, July 30, 2015 | Approved | |
SEEK DSC Software 2.0.0-alpha7 | 442 | Friday, May 1, 2015 | Approved | |
SEEK DSC Software 2.0.0-alpha6 | 435 | Wednesday, April 22, 2015 | Approved | |
SEEK DSC Software 2.0.0-alpha5 | 418 | Tuesday, April 21, 2015 | Approved | |
SEEK DSC Software 2.0.0-alpha4 | 490 | Tuesday, April 21, 2015 | Approved | |
SEEK DSC Software 2.0.0-alpha2 | 457 | Tuesday, February 24, 2015 | Approved | |
SEEK DSC Software 2.0.0-alpha1 | 453 | Monday, February 23, 2015 | Approved | |
SEEK DSC Software 1.0.10 | 1851 | Thursday, July 30, 2015 | Approved | |
SEEK DSC Software 1.0.9-alpha6 | 429 | Tuesday, June 9, 2015 | Approved | |
SEEK DSC Software 1.0.9-alpha5 | 461 | Tuesday, June 9, 2015 | Approved | |
SEEK DSC Software 1.0.9-alpha4 | 443 | Tuesday, June 9, 2015 | Approved | |
SEEK DSC Software 1.0.9-alpha3 | 412 | Tuesday, May 26, 2015 | Approved | |
SEEK DSC Software 1.0.9-alpha2 | 438 | Tuesday, May 26, 2015 | Approved | |
SEEK DSC Software 1.0.9-alpha1 | 447 | Friday, May 22, 2015 | Approved | |
SEEK DSC Software 1.0.4 | 492 | Friday, May 1, 2015 | Approved | |
SEEK DSC Software 1.0.3 | 446 | Wednesday, April 22, 2015 | Approved | |
SEEK DSC Software 1.0.2 | 416 | Tuesday, April 21, 2015 | Approved | |
SEEK DSC Software 1.0.0.87 | 630 | Sunday, February 22, 2015 | Approved | |
SEEK DSC Software 1.0.0.77 | 485 | Sunday, January 25, 2015 | Approved | |
SEEK DSC Software 1.0.0.76 | 416 | Wednesday, January 14, 2015 | Approved | |
SEEK DSC Software 1.0.0.75 | 666 | Tuesday, December 2, 2014 | Approved | |
SEEK DSC Software 1.0.0.74 | 510 | Sunday, November 9, 2014 | Approved | |
SEEK DSC Software 1.0.0.73 | 444 | Friday, November 7, 2014 | Approved | |
SEEK DSC Software 1.0.0.72 | 416 | Thursday, November 6, 2014 | Approved | |
SEEK DSC Software 1.0.0.71 | 431 | Thursday, November 6, 2014 | Approved | |
SEEK DSC Software 1.0.0.70 | 404 | Thursday, November 6, 2014 | Approved | |
SEEK DSC Software 1.0.0.69 | 434 | Monday, November 3, 2014 | Approved | |
SEEK DSC Software 1.0.0.68 | 414 | Monday, November 3, 2014 | Approved | |
SEEK DSC Software 1.0.0.67 | 422 | Monday, November 3, 2014 | Approved | |
SEEK DSC Software 1.0.0.64 | 442 | Thursday, October 30, 2014 | Approved | |
SEEK DSC Software 1.0.0.63 | 379 | Thursday, October 30, 2014 | Approved | |
SEEK DSC Software 1.0.0.62 | 454 | Monday, October 27, 2014 | Approved | |
SEEK DSC Software 1.0.0.61 | 419 | Friday, October 24, 2014 | Approved | |
SEEK DSC Software 1.0.0.60 | 439 | Friday, October 24, 2014 | Approved | |
SEEK DSC Software 1.0.0.59 | 451 | Friday, October 24, 2014 | Approved | |
SEEK DSC Software 1.0.0.58 | 391 | Friday, October 24, 2014 | Approved | |
SEEK DSC Software 1.0.0.55 | 472 | Friday, October 24, 2014 | Approved | |
SEEK DSC Software 1.0.0.54 | 472 | Wednesday, October 15, 2014 | Approved | |
SEEK DSC Software 1.0.0.53 | 442 | Wednesday, October 15, 2014 | Approved | |
SEEK DSC Software 1.0.0.52 | 381 | Wednesday, October 15, 2014 | Approved | |
SEEK DSC Software 1.0.0.51 | 433 | Wednesday, October 15, 2014 | Approved | |
SEEK DSC Software 1.0.0.50 | 401 | Sunday, October 12, 2014 | Approved | |
SEEK DSC Software 1.0.0.48 | 402 | Friday, October 10, 2014 | Approved | |
SEEK DSC Software 1.0.0.47 | 429 | Friday, October 10, 2014 | Approved | |
SEEK DSC Software 1.0.0.46 | 400 | Friday, October 10, 2014 | Approved | |
SEEK DSC Software 1.0.0.45 | 450 | Thursday, October 9, 2014 | Approved | |
SEEK DSC Software 1.0.0.43 | 416 | Wednesday, October 8, 2014 | Approved | |
SEEK DSC Software 1.0.0.42 | 379 | Wednesday, October 8, 2014 | Approved | |
SEEK DSC Software 1.0.0.41 | 415 | Thursday, October 2, 2014 | Approved | |
SEEK DSC Software 1.0.0.40 | 437 | Thursday, September 25, 2014 | Approved | |
SEEK DSC Software 1.0.0.39 | 398 | Thursday, September 25, 2014 | Approved | |
SEEK DSC Software 1.0.0.37 | 415 | Wednesday, September 24, 2014 | Approved | |
SEEK DSC Software 1.0.0.36 | 411 | Monday, September 22, 2014 | Approved | |
SEEK DSC Software 1.0.0.35 | 391 | Monday, September 15, 2014 | Approved | |
SEEK DSC Software 1.0.0.34 | 362 | Monday, September 15, 2014 | Approved | |
SEEK DSC Software 1.0.0.33 | 376 | Monday, September 15, 2014 | Approved | |
SEEK DSC Software 1.0.0.32 | 390 | Thursday, September 11, 2014 | Approved | |
SEEK DSC Software 1.0.0.31 | 365 | Wednesday, September 10, 2014 | Approved | |
SEEK DSC Software 1.0.0.30 | 383 | Wednesday, September 10, 2014 | Approved | |
SEEK DSC Software 1.0.0.29 | 347 | Wednesday, September 10, 2014 | Approved | |
SEEK DSC Software 1.0.0.28 | 391 | Tuesday, September 9, 2014 | Approved | |
SEEK DSC Software 1.0.0.27 | 418 | Tuesday, September 9, 2014 | Approved | |
SEEK DSC Software 1.0.0.20 | 376 | Tuesday, September 9, 2014 | Approved | |
SEEK DSC Software 1.0.0.19 | 401 | Tuesday, September 9, 2014 | Approved | |
SEEK DSC Software 1.0.0.18 | 359 | Tuesday, September 9, 2014 | Approved | |
SEEK DSC Software 1.0.0.17 | 388 | Tuesday, September 9, 2014 | Approved | |
SEEK DSC Software 1.0.0.13 | 430 | Friday, September 5, 2014 | Approved | |
SEEK DSC Software 1.0.0.11 | 403 | Friday, September 5, 2014 | Approved | |
SEEK DSC Software 1.0.0 | 390 | Tuesday, September 9, 2014 | Approved | |
SEEK DSC Software 0.0.0.1 | 375 | Tuesday, May 5, 2015 | Approved |
© SEEK 2015. All rights reserved.
This package has no dependencies.
Ground Rules:
- This discussion is only about SEEK DSC Software and the SEEK DSC Software package. If you have feedback for Chocolatey, please contact the Google Group.
- This discussion will carry over multiple versions. If you have a comment about a particular version, please note that in your comments.
- The maintainers of this Chocolatey Package will be notified about new comments that are posted to this Disqus thread, however, it is NOT a guarantee that you will get a response. If you do not hear back from the maintainers after posting a message below, please follow up by using the link on the left side of this page or follow this link to contact maintainers. If you still hear nothing back, please follow the package triage process.
- Tell us what you love about the package or SEEK DSC Software, or tell us what needs improvement.
- Share your experiences with the package, or extra configuration or gotchas that you've found.
- If you use a url, the comment will be flagged for moderation until you've been whitelisted. Disqus moderated comments are approved on a weekly schedule if not sooner. It could take between 1-5 days for your comment to show up.