
    hhK                        d Z ddl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mZ i d	d
dd
ddddddddddddddddddddddddddddd di d!dd"d#d$d#d%d&d'd&d(d)d*d)d+d,d-d,d.d/d0d/d1d2d3d2d4d)d5d)d6d7d8d7i d9d:d;d:d<d=d>d=d?d@dAd@dBdCdDdCdEdFdGdFdHdIdJdIdKdCdLdCdMdNdOdNdPdIi dQdIdRdCdSdNdTdCdUdNdVdIdWdIdXd,dYd/dZd,d[d/d\d2d]d2d^d=d_d`dadbdcd=i ddd`ded=dfd`dgd:dhd,did:djd:dkd=dld=dmd=dnd:dod:dpd:dqdbdrdbdsdbdtd=i dud=dvd=dwdxdydxdzdxd{d|d}d~dd|dd~dddddd|dd|ddddddddi dddddddddd|dd|dddddd=dd=dd:dd:ddddddddddi dddddd2dd2dd2dd:dd:dd:dd:dd:dd:dd2dd2dd2ddddddi dddddddddddddddddddddddddddddd
dddd
i dd
dd
dd
ddɓddɓdddddd
dddddddddd
dddd
dd
dd
i ddɓddɓdddddddddd
dd
ddxddxddxddddddddddddi dd|dddddddddddddddd
dddddd
dd
ddddddddZ G d de          Z	 dej        dded ededefdZ	 dej        ddeded ededef
dZ G d de          ZdS (	  z(Callback Handler that prints to std out.    N)Enumauto)AnyDictList)warn_deprecated)BaseCallbackHandler)	AIMessage)ChatGeneration	LLMResultgpt-4.1gMb`?zgpt-4.1-2025-04-14zgpt-4.1-cachedgMb@?zgpt-4.1-2025-04-14-cachedzgpt-4.1-completiongMb?zgpt-4.1-2025-04-14-completionzgpt-4.1-minig-C6:?zgpt-4.1-mini-2025-04-14zgpt-4.1-mini-cachedg-C6?zgpt-4.1-mini-2025-04-14-cachedzgpt-4.1-mini-completiong-C6Z?z"gpt-4.1-mini-2025-04-14-completionzgpt-4.1-nanozgpt-4.1-nano-2025-04-14zgpt-4.1-nano-cachedg-C6>zgpt-4.1-nano-2025-04-14-cachedzgpt-4.1-nano-completionz"gpt-4.1-nano-2025-04-14-completionzgpt-4.5-previewg333333?zgpt-4.5-preview-2025-02-27zgpt-4.5-preview-cachedg333333?z!gpt-4.5-preview-2025-02-27-cachedzgpt-4.5-preview-completiong333333?z%gpt-4.5-preview-2025-02-27-completiono1gQ?zo1-2024-12-17z	o1-cachedgQ~?zo1-2024-12-17-cachedzo1-completiongQ?zo1-2024-12-17-completionzo1-prozo1-pro-2025-03-19zo1-pro-completiong333333?zo1-pro-2025-03-19-completiono3g{Gz?zo3-2025-04-16z	o3-cachedg{Gzd?zo3-2025-04-16-cachedzo3-completiong{Gz?zo3-2025-04-16-completionzo4-minig/nR?zo4-mini-2025-04-16zo4-mini-cachedg/n2?zo4-mini-2025-04-16-cachedzo4-mini-completiong/nr?zo4-mini-2025-04-16-completionzo3-minizo3-mini-2025-01-31zo3-mini-cachedg/nB?zo3-mini-2025-01-31-cachedzo3-mini-completionzo3-mini-2025-01-31-completionzo1-minizo1-mini-cachedzo1-mini-2024-09-12zo1-mini-2024-09-12-cachedzo1-mini-completionzo1-mini-2024-09-12-completionz
o1-previewzo1-preview-cachedzo1-preview-2024-09-12zo1-preview-2024-09-12-cachedzo1-preview-completionz o1-preview-2024-09-12-completiongpt-4ozgpt-4o-cachedg{GzT?gpt-4o-2024-05-13g{Gzt?zgpt-4o-2024-08-06zgpt-4o-2024-08-06-cachedzgpt-4o-2024-11-20zgpt-4o-2024-11-20-cachedzgpt-4o-completionzgpt-4o-2024-05-13-completionzgpt-4o-2024-08-06-completionzgpt-4o-2024-11-20-completionzgpt-4o-audio-previewzgpt-4o-audio-preview-2024-12-17zgpt-4o-audio-preview-2024-10-01zgpt-4o-audio-preview-completionz*gpt-4o-audio-preview-2024-12-17-completionz*gpt-4o-audio-preview-2024-10-01-completionzgpt-4o-realtime-previewz"gpt-4o-realtime-preview-2024-12-17z"gpt-4o-realtime-preview-2024-10-01zgpt-4o-realtime-preview-cachedz)gpt-4o-realtime-preview-2024-12-17-cachedz)gpt-4o-realtime-preview-2024-10-01-cachedz"gpt-4o-realtime-preview-completiong{Gz?z-gpt-4o-realtime-preview-2024-12-17-completionz-gpt-4o-realtime-preview-2024-10-01-completionzgpt-4o-miniga2U0*#?zgpt-4o-mini-cachedga2U0*?zgpt-4o-mini-2024-07-18zgpt-4o-mini-2024-07-18-cachedzgpt-4o-mini-completionga2U0*C?z!gpt-4o-mini-2024-07-18-completionzgpt-4o-mini-audio-previewz$gpt-4o-mini-audio-preview-2024-12-17z$gpt-4o-mini-audio-preview-completionz/gpt-4o-mini-audio-preview-2024-12-17-completionzgpt-4o-mini-realtime-previewz'gpt-4o-mini-realtime-preview-2024-12-17z#gpt-4o-mini-realtime-preview-cachedga2U0*3?z.gpt-4o-mini-realtime-preview-2024-12-17-cachedz'gpt-4o-mini-realtime-preview-completionga2U0*c?z2gpt-4o-mini-realtime-preview-2024-12-17-completionzgpt-4o-mini-search-previewz%gpt-4o-mini-search-preview-2025-03-11z%gpt-4o-mini-search-preview-completionz0gpt-4o-mini-search-preview-2025-03-11-completionzgpt-4o-search-previewz gpt-4o-search-preview-2025-03-11z gpt-4o-search-preview-completionz+gpt-4o-search-preview-2025-03-11-completionzcomputer-use-previewg~jth?zcomputer-use-preview-2025-03-11zcomputer-use-preview-completiong~jt?z*computer-use-preview-2025-03-11-completiongpt-4gQ?z
gpt-4-0314z
gpt-4-0613z	gpt-4-32kzgpt-4-32k-0314zgpt-4-32k-0613zgpt-4-vision-previewzgpt-4-1106-previewzgpt-4-0125-previewzgpt-4-turbo-previewzgpt-4-turbozgpt-4-turbo-2024-04-09zgpt-4-completionzgpt-4-0314-completionzgpt-4-0613-completionzgpt-4-32k-completiongQ?zgpt-4-32k-0314-completionzgpt-4-32k-0613-completionzgpt-4-vision-preview-completionzgpt-4-1106-preview-completionzgpt-4-0125-preview-completionzgpt-4-turbo-preview-completionzgpt-4-turbo-completionz!gpt-4-turbo-2024-04-09-completionzgpt-3.5-turbog~jtX?zgpt-3.5-turbo-0125zgpt-3.5-turbo-0301zgpt-3.5-turbo-0613zgpt-3.5-turbo-1106gMbP?zgpt-3.5-turbo-instructzgpt-3.5-turbo-16kzgpt-3.5-turbo-16k-0613zgpt-3.5-turbo-completionzgpt-3.5-turbo-0125-completionzgpt-3.5-turbo-0301-completionzgpt-3.5-turbo-0613-completionzgpt-3.5-turbo-1106-completionz!gpt-3.5-turbo-instruct-completionzgpt-3.5-turbo-16k-completiongMbp?z!gpt-3.5-turbo-16k-0613-completionzgpt-35-turbozgpt-35-turbo-0125zgpt-35-turbo-0301zgpt-35-turbo-0613zgpt-35-turbo-instructzgpt-35-turbo-16kzgpt-35-turbo-16k-0613zgpt-35-turbo-completionzgpt-35-turbo-0125-completionzgpt-35-turbo-0301-completionzgpt-35-turbo-0613-completionz gpt-35-turbo-instruct-completionzgpt-35-turbo-16k-completionz gpt-35-turbo-16k-0613-completionztext-ada-001adaztext-babbage-001babbageztext-curie-001curieztext-davinci-003ztext-davinci-002zcode-davinci-002zbabbage-002-finetunedzdavinci-002-finetunedzgpt-3.5-turbo-0613-finetunedzgpt-3.5-turbo-1106-finetunedzgpt-3.5-turbo-0125-finetunedz gpt-4o-mini-2024-07-18-finetunedz'gpt-4o-mini-2024-07-18-finetuned-cachedz babbage-002-finetuned-completionz davinci-002-finetuned-completionz'gpt-3.5-turbo-0613-finetuned-completiong~jtx?z'gpt-3.5-turbo-1106-finetuned-completionz'gpt-3.5-turbo-0125-finetuned-completionz+gpt-4o-mini-2024-07-18-finetuned-completionga2U0*S?zbabbage-002-azure-finetunedzdavinci-002-azure-finetunedz!gpt-35-turbo-0613-azure-finetunedz&babbage-002-azure-finetuned-completionz&davinci-002-azure-finetuned-completionz,gpt-35-turbo-0613-azure-finetuned-completionzada-finetuned-legacyzbabbage-finetuned-legacyzcurie-finetuned-legacyzdavinci-finetuned-legacyc                   N    e Zd ZdZ e            Z e            Z e            ZdS )	TokenTypezToken type enum.N)__name__
__module____qualname____doc__r   PROMPTPROMPT_CACHED
COMPLETION     f/var/www/FlaskApp/flask-venv/lib/python3.11/site-packages/langchain_community/callbacks/openai_info.pyr   r     s5        TVVFDFFMJJJr    r   F
token_type
model_nameis_completionr#   returnc                   |rt          ddd           t          j        }|                                 } d| v r|                     d          d         dz   } d| v r|                     d	          d         d
z   } d| v r|                     d	          d         dz   } |t          j        k    r|                     d          sq|                     d          s\|                     d          sG|                     d          s2|                     d          s|                     d          sd| v r	d| vr| dz   S |t          j        k    r|                     d          sT|                     d          s?|                     d          s*|                     d          s|                     d          r|                     d          s| dz   S | S )a  
    Standardize the model name to a format that can be used in the OpenAI API.

    Args:
        model_name: Model name to standardize.
        is_completion: Whether the model is used for completion or not.
            Defaults to False. Deprecated in favor of ``token_type``.
        token_type: Token type. Defaults to ``TokenType.PROMPT``.

    Returns:
        Standardized model name.

    0.3.13zis_completion is deprecated. Use token_type instead. Example:

from langchain_community.callbacks.openai_info import TokenType

standardize_model_name('gpt-4o', token_type=TokenType.COMPLETION)
1.0sincemessageremovalz.ft-r   z-azure-finetunedz:ft-:z-finetuned-legacyzft:   z
-finetunedr   zgpt-3.5zgpt-35zo1-zo3-zo4-	finetunedlegacyz-completionr   r   r   r   o4r   z-cached)r   r   r   lowersplit
startswithr   )r$   r%   r#   s      r!   standardize_model_namer6     s2   &  
*V 	
 	
 	
 	
 )
!!##J%%f--a03EE
%%c**1-0CC

%%c**1-<
Y)))g&& *  ++ *   ** *   ''	 *
   '' *   '' * :%%(**D*DM))i---!!(++ 	. $$Y// 	. $$T**	 	.
 $$T** 	. $$T** 	. &&':;; 	. I%%r    
num_tokensc                   |rt          ddd           t          j        }t          | |          } | t          vr@t          d|  dd                    t                                                    z             t          |          |d	z  z  S )
a  
    Get the cost in USD for a given model and number of tokens.

    Args:
        model_name: Name of the model
        num_tokens: Number of tokens.
        is_completion: Whether the model is used for completion or not.
            Defaults to False. Deprecated in favor of ``token_type``.
        token_type: Token type. Defaults to ``TokenType.PROMPT``.

    Returns:
        Cost in USD.
    r(   zis_completion is deprecated. Use token_type instead. Example:

from langchain_community.callbacks.openai_info import TokenType

get_openai_token_cost_for_model('gpt-4o', 10, token_type=TokenType.COMPLETION)
r)   r*   r"   zUnknown model: z=. Please provide a valid OpenAI model name.Known models are: z, i  )r   r   r   r6   MODEL_COST_PER_1K_TOKENS
ValueErrorjoinkeys)r$   r7   r%   r#   s       r!   get_openai_token_cost_for_modelr=   [  s    (  
*c 	
 	
 	
 	
 )
'
zJJJJ111!j ! ! !#'99-E-J-J-L-L#M#MN
 
 	
 $J/:3DEEr    c                   $    e Zd ZU dZdZeed<   dZeed<   dZeed<   dZ	eed<   dZ
eed<   dZeed<   d	Zeed
<   d fdZdefdZedefd            Zdeeef         dee         deddfdZdededdfdZdededdfdZddZdedd fdZ xZS )OpenAICallbackHandlerz)Callback Handler that tracks OpenAI info.r   total_tokensprompt_tokensprompt_tokens_cachedcompletion_tokensreasoning_tokenssuccessful_requestsg        
total_costr&   Nc                 x    t                                                       t          j                    | _        d S )N)super__init__	threadingLock_lock)self	__class__s    r!   rI   zOpenAICallbackHandler.__init__  s,    ^%%


r    c                 v    d| j          d| j         d| j         d| j         d| j         d| j         d| j         S )NzTokens Used: z
	Prompt Tokens: z
		Prompt Tokens Cached: z
	Completion Tokens: z
		Reasoning Tokens: z
Successful Requests: z
Total Cost (USD): $)r@   rA   rB   rC   rD   rE   rF   rM   s    r!   __repr__zOpenAICallbackHandler.__repr__  s    4D- 4 4 $ 24 4)-)B4 4 %)$:4 4 &*%:	4 4
 %)$<4 4 #'/4 4	
r    c                     dS )z;Whether to call verbose callbacks even if verbose is False.Tr   rP   s    r!   always_verbosez$OpenAICallbackHandler.always_verbose  s	     tr    
serializedpromptskwargsc                     dS )zPrint out the prompts.Nr   )rM   rT   rU   rV   s       r!   on_llm_startz"OpenAICallbackHandler.on_llm_start  s	     	r    tokenc                     dS )zPrint out the token.Nr   )rM   rY   rV   s      r!   on_llm_new_tokenz&OpenAICallbackHandler.on_llm_new_token  s    r    responsec                    	 |j         d         d         }n# t          $ r d}Y nw xY wt          |t                    rE	 |j        }t          |t
                    r|j        }|j        }nd}d}n# t          $ r d}d}Y nw xY wd}d}d}d}|rd|d         i}	|d         }
|d         }|pi 	                    d          x}rt          |          }n2|j        d}n(t          |j        	                    dd                    }d|	                    d	i           v r|d	         d         }d
|	                    di           v r|d         d
         }n|j        dS d|j        vr1| j        5  | xj        dz  c_        ddd           n# 1 swxY w Y   dS |j        d         }	|		                    dd          }
|		                    dd          }t          |j        	                    dd                    }|t          v r_||z
  }t          ||t           j                  }t          ||t           j                  }||z   }t          ||
t           j                  }nd}d}| j        5  | xj        ||z   z  c_        | xj        |		                    dd          z  c_        | xj        |z  c_        | xj        |z  c_        | xj        |
z  c_        | xj        |z  c_        | xj        dz  c_        ddd           dS # 1 swxY w Y   dS )zCollect token usage.r   Nr@   output_tokensinput_tokensr$    
cache_readinput_token_details	reasoningoutput_token_detailstoken_usager/   rC   rA   r"   )generations
IndexError
isinstancer   r,   r
   usage_metadataresponse_metadataAttributeErrorgetr6   
llm_outputrL   rE   r9   r=   r   r   r   r   rF   r@   rA   rB   rC   rD   )rM   r\   rV   
generationr,   ri   rj   rB   rD   re   rC   rA   response_model_namer$   uncached_prompt_tokensuncached_prompt_costcached_prompt_costprompt_costcompletion_costs                      r!   
on_llm_endz OpenAICallbackHandler.on_llm_end  sZ   	!-a03JJ 	 	 	JJJ	j.11 	%
)$,gy11 -%,%;N(/(A%%%)N(,%! ) ) )!%$(!!!) "N $  !	)>.+IJK . ?*>:M'8'>B&C&CL&Q&QQ" 34GHH

$,

3'++L"== 
 ~112GLLLL'56K'L ($ n001GLLLL#12H#I+#V "*tH$777Z 2 2,,1,,2 2 2 2 2 2 2 2 2 2 2 2 2 2 2t #-m<K +0CQ G G'OOOQ??M/#''b99 J 111%25I%I"#B2y?O$ $ $  "A0Y=T" " " /1CCK=-):N  OO  OK Z 	* 	*OO{_<<OO!C!CC-/%%)==%%""&77""!!%55!!$$)$$	* 	* 	* 	* 	* 	* 	* 	* 	* 	* 	* 	* 	* 	* 	* 	* 	* 	*sB    %%/A. .A?>A?'FFF%BK::K>K>c                     | S )z&Return a copy of the callback handler.r   rP   s    r!   __copy__zOpenAICallbackHandler.__copy__      r    memoc                     | S )z+Return a deep copy of the callback handler.r   )rM   ry   s     r!   __deepcopy__z"OpenAICallbackHandler.__deepcopy__  rx   r    )r&   N)r&   r?   )r   r   r   r   r@   int__annotations__rA   rB   rC   rD   rE   rF   floatrI   strrQ   propertyboolrS   r   r   r   rX   r[   r   ru   rw   r{   __classcell__)rN   s   @r!   r?   r?     s        33L#M3 !#!!!sc    J& & & & & &	
# 	
 	
 	
 	
     XsCx.379HK	   c S T    U*9 U* U* U* U* U* U*n    )@        r    r?   )F)r   rJ   enumr   r   typingr   r   r   langchain_core._apir   langchain_core.callbacksr	   langchain_core.messagesr
   langchain_core.outputsr   r   r9   r   r   r   r   r6   r|   r~   r=   r?   r   r    r!   <module>r      s   . .             " " " " " " " " " " / / / / / / 8 8 8 8 8 8 - - - - - - < < < < < < < <EuE %E f	E
  E %E $UE FE vE 6E %fE vE  )&!E$ F%E& v'E( 8)E* %h+E. v/E E0 )&1E4 u5E6 !%7E8 f9E: (;E> !$?E@ ,TAED 	%EEF UGEH IEJ FKEN TOEP QET dUEV WEZ [E\ #C]E E E` 	$aEb TcEd eEf FgEj TkEl mEp vqEr &sEt huEv  wEz &{E| $V}E@ vAEB &CED gEEF  GEJ &KE E EL $VMEP vQER gSET &UEV  WEZ &[E\ $V]E` %aEb cEd UeEf #FgEj TkEl 'mEp fqEr WsEt uEv wE E Ex yEz {E| }E@ AEB #ECED #DEEF #DGEJ FKEL &vMEN &vOER &tSET 1$UEV 1$WEZ u[E\ )%]E^ )%_E` %faE E Eb 0cEd 0eEh )$iEj 4TkEl 4TmEp 7qEr (sEt guEv $XwEz f{E| (}E@  AEB +GCEF +FGEH 6vIEL #FMEN .vOE E EP *6QER 5fSEV .vWEX 9&YE\ !']E^ ,W_Eb ,VcEd 7eEh ViEj 'kEn 'oEp 24qEt EuEv &uwEz &u{E| 1%}E@ TAE E EB $CED $EEF GEH dIEJ dKEL DMEN $OEP $QER 4SET 4UEV dWEZ [E\ T]E^ T_E` DaEb  cEd  eE E Ef &tgEh $TiEj $TkEl %dmEn doEp (qEx VyEz &{E| &}E~ &E@ %AEB fCED EEF eGEN OEP $VQER $USE E ET $UUEV $UWEX (YEZ #E[E\ (]E` FaEb cEd eEf gEh ViEj kEl UmEp uqEr #FsEt #EuEv #EwEx 'yE E Ez "5{E| '}E@ FAEB 
6CED EEF vGEH eIEJ UKEL MEN OEP QET VUEV UWEX #EYEZ #E[E\ #E]E^ '_E E E` .waEd 'eEf 'gEh .uiEj .ukEl .umEn 26oEr "6sEt "5uEv (wEz -f{E| -e}E~ 3EEB FCED EEF eGEH IE E P         < &,	< < <<< 	<
 	< < < <D  %F
 &,%F %F %F%F%F %F
 %F %F %F %F %FPF F F F F/ F F F F Fr    