Skip to main content

A decorator for logging OpenAI API requests and responses.

Project description

hrai_python

A Python package designed to log and monitor interactions with OpenAI’s API, supporting both local and remote logging. It enables structured logging for OpenAI API calls and facilitates asynchronous remote logging for scalability.

Installation

Install the package using pip:

pip install hrai_python

Configuration

Initialize the logger with options for configuring the OpenAI client, logging preferences, and remote logging.

from hrai_python.hrai_logger import hrai_logger

# Initialize the Logger
logger_instance = hrai_logger(
    client_attr_name='client',       # Attribute name of the OpenAI client in your class
    enable_remote=True,              # Enable remote logging
    enable_async=True,               # Use asynchronous remote logging
    return_type=hrai_logger.Return_Type.content_only
)

Basic Usage Example

import os
from openai import OpenAI
from dotenv import load_dotenv
from hrai_python.hrai_logger import hrai_logger

# Initialize the logger
logger = hrai_logger()

class GPTClient:
    def __init__(self):
        load_dotenv()
        self.model = os.environ.get("OPENAI_MODEL")
        self.client = OpenAI(api_key=os.environ.get("OPENAI_API_KEY"))

    @logger.readable
    def basic_completion(self, messages):
        completion = self.client.chat.completions.create(
            model=self.model,
            messages=messages
        )
        return completion

Configuration Options

hrai_logger offers flexible configuration options:

  • client_instance (Optional[openai.ChatCompletion]): OpenAI client instance if standalone.
  • client_attr_name (Optional[str]): Attribute name of the OpenAI client in your class (default: "client").
  • base_url (Optional[str]): Remote server URL for logging (default: "https://api.humanreadable.ai/").
  • apikey (Optional[str]): API key for authenticating with the remote logging server.
  • log_file (str): Log file name (default: "hrai.log").
  • log_level (str): Logging level, e.g., "INFO", "DEBUG", "WARNING".
  • log_format (Optional[str]): Log message format (default: "%(asctime)s - %(levelname)s - %(message)s").
  • enable_remote (bool): Enable/disable remote logging (default: True).
  • enable_async (bool): Use asynchronous remote logging (default: False).
  • return_type (Return_Type): Format of the response from API calls (default: content_only).

Return Types

Return_Type defines the format of responses from OpenAI API calls:

  • content_only (1): Returns only the message content.
  • json (2): Returns the response as a JSON object.
  • openai_object (3): Returns the full OpenAI response object.

Utilities with hrai_utils

Tool Creation

hrai_utils.create_tool helps build tool structures for OpenAI function calls.

from hrai_python.hrai_utils import hrai_utils

# Define tool properties
name = "my_tool"
description = "This is a tool that does something"
properties = {
    "answer": "The answer to the tool",
    "request": "The request to the tool"
}

# Create a tool dictionary
my_tool = hrai_utils.create_tool(name, description, properties)

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

hrai_python-0.3.2.tar.gz (8.1 kB view details)

Uploaded Source

Built Distribution

hrai_python-0.3.2-py3-none-any.whl (9.0 kB view details)

Uploaded Python 3

File details

Details for the file hrai_python-0.3.2.tar.gz.

File metadata

  • Download URL: hrai_python-0.3.2.tar.gz
  • Upload date:
  • Size: 8.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.4 CPython/3.13.0 Darwin/23.5.0

File hashes

Hashes for hrai_python-0.3.2.tar.gz
Algorithm Hash digest
SHA256 bd91724c15a38f42724f3ac50f310f1da9fbf36a9d2735e2022f60cd7b7d4adb
MD5 43b540d965bfc2e617c46b439ae5c21c
BLAKE2b-256 4c5aa7b3119066c5e63fa81960a320743d4dff1e81cf0cde8ca40fcf400ff443

See more details on using hashes here.

File details

Details for the file hrai_python-0.3.2-py3-none-any.whl.

File metadata

  • Download URL: hrai_python-0.3.2-py3-none-any.whl
  • Upload date:
  • Size: 9.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.4 CPython/3.13.0 Darwin/23.5.0

File hashes

Hashes for hrai_python-0.3.2-py3-none-any.whl
Algorithm Hash digest
SHA256 4fa41035010082cab3450718303d419221a1daecea46edff2978c886c3233179
MD5 a2d30eaf6a8ee7613f879805d19a7ca2
BLAKE2b-256 92a330fd2781e0d6e4c81b71c91eb74cd1b022e5ed3a5c458072debe7830614a

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page