U C^1-@s^ddlZddlmZddlmZddZdddZd d ZGd d d eZ Gd ddeZ dS)N) xform_name)get_data_membercCs|D]}|dkrdSqdS)z Return True if all elements of the iterable are not None (or if the iterable is empty). This is like the built-in ``all``, except checks against None, so 0 and False are allowable values. NFT)iterableelementrr;/tmp/pip-install-6_kvzl1k/boto3/boto3/resources/response.py all_not_nonesr c Csg}|D]}|j}|j}|dkr0t|j|}nb|dkrHt|j|}nJ|dkrbt|t|j}n0|dkrxt||j}n|dkrqnt d || t||fq|S)a Builds a mapping of identifier names to values based on the identifier source location, type, and target. Identifier values may be scalars or lists depending on the source type and location. :type identifiers: list :param identifiers: List of :py:class:`~boto3.resources.model.Parameter` definitions :type parent: ServiceResource :param parent: The resource instance to which this action is attached. :type params: dict :param params: Request parameters sent to the service. :type raw_response: dict :param raw_response: Low-level operation response. :rtype: list :return: An ordered list of ``(name, value)`` identifier tuples. responseZrequestParameter identifierdatainputzUnsupported source type: {0}) sourcetargetjmespathsearchpathgetattrrnamerNotImplementedErrorformatappend) identifiersparentparams raw_responseresultsr rrvaluerrrbuild_identifiers s&rcCsd}||}|j}|rl|dD]H}|d}|jdkrF|j|}q"|jdkrX|j}q"td|j|q"|jdkr|i}n|jdkrg}n|jdkri}|S)a Creates an appropriate empty response for the type that is expected, based on the service model's shape type. For example, a value that is normally a list would then return an empty list. A structure would return an empty dict, and a number would return None. :type search_path: string :param search_path: JMESPath expression to search in the response :type operation_name: string :param operation_name: Name of the underlying service operation. :type service_model: :ref:`botocore.model.ServiceModel` :param service_model: The Botocore service model :rtype: dict, list, or None :return: An appropriate empty value N.z [0123456789]$Z structurelistz(Search path hits shape type {0} from {1}map) operation_modelZ output_shapesplitstrip type_namemembersmemberrr) search_pathoperation_name service_modelr r"shapeitemrrrbuild_empty_responseOs.        r-c@s eZdZdZddZddZdS) RawHandleraG A raw action response handler. This passed through the response dictionary, optionally after performing a JMESPath search if one has been defined for the action. :type search_path: string :param search_path: JMESPath expression to search in the response :rtype: dict :return: Service response cCs ||_dSN)r()selfr(rrr__init__szRawHandler.__init__cCs"|jr|jdkrt|j|}|S), :type parent: ServiceResource :param parent: The resource instance to which this action is attached. :type params: dict :param params: Request parameters sent to the service. :type response: dict :param response: Low-level operation response. $)r(rr)r0rrr rrr__call__s zRawHandler.__call__N)__name__ __module__ __qualname____doc__r1r4rrrrr.s r.c@s*eZdZdZd ddZddZddZdS) ResourceHandleraf Creates a new resource or list of new resources from the low-level response based on the given response resource definition. :type search_path: string :param search_path: JMESPath expression to search in the response :type factory: ResourceFactory :param factory: The factory that created the resource class to which this action is attached. :type resource_model: :py:class:`~boto3.resources.model.ResponseResource` :param resource_model: Response resource model. :type service_context: :py:class:`~boto3.utils.ServiceContext` :param service_context: Context about the AWS service :type operation_name: string :param operation_name: Name of the underlying service operation, if it exists. :rtype: ServiceResource or list :return: New resource instance(s). NcCs"||_||_||_||_||_dSr/)r(factoryresource_modelr)service_context)r0r(r:r;r<r)rrrr1s zResourceHandler.__init__c Cs|jj}|jj|}|jj|||jd}|}d}|jrFt |j|}t t |jj |||} dd| D} | rg}tt| dD]*} d} |r|| } ||||| | qn@t| r|||| |}n"d}|jdk rt|j|j|jj}|S)r2) resource_nameZsingle_resource_json_definitionr<NcSsg|]}t|tr|qSr) isinstancer ).0vrrr s z,ResourceHandler.__call__..r)r;typer<Zresource_json_definitionsgetr:Zload_from_definitionr(rrdictrrvaluesrangelenrhandle_response_itemr r)r-r*) r0rrr r=Zjson_definition resource_clsrZsearch_responserpluraliZ response_itemrrrr4s^   zResourceHandler.__call__c CsXd|jji}|D]$\}}t|tr0|d}|||<q|f|}|dk rT||j_|S)a Handles the creation of a single response item by setting parameters and creating the appropriate resource instance. :type resource_cls: ServiceResource subclass :param resource_cls: The resource class to instantiate. :type parent: ServiceResource :param parent: The resource instance to which this action is attached. :type identifiers: dict :param identifiers: Map of identifier names to value or values. :type resource_data: dict or None :param resource_data: Data for resource attributes. :rtype: ServiceResource :return: New resource instance. clientrN)metarLitemsr>r popr ) r0rIrrZ resource_datakwargsrrresourcerrrrH s    z$ResourceHandler.handle_response_item)N)r5r6r7r8r1r4rHrrrrr9s  Lr9)NN) rZbotocorerrrr rr-objectr.r9rrrrs   /1