Skip to main content

AnoSys SDK for OpenAI - Automatic instrumentation and logging for OpenAI API calls

Project description

AnoSys SDK for OpenAI

License: Apache 2.0 Python

Automatically capture and send OpenAI API calls to AnoSys for monitoring, analytics, and observability.

Features

Automatic OpenAI Instrumentation - Captures all OpenAI API calls via OpenTelemetry
Streaming Support - Detects and logs streaming responses
OpenTelemetry Semantic Conventions - Follows Gen AI standards
Error Tracking - Captures exceptions with full stack traces
Zero Configuration - Works out of the box with just your API key

Installation

pip install anosys-sdk-openai

Quick Start

import os
from openai import OpenAI
from anosys_sdk_openai import AnosysOpenAILogger

os.environ["OPENAI_API_KEY"] = "your-openai-key"
os.environ["ANOSYS_API_KEY"] = "your-anosys-key"

# Initialize (do once at startup)
AnosysOpenAILogger()

# Use OpenAI normally - all calls are automatically logged
client = OpenAI()

response = client.chat.completions.create(
    model="gpt-4o-mini",
    messages=[
        {"role": "system", "content": "You are a helpful assistant."},
        {"role": "user", "content": "Hello!"}
    ]
)
print(response.choices[0].message.content)

Streaming

Streaming is automatically detected and logged:

stream = client.chat.completions.create(
    model="gpt-4o-mini",
    messages=[{"role": "user", "content": "Write a haiku"}],
    stream=True
)

for chunk in stream:
    if chunk.choices[0].delta.content:
        print(chunk.choices[0].delta.content, end="")

Custom Function Logging

You can also log custom functions using decorators from the core package:

from anosys_sdk_core import anosys_logger

@anosys_logger(source="my_app")
def process_response(response):
    return response.choices[0].message.content

What Data is Captured?

Following OpenTelemetry Gen AI standards:

  • gen_ai.system - Always "openai"
  • gen_ai.request.model - Model requested
  • gen_ai.response.model - Model that responded
  • gen_ai.request.temperature - Temperature parameter
  • gen_ai.usage.input_tokens - Input token count
  • gen_ai.usage.output_tokens - Output token count
  • Request/response messages
  • Timestamps and duration
  • Error details

Environment Variables

Variable Required Description
ANOSYS_API_KEY Yes Your AnoSys API key
OPENAI_API_KEY Yes Your OpenAI API key

License

Apache 2.0

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

anosys_sdk_openai-1.0.2.tar.gz (10.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

anosys_sdk_openai-1.0.2-py3-none-any.whl (9.9 kB view details)

Uploaded Python 3

File details

Details for the file anosys_sdk_openai-1.0.2.tar.gz.

File metadata

  • Download URL: anosys_sdk_openai-1.0.2.tar.gz
  • Upload date:
  • Size: 10.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for anosys_sdk_openai-1.0.2.tar.gz
Algorithm Hash digest
SHA256 f9018e151b97cb3524fd7281f0f5ea9bf9f54869e29a0154698ea2a96baeeb9a
MD5 96678c4f573c893e623735097359e01a
BLAKE2b-256 74cd5906d54704db24e9e9df0ffe5949b7c2eab1a712154e07dfb85a97585f4e

See more details on using hashes here.

File details

Details for the file anosys_sdk_openai-1.0.2-py3-none-any.whl.

File metadata

File hashes

Hashes for anosys_sdk_openai-1.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 33c442f0b4e42c35cd5ff2f32ad7575db1d21a50905dc7b2e002df63bcba6d32
MD5 dd9d3d4d1b951e95ed2ea5e7ca7a3813
BLAKE2b-256 55a7981218842fee6ac22b2e6c8d1e2382ef850f900e9ed548034b3e22b2ad12

See more details on using hashes here.

Supported by

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