llm-stack-openai 0.7.0

OpenAI GPT provider for the llm-stack SDK
Documentation
//! `OpenAI` provider for the llm-stack SDK.
//!
//! This crate implements [`Provider`](llm_stack::Provider) for `OpenAI`'s
//! Chat Completions API, supporting both non-streaming and streaming
//! generation with tool calling and structured output.
//!
//! # Quick start
//!
//! ```rust,no_run
//! use llm_stack_openai::{OpenAiConfig, OpenAiProvider};
//! use llm_stack::{ChatMessage, ChatParams, Provider};
//!
//! # async fn example() -> Result<(), llm_stack::LlmError> {
//! let provider = OpenAiProvider::new(OpenAiConfig {
//!     api_key: std::env::var("OPENAI_API_KEY").unwrap(),
//!     ..Default::default()
//! });
//!
//! let params = ChatParams {
//!     messages: vec![ChatMessage::user("Hello!")],
//!     ..Default::default()
//! };
//!
//! let response = provider.generate(&params).await?;
//! println!("{}", response.text().unwrap_or("no text"));
//! # Ok(())
//! # }
//! ```

#![warn(missing_docs)]

mod config;
mod convert;
mod factory;
mod provider;
mod stream;
mod types;

pub use config::OpenAiConfig;
pub use factory::{OpenAiFactory, register_global};
pub use provider::OpenAiProvider;