Skip to content

Commit

Permalink
enable ollama-js use in an environment without whatwg (#125)
Browse files Browse the repository at this point in the history
- use dynamic import to allow setting fetch without whatwg-fetch being present
  • Loading branch information
BruceMacD authored Aug 5, 2024
1 parent 8ab57ca commit f73dae5
Showing 1 changed file with 18 additions and 4 deletions.
22 changes: 18 additions & 4 deletions src/browser.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,5 @@
import * as utils from './utils.js'
import { AbortableAsyncIterator, parseJSON, post } from './utils.js'
import 'whatwg-fetch'

import type {
ChatRequest,
Expand Down Expand Up @@ -39,9 +38,24 @@ export class Ollama {
this.config.host = utils.formatHost(config?.host ?? 'http://127.0.0.1:11434')
}

this.fetch = fetch
if (config?.fetch != null) {
this.fetch = config.fetch
this.fetch = config?.fetch || this.getFetch();
}

private getFetch(): Fetch {
if (typeof window !== 'undefined' && window.fetch) {
return window.fetch.bind(window);
}

if (typeof global !== 'undefined' && global.fetch) {
return global.fetch;
}

try {
// Use dynamic import for Node.js environments
return require('node-fetch');
} catch (error) {
console.error('Failed to import node-fetch:', error);
throw new Error('Fetch is not available. Please provide a fetch implementation in the config.');
}
}

Expand Down

0 comments on commit f73dae5

Please sign in to comment.