mirror of
				https://github.com/ansible-collections/community.general.git
				synced 2025-10-25 13:34:01 -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
		
			
				
	
	
		
			100 lines
		
	
	
	
		
			2.8 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			100 lines
		
	
	
	
		
			2.8 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| 
 | |
| # Copyright (c) 2021, Andrew Pantuso (@ajpantuso) <ajpantuso@gmail.com>
 | |
| # GNU General Public License v3.0+ (see LICENSES/GPL-3.0-or-later.txt or https://www.gnu.org/licenses/gpl-3.0.txt)
 | |
| # SPDX-License-Identifier: GPL-3.0-or-later
 | |
| 
 | |
| from __future__ import annotations
 | |
| 
 | |
| from ansible.errors import (
 | |
|     AnsibleError,
 | |
|     AnsibleFilterError,
 | |
| )
 | |
| 
 | |
| from ansible.module_utils.common.text.converters import to_native
 | |
| from ansible.module_utils.common.collections import is_sequence
 | |
| 
 | |
| try:
 | |
|     from ansible.errors import AnsibleTypeError
 | |
| except ImportError:
 | |
|     from ansible.errors import AnsibleFilterTypeError as AnsibleTypeError
 | |
| 
 | |
| try:
 | |
|     from hashids import Hashids
 | |
|     HAS_HASHIDS = True
 | |
| except ImportError:
 | |
|     HAS_HASHIDS = False
 | |
| 
 | |
| 
 | |
| def initialize_hashids(**kwargs):
 | |
|     if not HAS_HASHIDS:
 | |
|         raise AnsibleError("The hashids library must be installed in order to use this plugin")
 | |
| 
 | |
|     params = {k: v for k, v in kwargs.items() if v}
 | |
| 
 | |
|     try:
 | |
|         return Hashids(**params)
 | |
|     except TypeError as e:
 | |
|         raise AnsibleFilterError(
 | |
|             "The provided parameters %s are invalid: %s" % (
 | |
|                 ', '.join(["%s=%s" % (k, v) for k, v in params.items()]),
 | |
|                 to_native(e)
 | |
|             )
 | |
|         )
 | |
| 
 | |
| 
 | |
| def hashids_encode(nums, salt=None, alphabet=None, min_length=None):
 | |
|     """Generates a YouTube-like hash from a sequence of ints
 | |
| 
 | |
|        :nums: Sequence of one or more ints to hash
 | |
|        :salt: String to use as salt when hashing
 | |
|        :alphabet: String of 16 or more unique characters to produce a hash
 | |
|        :min_length: Minimum length of hash produced
 | |
|     """
 | |
| 
 | |
|     hashids = initialize_hashids(
 | |
|         salt=salt,
 | |
|         alphabet=alphabet,
 | |
|         min_length=min_length
 | |
|     )
 | |
| 
 | |
|     # Handles the case where a single int is not encapsulated in a list or tuple.
 | |
|     # User convenience seems preferable to strict typing in this case
 | |
|     # Also avoids obfuscated error messages related to single invalid inputs
 | |
|     if not is_sequence(nums):
 | |
|         nums = [nums]
 | |
| 
 | |
|     try:
 | |
|         hashid = hashids.encode(*nums)
 | |
|     except TypeError as e:
 | |
|         raise AnsibleTypeError(
 | |
|             "Data to encode must by a tuple or list of ints: %s" % to_native(e)
 | |
|         )
 | |
| 
 | |
|     return hashid
 | |
| 
 | |
| 
 | |
| def hashids_decode(hashid, salt=None, alphabet=None, min_length=None):
 | |
|     """Decodes a YouTube-like hash to a sequence of ints
 | |
| 
 | |
|        :hashid: Hash string to decode
 | |
|        :salt: String to use as salt when hashing
 | |
|        :alphabet: String of 16 or more unique characters to produce a hash
 | |
|        :min_length: Minimum length of hash produced
 | |
|     """
 | |
| 
 | |
|     hashids = initialize_hashids(
 | |
|         salt=salt,
 | |
|         alphabet=alphabet,
 | |
|         min_length=min_length
 | |
|     )
 | |
|     nums = hashids.decode(hashid)
 | |
|     return list(nums)
 | |
| 
 | |
| 
 | |
| class FilterModule(object):
 | |
| 
 | |
|     def filters(self):
 | |
|         return {
 | |
|             'hashids_encode': hashids_encode,
 | |
|             'hashids_decode': hashids_decode,
 | |
|         }
 |