7 releases

0.0.8 Sep 3, 2024
0.0.7 May 16, 2023

#1716 in Web programming

Download history 49/week @ 2024-09-18 67/week @ 2024-09-25 20/week @ 2024-10-02 71/week @ 2024-10-09 104/week @ 2024-10-16 7/week @ 2024-10-23 16/week @ 2024-10-30 15/week @ 2024-11-06 11/week @ 2024-11-13 27/week @ 2024-11-20 19/week @ 2024-11-27 27/week @ 2024-12-04 189/week @ 2024-12-11 78/week @ 2024-12-18 16/week @ 2024-12-25 36/week @ 2025-01-01

325 downloads per month
Used in pullrequest

MIT license

36KB
460 lines

Anthropic unofficial Rust SDK 🦀

GitHub Workflow Status Project license Pull Requests welcome Rust docs Rust crate

anthropic-rs is an unofficial Rust library to interact with Anthropic REST API, with async support.

Wanna play with Claude in Rust? This is the place to be!

Usage

#[tokio::main]
async fn main() -> Result<(), Box<dyn Error>> {
    // Load the environment variables from the .env file.
    dotenv().ok();

    // Build from configuration.
    let cfg = AnthropicConfig::new()?;
    let client = Client::try_from(cfg)?;

    let complete_request = CompleteRequestBuilder::default()
        .prompt(format!("{HUMAN_PROMPT}How many toes do dogs have?{AI_PROMPT}"))
        .model("claude-instant-1".to_string())
        .stream_response(false)
        .stop_sequences(vec![HUMAN_PROMPT.to_string()])
        .build()?;

    // Send a completion request.
    let complete_response = client.complete(complete_request).await?;

    println!("completion response: {complete_response:?}");

    Ok(())
}

You can find full working examples in the examples directory.

Configuration

anthropic-rs uses dotenv to automatically load environment variables from a .env file. You can also set these variables manually in your environment. Here is an example of the configuration variables used:

ANTHROPIC_API_KEY="..."
ANTHROPIC_DEFAULT_MODEL="claude-v1"

Replace the "..." with your actual tokens and preferences.

You can also set these variables manually when you crate a new Client instance, see more details in usage section.

Features

  • Completion (/v1/complete)
  • Manage stream mode

Contributing

Contributions to anthropic-rs are welcomed! Feel free to submit a pull request or create an issue.

License

anthropic-rs is licensed under the MIT License.

Acknowledgements

  • Anthropic API reference for the clear and concise documentation.
  • The architecture of the SDK is inspired by async-openai, an asynchronous Rust library developed for OpenAI. We extend our heartfelt gratitude to the creators for their invaluable work. We envisage significant benefits in developing a standardized interface for interaction with various AI GPT providers' APIs. As an example, it would facilitate the development of versatile wrappers that could seamlessly interface with different providers.

Dependencies

~9–21MB
~305K SLoC