|
|
|
@ -17,7 +17,7 @@ DOCUMENTATION = r'''
|
|
|
|
|
module: bigip_monitor_tcp_half_open
|
|
|
|
|
short_description: Manages F5 BIG-IP LTM tcp half-open monitors
|
|
|
|
|
description: Manages F5 BIG-IP LTM tcp half-open monitors.
|
|
|
|
|
version_added: "2.4"
|
|
|
|
|
version_added: 2.4
|
|
|
|
|
options:
|
|
|
|
|
name:
|
|
|
|
|
description:
|
|
|
|
@ -87,7 +87,7 @@ author:
|
|
|
|
|
'''
|
|
|
|
|
|
|
|
|
|
EXAMPLES = r'''
|
|
|
|
|
- name: Create TCP Monitor
|
|
|
|
|
- name: Create TCP half-open Monitor
|
|
|
|
|
bigip_monitor_tcp_half_open:
|
|
|
|
|
state: present
|
|
|
|
|
ip: 10.10.10.10
|
|
|
|
@ -97,7 +97,7 @@ EXAMPLES = r'''
|
|
|
|
|
name: my_tcp_monitor
|
|
|
|
|
delegate_to: localhost
|
|
|
|
|
|
|
|
|
|
- name: Remove TCP Monitor
|
|
|
|
|
- name: Remove TCP half-open Monitor
|
|
|
|
|
bigip_monitor_tcp_half_open:
|
|
|
|
|
state: absent
|
|
|
|
|
server: lb.mydomain.com
|
|
|
|
@ -149,30 +149,23 @@ import os
|
|
|
|
|
from ansible.module_utils.basic import AnsibleModule
|
|
|
|
|
from ansible.module_utils.basic import env_fallback
|
|
|
|
|
|
|
|
|
|
HAS_DEVEL_IMPORTS = False
|
|
|
|
|
|
|
|
|
|
try:
|
|
|
|
|
# Sideband repository used for dev
|
|
|
|
|
from library.module_utils.network.f5.bigip import HAS_F5SDK
|
|
|
|
|
from library.module_utils.network.f5.bigip import F5Client
|
|
|
|
|
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 cleanup_tokens
|
|
|
|
|
from library.module_utils.network.f5.common import fqdn_name
|
|
|
|
|
from library.module_utils.network.f5.common import f5_argument_spec
|
|
|
|
|
try:
|
|
|
|
|
from library.module_utils.network.f5.common import iControlUnexpectedHTTPError
|
|
|
|
|
except ImportError:
|
|
|
|
|
HAS_F5SDK = False
|
|
|
|
|
HAS_DEVEL_IMPORTS = True
|
|
|
|
|
except ImportError:
|
|
|
|
|
# Upstream Ansible
|
|
|
|
|
from ansible.module_utils.network.f5.bigip import HAS_F5SDK
|
|
|
|
|
from ansible.module_utils.network.f5.bigip import F5Client
|
|
|
|
|
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 cleanup_tokens
|
|
|
|
|
from ansible.module_utils.network.f5.common import fqdn_name
|
|
|
|
|
from ansible.module_utils.network.f5.common import f5_argument_spec
|
|
|
|
|
try:
|
|
|
|
|
from ansible.module_utils.network.f5.common import iControlUnexpectedHTTPError
|
|
|
|
@ -194,24 +187,17 @@ class Parameters(AnsibleF5Parameters):
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
api_attributes = [
|
|
|
|
|
'timeUntilUp', 'defaultsFrom', 'interval', 'timeout', 'recv', 'send',
|
|
|
|
|
'destination'
|
|
|
|
|
'timeUntilUp', 'defaultsFrom', 'interval', 'timeout', 'destination'
|
|
|
|
|
]
|
|
|
|
|
|
|
|
|
|
returnables = [
|
|
|
|
|
'parent', 'send', 'receive', 'ip', 'port', 'interval', 'timeout',
|
|
|
|
|
'time_until_up'
|
|
|
|
|
'parent', 'ip', 'port', 'interval', 'timeout', 'time_until_up'
|
|
|
|
|
]
|
|
|
|
|
|
|
|
|
|
updatables = [
|
|
|
|
|
'destination', 'send', 'receive', 'interval', 'timeout', 'time_until_up'
|
|
|
|
|
'destination', 'interval', 'timeout', 'time_until_up'
|
|
|
|
|
]
|
|
|
|
|
|
|
|
|
|
def _fqdn_name(self, value):
|
|
|
|
|
if value is not None and not value.startswith('/'):
|
|
|
|
|
return '/{0}/{1}'.format(self.partition, value)
|
|
|
|
|
return value
|
|
|
|
|
|
|
|
|
|
def to_return(self):
|
|
|
|
|
result = {}
|
|
|
|
|
try:
|
|
|
|
@ -241,7 +227,7 @@ class Parameters(AnsibleF5Parameters):
|
|
|
|
|
return None
|
|
|
|
|
|
|
|
|
|
# Per BZ617284, the BIG-IP UI does not raise a warning about this.
|
|
|
|
|
# So i
|
|
|
|
|
# So I raise the error instead.
|
|
|
|
|
if 1 > int(self._values['interval']) > 86400:
|
|
|
|
|
raise F5ModuleError(
|
|
|
|
|
"Interval value must be between 1 and 86400"
|
|
|
|
|