
    8hql                       d dl mZ d dlmZmZmZ d dlmZ d dlZddl	m
Z
 ddlmZmZmZmZmZ ddlmZmZ dd	lmZ dd
lmZmZ ddlmZmZ ddlmZmZ ddl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- ddgZ. G d de      Z/ G d de      Z0 G d d      Z1 G d d      Z2 G d d      Z3 G d d      Z4y)    )annotations)UnionIterableOptional)LiteralN   )_legacy_response)	NOT_GIVENBodyQueryHeadersNotGiven)maybe_transformasync_maybe_transform)cached_property)SyncAPIResourceAsyncAPIResource)to_streamed_response_wrapper"async_to_streamed_response_wrapper)SyncCursorPageAsyncCursorPage)AsyncPaginatormake_request_options)message_list_paramsmessage_create_paramsmessage_update_params)Message)Metadata)MessageDeleted)MessageContentPartParamMessagesAsyncMessagesc            
      F   e Zd Zedd       Zedd       Zeeddded	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 ddZddded	 	 	 	 	 	 	 	 	 	 	 	 	 ddZeddded	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 dd	Z	eeeeeddded
		 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 ddZ
ddded	 	 	 	 	 	 	 	 	 	 	 	 	 ddZy)r!   c                    t        |       S a  
        This property can be used as a prefix for any HTTP method call to return
        the raw response object instead of the parsed content.

        For more information, see https://www.github.com/openai/openai-python#accessing-raw-response-data-eg-headers
        )MessagesWithRawResponseselfs    }/home/stella.sw7ft.com/public_html/site_rebuilder/venv/lib/python3.12/site-packages/openai/resources/beta/threads/messages.pywith_raw_responsezMessages.with_raw_response   s     't,,    c                    t        |       S z
        An alternative to `.with_raw_response` that doesn't eagerly read the response body.

        For more information, see https://www.github.com/openai/openai-python#with_streaming_response
        )MessagesWithStreamingResponser'   s    r)   with_streaming_responsez Messages.with_streaming_response)   s     -T22r+   Nattachmentsmetadataextra_headersextra_query
extra_bodytimeoutc          
         |st        d|      ddi|xs i }| j                  d| dt        ||||dt        j                        t        ||||	      t              S )	/  
        Create a message.

        Args:
          content: The text contents of the message.

          role:
              The role of the entity that is creating the message. Allowed values include:

              - `user`: Indicates the message is sent by an actual user and should be used in
                most cases to represent user-generated messages.
              - `assistant`: Indicates the message is generated by the assistant. Use this
                value to insert messages from the assistant into the conversation.

          attachments: A list of files attached to the message, and the tools they should be added to.

          metadata: Set of 16 key-value pairs that can be attached to an object. This can be useful
              for storing additional information about the object in a structured format, and
              querying for objects via API or the dashboard.

              Keys are strings with a maximum length of 64 characters. Values are strings with
              a maximum length of 512 characters.

          extra_headers: Send extra headers

          extra_query: Add additional query parameters to the request

          extra_body: Add additional JSON properties to the request

          timeout: Override the client-level default timeout for this request, in seconds
        8Expected a non-empty value for `thread_id` but received OpenAI-Betaassistants=v2	/threads/	/messagescontentroler1   r2   r3   r4   r5   r6   bodyoptionscast_to)
ValueError_postr   r   MessageCreateParamsr   r   
r(   	thread_idr?   r@   r1   r2   r3   r4   r5   r6   s
             r)   createzMessages.create2   s    \ WXaWdeff&QM<ORQzz	{), & #. (	 &99 )+Q[el   
 	
r+   rA   c          	         |st        d|      |st        d|      ddi|xs i }| j                  d| d| t        ||||      t              S )	G  
        Retrieve a message.

        Args:
          extra_headers: Send extra headers

          extra_query: Add additional query parameters to the request

          extra_body: Add additional JSON properties to the request

          timeout: Override the client-level default timeout for this request, in seconds
        r9   9Expected a non-empty value for `message_id` but received r:   r;   r<   
