mirror of
https://github.com/pewdiepie-archdaemon/odysseus.git
synced 2026-06-17 02:05:22 -04:00
This commit is contained in:
+5
-1
@@ -270,8 +270,10 @@ def _is_ollama_native_url(url: str) -> bool:
|
||||
path = (parsed.path or "").rstrip("/")
|
||||
if _host_match(url, "ollama.com"):
|
||||
return True
|
||||
if path.startswith("/v1"):
|
||||
return False
|
||||
local_ollama_host = host in {"localhost", "127.0.0.1", "0.0.0.0", "::1"} or parsed.port == 11434
|
||||
return local_ollama_host and (path == "/api" or path.startswith("/api/"))
|
||||
return local_ollama_host and (path == "" or path == "/api" or path.startswith("/api/"))
|
||||
|
||||
|
||||
def _ollama_api_root(url: str) -> str:
|
||||
@@ -287,6 +289,8 @@ def _ollama_api_root(url: str) -> str:
|
||||
return url[: -len("/generate")]
|
||||
if path.endswith("/api"):
|
||||
return url
|
||||
if path == "":
|
||||
return url + "/api"
|
||||
if _host_match(url, "ollama.com"):
|
||||
root = f"{parsed.scheme}://{parsed.netloc}" if parsed.scheme and parsed.netloc else "https://ollama.com"
|
||||
return root.rstrip("/") + "/api"
|
||||
|
||||
@@ -61,7 +61,11 @@ def _detect_provider(url: str) -> str:
|
||||
parsed = urlparse(url or "")
|
||||
host = parsed.hostname or ""
|
||||
path = (parsed.path or "").rstrip("/")
|
||||
if host.endswith("ollama.com") or (parsed.port == 11434 and (path == "/api" or path.startswith("/api/"))):
|
||||
if host.endswith("ollama.com"):
|
||||
return "ollama"
|
||||
if path.startswith("/v1"):
|
||||
pass # OpenAI compat
|
||||
elif (parsed.port == 11434 or host in {"localhost", "127.0.0.1", "0.0.0.0", "::1"}) and (path == "" or path == "/api" or path.startswith("/api/")):
|
||||
return "ollama"
|
||||
if "anthropic.com" in (url or ""):
|
||||
return "anthropic"
|
||||
@@ -75,6 +79,8 @@ def _ollama_api_root(base: str) -> str:
|
||||
path = (parsed.path or "").rstrip("/")
|
||||
if path.endswith("/api"):
|
||||
return base
|
||||
if path == "":
|
||||
return base + "/api"
|
||||
if host.endswith("ollama.com"):
|
||||
return f"{parsed.scheme}://{parsed.netloc}/api"
|
||||
return base
|
||||
@@ -156,6 +162,12 @@ class TestBuildChatUrl:
|
||||
def test_ollama_cloud_root_adds_api(self):
|
||||
assert build_chat_url("https://ollama.com") == "https://ollama.com/api/chat"
|
||||
|
||||
def test_ollama_bare_url_adds_api(self):
|
||||
assert build_chat_url("http://nas:11434") == "http://nas:11434/api/chat"
|
||||
|
||||
def test_ollama_v1_preserves_openai_compat(self):
|
||||
assert build_chat_url("http://nas:11434/v1") == "http://nas:11434/v1/chat/completions"
|
||||
|
||||
|
||||
class TestBuildModelsUrl:
|
||||
def test_openai_models(self):
|
||||
|
||||
Reference in New Issue
Block a user