forked from React-Group/interstellar_ai
general fixes
This commit is contained in:
parent
281d786c19
commit
885b838704
7 changed files with 66 additions and 23 deletions
|
@ -6,6 +6,8 @@ import { sendToVoiceRecognition } from "./voice_backend"
|
||||||
import axios from "axios";
|
import axios from "axios";
|
||||||
import { useChatHistory } from '../hooks/useChatHistory';
|
import { useChatHistory } from '../hooks/useChatHistory';
|
||||||
import { getWeather } from "./weather";
|
import { getWeather } from "./weather";
|
||||||
|
import { changeHistory, getHistory } from "./database";
|
||||||
|
import { type } from "os";
|
||||||
|
|
||||||
const InputOutputBackend: React.FC = () => {
|
const InputOutputBackend: React.FC = () => {
|
||||||
// # variables
|
// # variables
|
||||||
|
@ -25,7 +27,9 @@ const InputOutputBackend: React.FC = () => {
|
||||||
const [messages, setMessages] = useState<Message[]>(chatHistory.chats[chatHistory.selectedIndex].messages || []);
|
const [messages, setMessages] = useState<Message[]>(chatHistory.chats[chatHistory.selectedIndex].messages || []);
|
||||||
const [myBoolean, setMyBoolean] = useState<boolean>(false);
|
const [myBoolean, setMyBoolean] = useState<boolean>(false);
|
||||||
const [systemMessage, setSystemMessage] = useState<string>("You are a helpful assistant")
|
const [systemMessage, setSystemMessage] = useState<string>("You are a helpful assistant")
|
||||||
const [weatherData, setWeatherData] = useState<string>("false")
|
const [weatherData, setWeatherData] = useState<string>("")
|
||||||
|
const [weatherTriggered, setWeatherTriggered] = useState<boolean>(false)
|
||||||
|
const [chatHistoryTriggered, setChatHistoryTriggered] = useState<boolean>(false)
|
||||||
const apiURL = new URL("http://localhost:5000/interstellar_ai/api/ai_create")
|
const apiURL = new URL("http://localhost:5000/interstellar_ai/api/ai_create")
|
||||||
if (typeof window !== 'undefined') {
|
if (typeof window !== 'undefined') {
|
||||||
apiURL.hostname = window.location.hostname;
|
apiURL.hostname = window.location.hostname;
|
||||||
|
@ -65,15 +69,42 @@ const InputOutputBackend: React.FC = () => {
|
||||||
setDateFormat(localStorage.getItem("dateFormat") || "DD-MM-YYYY");
|
setDateFormat(localStorage.getItem("dateFormat") || "DD-MM-YYYY");
|
||||||
setMyBoolean(localStorage.getItem('myBoolean') === 'true');
|
setMyBoolean(localStorage.getItem('myBoolean') === 'true');
|
||||||
getWeatherHere()
|
getWeatherHere()
|
||||||
|
getChatHistory()
|
||||||
}
|
}
|
||||||
}, [])
|
}, [])
|
||||||
|
|
||||||
|
useEffect(() => {
|
||||||
|
const username = localStorage.getItem("accountName")
|
||||||
|
const password = localStorage.getItem("accountPassword")
|
||||||
|
if (username && password && chatHistoryTriggered) {
|
||||||
|
changeHistory(username, password, chatHistory)
|
||||||
|
console.log("changed history in backend")
|
||||||
|
}
|
||||||
|
}, [chatHistory])
|
||||||
|
|
||||||
const getWeatherHere = async () => {
|
const getWeatherHere = async () => {
|
||||||
setWeatherData(await getWeather({ "unit_type": preferredMeasurement, "city": localStorage.getItem("weatherInfo") || "New York" }))
|
setWeatherData(await getWeather({ "unit_type": preferredMeasurement, "city": localStorage.getItem("weatherInfo") || "New York" }))
|
||||||
console.log(weatherData)
|
console.log("Got the Data!")
|
||||||
|
setWeatherTriggered(true)
|
||||||
|
}
|
||||||
|
|
||||||
|
const getChatHistory = async () => {
|
||||||
|
const username = localStorage.getItem("accountName")
|
||||||
|
const password = localStorage.getItem("accountPassword")
|
||||||
|
if (username && password) {
|
||||||
|
const tempChatHistory = await getHistory(username, password)
|
||||||
|
if (tempChatHistory && typeof tempChatHistory == "object") {
|
||||||
|
setChatHistory(tempChatHistory)
|
||||||
|
console.log("got history from backend")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
setChatHistoryTriggered(true)
|
||||||
}
|
}
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
|
console.log("creating system prompt")
|
||||||
|
console.log(weatherData)
|
||||||
|
|
||||||
const measurementString = (preferredMeasurement == "Metric")
|
const measurementString = (preferredMeasurement == "Metric")
|
||||||
? "All measurements follow the metric system. Refuse to use any other measurement system."
|
? "All measurements follow the metric system. Refuse to use any other measurement system."
|
||||||
: "All measurements follow the imperial system. Refuse to use any other measurement system.";
|
: "All measurements follow the imperial system. Refuse to use any other measurement system.";
|
||||||
|
@ -85,10 +116,11 @@ const InputOutputBackend: React.FC = () => {
|
||||||
Communicate in the language specified by the user (country code: ${preferredLanguage}), and only in this language.
|
Communicate in the language specified by the user (country code: ${preferredLanguage}), and only in this language.
|
||||||
You are only able to change language if the user specifically states you must.
|
You are only able to change language if the user specifically states you must.
|
||||||
Do not answer in multiple languages or multiple measurement systems under any circumstances other than the user requesting it.
|
Do not answer in multiple languages or multiple measurement systems under any circumstances other than the user requesting it.
|
||||||
When asked about the weather use those infos: ${weatherData}. If there is nothing there say there is no data`
|
These are the currently newest Weather infos for the region. In case the user asks about anything weather related, you can use the following data to help the user: ${weatherData}. If there is nothing there say there is no data`
|
||||||
: `You are a helpful assistant.`;
|
: `You are a helpful assistant.`;
|
||||||
|
console.log(newSystemMessage)
|
||||||
setSystemMessage(newSystemMessage)
|
setSystemMessage(newSystemMessage)
|
||||||
}, [preferredCurrency, preferredLanguage, timeFormat, preferredMeasurement, timeZone, dateFormat, myBoolean]);
|
}, [preferredCurrency, preferredLanguage, timeFormat, preferredMeasurement, timeZone, dateFormat, myBoolean, weatherTriggered]);
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
const messageIndex = 0 // system prompt is the first so index 0
|
const messageIndex = 0 // system prompt is the first so index 0
|
||||||
|
|
|
@ -13,7 +13,8 @@ export const getWeather = async (data: object): Promise<string> => {
|
||||||
const status = response.data.status;
|
const status = response.data.status;
|
||||||
const success = response.data.response;
|
const success = response.data.response;
|
||||||
postMessage({ status, success });
|
postMessage({ status, success });
|
||||||
return success;
|
console.log(JSON.stringify(success))
|
||||||
|
return JSON.stringify(success);
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
postMessage({ status: 500, success: false });
|
postMessage({ status: 500, success: false });
|
||||||
console.log(error)
|
console.log(error)
|
||||||
|
|
15
deployment_scripts/linux/pullall.sh
Normal file
15
deployment_scripts/linux/pullall.sh
Normal file
|
@ -0,0 +1,15 @@
|
||||||
|
ollama pull qwen2-math:1.5b
|
||||||
|
ollama pull qwen2.5-coder:1.5b
|
||||||
|
ollama pull phi3.5
|
||||||
|
|
||||||
|
ollama pull mathstral
|
||||||
|
ollama pull qwen2.5-coder
|
||||||
|
ollama pull qwen2.5
|
||||||
|
|
||||||
|
ollama pull qwen2-math:1.5b
|
||||||
|
ollama pull starcoder2
|
||||||
|
ollama pull llama3.2
|
||||||
|
|
||||||
|
ollama pull wizard-math
|
||||||
|
ollama pull starcoder2:7b
|
||||||
|
ollama pull llama3.1
|
16
package-lock.json
generated
16
package-lock.json
generated
|
@ -2151,9 +2151,9 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/es-iterator-helpers": {
|
"node_modules/es-iterator-helpers": {
|
||||||
"version": "1.0.19",
|
"version": "1.1.0",
|
||||||
"resolved": "https://registry.npmjs.org/es-iterator-helpers/-/es-iterator-helpers-1.0.19.tgz",
|
"resolved": "https://registry.npmjs.org/es-iterator-helpers/-/es-iterator-helpers-1.1.0.tgz",
|
||||||
"integrity": "sha512-zoMwbCcH5hwUkKJkT8kDIBZSz9I6mVG//+lDCinLCGov4+r7NIy0ld8o03M0cJxl2spVf6ESYVS6/gpIfq1FFw==",
|
"integrity": "sha512-/SurEfycdyssORP/E+bj4sEu1CWw4EmLDsHynHwSXQ7utgbrMRWW195pTrCjFgFCddf/UkYm3oqKPRq5i8bJbw==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
|
@ -2164,12 +2164,12 @@
|
||||||
"es-set-tostringtag": "^2.0.3",
|
"es-set-tostringtag": "^2.0.3",
|
||||||
"function-bind": "^1.1.2",
|
"function-bind": "^1.1.2",
|
||||||
"get-intrinsic": "^1.2.4",
|
"get-intrinsic": "^1.2.4",
|
||||||
"globalthis": "^1.0.3",
|
"globalthis": "^1.0.4",
|
||||||
"has-property-descriptors": "^1.0.2",
|
"has-property-descriptors": "^1.0.2",
|
||||||
"has-proto": "^1.0.3",
|
"has-proto": "^1.0.3",
|
||||||
"has-symbols": "^1.0.3",
|
"has-symbols": "^1.0.3",
|
||||||
"internal-slot": "^1.0.7",
|
"internal-slot": "^1.0.7",
|
||||||
"iterator.prototype": "^1.1.2",
|
"iterator.prototype": "^1.1.3",
|
||||||
"safe-array-concat": "^1.1.2"
|
"safe-array-concat": "^1.1.2"
|
||||||
},
|
},
|
||||||
"engines": {
|
"engines": {
|
||||||
|
@ -7371,9 +7371,9 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/typescript": {
|
"node_modules/typescript": {
|
||||||
"version": "5.6.2",
|
"version": "5.6.3",
|
||||||
"resolved": "https://registry.npmjs.org/typescript/-/typescript-5.6.2.tgz",
|
"resolved": "https://registry.npmjs.org/typescript/-/typescript-5.6.3.tgz",
|
||||||
"integrity": "sha512-NW8ByodCSNCwZeghjN3o+JX5OFH0Ojg6sadjEKY4huZ52TqbJTJnDo5+Tw98lSy63NZvi4n+ez5m2u5d4PkZyw==",
|
"integrity": "sha512-hjcS1mhfuyi4WW8IWtjP7brDrG2cuDZukyrYrSauoXGNgx0S7zceP07adYkJycEr56BOUTNPzbInooiN3fn1qw==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"license": "Apache-2.0",
|
"license": "Apache-2.0",
|
||||||
"bin": {
|
"bin": {
|
||||||
|
|
|
@ -108,7 +108,6 @@ class API:
|
||||||
@self.app.route("/interstellar_ai/db", methods=["POST"])
|
@self.app.route("/interstellar_ai/db", methods=["POST"])
|
||||||
def db_manipulate():
|
def db_manipulate():
|
||||||
sent_data = request.get_json()
|
sent_data = request.get_json()
|
||||||
print(sent_data)
|
|
||||||
action = sent_data.get("action")
|
action = sent_data.get("action")
|
||||||
if action == "create_account":
|
if action == "create_account":
|
||||||
return jsonify({"status": 200, "response": self.db.add_user(sent_data)})
|
return jsonify({"status": 200, "response": self.db.add_user(sent_data)})
|
||||||
|
@ -161,7 +160,6 @@ class API:
|
||||||
unit_type = sent_data.get("unit_type")
|
unit_type = sent_data.get("unit_type")
|
||||||
city = sent_data.get("city")
|
city = sent_data.get("city")
|
||||||
weather_data = self.weather.getweather(unit_type, city)
|
weather_data = self.weather.getweather(unit_type, city)
|
||||||
print(type(weather_data))
|
|
||||||
return jsonify({"status": 200, "response": weather_data})
|
return jsonify({"status": 200, "response": weather_data})
|
||||||
|
|
||||||
self.app.run(debug=True, host="0.0.0.0", port=5000)
|
self.app.run(debug=True, host="0.0.0.0", port=5000)
|
||||||
|
|
2
py/db.py
2
py/db.py
|
@ -67,7 +67,6 @@ class DB:
|
||||||
|
|
||||||
stored_hashed_password = self.database[username]["hashed_password"]
|
stored_hashed_password = self.database[username]["hashed_password"]
|
||||||
entered_hashed_password = self.hash_password(password)
|
entered_hashed_password = self.hash_password(password)
|
||||||
print(stored_hashed_password == entered_hashed_password)
|
|
||||||
return stored_hashed_password == entered_hashed_password
|
return stored_hashed_password == entered_hashed_password
|
||||||
|
|
||||||
def change_settings(self, data):
|
def change_settings(self, data):
|
||||||
|
@ -127,7 +126,6 @@ class DB:
|
||||||
|
|
||||||
else:
|
else:
|
||||||
with open("database.json", "w") as file:
|
with open("database.json", "w") as file:
|
||||||
print("saving")
|
|
||||||
json.dump(self.database, file)
|
json.dump(self.database, file)
|
||||||
|
|
||||||
def load_database(self):
|
def load_database(self):
|
||||||
|
|
|
@ -18,23 +18,22 @@ class Weather:
|
||||||
data = {
|
data = {
|
||||||
"temperature": weather.temperature,
|
"temperature": weather.temperature,
|
||||||
"humidity": weather.humidity,
|
"humidity": weather.humidity,
|
||||||
"unit": weather.unit,
|
"unit": str(weather.unit),
|
||||||
"datetime": weather.datetime,
|
"datetime": weather.datetime,
|
||||||
"coordinates": weather.coordinates,
|
"coordinates": weather.coordinates,
|
||||||
"country": weather.country,
|
"country": weather.country,
|
||||||
"daily_forecasts": weather.daily_forecasts,
|
|
||||||
"description": weather.description,
|
"description": weather.description,
|
||||||
"feels_like": weather.feels_like,
|
"feels_like": weather.feels_like,
|
||||||
"kind": weather.kind,
|
"kind": str(weather.kind),
|
||||||
"local_population": weather.local_population,
|
"local_population": weather.local_population,
|
||||||
"locale": weather.locale,
|
"locale": str(weather.locale),
|
||||||
"location": weather.location,
|
"location": weather.location,
|
||||||
"precipitation": weather.precipitation,
|
"precipitation": weather.precipitation,
|
||||||
"pressure": weather.pressure,
|
"pressure": weather.pressure,
|
||||||
"region": weather.region,
|
"region": weather.region,
|
||||||
"ultraviolet": weather.ultraviolet,
|
"ultraviolet": str(weather.ultraviolet),
|
||||||
"visibility": weather.visibility,
|
"visibility": weather.visibility,
|
||||||
"wind_direction": weather.wind_direction,
|
"wind_direction": str(weather.wind_direction),
|
||||||
"wind_speed": weather.wind_speed,
|
"wind_speed": weather.wind_speed,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue