|
import os |
|
import sys |
|
import traceback |
|
|
|
|
|
|
|
sys.path.insert( |
|
0, os.path.abspath("../..") |
|
) |
|
|
|
import inspect |
|
|
|
import litellm |
|
from litellm.integrations.custom_logger import CustomLogger |
|
|
|
|
|
|
|
|
|
def print_verbose(print_statement): |
|
if litellm.set_verbose: |
|
print(print_statement) |
|
|
|
|
|
class MyCustomHandler(CustomLogger): |
|
def __init__(self): |
|
blue_color_code = "\033[94m" |
|
reset_color_code = "\033[0m" |
|
print_verbose(f"{blue_color_code}Initialized LiteLLM custom logger") |
|
try: |
|
print_verbose("Logger Initialized with following methods:") |
|
methods = [ |
|
method |
|
for method in dir(self) |
|
if inspect.ismethod(getattr(self, method)) |
|
] |
|
|
|
|
|
for method in methods: |
|
print_verbose(f" - {method}") |
|
print_verbose(f"{reset_color_code}") |
|
except Exception: |
|
pass |
|
|
|
def log_pre_api_call(self, model, messages, kwargs): |
|
print_verbose("Pre-API Call") |
|
|
|
def log_post_api_call(self, kwargs, response_obj, start_time, end_time): |
|
print_verbose("Post-API Call") |
|
|
|
def log_stream_event(self, kwargs, response_obj, start_time, end_time): |
|
print_verbose("On Stream") |
|
|
|
def log_success_event(self, kwargs, response_obj, start_time, end_time): |
|
print_verbose("On Success!") |
|
|
|
async def async_log_success_event(self, kwargs, response_obj, start_time, end_time): |
|
print_verbose("On Async Success!") |
|
response_cost = litellm.completion_cost(completion_response=response_obj) |
|
assert response_cost > 0.0 |
|
return |
|
|
|
async def async_log_failure_event(self, kwargs, response_obj, start_time, end_time): |
|
try: |
|
print_verbose("On Async Failure !") |
|
except Exception as e: |
|
print_verbose(f"Exception: {e}") |
|
|
|
|
|
proxy_handler_instance = MyCustomHandler() |
|
|
|
|
|
|
|
|
|
|
|
|