
    piY                         d Z ddlmZ ddlmZmZmZmZmZmZm	Z	 ddl
mZmZmZ ddlmZ ddlmZ ddlmZ ddlmZ  G d	 d
e      Z G d de      Z G d de      Zy)a  
    This code was generated by
   ___ _ _ _ _ _    _ ____    ____ ____ _    ____ ____ _  _ ____ ____ ____ ___ __   __
    |  | | | | |    | |  | __ |  | |__| | __ | __ |___ |\ | |___ |__/ |__|  | |  | |__/
    |  |_|_| | |___ | |__|    |__| |  | |    |__] |___ | \| |___ |  \ |  |  | |__| |  \

    Twilio - Content
    This is the public Twilio REST API.

    NOTE: This class is auto generated by OpenAPI Generator.
    https://openapi-generator.tech
    Do not edit the class manually.
    )datetime)AnyDictListOptionalUnionIteratorAsyncIterator)deserialize	serializevalues)InstanceResource)ListResource)Version)Pagec                   B     e Zd ZdZdedeeef   f fdZdefdZ	 xZ
S )ContentAndApprovalsInstanceaw  
    :ivar date_created: The date and time in GMT that the resource was created specified in [RFC 2822](https://www.ietf.org/rfc/rfc2822.txt) format.
    :ivar date_updated: The date and time in GMT that the resource was last updated specified in [RFC 2822](https://www.ietf.org/rfc/rfc2822.txt) format.
    :ivar sid: The unique string that that we created to identify the Content resource.
    :ivar account_sid: The SID of the [Account](https://www.twilio.com/docs/usage/api/account) that created Content resource.
    :ivar friendly_name: A string name used to describe the Content resource. Not visible to the end recipient.
    :ivar language: Two-letter (ISO 639-1) language code (e.g., en) identifying the language the Content resource is in.
    :ivar variables: Defines the default placeholder values for variables included in the Content resource. e.g. {"1": "Customer_Name"}.
    :ivar types: The [Content types](https://www.twilio.com/docs/content/content-types-overview) (e.g. twilio/text) for this Content resource.
    :ivar approval_requests: The submitted information and approval request status of the Content resource.
    versionpayloadc                    t         |   |       t        j                  |j	                  d            | _        t        j                  |j	                  d            | _        |j	                  d      | _        |j	                  d      | _        |j	                  d      | _	        |j	                  d      | _
        |j	                  d      | _        |j	                  d      | _        |j	                  d	      | _        y )
Ndate_createddate_updatedsidaccount_sidfriendly_namelanguage	variablestypesapproval_requests)super__init__r   iso8601_datetimegetr   r   r   r   r   r   r   r   r   )selfr   r   	__class__s      n/opt/services/ai/voice_agent/venv/lib/python3.12/site-packages/twilio/rest/content/v2/content_and_approvals.pyr!   z$ContentAndApprovalsInstance.__init__&   s    !0;0L0LKK'1
 1<0L0LKK'1
 #*++e"4*1++m*D,3KK,H'.{{:'>6=kk+6N29++g2F
>Ekk?
    returnc                      y)f
        Provide a friendly representation

        :returns: Machine friendly representation
        z/<Twilio.Content.V2.ContentAndApprovalsInstance> r$   s    r&   __repr__z$ContentAndApprovalsInstance.__repr__9   s     Ar'   )__name__
__module____qualname____doc__r   r   strr   r!   r-   __classcell__r%   s   @r&   r   r      s1    

 
$sCx. 
&A# Ar'   r   c                   2    e Zd Zdeeef   defdZdefdZy)ContentAndApprovalsPager   r(   c                 .    t        | j                  |      S )zy
        Build an instance of ContentAndApprovalsInstance

        :param payload: Payload response from the API
        )r   _version)r$   r   s     r&   get_instancez$ContentAndApprovalsPage.get_instanceE   s     +4=='BBr'   c                      y)r*   z+<Twilio.Content.V2.ContentAndApprovalsPage>r+   r,   s    r&   r-   z ContentAndApprovalsPage.__repr__M        =r'   N)	r.   r/   r0   r   r2   r   r   r9   r-   r+   r'   r&   r6   r6   C   s-    CDcN C7R C=# =r'   r6   c                   	    e Zd Zdef fdZej                  ej                  ej                  ej                  ej                  ej                  ej                  ej                  ej                  ddfdeee	f   deee	f   dee
