 dc8596fe74
			
		
	
	dc8596fe74
	
	
	
		
			
			Change-Id: I665cd61272f881dce2d387da6035a2f35c866add Signed-off-by: Stephen Finucane <stephenfin@redhat.com>
		
			
				
	
	
		
			58 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			58 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| # Licensed under the Apache License, Version 2.0 (the "License"); you may
 | |
| # not use this file except in compliance with the License. You may obtain
 | |
| # a copy of the License at
 | |
| #
 | |
| #     http://www.apache.org/licenses/LICENSE-2.0
 | |
| #
 | |
| # Unless required by applicable law or agreed to in writing, software
 | |
| # distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
 | |
| # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
 | |
| # License for the specific language governing permissions and limitations
 | |
| # under the License.
 | |
| 
 | |
| import os
 | |
| 
 | |
| from openstackclient.i18n import _
 | |
| 
 | |
| 
 | |
| def bool_from_str(value, strict=False):
 | |
|     true_strings = ('1', 't', 'true', 'on', 'y', 'yes')
 | |
|     false_strings = ('0', 'f', 'false', 'off', 'n', 'no')
 | |
| 
 | |
|     if isinstance(value, bool):
 | |
|         return value
 | |
| 
 | |
|     lowered = value.strip().lower()
 | |
|     if lowered in true_strings:
 | |
|         return True
 | |
|     elif lowered in false_strings or not strict:
 | |
|         return False
 | |
| 
 | |
|     msg = _(
 | |
|         "Unrecognized value '%(value)s'; acceptable values are: %(valid)s"
 | |
|     ) % {
 | |
|         'value': value,
 | |
|         'valid': ', '.join(
 | |
|             f"'{s}'" for s in sorted(true_strings + false_strings)
 | |
|         ),
 | |
|     }
 | |
|     raise ValueError(msg)
 | |
| 
 | |
| 
 | |
| def boolenv(*vars, default=False):
 | |
|     """Search for the first defined of possibly many bool-like env vars.
 | |
| 
 | |
|     Returns the first environment variable defined in vars, or returns the
 | |
|     default.
 | |
| 
 | |
|     :param vars: Arbitrary strings to search for. Case sensitive.
 | |
|     :param default: The default to return if no value found.
 | |
|     :returns: A boolean corresponding to the value found, else the default if
 | |
|         no value found.
 | |
|     """
 | |
|     for v in vars:
 | |
|         value = os.environ.get(v, None)
 | |
|         if value:
 | |
|             return bool_from_str(value)
 | |
|     return default
 |