From edd765c0c3ceb652e7c22262444952421817d393 Mon Sep 17 00:00:00 2001 From: thiswillbeyourgithub <26625900+thiswillbeyourgithub@users.noreply.github.com> Date: Fri, 9 May 2025 15:30:37 +0200 Subject: [PATCH] feat: new page to detail special arguments Signed-off-by: thiswillbeyourgithub <26625900+thiswillbeyourgithub@users.noreply.github.com> --- docs/tutorials/tips/special_arguments.mdx | 361 ++++++++++++++++++++++ 1 file changed, 361 insertions(+) create mode 100644 docs/tutorials/tips/special_arguments.mdx diff --git a/docs/tutorials/tips/special_arguments.mdx b/docs/tutorials/tips/special_arguments.mdx new file mode 100644 index 0000000..8d6545e --- /dev/null +++ b/docs/tutorials/tips/special_arguments.mdx @@ -0,0 +1,361 @@ +--- +sidebar_position: 20 +title: "💡 Special Arguments" +--- + +:::warning +This tutorial is a community contribution and is not supported by the Open WebUI team. It serves only as a demonstration on how to customize Open WebUI for your specific use case. Want to contribute? Check out the contributing tutorial. +::: + +# 💡 Special Arguments + +When developping your own `Tools`, `Functions` (`Filters`, `Pipes` or `Actions`), `Pipelines` etc, you can use special arguments explore the full spectrum of what Open-WebUI has to offer. + +This page aims to detail the type and structure of each special argument as well as provide an example. + + + +### `body` + +A `dict` usually destined to go almost directly to the model. Although it is not strictly a special argument, it is included here for easier reference and because it contains itself some special arguments. + +
Example + +```json + +{ + "stream": true, + "model": "my-cool-model", + # lowercase string with - separated words: this is the ID of the model + "messages": [ + { + "role": "user", + "content": [ + { + "type": "text", + "text": "What is in this picture?" + }, + { + "type": "image_url", + "image_url": { + "url": "[REDACTED]" + # Images are passed as base64 encoded data + } + } + ] + }, + { + "role": "assistant", + "content": "The image appears to be [REDACTED]" + }, + ], + "features": { + "image_generation": false, + "code_interpreter": false, + "web_search": false + }, + "stream_options": { + "include_usage": true + }, + "metadata": "[The exact same dict as __metadata__]", + "files": "[The exact same list as __files__]" +} + + +``` + +
+ +### `__user__` + +A `dict` with user information. + +Note that if the `UserValves` class is defined, its instance has to be accessed via `__user__["valves"]`. Otherwise, the `valves` keyvalue is missing entirely from `__user__`. + +
Example + +```json +{ + "id": "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx", + "email": "cheesy_dude@openwebui.com", + "name": "Patrick", + "role": "user", + # role can be either `user` or `admin` + "valves": "[the UserValve instance]" +} +``` + +
+ +### `__metadata__` + +A `dict` with wide ranging information about the chat, model, files, etc. + +
Example + +```json +{ + "user_id": "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx", + "chat_id": "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx", + "message_id": "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx", + "session_id": "xxxxxxxxxxxxxxxxxxxx", + "tool_ids": null, + # tool_ids is a list of str. + "tool_servers": [], + "files": "[Same as in body['files']]", + # If no files are given, the files key exists in __metadata__ and its value is [] + "features": { + "image_generation": false, + "code_interpreter": false, + "web_search": false + }, + "variables": { + "{{USER_NAME}}": "cheesy_username", + "{{USER_LOCATION}}": "Unknown", + "{{CURRENT_DATETIME}}": "2025-02-02 XX:XX:XX", + "{{CURRENT_DATE}}": "2025-02-02", + "{{CURRENT_TIME}}": "XX:XX:XX", + "{{CURRENT_WEEKDAY}}": "Monday", + "{{CURRENT_TIMEZONE}}": "Europe/Berlin", + "{{USER_LANGUAGE}}": "en-US" + }, + "model": "[The exact same dict as __model__]", + "direct": false, + "function_calling": "native", + "type": "user_response", + "interface": "open-webui" +} + +``` + +
+ +### `__model__` + +A `dict` with information about the model. + +
Example + +```json +{ + "id": "my-cool-model", + "name": "My Cool Model", + "object": "model", + "created": 1746000000, + "owned_by": "openai", + # either openai or ollama + "info": { + "id": "my-cool-model", + "user_id": "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx", + "base_model_id": "gpt-4o", + # this is the name of model that the model endpoint serves + "name": "My Cool Model", + "params": { + "system": "You are my best assistant. You answer [REDACTED]", + "function_calling": "native" + # custom options appear here, for example "Top K" + }, + "meta": { + "profile_image_url": "/static/favicon.png", + "description": "Description of my-cool-model", + "capabilities": { + "vision": true, + "usage": true, + "citations": true + }, + "position": 17, + "tags": [ + { + "name": "for_friends" + }, + { + "name": "vision_enabled" + } + ], + "suggestion_prompts": null + }, + "access_control": { + "read": { + "group_ids": [], + "user_ids": [] + }, + "write": { + "group_ids": [], + "user_ids": [] + } + }, + "is_active": true, + "updated_at": 1740000000, + "created_at": 1740000000 + }, + "preset": true, + "actions": [], + "tags": [ + { + "name": "for_friends" + }, + { + "name": "vision_enabled" + } + ] +} + +``` + +
+ +### `__messages__` + +A `list` of the previous messages. + +See the `body["messages"]` value above. + + +### `__chat_id__` + +The `str` of the `chat_id`. + +See the `__metadata__["chat_id"]` value above. + +### `__session_id__` + +The `str` of the `session_id`. + +See the `__metadata__["session_id"]` value above. + +### `__message_id__` + +The `str` of the `message_id`. + +See the `__metadata__["message_id"]` value above. + +### `__event_emitter__` + +A `Callable` used to display event information to the user. + +See the [related Tools page](./development.mdx) for examples. + +### `__event_call__` + +A `Callable` used for `Actions`. + +See the [related Actions page](../functions/action.mdx) for examples. + +### `__files__` + +A `list` of files sent via the chat. Note that images are not considered files and are sent directly to the model as part of the `body["messages"]` list. + +The actual binary of the file is not part of the arguments for performance reason, but the file remain nonetheless accessible by its path if needed. For example using `docker` the python syntax for the path could be: + +```python +from pathlib import Path + +the_file = Path(f"/app/backend/data/uploads/{__files__[0]["files"]["id"]}_{__files__[0]["files"]["filename"]}") +assert the_file.exists() +``` + +Note that the same files dict can also be accessed via `__metadata__["files"]` (and its value is `[]` if no files are sent) or via `body["files"]` (but the `files` key is missing entirely from `body` if no files are sent). + +
Example + +```json + +[ + { + "type": "file", + "file": { + "id": "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx", + "filename": "Napoleon - Wikipedia.pdf", + "user_id": "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx", + "hash": "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx", + "data": { + "content": "Napoleon - Wikipedia\n\n\nNapoleon I\n\nThe Emperor Napoleon in His Study at the\nTuileries, 1812\n\nEmperor of the French\n\n1st reign 18 May 1804 – 6 April 1814\n\nSuccessor Louis XVIII[a]\n\n2nd reign 20 March 1815 – 22 June 1815\n\nSuccessor Louis XVIII[a]\n\nFirst Consul of the French Republic\n\nIn office\n13 December 1799 – 18 May 1804\n\nBorn Napoleone Buonaparte\n15 August 1769\nAjaccio, Corsica, Kingdom of\nFrance\n\nDied 5 May 1821 (aged 51)\nLongwood, Saint Helena\n\nBurial 15 December 1840\nLes Invalides, Paris\n\nNapoleon\nNapoleon Bonaparte[b] (born Napoleone\nBuonaparte;[1][c] 15 August 1769 – 5 May 1821), later\nknown [REDACTED]", + # The content value is the output of the document parser, the above example is with Tika as a document parser + }, + "meta": { + "name": "Napoleon - Wikipedia.pdf", + "content_type": "application/pdf", + "size": 10486578, + # in bytes, here about 10Mb + "data": {}, + "collection_name": "file-96xxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx" + # always begins by 'file' + }, + "created_at": 1740000000, + "updated_at": 1740000000 + }, + "id": "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx", + "url": "/api/v1/files/xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx", + "name": "Napoleon - Wikipedia.pdf", + "collection_name": "file-96xxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx" + "status": "uploaded", + "size": 10486578, + "error": "", + "itemId": "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx" + # itemId is not the same as file["id"] + } +] + + +``` + +
+ +### `__request__` + +An instance of `fastapi.Request`. You can read more at the [migration page](../../features/plugin/migration/index.mdx) or at [fastapi's documentation](https://fastapi.tiangolo.com/reference/request/). + +### `__task__` + +A `str` for the type of task. Its value is just a shorthand for `__metadata__["task"]` if present, otherwise `None`. + +
+Possible values + +```json + +[ + "title_generation", + "tags_generation", + "emoji_generation", + "query_generation", + "image_prompt_generation", + "autocomplete_generation", + "function_calling", + "moa_response_generation" +] +``` + +
+ + + + +### `__task_body__` + +A `dict` containing the `body` needed to accomplish a given `__task__`. Its value is just a shorthand for `__metadata__["task_body"]` if present, otherwise `None`. + +Its structure is the same as `body` above, with modifications like using the appropriate model and system message etc. + + + + +### `__tools__` + +A `list` of `ToolUserModel` instances. + +For details the attributes of `ToolUserModel` instances, the code can be found in [tools.py](https://github.com/open-webui/open-webui/blob/main/backend/open_webui/models/tools.py). + +