當前位置: 首頁>>代碼示例>>Python>>正文


Python _text.to_native方法代碼示例

本文整理匯總了Python中ansible.module_utils._text.to_native方法的典型用法代碼示例。如果您正苦於以下問題:Python _text.to_native方法的具體用法?Python _text.to_native怎麽用?Python _text.to_native使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在ansible.module_utils._text的用法示例。


在下文中一共展示了_text.to_native方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: query_metadata

# 需要導入模塊: from ansible.module_utils import _text [as 別名]
# 或者: from ansible.module_utils._text import to_native [as 別名]
def query_metadata(metadata_url, headers=None, expect_json=False):
    """ Return metadata from the provided metadata_url

        Args:
            metadata_url (str): metadata url
            headers (dict): headers to set for metadata request
            expect_json (bool): does the metadata_url return json
        Returns:
            dict or list: metadata request result
    """
    result, info = fetch_url(module, metadata_url, headers=headers)
    if info['status'] != 200:
        raise OpenShiftFactsMetadataUnavailableError("Metadata unavailable")
    if expect_json:
        return module.from_json(to_native(result.read()))
    else:
        return [to_native(line.strip()) for line in result.readlines()] 
開發者ID:openshift,項目名稱:origin-ci-tool,代碼行數:19,代碼來源:openshift_facts.py

示例2: _get_instances_by_region

# 需要導入模塊: from ansible.module_utils import _text [as 別名]
# 或者: from ansible.module_utils._text import to_native [as 別名]
def _get_instances_by_region(self, regions, filters):
        '''
           :param regions: a list of regions in which to describe instances
           :param filters: a list of ECS filter dictionaries
           :return A list of instance dictionaries
        '''
        all_instances = []
        if not regions:
            try:
                regions = list(map(lambda x: x.id, self.connect_to_ecs(footmark.ecs, "cn-beijing").describe_regions()))
            except Exception as e:
                raise AnsibleError('Unable to get regions list from available methods, you must specify the "regions" option to continue.')

        for region in regions:
            try:
                conn = connect_to_acs(footmark.ecs, region, **self.credentials)
                insts = conn.describe_instances(**filters)
                all_instances.extend(map(lambda x: x.read(), insts))
            except Exception as e:
                raise AnsibleError("Failed to describe instances: %s" % to_native(e))
        return sorted(all_instances, key=lambda x: x['instance_id']) 
開發者ID:alibaba,項目名稱:alibaba.alicloud,代碼行數:23,代碼來源:alicloud_ecs.py

示例3: resource_action

# 需要導入模塊: from ansible.module_utils import _text [as 別名]
# 或者: from ansible.module_utils._text import to_native [as 別名]
def resource_action(self, resource, action, params, options=None, data=None, files=None,
                        ignore_check_mode=False, record_change=True, ignore_task_errors=False):
        resource_payload = self._resource_prepare_params(resource, action, params)
        if options is None:
            options = {}
        try:
            result = None
            if ignore_check_mode or not self.check_mode:
                result = self._resource_call(resource, action, resource_payload, options=options, data=data, files=files)
                is_foreman_task = isinstance(result, dict) and 'action' in result and 'state' in result and 'started_at' in result
                if is_foreman_task:
                    result = self.wait_for_task(result, ignore_errors=ignore_task_errors)
        except Exception as e:
            msg = 'Error while performing {0} on {1}: {2}'.format(
                action, resource, to_native(e))
            self.fail_from_exception(e, msg)
        if record_change and not ignore_check_mode:
            # If we were supposed to ignore check_mode we can assume this action was not a changing one.
            self.set_changed()
        return result 
開發者ID:theforeman,項目名稱:foreman-ansible-modules,代碼行數:22,代碼來源:foreman_helper.py

示例4: parse_template

