-
Notifications
You must be signed in to change notification settings - Fork 1.2k
/
Copy path_openai_shared.py
102 lines (75 loc) · 2.6 KB
/
_openai_shared.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
from __future__ import annotations
import logging
from typing import Any, TypeAlias
from openai import AsyncOpenAI
# Type aliases for common OpenAI types
TOpenAIClient: TypeAlias = AsyncOpenAI
TOpenAIClientOptions: TypeAlias = dict[str, Any]
_default_openai_key: str | None = None
_default_openai_client: TOpenAIClient | None = None
_use_responses_by_default: bool = True
_logger = logging.getLogger(__name__)
def set_default_openai_key(key: str) -> None:
"""Set the default OpenAI API key to use when creating clients.
Args:
key: The OpenAI API key
"""
global _default_openai_key
_default_openai_key = key
def get_default_openai_key() -> str | None:
"""Get the default OpenAI API key.
Returns:
The default OpenAI API key, or None if not set
"""
return _default_openai_key
def set_default_openai_client(client: TOpenAIClient) -> None:
"""Set the default OpenAI client to use.
Args:
client: The OpenAI client instance
"""
global _default_openai_client
_default_openai_client = client
def get_default_openai_client() -> TOpenAIClient | None:
"""Get the default OpenAI client.
Returns:
The default OpenAI client, or None if not set
"""
return _default_openai_client
def set_use_responses_by_default(use_responses: bool) -> None:
"""Set whether to use the Responses API by default.
Args:
use_responses: Whether to use the Responses API
"""
global _use_responses_by_default
_use_responses_by_default = use_responses
def get_use_responses_by_default() -> bool:
"""Get whether to use the Responses API by default.
Returns:
Whether to use the Responses API by default
"""
return _use_responses_by_default
def create_client(
api_key: str | None = None,
base_url: str | None = None,
organization: str | None = None,
project: str | None = None,
http_client: Any = None,
) -> TOpenAIClient:
"""Create a new OpenAI client with the given parameters.
This is a utility function to standardize client creation across the codebase.
Args:
api_key: The API key to use. If not provided, uses the default.
base_url: The base URL to use. If not provided, uses the default.
organization: The organization to use.
project: The project to use.
http_client: The HTTP client to use.
Returns:
A new OpenAI client
"""
return AsyncOpenAI(
api_key=api_key or get_default_openai_key(),
base_url=base_url,
organization=organization,
project=project,
http_client=http_client,
)