e	f   dee
e	f   deee	f   d	eee	f   d
eee   e	f   deee   e	f   deee   e	f   dee   dee   dee   fdZej                  ej                  ej                  ej                  ej                  ej                  ej                  ej                  ej                  ddfdeee	f   deee	f   dee
e	f   dee
e	f   deee	f   d	eee	f   d
eee   e	f   deee   e	f   deee   e	f   dee   dee   dee   fdZej                  ej                  ej                  ej                  ej                  ej                  ej                  ej                  ej                  ddfdeee	f   deee	f   dee
e	f   dee
e	f   deee	f   d	eee	f   d
eee   e	f   deee   e	f   deee   e	f   dee   dee   dee   fdZej                  ej                  ej                  ej                  ej                  ej                  ej                  ej                  ej                  ddfdeee	f   deee	f   dee
e	f   dee
e	f   deee	f   d	eee	f   d
eee   e	f   deee   e	f   deee   e	f   dee   dee   dee   fdZej                  ej                  ej                  ej                  ej                  ej                  ej                  ej                  ej                  ej                  ej                  ej                  fdeee	f   deee	f   dee
e	f   dee
e	f   deee	f   d	eee	f   d
eee   e	f   deee   e	f   deee   e	f   deee	f   deee	f   deee	f   defdZej                  ej                  ej                  ej                  ej                  ej                  ej                  ej                  ej                  ej                  ej                  ej                  fdeee	f   deee	f   dee
e	f   dee
e	f   deee	f   d	eee	f   d
eee   e	f   deee   e	f   deee   e	f   deee	f   deee	f   deee	f   defdZdedefdZdedefdZdefdZ xZS )ContentAndApprovalsListr   c                 2    t         |   |       d| _        y)zu
        Initialize the ContentAndApprovalsList

        :param version: Version that contains the resource

        z/ContentAndApprovalsN)r    r!   _uri)r$   r   r%   s     r&   r!   z ContentAndApprovalsList.__init__X   s     	!*	r'   Nsort_by_datesort_by_content_namedate_created_afterdate_created_beforecontent_namecontentr   content_typechannel_eligibilitylimit	page_sizer(   c                     | j                   j                  |
|      }| j                  |||||||||	|d   
      }| j                   j                  ||d         S )aR  
        Streams ContentAndApprovalsInstance records from the API as a generator stream.
        This operation lazily loads records as efficiently as possible until the limit
        is reached.
        The results are returned as a generator, so this operation is memory efficient.

        :param str sort_by_date: Whether to sort by ascending or descending date updated
        :param str sort_by_content_name: Whether to sort by ascending or descending content name
        :param datetime date_created_after: Filter by >=[date-time]
        :param datetime date_created_before: Filter by <=[date-time]
        :param str content_name: Filter by Regex Pattern in content name
        :param str content: Filter by Regex Pattern in template content
        :param List[str] language: Filter by array of valid language(s)
        :param List[str] content_type: Filter by array of contentType(s)
        :param List[str] channel_eligibility: Filter by array of ChannelEligibility(s), where ChannelEligibility=<channel>:<status>
        :param limit: Upper limit for the number of records to return. stream()
                      guarantees to never return more than limit.  Default is no limit
        :param page_size: Number of records to fetch per request, when not set will use
                          the default value of 50 records.  If no page_size is defined
                          but a limit is defined, stream() will attempt to read the
                          limit with the most efficient page size, i.e. min(limit, 1000)

        :returns: Generator that will yield up to limit results
        rI   
r@   rA   rB   rC   rD   rE   r   rF   rG   rI   rH   )r8   read_limitspagestreamr$   r@   rA   rB   rC   rD   rE   r   rF   rG   rH   rI   limitsrM   s                 r&   rN   zContentAndApprovalsList.streamc   sn    L **5)<yy%!51 3%% 3[)  
 }}##D&/::r'   c                    K   | j                   j                  |
