Refactors main() function and module manager in multiple modules in line with recent changes (#53984)
Adds variable types to docs Refactors unit tests to remove deprecated parameters
This commit is contained in:
parent
ab238071e3
commit
9a007799d4
32 changed files with 627 additions and 465 deletions
|
@ -23,20 +23,24 @@ options:
|
||||||
name:
|
name:
|
||||||
description:
|
description:
|
||||||
- Specifies the name of the traffic selector.
|
- Specifies the name of the traffic selector.
|
||||||
|
type: str
|
||||||
required: True
|
required: True
|
||||||
destination_address:
|
destination_address:
|
||||||
description:
|
description:
|
||||||
- Specifies the host or network IP address to which the application traffic is destined.
|
- Specifies the host or network IP address to which the application traffic is destined.
|
||||||
- When creating a new traffic selector, this parameter is required.
|
- When creating a new traffic selector, this parameter is required.
|
||||||
|
type: str
|
||||||
source_address:
|
source_address:
|
||||||
description:
|
description:
|
||||||
- Specifies the host or network IP address from which the application traffic originates.
|
- Specifies the host or network IP address from which the application traffic originates.
|
||||||
- When creating a new traffic selector, this parameter is required.
|
- When creating a new traffic selector, this parameter is required.
|
||||||
|
type: str
|
||||||
ipsec_policy:
|
ipsec_policy:
|
||||||
description:
|
description:
|
||||||
- Specifies the IPsec policy that tells the BIG-IP system how to handle the packets.
|
- Specifies the IPsec policy that tells the BIG-IP system how to handle the packets.
|
||||||
- When creating a new traffic selector, if this parameter is not specified, the default
|
- When creating a new traffic selector, if this parameter is not specified, the default
|
||||||
is C(default-ipsec-policy).
|
is C(default-ipsec-policy).
|
||||||
|
type: str
|
||||||
order:
|
order:
|
||||||
description:
|
description:
|
||||||
- Specifies the order in which traffic is matched, if traffic can be matched to multiple
|
- Specifies the order in which traffic is matched, if traffic can be matched to multiple
|
||||||
|
@ -44,21 +48,25 @@ options:
|
||||||
- Traffic is matched to the traffic selector with the highest priority (lowest order number).
|
- Traffic is matched to the traffic selector with the highest priority (lowest order number).
|
||||||
- When creating a new traffic selector, if this parameter is not specified, the default
|
- When creating a new traffic selector, if this parameter is not specified, the default
|
||||||
is C(last).
|
is C(last).
|
||||||
|
type: int
|
||||||
description:
|
description:
|
||||||
description:
|
description:
|
||||||
- Description of the traffic selector.
|
- Description of the traffic selector.
|
||||||
|
type: str
|
||||||
partition:
|
partition:
|
||||||
description:
|
description:
|
||||||
- Device partition to manage resources on.
|
- Device partition to manage resources on.
|
||||||
|
type: str
|
||||||
default: Common
|
default: Common
|
||||||
state:
|
state:
|
||||||
description:
|
description:
|
||||||
- When C(present), ensures that the resource exists.
|
- When C(present), ensures that the resource exists.
|
||||||
- When C(absent), ensures the resource is removed.
|
- When C(absent), ensures the resource is removed.
|
||||||
default: present
|
type: str
|
||||||
choices:
|
choices:
|
||||||
- present
|
- present
|
||||||
- absent
|
- absent
|
||||||
|
default: present
|
||||||
extends_documentation_fragment: f5
|
extends_documentation_fragment: f5
|
||||||
author:
|
author:
|
||||||
- Tim Rupp (@caphrim007)
|
- Tim Rupp (@caphrim007)
|
||||||
|
@ -112,11 +120,8 @@ try:
|
||||||
from library.module_utils.network.f5.bigip import F5RestClient
|
from library.module_utils.network.f5.bigip import F5RestClient
|
||||||
from library.module_utils.network.f5.common import F5ModuleError
|
from library.module_utils.network.f5.common import F5ModuleError
|
||||||
from library.module_utils.network.f5.common import AnsibleF5Parameters
|
from library.module_utils.network.f5.common import AnsibleF5Parameters
|
||||||
from library.module_utils.network.f5.common import cleanup_tokens
|
|
||||||
from library.module_utils.network.f5.common import fq_name
|
from library.module_utils.network.f5.common import fq_name
|
||||||
from library.module_utils.network.f5.common import f5_argument_spec
|
from library.module_utils.network.f5.common import f5_argument_spec
|
||||||
from library.module_utils.network.f5.common import exit_json
|
|
||||||
from library.module_utils.network.f5.common import fail_json
|
|
||||||
from library.module_utils.network.f5.common import transform_name
|
from library.module_utils.network.f5.common import transform_name
|
||||||
from library.module_utils.compat.ipaddress import ip_interface
|
from library.module_utils.compat.ipaddress import ip_interface
|
||||||
from library.module_utils.network.f5.compare import cmp_str_with_none
|
from library.module_utils.network.f5.compare import cmp_str_with_none
|
||||||
|
@ -124,11 +129,8 @@ except ImportError:
|
||||||
from ansible.module_utils.network.f5.bigip import F5RestClient
|
from ansible.module_utils.network.f5.bigip import F5RestClient
|
||||||
from ansible.module_utils.network.f5.common import F5ModuleError
|
from ansible.module_utils.network.f5.common import F5ModuleError
|
||||||
from ansible.module_utils.network.f5.common import AnsibleF5Parameters
|
from ansible.module_utils.network.f5.common import AnsibleF5Parameters
|
||||||
from ansible.module_utils.network.f5.common import cleanup_tokens
|
|
||||||
from ansible.module_utils.network.f5.common import fq_name
|
from ansible.module_utils.network.f5.common import fq_name
|
||||||
from ansible.module_utils.network.f5.common import f5_argument_spec
|
from ansible.module_utils.network.f5.common import f5_argument_spec
|
||||||
from ansible.module_utils.network.f5.common import exit_json
|
|
||||||
from ansible.module_utils.network.f5.common import fail_json
|
|
||||||
from ansible.module_utils.network.f5.common import transform_name
|
from ansible.module_utils.network.f5.common import transform_name
|
||||||
from ansible.module_utils.compat.ipaddress import ip_interface
|
from ansible.module_utils.compat.ipaddress import ip_interface
|
||||||
from ansible.module_utils.network.f5.compare import cmp_str_with_none
|
from ansible.module_utils.network.f5.compare import cmp_str_with_none
|
||||||
|
@ -282,7 +284,7 @@ class Difference(object):
|
||||||
class ModuleManager(object):
|
class ModuleManager(object):
|
||||||
def __init__(self, *args, **kwargs):
|
def __init__(self, *args, **kwargs):
|
||||||
self.module = kwargs.get('module', None)
|
self.module = kwargs.get('module', None)
|
||||||
self.client = kwargs.get('client', None)
|
self.client = F5RestClient(**self.module.params)
|
||||||
self.want = ModuleParameters(params=self.module.params)
|
self.want = ModuleParameters(params=self.module.params)
|
||||||
self.have = ApiParameters()
|
self.have = ApiParameters()
|
||||||
self.changes = UsableChanges()
|
self.changes = UsableChanges()
|
||||||
|
@ -495,16 +497,12 @@ def main():
|
||||||
supports_check_mode=spec.supports_check_mode,
|
supports_check_mode=spec.supports_check_mode,
|
||||||
)
|
)
|
||||||
|
|
||||||
client = F5RestClient(**module.params)
|
|
||||||
|
|
||||||
try:
|
try:
|
||||||
mm = ModuleManager(module=module, client=client)
|
mm = ModuleManager(module=module)
|
||||||
results = mm.exec_module()
|
results = mm.exec_module()
|
||||||
cleanup_tokens(client)
|
module.exit_json(**results)
|
||||||
exit_json(module, results, client)
|
|
||||||
except F5ModuleError as ex:
|
except F5ModuleError as ex:
|
||||||
cleanup_tokens(client)
|
module.fail_json(msg=str(ex))
|
||||||
fail_json(module, ex, client)
|
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
|
|
|
@ -23,14 +23,17 @@ options:
|
||||||
name:
|
name:
|
||||||
description:
|
description:
|
||||||
- Specifies the name of the trunk.
|
- Specifies the name of the trunk.
|
||||||
|
type: str
|
||||||
required: True
|
required: True
|
||||||
interfaces:
|
interfaces:
|
||||||
description:
|
description:
|
||||||
- The interfaces that are part of the trunk.
|
- The interfaces that are part of the trunk.
|
||||||
- To clear the list of interfaces, specify an empty list.
|
- To clear the list of interfaces, specify an empty list.
|
||||||
|
type: list
|
||||||
description:
|
description:
|
||||||
description:
|
description:
|
||||||
- Description of the trunk.
|
- Description of the trunk.
|
||||||
|
type: str
|
||||||
version_added: 2.7
|
version_added: 2.7
|
||||||
link_selection_policy:
|
link_selection_policy:
|
||||||
description:
|
description:
|
||||||
|
@ -42,6 +45,7 @@ options:
|
||||||
same media type and speed.
|
same media type and speed.
|
||||||
- When C(maximum-bandwidth), specifies that the system determines which interfaces
|
- When C(maximum-bandwidth), specifies that the system determines which interfaces
|
||||||
can handle new traffic based on the members' maximum bandwidth.
|
can handle new traffic based on the members' maximum bandwidth.
|
||||||
|
type: str
|
||||||
choices:
|
choices:
|
||||||
- auto
|
- auto
|
||||||
- maximum-bandwidth
|
- maximum-bandwidth
|
||||||
|
@ -58,6 +62,7 @@ options:
|
||||||
address of the destination.
|
address of the destination.
|
||||||
- When C(source-destination-ip), specifies that the system bases the hash on the
|
- When C(source-destination-ip), specifies that the system bases the hash on the
|
||||||
combined IP addresses of the source and the destination.
|
combined IP addresses of the source and the destination.
|
||||||
|
type: str
|
||||||
choices:
|
choices:
|
||||||
- destination-mac
|
- destination-mac
|
||||||
- source-destination-ip
|
- source-destination-ip
|
||||||
|
@ -83,6 +88,7 @@ options:
|
||||||
regardless of whether the partner system has issued a request.
|
regardless of whether the partner system has issued a request.
|
||||||
- When C(passive), specifies that the system sends control packets only when
|
- When C(passive), specifies that the system sends control packets only when
|
||||||
the partner system has issued a request.
|
the partner system has issued a request.
|
||||||
|
type: str
|
||||||
choices:
|
choices:
|
||||||
- active
|
- active
|
||||||
- passive
|
- passive
|
||||||
|
@ -93,6 +99,7 @@ options:
|
||||||
C(long).
|
C(long).
|
||||||
- When C(long), specifies that the system sends an LACP control packet every 30 seconds.
|
- When C(long), specifies that the system sends an LACP control packet every 30 seconds.
|
||||||
- When C(short), specifies that the system sends an LACP control packet every 1 seconds.
|
- When C(short), specifies that the system sends an LACP control packet every 1 seconds.
|
||||||
|
type: str
|
||||||
choices:
|
choices:
|
||||||
- long
|
- long
|
||||||
- short
|
- short
|
||||||
|
@ -105,15 +112,17 @@ options:
|
||||||
- This parameter is not supported on Virtual Editions.
|
- This parameter is not supported on Virtual Editions.
|
||||||
- You should always wrap this value in quotes to prevent Ansible from interpreting
|
- You should always wrap this value in quotes to prevent Ansible from interpreting
|
||||||
the value as a literal hexadecimal number and converting it to an integer.
|
the value as a literal hexadecimal number and converting it to an integer.
|
||||||
|
type: raw
|
||||||
version_added: 2.7
|
version_added: 2.7
|
||||||
state:
|
state:
|
||||||
description:
|
description:
|
||||||
- When C(present), ensures that the resource exists.
|
- When C(present), ensures that the resource exists.
|
||||||
- When C(absent), ensures the resource is removed.
|
- When C(absent), ensures the resource is removed.
|
||||||
default: present
|
type: str
|
||||||
choices:
|
choices:
|
||||||
- present
|
- present
|
||||||
- absent
|
- absent
|
||||||
|
default: present
|
||||||
extends_documentation_fragment: f5
|
extends_documentation_fragment: f5
|
||||||
author:
|
author:
|
||||||
- Tim Rupp (@caphrim007)
|
- Tim Rupp (@caphrim007)
|
||||||
|
@ -190,18 +199,12 @@ try:
|
||||||
from library.module_utils.network.f5.bigip import F5RestClient
|
from library.module_utils.network.f5.bigip import F5RestClient
|
||||||
from library.module_utils.network.f5.common import F5ModuleError
|
from library.module_utils.network.f5.common import F5ModuleError
|
||||||
from library.module_utils.network.f5.common import AnsibleF5Parameters
|
from library.module_utils.network.f5.common import AnsibleF5Parameters
|
||||||
from library.module_utils.network.f5.common import cleanup_tokens
|
|
||||||
from library.module_utils.network.f5.common import exit_json
|
|
||||||
from library.module_utils.network.f5.common import fail_json
|
|
||||||
from library.module_utils.network.f5.common import f5_argument_spec
|
from library.module_utils.network.f5.common import f5_argument_spec
|
||||||
from library.module_utils.network.f5.compare import cmp_simple_list
|
from library.module_utils.network.f5.compare import cmp_simple_list
|
||||||
except ImportError:
|
except ImportError:
|
||||||
from ansible.module_utils.network.f5.bigip import F5RestClient
|
from ansible.module_utils.network.f5.bigip import F5RestClient
|
||||||
from ansible.module_utils.network.f5.common import F5ModuleError
|
from ansible.module_utils.network.f5.common import F5ModuleError
|
||||||
from ansible.module_utils.network.f5.common import AnsibleF5Parameters
|
from ansible.module_utils.network.f5.common import AnsibleF5Parameters
|
||||||
from ansible.module_utils.network.f5.common import cleanup_tokens
|
|
||||||
from ansible.module_utils.network.f5.common import exit_json
|
|
||||||
from ansible.module_utils.network.f5.common import fail_json
|
|
||||||
from ansible.module_utils.network.f5.common import f5_argument_spec
|
from ansible.module_utils.network.f5.common import f5_argument_spec
|
||||||
from ansible.module_utils.network.f5.compare import cmp_simple_list
|
from ansible.module_utils.network.f5.compare import cmp_simple_list
|
||||||
|
|
||||||
|
@ -365,7 +368,7 @@ class Difference(object):
|
||||||
class ModuleManager(object):
|
class ModuleManager(object):
|
||||||
def __init__(self, *args, **kwargs):
|
def __init__(self, *args, **kwargs):
|
||||||
self.module = kwargs.get('module', None)
|
self.module = kwargs.get('module', None)
|
||||||
self.client = kwargs.get('client', None)
|
self.client = F5RestClient(**self.module.params)
|
||||||
self.want = ModuleParameters(params=self.module.params)
|
self.want = ModuleParameters(params=self.module.params)
|
||||||
self.have = ApiParameters()
|
self.have = ApiParameters()
|
||||||
self.changes = UsableChanges()
|
self.changes = UsableChanges()
|
||||||
|
@ -590,16 +593,12 @@ def main():
|
||||||
supports_check_mode=spec.supports_check_mode
|
supports_check_mode=spec.supports_check_mode
|
||||||
)
|
)
|
||||||
|
|
||||||
client = F5RestClient(**module.params)
|
|
||||||
|
|
||||||
try:
|
try:
|
||||||
mm = ModuleManager(module=module, client=client)
|
mm = ModuleManager(module=module)
|
||||||
results = mm.exec_module()
|
results = mm.exec_module()
|
||||||
cleanup_tokens(client)
|
module.exit_json(**results)
|
||||||
exit_json(module, results, client)
|
|
||||||
except F5ModuleError as ex:
|
except F5ModuleError as ex:
|
||||||
cleanup_tokens(client)
|
module.fail_json(msg=str(ex))
|
||||||
fail_json(module, ex, client)
|
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
|
|
|
@ -30,15 +30,18 @@ options:
|
||||||
name:
|
name:
|
||||||
description:
|
description:
|
||||||
- Specifies the name of the tunnel.
|
- Specifies the name of the tunnel.
|
||||||
|
type: str
|
||||||
required: True
|
required: True
|
||||||
description:
|
description:
|
||||||
description:
|
description:
|
||||||
- Description of the tunnel.
|
- Description of the tunnel.
|
||||||
|
type: str
|
||||||
profile:
|
profile:
|
||||||
description:
|
description:
|
||||||
- Specifies the profile to associate with the tunnel for handling traffic.
|
- Specifies the profile to associate with the tunnel for handling traffic.
|
||||||
- Depending on your selection, other settings become available or disappear.
|
- Depending on your selection, other settings become available or disappear.
|
||||||
- This parameter may not be changed after it is set.
|
- This parameter may not be changed after it is set.
|
||||||
|
type: str
|
||||||
key:
|
key:
|
||||||
description:
|
description:
|
||||||
- When applied to a GRE tunnel, this value specifies an optional field in the GRE header,
|
- When applied to a GRE tunnel, this value specifies an optional field in the GRE header,
|
||||||
|
@ -48,24 +51,29 @@ options:
|
||||||
- When applied to an NVGRE tunnel, this value specifies the Virtual Subnet Identifier (VSID).
|
- When applied to an NVGRE tunnel, this value specifies the Virtual Subnet Identifier (VSID).
|
||||||
- When creating a new tunnel, if this parameter is supported by the tunnel profile but not
|
- When creating a new tunnel, if this parameter is supported by the tunnel profile but not
|
||||||
specified, the default value is C(0).
|
specified, the default value is C(0).
|
||||||
|
type: int
|
||||||
local_address:
|
local_address:
|
||||||
description:
|
description:
|
||||||
- Specifies the IP address of the local endpoint of the tunnel.
|
- Specifies the IP address of the local endpoint of the tunnel.
|
||||||
|
type: str
|
||||||
remote_address:
|
remote_address:
|
||||||
description:
|
description:
|
||||||
- Specifies the IP address of the remote endpoint of the tunnel.
|
- Specifies the IP address of the remote endpoint of the tunnel.
|
||||||
- For C(dslite), C(fec) (when configuring the FEC tunnel for receiving traffic only),
|
- For C(dslite), C(fec) (when configuring the FEC tunnel for receiving traffic only),
|
||||||
C(v6rd) (configured as a border relay), or C(map), the tunnel must have an unspecified
|
C(v6rd) (configured as a border relay), or C(map), the tunnel must have an unspecified
|
||||||
remote address (any).
|
remote address (any).
|
||||||
|
type: str
|
||||||
secondary_address:
|
secondary_address:
|
||||||
description:
|
description:
|
||||||
- Specifies a non-floating IP address for the tunnel, to be used with host-initiated traffic.
|
- Specifies a non-floating IP address for the tunnel, to be used with host-initiated traffic.
|
||||||
|
type: str
|
||||||
mtu:
|
mtu:
|
||||||
description:
|
description:
|
||||||
- Specifies the maximum transmission unit (MTU) of the tunnel.
|
- Specifies the maximum transmission unit (MTU) of the tunnel.
|
||||||
- When creating a new tunnel, if this parameter is supported by the tunnel profile but not
|
- When creating a new tunnel, if this parameter is supported by the tunnel profile but not
|
||||||
specified, the default value is C(0).
|
specified, the default value is C(0).
|
||||||
- The valid range is from C(0) to C(65515).
|
- The valid range is from C(0) to C(65515).
|
||||||
|
type: int
|
||||||
use_pmtu:
|
use_pmtu:
|
||||||
description:
|
description:
|
||||||
- Enables or disables the tunnel to use the PMTU (Path MTU) information provided by ICMP
|
- Enables or disables the tunnel to use the PMTU (Path MTU) information provided by ICMP
|
||||||
|
@ -84,6 +92,7 @@ options:
|
||||||
specified, the default value is C(preserve).
|
specified, the default value is C(preserve).
|
||||||
- When C(preserve), the system copies the TOS value from the inner header to the outer header.
|
- When C(preserve), the system copies the TOS value from the inner header to the outer header.
|
||||||
- You may also specify a numeric value. The possible values are from C(0) to C(255).
|
- You may also specify a numeric value. The possible values are from C(0) to C(255).
|
||||||
|
type: str
|
||||||
auto_last_hop:
|
auto_last_hop:
|
||||||
description:
|
description:
|
||||||
- Allows you to configure auto last hop on a per-tunnel basis.
|
- Allows you to configure auto last hop on a per-tunnel basis.
|
||||||
|
@ -94,6 +103,7 @@ options:
|
||||||
- When C(enabled), allows the system to send return traffic to the MAC address that transmitted
|
- When C(enabled), allows the system to send return traffic to the MAC address that transmitted
|
||||||
the request, even if the routing table points to a different network or interface. As a
|
the request, even if the routing table points to a different network or interface. As a
|
||||||
result, the system can send return traffic to clients even when there is no matching route.
|
result, the system can send return traffic to clients even when there is no matching route.
|
||||||
|
type: str
|
||||||
choices:
|
choices:
|
||||||
- default
|
- default
|
||||||
- enabled
|
- enabled
|
||||||
|
@ -102,6 +112,7 @@ options:
|
||||||
description:
|
description:
|
||||||
- Specifies the traffic group to associate with the tunnel.
|
- Specifies the traffic group to associate with the tunnel.
|
||||||
- This value cannot be changed after it is set. This is a limitation of BIG-IP.
|
- This value cannot be changed after it is set. This is a limitation of BIG-IP.
|
||||||
|
type: str
|
||||||
mode:
|
mode:
|
||||||
description:
|
description:
|
||||||
- Specifies how the tunnel carries traffic.
|
- Specifies how the tunnel carries traffic.
|
||||||
|
@ -110,6 +121,7 @@ options:
|
||||||
- When C(bidirectional), specifies that the tunnel carries both inbound and outbound traffic.
|
- When C(bidirectional), specifies that the tunnel carries both inbound and outbound traffic.
|
||||||
- When C(inbound), specifies that the tunnel carries only incoming traffic.
|
- When C(inbound), specifies that the tunnel carries only incoming traffic.
|
||||||
- When C(outbound), specifies that the tunnel carries only outgoing traffic.
|
- When C(outbound), specifies that the tunnel carries only outgoing traffic.
|
||||||
|
type: str
|
||||||
choices:
|
choices:
|
||||||
- bidirectional
|
- bidirectional
|
||||||
- inbound
|
- inbound
|
||||||
|
@ -126,15 +138,17 @@ options:
|
||||||
partition:
|
partition:
|
||||||
description:
|
description:
|
||||||
- Device partition to manage resources on.
|
- Device partition to manage resources on.
|
||||||
|
type: str
|
||||||
default: Common
|
default: Common
|
||||||
state:
|
state:
|
||||||
description:
|
description:
|
||||||
- When C(present), ensures that the tunnel exists.
|
- When C(present), ensures that the tunnel exists.
|
||||||
- When C(absent), ensures the tunnel is removed.
|
- When C(absent), ensures the tunnel is removed.
|
||||||
default: present
|
type: str
|
||||||
choices:
|
choices:
|
||||||
- present
|
- present
|
||||||
- absent
|
- absent
|
||||||
|
default: present
|
||||||
extends_documentation_fragment: f5
|
extends_documentation_fragment: f5
|
||||||
author:
|
author:
|
||||||
- Tim Rupp (@caphrim007)
|
- Tim Rupp (@caphrim007)
|
||||||
|
@ -180,22 +194,16 @@ try:
|
||||||
from library.module_utils.network.f5.bigip import F5RestClient
|
from library.module_utils.network.f5.bigip import F5RestClient
|
||||||
from library.module_utils.network.f5.common import F5ModuleError
|
from library.module_utils.network.f5.common import F5ModuleError
|
||||||
from library.module_utils.network.f5.common import AnsibleF5Parameters
|
from library.module_utils.network.f5.common import AnsibleF5Parameters
|
||||||
from library.module_utils.network.f5.common import cleanup_tokens
|
|
||||||
from library.module_utils.network.f5.common import fq_name
|
from library.module_utils.network.f5.common import fq_name
|
||||||
from library.module_utils.network.f5.common import f5_argument_spec
|
from library.module_utils.network.f5.common import f5_argument_spec
|
||||||
from library.module_utils.network.f5.common import exit_json
|
|
||||||
from library.module_utils.network.f5.common import fail_json
|
|
||||||
from library.module_utils.network.f5.common import flatten_boolean
|
from library.module_utils.network.f5.common import flatten_boolean
|
||||||
from library.module_utils.network.f5.common import transform_name
|
from library.module_utils.network.f5.common import transform_name
|
||||||
except ImportError:
|
except ImportError:
|
||||||
from ansible.module_utils.network.f5.bigip import F5RestClient
|
from ansible.module_utils.network.f5.bigip import F5RestClient
|
||||||
from ansible.module_utils.network.f5.common import F5ModuleError
|
from ansible.module_utils.network.f5.common import F5ModuleError
|
||||||
from ansible.module_utils.network.f5.common import AnsibleF5Parameters
|
from ansible.module_utils.network.f5.common import AnsibleF5Parameters
|
||||||
from ansible.module_utils.network.f5.common import cleanup_tokens
|
|
||||||
from ansible.module_utils.network.f5.common import fq_name
|
from ansible.module_utils.network.f5.common import fq_name
|
||||||
from ansible.module_utils.network.f5.common import f5_argument_spec
|
from ansible.module_utils.network.f5.common import f5_argument_spec
|
||||||
from ansible.module_utils.network.f5.common import exit_json
|
|
||||||
from ansible.module_utils.network.f5.common import fail_json
|
|
||||||
from ansible.module_utils.network.f5.common import flatten_boolean
|
from ansible.module_utils.network.f5.common import flatten_boolean
|
||||||
from ansible.module_utils.network.f5.common import transform_name
|
from ansible.module_utils.network.f5.common import transform_name
|
||||||
|
|
||||||
|
@ -368,7 +376,7 @@ class Difference(object):
|
||||||
class ModuleManager(object):
|
class ModuleManager(object):
|
||||||
def __init__(self, *args, **kwargs):
|
def __init__(self, *args, **kwargs):
|
||||||
self.module = kwargs.get('module', None)
|
self.module = kwargs.get('module', None)
|
||||||
self.client = kwargs.get('client', None)
|
self.client = F5RestClient(**self.module.params)
|
||||||
self.want = ModuleParameters(params=self.module.params)
|
self.want = ModuleParameters(params=self.module.params)
|
||||||
self.have = ApiParameters()
|
self.have = ApiParameters()
|
||||||
self.changes = UsableChanges()
|
self.changes = UsableChanges()
|
||||||
|
@ -599,16 +607,12 @@ def main():
|
||||||
supports_check_mode=spec.supports_check_mode,
|
supports_check_mode=spec.supports_check_mode,
|
||||||
)
|
)
|
||||||
|
|
||||||
client = F5RestClient(**module.params)
|
|
||||||
|
|
||||||
try:
|
try:
|
||||||
mm = ModuleManager(module=module, client=client)
|
mm = ModuleManager(module=module)
|
||||||
results = mm.exec_module()
|
results = mm.exec_module()
|
||||||
cleanup_tokens(client)
|
module.exit_json(**results)
|
||||||
exit_json(module, results, client)
|
|
||||||
except F5ModuleError as ex:
|
except F5ModuleError as ex:
|
||||||
cleanup_tokens(client)
|
module.fail_json(msg=str(ex))
|
||||||
fail_json(module, ex, client)
|
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
|
|
|
@ -34,6 +34,7 @@ options:
|
||||||
ignored and only the filename will be used to select a UCS for removal.
|
ignored and only the filename will be used to select a UCS for removal.
|
||||||
Therefore you could specify C(/mickey/mouse/test.ucs) and this module
|
Therefore you could specify C(/mickey/mouse/test.ucs) and this module
|
||||||
would only look for C(test.ucs).
|
would only look for C(test.ucs).
|
||||||
|
type: str
|
||||||
force:
|
force:
|
||||||
description:
|
description:
|
||||||
- If C(yes) will upload the file every time and replace the file on the
|
- If C(yes) will upload the file every time and replace the file on the
|
||||||
|
@ -70,11 +71,12 @@ options:
|
||||||
When C(absent), the UCS will be removed from the system. When
|
When C(absent), the UCS will be removed from the system. When
|
||||||
C(installed), the uploading of the UCS is idempotent, however the
|
C(installed), the uploading of the UCS is idempotent, however the
|
||||||
installation of that configuration is not idempotent.
|
installation of that configuration is not idempotent.
|
||||||
default: present
|
type: str
|
||||||
choices:
|
choices:
|
||||||
- absent
|
- absent
|
||||||
- installed
|
- installed
|
||||||
- present
|
- present
|
||||||
|
default: present
|
||||||
notes:
|
notes:
|
||||||
- Only the most basic checks are performed by this module. Other checks and
|
- Only the most basic checks are performed by this module. Other checks and
|
||||||
considerations need to be taken into account. See the following URL.
|
considerations need to be taken into account. See the following URL.
|
||||||
|
@ -184,20 +186,14 @@ try:
|
||||||
from library.module_utils.network.f5.bigip import F5RestClient
|
from library.module_utils.network.f5.bigip import F5RestClient
|
||||||
from library.module_utils.network.f5.common import F5ModuleError
|
from library.module_utils.network.f5.common import F5ModuleError
|
||||||
from library.module_utils.network.f5.common import AnsibleF5Parameters
|
from library.module_utils.network.f5.common import AnsibleF5Parameters
|
||||||
from library.module_utils.network.f5.common import cleanup_tokens
|
|
||||||
from library.module_utils.network.f5.common import f5_argument_spec
|
from library.module_utils.network.f5.common import f5_argument_spec
|
||||||
from library.module_utils.network.f5.common import exit_json
|
|
||||||
from library.module_utils.network.f5.common import fail_json
|
|
||||||
from library.module_utils.network.f5.icontrol import tmos_version
|
from library.module_utils.network.f5.icontrol import tmos_version
|
||||||
from library.module_utils.network.f5.icontrol import upload_file
|
from library.module_utils.network.f5.icontrol import upload_file
|
||||||
except ImportError:
|
except ImportError:
|
||||||
from ansible.module_utils.network.f5.bigip import F5RestClient
|
from ansible.module_utils.network.f5.bigip import F5RestClient
|
||||||
from ansible.module_utils.network.f5.common import F5ModuleError
|
from ansible.module_utils.network.f5.common import F5ModuleError
|
||||||
from ansible.module_utils.network.f5.common import AnsibleF5Parameters
|
from ansible.module_utils.network.f5.common import AnsibleF5Parameters
|
||||||
from ansible.module_utils.network.f5.common import cleanup_tokens
|
|
||||||
from ansible.module_utils.network.f5.common import f5_argument_spec
|
from ansible.module_utils.network.f5.common import f5_argument_spec
|
||||||
from ansible.module_utils.network.f5.common import exit_json
|
|
||||||
from ansible.module_utils.network.f5.common import fail_json
|
|
||||||
from ansible.module_utils.network.f5.icontrol import tmos_version
|
from ansible.module_utils.network.f5.icontrol import tmos_version
|
||||||
from ansible.module_utils.network.f5.icontrol import upload_file
|
from ansible.module_utils.network.f5.icontrol import upload_file
|
||||||
|
|
||||||
|
@ -306,8 +302,9 @@ class UsableChanges(Changes):
|
||||||
|
|
||||||
class ModuleManager(object):
|
class ModuleManager(object):
|
||||||
def __init__(self, *args, **kwargs):
|
def __init__(self, *args, **kwargs):
|
||||||
self.client = kwargs.get('client', None)
|
|
||||||
self.kwargs = kwargs
|
self.kwargs = kwargs
|
||||||
|
self.module = kwargs.get('module', None)
|
||||||
|
self.client = F5RestClient(**self.module.params)
|
||||||
|
|
||||||
def exec_module(self):
|
def exec_module(self):
|
||||||
if self.is_version_v1():
|
if self.is_version_v1():
|
||||||
|
@ -341,7 +338,7 @@ class Difference(object):
|
||||||
class BaseManager(object):
|
class BaseManager(object):
|
||||||
def __init__(self, *args, **kwargs):
|
def __init__(self, *args, **kwargs):
|
||||||
self.module = kwargs.get('module', None)
|
self.module = kwargs.get('module', None)
|
||||||
self.client = kwargs.get('client', None)
|
self.client = F5RestClient(**self.module.params)
|
||||||
self.want = ModuleParameters(params=self.module.params)
|
self.want = ModuleParameters(params=self.module.params)
|
||||||
self.changes = UsableChanges()
|
self.changes = UsableChanges()
|
||||||
|
|
||||||
|
@ -709,16 +706,12 @@ def main():
|
||||||
supports_check_mode=spec.supports_check_mode
|
supports_check_mode=spec.supports_check_mode
|
||||||
)
|
)
|
||||||
|
|
||||||
client = F5RestClient(**module.params)
|
|
||||||
|
|
||||||
try:
|
try:
|
||||||
mm = ModuleManager(module=module, client=client)
|
mm = ModuleManager(module=module)
|
||||||
results = mm.exec_module()
|
results = mm.exec_module()
|
||||||
cleanup_tokens(client)
|
module.exit_json(**results)
|
||||||
exit_json(module, results, client)
|
|
||||||
except F5ModuleError as ex:
|
except F5ModuleError as ex:
|
||||||
cleanup_tokens(client)
|
module.fail_json(msg=str(ex))
|
||||||
fail_json(module, ex, client)
|
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
|
|
|
@ -28,35 +28,38 @@ options:
|
||||||
description:
|
description:
|
||||||
- Create a backup file including the timestamp information so you can
|
- Create a backup file including the timestamp information so you can
|
||||||
get the original file back if you somehow clobbered it incorrectly.
|
get the original file back if you somehow clobbered it incorrectly.
|
||||||
default: no
|
|
||||||
type: bool
|
type: bool
|
||||||
|
default: no
|
||||||
create_on_missing:
|
create_on_missing:
|
||||||
description:
|
description:
|
||||||
- Creates the UCS based on the value of C(src) if the file does not already
|
- Creates the UCS based on the value of C(src) if the file does not already
|
||||||
exist on the remote system.
|
exist on the remote system.
|
||||||
default: yes
|
|
||||||
type: bool
|
type: bool
|
||||||
|
default: yes
|
||||||
dest:
|
dest:
|
||||||
description:
|
description:
|
||||||
- A directory to save the UCS file into.
|
- A directory to save the UCS file into.
|
||||||
required: yes
|
type: path
|
||||||
|
required: True
|
||||||
encryption_password:
|
encryption_password:
|
||||||
description:
|
description:
|
||||||
- Password to use to encrypt the UCS file if desired
|
- Password to use to encrypt the UCS file if desired.
|
||||||
|
type: str
|
||||||
fail_on_missing:
|
fail_on_missing:
|
||||||
description:
|
description:
|
||||||
- Make the module fail if the UCS file on the remote system is missing.
|
- Make the module fail if the UCS file on the remote system is missing.
|
||||||
default: no
|
|
||||||
type: bool
|
type: bool
|
||||||
|
default: no
|
||||||
force:
|
force:
|
||||||
description:
|
description:
|
||||||
- If C(no), the file will only be transferred if the destination does not
|
- If C(no), the file will only be transferred if the destination does not
|
||||||
exist.
|
exist.
|
||||||
default: yes
|
|
||||||
type: bool
|
type: bool
|
||||||
|
default: yes
|
||||||
src:
|
src:
|
||||||
description:
|
description:
|
||||||
- The name of the UCS file to create on the remote server for downloading
|
- The name of the UCS file to create on the remote server for downloading
|
||||||
|
type: str
|
||||||
notes:
|
notes:
|
||||||
- BIG-IP provides no way to get a checksum of the UCS files on the system
|
- BIG-IP provides no way to get a checksum of the UCS files on the system
|
||||||
via any interface except, perhaps, logging in directly to the box (which
|
via any interface except, perhaps, logging in directly to the box (which
|
||||||
|
@ -64,7 +67,7 @@ notes:
|
||||||
do is check for the existence of the file on disk; no check-summing.
|
do is check for the existence of the file on disk; no check-summing.
|
||||||
- If you are using this module with either Ansible Tower or Ansible AWX, you
|
- If you are using this module with either Ansible Tower or Ansible AWX, you
|
||||||
should be aware of how these Ansible products execute jobs in restricted
|
should be aware of how these Ansible products execute jobs in restricted
|
||||||
environments. More informat can be found here
|
environments. More information can be found here
|
||||||
https://clouddocs.f5.com/products/orchestration/ansible/devel/usage/module-usage-with-tower.html
|
https://clouddocs.f5.com/products/orchestration/ansible/devel/usage/module-usage-with-tower.html
|
||||||
extends_documentation_fragment: f5
|
extends_documentation_fragment: f5
|
||||||
author:
|
author:
|
||||||
|
@ -155,10 +158,7 @@ try:
|
||||||
from library.module_utils.network.f5.bigip import F5RestClient
|
from library.module_utils.network.f5.bigip import F5RestClient
|
||||||
from library.module_utils.network.f5.common import F5ModuleError
|
from library.module_utils.network.f5.common import F5ModuleError
|
||||||
from library.module_utils.network.f5.common import AnsibleF5Parameters
|
from library.module_utils.network.f5.common import AnsibleF5Parameters
|
||||||
from library.module_utils.network.f5.common import cleanup_tokens
|
|
||||||
from library.module_utils.network.f5.common import f5_argument_spec
|
from library.module_utils.network.f5.common import f5_argument_spec
|
||||||
from library.module_utils.network.f5.common import exit_json
|
|
||||||
from library.module_utils.network.f5.common import fail_json
|
|
||||||
from library.module_utils.network.f5.common import transform_name
|
from library.module_utils.network.f5.common import transform_name
|
||||||
from library.module_utils.network.f5.icontrol import download_file
|
from library.module_utils.network.f5.icontrol import download_file
|
||||||
from library.module_utils.network.f5.icontrol import tmos_version
|
from library.module_utils.network.f5.icontrol import tmos_version
|
||||||
|
@ -166,10 +166,7 @@ except ImportError:
|
||||||
from ansible.module_utils.network.f5.bigip import F5RestClient
|
from ansible.module_utils.network.f5.bigip import F5RestClient
|
||||||
from ansible.module_utils.network.f5.common import F5ModuleError
|
from ansible.module_utils.network.f5.common import F5ModuleError
|
||||||
from ansible.module_utils.network.f5.common import AnsibleF5Parameters
|
from ansible.module_utils.network.f5.common import AnsibleF5Parameters
|
||||||
from ansible.module_utils.network.f5.common import cleanup_tokens
|
|
||||||
from ansible.module_utils.network.f5.common import f5_argument_spec
|
from ansible.module_utils.network.f5.common import f5_argument_spec
|
||||||
from ansible.module_utils.network.f5.common import exit_json
|
|
||||||
from ansible.module_utils.network.f5.common import fail_json
|
|
||||||
from ansible.module_utils.network.f5.common import transform_name
|
from ansible.module_utils.network.f5.common import transform_name
|
||||||
from ansible.module_utils.network.f5.icontrol import download_file
|
from ansible.module_utils.network.f5.icontrol import download_file
|
||||||
from ansible.module_utils.network.f5.icontrol import tmos_version
|
from ansible.module_utils.network.f5.icontrol import tmos_version
|
||||||
|
@ -256,8 +253,9 @@ class ReportableChanges(Changes):
|
||||||
|
|
||||||
class ModuleManager(object):
|
class ModuleManager(object):
|
||||||
def __init__(self, *args, **kwargs):
|
def __init__(self, *args, **kwargs):
|
||||||
self.client = kwargs.get('client', None)
|
|
||||||
self.kwargs = kwargs
|
self.kwargs = kwargs
|
||||||
|
self.module = kwargs.get('module', None)
|
||||||
|
self.client = F5RestClient(**self.module.params)
|
||||||
|
|
||||||
def exec_module(self):
|
def exec_module(self):
|
||||||
if self.is_version_v1():
|
if self.is_version_v1():
|
||||||
|
@ -292,7 +290,7 @@ class ModuleManager(object):
|
||||||
class BaseManager(object):
|
class BaseManager(object):
|
||||||
def __init__(self, *args, **kwargs):
|
def __init__(self, *args, **kwargs):
|
||||||
self.module = kwargs.get('module', None)
|
self.module = kwargs.get('module', None)
|
||||||
self.client = kwargs.get('client', None)
|
self.client = F5RestClient(**self.module.params)
|
||||||
self.want = Parameters(params=self.module.params)
|
self.want = Parameters(params=self.module.params)
|
||||||
self.changes = UsableChanges()
|
self.changes = UsableChanges()
|
||||||
|
|
||||||
|
@ -602,16 +600,12 @@ def main():
|
||||||
add_file_common_args=spec.add_file_common_args
|
add_file_common_args=spec.add_file_common_args
|
||||||
)
|
)
|
||||||
|
|
||||||
client = F5RestClient(**module.params)
|
|
||||||
|
|
||||||
try:
|
try:
|
||||||
mm = ModuleManager(module=module, client=client)
|
mm = ModuleManager(module=module)
|
||||||
results = mm.exec_module()
|
results = mm.exec_module()
|
||||||
cleanup_tokens(client)
|
module.exit_json(**results)
|
||||||
exit_json(module, results, client)
|
|
||||||
except F5ModuleError as ex:
|
except F5ModuleError as ex:
|
||||||
cleanup_tokens(client)
|
module.fail_json(msg=str(ex))
|
||||||
fail_json(module, ex, client)
|
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
|
|
|
@ -28,10 +28,12 @@ options:
|
||||||
full_name:
|
full_name:
|
||||||
description:
|
description:
|
||||||
- Full name of the user.
|
- Full name of the user.
|
||||||
|
type: str
|
||||||
username_credential:
|
username_credential:
|
||||||
description:
|
description:
|
||||||
- Name of the user to create, remove or modify.
|
- Name of the user to create, remove or modify.
|
||||||
- The C(root) user may not be removed.
|
- The C(root) user may not be removed.
|
||||||
|
type: str
|
||||||
required: True
|
required: True
|
||||||
aliases:
|
aliases:
|
||||||
- name
|
- name
|
||||||
|
@ -39,9 +41,11 @@ options:
|
||||||
description:
|
description:
|
||||||
- Set the users password to this unencrypted value.
|
- Set the users password to this unencrypted value.
|
||||||
C(password_credential) is required when creating a new account.
|
C(password_credential) is required when creating a new account.
|
||||||
|
type: str
|
||||||
shell:
|
shell:
|
||||||
description:
|
description:
|
||||||
- Optionally set the users shell.
|
- Optionally set the users shell.
|
||||||
|
type: str
|
||||||
choices:
|
choices:
|
||||||
- bash
|
- bash
|
||||||
- none
|
- none
|
||||||
|
@ -56,26 +60,30 @@ options:
|
||||||
C(operator), C(resource-admin), C(user-manager), C(web-application-security-administrator),
|
C(operator), C(resource-admin), C(user-manager), C(web-application-security-administrator),
|
||||||
and C(web-application-security-editor).
|
and C(web-application-security-editor).
|
||||||
- Partition portion of tuple should be an existing partition or the value 'all'.
|
- Partition portion of tuple should be an existing partition or the value 'all'.
|
||||||
|
type: list
|
||||||
state:
|
state:
|
||||||
description:
|
description:
|
||||||
- Whether the account should exist or not, taking action if the state is
|
- Whether the account should exist or not, taking action if the state is
|
||||||
different from what is stated.
|
different from what is stated.
|
||||||
default: present
|
type: str
|
||||||
choices:
|
choices:
|
||||||
- present
|
- present
|
||||||
- absent
|
- absent
|
||||||
|
default: present
|
||||||
update_password:
|
update_password:
|
||||||
description:
|
description:
|
||||||
- C(always) will allow to update passwords if the user chooses to do so.
|
- C(always) will allow to update passwords if the user chooses to do so.
|
||||||
C(on_create) will only set the password for newly created users.
|
C(on_create) will only set the password for newly created users.
|
||||||
- When C(username_credential) is C(root), this value will be forced to C(always).
|
- When C(username_credential) is C(root), this value will be forced to C(always).
|
||||||
default: always
|
type: str
|
||||||
choices:
|
choices:
|
||||||
- always
|
- always
|
||||||
- on_create
|
- on_create
|
||||||
|
default: always
|
||||||
partition:
|
partition:
|
||||||
description:
|
description:
|
||||||
- Device partition to manage resources on.
|
- Device partition to manage resources on.
|
||||||
|
type: str
|
||||||
default: Common
|
default: Common
|
||||||
version_added: 2.5
|
version_added: 2.5
|
||||||
notes:
|
notes:
|
||||||
|
@ -215,20 +223,14 @@ try:
|
||||||
from library.module_utils.network.f5.bigip import F5RestClient
|
from library.module_utils.network.f5.bigip import F5RestClient
|
||||||
from library.module_utils.network.f5.common import F5ModuleError
|
from library.module_utils.network.f5.common import F5ModuleError
|
||||||
from library.module_utils.network.f5.common import AnsibleF5Parameters
|
from library.module_utils.network.f5.common import AnsibleF5Parameters
|
||||||
from library.module_utils.network.f5.common import cleanup_tokens
|
|
||||||
from library.module_utils.network.f5.common import f5_argument_spec
|
from library.module_utils.network.f5.common import f5_argument_spec
|
||||||
from library.module_utils.network.f5.common import exit_json
|
|
||||||
from library.module_utils.network.f5.common import fail_json
|
|
||||||
from library.module_utils.network.f5.icontrol import tmos_version
|
from library.module_utils.network.f5.icontrol import tmos_version
|
||||||
from library.module_utils.network.f5.icontrol import upload_file
|
from library.module_utils.network.f5.icontrol import upload_file
|
||||||
except ImportError:
|
except ImportError:
|
||||||
from ansible.module_utils.network.f5.bigip import F5RestClient
|
from ansible.module_utils.network.f5.bigip import F5RestClient
|
||||||
from ansible.module_utils.network.f5.common import F5ModuleError
|
from ansible.module_utils.network.f5.common import F5ModuleError
|
||||||
from ansible.module_utils.network.f5.common import AnsibleF5Parameters
|
from ansible.module_utils.network.f5.common import AnsibleF5Parameters
|
||||||
from ansible.module_utils.network.f5.common import cleanup_tokens
|
|
||||||
from ansible.module_utils.network.f5.common import f5_argument_spec
|
from ansible.module_utils.network.f5.common import f5_argument_spec
|
||||||
from ansible.module_utils.network.f5.common import exit_json
|
|
||||||
from ansible.module_utils.network.f5.common import fail_json
|
|
||||||
from ansible.module_utils.network.f5.icontrol import tmos_version
|
from ansible.module_utils.network.f5.icontrol import tmos_version
|
||||||
from ansible.module_utils.network.f5.icontrol import upload_file
|
from ansible.module_utils.network.f5.icontrol import upload_file
|
||||||
|
|
||||||
|
@ -459,7 +461,7 @@ class Difference(object):
|
||||||
class ModuleManager(object):
|
class ModuleManager(object):
|
||||||
def __init__(self, *args, **kwargs):
|
def __init__(self, *args, **kwargs):
|
||||||
self.module = kwargs.get('module', None)
|
self.module = kwargs.get('module', None)
|
||||||
self.client = kwargs.get('client', None)
|
self.client = F5RestClient(**self.module.params)
|
||||||
self.kwargs = kwargs
|
self.kwargs = kwargs
|
||||||
|
|
||||||
def exec_module(self):
|
def exec_module(self):
|
||||||
|
@ -503,7 +505,7 @@ class ModuleManager(object):
|
||||||
class BaseManager(object):
|
class BaseManager(object):
|
||||||
def __init__(self, *args, **kwargs):
|
def __init__(self, *args, **kwargs):
|
||||||
self.module = kwargs.get('module', None)
|
self.module = kwargs.get('module', None)
|
||||||
self.client = kwargs.get('client', None)
|
self.client = F5RestClient(**self.module.params)
|
||||||
self.want = ModuleParameters(params=self.module.params)
|
self.want = ModuleParameters(params=self.module.params)
|
||||||
self.have = ApiParameters()
|
self.have = ApiParameters()
|
||||||
self.changes = UsableChanges()
|
self.changes = UsableChanges()
|
||||||
|
@ -1103,16 +1105,12 @@ def main():
|
||||||
supports_check_mode=spec.supports_check_mode
|
supports_check_mode=spec.supports_check_mode
|
||||||
)
|
)
|
||||||
|
|
||||||
client = F5RestClient(**module.params)
|
|
||||||
|
|
||||||
try:
|
try:
|
||||||
mm = ModuleManager(module=module, client=client)
|
mm = ModuleManager(module=module)
|
||||||
results = mm.exec_module()
|
results = mm.exec_module()
|
||||||
cleanup_tokens(client)
|
module.exit_json(**results)
|
||||||
exit_json(module, results, client)
|
|
||||||
except F5ModuleError as ex:
|
except F5ModuleError as ex:
|
||||||
cleanup_tokens(client)
|
module.fail_json(msg=str(ex))
|
||||||
fail_json(module, ex, client)
|
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
|
|
|
@ -25,6 +25,7 @@ options:
|
||||||
name:
|
name:
|
||||||
description:
|
description:
|
||||||
- The name of the vCMP guest to manage.
|
- The name of the vCMP guest to manage.
|
||||||
|
type: str
|
||||||
required: True
|
required: True
|
||||||
vlans:
|
vlans:
|
||||||
description:
|
description:
|
||||||
|
@ -34,11 +35,13 @@ options:
|
||||||
- The order of these VLANs is not important; in fact, it's ignored. This module will
|
- The order of these VLANs is not important; in fact, it's ignored. This module will
|
||||||
order the VLANs for you automatically. Therefore, if you deliberately re-order them
|
order the VLANs for you automatically. Therefore, if you deliberately re-order them
|
||||||
in subsequent tasks, you will find that this module will B(not) register a change.
|
in subsequent tasks, you will find that this module will B(not) register a change.
|
||||||
|
type: list
|
||||||
initial_image:
|
initial_image:
|
||||||
description:
|
description:
|
||||||
- Specifies the base software release ISO image file for installing the TMOS
|
- Specifies the base software release ISO image file for installing the TMOS
|
||||||
hypervisor instance and any licensed BIG-IP modules onto the guest's virtual
|
hypervisor instance and any licensed BIG-IP modules onto the guest's virtual
|
||||||
disk. When creating a new guest, this parameter is required.
|
disk. When creating a new guest, this parameter is required.
|
||||||
|
type: str
|
||||||
mgmt_network:
|
mgmt_network:
|
||||||
description:
|
description:
|
||||||
- Specifies the method by which the management address is used in the vCMP guest.
|
- Specifies the method by which the management address is used in the vCMP guest.
|
||||||
|
@ -60,6 +63,7 @@ options:
|
||||||
management network. This immediately connects all of the guest's VMs to the
|
management network. This immediately connects all of the guest's VMs to the
|
||||||
physical management network. Changing this property while the guest is in the
|
physical management network. Changing this property while the guest is in the
|
||||||
C(configured) or C(provisioned) state has no immediate effect.
|
C(configured) or C(provisioned) state has no immediate effect.
|
||||||
|
type: str
|
||||||
choices:
|
choices:
|
||||||
- bridged
|
- bridged
|
||||||
- isolated
|
- isolated
|
||||||
|
@ -77,11 +81,13 @@ options:
|
||||||
parameter is required if the C(mgmt_network) parameter is C(bridged).
|
parameter is required if the C(mgmt_network) parameter is C(bridged).
|
||||||
- When creating a new guest, if you do not specify a network or network mask,
|
- When creating a new guest, if you do not specify a network or network mask,
|
||||||
a default of C(/24) (C(255.255.255.0)) will be assumed.
|
a default of C(/24) (C(255.255.255.0)) will be assumed.
|
||||||
|
type: str
|
||||||
mgmt_route:
|
mgmt_route:
|
||||||
description:
|
description:
|
||||||
- Specifies the gateway address for the C(mgmt_address).
|
- Specifies the gateway address for the C(mgmt_address).
|
||||||
- If this value is not specified when creating a new guest, it is set to C(none).
|
- If this value is not specified when creating a new guest, it is set to C(none).
|
||||||
- The value C(none) can be used during an update to remove this value.
|
- The value C(none) can be used during an update to remove this value.
|
||||||
|
type: str
|
||||||
state:
|
state:
|
||||||
description:
|
description:
|
||||||
- The state of the vCMP guest on the system. Each state implies the actions of
|
- The state of the vCMP guest on the system. Each state implies the actions of
|
||||||
|
@ -97,13 +103,14 @@ options:
|
||||||
- When C(present), ensures the guest is properly provisioned and starts
|
- When C(present), ensures the guest is properly provisioned and starts
|
||||||
the guest so that it is in a running state.
|
the guest so that it is in a running state.
|
||||||
- When C(absent), removes the vCMP from the system.
|
- When C(absent), removes the vCMP from the system.
|
||||||
default: "present"
|
type: str
|
||||||
choices:
|
choices:
|
||||||
- configured
|
- configured
|
||||||
- disabled
|
- disabled
|
||||||
- provisioned
|
- provisioned
|
||||||
- present
|
- present
|
||||||
- absent
|
- absent
|
||||||
|
default: present
|
||||||
cores_per_slot:
|
cores_per_slot:
|
||||||
description:
|
description:
|
||||||
- Specifies the number of cores that the system allocates to the guest.
|
- Specifies the number of cores that the system allocates to the guest.
|
||||||
|
@ -113,9 +120,11 @@ options:
|
||||||
- The number you can specify depends on the type of hardware you have.
|
- The number you can specify depends on the type of hardware you have.
|
||||||
- In the event of a reboot, the system persists the guest to the same slot on
|
- In the event of a reboot, the system persists the guest to the same slot on
|
||||||
which it ran prior to the reboot.
|
which it ran prior to the reboot.
|
||||||
|
type: int
|
||||||
partition:
|
partition:
|
||||||
description:
|
description:
|
||||||
- Device partition to manage resources on.
|
- Device partition to manage resources on.
|
||||||
|
type: str
|
||||||
default: Common
|
default: Common
|
||||||
number_of_slots:
|
number_of_slots:
|
||||||
description:
|
description:
|
||||||
|
@ -124,6 +133,7 @@ options:
|
||||||
it is assigned to.
|
it is assigned to.
|
||||||
- Possible values are dependent on the type of blades being used in this cluster.
|
- Possible values are dependent on the type of blades being used in this cluster.
|
||||||
- The default value depends on the type of blades being used in this cluster.
|
- The default value depends on the type of blades being used in this cluster.
|
||||||
|
type: int
|
||||||
version_added: 2.7
|
version_added: 2.7
|
||||||
min_number_of_slots:
|
min_number_of_slots:
|
||||||
description:
|
description:
|
||||||
|
@ -133,6 +143,7 @@ options:
|
||||||
- If at the end of any allocation attempt the guest is not assigned to at least
|
- If at the end of any allocation attempt the guest is not assigned to at least
|
||||||
this many slots, the attempt fails and the change that initiated it is reverted.
|
this many slots, the attempt fails and the change that initiated it is reverted.
|
||||||
- A guest's C(min_number_of_slots) value cannot be greater than its C(number_of_slots).
|
- A guest's C(min_number_of_slots) value cannot be greater than its C(number_of_slots).
|
||||||
|
type: int
|
||||||
version_added: 2.7
|
version_added: 2.7
|
||||||
allowed_slots:
|
allowed_slots:
|
||||||
description:
|
description:
|
||||||
|
@ -144,6 +155,7 @@ options:
|
||||||
never assigned to the same slot.
|
never assigned to the same slot.
|
||||||
- By default this list includes every available slot in the cluster. This means,
|
- By default this list includes every available slot in the cluster. This means,
|
||||||
by default, the guest may be assigned to any slot.
|
by default, the guest may be assigned to any slot.
|
||||||
|
type: list
|
||||||
version_added: 2.7
|
version_added: 2.7
|
||||||
notes:
|
notes:
|
||||||
- This module can take a lot of time to deploy vCMP guests. This is an intrinsic
|
- This module can take a lot of time to deploy vCMP guests. This is an intrinsic
|
||||||
|
@ -216,11 +228,8 @@ try:
|
||||||
from library.module_utils.network.f5.bigip import F5RestClient
|
from library.module_utils.network.f5.bigip import F5RestClient
|
||||||
from library.module_utils.network.f5.common import F5ModuleError
|
from library.module_utils.network.f5.common import F5ModuleError
|
||||||
from library.module_utils.network.f5.common import AnsibleF5Parameters
|
from library.module_utils.network.f5.common import AnsibleF5Parameters
|
||||||
from library.module_utils.network.f5.common import cleanup_tokens
|
|
||||||
from library.module_utils.network.f5.common import fq_name
|
from library.module_utils.network.f5.common import fq_name
|
||||||
from library.module_utils.network.f5.common import f5_argument_spec
|
from library.module_utils.network.f5.common import f5_argument_spec
|
||||||
from library.module_utils.network.f5.common import exit_json
|
|
||||||
from library.module_utils.network.f5.common import fail_json
|
|
||||||
from library.module_utils.network.f5.urls import parseStats
|
from library.module_utils.network.f5.urls import parseStats
|
||||||
from library.module_utils.network.f5.ipaddress import is_valid_ip
|
from library.module_utils.network.f5.ipaddress import is_valid_ip
|
||||||
from library.module_utils.compat.ipaddress import ip_interface
|
from library.module_utils.compat.ipaddress import ip_interface
|
||||||
|
@ -228,11 +237,8 @@ except ImportError:
|
||||||
from ansible.module_utils.network.f5.bigip import F5RestClient
|
from ansible.module_utils.network.f5.bigip import F5RestClient
|
||||||
from ansible.module_utils.network.f5.common import F5ModuleError
|
from ansible.module_utils.network.f5.common import F5ModuleError
|
||||||
from ansible.module_utils.network.f5.common import AnsibleF5Parameters
|
from ansible.module_utils.network.f5.common import AnsibleF5Parameters
|
||||||
from ansible.module_utils.network.f5.common import cleanup_tokens
|
|
||||||
from ansible.module_utils.network.f5.common import fq_name
|
from ansible.module_utils.network.f5.common import fq_name
|
||||||
from ansible.module_utils.network.f5.common import f5_argument_spec
|
from ansible.module_utils.network.f5.common import f5_argument_spec
|
||||||
from ansible.module_utils.network.f5.common import exit_json
|
|
||||||
from ansible.module_utils.network.f5.common import fail_json
|
|
||||||
from ansible.module_utils.network.f5.urls import parseStats
|
from ansible.module_utils.network.f5.urls import parseStats
|
||||||
from ansible.module_utils.network.f5.ipaddress import is_valid_ip
|
from ansible.module_utils.network.f5.ipaddress import is_valid_ip
|
||||||
from ansible.module_utils.compat.ipaddress import ip_interface
|
from ansible.module_utils.compat.ipaddress import ip_interface
|
||||||
|
@ -458,7 +464,7 @@ class Difference(object):
|
||||||
class ModuleManager(object):
|
class ModuleManager(object):
|
||||||
def __init__(self, *args, **kwargs):
|
def __init__(self, *args, **kwargs):
|
||||||
self.module = kwargs.get('module', None)
|
self.module = kwargs.get('module', None)
|
||||||
self.client = kwargs.get('client', None)
|
self.client = F5RestClient(**self.module.params)
|
||||||
self.want = ModuleParameters(client=self.client, params=self.module.params)
|
self.want = ModuleParameters(client=self.client, params=self.module.params)
|
||||||
self.have = None
|
self.have = None
|
||||||
self.changes = ReportableChanges()
|
self.changes = ReportableChanges()
|
||||||
|
@ -952,19 +958,16 @@ def main():
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
argument_spec=spec.argument_spec,
|
argument_spec=spec.argument_spec,
|
||||||
supports_check_mode=spec.supports_check_mode
|
supports_check_mode=spec.supports_check_mode,
|
||||||
|
required_if=spec.required_if
|
||||||
)
|
)
|
||||||
|
|
||||||
client = F5RestClient(**module.params)
|
|
||||||
|
|
||||||
try:
|
try:
|
||||||
mm = ModuleManager(module=module, client=client)
|
mm = ModuleManager(module=module)
|
||||||
results = mm.exec_module()
|
results = mm.exec_module()
|
||||||
cleanup_tokens(client)
|
module.exit_json(**results)
|
||||||
exit_json(module, results, client)
|
|
||||||
except F5ModuleError as ex:
|
except F5ModuleError as ex:
|
||||||
cleanup_tokens(client)
|
module.fail_json(msg=str(ex))
|
||||||
fail_json(module, ex, client)
|
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
|
|
|
@ -25,6 +25,7 @@ options:
|
||||||
- Name of the virtual address.
|
- Name of the virtual address.
|
||||||
- If this parameter is not provided, then the value of C(address) will
|
- If this parameter is not provided, then the value of C(address) will
|
||||||
be used.
|
be used.
|
||||||
|
type: str
|
||||||
version_added: 2.6
|
version_added: 2.6
|
||||||
address:
|
address:
|
||||||
description:
|
description:
|
||||||
|
@ -32,6 +33,7 @@ options:
|
||||||
- If you never created a virtual address, but did create virtual servers, then
|
- If you never created a virtual address, but did create virtual servers, then
|
||||||
a virtual address for each virtual server was created automatically. The name
|
a virtual address for each virtual server was created automatically. The name
|
||||||
of this virtual address is its IP address value.
|
of this virtual address is its IP address value.
|
||||||
|
type: str
|
||||||
netmask:
|
netmask:
|
||||||
description:
|
description:
|
||||||
- Netmask of the provided virtual address. This value cannot be
|
- Netmask of the provided virtual address. This value cannot be
|
||||||
|
@ -39,10 +41,12 @@ options:
|
||||||
- When creating a new virtual address, if this parameter is not specified, the
|
- When creating a new virtual address, if this parameter is not specified, the
|
||||||
default value is C(255.255.255.255) for IPv4 addresses and
|
default value is C(255.255.255.255) for IPv4 addresses and
|
||||||
C(ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff) for IPv6 addresses.
|
C(ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff) for IPv6 addresses.
|
||||||
|
type: str
|
||||||
connection_limit:
|
connection_limit:
|
||||||
description:
|
description:
|
||||||
- Specifies the number of concurrent connections that the system
|
- Specifies the number of concurrent connections that the system
|
||||||
allows on this virtual address.
|
allows on this virtual address.
|
||||||
|
type: int
|
||||||
arp_state:
|
arp_state:
|
||||||
description:
|
description:
|
||||||
- Specifies whether the system accepts ARP requests. When (disabled),
|
- Specifies whether the system accepts ARP requests. When (disabled),
|
||||||
|
@ -53,6 +57,7 @@ options:
|
||||||
- Deprecated. Use the C(arp) parameter instead.
|
- Deprecated. Use the C(arp) parameter instead.
|
||||||
- When creating a new virtual address, if this parameter is not specified,
|
- When creating a new virtual address, if this parameter is not specified,
|
||||||
the default value is C(enabled).
|
the default value is C(enabled).
|
||||||
|
type: str
|
||||||
choices:
|
choices:
|
||||||
- enabled
|
- enabled
|
||||||
- disabled
|
- disabled
|
||||||
|
@ -77,6 +82,7 @@ options:
|
||||||
- C(enabled) and C(disabled) are deprecated and will be removed in
|
- C(enabled) and C(disabled) are deprecated and will be removed in
|
||||||
Ansible 2.11. Instead, use known Ansible booleans such as C(yes) and
|
Ansible 2.11. Instead, use known Ansible booleans such as C(yes) and
|
||||||
C(no)
|
C(no)
|
||||||
|
type: str
|
||||||
icmp_echo:
|
icmp_echo:
|
||||||
description:
|
description:
|
||||||
- Specifies how the systems sends responses to (ICMP) echo requests
|
- Specifies how the systems sends responses to (ICMP) echo requests
|
||||||
|
@ -88,6 +94,7 @@ options:
|
||||||
disable responses based on virtual server state; C(when_any_available),
|
disable responses based on virtual server state; C(when_any_available),
|
||||||
C(when_all_available, or C(always), regardless of the state of any
|
C(when_all_available, or C(always), regardless of the state of any
|
||||||
virtual servers.
|
virtual servers.
|
||||||
|
type: str
|
||||||
choices:
|
choices:
|
||||||
- enabled
|
- enabled
|
||||||
- disabled
|
- disabled
|
||||||
|
@ -100,12 +107,13 @@ options:
|
||||||
the virtual address and enables it. If C(enabled), enable the virtual
|
the virtual address and enables it. If C(enabled), enable the virtual
|
||||||
address if it exists. If C(disabled), create the virtual address if
|
address if it exists. If C(disabled), create the virtual address if
|
||||||
needed, and set state to C(disabled).
|
needed, and set state to C(disabled).
|
||||||
default: present
|
type: str
|
||||||
choices:
|
choices:
|
||||||
- present
|
- present
|
||||||
- absent
|
- absent
|
||||||
- enabled
|
- enabled
|
||||||
- disabled
|
- disabled
|
||||||
|
default: present
|
||||||
availability_calculation:
|
availability_calculation:
|
||||||
description:
|
description:
|
||||||
- Specifies what routes of the virtual address the system advertises.
|
- Specifies what routes of the virtual address the system advertises.
|
||||||
|
@ -113,6 +121,7 @@ options:
|
||||||
server is available. When C(when_all_available), advertises the
|
server is available. When C(when_all_available), advertises the
|
||||||
route when all virtual servers are available. When (always), always
|
route when all virtual servers are available. When (always), always
|
||||||
advertises the route regardless of the virtual servers available.
|
advertises the route regardless of the virtual servers available.
|
||||||
|
type: str
|
||||||
choices:
|
choices:
|
||||||
- always
|
- always
|
||||||
- when_all_available
|
- when_all_available
|
||||||
|
@ -149,6 +158,7 @@ options:
|
||||||
when any virtual server is available.
|
when any virtual server is available.
|
||||||
- When C(all), the BIG-IP system will advertise the route for the virtual address
|
- When C(all), the BIG-IP system will advertise the route for the virtual address
|
||||||
when all virtual servers are available.
|
when all virtual servers are available.
|
||||||
|
type: str
|
||||||
choices:
|
choices:
|
||||||
- disabled
|
- disabled
|
||||||
- enabled
|
- enabled
|
||||||
|
@ -160,6 +170,7 @@ options:
|
||||||
partition:
|
partition:
|
||||||
description:
|
description:
|
||||||
- Device partition to manage resources on.
|
- Device partition to manage resources on.
|
||||||
|
type: str
|
||||||
default: Common
|
default: Common
|
||||||
version_added: 2.5
|
version_added: 2.5
|
||||||
traffic_group:
|
traffic_group:
|
||||||
|
@ -167,11 +178,13 @@ options:
|
||||||
- The traffic group for the virtual address. When creating a new address,
|
- The traffic group for the virtual address. When creating a new address,
|
||||||
if this value is not specified, the default of C(/Common/traffic-group-1)
|
if this value is not specified, the default of C(/Common/traffic-group-1)
|
||||||
will be used.
|
will be used.
|
||||||
|
type: str
|
||||||
version_added: 2.5
|
version_added: 2.5
|
||||||
route_domain:
|
route_domain:
|
||||||
description:
|
description:
|
||||||
- The route domain of the C(address) that you want to use.
|
- The route domain of the C(address) that you want to use.
|
||||||
- This value cannot be modified after it is set.
|
- This value cannot be modified after it is set.
|
||||||
|
type: str
|
||||||
version_added: 2.6
|
version_added: 2.6
|
||||||
spanning:
|
spanning:
|
||||||
description:
|
description:
|
||||||
|
@ -276,10 +289,7 @@ try:
|
||||||
from library.module_utils.network.f5.bigip import F5RestClient
|
from library.module_utils.network.f5.bigip import F5RestClient
|
||||||
from library.module_utils.network.f5.common import F5ModuleError
|
from library.module_utils.network.f5.common import F5ModuleError
|
||||||
from library.module_utils.network.f5.common import AnsibleF5Parameters
|
from library.module_utils.network.f5.common import AnsibleF5Parameters
|
||||||
from library.module_utils.network.f5.common import cleanup_tokens
|
|
||||||
from library.module_utils.network.f5.common import transform_name
|
from library.module_utils.network.f5.common import transform_name
|
||||||
from library.module_utils.network.f5.common import exit_json
|
|
||||||
from library.module_utils.network.f5.common import fail_json
|
|
||||||
from library.module_utils.network.f5.common import fq_name
|
from library.module_utils.network.f5.common import fq_name
|
||||||
from library.module_utils.network.f5.common import f5_argument_spec
|
from library.module_utils.network.f5.common import f5_argument_spec
|
||||||
from library.module_utils.network.f5.ipaddress import is_valid_ip
|
from library.module_utils.network.f5.ipaddress import is_valid_ip
|
||||||
|
@ -289,10 +299,7 @@ except ImportError:
|
||||||
from ansible.module_utils.network.f5.bigip import F5RestClient
|
from ansible.module_utils.network.f5.bigip import F5RestClient
|
||||||
from ansible.module_utils.network.f5.common import F5ModuleError
|
from ansible.module_utils.network.f5.common import F5ModuleError
|
||||||
from ansible.module_utils.network.f5.common import AnsibleF5Parameters
|
from ansible.module_utils.network.f5.common import AnsibleF5Parameters
|
||||||
from ansible.module_utils.network.f5.common import cleanup_tokens
|
|
||||||
from ansible.module_utils.network.f5.common import transform_name
|
from ansible.module_utils.network.f5.common import transform_name
|
||||||
from ansible.module_utils.network.f5.common import exit_json
|
|
||||||
from ansible.module_utils.network.f5.common import fail_json
|
|
||||||
from ansible.module_utils.network.f5.common import fq_name
|
from ansible.module_utils.network.f5.common import fq_name
|
||||||
from ansible.module_utils.network.f5.common import f5_argument_spec
|
from ansible.module_utils.network.f5.common import f5_argument_spec
|
||||||
from ansible.module_utils.network.f5.ipaddress import is_valid_ip
|
from ansible.module_utils.network.f5.ipaddress import is_valid_ip
|
||||||
|
@ -635,7 +642,7 @@ class Difference(object):
|
||||||
class ModuleManager(object):
|
class ModuleManager(object):
|
||||||
def __init__(self, *args, **kwargs):
|
def __init__(self, *args, **kwargs):
|
||||||
self.module = kwargs.get('module', None)
|
self.module = kwargs.get('module', None)
|
||||||
self.client = kwargs.get('client', None)
|
self.client = F5RestClient(**self.module.params)
|
||||||
self.have = ApiParameters()
|
self.have = ApiParameters()
|
||||||
self.want = ModuleParameters(client=self.client, params=self.module.params)
|
self.want = ModuleParameters(client=self.client, params=self.module.params)
|
||||||
self.changes = UsableChanges()
|
self.changes = UsableChanges()
|
||||||
|
@ -940,19 +947,17 @@ def main():
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
argument_spec=spec.argument_spec,
|
argument_spec=spec.argument_spec,
|
||||||
supports_check_mode=spec.supports_check_mode
|
supports_check_mode=spec.supports_check_mode,
|
||||||
|
mutually_exclusive=spec.mutually_exclusive,
|
||||||
|
required_one_of=spec.required_one_of
|
||||||
)
|
)
|
||||||
|
|
||||||
client = F5RestClient(**module.params)
|
|
||||||
|
|
||||||
try:
|
try:
|
||||||
mm = ModuleManager(module=module, client=client)
|
mm = ModuleManager(module=module)
|
||||||
results = mm.exec_module()
|
results = mm.exec_module()
|
||||||
cleanup_tokens(client)
|
module.exit_json(**results)
|
||||||
exit_json(module, results, client)
|
|
||||||
except F5ModuleError as ex:
|
except F5ModuleError as ex:
|
||||||
cleanup_tokens(client)
|
module.fail_json(msg=str(ex))
|
||||||
fail_json(module, ex, client)
|
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
|
|
|
@ -26,12 +26,13 @@ options:
|
||||||
if it exists. C(present) creates the virtual server and enable it.
|
if it exists. C(present) creates the virtual server and enable it.
|
||||||
If C(enabled), enable the virtual server if it exists. If C(disabled),
|
If C(enabled), enable the virtual server if it exists. If C(disabled),
|
||||||
create the virtual server if needed, and set state to C(disabled).
|
create the virtual server if needed, and set state to C(disabled).
|
||||||
default: present
|
type: str
|
||||||
choices:
|
choices:
|
||||||
- present
|
- present
|
||||||
- absent
|
- absent
|
||||||
- enabled
|
- enabled
|
||||||
- disabled
|
- disabled
|
||||||
|
default: present
|
||||||
type:
|
type:
|
||||||
description:
|
description:
|
||||||
- Specifies the network service provided by this virtual server.
|
- Specifies the network service provided by this virtual server.
|
||||||
|
@ -73,6 +74,7 @@ options:
|
||||||
profile and adding Request Adapt or Response Adapt profiles to the virtual server.
|
profile and adding Request Adapt or Response Adapt profiles to the virtual server.
|
||||||
- When C(message-routing), specifies a virtual server that uses a SIP application protocol
|
- When C(message-routing), specifies a virtual server that uses a SIP application protocol
|
||||||
and functions in accordance with a SIP session profile and SIP router profile.
|
and functions in accordance with a SIP session profile and SIP router profile.
|
||||||
|
type: str
|
||||||
choices:
|
choices:
|
||||||
- standard
|
- standard
|
||||||
- forwarding-l2
|
- forwarding-l2
|
||||||
|
@ -89,6 +91,7 @@ options:
|
||||||
name:
|
name:
|
||||||
description:
|
description:
|
||||||
- Virtual server name.
|
- Virtual server name.
|
||||||
|
type: str
|
||||||
required: True
|
required: True
|
||||||
aliases:
|
aliases:
|
||||||
- vs
|
- vs
|
||||||
|
@ -99,6 +102,7 @@ options:
|
||||||
- When C(type) is C(internal), this parameter is ignored. For all other types,
|
- When C(type) is C(internal), this parameter is ignored. For all other types,
|
||||||
it is required.
|
it is required.
|
||||||
- Destination can also be specified as a name for an existing Virtual Address.
|
- Destination can also be specified as a name for an existing Virtual Address.
|
||||||
|
type: str
|
||||||
aliases:
|
aliases:
|
||||||
- address
|
- address
|
||||||
- ip
|
- ip
|
||||||
|
@ -113,6 +117,7 @@ options:
|
||||||
- Specify the IP address in Classless Inter-Domain Routing (CIDR) format; address/prefix,
|
- Specify the IP address in Classless Inter-Domain Routing (CIDR) format; address/prefix,
|
||||||
where the prefix length is in bits. For example, for IPv4, 10.0.0.1/32 or 10.0.0.0/24,
|
where the prefix length is in bits. For example, for IPv4, 10.0.0.1/32 or 10.0.0.0/24,
|
||||||
and for IPv6, ffe1::0020/64 or 2001:ed8:77b5:2:10:10:100:42/64.
|
and for IPv6, ffe1::0020/64 or 2001:ed8:77b5:2:10:10:100:42/64.
|
||||||
|
type: str
|
||||||
version_added: 2.5
|
version_added: 2.5
|
||||||
port:
|
port:
|
||||||
description:
|
description:
|
||||||
|
@ -136,6 +141,7 @@ options:
|
||||||
- The string C(isakmp) may be substituted for for port C(500).
|
- The string C(isakmp) may be substituted for for port C(500).
|
||||||
- The string C(mqtt) may be substituted for for port C(1883).
|
- The string C(mqtt) may be substituted for for port C(1883).
|
||||||
- The string C(mqtt-tls) may be substituted for for port C(8883).
|
- The string C(mqtt-tls) may be substituted for for port C(8883).
|
||||||
|
type: str
|
||||||
profiles:
|
profiles:
|
||||||
description:
|
description:
|
||||||
- List of profiles (HTTP, ClientSSL, ServerSSL, etc) to apply to both sides
|
- List of profiles (HTTP, ClientSSL, ServerSSL, etc) to apply to both sides
|
||||||
|
@ -166,14 +172,17 @@ options:
|
||||||
- If this is not specified, then it is assumed that the profile item is
|
- If this is not specified, then it is assumed that the profile item is
|
||||||
only a name of a profile.
|
only a name of a profile.
|
||||||
- This must be specified if a context is specified.
|
- This must be specified if a context is specified.
|
||||||
|
type: str
|
||||||
context:
|
context:
|
||||||
description:
|
description:
|
||||||
- The side of the connection on which the profile should be applied.
|
- The side of the connection on which the profile should be applied.
|
||||||
|
type: str
|
||||||
choices:
|
choices:
|
||||||
- all
|
- all
|
||||||
- server-side
|
- server-side
|
||||||
- client-side
|
- client-side
|
||||||
default: all
|
default: all
|
||||||
|
type: list
|
||||||
aliases:
|
aliases:
|
||||||
- all_profiles
|
- all_profiles
|
||||||
irules:
|
irules:
|
||||||
|
@ -186,22 +195,25 @@ options:
|
||||||
- When C(type) is C(stateless), this parameter will be ignored.
|
- When C(type) is C(stateless), this parameter will be ignored.
|
||||||
- When C(type) is C(reject), this parameter will be ignored.
|
- When C(type) is C(reject), this parameter will be ignored.
|
||||||
- When C(type) is C(internal), this parameter will be ignored.
|
- When C(type) is C(internal), this parameter will be ignored.
|
||||||
|
type: list
|
||||||
aliases:
|
aliases:
|
||||||
- all_rules
|
- all_rules
|
||||||
enabled_vlans:
|
enabled_vlans:
|
||||||
version_added: "2.2"
|
|
||||||
description:
|
description:
|
||||||
- List of VLANs to be enabled. When a VLAN named C(all) is used, all
|
- List of VLANs to be enabled. When a VLAN named C(all) is used, all
|
||||||
VLANs will be allowed. VLANs can be specified with or without the
|
VLANs will be allowed. VLANs can be specified with or without the
|
||||||
leading partition. If the partition is not specified in the VLAN,
|
leading partition. If the partition is not specified in the VLAN,
|
||||||
then the C(partition) option of this module will be used.
|
then the C(partition) option of this module will be used.
|
||||||
- This parameter is mutually exclusive with the C(disabled_vlans) parameter.
|
- This parameter is mutually exclusive with the C(disabled_vlans) parameter.
|
||||||
|
type: list
|
||||||
|
version_added: 2.2
|
||||||
disabled_vlans:
|
disabled_vlans:
|
||||||
version_added: 2.5
|
|
||||||
description:
|
description:
|
||||||
- List of VLANs to be disabled. If the partition is not specified in the VLAN,
|
- List of VLANs to be disabled. If the partition is not specified in the VLAN,
|
||||||
then the C(partition) option of this module will be used.
|
then the C(partition) option of this module will be used.
|
||||||
- This parameter is mutually exclusive with the C(enabled_vlans) parameters.
|
- This parameter is mutually exclusive with the C(enabled_vlans) parameters.
|
||||||
|
type: list
|
||||||
|
version_added: 2.5
|
||||||
pool:
|
pool:
|
||||||
description:
|
description:
|
||||||
- Default pool for the virtual server.
|
- Default pool for the virtual server.
|
||||||
|
@ -211,12 +223,14 @@ options:
|
||||||
is required.
|
is required.
|
||||||
- If C(type) is C(stateless), the C(pool) that is used must not have any members
|
- If C(type) is C(stateless), the C(pool) that is used must not have any members
|
||||||
which define a C(rate_limit).
|
which define a C(rate_limit).
|
||||||
|
type: str
|
||||||
policies:
|
policies:
|
||||||
description:
|
description:
|
||||||
- Specifies the policies for the virtual server.
|
- Specifies the policies for the virtual server.
|
||||||
- When C(type) is C(dhcp), this parameter will be ignored.
|
- When C(type) is C(dhcp), this parameter will be ignored.
|
||||||
- When C(type) is C(reject), this parameter will be ignored.
|
- When C(type) is C(reject), this parameter will be ignored.
|
||||||
- When C(type) is C(internal), this parameter will be ignored.
|
- When C(type) is C(internal), this parameter will be ignored.
|
||||||
|
type: list
|
||||||
aliases:
|
aliases:
|
||||||
- all_policies
|
- all_policies
|
||||||
snat:
|
snat:
|
||||||
|
@ -229,15 +243,18 @@ options:
|
||||||
with the specific pool.
|
with the specific pool.
|
||||||
- To remove SNAT, specify the word C(none).
|
- To remove SNAT, specify the word C(none).
|
||||||
- To specify automap, use the word C(automap).
|
- To specify automap, use the word C(automap).
|
||||||
|
type: str
|
||||||
default_persistence_profile:
|
default_persistence_profile:
|
||||||
description:
|
description:
|
||||||
- Default Profile which manages the session persistence.
|
- Default Profile which manages the session persistence.
|
||||||
- If you want to remove the existing default persistence profile, specify an
|
- If you want to remove the existing default persistence profile, specify an
|
||||||
empty value; C(""). See the documentation for an example.
|
empty value; C(""). See the documentation for an example.
|
||||||
- When C(type) is C(dhcp), this parameter will be ignored.
|
- When C(type) is C(dhcp), this parameter will be ignored.
|
||||||
|
type: str
|
||||||
description:
|
description:
|
||||||
description:
|
description:
|
||||||
- Virtual server description.
|
- Virtual server description.
|
||||||
|
type: str
|
||||||
fallback_persistence_profile:
|
fallback_persistence_profile:
|
||||||
description:
|
description:
|
||||||
- Specifies the persistence profile you want the system to use if it
|
- Specifies the persistence profile you want the system to use if it
|
||||||
|
@ -245,10 +262,12 @@ options:
|
||||||
- If you want to remove the existing fallback persistence profile, specify an
|
- If you want to remove the existing fallback persistence profile, specify an
|
||||||
empty value; C(""). See the documentation for an example.
|
empty value; C(""). See the documentation for an example.
|
||||||
- When C(type) is C(dhcp), this parameter will be ignored.
|
- When C(type) is C(dhcp), this parameter will be ignored.
|
||||||
|
type: str
|
||||||
version_added: 2.3
|
version_added: 2.3
|
||||||
partition:
|
partition:
|
||||||
description:
|
description:
|
||||||
- Device partition to manage resources on.
|
- Device partition to manage resources on.
|
||||||
|
type: str
|
||||||
default: Common
|
default: Common
|
||||||
version_added: 2.5
|
version_added: 2.5
|
||||||
metadata:
|
metadata:
|
||||||
|
@ -259,6 +278,7 @@ options:
|
||||||
- Values for all of the keys will be stored as strings; this includes values
|
- Values for all of the keys will be stored as strings; this includes values
|
||||||
that are numbers.
|
that are numbers.
|
||||||
- Data will be persisted, not ephemeral.
|
- Data will be persisted, not ephemeral.
|
||||||
|
type: raw
|
||||||
version_added: 2.5
|
version_added: 2.5
|
||||||
insert_metadata:
|
insert_metadata:
|
||||||
description:
|
description:
|
||||||
|
@ -293,6 +313,7 @@ options:
|
||||||
description:
|
description:
|
||||||
- Specifies whether the system preserves the source port of the connection.
|
- Specifies whether the system preserves the source port of the connection.
|
||||||
- When creating a new virtual server, if this parameter is not specified, the default is C(preserve).
|
- When creating a new virtual server, if this parameter is not specified, the default is C(preserve).
|
||||||
|
type: str
|
||||||
choices:
|
choices:
|
||||||
- preserve
|
- preserve
|
||||||
- preserve-strict
|
- preserve-strict
|
||||||
|
@ -317,6 +338,7 @@ options:
|
||||||
inferred from C(destination).
|
inferred from C(destination).
|
||||||
- When C(destination) is provided as Virtual Address name, and C(mask) is not specified,
|
- When C(destination) is provided as Virtual Address name, and C(mask) is not specified,
|
||||||
the mask will be C(None) allowing device set it with its internal defaults.
|
the mask will be C(None) allowing device set it with its internal defaults.
|
||||||
|
type: str
|
||||||
version_added: 2.8
|
version_added: 2.8
|
||||||
ip_protocol:
|
ip_protocol:
|
||||||
description:
|
description:
|
||||||
|
@ -329,6 +351,7 @@ options:
|
||||||
- For a list of valid IP protocol numbers, refer to this page
|
- For a list of valid IP protocol numbers, refer to this page
|
||||||
https://en.wikipedia.org/wiki/List_of_IP_protocol_numbers
|
https://en.wikipedia.org/wiki/List_of_IP_protocol_numbers
|
||||||
- When C(type) is C(dhcp), this module will force the C(ip_protocol) parameter to be C(17) (UDP).
|
- When C(type) is C(dhcp), this module will force the C(ip_protocol) parameter to be C(17) (UDP).
|
||||||
|
type: str
|
||||||
choices:
|
choices:
|
||||||
- ah
|
- ah
|
||||||
- any
|
- any
|
||||||
|
@ -355,6 +378,7 @@ options:
|
||||||
- Applies the specify AFM policy to the virtual in an enforcing way.
|
- Applies the specify AFM policy to the virtual in an enforcing way.
|
||||||
- When creating a new virtual, if this parameter is not specified, the enforced
|
- When creating a new virtual, if this parameter is not specified, the enforced
|
||||||
policy is disabled.
|
policy is disabled.
|
||||||
|
type: str
|
||||||
version_added: 2.6
|
version_added: 2.6
|
||||||
firewall_staged_policy:
|
firewall_staged_policy:
|
||||||
description:
|
description:
|
||||||
|
@ -363,6 +387,7 @@ options:
|
||||||
actually applying the rules to traffic.
|
actually applying the rules to traffic.
|
||||||
- When creating a new virtual, if this parameter is not specified, the staged
|
- When creating a new virtual, if this parameter is not specified, the staged
|
||||||
policy is disabled.
|
policy is disabled.
|
||||||
|
type: str
|
||||||
version_added: 2.6
|
version_added: 2.6
|
||||||
security_log_profiles:
|
security_log_profiles:
|
||||||
description:
|
description:
|
||||||
|
@ -370,6 +395,7 @@ options:
|
||||||
- To make use of this feature, the AFM module must be licensed and provisioned.
|
- To make use of this feature, the AFM module must be licensed and provisioned.
|
||||||
- The C(Log all requests) and C(Log illegal requests) are mutually exclusive and
|
- The C(Log all requests) and C(Log illegal requests) are mutually exclusive and
|
||||||
therefore, this module will raise an error if the two are specified together.
|
therefore, this module will raise an error if the two are specified together.
|
||||||
|
type: list
|
||||||
version_added: 2.6
|
version_added: 2.6
|
||||||
security_nat_policy:
|
security_nat_policy:
|
||||||
description:
|
description:
|
||||||
|
@ -386,6 +412,7 @@ options:
|
||||||
- The virtual server NAT policy is the most specific, and overrides a
|
- The virtual server NAT policy is the most specific, and overrides a
|
||||||
route domain and device policy, if specified.
|
route domain and device policy, if specified.
|
||||||
- To remove the policy, specify an empty string value.
|
- To remove the policy, specify an empty string value.
|
||||||
|
type: str
|
||||||
use_device_policy:
|
use_device_policy:
|
||||||
description:
|
description:
|
||||||
- Specify that the virtual server uses the device NAT policy, as specified
|
- Specify that the virtual server uses the device NAT policy, as specified
|
||||||
|
@ -400,11 +427,13 @@ options:
|
||||||
- When specified, the route domain policy overrides the device policy, and
|
- When specified, the route domain policy overrides the device policy, and
|
||||||
is overridden by a virtual server policy.
|
is overridden by a virtual server policy.
|
||||||
type: bool
|
type: bool
|
||||||
|
type: dict
|
||||||
ip_intelligence_policy:
|
ip_intelligence_policy:
|
||||||
description:
|
description:
|
||||||
- Specifies the IP intelligence policy applied to the virtual server.
|
- Specifies the IP intelligence policy applied to the virtual server.
|
||||||
- This parameter requires that a valid BIG-IP security module such as ASM or AFM
|
- This parameter requires that a valid BIG-IP security module such as ASM or AFM
|
||||||
be provisioned.
|
be provisioned.
|
||||||
|
type: str
|
||||||
version_added: 2.8
|
version_added: 2.8
|
||||||
rate_limit:
|
rate_limit:
|
||||||
description:
|
description:
|
||||||
|
@ -432,6 +461,7 @@ options:
|
||||||
- Indicates whether the rate limit is applied per virtual object, per source address, per destination address,
|
- Indicates whether the rate limit is applied per virtual object, per source address, per destination address,
|
||||||
or some combination thereof.
|
or some combination thereof.
|
||||||
- The default value is 'object', which does not use the source or destination address as part of the key.
|
- The default value is 'object', which does not use the source or destination address as part of the key.
|
||||||
|
type: str
|
||||||
choices:
|
choices:
|
||||||
- object
|
- object
|
||||||
- object-source
|
- object-source
|
||||||
|
@ -447,7 +477,6 @@ options:
|
||||||
- Specifies a pool or list of pools that the virtual server uses to replicate either client-side
|
- Specifies a pool or list of pools that the virtual server uses to replicate either client-side
|
||||||
or server-side traffic.
|
or server-side traffic.
|
||||||
- Typically this option is used for intrusion detection.
|
- Typically this option is used for intrusion detection.
|
||||||
version_added: 2.8
|
|
||||||
suboptions:
|
suboptions:
|
||||||
pool_name:
|
pool_name:
|
||||||
description:
|
description:
|
||||||
|
@ -455,13 +484,17 @@ options:
|
||||||
- Only pools created on Common partition or on the same partition as the virtual server can be used.
|
- Only pools created on Common partition or on the same partition as the virtual server can be used.
|
||||||
- Referencing pool on common partition needs to be done in the full path format,
|
- Referencing pool on common partition needs to be done in the full path format,
|
||||||
for example, C(/Common/pool_name).
|
for example, C(/Common/pool_name).
|
||||||
|
type: str
|
||||||
required: True
|
required: True
|
||||||
context:
|
context:
|
||||||
description:
|
description:
|
||||||
- The context option for a clone pool to replicate either client-side or server-side traffic.
|
- The context option for a clone pool to replicate either client-side or server-side traffic.
|
||||||
|
type: str
|
||||||
choices:
|
choices:
|
||||||
- clientside
|
- clientside
|
||||||
- serverside
|
- serverside
|
||||||
|
type: list
|
||||||
|
version_added: 2.8
|
||||||
extends_documentation_fragment: f5
|
extends_documentation_fragment: f5
|
||||||
author:
|
author:
|
||||||
- Tim Rupp (@caphrim007)
|
- Tim Rupp (@caphrim007)
|
||||||
|
@ -852,11 +885,8 @@ try:
|
||||||
from library.module_utils.network.f5.common import MANAGED_BY_ANNOTATION_MODIFIED
|
from library.module_utils.network.f5.common import MANAGED_BY_ANNOTATION_MODIFIED
|
||||||
from library.module_utils.network.f5.common import F5ModuleError
|
from library.module_utils.network.f5.common import F5ModuleError
|
||||||
from library.module_utils.network.f5.common import AnsibleF5Parameters
|
from library.module_utils.network.f5.common import AnsibleF5Parameters
|
||||||
from library.module_utils.network.f5.common import cleanup_tokens
|
|
||||||
from library.module_utils.network.f5.common import fq_name
|
from library.module_utils.network.f5.common import fq_name
|
||||||
from library.module_utils.network.f5.common import f5_argument_spec
|
from library.module_utils.network.f5.common import f5_argument_spec
|
||||||
from library.module_utils.network.f5.common import fail_json
|
|
||||||
from library.module_utils.network.f5.common import exit_json
|
|
||||||
from library.module_utils.network.f5.common import transform_name
|
from library.module_utils.network.f5.common import transform_name
|
||||||
from library.module_utils.network.f5.common import mark_managed_by
|
from library.module_utils.network.f5.common import mark_managed_by
|
||||||
from library.module_utils.network.f5.common import only_has_managed_metadata
|
from library.module_utils.network.f5.common import only_has_managed_metadata
|
||||||
|
@ -874,11 +904,8 @@ except ImportError:
|
||||||
from ansible.module_utils.network.f5.common import MANAGED_BY_ANNOTATION_MODIFIED
|
from ansible.module_utils.network.f5.common import MANAGED_BY_ANNOTATION_MODIFIED
|
||||||
from ansible.module_utils.network.f5.common import F5ModuleError
|
from ansible.module_utils.network.f5.common import F5ModuleError
|
||||||
from ansible.module_utils.network.f5.common import AnsibleF5Parameters
|
from ansible.module_utils.network.f5.common import AnsibleF5Parameters
|
||||||
from ansible.module_utils.network.f5.common import cleanup_tokens
|
|
||||||
from ansible.module_utils.network.f5.common import fq_name
|
from ansible.module_utils.network.f5.common import fq_name
|
||||||
from ansible.module_utils.network.f5.common import f5_argument_spec
|
from ansible.module_utils.network.f5.common import f5_argument_spec
|
||||||
from ansible.module_utils.network.f5.common import fail_json
|
|
||||||
from ansible.module_utils.network.f5.common import exit_json
|
|
||||||
from ansible.module_utils.network.f5.common import transform_name
|
from ansible.module_utils.network.f5.common import transform_name
|
||||||
from ansible.module_utils.network.f5.common import mark_managed_by
|
from ansible.module_utils.network.f5.common import mark_managed_by
|
||||||
from ansible.module_utils.network.f5.common import only_has_managed_metadata
|
from ansible.module_utils.network.f5.common import only_has_managed_metadata
|
||||||
|
@ -3250,7 +3277,7 @@ class Difference(object):
|
||||||
class ModuleManager(object):
|
class ModuleManager(object):
|
||||||
def __init__(self, *args, **kwargs):
|
def __init__(self, *args, **kwargs):
|
||||||
self.module = kwargs.get('module', None)
|
self.module = kwargs.get('module', None)
|
||||||
self.client = kwargs.get('client', None)
|
self.client = F5RestClient(**self.module.params)
|
||||||
self.have = ApiParameters(client=self.client)
|
self.have = ApiParameters(client=self.client)
|
||||||
self.want = ModuleParameters(client=self.client, params=self.module.params)
|
self.want = ModuleParameters(client=self.client, params=self.module.params)
|
||||||
self.changes = UsableChanges()
|
self.changes = UsableChanges()
|
||||||
|
@ -3595,13 +3622,11 @@ def main():
|
||||||
client = F5RestClient(**module.params)
|
client = F5RestClient(**module.params)
|
||||||
|
|
||||||
try:
|
try:
|
||||||
mm = ModuleManager(module=module, client=client)
|
mm = ModuleManager(module=module)
|
||||||
results = mm.exec_module()
|
results = mm.exec_module()
|
||||||
exit_json(module, results, client)
|
module.exit_json(**results)
|
||||||
cleanup_tokens(client)
|
|
||||||
except F5ModuleError as ex:
|
except F5ModuleError as ex:
|
||||||
cleanup_tokens(client)
|
module.fail_json(msg=str(ex))
|
||||||
fail_json(module, ex, client)
|
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
|
|
|
@ -29,18 +29,22 @@ options:
|
||||||
- When used without other conditions it is equivalent of just sleeping.
|
- When used without other conditions it is equivalent of just sleeping.
|
||||||
- The default timeout is deliberately set to 2 hours because no individual
|
- The default timeout is deliberately set to 2 hours because no individual
|
||||||
REST API.
|
REST API.
|
||||||
|
type: int
|
||||||
default: 7200
|
default: 7200
|
||||||
delay:
|
delay:
|
||||||
description:
|
description:
|
||||||
- Number of seconds to wait before starting to poll.
|
- Number of seconds to wait before starting to poll.
|
||||||
|
type: int
|
||||||
default: 0
|
default: 0
|
||||||
sleep:
|
sleep:
|
||||||
default: 1
|
|
||||||
description:
|
description:
|
||||||
- Number of seconds to sleep between checks, before 2.3 this was hardcoded to 1 second.
|
- Number of seconds to sleep between checks, before 2.3 this was hardcoded to 1 second.
|
||||||
|
type: int
|
||||||
|
default: 1
|
||||||
msg:
|
msg:
|
||||||
description:
|
description:
|
||||||
- This overrides the normal error message from a failure to meet the required conditions.
|
- This overrides the normal error message from a failure to meet the required conditions.
|
||||||
|
type: str
|
||||||
extends_documentation_fragment: f5
|
extends_documentation_fragment: f5
|
||||||
author:
|
author:
|
||||||
- Tim Rupp (@caphrim007)
|
- Tim Rupp (@caphrim007)
|
||||||
|
@ -89,15 +93,11 @@ try:
|
||||||
from library.module_utils.network.f5.common import F5ModuleError
|
from library.module_utils.network.f5.common import F5ModuleError
|
||||||
from library.module_utils.network.f5.common import AnsibleF5Parameters
|
from library.module_utils.network.f5.common import AnsibleF5Parameters
|
||||||
from library.module_utils.network.f5.common import f5_argument_spec
|
from library.module_utils.network.f5.common import f5_argument_spec
|
||||||
from library.module_utils.network.f5.common import exit_json
|
|
||||||
from library.module_utils.network.f5.common import fail_json
|
|
||||||
except ImportError:
|
except ImportError:
|
||||||
from ansible.module_utils.network.f5.bigip import F5RestClient
|
from ansible.module_utils.network.f5.bigip import F5RestClient
|
||||||
from ansible.module_utils.network.f5.common import F5ModuleError
|
from ansible.module_utils.network.f5.common import F5ModuleError
|
||||||
from ansible.module_utils.network.f5.common import AnsibleF5Parameters
|
from ansible.module_utils.network.f5.common import AnsibleF5Parameters
|
||||||
from ansible.module_utils.network.f5.common import f5_argument_spec
|
from ansible.module_utils.network.f5.common import f5_argument_spec
|
||||||
from ansible.module_utils.network.f5.common import exit_json
|
|
||||||
from ansible.module_utils.network.f5.common import fail_json
|
|
||||||
|
|
||||||
|
|
||||||
def hard_timeout(module, want, start):
|
def hard_timeout(module, want, start):
|
||||||
|
@ -148,7 +148,7 @@ class Changes(Parameters):
|
||||||
class ModuleManager(object):
|
class ModuleManager(object):
|
||||||
def __init__(self, *args, **kwargs):
|
def __init__(self, *args, **kwargs):
|
||||||
self.module = kwargs.get('module', None)
|
self.module = kwargs.get('module', None)
|
||||||
self.client = kwargs.get('client', None)
|
self.client = F5RestClient(**self.module.params)
|
||||||
self.have = None
|
self.have = None
|
||||||
self.want = Parameters(params=self.module.params)
|
self.want = Parameters(params=self.module.params)
|
||||||
self.changes = Parameters()
|
self.changes = Parameters()
|
||||||
|
@ -334,14 +334,12 @@ def main():
|
||||||
supports_check_mode=spec.supports_check_mode
|
supports_check_mode=spec.supports_check_mode
|
||||||
)
|
)
|
||||||
|
|
||||||
client = F5RestClient(**module.params)
|
|
||||||
|
|
||||||
try:
|
try:
|
||||||
mm = ModuleManager(module=module, client=client)
|
mm = ModuleManager(module=module)
|
||||||
results = mm.exec_module()
|
results = mm.exec_module()
|
||||||
exit_json(module, results, client)
|
module.exit_json(**results)
|
||||||
except F5ModuleError as ex:
|
except F5ModuleError as ex:
|
||||||
fail_json(module, ex, client)
|
module.fail_json(msg=str(ex))
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
|
|
|
@ -26,6 +26,7 @@ options:
|
||||||
- Can specify a list of values to include a larger subset.
|
- Can specify a list of values to include a larger subset.
|
||||||
- Values can also be used with an initial C(!) to specify that a specific subset
|
- Values can also be used with an initial C(!) to specify that a specific subset
|
||||||
should not be collected.
|
should not be collected.
|
||||||
|
type: list
|
||||||
required: True
|
required: True
|
||||||
choices:
|
choices:
|
||||||
- all
|
- all
|
||||||
|
@ -827,7 +828,6 @@ try:
|
||||||
from library.module_utils.network.f5.bigiq import F5RestClient
|
from library.module_utils.network.f5.bigiq import F5RestClient
|
||||||
from library.module_utils.network.f5.common import F5ModuleError
|
from library.module_utils.network.f5.common import F5ModuleError
|
||||||
from library.module_utils.network.f5.common import AnsibleF5Parameters
|
from library.module_utils.network.f5.common import AnsibleF5Parameters
|
||||||
from library.module_utils.network.f5.common import cleanup_tokens
|
|
||||||
from library.module_utils.network.f5.common import f5_argument_spec
|
from library.module_utils.network.f5.common import f5_argument_spec
|
||||||
from library.module_utils.network.f5.common import fq_name
|
from library.module_utils.network.f5.common import fq_name
|
||||||
from library.module_utils.network.f5.common import flatten_boolean
|
from library.module_utils.network.f5.common import flatten_boolean
|
||||||
|
@ -837,7 +837,6 @@ except ImportError:
|
||||||
from ansible.module_utils.network.f5.bigiq import F5RestClient
|
from ansible.module_utils.network.f5.bigiq import F5RestClient
|
||||||
from ansible.module_utils.network.f5.common import F5ModuleError
|
from ansible.module_utils.network.f5.common import F5ModuleError
|
||||||
from ansible.module_utils.network.f5.common import AnsibleF5Parameters
|
from ansible.module_utils.network.f5.common import AnsibleF5Parameters
|
||||||
from ansible.module_utils.network.f5.common import cleanup_tokens
|
|
||||||
from ansible.module_utils.network.f5.common import f5_argument_spec
|
from ansible.module_utils.network.f5.common import f5_argument_spec
|
||||||
from ansible.module_utils.network.f5.common import fq_name
|
from ansible.module_utils.network.f5.common import fq_name
|
||||||
from ansible.module_utils.network.f5.common import flatten_boolean
|
from ansible.module_utils.network.f5.common import flatten_boolean
|
||||||
|
@ -2299,15 +2298,11 @@ def main():
|
||||||
supports_check_mode=spec.supports_check_mode
|
supports_check_mode=spec.supports_check_mode
|
||||||
)
|
)
|
||||||
|
|
||||||
client = F5RestClient(**module.params)
|
|
||||||
|
|
||||||
try:
|
try:
|
||||||
mm = ModuleManager(module=module, client=client)
|
mm = ModuleManager(module=module)
|
||||||
results = mm.exec_module()
|
results = mm.exec_module()
|
||||||
cleanup_tokens(client)
|
|
||||||
module.exit_json(**results)
|
module.exit_json(**results)
|
||||||
except F5ModuleError as ex:
|
except F5ModuleError as ex:
|
||||||
cleanup_tokens(client)
|
|
||||||
module.fail_json(msg=str(ex))
|
module.fail_json(msg=str(ex))
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -27,14 +27,17 @@ options:
|
||||||
BIG-IQ does not require this, this module does. If you do not do this,
|
BIG-IQ does not require this, this module does. If you do not do this,
|
||||||
the behavior of the module is undefined and you may end up putting
|
the behavior of the module is undefined and you may end up putting
|
||||||
licenses in the wrong registration key pool.
|
licenses in the wrong registration key pool.
|
||||||
|
type: str
|
||||||
required: True
|
required: True
|
||||||
license_key:
|
license_key:
|
||||||
description:
|
description:
|
||||||
- The license key to put in the pool.
|
- The license key to put in the pool.
|
||||||
|
type: str
|
||||||
required: True
|
required: True
|
||||||
description:
|
description:
|
||||||
description:
|
description:
|
||||||
- Description of the license.
|
- Description of the license.
|
||||||
|
type: str
|
||||||
accept_eula:
|
accept_eula:
|
||||||
description:
|
description:
|
||||||
- A key that signifies that you accept the F5 EULA for this license.
|
- A key that signifies that you accept the F5 EULA for this license.
|
||||||
|
@ -46,10 +49,11 @@ options:
|
||||||
- The state of the regkey license in the pool on the system.
|
- The state of the regkey license in the pool on the system.
|
||||||
- When C(present), guarantees that the license exists in the pool.
|
- When C(present), guarantees that the license exists in the pool.
|
||||||
- When C(absent), removes the license from the pool.
|
- When C(absent), removes the license from the pool.
|
||||||
default: present
|
type: str
|
||||||
choices:
|
choices:
|
||||||
- absent
|
- absent
|
||||||
- present
|
- present
|
||||||
|
default: present
|
||||||
requirements:
|
requirements:
|
||||||
- BIG-IQ >= 5.3.0
|
- BIG-IQ >= 5.3.0
|
||||||
extends_documentation_fragment: f5
|
extends_documentation_fragment: f5
|
||||||
|
@ -98,17 +102,11 @@ try:
|
||||||
from library.module_utils.network.f5.common import F5ModuleError
|
from library.module_utils.network.f5.common import F5ModuleError
|
||||||
from library.module_utils.network.f5.common import AnsibleF5Parameters
|
from library.module_utils.network.f5.common import AnsibleF5Parameters
|
||||||
from library.module_utils.network.f5.common import f5_argument_spec
|
from library.module_utils.network.f5.common import f5_argument_spec
|
||||||
from library.module_utils.network.f5.common import cleanup_tokens
|
|
||||||
from library.module_utils.network.f5.common import exit_json
|
|
||||||
from library.module_utils.network.f5.common import fail_json
|
|
||||||
except ImportError:
|
except ImportError:
|
||||||
from ansible.module_utils.network.f5.bigiq import F5RestClient
|
from ansible.module_utils.network.f5.bigiq import F5RestClient
|
||||||
from ansible.module_utils.network.f5.common import F5ModuleError
|
from ansible.module_utils.network.f5.common import F5ModuleError
|
||||||
from ansible.module_utils.network.f5.common import AnsibleF5Parameters
|
from ansible.module_utils.network.f5.common import AnsibleF5Parameters
|
||||||
from ansible.module_utils.network.f5.common import f5_argument_spec
|
from ansible.module_utils.network.f5.common import f5_argument_spec
|
||||||
from ansible.module_utils.network.f5.common import cleanup_tokens
|
|
||||||
from ansible.module_utils.network.f5.common import exit_json
|
|
||||||
from ansible.module_utils.network.f5.common import fail_json
|
|
||||||
|
|
||||||
|
|
||||||
class Parameters(AnsibleF5Parameters):
|
class Parameters(AnsibleF5Parameters):
|
||||||
|
@ -222,7 +220,7 @@ class Difference(object):
|
||||||
class ModuleManager(object):
|
class ModuleManager(object):
|
||||||
def __init__(self, *args, **kwargs):
|
def __init__(self, *args, **kwargs):
|
||||||
self.module = kwargs.get('module', None)
|
self.module = kwargs.get('module', None)
|
||||||
self.client = kwargs.get('client', None)
|
self.client = F5RestClient(**self.module.params)
|
||||||
self.want = ModuleParameters(client=self.client, params=self.module.params)
|
self.want = ModuleParameters(client=self.client, params=self.module.params)
|
||||||
self.have = ApiParameters()
|
self.have = ApiParameters()
|
||||||
self.changes = UsableChanges()
|
self.changes = UsableChanges()
|
||||||
|
@ -472,16 +470,12 @@ def main():
|
||||||
required_if=spec.required_if,
|
required_if=spec.required_if,
|
||||||
)
|
)
|
||||||
|
|
||||||
client = F5RestClient(**module.params)
|
|
||||||
|
|
||||||
try:
|
try:
|
||||||
mm = ModuleManager(module=module, client=client)
|
mm = ModuleManager(module=module)
|
||||||
results = mm.exec_module()
|
results = mm.exec_module()
|
||||||
cleanup_tokens(client)
|
module.exit_json(**results)
|
||||||
exit_json(module, results, client)
|
|
||||||
except F5ModuleError as ex:
|
except F5ModuleError as ex:
|
||||||
cleanup_tokens(client)
|
module.fail_json(msg=str(ex))
|
||||||
fail_json(module, ex, client)
|
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
|
|
|
@ -25,10 +25,12 @@ options:
|
||||||
pool:
|
pool:
|
||||||
description:
|
description:
|
||||||
- The registration key pool to use.
|
- The registration key pool to use.
|
||||||
|
type: str
|
||||||
required: True
|
required: True
|
||||||
key:
|
key:
|
||||||
description:
|
description:
|
||||||
- The registration key that you want to assign from the pool.
|
- The registration key that you want to assign from the pool.
|
||||||
|
type: str
|
||||||
required: True
|
required: True
|
||||||
device:
|
device:
|
||||||
description:
|
description:
|
||||||
|
@ -40,6 +42,7 @@ options:
|
||||||
one device with the same name. BIG-IQ internally recognizes devices by their ID,
|
one device with the same name. BIG-IQ internally recognizes devices by their ID,
|
||||||
and therefore, this module's cannot guarantee that the correct device will be
|
and therefore, this module's cannot guarantee that the correct device will be
|
||||||
registered. The device returned is the device that will be used.
|
registered. The device returned is the device that will be used.
|
||||||
|
type: str
|
||||||
managed:
|
managed:
|
||||||
description:
|
description:
|
||||||
- Whether the specified device is a managed or un-managed device.
|
- Whether the specified device is a managed or un-managed device.
|
||||||
|
@ -49,6 +52,7 @@ options:
|
||||||
description:
|
description:
|
||||||
- Specifies the port of the remote device to connect to.
|
- Specifies the port of the remote device to connect to.
|
||||||
- If this parameter is not specified, the default of C(443) will be used.
|
- If this parameter is not specified, the default of C(443) will be used.
|
||||||
|
type: int
|
||||||
default: 443
|
default: 443
|
||||||
device_username:
|
device_username:
|
||||||
description:
|
description:
|
||||||
|
@ -56,19 +60,22 @@ options:
|
||||||
- This username should be one that has sufficient privileges on the remote device
|
- This username should be one that has sufficient privileges on the remote device
|
||||||
to do licensing. Usually this is the C(Administrator) role.
|
to do licensing. Usually this is the C(Administrator) role.
|
||||||
- When C(managed) is C(no), this parameter is required.
|
- When C(managed) is C(no), this parameter is required.
|
||||||
|
type: str
|
||||||
device_password:
|
device_password:
|
||||||
description:
|
description:
|
||||||
- The password of the C(device_username).
|
- The password of the C(device_username).
|
||||||
- When C(managed) is C(no), this parameter is required.
|
- When C(managed) is C(no), this parameter is required.
|
||||||
|
type: str
|
||||||
state:
|
state:
|
||||||
description:
|
description:
|
||||||
- When C(present), ensures that the device is assigned the specified license.
|
- When C(present), ensures that the device is assigned the specified license.
|
||||||
- When C(absent), ensures the license is revokes from the remote device and freed
|
- When C(absent), ensures the license is revokes from the remote device and freed
|
||||||
on the BIG-IQ.
|
on the BIG-IQ.
|
||||||
default: present
|
type: str
|
||||||
choices:
|
choices:
|
||||||
- present
|
- present
|
||||||
- absent
|
- absent
|
||||||
|
default: present
|
||||||
extends_documentation_fragment: f5
|
extends_documentation_fragment: f5
|
||||||
author:
|
author:
|
||||||
- Tim Rupp (@caphrim007)
|
- Tim Rupp (@caphrim007)
|
||||||
|
@ -131,16 +138,12 @@ try:
|
||||||
from library.module_utils.network.f5.common import F5ModuleError
|
from library.module_utils.network.f5.common import F5ModuleError
|
||||||
from library.module_utils.network.f5.common import AnsibleF5Parameters
|
from library.module_utils.network.f5.common import AnsibleF5Parameters
|
||||||
from library.module_utils.network.f5.common import f5_argument_spec
|
from library.module_utils.network.f5.common import f5_argument_spec
|
||||||
from library.module_utils.network.f5.common import exit_json
|
|
||||||
from library.module_utils.network.f5.common import fail_json
|
|
||||||
from library.module_utils.network.f5.ipaddress import is_valid_ip
|
from library.module_utils.network.f5.ipaddress import is_valid_ip
|
||||||
except ImportError:
|
except ImportError:
|
||||||
from ansible.module_utils.network.f5.bigiq import F5RestClient
|
from ansible.module_utils.network.f5.bigiq import F5RestClient
|
||||||
from ansible.module_utils.network.f5.common import F5ModuleError
|
from ansible.module_utils.network.f5.common import F5ModuleError
|
||||||
from ansible.module_utils.network.f5.common import AnsibleF5Parameters
|
from ansible.module_utils.network.f5.common import AnsibleF5Parameters
|
||||||
from ansible.module_utils.network.f5.common import f5_argument_spec
|
from ansible.module_utils.network.f5.common import f5_argument_spec
|
||||||
from ansible.module_utils.network.f5.common import exit_json
|
|
||||||
from ansible.module_utils.network.f5.common import fail_json
|
|
||||||
from ansible.module_utils.network.f5.ipaddress import is_valid_ip
|
from ansible.module_utils.network.f5.ipaddress import is_valid_ip
|
||||||
|
|
||||||
|
|
||||||
|
@ -394,7 +397,7 @@ class Difference(object):
|
||||||
class ModuleManager(object):
|
class ModuleManager(object):
|
||||||
def __init__(self, *args, **kwargs):
|
def __init__(self, *args, **kwargs):
|
||||||
self.module = kwargs.get('module', None)
|
self.module = kwargs.get('module', None)
|
||||||
self.client = kwargs.get('client', None)
|
self.client = F5RestClient(**self.module.params)
|
||||||
self.want = ModuleParameters(params=self.module.params, client=self.client)
|
self.want = ModuleParameters(params=self.module.params, client=self.client)
|
||||||
self.have = ApiParameters()
|
self.have = ApiParameters()
|
||||||
self.changes = UsableChanges()
|
self.changes = UsableChanges()
|
||||||
|
@ -620,14 +623,12 @@ def main():
|
||||||
required_if=spec.required_if
|
required_if=spec.required_if
|
||||||
)
|
)
|
||||||
|
|
||||||
client = F5RestClient(**module.params)
|
|
||||||
|
|
||||||
try:
|
try:
|
||||||
mm = ModuleManager(module=module, client=client)
|
mm = ModuleManager(module=module)
|
||||||
results = mm.exec_module()
|
results = mm.exec_module()
|
||||||
exit_json(module, results, client)
|
module.exit_json(**results)
|
||||||
except F5ModuleError as ex:
|
except F5ModuleError as ex:
|
||||||
fail_json(module, ex, client)
|
module.fail_json(msg=str(ex))
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
|
|
|
@ -29,20 +29,23 @@ options:
|
||||||
BIG-IQ does not require this, this module does. If you do not do this,
|
BIG-IQ does not require this, this module does. If you do not do this,
|
||||||
the behavior of the module is undefined and you may end up putting
|
the behavior of the module is undefined and you may end up putting
|
||||||
licenses in the wrong registration key pool.
|
licenses in the wrong registration key pool.
|
||||||
|
type: str
|
||||||
required: True
|
required: True
|
||||||
description:
|
description:
|
||||||
description:
|
description:
|
||||||
- A description to attach to the pool.
|
- A description to attach to the pool.
|
||||||
|
type: str
|
||||||
state:
|
state:
|
||||||
description:
|
description:
|
||||||
- The state of the regkey pool on the system.
|
- The state of the regkey pool on the system.
|
||||||
- When C(present), guarantees that the pool exists.
|
- When C(present), guarantees that the pool exists.
|
||||||
- When C(absent), removes the pool, and the licenses it contains, from the
|
- When C(absent), removes the pool, and the licenses it contains, from the
|
||||||
system.
|
system.
|
||||||
default: present
|
type: str
|
||||||
choices:
|
choices:
|
||||||
- absent
|
- absent
|
||||||
- present
|
- present
|
||||||
|
default: present
|
||||||
requirements:
|
requirements:
|
||||||
- BIG-IQ >= 5.3.0
|
- BIG-IQ >= 5.3.0
|
||||||
extends_documentation_fragment: f5
|
extends_documentation_fragment: f5
|
||||||
|
@ -198,7 +201,6 @@ class Difference(object):
|
||||||
class ModuleManager(object):
|
class ModuleManager(object):
|
||||||
def __init__(self, *args, **kwargs):
|
def __init__(self, *args, **kwargs):
|
||||||
self.module = kwargs.get('module', None)
|
self.module = kwargs.get('module', None)
|
||||||
self.client = kwargs.get('client', None)
|
|
||||||
self.client = F5RestClient(**self.module.params)
|
self.client = F5RestClient(**self.module.params)
|
||||||
self.want = ModuleParameters(client=self.client, params=self.module.params)
|
self.want = ModuleParameters(client=self.client, params=self.module.params)
|
||||||
self.have = ApiParameters()
|
self.have = ApiParameters()
|
||||||
|
|
|
@ -26,6 +26,7 @@ options:
|
||||||
license_key:
|
license_key:
|
||||||
description:
|
description:
|
||||||
- The license key to install and activate.
|
- The license key to install and activate.
|
||||||
|
type: str
|
||||||
required: True
|
required: True
|
||||||
accept_eula:
|
accept_eula:
|
||||||
description:
|
description:
|
||||||
|
@ -38,10 +39,11 @@ options:
|
||||||
- The state of the utility license on the system.
|
- The state of the utility license on the system.
|
||||||
- When C(present), guarantees that the license exists.
|
- When C(present), guarantees that the license exists.
|
||||||
- When C(absent), removes the license from the system.
|
- When C(absent), removes the license from the system.
|
||||||
default: present
|
type: str
|
||||||
choices:
|
choices:
|
||||||
- absent
|
- absent
|
||||||
- present
|
- present
|
||||||
|
default: present
|
||||||
requirements:
|
requirements:
|
||||||
- BIG-IQ >= 5.3.0
|
- BIG-IQ >= 5.3.0
|
||||||
extends_documentation_fragment: f5
|
extends_documentation_fragment: f5
|
||||||
|
@ -85,15 +87,11 @@ try:
|
||||||
from library.module_utils.network.f5.common import F5ModuleError
|
from library.module_utils.network.f5.common import F5ModuleError
|
||||||
from library.module_utils.network.f5.common import AnsibleF5Parameters
|
from library.module_utils.network.f5.common import AnsibleF5Parameters
|
||||||
from library.module_utils.network.f5.common import f5_argument_spec
|
from library.module_utils.network.f5.common import f5_argument_spec
|
||||||
from library.module_utils.network.f5.common import exit_json
|
|
||||||
from library.module_utils.network.f5.common import fail_json
|
|
||||||
except ImportError:
|
except ImportError:
|
||||||
from ansible.module_utils.network.f5.bigiq import F5RestClient
|
from ansible.module_utils.network.f5.bigiq import F5RestClient
|
||||||
from ansible.module_utils.network.f5.common import F5ModuleError
|
from ansible.module_utils.network.f5.common import F5ModuleError
|
||||||
from ansible.module_utils.network.f5.common import AnsibleF5Parameters
|
from ansible.module_utils.network.f5.common import AnsibleF5Parameters
|
||||||
from ansible.module_utils.network.f5.common import f5_argument_spec
|
from ansible.module_utils.network.f5.common import f5_argument_spec
|
||||||
from ansible.module_utils.network.f5.common import exit_json
|
|
||||||
from ansible.module_utils.network.f5.common import fail_json
|
|
||||||
|
|
||||||
|
|
||||||
class Parameters(AnsibleF5Parameters):
|
class Parameters(AnsibleF5Parameters):
|
||||||
|
@ -179,7 +177,7 @@ class Difference(object):
|
||||||
class ModuleManager(object):
|
class ModuleManager(object):
|
||||||
def __init__(self, *args, **kwargs):
|
def __init__(self, *args, **kwargs):
|
||||||
self.module = kwargs.get('module', None)
|
self.module = kwargs.get('module', None)
|
||||||
self.client = kwargs.get('client', None)
|
self.client = F5RestClient(**self.module.params)
|
||||||
self.want = ModuleParameters(client=self.client, params=self.module.params)
|
self.want = ModuleParameters(client=self.client, params=self.module.params)
|
||||||
self.have = ApiParameters()
|
self.have = ApiParameters()
|
||||||
self.changes = UsableChanges()
|
self.changes = UsableChanges()
|
||||||
|
@ -453,11 +451,11 @@ def main():
|
||||||
client = F5RestClient(**module.params)
|
client = F5RestClient(**module.params)
|
||||||
|
|
||||||
try:
|
try:
|
||||||
mm = ModuleManager(module=module, client=client)
|
mm = ModuleManager(module=module)
|
||||||
results = mm.exec_module()
|
results = mm.exec_module()
|
||||||
exit_json(module, results, client)
|
module.exit_json(**results)
|
||||||
except F5ModuleError as ex:
|
except F5ModuleError as ex:
|
||||||
fail_json(module, ex, client)
|
module.fail_json(msg=str(ex))
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
|
|
|
@ -28,19 +28,22 @@ options:
|
||||||
- Depending on your license, you may have different units of measures
|
- Depending on your license, you may have different units of measures
|
||||||
available to you. If a particular unit is not available to you, the module
|
available to you. If a particular unit is not available to you, the module
|
||||||
will notify you at licensing time.
|
will notify you at licensing time.
|
||||||
default: hourly
|
type: str
|
||||||
choices:
|
choices:
|
||||||
- hourly
|
- hourly
|
||||||
- daily
|
- daily
|
||||||
- monthly
|
- monthly
|
||||||
- yearly
|
- yearly
|
||||||
|
default: hourly
|
||||||
key:
|
key:
|
||||||
description:
|
description:
|
||||||
- The registration key that you want choose an offering from.
|
- The registration key that you want choose an offering from.
|
||||||
|
type: str
|
||||||
required: True
|
required: True
|
||||||
offering:
|
offering:
|
||||||
description:
|
description:
|
||||||
- Name of the license offering to assign to the device.
|
- Name of the license offering to assign to the device.
|
||||||
|
type: str
|
||||||
device:
|
device:
|
||||||
description:
|
description:
|
||||||
- When C(managed) is C(no), specifies the address, or hostname, where the BIG-IQ
|
- When C(managed) is C(no), specifies the address, or hostname, where the BIG-IQ
|
||||||
|
@ -51,6 +54,7 @@ options:
|
||||||
one device with the same name. BIG-IQ internally recognizes devices by their ID,
|
one device with the same name. BIG-IQ internally recognizes devices by their ID,
|
||||||
and therefore, this module's cannot guarantee that the correct device will be
|
and therefore, this module's cannot guarantee that the correct device will be
|
||||||
registered. The device returned is the device that will be used.
|
registered. The device returned is the device that will be used.
|
||||||
|
type: str
|
||||||
managed:
|
managed:
|
||||||
description:
|
description:
|
||||||
- Whether the specified device is a managed or un-managed device.
|
- Whether the specified device is a managed or un-managed device.
|
||||||
|
@ -60,6 +64,7 @@ options:
|
||||||
description:
|
description:
|
||||||
- Specifies the port of the remote device to connect to.
|
- Specifies the port of the remote device to connect to.
|
||||||
- If this parameter is not specified, the default of C(443) will be used.
|
- If this parameter is not specified, the default of C(443) will be used.
|
||||||
|
type: int
|
||||||
default: 443
|
default: 443
|
||||||
device_username:
|
device_username:
|
||||||
description:
|
description:
|
||||||
|
@ -67,19 +72,22 @@ options:
|
||||||
- This username should be one that has sufficient privileges on the remote device
|
- This username should be one that has sufficient privileges on the remote device
|
||||||
to do licensing. Usually this is the C(Administrator) role.
|
to do licensing. Usually this is the C(Administrator) role.
|
||||||
- When C(managed) is C(no), this parameter is required.
|
- When C(managed) is C(no), this parameter is required.
|
||||||
|
type: str
|
||||||
device_password:
|
device_password:
|
||||||
description:
|
description:
|
||||||
- The password of the C(device_username).
|
- The password of the C(device_username).
|
||||||
- When C(managed) is C(no), this parameter is required.
|
- When C(managed) is C(no), this parameter is required.
|
||||||
|
type: str
|
||||||
state:
|
state:
|
||||||
description:
|
description:
|
||||||
- When C(present), ensures that the device is assigned the specified license.
|
- When C(present), ensures that the device is assigned the specified license.
|
||||||
- When C(absent), ensures the license is revokes from the remote device and freed
|
- When C(absent), ensures the license is revokes from the remote device and freed
|
||||||
on the BIG-IQ.
|
on the BIG-IQ.
|
||||||
default: present
|
type: str
|
||||||
choices:
|
choices:
|
||||||
- present
|
- present
|
||||||
- absent
|
- absent
|
||||||
|
default: present
|
||||||
extends_documentation_fragment: f5
|
extends_documentation_fragment: f5
|
||||||
author:
|
author:
|
||||||
- Tim Rupp (@caphrim007)
|
- Tim Rupp (@caphrim007)
|
||||||
|
@ -141,16 +149,12 @@ try:
|
||||||
from library.module_utils.network.f5.common import F5ModuleError
|
from library.module_utils.network.f5.common import F5ModuleError
|
||||||
from library.module_utils.network.f5.common import AnsibleF5Parameters
|
from library.module_utils.network.f5.common import AnsibleF5Parameters
|
||||||
from library.module_utils.network.f5.common import f5_argument_spec
|
from library.module_utils.network.f5.common import f5_argument_spec
|
||||||
from library.module_utils.network.f5.common import exit_json
|
|
||||||
from library.module_utils.network.f5.common import fail_json
|
|
||||||
from library.module_utils.network.f5.ipaddress import is_valid_ip
|
from library.module_utils.network.f5.ipaddress import is_valid_ip
|
||||||
except ImportError:
|
except ImportError:
|
||||||
from ansible.module_utils.network.f5.bigiq import F5RestClient
|
from ansible.module_utils.network.f5.bigiq import F5RestClient
|
||||||
from ansible.module_utils.network.f5.common import F5ModuleError
|
from ansible.module_utils.network.f5.common import F5ModuleError
|
||||||
from ansible.module_utils.network.f5.common import AnsibleF5Parameters
|
from ansible.module_utils.network.f5.common import AnsibleF5Parameters
|
||||||
from ansible.module_utils.network.f5.common import f5_argument_spec
|
from ansible.module_utils.network.f5.common import f5_argument_spec
|
||||||
from ansible.module_utils.network.f5.common import exit_json
|
|
||||||
from ansible.module_utils.network.f5.common import fail_json
|
|
||||||
from ansible.module_utils.network.f5.ipaddress import is_valid_ip
|
from ansible.module_utils.network.f5.ipaddress import is_valid_ip
|
||||||
|
|
||||||
|
|
||||||
|
@ -406,7 +410,7 @@ class Difference(object):
|
||||||
class ModuleManager(object):
|
class ModuleManager(object):
|
||||||
def __init__(self, *args, **kwargs):
|
def __init__(self, *args, **kwargs):
|
||||||
self.module = kwargs.get('module', None)
|
self.module = kwargs.get('module', None)
|
||||||
self.client = kwargs.get('client', None)
|
self.client = F5RestClient(**self.module.params)
|
||||||
self.want = ModuleParameters(params=self.module.params, client=self.client)
|
self.want = ModuleParameters(params=self.module.params, client=self.client)
|
||||||
self.have = ApiParameters()
|
self.have = ApiParameters()
|
||||||
self.changes = UsableChanges()
|
self.changes = UsableChanges()
|
||||||
|
@ -629,14 +633,12 @@ def main():
|
||||||
required_if=spec.required_if
|
required_if=spec.required_if
|
||||||
)
|
)
|
||||||
|
|
||||||
client = F5RestClient(**module.params)
|
|
||||||
|
|
||||||
try:
|
try:
|
||||||
mm = ModuleManager(module=module, client=client)
|
mm = ModuleManager(module=module)
|
||||||
results = mm.exec_module()
|
results = mm.exec_module()
|
||||||
exit_json(module, results, client)
|
module.exit_json(**results)
|
||||||
except F5ModuleError as ex:
|
except F5ModuleError as ex:
|
||||||
fail_json(module, ex, client)
|
module.fail_json(msg=str(ex))
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
|
|
|
@ -88,9 +88,11 @@ class TestUntypedManager(unittest.TestCase):
|
||||||
def test_create(self, *args):
|
def test_create(self, *args):
|
||||||
set_module_args(dict(
|
set_module_args(dict(
|
||||||
name='selector1',
|
name='selector1',
|
||||||
password='password',
|
provider=dict(
|
||||||
server='localhost',
|
server='localhost',
|
||||||
|
password='password',
|
||||||
user='admin'
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
|
|
|
@ -116,9 +116,11 @@ class TestManager(unittest.TestCase):
|
||||||
lacp_enabled=True,
|
lacp_enabled=True,
|
||||||
lacp_mode='active',
|
lacp_mode='active',
|
||||||
lacp_timeout='long',
|
lacp_timeout='long',
|
||||||
|
provider=dict(
|
||||||
server='localhost',
|
server='localhost',
|
||||||
password='password',
|
password='password',
|
||||||
user='admin'
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
|
|
|
@ -92,9 +92,11 @@ class TestManager(unittest.TestCase):
|
||||||
name='foo',
|
name='foo',
|
||||||
profile='ipip',
|
profile='ipip',
|
||||||
local_address='2.2.2.2.',
|
local_address='2.2.2.2.',
|
||||||
|
provider=dict(
|
||||||
server='localhost',
|
server='localhost',
|
||||||
password='password',
|
password='password',
|
||||||
user='admin'
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
|
|
|
@ -152,10 +152,12 @@ class TestV1Manager(unittest.TestCase):
|
||||||
def test_ucs_explicit_present(self, *args):
|
def test_ucs_explicit_present(self, *args):
|
||||||
set_module_args(dict(
|
set_module_args(dict(
|
||||||
ucs="/root/bigip.localhost.localdomain.ucs",
|
ucs="/root/bigip.localhost.localdomain.ucs",
|
||||||
|
state='present',
|
||||||
|
provider=dict(
|
||||||
server='localhost',
|
server='localhost',
|
||||||
password='password',
|
password='password',
|
||||||
user='admin',
|
user='admin'
|
||||||
state='present'
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
|
@ -178,10 +180,12 @@ class TestV1Manager(unittest.TestCase):
|
||||||
def test_ucs_installed(self, *args):
|
def test_ucs_installed(self, *args):
|
||||||
set_module_args(dict(
|
set_module_args(dict(
|
||||||
ucs="/root/bigip.localhost.localdomain.ucs",
|
ucs="/root/bigip.localhost.localdomain.ucs",
|
||||||
|
state='installed',
|
||||||
|
provider=dict(
|
||||||
server='localhost',
|
server='localhost',
|
||||||
password='password',
|
password='password',
|
||||||
user='admin',
|
user='admin'
|
||||||
state='installed'
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
|
@ -205,10 +209,12 @@ class TestV1Manager(unittest.TestCase):
|
||||||
def test_ucs_absent_exists(self, *args):
|
def test_ucs_absent_exists(self, *args):
|
||||||
set_module_args(dict(
|
set_module_args(dict(
|
||||||
ucs="/root/bigip.localhost.localdomain.ucs",
|
ucs="/root/bigip.localhost.localdomain.ucs",
|
||||||
|
state='absent',
|
||||||
|
provider=dict(
|
||||||
server='localhost',
|
server='localhost',
|
||||||
password='password',
|
password='password',
|
||||||
user='admin',
|
user='admin'
|
||||||
state='absent'
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
|
@ -231,10 +237,12 @@ class TestV1Manager(unittest.TestCase):
|
||||||
def test_ucs_absent_fails(self, *args):
|
def test_ucs_absent_fails(self, *args):
|
||||||
set_module_args(dict(
|
set_module_args(dict(
|
||||||
ucs="/root/bigip.localhost.localdomain.ucs",
|
ucs="/root/bigip.localhost.localdomain.ucs",
|
||||||
|
state='absent',
|
||||||
|
provider=dict(
|
||||||
server='localhost',
|
server='localhost',
|
||||||
password='password',
|
password='password',
|
||||||
user='admin',
|
user='admin'
|
||||||
state='absent'
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
|
@ -263,9 +271,11 @@ class TestV2Manager(unittest.TestCase):
|
||||||
def test_ucs_default_present(self, *args):
|
def test_ucs_default_present(self, *args):
|
||||||
set_module_args(dict(
|
set_module_args(dict(
|
||||||
ucs="/root/bigip.localhost.localdomain.ucs",
|
ucs="/root/bigip.localhost.localdomain.ucs",
|
||||||
|
provider=dict(
|
||||||
server='localhost',
|
server='localhost',
|
||||||
password='password',
|
password='password',
|
||||||
user='admin'
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
|
@ -288,10 +298,12 @@ class TestV2Manager(unittest.TestCase):
|
||||||
def test_ucs_explicit_present(self, *args):
|
def test_ucs_explicit_present(self, *args):
|
||||||
set_module_args(dict(
|
set_module_args(dict(
|
||||||
ucs="/root/bigip.localhost.localdomain.ucs",
|
ucs="/root/bigip.localhost.localdomain.ucs",
|
||||||
|
state='present',
|
||||||
|
provider=dict(
|
||||||
server='localhost',
|
server='localhost',
|
||||||
password='password',
|
password='password',
|
||||||
user='admin',
|
user='admin'
|
||||||
state='present'
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
|
@ -314,10 +326,12 @@ class TestV2Manager(unittest.TestCase):
|
||||||
def test_ucs_installed(self, *args):
|
def test_ucs_installed(self, *args):
|
||||||
set_module_args(dict(
|
set_module_args(dict(
|
||||||
ucs="/root/bigip.localhost.localdomain.ucs",
|
ucs="/root/bigip.localhost.localdomain.ucs",
|
||||||
|
state='installed',
|
||||||
|
provider=dict(
|
||||||
server='localhost',
|
server='localhost',
|
||||||
password='password',
|
password='password',
|
||||||
user='admin',
|
user='admin'
|
||||||
state='installed'
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
|
@ -341,10 +355,12 @@ class TestV2Manager(unittest.TestCase):
|
||||||
def test_ucs_absent_exists(self, *args):
|
def test_ucs_absent_exists(self, *args):
|
||||||
set_module_args(dict(
|
set_module_args(dict(
|
||||||
ucs="/root/bigip.localhost.localdomain.ucs",
|
ucs="/root/bigip.localhost.localdomain.ucs",
|
||||||
|
state='absent',
|
||||||
|
provider=dict(
|
||||||
server='localhost',
|
server='localhost',
|
||||||
password='password',
|
password='password',
|
||||||
user='admin',
|
user='admin'
|
||||||
state='absent'
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
|
@ -367,10 +383,12 @@ class TestV2Manager(unittest.TestCase):
|
||||||
def test_ucs_absent_fails(self, *args):
|
def test_ucs_absent_fails(self, *args):
|
||||||
set_module_args(dict(
|
set_module_args(dict(
|
||||||
ucs="/root/bigip.localhost.localdomain.ucs",
|
ucs="/root/bigip.localhost.localdomain.ucs",
|
||||||
|
state='absent',
|
||||||
|
provider=dict(
|
||||||
server='localhost',
|
server='localhost',
|
||||||
password='password',
|
password='password',
|
||||||
user='admin',
|
user='admin'
|
||||||
state='absent'
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
|
|
|
@ -76,9 +76,6 @@ class TestParameters(unittest.TestCase):
|
||||||
force='yes',
|
force='yes',
|
||||||
fail_on_missing='no',
|
fail_on_missing='no',
|
||||||
src='remote.ucs',
|
src='remote.ucs',
|
||||||
password='password',
|
|
||||||
server='localhost',
|
|
||||||
user='admin'
|
|
||||||
)
|
)
|
||||||
p = Parameters(params=args)
|
p = Parameters(params=args)
|
||||||
assert p.backup == 'yes'
|
assert p.backup == 'yes'
|
||||||
|
@ -97,14 +94,17 @@ class TestV1Manager(unittest.TestCase):
|
||||||
force='yes',
|
force='yes',
|
||||||
fail_on_missing='no',
|
fail_on_missing='no',
|
||||||
src='remote.ucs',
|
src='remote.ucs',
|
||||||
password='password',
|
provider=dict(
|
||||||
server='localhost',
|
server='localhost',
|
||||||
|
password='password',
|
||||||
user='admin'
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
argument_spec=self.spec.argument_spec,
|
argument_spec=self.spec.argument_spec,
|
||||||
supports_check_mode=self.spec.supports_check_mode
|
supports_check_mode=self.spec.supports_check_mode,
|
||||||
|
add_file_common_args=self.spec.add_file_common_args
|
||||||
)
|
)
|
||||||
|
|
||||||
# Override methods to force specific logic in the module to happen
|
# Override methods to force specific logic in the module to happen
|
||||||
|
|
|
@ -115,10 +115,12 @@ class TestManager(unittest.TestCase):
|
||||||
username_credential='someuser',
|
username_credential='someuser',
|
||||||
password_credential='testpass',
|
password_credential='testpass',
|
||||||
partition_access=access,
|
partition_access=access,
|
||||||
|
update_password='on_create',
|
||||||
|
provider=dict(
|
||||||
server='localhost',
|
server='localhost',
|
||||||
password='password',
|
password='password',
|
||||||
user='admin',
|
user='admin'
|
||||||
update_password='on_create'
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
|
@ -145,9 +147,11 @@ class TestManager(unittest.TestCase):
|
||||||
set_module_args(dict(
|
set_module_args(dict(
|
||||||
username_credential='someuser',
|
username_credential='someuser',
|
||||||
partition_access=access,
|
partition_access=access,
|
||||||
|
provider=dict(
|
||||||
server='localhost',
|
server='localhost',
|
||||||
password='password',
|
password='password',
|
||||||
user='admin'
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
|
@ -172,9 +176,11 @@ class TestManager(unittest.TestCase):
|
||||||
def test_create_user_partition_access_raises(self, *args):
|
def test_create_user_partition_access_raises(self, *args):
|
||||||
set_module_args(dict(
|
set_module_args(dict(
|
||||||
username_credential='someuser',
|
username_credential='someuser',
|
||||||
password='password',
|
provider=dict(
|
||||||
server='localhost',
|
server='localhost',
|
||||||
|
password='password',
|
||||||
user='admin'
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
|
@ -204,11 +210,13 @@ class TestManager(unittest.TestCase):
|
||||||
username_credential='someuser',
|
username_credential='someuser',
|
||||||
password_credential='testpass',
|
password_credential='testpass',
|
||||||
partition_access=access,
|
partition_access=access,
|
||||||
password='password',
|
|
||||||
server='localhost',
|
|
||||||
update_password='on_create',
|
update_password='on_create',
|
||||||
user='admin',
|
shell='bash',
|
||||||
shell='bash'
|
provider=dict(
|
||||||
|
server='localhost',
|
||||||
|
password='password',
|
||||||
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
|
@ -237,10 +245,12 @@ class TestManager(unittest.TestCase):
|
||||||
password_credential='testpass',
|
password_credential='testpass',
|
||||||
partition_access=access,
|
partition_access=access,
|
||||||
update_password='on_create',
|
update_password='on_create',
|
||||||
password='password',
|
shell='bash',
|
||||||
|
provider=dict(
|
||||||
server='localhost',
|
server='localhost',
|
||||||
user='admin',
|
password='password',
|
||||||
shell='bash'
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
|
@ -268,9 +278,11 @@ class TestManager(unittest.TestCase):
|
||||||
set_module_args(dict(
|
set_module_args(dict(
|
||||||
username_credential='someuser',
|
username_credential='someuser',
|
||||||
password_credential='testpass',
|
password_credential='testpass',
|
||||||
password='password',
|
provider=dict(
|
||||||
server='localhost',
|
server='localhost',
|
||||||
|
password='password',
|
||||||
user='admin'
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
|
@ -300,9 +312,11 @@ class TestManager(unittest.TestCase):
|
||||||
set_module_args(dict(
|
set_module_args(dict(
|
||||||
username_credential='someuser',
|
username_credential='someuser',
|
||||||
password_credential='testpass',
|
password_credential='testpass',
|
||||||
password='password',
|
provider=dict(
|
||||||
server='localhost',
|
server='localhost',
|
||||||
|
password='password',
|
||||||
user='admin'
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
|
@ -331,10 +345,12 @@ class TestManager(unittest.TestCase):
|
||||||
def test_update_user_shell_to_none(self, *args):
|
def test_update_user_shell_to_none(self, *args):
|
||||||
set_module_args(dict(
|
set_module_args(dict(
|
||||||
username_credential='someuser',
|
username_credential='someuser',
|
||||||
password='password',
|
shell='none',
|
||||||
|
provider=dict(
|
||||||
server='localhost',
|
server='localhost',
|
||||||
user='admin',
|
password='password',
|
||||||
shell='none'
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
|
@ -369,10 +385,12 @@ class TestManager(unittest.TestCase):
|
||||||
def test_update_user_shell_to_none_shell_attribute_missing(self, *args):
|
def test_update_user_shell_to_none_shell_attribute_missing(self, *args):
|
||||||
set_module_args(dict(
|
set_module_args(dict(
|
||||||
username_credential='someuser',
|
username_credential='someuser',
|
||||||
password='password',
|
shell='none',
|
||||||
|
provider=dict(
|
||||||
server='localhost',
|
server='localhost',
|
||||||
user='admin',
|
password='password',
|
||||||
shell='none'
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
|
@ -408,10 +426,12 @@ class TestManager(unittest.TestCase):
|
||||||
def test_update_user_shell_to_bash(self, *args):
|
def test_update_user_shell_to_bash(self, *args):
|
||||||
set_module_args(dict(
|
set_module_args(dict(
|
||||||
username_credential='someuser',
|
username_credential='someuser',
|
||||||
password='password',
|
shell='bash',
|
||||||
|
provider=dict(
|
||||||
server='localhost',
|
server='localhost',
|
||||||
user='admin',
|
password='password',
|
||||||
shell='bash'
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
|
@ -448,10 +468,12 @@ class TestManager(unittest.TestCase):
|
||||||
def test_update_user_shell_to_bash_mutliple_roles(self, *args):
|
def test_update_user_shell_to_bash_mutliple_roles(self, *args):
|
||||||
set_module_args(dict(
|
set_module_args(dict(
|
||||||
username_credential='someuser',
|
username_credential='someuser',
|
||||||
password='password',
|
shell='bash',
|
||||||
|
provider=dict(
|
||||||
server='localhost',
|
server='localhost',
|
||||||
user='admin',
|
password='password',
|
||||||
shell='bash'
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
|
@ -502,10 +524,12 @@ class TestLegacyManager(unittest.TestCase):
|
||||||
username_credential='someuser',
|
username_credential='someuser',
|
||||||
password_credential='testpass',
|
password_credential='testpass',
|
||||||
partition_access=access,
|
partition_access=access,
|
||||||
|
update_password='on_create',
|
||||||
|
provider=dict(
|
||||||
server='localhost',
|
server='localhost',
|
||||||
password='password',
|
password='password',
|
||||||
user='admin',
|
user='admin'
|
||||||
update_password='on_create'
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
|
@ -532,9 +556,11 @@ class TestLegacyManager(unittest.TestCase):
|
||||||
set_module_args(dict(
|
set_module_args(dict(
|
||||||
username_credential='someuser',
|
username_credential='someuser',
|
||||||
partition_access=access,
|
partition_access=access,
|
||||||
|
provider=dict(
|
||||||
server='localhost',
|
server='localhost',
|
||||||
password='password',
|
password='password',
|
||||||
user='admin'
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
|
@ -559,9 +585,11 @@ class TestLegacyManager(unittest.TestCase):
|
||||||
def test_create_user_partition_access_raises(self, *args):
|
def test_create_user_partition_access_raises(self, *args):
|
||||||
set_module_args(dict(
|
set_module_args(dict(
|
||||||
username_credential='someuser',
|
username_credential='someuser',
|
||||||
password='password',
|
provider=dict(
|
||||||
server='localhost',
|
server='localhost',
|
||||||
|
password='password',
|
||||||
user='admin'
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
|
@ -591,11 +619,13 @@ class TestLegacyManager(unittest.TestCase):
|
||||||
username_credential='someuser',
|
username_credential='someuser',
|
||||||
password_credential='testpass',
|
password_credential='testpass',
|
||||||
partition_access=access,
|
partition_access=access,
|
||||||
password='password',
|
|
||||||
server='localhost',
|
|
||||||
update_password='on_create',
|
update_password='on_create',
|
||||||
user='admin',
|
shell='bash',
|
||||||
shell='bash'
|
provider=dict(
|
||||||
|
server='localhost',
|
||||||
|
password='password',
|
||||||
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
|
@ -624,10 +654,12 @@ class TestLegacyManager(unittest.TestCase):
|
||||||
password_credential='testpass',
|
password_credential='testpass',
|
||||||
partition_access=access,
|
partition_access=access,
|
||||||
update_password='on_create',
|
update_password='on_create',
|
||||||
password='password',
|
shell='bash',
|
||||||
|
provider=dict(
|
||||||
server='localhost',
|
server='localhost',
|
||||||
user='admin',
|
password='password',
|
||||||
shell='bash'
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
|
@ -655,9 +687,11 @@ class TestLegacyManager(unittest.TestCase):
|
||||||
set_module_args(dict(
|
set_module_args(dict(
|
||||||
username_credential='someuser',
|
username_credential='someuser',
|
||||||
password_credential='testpass',
|
password_credential='testpass',
|
||||||
password='password',
|
provider=dict(
|
||||||
server='localhost',
|
server='localhost',
|
||||||
|
password='password',
|
||||||
user='admin'
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
|
@ -692,10 +726,12 @@ class TestLegacyManager(unittest.TestCase):
|
||||||
def test_update_user_shell_to_none(self, *args):
|
def test_update_user_shell_to_none(self, *args):
|
||||||
set_module_args(dict(
|
set_module_args(dict(
|
||||||
username_credential='someuser',
|
username_credential='someuser',
|
||||||
password='password',
|
shell='none',
|
||||||
|
provider=dict(
|
||||||
server='localhost',
|
server='localhost',
|
||||||
user='admin',
|
password='password',
|
||||||
shell='none'
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
|
@ -730,10 +766,12 @@ class TestLegacyManager(unittest.TestCase):
|
||||||
def test_update_user_shell_to_none_shell_attribute_missing(self, *args):
|
def test_update_user_shell_to_none_shell_attribute_missing(self, *args):
|
||||||
set_module_args(dict(
|
set_module_args(dict(
|
||||||
username_credential='someuser',
|
username_credential='someuser',
|
||||||
password='password',
|
shell='none',
|
||||||
|
provider=dict(
|
||||||
server='localhost',
|
server='localhost',
|
||||||
user='admin',
|
password='password',
|
||||||
shell='none'
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
|
@ -769,10 +807,12 @@ class TestLegacyManager(unittest.TestCase):
|
||||||
def test_update_user_shell_to_bash(self, *args):
|
def test_update_user_shell_to_bash(self, *args):
|
||||||
set_module_args(dict(
|
set_module_args(dict(
|
||||||
username_credential='someuser',
|
username_credential='someuser',
|
||||||
password='password',
|
shell='bash',
|
||||||
|
provider=dict(
|
||||||
server='localhost',
|
server='localhost',
|
||||||
user='admin',
|
password='password',
|
||||||
shell='bash'
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
|
@ -809,10 +849,12 @@ class TestLegacyManager(unittest.TestCase):
|
||||||
def test_update_user_shell_to_bash_mutliple_roles(self, *args):
|
def test_update_user_shell_to_bash_mutliple_roles(self, *args):
|
||||||
set_module_args(dict(
|
set_module_args(dict(
|
||||||
username_credential='someuser',
|
username_credential='someuser',
|
||||||
password='password',
|
shell='bash',
|
||||||
|
provider=dict(
|
||||||
server='localhost',
|
server='localhost',
|
||||||
user='admin',
|
password='password',
|
||||||
shell='bash'
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
|
|
|
@ -156,23 +156,36 @@ class TestManager(unittest.TestCase):
|
||||||
self.patcher1 = patch('time.sleep')
|
self.patcher1 = patch('time.sleep')
|
||||||
self.patcher1.start()
|
self.patcher1.start()
|
||||||
|
|
||||||
|
try:
|
||||||
|
self.p1 = patch('library.modules.bigip_vcmp_guest.ModuleParameters.initial_image_exists')
|
||||||
|
self.m1 = self.p1.start()
|
||||||
|
self.m1.return_value = True
|
||||||
|
except Exception:
|
||||||
|
self.p1 = patch('ansible.modules.network.f5.bigip_vcmp_guest.ModuleParameters.initial_image_exists')
|
||||||
|
self.m1 = self.p1.start()
|
||||||
|
self.m1.return_value = True
|
||||||
|
|
||||||
def tearDown(self):
|
def tearDown(self):
|
||||||
self.patcher1.stop()
|
self.patcher1.stop()
|
||||||
|
self.p1.stop()
|
||||||
|
|
||||||
def test_create_vlan(self, *args):
|
def test_create_vcmpguest(self, *args):
|
||||||
set_module_args(dict(
|
set_module_args(dict(
|
||||||
name="guest1",
|
name="guest1",
|
||||||
mgmt_network="bridged",
|
mgmt_network="bridged",
|
||||||
mgmt_address="10.10.10.10/24",
|
mgmt_address="10.10.10.10/24",
|
||||||
initial_image="BIGIP-13.1.0.0.0.931.iso",
|
initial_image="BIGIP-13.1.0.0.0.931.iso",
|
||||||
|
provider=dict(
|
||||||
server='localhost',
|
server='localhost',
|
||||||
password='password',
|
password='password',
|
||||||
user='admin'
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
argument_spec=self.spec.argument_spec,
|
argument_spec=self.spec.argument_spec,
|
||||||
supports_check_mode=self.spec.supports_check_mode
|
supports_check_mode=self.spec.supports_check_mode,
|
||||||
|
required_if=self.spec.required_if
|
||||||
)
|
)
|
||||||
|
|
||||||
# Override methods to force specific logic in the module to happen
|
# Override methods to force specific logic in the module to happen
|
||||||
|
|
|
@ -199,14 +199,18 @@ class TestManager(unittest.TestCase):
|
||||||
icmp_echo='enabled',
|
icmp_echo='enabled',
|
||||||
advertise_route='always',
|
advertise_route='always',
|
||||||
use_route_advertisement='yes',
|
use_route_advertisement='yes',
|
||||||
password='admin',
|
provider=dict(
|
||||||
server='localhost',
|
server='localhost',
|
||||||
user='admin',
|
password='password',
|
||||||
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
argument_spec=self.spec.argument_spec,
|
argument_spec=self.spec.argument_spec,
|
||||||
supports_check_mode=self.spec.supports_check_mode
|
supports_check_mode=self.spec.supports_check_mode,
|
||||||
|
mutually_exclusive=self.spec.mutually_exclusive,
|
||||||
|
required_one_of=self.spec.required_one_of
|
||||||
)
|
)
|
||||||
mm = ModuleManager(module=module)
|
mm = ModuleManager(module=module)
|
||||||
|
|
||||||
|
@ -221,14 +225,18 @@ class TestManager(unittest.TestCase):
|
||||||
set_module_args(dict(
|
set_module_args(dict(
|
||||||
state='absent',
|
state='absent',
|
||||||
address='1.1.1.1',
|
address='1.1.1.1',
|
||||||
password='admin',
|
provider=dict(
|
||||||
server='localhost',
|
server='localhost',
|
||||||
user='admin',
|
password='password',
|
||||||
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
argument_spec=self.spec.argument_spec,
|
argument_spec=self.spec.argument_spec,
|
||||||
supports_check_mode=self.spec.supports_check_mode
|
supports_check_mode=self.spec.supports_check_mode,
|
||||||
|
mutually_exclusive=self.spec.mutually_exclusive,
|
||||||
|
required_one_of=self.spec.required_one_of
|
||||||
)
|
)
|
||||||
mm = ModuleManager(module=module)
|
mm = ModuleManager(module=module)
|
||||||
|
|
||||||
|
|
|
@ -163,9 +163,6 @@ class TestParameters(unittest.TestCase):
|
||||||
|
|
||||||
def test_module_no_partition_prefix_parameters(self):
|
def test_module_no_partition_prefix_parameters(self):
|
||||||
args = dict(
|
args = dict(
|
||||||
server='localhost',
|
|
||||||
user='admin',
|
|
||||||
password='secret',
|
|
||||||
state='present',
|
state='present',
|
||||||
partition='Common',
|
partition='Common',
|
||||||
name='my-virtual-server',
|
name='my-virtual-server',
|
||||||
|
@ -197,9 +194,6 @@ class TestParameters(unittest.TestCase):
|
||||||
|
|
||||||
def test_module_partition_prefix_parameters(self):
|
def test_module_partition_prefix_parameters(self):
|
||||||
args = dict(
|
args = dict(
|
||||||
server='localhost',
|
|
||||||
user='admin',
|
|
||||||
password='secret',
|
|
||||||
state='present',
|
state='present',
|
||||||
partition='Common',
|
partition='Common',
|
||||||
name='my-virtual-server',
|
name='my-virtual-server',
|
||||||
|
@ -365,10 +359,22 @@ class TestManager(unittest.TestCase):
|
||||||
self.p3 = patch(
|
self.p3 = patch(
|
||||||
'library.modules.bigip_virtual_server.Parameters._read_current_serverssl_profiles_from_device'
|
'library.modules.bigip_virtual_server.Parameters._read_current_serverssl_profiles_from_device'
|
||||||
)
|
)
|
||||||
|
self.p4 = patch(
|
||||||
|
'library.modules.bigip_virtual_server.VirtualServerValidator.check_create'
|
||||||
|
)
|
||||||
|
|
||||||
|
self.p5 = patch(
|
||||||
|
'library.modules.bigip_virtual_server.VirtualServerValidator.check_update'
|
||||||
|
)
|
||||||
|
|
||||||
self.m2 = self.p2.start()
|
self.m2 = self.p2.start()
|
||||||
self.m3 = self.p3.start()
|
self.m3 = self.p3.start()
|
||||||
|
self.m4 = self.p4.start()
|
||||||
|
self.m5 = self.p5.start()
|
||||||
self.m2.return_value = ['asda', 'clientssl', 'cs_foobar.star.local']
|
self.m2.return_value = ['asda', 'clientssl', 'cs_foobar.star.local']
|
||||||
self.m3.return_value = ['baz', 'serverssl', 'ss_foobar.star.local']
|
self.m3.return_value = ['baz', 'serverssl', 'ss_foobar.star.local']
|
||||||
|
self.m4.return_value = Mock(return_value=True)
|
||||||
|
self.m5.return_value = Mock(return_value=True)
|
||||||
except Exception:
|
except Exception:
|
||||||
self.p1 = patch('ansible.modules.network.f5.bigip_virtual_server.modules_provisioned')
|
self.p1 = patch('ansible.modules.network.f5.bigip_virtual_server.modules_provisioned')
|
||||||
self.m1 = self.p1.start()
|
self.m1 = self.p1.start()
|
||||||
|
@ -379,15 +385,27 @@ class TestManager(unittest.TestCase):
|
||||||
self.p3 = patch(
|
self.p3 = patch(
|
||||||
'ansible.modules.network.f5.bigip_virtual_server.Parameters._read_current_serverssl_profiles_from_device'
|
'ansible.modules.network.f5.bigip_virtual_server.Parameters._read_current_serverssl_profiles_from_device'
|
||||||
)
|
)
|
||||||
|
self.p4 = patch(
|
||||||
|
'ansible.modules.network.f5.bigip_virtual_server.VirtualServerValidator.check_create'
|
||||||
|
)
|
||||||
|
self.p5 = patch(
|
||||||
|
'ansible.modules.network.f5.bigip_virtual_server.VirtualServerValidator.check_update'
|
||||||
|
)
|
||||||
self.m2 = self.p2.start()
|
self.m2 = self.p2.start()
|
||||||
self.m3 = self.p3.start()
|
self.m3 = self.p3.start()
|
||||||
|
self.m4 = self.p4.start()
|
||||||
|
self.m5 = self.p5.start()
|
||||||
self.m2.return_value = ['asda', 'clientssl', 'cs_foobar.star.local']
|
self.m2.return_value = ['asda', 'clientssl', 'cs_foobar.star.local']
|
||||||
self.m3.return_value = ['baz', 'serverssl', 'ss_foobar.star.local']
|
self.m3.return_value = ['baz', 'serverssl', 'ss_foobar.star.local']
|
||||||
|
self.m4.return_value = Mock(return_value=True)
|
||||||
|
self.m5.return_value = Mock(return_value=True)
|
||||||
|
|
||||||
def tearDown(self):
|
def tearDown(self):
|
||||||
self.p1.stop()
|
self.p1.stop()
|
||||||
self.p2.stop()
|
self.p2.stop()
|
||||||
self.p3.stop()
|
self.p3.stop()
|
||||||
|
self.p4.stop()
|
||||||
|
self.p5.stop()
|
||||||
|
|
||||||
def test_create_virtual_server(self, *args):
|
def test_create_virtual_server(self, *args):
|
||||||
set_module_args(dict(
|
set_module_args(dict(
|
||||||
|
@ -403,18 +421,21 @@ class TestManager(unittest.TestCase):
|
||||||
destination="10.10.10.10",
|
destination="10.10.10.10",
|
||||||
name="my-snat-pool",
|
name="my-snat-pool",
|
||||||
partition="Common",
|
partition="Common",
|
||||||
password="secret",
|
|
||||||
port="443",
|
port="443",
|
||||||
server="localhost",
|
|
||||||
snat="Automap",
|
snat="Automap",
|
||||||
state="present",
|
state="present",
|
||||||
user="admin",
|
provider=dict(
|
||||||
validate_certs="no"
|
server='localhost',
|
||||||
|
password='password',
|
||||||
|
user='admin'
|
||||||
|
)
|
||||||
|
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
argument_spec=self.spec.argument_spec,
|
argument_spec=self.spec.argument_spec,
|
||||||
supports_check_mode=self.spec.supports_check_mode
|
supports_check_mode=self.spec.supports_check_mode,
|
||||||
|
mutually_exclusive=self.spec.mutually_exclusive
|
||||||
)
|
)
|
||||||
|
|
||||||
# Override methods to force specific logic in the module to happen
|
# Override methods to force specific logic in the module to happen
|
||||||
|
@ -434,18 +455,20 @@ class TestManager(unittest.TestCase):
|
||||||
destination="10.10.10.10",
|
destination="10.10.10.10",
|
||||||
name="my-snat-pool",
|
name="my-snat-pool",
|
||||||
partition="Common",
|
partition="Common",
|
||||||
password="secret",
|
|
||||||
port="443",
|
port="443",
|
||||||
server="localhost",
|
|
||||||
snat="Automap",
|
snat="Automap",
|
||||||
state="absent",
|
state="absent",
|
||||||
user="admin",
|
provider=dict(
|
||||||
validate_certs="no"
|
server='localhost',
|
||||||
|
password='password',
|
||||||
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
argument_spec=self.spec.argument_spec,
|
argument_spec=self.spec.argument_spec,
|
||||||
supports_check_mode=self.spec.supports_check_mode
|
supports_check_mode=self.spec.supports_check_mode,
|
||||||
|
mutually_exclusive=self.spec.mutually_exclusive
|
||||||
)
|
)
|
||||||
|
|
||||||
# Override methods to force specific logic in the module to happen
|
# Override methods to force specific logic in the module to happen
|
||||||
|
@ -465,13 +488,14 @@ class TestManager(unittest.TestCase):
|
||||||
destination="10.10.10.10",
|
destination="10.10.10.10",
|
||||||
name="my-snat-pool",
|
name="my-snat-pool",
|
||||||
partition="Common",
|
partition="Common",
|
||||||
password="secret",
|
|
||||||
port="443",
|
port="443",
|
||||||
server="localhost",
|
|
||||||
snat="Automap",
|
snat="Automap",
|
||||||
state="absent",
|
state="absent",
|
||||||
user="admin",
|
provider=dict(
|
||||||
validate_certs="no"
|
server='localhost',
|
||||||
|
password='password',
|
||||||
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
# Configure the parameters that would be returned by querying the
|
# Configure the parameters that would be returned by querying the
|
||||||
|
@ -484,7 +508,8 @@ class TestManager(unittest.TestCase):
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
argument_spec=self.spec.argument_spec,
|
argument_spec=self.spec.argument_spec,
|
||||||
supports_check_mode=self.spec.supports_check_mode
|
supports_check_mode=self.spec.supports_check_mode,
|
||||||
|
mutually_exclusive=self.spec.mutually_exclusive
|
||||||
)
|
)
|
||||||
|
|
||||||
# Override methods to force specific logic in the module to happen
|
# Override methods to force specific logic in the module to happen
|
||||||
|
@ -500,12 +525,13 @@ class TestManager(unittest.TestCase):
|
||||||
set_module_args(dict(
|
set_module_args(dict(
|
||||||
name="my-virtual-server",
|
name="my-virtual-server",
|
||||||
partition="Common",
|
partition="Common",
|
||||||
password="secret",
|
|
||||||
port="10443",
|
port="10443",
|
||||||
server="localhost",
|
|
||||||
state="present",
|
state="present",
|
||||||
user="admin",
|
provider=dict(
|
||||||
validate_certs="no"
|
server='localhost',
|
||||||
|
password='password',
|
||||||
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
# Configure the parameters that would be returned by querying the
|
# Configure the parameters that would be returned by querying the
|
||||||
|
@ -514,7 +540,8 @@ class TestManager(unittest.TestCase):
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
argument_spec=self.spec.argument_spec,
|
argument_spec=self.spec.argument_spec,
|
||||||
supports_check_mode=self.spec.supports_check_mode
|
supports_check_mode=self.spec.supports_check_mode,
|
||||||
|
mutually_exclusive=self.spec.mutually_exclusive
|
||||||
)
|
)
|
||||||
|
|
||||||
# Override methods to force specific logic in the module to happen
|
# Override methods to force specific logic in the module to happen
|
||||||
|
@ -530,12 +557,13 @@ class TestManager(unittest.TestCase):
|
||||||
set_module_args(dict(
|
set_module_args(dict(
|
||||||
name="my-virtual-server",
|
name="my-virtual-server",
|
||||||
partition="Common",
|
partition="Common",
|
||||||
password="secret",
|
|
||||||
port="443",
|
port="443",
|
||||||
server="localhost",
|
|
||||||
state="present",
|
state="present",
|
||||||
user="admin",
|
provider=dict(
|
||||||
validate_certs="no"
|
server='localhost',
|
||||||
|
password='password',
|
||||||
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
# Configure the parameters that would be returned by querying the
|
# Configure the parameters that would be returned by querying the
|
||||||
|
@ -544,7 +572,8 @@ class TestManager(unittest.TestCase):
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
argument_spec=self.spec.argument_spec,
|
argument_spec=self.spec.argument_spec,
|
||||||
supports_check_mode=self.spec.supports_check_mode
|
supports_check_mode=self.spec.supports_check_mode,
|
||||||
|
mutually_exclusive=self.spec.mutually_exclusive
|
||||||
)
|
)
|
||||||
|
|
||||||
# Override methods to force specific logic in the module to happen
|
# Override methods to force specific logic in the module to happen
|
||||||
|
@ -559,14 +588,15 @@ class TestManager(unittest.TestCase):
|
||||||
set_module_args(dict(
|
set_module_args(dict(
|
||||||
name="my-virtual-server",
|
name="my-virtual-server",
|
||||||
partition="Common",
|
partition="Common",
|
||||||
password="secret",
|
|
||||||
disabled_vlans=[
|
disabled_vlans=[
|
||||||
"net1"
|
"net1"
|
||||||
],
|
],
|
||||||
server="localhost",
|
|
||||||
state="present",
|
state="present",
|
||||||
user="admin",
|
provider=dict(
|
||||||
validate_certs="no"
|
server='localhost',
|
||||||
|
password='password',
|
||||||
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
# Configure the parameters that would be returned by querying the
|
# Configure the parameters that would be returned by querying the
|
||||||
|
@ -575,7 +605,8 @@ class TestManager(unittest.TestCase):
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
argument_spec=self.spec.argument_spec,
|
argument_spec=self.spec.argument_spec,
|
||||||
supports_check_mode=self.spec.supports_check_mode
|
supports_check_mode=self.spec.supports_check_mode,
|
||||||
|
mutually_exclusive=self.spec.mutually_exclusive
|
||||||
)
|
)
|
||||||
|
|
||||||
# Override methods to force specific logic in the module to happen
|
# Override methods to force specific logic in the module to happen
|
||||||
|
@ -591,14 +622,15 @@ class TestManager(unittest.TestCase):
|
||||||
set_module_args(dict(
|
set_module_args(dict(
|
||||||
name="my-virtual-server",
|
name="my-virtual-server",
|
||||||
partition="Common",
|
partition="Common",
|
||||||
password="secret",
|
|
||||||
profiles=[
|
profiles=[
|
||||||
'http', 'clientssl'
|
'http', 'clientssl'
|
||||||
],
|
],
|
||||||
server="localhost",
|
|
||||||
state="present",
|
state="present",
|
||||||
user="admin",
|
provider=dict(
|
||||||
validate_certs="no"
|
server='localhost',
|
||||||
|
password='password',
|
||||||
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
# Configure the parameters that would be returned by querying the
|
# Configure the parameters that would be returned by querying the
|
||||||
|
@ -606,7 +638,8 @@ class TestManager(unittest.TestCase):
|
||||||
current = ApiParameters(params=load_fixture('load_ltm_virtual_2.json'))
|
current = ApiParameters(params=load_fixture('load_ltm_virtual_2.json'))
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
argument_spec=self.spec.argument_spec,
|
argument_spec=self.spec.argument_spec,
|
||||||
supports_check_mode=self.spec.supports_check_mode
|
supports_check_mode=self.spec.supports_check_mode,
|
||||||
|
mutually_exclusive=self.spec.mutually_exclusive
|
||||||
)
|
)
|
||||||
|
|
||||||
# Override methods to force specific logic in the module to happen
|
# Override methods to force specific logic in the module to happen
|
||||||
|
@ -642,14 +675,10 @@ class TestManager(unittest.TestCase):
|
||||||
destination="1.1.1.1",
|
destination="1.1.1.1",
|
||||||
name="my-virtual-server",
|
name="my-virtual-server",
|
||||||
partition="Common",
|
partition="Common",
|
||||||
password="secret",
|
|
||||||
port="8443",
|
port="8443",
|
||||||
server="localhost",
|
|
||||||
snat="snat-pool1",
|
snat="snat-pool1",
|
||||||
state="disabled",
|
state="disabled",
|
||||||
source='1.2.3.4/32',
|
source='1.2.3.4/32',
|
||||||
user="admin",
|
|
||||||
validate_certs="no",
|
|
||||||
irules=[
|
irules=[
|
||||||
'irule1',
|
'irule1',
|
||||||
'irule2'
|
'irule2'
|
||||||
|
@ -664,7 +693,12 @@ class TestManager(unittest.TestCase):
|
||||||
],
|
],
|
||||||
pool='my-pool',
|
pool='my-pool',
|
||||||
default_persistence_profile='source_addr',
|
default_persistence_profile='source_addr',
|
||||||
fallback_persistence_profile='dest_addr'
|
fallback_persistence_profile='dest_addr',
|
||||||
|
provider=dict(
|
||||||
|
server='localhost',
|
||||||
|
password='password',
|
||||||
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
# Configure the parameters that would be returned by querying the
|
# Configure the parameters that would be returned by querying the
|
||||||
|
@ -673,7 +707,8 @@ class TestManager(unittest.TestCase):
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
argument_spec=self.spec.argument_spec,
|
argument_spec=self.spec.argument_spec,
|
||||||
supports_check_mode=self.spec.supports_check_mode
|
supports_check_mode=self.spec.supports_check_mode,
|
||||||
|
mutually_exclusive=self.spec.mutually_exclusive
|
||||||
)
|
)
|
||||||
|
|
||||||
# Override methods to force specific logic in the module to happen
|
# Override methods to force specific logic in the module to happen
|
||||||
|
@ -725,17 +760,19 @@ class TestManager(unittest.TestCase):
|
||||||
address_translation=True,
|
address_translation=True,
|
||||||
name="my-snat-pool",
|
name="my-snat-pool",
|
||||||
partition="Common",
|
partition="Common",
|
||||||
password="secret",
|
|
||||||
port="443",
|
port="443",
|
||||||
server="localhost",
|
|
||||||
state="present",
|
state="present",
|
||||||
user="admin",
|
provider=dict(
|
||||||
validate_certs="no"
|
server='localhost',
|
||||||
|
password='password',
|
||||||
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
argument_spec=self.spec.argument_spec,
|
argument_spec=self.spec.argument_spec,
|
||||||
supports_check_mode=self.spec.supports_check_mode
|
supports_check_mode=self.spec.supports_check_mode,
|
||||||
|
mutually_exclusive=self.spec.mutually_exclusive
|
||||||
)
|
)
|
||||||
|
|
||||||
# Override methods to force specific logic in the module to happen
|
# Override methods to force specific logic in the module to happen
|
||||||
|
@ -753,17 +790,19 @@ class TestManager(unittest.TestCase):
|
||||||
address_translation='yes',
|
address_translation='yes',
|
||||||
name="my-snat-pool",
|
name="my-snat-pool",
|
||||||
partition="Common",
|
partition="Common",
|
||||||
password="secret",
|
|
||||||
port="443",
|
port="443",
|
||||||
server="localhost",
|
|
||||||
state="present",
|
state="present",
|
||||||
user="admin",
|
provider=dict(
|
||||||
validate_certs="no"
|
server='localhost',
|
||||||
|
password='password',
|
||||||
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
argument_spec=self.spec.argument_spec,
|
argument_spec=self.spec.argument_spec,
|
||||||
supports_check_mode=self.spec.supports_check_mode
|
supports_check_mode=self.spec.supports_check_mode,
|
||||||
|
mutually_exclusive=self.spec.mutually_exclusive
|
||||||
)
|
)
|
||||||
|
|
||||||
# Override methods to force specific logic in the module to happen
|
# Override methods to force specific logic in the module to happen
|
||||||
|
@ -781,17 +820,19 @@ class TestManager(unittest.TestCase):
|
||||||
address_translation=False,
|
address_translation=False,
|
||||||
name="my-snat-pool",
|
name="my-snat-pool",
|
||||||
partition="Common",
|
partition="Common",
|
||||||
password="secret",
|
|
||||||
port="443",
|
port="443",
|
||||||
server="localhost",
|
|
||||||
state="present",
|
state="present",
|
||||||
user="admin",
|
provider=dict(
|
||||||
validate_certs="no"
|
server='localhost',
|
||||||
|
password='password',
|
||||||
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
argument_spec=self.spec.argument_spec,
|
argument_spec=self.spec.argument_spec,
|
||||||
supports_check_mode=self.spec.supports_check_mode
|
supports_check_mode=self.spec.supports_check_mode,
|
||||||
|
mutually_exclusive=self.spec.mutually_exclusive
|
||||||
)
|
)
|
||||||
|
|
||||||
# Override methods to force specific logic in the module to happen
|
# Override methods to force specific logic in the module to happen
|
||||||
|
@ -809,17 +850,19 @@ class TestManager(unittest.TestCase):
|
||||||
address_translation='no',
|
address_translation='no',
|
||||||
name="my-snat-pool",
|
name="my-snat-pool",
|
||||||
partition="Common",
|
partition="Common",
|
||||||
password="secret",
|
|
||||||
port="443",
|
port="443",
|
||||||
server="localhost",
|
|
||||||
state="present",
|
state="present",
|
||||||
user="admin",
|
provider=dict(
|
||||||
validate_certs="no"
|
server='localhost',
|
||||||
|
password='password',
|
||||||
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
argument_spec=self.spec.argument_spec,
|
argument_spec=self.spec.argument_spec,
|
||||||
supports_check_mode=self.spec.supports_check_mode
|
supports_check_mode=self.spec.supports_check_mode,
|
||||||
|
mutually_exclusive=self.spec.mutually_exclusive
|
||||||
)
|
)
|
||||||
|
|
||||||
# Override methods to force specific logic in the module to happen
|
# Override methods to force specific logic in the module to happen
|
||||||
|
@ -837,17 +880,19 @@ class TestManager(unittest.TestCase):
|
||||||
port_translation=True,
|
port_translation=True,
|
||||||
name="my-snat-pool",
|
name="my-snat-pool",
|
||||||
partition="Common",
|
partition="Common",
|
||||||
password="secret",
|
|
||||||
port="443",
|
port="443",
|
||||||
server="localhost",
|
|
||||||
state="present",
|
state="present",
|
||||||
user="admin",
|
provider=dict(
|
||||||
validate_certs="no"
|
server='localhost',
|
||||||
|
password='password',
|
||||||
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
argument_spec=self.spec.argument_spec,
|
argument_spec=self.spec.argument_spec,
|
||||||
supports_check_mode=self.spec.supports_check_mode
|
supports_check_mode=self.spec.supports_check_mode,
|
||||||
|
mutually_exclusive=self.spec.mutually_exclusive
|
||||||
)
|
)
|
||||||
|
|
||||||
# Override methods to force specific logic in the module to happen
|
# Override methods to force specific logic in the module to happen
|
||||||
|
@ -865,17 +910,19 @@ class TestManager(unittest.TestCase):
|
||||||
port_translation='yes',
|
port_translation='yes',
|
||||||
name="my-snat-pool",
|
name="my-snat-pool",
|
||||||
partition="Common",
|
partition="Common",
|
||||||
password="secret",
|
|
||||||
port="443",
|
port="443",
|
||||||
server="localhost",
|
|
||||||
state="present",
|
state="present",
|
||||||
user="admin",
|
provider=dict(
|
||||||
validate_certs="no"
|
server='localhost',
|
||||||
|
password='password',
|
||||||
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
argument_spec=self.spec.argument_spec,
|
argument_spec=self.spec.argument_spec,
|
||||||
supports_check_mode=self.spec.supports_check_mode
|
supports_check_mode=self.spec.supports_check_mode,
|
||||||
|
mutually_exclusive=self.spec.mutually_exclusive
|
||||||
)
|
)
|
||||||
|
|
||||||
# Override methods to force specific logic in the module to happen
|
# Override methods to force specific logic in the module to happen
|
||||||
|
@ -893,17 +940,19 @@ class TestManager(unittest.TestCase):
|
||||||
port_translation=False,
|
port_translation=False,
|
||||||
name="my-snat-pool",
|
name="my-snat-pool",
|
||||||
partition="Common",
|
partition="Common",
|
||||||
password="secret",
|
|
||||||
port="443",
|
port="443",
|
||||||
server="localhost",
|
|
||||||
state="present",
|
state="present",
|
||||||
user="admin",
|
provider=dict(
|
||||||
validate_certs="no"
|
server='localhost',
|
||||||
|
password='password',
|
||||||
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
argument_spec=self.spec.argument_spec,
|
argument_spec=self.spec.argument_spec,
|
||||||
supports_check_mode=self.spec.supports_check_mode
|
supports_check_mode=self.spec.supports_check_mode,
|
||||||
|
mutually_exclusive=self.spec.mutually_exclusive
|
||||||
)
|
)
|
||||||
|
|
||||||
# Override methods to force specific logic in the module to happen
|
# Override methods to force specific logic in the module to happen
|
||||||
|
@ -921,17 +970,19 @@ class TestManager(unittest.TestCase):
|
||||||
port_translation='no',
|
port_translation='no',
|
||||||
name="my-snat-pool",
|
name="my-snat-pool",
|
||||||
partition="Common",
|
partition="Common",
|
||||||
password="secret",
|
|
||||||
port="443",
|
port="443",
|
||||||
server="localhost",
|
|
||||||
state="present",
|
state="present",
|
||||||
user="admin",
|
provider=dict(
|
||||||
validate_certs="no"
|
server='localhost',
|
||||||
|
password='password',
|
||||||
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
argument_spec=self.spec.argument_spec,
|
argument_spec=self.spec.argument_spec,
|
||||||
supports_check_mode=self.spec.supports_check_mode
|
supports_check_mode=self.spec.supports_check_mode,
|
||||||
|
mutually_exclusive=self.spec.mutually_exclusive
|
||||||
)
|
)
|
||||||
|
|
||||||
# Override methods to force specific logic in the module to happen
|
# Override methods to force specific logic in the module to happen
|
||||||
|
|
|
@ -103,9 +103,11 @@ class TestManager(unittest.TestCase):
|
||||||
|
|
||||||
def test_wait_already_available(self, *args):
|
def test_wait_already_available(self, *args):
|
||||||
set_module_args(dict(
|
set_module_args(dict(
|
||||||
password='password',
|
provider=dict(
|
||||||
server='localhost',
|
server='localhost',
|
||||||
|
password='password',
|
||||||
user='admin'
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
|
|
|
@ -81,9 +81,11 @@ class TestManager(unittest.TestCase):
|
||||||
def test_get_facts(self, *args):
|
def test_get_facts(self, *args):
|
||||||
set_module_args(dict(
|
set_module_args(dict(
|
||||||
gather_subset=['system-info'],
|
gather_subset=['system-info'],
|
||||||
password='password',
|
provider=dict(
|
||||||
server='localhost',
|
server='localhost',
|
||||||
|
password='password',
|
||||||
user='admin'
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
fixture1 = load_fixture('load_shared_system_setup_1.json')
|
fixture1 = load_fixture('load_shared_system_setup_1.json')
|
||||||
|
|
|
@ -102,9 +102,11 @@ class TestManager(unittest.TestCase):
|
||||||
license_key='XXXX-XXXX-XXXX-XXXX-XXXX',
|
license_key='XXXX-XXXX-XXXX-XXXX-XXXX',
|
||||||
accept_eula=True,
|
accept_eula=True,
|
||||||
description='this is a description',
|
description='this is a description',
|
||||||
password='password',
|
provider=dict(
|
||||||
server='localhost',
|
server='localhost',
|
||||||
|
password='password',
|
||||||
user='admin'
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
|
|
|
@ -119,9 +119,11 @@ class TestManager(unittest.TestCase):
|
||||||
device_password='secret',
|
device_password='secret',
|
||||||
managed='no',
|
managed='no',
|
||||||
state='present',
|
state='present',
|
||||||
password='password',
|
provider=dict(
|
||||||
server='localhost',
|
server='localhost',
|
||||||
|
password='password',
|
||||||
user='admin'
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
|
|
|
@ -89,9 +89,11 @@ class TestManager(unittest.TestCase):
|
||||||
set_module_args(dict(
|
set_module_args(dict(
|
||||||
name='foo',
|
name='foo',
|
||||||
description='bar baz',
|
description='bar baz',
|
||||||
|
provider=dict(
|
||||||
server='localhost',
|
server='localhost',
|
||||||
password='password',
|
password='password',
|
||||||
user='admin'
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
|
|
|
@ -88,14 +88,17 @@ class TestManager(unittest.TestCase):
|
||||||
set_module_args(dict(
|
set_module_args(dict(
|
||||||
license_key='XXXX-XXXX-XXXX-XXXX-XXXX',
|
license_key='XXXX-XXXX-XXXX-XXXX-XXXX',
|
||||||
accept_eula=True,
|
accept_eula=True,
|
||||||
password='password',
|
provider=dict(
|
||||||
server='localhost',
|
server='localhost',
|
||||||
|
password='password',
|
||||||
user='admin'
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
argument_spec=self.spec.argument_spec,
|
argument_spec=self.spec.argument_spec,
|
||||||
supports_check_mode=self.spec.supports_check_mode
|
supports_check_mode=self.spec.supports_check_mode,
|
||||||
|
required_if=self.spec.required_if
|
||||||
)
|
)
|
||||||
mm = ModuleManager(module=module)
|
mm = ModuleManager(module=module)
|
||||||
|
|
||||||
|
|
|
@ -114,9 +114,11 @@ class TestManager(unittest.TestCase):
|
||||||
device_password='secret',
|
device_password='secret',
|
||||||
managed='no',
|
managed='no',
|
||||||
state='present',
|
state='present',
|
||||||
password='password',
|
provider=dict(
|
||||||
server='localhost',
|
server='localhost',
|
||||||
|
password='password',
|
||||||
user='admin'
|
user='admin'
|
||||||
|
)
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
|
|
Loading…
Reference in a new issue