@karsten13 i thought that as well but it didn’t change anything
Read the statement by Michael Teeuw here.
Posts
-
RE: Wifi connection drops and doesn't get restablished
-
Wifi connection drops and doesn't get restablished
If I boot my pi 4 4gb and just let it sit in the home screen. No Magic Mirror. It works fine. And network connection is stable. When I start Magic Mirror and look at the logs everything seems fine. Except some DNS name resolve issue from MMM-GoogleAssistant by bugsonet. But I am pretty sure thats unrelated. Anyways after a couple minutes my ssh connection drops and I get a notification on the top of the display saying that the internet connection was lost. Everything continues to run normally but no information gets updated. (Weather, rainmap, etc) I don’t have any relevant logs because I do not know what too log or how.
I am using networkManager over the default system dhcpcd because I had a whole bunch of different wifi issues with that system. I am asking for help on where too start too trouble shoot this issue. Any help is greatly appreciated. Could it be some kind of overheating. But if that’s the case, why haven’t other people had the same issue.
-
RE: ChatGpt intergration
@sdetweil ok i tried with that module and all i changed was in the googleassistant module it should have sent the payload of everything after “chatgpt” but when i say somthing like chatgpt say banana it does send the notification and the notification gets recieved and the module displays an answer but this is what it looks like:
as you see it says undefined and just answer a random question. this is my recipe:var recipe = { transcriptionHooks: { "ASK_QUESTION": { pattern: "chatgpt (.*)", command: "ASK_QUESTION" } }, commands: { "ASK_QUESTION": { notificationExec: { notification: "OPENAI_REQUEST", payload: (params) => { console.log("Debug: params received", params); return { question: params[1] } } } }
the weird thing is is that if im not mistaken in the logs of magicmirror it should say params recieved and then params after but it doesnt. why do you think the module says undefined now but in my module the notification gets recieved and the params after “chatgpt” get sent over with it? but in this module it shows up as undefined?
-
RE: ChatGpt intergration
@sdetweil yes i just saw that i will try too use that module and from there send a notifications with the payload of the googleassistant recipie
-
RE: ChatGpt intergration
@sdetweil so sorry for not being active. i have been on vacation and working on another project. you are right it doesnt seem too give any answer but it does use the “tokens” and that would mean it DOES somhow make an answer but it doesnt get displayed or somthing. i have added some debug logs and now i dont get the maximum callstack error anymore but with the added debug code i get this error when asking “chatgpt say banana”
0|MagicMirror | [05.03.2023 21:17.49.185] [LOG] Received ASK_QUESTION notification with payload: say banana 0|MagicMirror | [05.03.2023 21:17.49.259] [LOG] [GATEWAY] [192.168.1.223][GET] /getEXTStatus 0|MagicMirror | [05.03.2023 21:17.50.205] [LOG] [GATEWAY] [192.168.1.223][GET] /getEXTStatus 0|MagicMirror | [05.03.2023 21:17.50.502] [LOG] Received response from API: { 0|MagicMirror | status: 200, 0|MagicMirror | statusText: 'OK', 0|MagicMirror | headers: { 0|MagicMirror | date: 'Sun, 05 Mar 2023 20:17:50 GMT', 0|MagicMirror | 'content-type': 'application/json', 0|MagicMirror | 'content-length': '274', 0|MagicMirror | connection: 'close', 0|MagicMirror | 'access-control-allow-origin': '*', 0|MagicMirror | 'cache-control': 'no-cache, must-revalidate', 0|MagicMirror | 'openai-model': 'text-davinci-003', 0|MagicMirror | 'openai-organization': 'user-pya0hjyay0pss3nexvnux3ro', 0|MagicMirror | 'openai-processing-ms': '688', 0|MagicMirror | 'openai-version': '2020-10-01', 0|MagicMirror | 'strict-transport-security': 'max-age=15724800; includeSubDomains', 0|MagicMirror | 'x-request-id': 'a3e862a0ca38b3ec23197aa8ece458b9' 0|MagicMirror | }, 0|MagicMirror | config: { 0|MagicMirror | transitional: { 0|MagicMirror | silentJSONParsing: true, 0|MagicMirror | forcedJSONParsing: true, 0|MagicMirror | clarifyTimeoutError: false 0|MagicMirror | }, 0|MagicMirror | adapter: [Function: httpAdapter], 0|MagicMirror | transformRequest: [ [Function: transformRequest] ], 0|MagicMirror | transformResponse: [ [Function: transformResponse] ], 0|MagicMirror | timeout: 0, 0|MagicMirror | xsrfCookieName: 'XSRF-TOKEN', 0|MagicMirror | xsrfHeaderName: 'X-XSRF-TOKEN', 0|MagicMirror | maxContentLength: -1, 0|MagicMirror | maxBodyLength: -1, 0|MagicMirror | validateStatus: [Function: validateStatus], 0|MagicMirror | headers: { 0|MagicMirror | Accept: 'application/json, text/plain, */*', 0|MagicMirror | 'Content-Type': 'application/json', 0|MagicMirror | 'User-Agent': 'OpenAI/NodeJS/3.1.0', 0|MagicMirror | Authorization: 'Bearer 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', 0|MagicMirror | 'Content-Length': 68 0|MagicMirror | }, 0|MagicMirror | method: 'post', 0|MagicMirror | data: '{"model":"text-davinci-003","prompt":"say banana","temperature":0.7}', 0|MagicMirror | url: 'https://api.openai.com/v1/completions' 0|MagicMirror | }, 0|MagicMirror | request: <ref *1> ClientRequest { 0|MagicMirror | _events: [Object: null prototype] { 0|MagicMirror | abort: [Function (anonymous)], 0|MagicMirror | aborted: [Function (anonymous)], 0|MagicMirror | connect: [Function (anonymous)], 0|MagicMirror | error: [Function (anonymous)], 0|MagicMirror | socket: [Function (anonymous)], 0|MagicMirror | timeout: [Function (anonymous)], 0|MagicMirror | prefinish: [Function: requestOnPrefinish] 0|MagicMirror | }, 0|MagicMirror | _eventsCount: 7, 0|MagicMirror | _maxListeners: undefined, 0|MagicMirror | outputData: [], 0|MagicMirror | outputSize: 0, 0|MagicMirror | writable: true, 0|MagicMirror | destroyed: false, 0|MagicMirror | _last: true, 0|MagicMirror | chunkedEncoding: false, 0|MagicMirror | shouldKeepAlive: false, 0|MagicMirror | maxRequestsOnConnectionReached: false, 0|MagicMirror | _defaultKeepAlive: true, 0|MagicMirror | useChunkedEncodingByDefault: true, 0|MagicMirror | sendDate: false, 0|MagicMirror | _removedConnection: false, 0|MagicMirror | _removedContLen: false, 0|MagicMirror | _removedTE: false, 0|MagicMirror | _contentLength: null, 0|MagicMirror | _hasBody: true, 0|MagicMirror | _trailer: '', 0|MagicMirror | finished: true, 0|MagicMirror | _headerSent: true, 0|MagicMirror | _closed: false, 0|MagicMirror | socket: TLSSocket { 0|MagicMirror | _tlsOptions: [Object], 0|MagicMirror | _secureEstablished: true, 0|MagicMirror | _securePending: false, 0|MagicMirror | _newSessionPending: false, 0|MagicMirror | _controlReleased: true, 0|MagicMirror | secureConnecting: false, 0|MagicMirror | _SNICallback: null, 0|MagicMirror | servername: 'api.openai.com', 0|MagicMirror | alpnProtocol: false, 0|MagicMirror | authorized: true, 0|MagicMirror | authorizationError: null, 0|MagicMirror | encrypted: true, 0|MagicMirror | _events: [Object: null prototype], 0|MagicMirror | _eventsCount: 10, 0|MagicMirror | connecting: false, 0|MagicMirror | _hadError: false, 0|MagicMirror | _parent: null, 0|MagicMirror | _host: 'api.openai.com', 0|MagicMirror | _readableState: [ReadableState], 0|MagicMirror | _maxListeners: undefined, 0|MagicMirror | _writableState: [WritableState], 0|MagicMirror | allowHalfOpen: false, 0|MagicMirror | _sockname: null, 0|MagicMirror | _pendingData: null, 0|MagicMirror | _pendingEncoding: '', 0|MagicMirror | server: undefined, 0|MagicMirror | _server: null, 0|MagicMirror | ssl: [TLSWrap], 0|MagicMirror | _requestCert: true, 0|MagicMirror | _rejectUnauthorized: true, 0|MagicMirror | parser: null, 0|MagicMirror | _httpMessage: [Circular *1], 0|MagicMirror | [Symbol(res)]: [TLSWrap], 0|MagicMirror | [Symbol(verified)]: true, 0|MagicMirror | [Symbol(pendingSession)]: null, 0|MagicMirror | [Symbol(async_id_symbol)]: 31736, 0|MagicMirror | [Symbol(kHandle)]: [TLSWrap], 0|MagicMirror | [Symbol(lastWriteQueueSize)]: 0, 0|MagicMirror | [Symbol(timeout)]: null, 0|MagicMirror | [Symbol(kBuffer)]: null, 0|MagicMirror | [Symbol(kBufferCb)]: null, 0|MagicMirror | [Symbol(kBufferGen)]: null, 0|MagicMirror | [Symbol(kCapture)]: false, 0|MagicMirror | [Symbol(kSetNoDelay)]: false, 0|MagicMirror | [Symbol(kSetKeepAlive)]: true, 0|MagicMirror | [Symbol(kSetKeepAliveInitialDelay)]: 60, 0|MagicMirror | [Symbol(kBytesRead)]: 0, 0|MagicMirror | [Symbol(kBytesWritten)]: 0, 0|MagicMirror | [Symbol(connect-options)]: [Object], 0|MagicMirror | [Symbol(RequestTimeout)]: undefined 0|MagicMirror | }, 0|MagicMirror | _header: 'POST /v1/completions HTTP/1.1\r\n' + 0|MagicMirror | 'Accept: application/json, text/plain, */*\r\n' + 0|MagicMirror | 'Content-Type: application/json\r\n' + 0|MagicMirror | 'User-Agent: OpenAI/NodeJS/3.1.0\r\n' + 0|MagicMirror | 'Authorization: Bearer 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\r\n' + 0|MagicMirror | 'Content-Length: 68\r\n' + 0|MagicMirror | 'Host: api.openai.com\r\n' + 0|MagicMirror | 'Connection: close\r\n' + 0|MagicMirror | '\r\n', 0|MagicMirror | _keepAliveTimeout: 0, 0|MagicMirror | _onPendingData: [Function: nop], 0|MagicMirror | agent: Agent { 0|MagicMirror | _events: [Object: null prototype], 0|MagicMirror | _eventsCount: 2, 0|MagicMirror | _maxListeners: undefined, 0|MagicMirror | defaultPort: 443, 0|MagicMirror | protocol: 'https:', 0|MagicMirror | options: [Object: null prototype], 0|MagicMirror | requests: [Object: null prototype] {}, 0|MagicMirror | sockets: [Object: null prototype], 0|MagicMirror | freeSockets: [Object: null prototype] {}, 0|MagicMirror | keepAliveMsecs: 1000, 0|MagicMirror | keepAlive: false, 0|MagicMirror | maxSockets: Infinity, 0|MagicMirror | maxFreeSockets: 256, 0|MagicMirror | scheduling: 'lifo', 0|MagicMirror | maxTotalSockets: Infinity, 0|MagicMirror | totalSocketCount: 1, 0|MagicMirror | maxCachedSessions: 100, 0|MagicMirror | _sessionCache: [Object], 0|MagicMirror | [Symbol(kCapture)]: false 0|MagicMirror | }, 0|MagicMirror | socketPath: undefined, 0|MagicMirror | method: 'POST', 0|MagicMirror | maxHeaderSize: undefined, 0|MagicMirror | insecureHTTPParser: undefined, 0|MagicMirror | path: '/v1/completions', 0|MagicMirror | _ended: true, 0|MagicMirror | res: IncomingMessage { 0|MagicMirror | _readableState: [ReadableState], 0|MagicMirror | _events: [Object: null prototype], 0|MagicMirror | _eventsCount: 4, 0|MagicMirror | _maxListeners: undefined, 0|MagicMirror | socket: [TLSSocket], 0|MagicMirror | httpVersionMajor: 1, 0|MagicMirror | httpVersionMinor: 1, 0|MagicMirror | httpVersion: '1.1', 0|MagicMirror | complete: true, 0|MagicMirror | rawHeaders: [Array], 0|MagicMirror | rawTrailers: [], 0|MagicMirror | aborted: false, 0|MagicMirror | upgrade: false, 0|MagicMirror | url: '', 0|MagicMirror | method: null, 0|MagicMirror | statusCode: 200, 0|MagicMirror | statusMessage: 'OK', 0|MagicMirror | client: [TLSSocket], 0|MagicMirror | _consuming: false, 0|MagicMirror | _dumped: false, 0|MagicMirror | req: [Circular *1], 0|MagicMirror | responseUrl: 'https://api.openai.com/v1/completions', 0|MagicMirror | redirects: [], 0|MagicMirror | [Symbol(kCapture)]: false, 0|MagicMirror | [Symbol(kHeaders)]: [Object], 0|MagicMirror | [Symbol(kHeadersCount)]: 24, 0|MagicMirror | [Symbol(kTrailers)]: null, 0|MagicMirror | [Symbol(kTrailersCount)]: 0, 0|MagicMirror | [Symbol(RequestTimeout)]: undefined 0|MagicMirror | }, 0|MagicMirror | aborted: false, 0|MagicMirror | timeoutCb: null, 0|MagicMirror | upgradeOrConnect: false, 0|MagicMirror | parser: null, 0|MagicMirror | maxHeadersCount: null, 0|MagicMirror | reusedSocket: false, 0|MagicMirror | host: 'api.openai.com', 0|MagicMirror | protocol: 'https:', 0|MagicMirror | _redirectable: Writable { 0|MagicMirror | _writableState: [WritableState], 0|MagicMirror | _events: [Object: null prototype], 0|MagicMirror | _eventsCount: 3, 0|MagicMirror | _maxListeners: undefined, 0|MagicMirror | _options: [Object], 0|MagicMirror | _ended: true, 0|MagicMirror | _ending: true, 0|MagicMirror | _redirectCount: 0, 0|MagicMirror | _redirects: [], 0|MagicMirror | _requestBodyLength: 68, 0|MagicMirror | _requestBodyBuffers: [], 0|MagicMirror | _onNativeResponse: [Function (anonymous)], 0|MagicMirror | _currentRequest: [Circular *1], 0|MagicMirror | _currentUrl: 'https://api.openai.com/v1/completions', 0|MagicMirror | [Symbol(kCapture)]: false 0|MagicMirror | }, 0|MagicMirror | [Symbol(kCapture)]: false, 0|MagicMirror | [Symbol(kNeedDrain)]: false, 0|MagicMirror | [Symbol(corked)]: 0, 0|MagicMirror | [Symbol(kOutHeaders)]: [Object: null prototype] { 0|MagicMirror | accept: [Array], 0|MagicMirror | 'content-type': [Array], 0|MagicMirror | 'user-agent': [Array], 0|MagicMirror | authorization: [Array], 0|MagicMirror | 'content-length': [Array], 0|MagicMirror | host: [Array] 0|MagicMirror | }, 0|MagicMirror | [Symbol(kUniqueHeaders)]: null 0|MagicMirror | }, 0|MagicMirror | data: { 0|MagicMirror | id: 'cmpl-6qp5h4r3TvsNZRhmVk1dwPWCmIyiX', 0|MagicMirror | object: 'text_completion', 0|MagicMirror | created: 1678047469, 0|MagicMirror | model: 'text-davinci-003', 0|MagicMirror | choices: [ [Object] ], 0|MagicMirror | usage: { prompt_tokens: 2, completion_tokens: 6, total_tokens: 8 } 0|MagicMirror | } 0|MagicMirror | } 0|MagicMirror | [05.03.2023 21:17.50.503] [LOG] Error in getResponse: Empty response from GPT-3 API
i get error in getresponse because the response from the api is empty my updated code is as follows:
chatgpt.js:
Module.register("chatgpt", { defaults: { question: "What is the weather like today?", }, start: function () { console.log("Starting module: " + this.name); this.question = this.config.question; }, notificationReceived: function (notification, payload) { if (notification === "ASK_QUESTION") { this.question = payload.question; console.log("Received question: " + this.question); this.sendSocketNotification("ASK_QUESTION", this.question); } }, socketNotificationReceived: function (notification, payload) { console.log("Payload received: ", payload); if(notification === "RESPONSE") { this.answer = payload.answer; console.log("Received answer: " + this.answer); console.log("Calling updateDom"); this.updateDom(); } else { console.log("Unhandled notification: " + notification); console.log("Payload: " + payload); } }, getDom: function () { var wrapper = document.createElement("div"); var question = document.createElement("div"); var answer = document.createElement("div"); if (this.answer) { answer.innerHTML = this.answer; } else { answer.innerHTML = "Ask me something"; } question.innerHTML = this.question; wrapper.appendChild(question); wrapper.appendChild(answer); return wrapper; }, });
And here is my node_helper.js file:
const NodeHelper = require("node_helper"); const { Configuration, OpenAIApi } = require("openai"); module.exports = NodeHelper.create({ start: function () { console.log("Starting node helper for: " + this.name); this.configuration = new Configuration({ apiKey: "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", }); this.openai = new OpenAIApi(this.configuration); }, // Send a message to the chatGPT API and receive a response getResponse: function (prompt) { return new Promise(async (resolve, reject) => { try { const response = await this.openai.createCompletion({ model: "text-davinci-003", prompt: prompt, temperature: 0.7, }); console.log("Received response from API: ", response); if (response.choices && response.choices.length > 0) { var text = response.choices[0].text; resolve(text); } else { reject("Empty response from GPT-3 API"); } } catch (error) { console.log("Error in getResponse: ", error); reject(error); } }); }, // Handle socket notifications socketNotificationReceived: function (notification, payload) { if (notification === "ASK_QUESTION") { console.log("Received ASK_QUESTION notification with payload: ", payload); this.getResponse(payload) .then((response) => { // create a new object and update the answer property var responsePayload = { answer: response }; console.log("Sending RESPONSE notification with payload: ", responsePayload); this.sendSocketNotification("RESPONSE", responsePayload); }) .catch((error) => { console.log("Error in getResponse: ", error); }); } }, });
note in the node_helper where the error log empty api response is coming from. as i have said multiple times i would love some help if anyone knows how you could fix this issue as i am a beginner in coding. i am trying my best but some help on why this is happening would be great.
-
RE: ChatGpt intergration
@sdetweil hey. I’m sorry for not being able too answer but i have other stuff going on and a math test coming up. The text is sent over as a string and the module does recieved the string and gets a response from the API it is after that the issue is caused. I Google the error and people say that there is probably a loop in the code somewhere. I will try with the debug module when i have time. I really want too get this too work.
-
RE: ChatGpt intergration
@sdetweil ok hello. alot of things have happend in the last week. i have got somthing that should be working but i had too fix abunch of errors in the code. but for the last couple of days i have been stuck on this perticular error in my code:
0|MagicMirror | [25.01.2023 21:05.25.175] [LOG] Error in getResponse: RangeError: Maximum call stack size exceeded 0|MagicMirror | at isBinary (/home/pi/MagicMirror/node_modules/socket.io-parser/build/cjs/is-binary.js:22:18) 0|MagicMirror | at hasBinary (/home/pi/MagicMirror/node_modules/socket.io-parser/build/cjs/is-binary.js:40:9) 0|MagicMirror | at hasBinary (/home/pi/MagicMirror/node_modules/socket.io-parser/build/cjs/is-binary.js:49:63) 0|MagicMirror | at hasBinary (/home/pi/MagicMirror/node_modules/socket.io-parser/build/cjs/is-binary.js:49:63) 0|MagicMirror | at hasBinary (/home/pi/MagicMirror/node_modules/socket.io-parser/build/cjs/is-binary.js:49:63) 0|MagicMirror | at hasBinary (/home/pi/MagicMirror/node_modules/socket.io-parser/build/cjs/is-binary.js:49:63) 0|MagicMirror | at hasBinary (/home/pi/MagicMirror/node_modules/socket.io-parser/build/cjs/is-binary.js:49:63) 0|MagicMirror | at hasBinary (/home/pi/MagicMirror/node_modules/socket.io-parser/build/cjs/is-binary.js:49:63) 0|MagicMirror | at hasBinary (/home/pi/MagicMirror/node_modules/socket.io-parser/build/cjs/is-binary.js:49:63) 0|MagicMirror | at hasBinary (/home/pi/MagicMirror/node_modules/socket.io-parser/build/cjs/is-binary.js:49:63)
the internet says that it is probobally a part of the code calling itself but i just cant seem too find anything. it may be super clear what the issue is here but i really cant seem too find the cause of the error. help would be greatly apprecieted. here is my code:
chatgpt.js:
Module.register("chatgpt",{ defaults: { question: "What is the weather like today?", }, start: function() { console.log("Starting module: " + this.name); this.question = this.config.question; }, notificationReceived: function(notification, payload) { if(notification === "ASK_QUESTION") { this.question = payload.question; console.log("Received question: " + this.question); this.sendSocketNotification("ASK_QUESTION", this.question); } }, socketNotificationReceived: function(notification, payload) { if(notification === "RESPONSE") { this.answer = payload.answer; console.log("Received answer: " + this.answer); console.log("Calling updateDom"); this.updateDom(); } else { console.log("Unhandled notification: " + notification); console.log("Payload: " + payload); } }, getDom: function() { var wrapper = document.createElement("div"); var question = document.createElement("div"); var answer = document.createElement("div"); if (this.answer) { answer.innerHTML = this.answer; } else { answer.innerHTML = "Ask me something"; } question.innerHTML = this.question; wrapper.appendChild(question); wrapper.appendChild(answer); return wrapper; }, });
node_helper.js:
const NodeHelper = require("node_helper"); const { Configuration, OpenAIApi } = require("openai"); module.exports = NodeHelper.create({ start: function() { console.log("Starting node helper for: " + this.name); this.configuration = new Configuration({ apiKey: "XXXXXXXXXXXXXXXXXXXXXXXXXX", }); this.openai = new OpenAIApi(this.configuration); }, // Send a message to the chatGPT API and receive a response getResponse: function(prompt) { return new Promise(async (resolve, reject) => { try { const response = await this.openai.createCompletion({ model: "text-davinci-003", prompt: prompt, temperature: 0.7, }); console.log("Received response from API: ", response); resolve(response); } catch (error) { console.log("Error in getResponse: ", error); reject(error); } }); }, // Handle socket notifications socketNotificationReceived: function(notification, payload) { if (notification === "ASK_QUESTION") { console.log("Received ASK_QUESTION notification with payload: ", payload); this.getResponse(payload) .then((response) => { // create a new object and update the answer property var responsePayload = {answer: response}; console.log("Sending RESPONSE notification with payload: ", responsePayload); this.sendSocketNotification("RESPONSE", responsePayload); }) .catch((error) => { console.log("Error in getResponse: ", error); }); } }, });
the api call is being made and everything else is working but as soon as i say “jarvis chatgpt say banana” or any other input i get the error
-
RE: ChatGpt intergration
@sdetweil maybe i formulated it bad. i know how the recipie structure should look like and i can make simple recipies but having the notification only send everything after “chatgpt” that i have no idea how too do. as i said i am a beginner in coding and trying my best
-
RE: ChatGpt intergration
@sdetweil yea i guess but how in the world would you make it send just the phrase after chatgpt is said. in other words i have no idea how the recipie file should be coded
-
RE: ChatGpt intergration
@sdetweil how would you make the recipie part and what to have as a command like how would you tell the recipie too send all text after the phrase chatgpt in the notification as question. and recieving that in the chatgpt.js