-
Notifications
You must be signed in to change notification settings - Fork 134
xMsiPackage
dscbot edited this page Nov 11, 2023
·
1 revision
Parameter | Attribute | DataType | Description | Allowed Values |
---|---|---|---|---|
ProductId | Key | String | The identifying number used to find the package, usually a GUID. | |
Path | Required | String | The path to the MSI file that should be installed or uninstalled. | |
Ensure | Write | String | Specifies whether or not the MSI file should be installed or uninstalled. |
Present , Absent
|
Arguments | Write | String | The arguments to be passed to the MSI package during installation or uninstallation. | |
Credential | Write | PSCredential | The credential of a user account to be used to mount a UNC path if needed. | |
LogPath | Write | String | The path to the log file to log the output from the MSI execution. | |
FileHash | Write | String | The expected hash value of the MSI file at the given path. | |
HashAlgorithm | Write | String | The algorithm used to generate the given hash value. |
SHA1 , SHA256 , SHA384 , SHA512 , MD5 , RIPEMD160
|
SignerSubject | Write | String | The subject that should match the signer certificate of the digital signature of the MSI file. | |
SignerThumbprint | Write | String | The certificate thumbprint that should match the signer certificate of the digital signature of the MSI file. | |
ServerCertificateValidationCallback | Write | String | PowerShell code that should be used to validate SSL certificates for paths using HTTPS. | |
IgnoreReboot | Write | Boolean | Ignore a pending reboot if requested by package installation. | |
RunAsCredential | Write | PSCredential | The credential of a user account under which to run the installation or uninstallation of the MSI package. | |
Name | Read | String | The display name of the MSI package. | |
InstallSource | Read | String | The path to the MSI package. | |
InstalledOn | Read | String | The date that the MSI package was installed on or serviced on, whichever is later. | |
Size | Read | UInt32 | The size of the MSI package in MB. | |
Version | Read | String | The version number of the MSI package. | |
PackageDescription | Read | String | The description of the MSI package. | |
Publisher | Read | String | The publisher of the MSI package. |
Provides a mechanism to install and uninstall .msi packages.
#Requires -Module xPSDesiredStateConfiguration
<#
.DESCRIPTION
Configuration that install an MSI file with the specified product
identification number.
.PARAMETER ProductId
The product identification number in the format
'{DEADBEEF-80C6-41E6-A1B9-8BDB8A05027F}'.
.PARAMETER Path
The URI path. Should start with an URI scheme, e.g. 'file://', 'http://',
'https://'.
.NOTES
When using the file scheme, the MSI file with the given product
identification number must already exist at the specified path.
When using the http or https scheme, the MSI file with the given product
identification number must already exist on the server.
The product ID and path value in this file are provided for example
purposes only and will need to be replaced with valid values.
You can run the following command to get a list of all available MSI's on
your system with the correct Path (LocalPackage) and product ID (IdentifyingNumber):
Get-WmiObject Win32_Product | Format-Table IdentifyingNumber, Name, LocalPackage
.EXAMPLE
xMsiPackage_InstallPackage_Config -ProductId '{DEADBEEF-80C6-41E6-A1B9-8BDB8A05027F}' -Path 'file://Examples/example.msi'
Compiles a configuration that installs the MSI package located at
the path 'file://Examples/example.msi' having the product identification
number as '{DEADBEEF-80C6-41E6-A1B9-8BDB8A05027F}'.
.EXAMPLE
xMsiPackage_InstallPackage_Config -ProductId '{DEADBEEF-80C6-41E6-A1B9-8BDB8A05027F}' -Path 'http://Examples/example.msi'
Compiles a configuration that installs the MSI package located at
the URL 'http://Examples/example.msi' having the product identification
number as '{DEADBEEF-80C6-41E6-A1B9-8BDB8A05027F}'.
#>
Configuration xMsiPackage_InstallPackage_Config
{
param
(
[Parameter(Mandatory = $true)]
[System.String]
$ProductId,
[Parameter(Mandatory = $true)]
[System.String]
$Path
)
Import-DscResource -ModuleName xPSDesiredStateConfiguration
Node localhost
{
xMsiPackage MsiPackage1
{
ProductId = $ProductId
Path = $Path
Ensure = 'Present'
}
}
}
#Requires -Module xPSDesiredStateConfiguration
<#
.DESCRIPTION
Uninstalls the MSI file with the product ID: '{DEADBEEF-80C6-41E6-A1B9-8BDB8A05027F}'
at the path: 'file://Examples/example.msi'.
.NOTES
The MSI file with the given product ID must already exist at the specified
path.
The product ID and path value in this file are provided for example
purposes only and will need to be replaced with valid values.
You can run the following command to get a list of all available MSI's
on your system with the correct Path (LocalPackage) and product ID
(IdentifyingNumber):
Get-WmiObject Win32_Product | Format-Table IdentifyingNumber, Name, LocalPackage
#>
Configuration xMsiPackage_UninstallPackageFromFile_Config
{
Import-DscResource -ModuleName xPSDesiredStateConfiguration
Node localhost
{
xMsiPackage UninstallMsiPackageFromFile
{
ProductId = '{DEADBEEF-80C6-41E6-A1B9-8BDB8A05027F}'
Path = 'file://Examples/example.msi'
Ensure = 'Absent'
}
}
}
#Requires -Module xPSDesiredStateConfiguration
<#
.DESCRIPTION
Uninstalls the MSI file with the product ID: '{DEADBEEF-80C6-41E6-A1B9-8BDB8A05027F}'
at the path: 'https://Examples/example.msi'.
.NOTES
The MSI file with the given product ID must already exist on
the server.
The product ID and path value in this file are provided for
example purposes only and will need to be replaced with valid values.
You can run the following command to get a list of all available MSI's
on your system with the correct Path (LocalPackage) and product ID
(IdentifyingNumber):
Get-WmiObject Win32_Product | Format-Table IdentifyingNumber, Name, LocalPackage
#>
Configuration xMsiPackage_UninstallPackageFromHttps_Config
{
Import-DscResource -ModuleName xPSDesiredStateConfiguration
Node localhost
{
xMsiPackage UninstallMsiPackageFromHttps
{
ProductId = '{DEADBEEF-80C6-41E6-A1B9-8BDB8A05027F}'
Path = 'https://Examples/example.msi'
Ensure = 'Absent'
}
}
}