# 需要導入模塊: from ansible.module_utils import _text [as 別名]
# 或者: from ansible.module_utils._text import to_native [as 別名]
def parse_template(template_content, module):
    if not HAS_PYYAML:
        module.fail_json(msg=missing_required_lib("PyYAML"), exception=PYYAML_IMP_ERR)

    try:
        template_dict = {}
        data = re.search(
            r'<%#([^%]*([^%]*%*[^>%])*%*)%>', template_content)
        if data:
            datalist = data.group(1)
            if datalist[-1] == '-':
                datalist = datalist[:-1]
            template_dict = yaml.safe_load(datalist)
        # No metadata, import template anyway
        template_dict['template'] = template_content
    except Exception as e:
        module.fail_json(msg='Error while parsing template: ' + to_native(e))
    return template_dict 
開發者ID:theforeman,項目名稱:foreman-ansible-modules,代碼行數:20,代碼來源:foreman_helper.py

示例5: _perform_action

# 需要導入模塊: from ansible.module_utils import _text [as 別名]
# 或者: from ansible.module_utils._text import to_native [as 別名]
def _perform_action(self, action):
        """Perform action with container

        Arguments:
            action {str} -- action to perform - start, create, stop, run, delete
        """
        b_command = construct_command_from_params(action, self.module.params)
        self.module.log(
            "PODMAN-DEBUG: %s" % " ".join([to_native(i) for i in b_command])
        )
        rc, out, err = run_podman_command(
            module=self.module, args=[b"container"] + b_command, ignore_errors=True
        )
        if rc != 0:
            self.module.fail_json(
                msg="Can't %s container %s" % (action, self.name),
                stdout=out,
                stderr=err,
            ) 
開發者ID:openshift-kni,項目名稱:baremetal-deploy,代碼行數:21,代碼來源:podman_container.py

示例6: grafana_list_dashboards

# 需要導入模塊: from ansible.module_utils import _text [as 別名]
# 或者: from ansible.module_utils._text import to_native [as 別名]
def grafana_list_dashboards(self):
        # define http headers
        headers = self.grafana_headers()

        dashboard_list = []
        try:
            if self.search:
                r = open_url('%s/api/search?query=%s' % (self.grafana_url, self.search), headers=headers, method='GET')
            else:
                r = open_url('%s/api/search/' % self.grafana_url, headers=headers, method='GET')
        except HTTPError as e:
            raise GrafanaAPIException('Unable to search dashboards : %s' % to_native(e))
        if r.getcode() == 200:
            try:
                dashboard_list = json.loads(r.read())
            except Exception as e:
                raise GrafanaAPIException('Unable to parse json list %s' % to_native(e))
        else:
            raise GrafanaAPIException('Unable to list grafana dashboards : %s' % str(r.getcode()))

        return dashboard_list 
開發者ID:ansible-collections,項目名稱:community.grafana,代碼行數:23,代碼來源:grafana_dashboard.py

示例7: find_object_by_name

# 需要導入模塊: from ansible.module_utils import _text [as 別名]
# 或者: from ansible.module_utils._text import to_native [as 別名]
def find_object_by_name(module,content, object_name):
    try:
    	if(object_name == module.params['datacenter']):
    	    vmware_objects = get_all_objs(module,content,[vim.Datacenter])
    	elif (object_name == module.params['cluster']):
    	    vmware_objects = get_all_objs(module,content,[vim.ComputeResource])
    	elif (object_name == module.params['datastore']):
            vmware_objects = get_all_objs(module,content,[vim.Datastore])
    	elif (object_name == module.params['portgroup1'] or module.params['portgroup2'] or module.params['portgroup3'] ):
            vmware_objects = get_all_objs(module,content,[vim.dvs.DistributedVirtualPortgroup, vim.Network])
 
    	for object in vmware_objects:
            if object.name == object_name:
            	logger.info('object: %s',object.name)
            	return object
    	return None
    except Exception as err:
       module.fail_json(changed=False, msg= "Error Occured while Finding the Object by name. Error is %s" %(to_native(err))) 
