From 024ceeda4e0b3dadd7b62115ee9174f0db16b6ab Mon Sep 17 00:00:00 2001 From: YasinOnm08 Date: Thu, 19 Sep 2024 13:02:56 +0200 Subject: [PATCH] started multithreading --- app/AI.tsx | 2 ++ app/InputOutputHandler.tsx | 49 ++++++++++++++++++++++++++++++++++++++ app/ProcessAPI.js | 39 ++++++++++++++++++++++++++++++ app/ProcessAPI.tsx | 2 -- app/ProcessMemory.tsx | 13 ++++++++++ 5 files changed, 103 insertions(+), 2 deletions(-) create mode 100644 app/InputOutputHandler.tsx create mode 100644 app/ProcessAPI.js delete mode 100644 app/ProcessAPI.tsx create mode 100644 app/ProcessMemory.tsx diff --git a/app/AI.tsx b/app/AI.tsx index 597b629..5e48841 100644 --- a/app/AI.tsx +++ b/app/AI.tsx @@ -1,10 +1,12 @@ // AI.tsx import React from 'react'; import InputBackend from './InputBackend'; +import InputOutputBackend from './InputOutputHandler'; const AI: React.FC = () => { return (
+
); diff --git a/app/InputOutputHandler.tsx b/app/InputOutputHandler.tsx new file mode 100644 index 0000000..21c7678 --- /dev/null +++ b/app/InputOutputHandler.tsx @@ -0,0 +1,49 @@ +"use client" +import React, { useEffect, useState } from "react"; +import axios from 'axios'; + +type lol = { + message: string[] +} +const InputOutputBackend: React.FC = () => { + const [getMessage, setGetMessage] = useState("") + const [accessToken, setAccessToken] = useState("") + const [postMessage, setPostMessage] = useState("") + const [input, setInput] = useState("") + + useEffect(() => { + const worker = new Worker(new URL("./ProcessAPI.js", import.meta.url)) + worker.postMessage({}) + worker.onmessage = (e) => { + setAccessToken(e.data.access_token) + console.log(accessToken) + } + + return () => { + worker.terminate() + } + }) + + const HandleGetRequest = () => { + axios.get('/interstellar/api/ai_get') + .then(Response => { + setAccessToken(Response.data.response) + }).catch(error => { + console.error("Error with GET response request:", error) + }) + } + + const HandlePostRequest = () => { + axios.post('/interstellar/api/ai_send', {}) + } + + return
Hello {accessToken}
+} + +export default InputOutputBackend + + + + + + \ No newline at end of file diff --git a/app/ProcessAPI.js b/app/ProcessAPI.js new file mode 100644 index 0000000..156a2ef --- /dev/null +++ b/app/ProcessAPI.js @@ -0,0 +1,39 @@ +import axios from 'axios' + +onmessage = function (e) { + const { functionName = "getAccess", access_token = "", message = "", ai_model = "phi3.5", system_prompt = "You are a helpful assistant" } = e.data + switch (functionName) { + case "getAccess": + axios.get('http://localhost:5000/interstellar/api/ai_create') + .then(Response => { + postMessage(Response.data.access_token) + }).catch(error => { + console.error("Error with GET Token request:", error) + }) + break + case "postRequest": + const data = { + ai_model: ai_model, + message: message, + system_prompt: system_prompt, + access_token: access_token + }; + axios.post('http://localhost:5000/interstellar/api/ai_send', data) + .then(Response => { + postMessage(Response.data) + }).catch(error => { + console.error("Error:", error) + }) + break + case "getResponse": + axios.get('http://localhost:5000/interstellar/api/ai_get') + .then(Response => { + postMessage(Response.data.response) + }).catch(error => { + console.error("Error with GET response request:", error) + }) + break + } + + +} \ No newline at end of file diff --git a/app/ProcessAPI.tsx b/app/ProcessAPI.tsx deleted file mode 100644 index 214165f..0000000 --- a/app/ProcessAPI.tsx +++ /dev/null @@ -1,2 +0,0 @@ -import React from "react"; -import axios from 'axios'; \ No newline at end of file diff --git a/app/ProcessMemory.tsx b/app/ProcessMemory.tsx new file mode 100644 index 0000000..c402e15 --- /dev/null +++ b/app/ProcessMemory.tsx @@ -0,0 +1,13 @@ +import React from 'react' + +type Chat = { + name:string + messages:string[] +} + +type History = { + chats:Chat[] +} + + +