mirror of
				https://github.com/ansible-collections/community.general.git
				synced 2025-10-26 05:50:36 -07:00 
			
		
		
		
	
		
			Some checks are pending
		
		
	
	EOL CI / EOL Sanity (Ⓐ2.17) (push) Waiting to run
				
			EOL CI / EOL Units (Ⓐ2.17+py3.10) (push) Waiting to run
				
			EOL CI / EOL Units (Ⓐ2.17+py3.12) (push) Waiting to run
				
			EOL CI / EOL Units (Ⓐ2.17+py3.7) (push) Waiting to run
				
			EOL CI / EOL I (Ⓐ2.17+alpine319+py:azp/posix/1/) (push) Waiting to run
				
			EOL CI / EOL I (Ⓐ2.17+alpine319+py:azp/posix/2/) (push) Waiting to run
				
			EOL CI / EOL I (Ⓐ2.17+alpine319+py:azp/posix/3/) (push) Waiting to run
				
			EOL CI / EOL I (Ⓐ2.17+fedora39+py:azp/posix/1/) (push) Waiting to run
				
			EOL CI / EOL I (Ⓐ2.17+fedora39+py:azp/posix/2/) (push) Waiting to run
				
			EOL CI / EOL I (Ⓐ2.17+fedora39+py:azp/posix/3/) (push) Waiting to run
				
			EOL CI / EOL I (Ⓐ2.17+ubuntu2004+py:azp/posix/1/) (push) Waiting to run
				
			EOL CI / EOL I (Ⓐ2.17+ubuntu2004+py:azp/posix/2/) (push) Waiting to run
				
			EOL CI / EOL I (Ⓐ2.17+ubuntu2004+py:azp/posix/3/) (push) Waiting to run
				
			nox / Run extra sanity tests (push) Waiting to run
				
			* Adjust all __future__ imports: for i in $(grep -REl "__future__.*absolute_import" plugins/ tests/); do sed -e 's/from __future__ import .*/from __future__ import annotations/g' -i $i; done * Remove all UTF-8 encoding specifications for Python source files: for i in $(grep -REl '[-][*]- coding: utf-8 -[*]-' plugins/ tests/); do sed -e '/^# -\*- coding: utf-8 -\*-/d' -i $i; done * Remove __metaclass__ = type: for i in $(grep -REl '__metaclass__ = type' plugins/ tests/); do sed -e '/^__metaclass__ = type/d' -i $i; done
		
			
				
	
	
		
			92 lines
		
	
	
	
		
			3.3 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			92 lines
		
	
	
	
		
			3.3 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| 
 | |
| # Copyright (c) 2017, Ansible Project
 | |
| # Simplified BSD License (see LICENSES/BSD-2-Clause.txt or https://opensource.org/licenses/BSD-2-Clause)
 | |
| # SPDX-License-Identifier: BSD-2-Clause
 | |
| 
 | |
| from __future__ import annotations
 | |
| 
 | |
| import traceback
 | |
| 
 | |
| from ansible.module_utils.basic import missing_required_lib
 | |
| 
 | |
| from ansible_collections.community.general.plugins.module_utils.version import LooseVersion
 | |
| 
 | |
| REQUESTS_IMP_ERR = None
 | |
| try:
 | |
|     import requests.exceptions  # noqa: F401, pylint: disable=unused-import
 | |
|     HAS_REQUESTS = True
 | |
| except ImportError:
 | |
|     REQUESTS_IMP_ERR = traceback.format_exc()
 | |
|     HAS_REQUESTS = False
 | |
| 
 | |
| INFLUXDB_IMP_ERR = None
 | |
| try:
 | |
|     from influxdb import InfluxDBClient
 | |
|     from influxdb import __version__ as influxdb_version
 | |
|     from influxdb import exceptions  # noqa: F401, pylint: disable=unused-import
 | |
|     HAS_INFLUXDB = True
 | |
| except ImportError:
 | |
|     INFLUXDB_IMP_ERR = traceback.format_exc()
 | |
|     HAS_INFLUXDB = False
 | |
| 
 | |
| 
 | |
| class InfluxDb():
 | |
|     def __init__(self, module):
 | |
|         self.module = module
 | |
|         self.params = self.module.params
 | |
|         self.check_lib()
 | |
|         self.hostname = self.params['hostname']
 | |
|         self.port = self.params['port']
 | |
|         self.path = self.params['path']
 | |
|         self.username = self.params['username']
 | |
|         self.password = self.params['password']
 | |
|         self.database_name = self.params.get('database_name')
 | |
| 
 | |
|     def check_lib(self):
 | |
|         if not HAS_REQUESTS:
 | |
|             self.module.fail_json(msg=missing_required_lib('requests'), exception=REQUESTS_IMP_ERR)
 | |
| 
 | |
|         if not HAS_INFLUXDB:
 | |
|             self.module.fail_json(msg=missing_required_lib('influxdb'), exception=INFLUXDB_IMP_ERR)
 | |
| 
 | |
|     @staticmethod
 | |
|     def influxdb_argument_spec():
 | |
|         return dict(
 | |
|             hostname=dict(type='str', default='localhost'),
 | |
|             port=dict(type='int', default=8086),
 | |
|             path=dict(type='str', default=''),
 | |
|             username=dict(type='str', default='root', aliases=['login_username']),
 | |
|             password=dict(type='str', default='root', no_log=True, aliases=['login_password']),
 | |
|             ssl=dict(type='bool', default=False),
 | |
|             validate_certs=dict(type='bool', default=True),
 | |
|             timeout=dict(type='int'),
 | |
|             retries=dict(type='int', default=3),
 | |
|             proxies=dict(type='dict', default={}),
 | |
|             use_udp=dict(type='bool', default=False),
 | |
|             udp_port=dict(type='int', default=4444),
 | |
|         )
 | |
| 
 | |
|     def connect_to_influxdb(self):
 | |
|         args = dict(
 | |
|             host=self.hostname,
 | |
|             port=self.port,
 | |
|             username=self.username,
 | |
|             password=self.password,
 | |
|             database=self.database_name,
 | |
|             ssl=self.params['ssl'],
 | |
|             verify_ssl=self.params['validate_certs'],
 | |
|             timeout=self.params['timeout'],
 | |
|             use_udp=self.params['use_udp'],
 | |
|             udp_port=self.params['udp_port'],
 | |
|             proxies=self.params['proxies'],
 | |
|         )
 | |
|         influxdb_api_version = LooseVersion(influxdb_version)
 | |
|         if influxdb_api_version >= LooseVersion('4.1.0'):
 | |
|             # retries option is added in version 4.1.0
 | |
|             args.update(retries=self.params['retries'])
 | |
| 
 | |
|         if influxdb_api_version >= LooseVersion('5.1.0'):
 | |
|             # path argument is added in version 5.1.0
 | |
|             args.update(path=self.path)
 | |
| 
 | |
|         return InfluxDBClient(**args)
 |