/messages/rA   rD   rE   rF   _getr   r   r(   
message_idrJ   r3   r4   r5   r6   s          r)   retrievezMessages.retrievet   s    0 WXaWdeffXYcXfghh&QM<ORQyy	{*ZL9(+Q[el   
 	
r+   r2   r3   r4   r5   r6   c          
         |st        d|      |st        d|      ddi|xs i }| j                  d| d| t        d|it        j                        t        ||||      t        	      S )
  
        Modifies a message.

        Args:
          metadata: Set of 16 key-value pairs that can be attached to an object. This can be useful
              for storing additional information about the object in a structured format, and
              querying for objects via API or the dashboard.

              Keys are strings with a maximum length of 64 characters. Values are strings with
              a maximum length of 512 characters.

          extra_headers: Send extra headers

          extra_query: Add additional query parameters to the request

          extra_body: Add additional JSON properties to the request

          timeout: Override the client-level default timeout for this request, in seconds
        r9   rN   r:   r;   r<   rO   r2   rA   rB   )rF   rG   r   r   MessageUpdateParamsr   r   r(   rT   rJ   r2   r3   r4   r5   r6   s           r)   updatezMessages.update   s    @ WXaWdeffXYcXfghh&QM<ORQzz	{*ZL9 *h!79N9b9bc(+Q[el   
 	
r+   	afterbeforelimitorderrun_idr3   r4   r5   r6   c       	            |st        d|      ddi|xs i }| j                  d| dt        t           t	        |||	|
t        |||||dt        j                              t              S 	ah  
        Returns a list of messages for a given thread.

        Args:
          after: A cursor for use in pagination. `after` is an object ID that defines your place
              in the list. For instance, if you make a list request and receive 100 objects,
              ending with obj_foo, your subsequent call can include after=obj_foo in order to
              fetch the next page of the list.

          before: A cursor for use in pagination. `before` is an object ID that defines your place
              in the list. For instance, if you make a list request and receive 100 objects,
              starting with obj_foo, your subsequent call can include before=obj_foo in order
              to fetch the previous page of the list.

          limit: A limit on the number of objects to be returned. Limit can range between 1 and
              100, and the default is 20.

          order: Sort order by the `created_at` timestamp of the objects. `asc` for ascending
              order and `desc` for descending order.

          run_id: Filter messages by the run ID that generated them.

          extra_headers: Send extra headers

          extra_query: Add additional query parameters to the request

          extra_body: Add additional JSON properties to the request

          timeout: Override the client-level default timeout for this request, in seconds
        r9   r:   r;   r<   r=   )r]   r^   r_   r`   ra   )r3   r4   r5   r6   query)pagerD   model)rF   _get_api_listr   r   r   r   r   MessageListParamsr(   rJ   r]   r^   r_   r`   ra   r3   r4   r5   r6   s              r)   listzMessages.list   s    \ WXaWdeff&QM<ORQ!!	{),((+'%%!&"(!&!&"( (99	  ' " 
 	
r+   c          	         |st        d|      |st        d|      ddi|xs i }| j                  d| d| t        ||||      t              S )	F  
        Deletes a message.

        Args:
          extra_headers: Send extra headers

          extra_query: Add additional query parameters to the request

          extra_body: Add additional JSON properties to the request

          timeout: Override the client-level default timeout for this request, in seconds
        r9   rN   r:   r;   r<   rO   rA   rP   rF   _deleter   r   rS   s          r)   deletezMessages.delete  s    0 WXaWdeffXYcXfghh&QM<ORQ||	{*ZL9(+Q[el #  
 	
r+   )returnr&   )rp   r.   rJ   strr?   z-Union[str, Iterable[MessageContentPartParam]]r@   zLiteral['user', 'assistant']r1   z?Optional[Iterable[message_create_params.Attachment]] | NotGivenr2   Optional[Metadata] | NotGivenr3   Headers | Noner4   Query | Noner5   Body | Noner6   'float | httpx.Timeout | None | NotGivenrp   r   rT   rr   rJ   rr   r3   rt   r4   ru   r5   rv   r6   rw   rp   r   rT   rr   rJ   rr   r2   rs   r3   rt   r4   ru   r5   rv   r6   rw   rp   r   )rJ   rr   r]   str | NotGivenr^   rz   r_   int | NotGivenr`   !Literal['asc', 'desc'] | NotGivenra   rz   r3   rt   r4   ru   r5   rv   r6   rw   rp   zSyncCursorPage[Message]rT   rr   rJ   rr   r3   rt   r4   ru   r5   rv   r6   rw   rp   r   __name__
__module____qualname__r   r*   r/   r
   rK   rU   r[   rj   ro    r+   r)   r!   r!      sg   - - 3 3 Xa2; )-$("&;D@
@
 ?	@

 +@
 U@
 0@
 &@
 "@
  @
 9@
 
@
R )-$("&;D#
#
 	#
 &#
 "#
  #
 9#
 
#
T 3< )-$("&;D,
,
 	,

 0,
 &,
 ",
  ,
 9,
 
,
d !*!* )3<!* )-$("&;DE
E
 	E

 E
 E
 1E
 E
 &E
 "E
  E
 9E
 
!E
\ )-$("&;D#
#
 	#
 &#
 "#
  #
 9#
 
#
r+   c            
      F   e Zd Zedd       Zedd       Zeeddded	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 ddZddded	 	 	 	 	 	 	 	 	 	 	 	 	 ddZeddded	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 dd	Z	eeeeeddded
		 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 ddZ
ddded	 	 	 	 	 	 	 	 	 	 	 	 	 ddZy)r"   c                    t        |       S r%   )AsyncMessagesWithRawResponser'   s    r)   r*   zAsyncMessages.with_raw_response5  s     ,D11r+   c                    t        |       S r-   )"AsyncMessagesWithStreamingResponser'   s    r)   r/   z%AsyncMessages.with_streaming_response?  s     2$77r+   Nr0   c          
        K   |st        d|      ddi|xs i }| j                  d| dt        ||||dt        j                         d{   t        ||||	      t        	       d{   S 7 $7 w)
r8   r9   r:   r;   r<   r=   r>   NrA   rB   )rF   rG   r   r   rH   r   r   rI   s
             r)   rK   zAsyncMessages.createH  s     \ WXaWdeff&QM<ORQZZ	{),,& #. (	 &99  )+Q[el    
 
 	