開發者ID:vmware-archive,項目名稱:ansible-module-chaperone,代碼行數:20,代碼來源:nsxt_vcenter_moids.py

示例8: transform_list_to_dict

# 需要導入模塊: from ansible.module_utils import _text [as 別名]
# 或者: from ansible.module_utils._text import to_native [as 別名]
def transform_list_to_dict(list_):
    """
    Transforms a list into a dictionary, putting values as keys.

    :arg list list_: List of values
    :return: dict: dictionary built
    """

    ret = {}

    if not list_:
        return ret

    for value in list_:
        if isinstance(value, collections.Mapping):
            ret.update(value)
        else:
            ret[to_native(value)] = True

    return ret


# Makes a deep merge of 2 dictionaries and returns the merged dictionary 
開發者ID:HewlettPackard,項目名稱:oneview-ansible,代碼行數:25,代碼來源:oneview.py

示例9: _connect

# 需要導入模塊: from ansible.module_utils import _text [as 別名]
# 或者: from ansible.module_utils._text import to_native [as 別名]
def _connect(self):
        if self.module.params['file_mode']:
            self.forti_device = FortiOS('')
        else:
            host = self.module.params['host']
            username = self.module.params['username']
            password = self.module.params['password']
            timeout = self.module.params['timeout']
            vdom = self.module.params['vdom']

            self.forti_device = FortiOS(host, username=username, password=password, timeout=timeout, vdom=vdom)

            try:
                self.forti_device.open()
            except Exception as e:
                self.module.fail_json(msg='Error connecting device. %s' % to_native(e),
                                      exception=traceback.format_exc()) 
開發者ID:eoprede,項目名稱:ansible_fortios_api,代碼行數:19,代碼來源:fortios_api.py

示例10: export_manifest

# 需要導入模塊: from ansible.module_utils import _text [as 別名]
# 或者: from ansible.module_utils._text import to_native [as 別名]
def export_manifest(module, manifest):
    path = "/subscription/consumers/%s/export" % (manifest['uuid'])
    try:
        resp, info = fetch_portal(module, path, 'GET', accept_header='application/zip')
        if not module.check_mode:
            with open(module.params['path'], 'wb') as f:
                while True:
                    data = resp.read(65536)  # 64K
                    if not data:
                        break
                    f.write(data)
    except Exception as e:
        module.fail_json(msg="Failure downloading manifest, {0}".format(to_native(e))) 
開發者ID:theforeman,項目名稱:foreman-ansible-modules,代碼行數:15,代碼來源:redhat_manifest.py

示例11: _exception2fail_json

# 需要導入模塊: from ansible.module_utils import _text [as 別名]
# 或者: from ansible.module_utils._text import to_native [as 別名]
def _exception2fail_json(msg='Generic failure: {0}'):
    def decor(f):
        @wraps(f)
        def inner(self, *args, **kwargs):
            try:
                return f(self, *args, **kwargs)
            except Exception as e:
                self.fail_from_exception(e, msg.format(to_native(e)))
        return inner
    return decor 
開發者ID:theforeman,項目名稱:foreman-ansible-modules,代碼行數:12,代碼來源:foreman_helper.py

示例12: _update_entity

