forked from open-webui/open-webui
-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
120 changed files
with
7,425 additions
and
4,022 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
*.sh text eol=lf |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,32 +1,32 @@ | ||
# Ollama Web UI Troubleshooting Guide | ||
# Open WebUI Troubleshooting Guide | ||
|
||
## Understanding the Ollama WebUI Architecture | ||
## Understanding the Open WebUI Architecture | ||
|
||
The Ollama WebUI system is designed to streamline interactions between the client (your browser) and the Ollama API. At the heart of this design is a backend reverse proxy, enhancing security and resolving CORS issues. | ||
The Open WebUI system is designed to streamline interactions between the client (your browser) and the Ollama API. At the heart of this design is a backend reverse proxy, enhancing security and resolving CORS issues. | ||
|
||
- **How it Works**: The Ollama WebUI is designed to interact with the Ollama API through a specific route. When a request is made from the WebUI to Ollama, it is not directly sent to the Ollama API. Initially, the request is sent to the Ollama WebUI backend via `/ollama/api` route. From there, the backend is responsible for forwarding the request to the Ollama API. This forwarding is accomplished by using the route specified in the `OLLAMA_API_BASE_URL` environment variable. Therefore, a request made to `/ollama/api` in the WebUI is effectively the same as making a request to `OLLAMA_API_BASE_URL` in the backend. For instance, a request to `/ollama/api/tags` in the WebUI is equivalent to `OLLAMA_API_BASE_URL/tags` in the backend. | ||
- **How it Works**: The Open WebUI is designed to interact with the Ollama API through a specific route. When a request is made from the WebUI to Ollama, it is not directly sent to the Ollama API. Initially, the request is sent to the Open WebUI backend via `/ollama/api` route. From there, the backend is responsible for forwarding the request to the Ollama API. This forwarding is accomplished by using the route specified in the `OLLAMA_API_BASE_URL` environment variable. Therefore, a request made to `/ollama/api` in the WebUI is effectively the same as making a request to `OLLAMA_API_BASE_URL` in the backend. For instance, a request to `/ollama/api/tags` in the WebUI is equivalent to `OLLAMA_API_BASE_URL/tags` in the backend. | ||
|
||
- **Security Benefits**: This design prevents direct exposure of the Ollama API to the frontend, safeguarding against potential CORS (Cross-Origin Resource Sharing) issues and unauthorized access. Requiring authentication to access the Ollama API further enhances this security layer. | ||
|
||
## Ollama WebUI: Server Connection Error | ||
## Open WebUI: Server Connection Error | ||
|
||
If you're experiencing connection issues, it’s often due to the WebUI docker container not being able to reach the Ollama server at 127.0.0.1:11434 (host.docker.internal:11434) inside the container . Use the `--network=host` flag in your docker command to resolve this. Note that the port changes from 3000 to 8080, resulting in the link: `http://localhost:8080`. | ||
|
||
**Example Docker Command**: | ||
|
||
```bash | ||
docker run -d --network=host -v ollama-webui:/app/backend/data -e OLLAMA_API_BASE_URL=http://127.0.0.1:11434/api --name ollama-webui --restart always ghcr.io/ollama-webui/ollama-webui:main | ||
docker run -d --network=host -v open-webui:/app/backend/data -e OLLAMA_API_BASE_URL=http://127.0.0.1:11434/api --name open-webui --restart always ghcr.io/open-webui/open-webui:main | ||
``` | ||
|
||
### General Connection Errors | ||
|
||
**Ensure Ollama Version is Up-to-Date**: Always start by checking that you have the latest version of Ollama. Visit [Ollama's official site](https://ollama.ai/) for the latest updates. | ||
**Ensure Ollama Version is Up-to-Date**: Always start by checking that you have the latest version of Ollama. Visit [Ollama's official site](https://ollama.com/) for the latest updates. | ||
|
||
**Troubleshooting Steps**: | ||
|
||
1. **Verify Ollama URL Format**: | ||
- When running the Web UI container, ensure the `OLLAMA_API_BASE_URL` is correctly set, including the `/api` suffix. (e.g., `http://192.168.1.1:11434/api` for different host setups). | ||
- In the Ollama WebUI, navigate to "Settings" > "General". | ||
- In the Open WebUI, navigate to "Settings" > "General". | ||
- Confirm that the Ollama Server URL is correctly set to `[OLLAMA URL]/api` (e.g., `http://localhost:11434/api`), including the `/api` suffix. | ||
|
||
By following these enhanced troubleshooting steps, connection issues should be effectively resolved. For further assistance or queries, feel free to reach out to us on our community Discord. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -6,4 +6,6 @@ uploads | |
*.db | ||
_test | ||
Pipfile | ||
data/* | ||
data/* | ||
!data/config.json | ||
.webui_secret_key |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,80 @@ | ||
import os | ||
from fastapi import ( | ||
FastAPI, | ||
Request, | ||
Depends, | ||
HTTPException, | ||
status, | ||
UploadFile, | ||
File, | ||
Form, | ||
) | ||
from fastapi.middleware.cors import CORSMiddleware | ||
from faster_whisper import WhisperModel | ||
|
||
from constants import ERROR_MESSAGES | ||
from utils.utils import ( | ||
decode_token, | ||
get_current_user, | ||
get_verified_user, | ||
get_admin_user, | ||
) | ||
from utils.misc import calculate_sha256 | ||
|
||
from config import CACHE_DIR, UPLOAD_DIR, WHISPER_MODEL, WHISPER_MODEL_DIR | ||
|
||
app = FastAPI() | ||
app.add_middleware( | ||
CORSMiddleware, | ||
allow_origins=["*"], | ||
allow_credentials=True, | ||
allow_methods=["*"], | ||
allow_headers=["*"], | ||
) | ||
|
||
|
||
@app.post("/transcribe") | ||
def transcribe( | ||
file: UploadFile = File(...), | ||
user=Depends(get_current_user), | ||
): | ||
print(file.content_type) | ||
|
||
if file.content_type not in ["audio/mpeg", "audio/wav"]: | ||
raise HTTPException( | ||
status_code=status.HTTP_400_BAD_REQUEST, | ||
detail=ERROR_MESSAGES.FILE_NOT_SUPPORTED, | ||
) | ||
|
||
try: | ||
filename = file.filename | ||
file_path = f"{UPLOAD_DIR}/{filename}" | ||
contents = file.file.read() | ||
with open(file_path, "wb") as f: | ||
f.write(contents) | ||
f.close() | ||
|
||
model = WhisperModel( | ||
WHISPER_MODEL, | ||
device="auto", | ||
compute_type="int8", | ||
download_root=WHISPER_MODEL_DIR, | ||
) | ||
|
||
segments, info = model.transcribe(file_path, beam_size=5) | ||
print( | ||
"Detected language '%s' with probability %f" | ||
% (info.language, info.language_probability) | ||
) | ||
|
||
transcript = "".join([segment.text for segment in list(segments)]) | ||
|
||
return {"text": transcript.strip()} | ||
|
||
except Exception as e: | ||
print(e) | ||
|
||
raise HTTPException( | ||
status_code=status.HTTP_400_BAD_REQUEST, | ||
detail=ERROR_MESSAGES.DEFAULT(e), | ||
) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.