s$   AA8A4
A8/A60A86A8rA   c          	        K   |st        d|      |st        d|      ddi|xs i }| j                  d| d| t        ||||      t               d	{   S 7 w)
rM   r9   rN   r:   r;   r<   rO   rA   rP   NrQ   rS   s          r)   rU   zAsyncMessages.retrieve  s     0 WXaWdeffXYcXfghh&QM<ORQYY	{*ZL9(+Q[el   
 
 	
 
   AA"A A"rV   c          
       K   |st        d|      |st        d|      ddi|xs i }| j                  d| d| t        d|it        j                         d{   t        ||||	      t        
       d{   S 7 $7 w)rX   r9   rN   r:   r;   r<   rO   r2   NrA   rB   )rF   rG   r   r   rY   r   r   rZ   s           r)   r[   zAsyncMessages.update  s     @ WXaWdeffXYcXfghh&QM<ORQZZ	{*ZL9,j(-CEZEnEnoo(+Q[el    
 
 	
o
s$   ABB
B>B?BBr\   c       	            |st        d|      ddi|xs i }| j                  d| dt        t           t	        |||	|
t        |||||dt        j                              t              S rc   )rF   rg   r   r   r   r   r   rh   ri   s              r)   rj   zAsyncMessages.list  s    \ WXaWdeff&QM<ORQ!!	{), )(+'%%!&"(!&!&"( (99	  ' " 
 	
r+   c          	        K   |st        d|      |st        d|      ddi|xs i }| j                  d| d| t        ||||      t               d	{   S 7 w)
rl   r9   rN   r:   r;   r<   rO   rA   rP   Nrm   rS   s          r)   ro   zAsyncMessages.delete$  s     0 WXaWdeffXYcXfghh&QM<ORQ\\	{*ZL9(+Q[el # " 
 
 	
 
r   )rp   r   )rp   r   rq   rx   ry   )rJ   rr   r]   rz   r^   rz   r_   r{   r`   r|   ra   rz   r3   rt   r4   ru   r5   rv   r6   rw   rp   z1AsyncPaginator[Message, AsyncCursorPage[Message]]r}   r~   r   r+   r)   r"   r"   4  sg   2 2 8 8 Xa2; )-$("&;D@
@
 ?	@

 +@
 U@
 0@
 &@
 "@
  @
 9@
 
@
R )-$("&;D#
#
 	#
 &#
 "#
  #
 9#
 
#
T 3< )-$("&;D,
,
 	,

 0,
 &,
 ",
  ,
 9,
 
,
d !*!* )3<!* )-$("&;DE
E
 	E

 E
 E
 1E
 E
 &E
 "E
  E
 9E
 
;E
\ )-$("&;D#
#
 	#
 &#
 "#
  #
 9#
 
#
r+   c                      e Zd ZddZy)r&   c                z   || _         t        j                  |j                        | _        t        j                  |j                        | _        t        j                  |j
                        | _        t        j                  |j                        | _        t        j                  |j                        | _        y N)	_messagesr	   to_raw_response_wrapperrK   rU   r[   rj   ro   r(   messagess     r)   __init__z MessagesWithRawResponse.__init__K  s    !&>>OO
 )@@
 '>>OO
 %<<MM
	 '>>OO
r+   Nr   r!   rp   Noner   r   r   r   r   r+   r)   r&   r&   J      
r+   r&   c                      e Zd ZddZy)r   c                z   || _         t        j                  |j                        | _        t        j                  |j                        | _        t        j                  |j
                        | _        t        j                  |j                        | _        t        j                  |j                        | _        y r   )r   r	   async_to_raw_response_wrapperrK   rU   r[   rj   ro   r   s     r)   r   z%AsyncMessagesWithRawResponse.__init__`  s    !&DDOO
 )FF
 'DDOO
 %BBMM
	 'DDOO