|      }| j                  |||||||||	|d   
       d{   }| j                   j                  ||d         S 7 #w)aa  
        Asynchronously streams ContentAndApprovalsInstance records from the API as a generator stream.
        This operation lazily loads records as efficiently as possible until the limit
        is reached.
        The results are returned as a generator, so this operation is memory efficient.

        :param str sort_by_date: Whether to sort by ascending or descending date updated
        :param str sort_by_content_name: Whether to sort by ascending or descending content name
        :param datetime date_created_after: Filter by >=[date-time]
        :param datetime date_created_before: Filter by <=[date-time]
        :param str content_name: Filter by Regex Pattern in content name
        :param str content: Filter by Regex Pattern in template content
        :param List[str] language: Filter by array of valid language(s)
        :param List[str] content_type: Filter by array of contentType(s)
        :param List[str] channel_eligibility: Filter by array of ChannelEligibility(s), where ChannelEligibility=<channel>:<status>
        :param limit: Upper limit for the number of records to return. stream()
                      guarantees to never return more than limit.  Default is no limit
        :param page_size: Number of records to fetch per request, when not set will use
                          the default value of 50 records.  If no page_size is defined
                          but a limit is defined, stream() will attempt to read the
                          limit with the most efficient page size, i.e. min(limit, 1000)

        :returns: Generator that will yield up to limit results
        rI   rK   NrH   )r8   rL   
page_asyncstream_asyncrO   s                 r&   rS   z$ContentAndApprovalsList.stream_async   s|     L **5)<__%!51 3%% 3[) % 
 
 }}))$w@@
s   >A& A$$A&c                 L    t        | j                  |||||||||	|
|            S )a  
        Lists ContentAndApprovalsInstance records from the API as a list.
        Unlike stream(), this operation is eager and will load `limit` records into
        memory before returning.

        :param str sort_by_date: Whether to sort by ascending or descending date updated
        :param str sort_by_content_name: Whether to sort by ascending or descending content name
        :param datetime date_created_after: Filter by >=[date-time]
        :param datetime date_created_before: Filter by <=[date-time]
        :param str content_name: Filter by Regex Pattern in content name
        :param str content: Filter by Regex Pattern in template content
        :param List[str] language: Filter by array of valid language(s)
        :param List[str] content_type: Filter by array of contentType(s)
        :param List[str] channel_eligibility: Filter by array of ChannelEligibility(s), where ChannelEligibility=<channel>:<status>
        :param limit: Upper limit for the number of records to return. list() guarantees
                      never to return more than limit.  Default is no limit
        :param page_size: Number of records to fetch per request, when not set will use
                          the default value of 50 records.  If no page_size is defined
                          but a limit is defined, list() will attempt to read the limit
                          with the most efficient page size, i.e. min(limit, 1000)

        :returns: list that will contain up to limit results
        r@   rA   rB   rC   rD   rE   r   rF   rG   rH   rI   )listrN   )r$   r@   rA   rB   rC   rD   rE   r   rF   rG   rH   rI   s               r&   rV   zContentAndApprovalsList.list   sD    J KK)%9#5$7)!)$7#  
 	
r'   c                    K   | j                  |||||||||	|
|       d{   2 cg c3 d{   }|7 7 	6 c}S c c}w w)a  
        Asynchronously lists ContentAndApprovalsInstance records from the API as a list.
        Unlike stream(), this operation is eager and will load `limit` records into
        memory before returning.

        :param str sort_by_date: Whether to sort by ascending or descending date updated
        :param str sort_by_content_name: Whether to sort by ascending or descending content name
        :param datetime date_created_after: Filter by >=[date-time]
        :param datetime date_created_before: Filter by <=[date-time]
        :param str content_name: Filter by Regex Pattern in content name
        :param str content: Filter by Regex Pattern in template content
        :param List[str] language: Filter by array of valid language(s)
        :param List[str] content_type: Filter by array of contentType(s)
        :param List[str] channel_eligibility: Filter by array of ChannelEligibility(s), where ChannelEligibility=<channel>:<status>
        :param limit: Upper limit for the number of records to return. list() guarantees
                      never to return more than limit.  Default is no limit
        :param page_size: Number of records to fetch per request, when not set will use
                          the default value of 50 records.  If no page_size is defined
                          but a limit is defined, list() will attempt to read the limit
                          with the most efficient page size, i.e. min(limit, 1000)

        :returns: list that will contain up to limit results
        rU   N)rS   )r$   r@   rA   rB   rC   rD   rE   r   rF   rG   rH   rI   records                r&   
