hoosh 1.3.0

AI inference gateway — multi-provider LLM routing, local model serving, speech-to-text, and token budget management
Documentation
//! Groq provider — thin wrapper over OpenAI-compatible API.

use crate::inference::{InferenceRequest, InferenceResponse, ModelInfo};
use crate::provider::openai_compat::OpenAiCompatibleProvider;
use crate::provider::{LlmProvider, ProviderType, TlsConfig};

/// Groq API provider (default: `https://api.groq.com/openai`).
pub struct GroqProvider {
    inner: OpenAiCompatibleProvider,
}

impl GroqProvider {
    pub fn new(
        base_url: impl Into<String>,
        api_key: Option<String>,
        tls_config: Option<&TlsConfig>,
    ) -> Self {
        let url = base_url.into();
        let url = if url.is_empty() {
            "https://api.groq.com/openai".to_string()
        } else {
            url
        };
        Self {
            inner: OpenAiCompatibleProvider::new(url, api_key, ProviderType::Groq, tls_config),
        }
    }
}

#[async_trait::async_trait]
impl LlmProvider for GroqProvider {
    async fn infer(&self, request: &InferenceRequest) -> anyhow::Result<InferenceResponse> {
        self.inner.infer(request).await
    }
    async fn infer_stream(
        &self,
        request: InferenceRequest,
    ) -> anyhow::Result<tokio::sync::mpsc::Receiver<anyhow::Result<String>>> {
        self.inner.infer_stream(request).await
    }
    async fn list_models(&self) -> anyhow::Result<Vec<ModelInfo>> {
        self.inner.list_models().await
    }
    async fn health_check(&self) -> anyhow::Result<bool> {
        self.inner.health_check().await
    }
    fn provider_type(&self) -> ProviderType {
        ProviderType::Groq
    }
}

#[cfg(test)]
mod tests {
    use super::*;

    #[test]
    fn default_url() {
        let p = GroqProvider::new("", Some("gsk-test".into()), None);
        assert_eq!(p.inner.base_url(), "https://api.groq.com/openai");
    }

    #[test]
    fn provider_type_is_groq() {
        let p = GroqProvider::new("", None, None);
        assert_eq!(p.provider_type(), ProviderType::Groq);
    }
}