# 需要導入模塊: from ansible.module_utils import _text [as 別名]
# 或者: from ansible.module_utils._text import to_native [as 別名]
def _update_entity(self, resource, desired_entity, current_entity, params, foreman_spec):
        """Update a given entity with given properties if any diverge

            Parameters:
                resource (string): Plural name of the api resource to manipulate
                desired_entity (dict): Desired properties of the entity
                current_entity (dict): Current properties of the entity
                params (dict): Lookup parameters (i.e. parent_id for nested entities) (optional)
                foreman_spec (dict): Description of the entity structure
            Return value:
                The new current state if the entity
        """
        payload = {}
        desired_entity = _flatten_entity(desired_entity, foreman_spec)
        current_entity = _flatten_entity(current_entity, foreman_spec)
        for key, value in desired_entity.items():
            # String comparison needs extra care in face of unicode
            if foreman_spec[key].get('type', 'str') == 'str':
                if to_native(current_entity.get(key)) != to_native(value):
                    payload[key] = value
            else:
                if current_entity.get(key) != value:
                    payload[key] = value
        if payload:
            payload['id'] = current_entity['id']
            if not self.check_mode:
                if params:
                    payload.update(params)
                return self.resource_action(resource, 'update', payload)
            else:
                # In check_mode we emulate the server updating the entity
                fake_entity = current_entity.copy()
                fake_entity.update(payload)
                self.set_changed()
                return fake_entity
        else:
            # Nothing needs changing
            return current_entity 
開發者ID:theforeman,項目名稱:foreman-ansible-modules,代碼行數:40,代碼來源:foreman_helper.py

示例13: download_plugin

# 需要導入模塊: from ansible.module_utils import _text [as 別名]
# 或者: from ansible.module_utils._text import to_native [as 別名]
def download_plugin(module, plugin_url, file_name, download_cache):
    if not os.path.isdir(download_cache):
        os.makedirs(download_cache, 0o775)

    download_path = os.path.join(download_cache, file_name)

    if os.path.isfile(download_path):
        return download_path

    for _ in range(0, 3):
        resp, info = fetch_url(
            module, plugin_url, method='GET', timeout=20, follow_redirects=True)
        status_code = info['status']

        if status_code >= 200 and status_code < 300:
            tmp_dest = getattr(module, 'tmpdir', None)

            fd, b_tempname = tempfile.mkstemp(dir=tmp_dest)

            f = os.fdopen(fd, 'wb')
            try:
                shutil.copyfileobj(resp, f)
            except Exception as e:
                os.remove(b_tempname)
                resp.close()
                module.fail_json(
                    msg='Failed to create temporary content file: %s' %
                    to_native(e))
            f.close()
            resp.close()

            module.atomic_move(to_native(b_tempname), download_path)

            return download_path

        if resp is not None:
            resp.close()

    module.fail_json(msg='Error downloading url "%s": %s' % (plugin_url,
                                                             info['msg'])) 
開發者ID:gantsign,項目名稱:ansible-role-intellij,代碼行數:42,代碼來源:intellij_install_plugin.py

示例14: parse

# 需要導入模塊: from ansible.module_utils import _text [as 別名]
# 或者: from ansible.module_utils._text import to_native [as 別名]
def parse(self, inventory, loader, host_string, cache=None):
        super(InventoryStringPlugin, self).parse(inventory, loader, host_string)
        try:
            if "," in host_string:
                host_string = [h.strip() for h in host_string.split(',') if h and h.strip()]
            else:
                host_string = [ host_string]

            for h in host_string:
                if h not in self.inventory.hosts:
                    self.inventory.add_host(h, group='ungrouped', port=None)
        except Exception as e:
            raise AnsibleParserError("Invalid data from string, could not parse: %s" % to_native(e)) 
開發者ID:opendevops-cn,項目名稱:codo-cmdb,代碼行數:15,代碼來源:myinventory.py

示例15: server_exists

# 需要導入模塊: from ansible.module_utils import _text [as 別名]
# 或者: from ansible.module_utils._text import to_native [as 別名]
def server_exists(api, server):
    # hack to determine if virtual server exists
    result = False
    try:
        api.GlobalLB.Server.get_object_status([server])
        result = True
    except bigsuds.OperationFailed as e:
        if "was not found" in to_native(e):
            result = False
        else:
            # genuine exception
            raise
    return result 
開發者ID:mcgonagle,項目名稱:ansible_f5,代碼行數:15,代碼來源:bigip_gtm_virtual_server.py


注:本文中的ansible.module_utils._text.to_native方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。