mirror of
https://github.com/ansible-collections/community.general.git
synced 2024-09-14 20:13:21 +02:00
95188ed35c
This patch fixes repeated attempts that the module would make to re-create an API object. The change stores a copy for later lookup instead. This prevents uncontrolled tokens from being created.
49 lines
1.5 KiB
Python
49 lines
1.5 KiB
Python
# -*- coding: utf-8 -*-
|
|
#
|
|
# Copyright (c) 2017 F5 Networks Inc.
|
|
# GNU General Public License v3.0 (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
|
|
|
|
from __future__ import absolute_import, division, print_function
|
|
__metaclass__ = type
|
|
|
|
|
|
import time
|
|
|
|
try:
|
|
from f5.bigip import ManagementRoot
|
|
from icontrol.exceptions import iControlUnexpectedHTTPError
|
|
HAS_F5SDK = True
|
|
except ImportError:
|
|
HAS_F5SDK = False
|
|
|
|
try:
|
|
from library.module_utils.network.f5.common import F5BaseClient
|
|
from library.module_utils.network.f5.common import F5ModuleError
|
|
except ImportError:
|
|
from ansible.module_utils.network.f5.common import F5BaseClient
|
|
from ansible.module_utils.network.f5.common import F5ModuleError
|
|
|
|
|
|
class F5Client(F5BaseClient):
|
|
@property
|
|
def api(self):
|
|
if self._client:
|
|
return self._client
|
|
for x in range(0, 10):
|
|
try:
|
|
result = ManagementRoot(
|
|
self.params['server'],
|
|
self.params['user'],
|
|
self.params['password'],
|
|
port=self.params['server_port'],
|
|
verify=self.params['validate_certs'],
|
|
token='tmos'
|
|
)
|
|
self._client = result
|
|
return self._client
|
|
except Exception:
|
|
time.sleep(3)
|
|
raise F5ModuleError(
|
|
'Unable to connect to {0} on port {1}. '
|
|
'Is "validate_certs" preventing this?'.format(self.params['server'], self.params['server_port'])
|
|
)
|