r+   Nr   r"   rp   r   r   r   r+   r)   r   r   _  r   r+   r   c                      e Zd ZddZy)r.   c                   || _         t        |j                        | _        t        |j                        | _        t        |j                        | _        t        |j
                        | _        t        |j                        | _        y r   )r   r   rK   rU   r[   rj   ro   r   s     r)   r   z&MessagesWithStreamingResponse.__init__u  sr    !2OO
 5
 3OO
 1MM
	 3OO
r+   Nr   r   r   r+   r)   r.   r.   t  r   r+   r.   c                      e Zd ZddZy)r   c                   || _         t        |j                        | _        t        |j                        | _        t        |j                        | _        t        |j
                        | _        t        |j                        | _        y r   )r   r   rK   rU   r[   rj   ro   r   s     r)   r   z+AsyncMessagesWithStreamingResponse.__init__  sr    !8OO
 ;
 9OO
 7MM
	 9OO
r+   Nr   r   r   r+   r)   r   r     r   r+   r   )5
__future__r   typingr   r   r   typing_extensionsr   httpx r	   _typesr
   r   r   r   r   _utilsr   r   _compatr   	_resourcer   r   	_responser   r   
paginationr   r   _base_clientr   r   types.beta.threadsr   r   r   types.beta.threads.messager   types.shared_params.metadatar   "types.beta.threads.message_deletedr   -types.beta.threads.message_content_part_paramr    __all__r!   r"   r&   r   r.   r   r   r+   r)   <module>r      s    # , , %  ! @ @ = ' ; Z : e d 2 5 A U
'S
 S
lS
$ S
l
 
*
 
*
 
*
 
r+   