#flows #llm #integration #networking #service #chat #llmservice

llmservice-flows

LLM Service integration for flows.network

5 releases

0.2.0 Sep 11, 2023
0.1.3 Aug 10, 2023
0.1.2 Aug 7, 2023
0.1.1 Aug 7, 2023
0.1.0 Aug 6, 2023

#19 in #flows

24 downloads per month

MIT/Apache

18KB
287 lines

LLM Service Integration for flows.network.


lib.rs:

LLM Service integration for Flows.network

Quick Start

To get started, let's write a tiny flow function.

use llmservice_flows::{
    chat::ChatOptions,
    LLMServiceFlows,
};
use lambda_flows::{request_received, send_response};
use serde_json::Value;
use std::collections::HashMap;

#[no_mangle]
#[tokio::main(flavor = "current_thread")]
pub async fn run() {
    request_received(handler).await;
}

async fn handler(_qry: HashMap<String, Value>, body: Vec<u8>) {
    let co = ChatOptions {
      model: Some("gpt-4"),
      token_limit: 8192,
      ..Default::default()
    };
    let mut lf = LLMServiceFlows::new("https://api.openai.com/v1");
    lf.set_api_key("your api key");

    let r = match lf.chat_completion(
        "any_conversation_id",
        String::from_utf8_lossy(&body).into_owned().as_str(),
        &co,
    )
    .await
    {
        Ok(c) => c.choice,
        Err(e) => e,
    };
    
    send_response(
        200,
        vec![(
            String::from("content-type"),
            String::from("text/plain; charset=UTF-8"),
        )],
        r.as_bytes().to_vec(),
    );
}

When the Lambda request is received, chat using [chat_completion] then send the response.

Dependencies

~1.6–2.5MB
~53K SLoC