mirror of
				https://github.com/ansible-collections/community.general.git
				synced 2025-10-24 21:14:00 -07:00 
			
		
		
		
	* Move licenses to LICENSES/, run add-license.py, add LICENSES/MIT.txt. * Replace 'Copyright:' with 'Copyright' sed -i 's|Copyright:\(.*\)|Copyright\1|' $(rg -l 'Copyright:') Co-authored-by: Maxwell G <gotmax@e.email>
		
			
				
	
	
		
			100 lines
		
	
	
	
		
			2.8 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			100 lines
		
	
	
	
		
			2.8 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| # -*- coding: utf-8 -*-
 | |
| # Copyright (c) 2021, Abhijeet Kasurde <akasurde@redhat.com>
 | |
| # Copyright (c) 2018, Ansible Project
 | |
| # 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 (absolute_import, division, print_function)
 | |
| 
 | |
| __metaclass__ = type
 | |
| 
 | |
| DOCUMENTATION = r'''
 | |
|     name: random_pet
 | |
|     author:
 | |
|       - Abhijeet Kasurde (@Akasurde)
 | |
|     short_description: Generates random pet names
 | |
|     version_added: '3.1.0'
 | |
|     requirements:
 | |
|       - petname U(https://github.com/dustinkirkland/python-petname)
 | |
|     description:
 | |
|       - Generates random pet names that can be used as unique identifiers for the resources.
 | |
|     options:
 | |
|       words:
 | |
|         description:
 | |
|         - The number of words in the pet name.
 | |
|         default: 2
 | |
|         type: int
 | |
|       length:
 | |
|         description:
 | |
|         - The maximal length of every component of the pet name.
 | |
|         - Values below 3 will be set to 3 by petname.
 | |
|         default: 6
 | |
|         type: int
 | |
|       prefix:
 | |
|         description: A string to prefix with the name.
 | |
|         type: str
 | |
|       separator:
 | |
|         description: The character to separate words in the pet name.
 | |
|         default: "-"
 | |
|         type: str
 | |
| '''
 | |
| 
 | |
| EXAMPLES = r'''
 | |
| - name: Generate pet name
 | |
|   ansible.builtin.debug:
 | |
|     var: lookup('community.general.random_pet')
 | |
|   # Example result: 'loving-raptor'
 | |
| 
 | |
| - name: Generate pet name with 3 words
 | |
|   ansible.builtin.debug:
 | |
|     var: lookup('community.general.random_pet', words=3)
 | |
|   # Example result: 'fully-fresh-macaw'
 | |
| 
 | |
| - name: Generate pet name with separator
 | |
|   ansible.builtin.debug:
 | |
|     var: lookup('community.general.random_pet', separator="_")
 | |
|   # Example result: 'causal_snipe'
 | |
| 
 | |
| - name: Generate pet name with length
 | |
|   ansible.builtin.debug:
 | |
|     var: lookup('community.general.random_pet', length=7)
 | |
|   # Example result: 'natural-peacock'
 | |
| '''
 | |
| 
 | |
| RETURN = r'''
 | |
|   _raw:
 | |
|     description: A one-element list containing a random pet name
 | |
|     type: list
 | |
|     elements: str
 | |
| '''
 | |
| 
 | |
| try:
 | |
|     import petname
 | |
| 
 | |
|     HAS_PETNAME = True
 | |
| except ImportError:
 | |
|     HAS_PETNAME = False
 | |
| 
 | |
| from ansible.errors import AnsibleError
 | |
| from ansible.plugins.lookup import LookupBase
 | |
| 
 | |
| 
 | |
| class LookupModule(LookupBase):
 | |
| 
 | |
|     def run(self, terms, variables=None, **kwargs):
 | |
| 
 | |
|         if not HAS_PETNAME:
 | |
|             raise AnsibleError('Python petname library is required. '
 | |
|                                'Please install using "pip install petname"')
 | |
| 
 | |
|         self.set_options(var_options=variables, direct=kwargs)
 | |
|         words = self.get_option('words')
 | |
|         length = self.get_option('length')
 | |
|         prefix = self.get_option('prefix')
 | |
|         separator = self.get_option('separator')
 | |
| 
 | |
|         values = petname.Generate(words=words, separator=separator, letters=length)
 | |
|         if prefix:
 | |
|             values = "%s%s%s" % (prefix, separator, values)
 | |
| 
 | |
|         return [values]
 |