list_asyncz"ContentAndApprovalsList.list_async  sp     N '+&7&7)%9#5$7)!)$7# '8 ' !
 
 !
 
 	
 
s4    A7A?;9
;?A;?A
page_tokenpage_numberc                    t        j                  ||t        j                  |      t        j                  |      ||t        j                  |d       t        j                  |d       t        j                  |	d       |
||d      }t        j                  ddi      }d|d<   | j
                  j                  d	| j                  ||
      }t        | j
                  |      S )a4  
        Retrieve a single page of ContentAndApprovalsInstance records from the API.
        Request is executed immediately

        :param sort_by_date: Whether to sort by ascending or descending date updated
        :param sort_by_content_name: Whether to sort by ascending or descending content name
        :param date_created_after: Filter by >=[date-time]
        :param date_created_before: Filter by <=[date-time]
        :param content_name: Filter by Regex Pattern in content name
        :param content: Filter by Regex Pattern in template content
        :param language: Filter by array of valid language(s)
        :param content_type: Filter by array of contentType(s)
        :param channel_eligibility: Filter by array of ChannelEligibility(s), where ChannelEligibility=<channel>:<status>
        :param page_token: PageToken provided by the API
        :param page_number: Page Number, this value is simply for client state
        :param page_size: Number of records to return, defaults to 50

        :returns: Page of ContentAndApprovalsInstance
        c                     | S Nr+   es    r&   <lambda>z.ContentAndApprovalsList.page.<locals>.<lambda>d      a r'   c                     | S r^   r+   r_   s    r&   ra   z.ContentAndApprovalsList.page.<locals>.<lambda>e      Q r'   c                     | S r^   r+   r_   s    r&   ra   z.ContentAndApprovalsList.page.<locals>.<lambda>f      ST r'   
SortByDateSortByContentNameDateCreatedAfterDateCreatedBeforeContentNameContentLanguageContentTypeChannelEligibility	PageTokenr   PageSizeContent-Type!application/x-www-form-urlencodedapplication/jsonAcceptGETmethoduriparamsheaders)	r   ofr   r"   mapr8   rM   r?   r6   r$   r@   rA   rB   rC   rD   rE   r   rF   rG   rZ   r[   rI   datar|   responses                   r&   rM   zContentAndApprovalsList.page:  s    D yy*%9$-$>$>?Q$R%.%?%?@S%T+"%MM(K@(}}\;G&/mm4G&U'#%
" ))^-PQR.==%%diig & 
 't}}h??r'   c                   K   t        j                  ||t        j                  |      t        j                  |      ||t        j                  |d       t        j                  |d       t        j                  |	d       |
||d      }t        j                  ddi      }d|d<   | j
                  j                  d	| j                  ||
       d{   }t        | j
                  |      S 7 w)aC  
        Asynchronously retrieve a single page of ContentAndApprovalsInstance records from the API.
        Request is executed immediately

        :param sort_by_date: Whether to sort by ascending or descending date updated
        :param sort_by_content_name: Whether to sort by ascending or descending content name
        :param date_created_after: Filter by >=[date-time]
        :param date_created_before: Filter by <=[date-time]
        :param content_name: Filter by Regex Pattern in content name
        :param content: Filter by Regex Pattern in template content
        :param language: Filter by array of valid language(s)
        :param content_type: Filter by array of contentType(s)
        :param channel_eligibility: Filter by array of ChannelEligibility(s), where ChannelEligibility=<channel>:<status>
        :param page_token: PageToken provided by the API
        :param page_number: Page Number, this value is simply for client state
        :param page_size: Number of records to return, defaults to 50

        :returns: Page of ContentAndApprovalsInstance
        c                     | S r^   r+   r_   s    r&   ra   z4ContentAndApprovalsList.page_async.<locals>.<lambda>  rb   r'   c                     | S r^   r+   r_   s    r&   ra   z4ContentAndApprovalsList.page_async.<locals>.<lambda>  rd   r'   c                     | S r^   r+   r_   s    r&   ra   z4ContentAndApprovalsList.page_async.<locals>.<lambda>  rf   r'   rg   rs   rt   ru   rv   rw   rx   N)	r   r}   r   r"   r~   r8   rR   r?   r6   r   s                   r&   rR   z"ContentAndApprovalsList.page_asyncv  s     D yy*%9$-$>$>?Q$R%.%?%?@S%T+"%MM(K@(}}\;G&/mm4G&U'#%
