mirror of
https://github.com/ansible-collections/community.general.git
synced 2025-07-02 14:40:19 -07:00
win_package: rewrite, check mode, tests, more check options (#27470)
* rewrite of win_package to enable win_msi deprecation * fix some minor doc issues * Removed exe tests * dag's changes seem to be missing, re-add them * fixed yaml for return values
This commit is contained in:
parent
91e2319806
commit
adabefd016
11 changed files with 1980 additions and 1450 deletions
|
@ -25,78 +25,135 @@ ANSIBLE_METADATA = {'metadata_version': '1.1',
|
|||
'status': ['preview'],
|
||||
'supported_by': 'core'}
|
||||
|
||||
|
||||
DOCUMENTATION = r'''
|
||||
---
|
||||
module: win_package
|
||||
version_added: "1.7"
|
||||
author: Trond Hindenes
|
||||
short_description: Installs/Uninstalls an installable package, either from local file system or url
|
||||
short_description: Installs/uninstalls an installable package
|
||||
description:
|
||||
- Installs or uninstalls a package.
|
||||
- >
|
||||
Use a product_id to check if the package needs installing. You can find product ids for installed programs in the windows registry
|
||||
either in C(HKLM:Software\Microsoft\Windows\CurrentVersion\Uninstall) or for 32 bit programs
|
||||
C(HKLM:Software\Wow6432Node\Microsoft\Windows\CurrentVersion\Uninstall)
|
||||
- For non-Windows targets, use the M(package) module instead.
|
||||
- Installs or uninstalls a package in either an MSI or EXE format.
|
||||
- These packages can be sources from the local file system, network file share
|
||||
or a url.
|
||||
- Please read the notes section around some caveats with this module.
|
||||
options:
|
||||
path:
|
||||
description:
|
||||
- Location of the package to be installed (either on file system, network share or url)
|
||||
required: true
|
||||
name:
|
||||
description:
|
||||
- Name of the package, if name isn't specified the path will be used for log messages
|
||||
required: false
|
||||
default: null
|
||||
product_id:
|
||||
description:
|
||||
- Product id of the installed package (used for checking if already installed)
|
||||
- >
|
||||
You can find product ids for installed programs in the windows registry either in C(HKLM:Software\Microsoft\Windows\CurrentVersion\Uninstall)
|
||||
or for 32 bit programs C(HKLM:Software\Wow6432Node\Microsoft\Windows\CurrentVersion\Uninstall)
|
||||
required: true
|
||||
aliases: [productid]
|
||||
arguments:
|
||||
description:
|
||||
- Any arguments the installer needs
|
||||
default: null
|
||||
required: false
|
||||
state:
|
||||
- Any arguments the installer needs to either install or uninstall the
|
||||
package.
|
||||
- If the package is an MSI do not supply the C(/qn), C(/log) or
|
||||
C(/norestart) arguments.
|
||||
creates_path:
|
||||
description:
|
||||
- Install or Uninstall
|
||||
choices:
|
||||
- present
|
||||
- absent
|
||||
default: present
|
||||
required: false
|
||||
aliases: [ensure]
|
||||
user_name:
|
||||
- Will check the existance of the path specified and use the result to
|
||||
determine whether the package is already installed.
|
||||
- You can use this in conjunction with C(product_id) and other C(creates_*).
|
||||
version_added: '2.4'
|
||||
creates_service:
|
||||
description:
|
||||
- Username of an account with access to the package if it's located on a file share. Only needed if the winrm user doesn't have access to the package.
|
||||
Also specify user_password for this to function properly.
|
||||
default: null
|
||||
required: false
|
||||
user_password:
|
||||
- Will check the existing of the service specified and use the result to
|
||||
determine whether the package is already installed.
|
||||
- You can use this in conjunction with C(product_id) and other C(creates_*).
|
||||
version_added: '2.4'
|
||||
creates_version:
|
||||
description:
|
||||
- Password of an account with access to the package if it's located on a file share. Only needed if the winrm user doesn't have access to the package.
|
||||
Also specify user_name for this to function properly.
|
||||
default: null
|
||||
required: false
|
||||
- Will check the file version property of the file at C(creates_path) and
|
||||
use the result to determine whether the package is already installed.
|
||||
- C(creates_path) MUST be set and is a file.
|
||||
- You can use this in conjunction with C(product_id) and other C(creates_*).
|
||||
version_added: '2.4'
|
||||
expected_return_code:
|
||||
description:
|
||||
- One or more return codes from the package installation that indicates success.
|
||||
- If not provided, defaults to 0
|
||||
required: no
|
||||
default: 0
|
||||
- One or more return codes from the package installation that indicates
|
||||
success.
|
||||
- Before Ansible 2.4 this was just 0 but since 2.4 this is both C(0) and
|
||||
C(3010).
|
||||
- A return code of C(3010) usually means that a reboot is required, the
|
||||
C(reboot_required) return value is set if the return code is C(3010).
|
||||
default: [0, 3010]
|
||||
name:
|
||||
description:
|
||||
- Name of the package, if name isn't specified the path will be used for
|
||||
log messages.
|
||||
- As of Ansible 2.4 this is deprecated and no longer required.
|
||||
password:
|
||||
description:
|
||||
- The password for C(user_name), must be set when C(user_name) is.
|
||||
aliases: [ user_password ]
|
||||
path:
|
||||
description:
|
||||
- Location of the package to be installed or uninstalled.
|
||||
- This package can either be on the local file system, network share or a
|
||||
url.
|
||||
- If the path is on a network share and the current WinRM transport doesn't
|
||||
support credential delegation, then C(user_name) and C(user_password)
|
||||
must be set to access the file.
|
||||
- There are cases where this file will be copied locally to the server so
|
||||
it can access it, see the notes for more info.
|
||||
- If C(state=present) then this value MUST be set.
|
||||
- If C(state=absent) then this value does not need to be set if
|
||||
C(product_id) is.
|
||||
product_id:
|
||||
description:
|
||||
- The product id of the installed packaged.
|
||||
- This is used for checking whether the product is already installed and
|
||||
getting the uninstall information if C(state=absent).
|
||||
- You can find product ids for installed programs in the Windows registry
|
||||
editor either at
|
||||
C(HKLM:Software\Microsoft\Windows\CurrentVersion\Uninstall) or for 32 bit
|
||||
programs at
|
||||
C(HKLM:Software\Wow6432Node\Microsoft\Windows\CurrentVersion\Uninstall).
|
||||
- This SHOULD be set when the package is not an MSI, or the path is a url
|
||||
or a network share and credential delegation is not being used. The
|
||||
C(creates_*) options can be used instead but is not recommended.
|
||||
aliases: [ productid ]
|
||||
state:
|
||||
description:
|
||||
- Whether to install or uninstall the package.
|
||||
- The module uses C(product_id) and whether it exists at the registry path
|
||||
to see whether it needs to install or uninstall the package.
|
||||
default: present
|
||||
aliases: [ ensure ]
|
||||
username:
|
||||
description:
|
||||
- Username of an account with access to the package if it is located on a
|
||||
file share.
|
||||
- This is only needed if the WinRM transport is over an auth method that
|
||||
does not support credential delegation like Basic or NTLM.
|
||||
aliases: [ user_name ]
|
||||
validate_certs:
|
||||
description:
|
||||
- If C(no), SSL certificates will not be validated. This should only be
|
||||
used on personally controlled sites using self-signed certificates.
|
||||
- Before Ansible 2.4 this defaulted to C(no).
|
||||
type: bool
|
||||
default: 'yes'
|
||||
version_added: '2.4'
|
||||
notes:
|
||||
- For non-Windows targets, use the M(package) module instead.
|
||||
- For non Windows targets, use the M(package) module instead.
|
||||
- When C(state=absent) and the product is an exe, the path may be different
|
||||
from what was used to install the package originally. If path is not set then
|
||||
the path used will be what is set under C(UninstallString) in the registry
|
||||
for that product_id.
|
||||
- Not all product ids are in a GUID form, some programs incorrectly use a
|
||||
different structure but this module should support any format.
|
||||
- By default all msi installs and uninstalls will be run with the options
|
||||
C(/log, /qn, /norestart).
|
||||
- It is recommended you download the pacakge first from the URL using the
|
||||
M(win_get_url) module as it opens up more flexibility with what must be set
|
||||
when calling C(win_package).
|
||||
- Packages will be temporarily downloaded or copied locally when path is a
|
||||
network location and credential delegation is not set, or path is a URL
|
||||
and the file is not an MSI.
|
||||
- All the installation checks under C(product_id) and C(creates_*) add
|
||||
together, if one fails then the program is considered to be absent.
|
||||
author:
|
||||
- Trond Hindenes (@trondhindenes)
|
||||
- Jordan Borean (@jborean93)
|
||||
'''
|
||||
|
||||
EXAMPLES = r'''
|
||||
- name: Install the Visual C thingy
|
||||
win_package:
|
||||
name: Microsoft Visual C thingy
|
||||
path: http://download.microsoft.com/download/1/6/B/16B06F60-3B20-4FF2-B699-5E9B7962F9AE/VSU_4/vcredist_x64.exe
|
||||
product_id: '{CF2BEA3C-26EA-32F8-AA9B-331F7E34BA97}'
|
||||
arguments: /install /passive /norestart
|
||||
|
@ -105,30 +162,98 @@ EXAMPLES = r'''
|
|||
win_package:
|
||||
path: https://download.microsoft.com/download/A/F/0/AF0071F3-B198-4A35-AA90-C68D103BDCCF/rdcman.msi
|
||||
product_id: '{0240359E-6A4C-4884-9E94-B397A02D893C}'
|
||||
state: present
|
||||
|
||||
- name: Uninstall Remote Desktop Connection Manager installed from msi
|
||||
- name: Uninstall Remote Desktop Connection Manager
|
||||
win_package:
|
||||
path: https://download.microsoft.com/download/A/F/0/AF0071F3-B198-4A35-AA90-C68D103BDCCF/rdcman.msi
|
||||
product_id: '{0240359E-6A4C-4884-9E94-B397A02D893C}'
|
||||
state: absent
|
||||
|
||||
# Specify the expected non-zero return code when successful
|
||||
# In this case 3010 indicates 'reboot required'
|
||||
- name: 'Microsoft .NET Framework 4.5.1'
|
||||
- name: Install Remote Desktop Connection Manager locally omitting the product_id
|
||||
win_package:
|
||||
path: https://download.microsoft.com/download/1/6/7/167F0D79-9317-48AE-AEDB-17120579F8E2/NDP451-KB2858728-x86-x64-AllOS-ENU.exe
|
||||
productid: '{7DEBE4EB-6B40-3766-BB35-5CBBC385DA37}'
|
||||
arguments: '/q /norestart'
|
||||
ensure: present
|
||||
expected_return_code: 3010
|
||||
path: C:\temp\rdcman.msi
|
||||
state: present
|
||||
|
||||
# Specify multiple non-zero return codes when successful
|
||||
# In this case we can say that both 0 (SUCCESSFUL) and 3010 (REBOOT REQUIRED) codes are acceptable
|
||||
- name: 'Microsoft .NET Framework 4.5.1'
|
||||
- name: Uninstall Remote Desktop Connection Manager from local MSI omitting the product_id
|
||||
win_package:
|
||||
path: C:\temp\rdcman.msi
|
||||
state: absent
|
||||
|
||||
# 7-Zip exe doesn't use a guid for the Product ID
|
||||
- name: Install 7zip from a network share specifying the credentials
|
||||
win_package:
|
||||
path: \\domain\programs\7z.exe
|
||||
product_id: 7-Zip
|
||||
arguments: /S
|
||||
state: present
|
||||
user_name: DOMAIN\User
|
||||
user_password: Password
|
||||
|
||||
- name: Install 7zip and use a file version for the installation check
|
||||
win_package:
|
||||
path: C:\temp\7z.exe
|
||||
creates_path: C:\Program Files\7-Zip\7z.exe
|
||||
creates_version: 16.04
|
||||
state: present
|
||||
|
||||
- name: Uninstall 7zip from the exe
|
||||
win_package:
|
||||
path: C:\Program Files\7-Zip\Uninstall.exe
|
||||
product_id: 7-Zip
|
||||
arguments: /S
|
||||
state: absent
|
||||
|
||||
- name: Uninstall 7zip without specifying the path
|
||||
win_package:
|
||||
product_id: 7-Zip
|
||||
arguments: /S
|
||||
state: absent
|
||||
|
||||
- name: Install application and override expected return codes
|
||||
win_package:
|
||||
path: https://download.microsoft.com/download/1/6/7/167F0D79-9317-48AE-AEDB-17120579F8E2/NDP451-KB2858728-x86-x64-AllOS-ENU.exe
|
||||
productid: '{7DEBE4EB-6B40-3766-BB35-5CBBC385DA37}'
|
||||
product_id: '{7DEBE4EB-6B40-3766-BB35-5CBBC385DA37}'
|
||||
arguments: '/q /norestart'
|
||||
ensure: present
|
||||
expected_return_code: [0,3010]
|
||||
state: present
|
||||
expected_return_code: [0, 666, 3010]
|
||||
'''
|
||||
|
||||
RETURN = r'''
|
||||
exit_code:
|
||||
description: See rc, this will be removed in favour of rc in Ansible 2.6.
|
||||
returned: change occured
|
||||
type: int
|
||||
sample: 0
|
||||
log:
|
||||
description: The contents of the MSI log.
|
||||
returned: change occured and package is an MSI
|
||||
type: str
|
||||
sample: Installation completed successfully
|
||||
rc:
|
||||
description: The return code of the pacakge process.
|
||||
returned: change occured
|
||||
type: int
|
||||
sample: 0
|
||||
reboot_required:
|
||||
description: Whether a reboot is required to finalise package. This is set
|
||||
to true if the executable return code is 3010.
|
||||
returned: always
|
||||
type: bool
|
||||
sample: True
|
||||
restart_required:
|
||||
description: See reboot_required, this will be removed in favour of
|
||||
reboot_required in Ansible 2.6
|
||||
returned: always
|
||||
type: bool
|
||||
sample: True
|
||||
stdout:
|
||||
description: The stdout stream of the package process.
|
||||
returned: failure during install or uninstall
|
||||
type: str
|
||||
sample: Installing program
|
||||
stderr:
|
||||
description: The stderr stream of the package process.
|
||||
returned: failure during install or uninstall
|
||||
type: str
|
||||
sample: Failed to install program
|
||||
'''
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue