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

Ollama AI #1299

Open
wants to merge 1 commit into
base: main
Choose a base branch
from
Open
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
114 changes: 114 additions & 0 deletions extensions/community/OllamaAI.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,114 @@
{
"author": "",
"category": "Third-party",
"extensionNamespace": "",
"fullName": "OllamaAI",
"helpPath": "",
"iconUrl": "",
"name": "OllamaAI",
"previewIconUrl": "https://asset-resources.gdevelop.io/public-resources/Icons/17afc029e0ccfc314f5b7f5f53632ca24b3e6082d0cc87c0777dcfa79fd56e0b_chat-processing-outline.svg",
"shortDescription": "This extension adds the functionality to your project to easily send requests to the \"Ollama\" AI, and get responses from it.",
"version": "1.0.0",
"description": [
"Create a simple action to send the following data to a Ollama AI server:",
"",
"- URL (The server's URL with port)",
"- Model (The model you want to generate the response)",
"- Prompt (The prompt you send to the server to reply to)"
],
"tags": [
"ollama",
"ai",
"llama",
"llama2",
"llama3",
"chat",
"bot"
],
"authorIds": [],
"dependencies": [],
"eventsFunctions": [
{
"description": "Sends the prompt string, the model string, and the stream boolean from the given structure.",
"fullName": "Send prompt to a model",
"functionType": "Action",
"name": "Request",
"sentence": "Send _PARAM2_ and _PARAM3_ to _PARAM1_, then store the response JSON in the variable \"Ollama_AI_JSON\"",
"events": [
{
"type": "BuiltinCommonInstructions::Standard",
"conditions": [],
"actions": [
{
"type": {
"value": "ModVarSceneTxt"
},
"parameters": [
"Ollama_AI.model",
"=",
"Model"
]
},
{
"type": {
"value": "ModVarSceneTxt"
},
"parameters": [
"Ollama_AI.prompt",
"=",
"Prompt"
]
},
{
"type": {
"value": "SetSceneVariableAsBoolean"
},
"parameters": [
"Ollama_AI.stream",
"False"
]
},
{
"type": {
"value": "SendAsyncRequest"
},
"parameters": [
"API_URL",
"ToJSON(Ollama_AI)",
"\"POST\"",
"",
"Ollama_AI_JSON",
"Ollama_AI_Error"
]
}
]
}
],
"parameters": [
{
"description": "The URL where the Ollama model is hosted (e.g. http://localhost:11434/api/generate)",
"longDescription": "The URL should be in this format: \"http://<ip address>:11434/api/generate\". If you are hosting and testing locally, use this URL: \"http://localhost:11434/api/generate\". Read the extension's GitHub issue on how to host your own server.",
"name": "API_URL",
"supplementaryInformation": "[\"http://localhost:11434/api/generate\"]",
"type": "stringWithSelector"
},
{
"description": "The model to be used when generating a response",
"longDescription": "The recommended one is \"llama3\", an older version is \"llama2\", but you can also customize the models and use those. Read the extension's GitHub issue on how to do this.",
"name": "Model",
"supplementaryInformation": "[\"llama3\",\"llama2\",\"codegemma\"]",
"type": "stringWithSelector"
},
{
"description": "Your prompt to the AI, for example: \"Why is the sky blue?\"",
"longDescription": "The response will be stored in JSON in the variable \"Ollama_AI_JSON\". After that, you can convert the JSON to a structure. You can see how you can do it in the example on the extension's GitHub.",
"name": "Prompt",
"type": "string"
}
],
"objectGroups": []
}
],
"eventsBasedBehaviors": [],
"eventsBasedObjects": []
}