Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Can't import AbortableAsyncIterator class from ollama library #187

Open
AbdulrhmanGoni opened this issue Jan 3, 2025 · 1 comment · May be fixed by #188
Open

Can't import AbortableAsyncIterator class from ollama library #187

AbdulrhmanGoni opened this issue Jan 3, 2025 · 1 comment · May be fixed by #188

Comments

@AbdulrhmanGoni
Copy link

I tried to pass the returned abortable async iterator from Ollama.chat method
as parameter to another custom function like here 👇🏿

async function handleChatResponse(chatResponse: AbortableAsyncIterator<ChatResponse>) {
    for await (const response of chatResponse) {
        console.log(response.message.content)
    }
};

const chatResponse = await ollama.chat({
    model: "llama3.2",
    messages: [...messages],
    stream: true,
})

handleChatResponse(chatResponse)

But the problem is that ollama library doesn't export AbortableAsyncIterator class as you see here 👇🏿

import type { ChatResponse, AbortableAsyncIterator } from "npm:ollama";
// 'ChatResponse' can be imported ✅, but 'AbortableAsyncIterator' causes 👇🏿 
// "Module 'npm:ollama' has no exported member 'AbortableAsyncIterator'" error.
@AbdulrhmanGoni AbdulrhmanGoni changed the title Can't export AbortableAsyncIterator class from ollama library Can't import AbortableAsyncIterator class from ollama library Jan 3, 2025
@AbdulrhmanGoni AbdulrhmanGoni linked a pull request Jan 3, 2025 that will close this issue
@madooei
Copy link

madooei commented Jan 19, 2025

@AbdulrhmanGoni I think you are right to ask for AbortableAsyncIterator to be exposed since it is used as a return type of the chat response. I don't know if the maintainers will expose it. In the meantime, in case this might help others, we can use TypeScript's AsyncIterator type combined with an additional abort method to define the return type:

import { ChatResponse } from "ollama/browser";

const response: Promise<AsyncIterator<ChatResponse> & { abort: () => void }> = await ollama.chat({
  // model, messages, and other inputs
  stream: true,
});

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging a pull request may close this issue.

2 participants