" ))^-PQR.11diig 2 
 
 't}}h??
s   CC/C-C/
target_urlc                     | j                   j                  j                  j                  d|      }t	        | j                   |      S )a  
        Retrieve a specific page of ContentAndApprovalsInstance records from the API.
        Request is executed immediately

        :param target_url: API-generated URL for the requested results page

        :returns: Page of ContentAndApprovalsInstance
        rw   )r8   domaintwiliorequestr6   r$   r   r   s      r&   get_pagez ContentAndApprovalsList.get_page  s7     ==''..66ujI&t}}h??r'   c                    K   | j                   j                  j                  j                  d|       d{   }t	        | j                   |      S 7 w)a  
        Asynchronously retrieve a specific page of ContentAndApprovalsInstance records from the API.
        Request is executed immediately

        :param target_url: API-generated URL for the requested results page

        :returns: Page of ContentAndApprovalsInstance
        rw   N)r8   r   r   request_asyncr6   r   s      r&   get_page_asyncz&ContentAndApprovalsList.get_page_async  sD      --44BB5*UU&t}}h?? Vs   4AAAc                      y)r*   z+<Twilio.Content.V2.ContentAndApprovalsList>r+   r,   s    r&   r-   z ContentAndApprovalsList.__repr__  r;   r'   )r.   r/   r0   r   r!   r   unsetr   r2   objectr   r   r   intr	   r   rN   r
   rS   rV   rY   r6   rM   rR   r   r   r-   r3   r4   s   @r&   r=   r=   V   s   	+ 	+ ,2<<39<<6<ll7=||+1<<&,ll-3\\178>##'4;CK(4; $CK04; "(F"23	4;
 #8V#344; CK(4; sF{#4; S	6)*4; DIv-.4; #49f#454; }4; C=4; 
-	.4;p ,2<<39<<6<ll7=||+1<<&,ll-3\\178>##'4ACK(4A $CK04A "(F"23	4A
 #8V#344A CK(4A sF{#4A S	6)*4A DIv-.4A #49f#454A }4A C=4A 
2	34Ap ,2<<39<<6<ll7=||+1<<&,ll-3\\178>##'3
CK(3
 $CK03
 "(F"23	3

 #8V#343
 CK(3
 sF{#3
 S	6)*3
 DIv-.3
 #49f#453
 }3
 C=3
 
)	*3
n ,2<<39<<6<ll7=||+1<<&,ll-3\\178>##'4
CK(4
 $CK04
 "(F"23	4

 #8V#344
 CK(4
 sF{#4
 S	6)*4
 DIv-.4
 #49f#454
 }4
 C=4
 
)	*4
p ,2<<39<<6<ll7=||+1<<&,ll-3\\178>)/*0,,(.:@CK(:@ $CK0:@ "(F"23	:@
 #8V#34:@ CK(:@ sF{#:@ S	6)*:@ DIv-.:@ #49f#45:@ #v+&:@ 3;':@ f%:@ 
!:@| ,2<<39<<6<ll7=||+1<<&,ll-3\\178>)/*0,,(.:@CK(:@ $CK0:@ "(F"23	:@
 #8V#34:@ CK(:@ sF{#:@ S	6)*:@ DIv-.:@ #49f#45:@ #v+&:@ 3;':@ f%:@ 
!:@x
@3 
@+B 
@
@s 
@7N 
@=# =r'   r=   N)r1   r   typingr   r   r   r   r   r	   r
   twilio.baser   r   r   twilio.base.instance_resourcer   twilio.base.list_resourcer   twilio.base.versionr   twilio.base.pager   r   r6   r=   r+   r'   r&   <module>r      sT     L L L 6 6 : 2 ' !'A"2 'AT=d =&z=l z=r'   