app2.js - cannot find module
unclej84 opened this issue · 13 comments
Hi,
I tried the current version of app2.js today and got following error in console:
`[EcovacsMQTT_JSON] callEcovacsDeviceAPI failed for cmd getMapSubSet: Error: Cannot find module '../build/Release/canvas.node'
Require stack:
- /usr/src/dev/ecovacs-deebot.js/node_modules/canvas/lib/bindings.js
- /usr/src/dev/ecovacs-deebot.js/node_modules/canvas/lib/canvas.js
- /usr/src/dev/ecovacs-deebot.js/node_modules/canvas/index.js
- /usr/src/dev/ecovacs-deebot.js/library/mapTemplate.js
- /usr/src/dev/ecovacs-deebot.js/library/vacBot_950type.js
- /usr/src/dev/ecovacs-deebot.js/index.js
- /usr/src/dev/ecovacs-deebot.js/example/app2.js`
Tested on node-red docker container. Seems no python is available to build the package. Same issue seems to be on RedMatic installation
Installation for canvas on debian based systems (e.g. RaspberryOS, Debian, Ubuntu):
apt install build-essential libcairo2-dev libpango1.0-dev libjpeg-dev libgif-dev librsvg2-dev libpixman-1-dev
Installation for canvas on alpine based systems (e.g. Node-RED docker container):
apk add --no-cache build-base g++ cairo-dev jpeg-dev pango-dev giflib-dev
Installation for canvas on debian based systems (e.g. RaspberryOS, Debian, Ubuntu):
apt install build-essential libcairo2-dev libpango1.0-dev libjpeg-dev libgif-dev librsvg2-dev libpixman-1-dev
Installation for canvas on alpine based systems (e.g. Node-RED docker container):
apk add --no-cache build-base g++ cairo-dev jpeg-dev pango-dev giflib-dev
Did this fix the problem? I was just about to answer you 😉
This error is gone after adding the dependencies - issue was that there is no pre-build binary for the platform canvas so it had to be build. Therefor these packages were needed. So the app2.js was running afterwards.
I am still searching for a solution for aarch6 based system (RaspberryMatic).
Canvas is an optional dependency. Currently it's only necessary for DeebotPositionCurrentSpotAreaID
event.
Are you sure? Before I did not get any feedback for GetSpotAreaInfo
but after it works like a charme
I have installed canvas on all of my systems so I can not check this right now, but I just made a commit where I removed GetMaps
cmd in app2.js from the interval. This might solve a few of your current problems 😉
Are you sure? ...
I just uninstalled canvas one of my systems and it still works properly (OZMO 920)
Maybe I did not describe it correct and the issue is wrong here.
The app2.js receives a response with the Spot Area Info and then throws the error above. [app2.js] MapDataObject
and [VacBot] *** MapSpotAreaInfo
are never logged but I get [EcovacsMQTT_JSON] handleCommand() command getMapSubSet received event:
for the [VacBot] action: GetSpotAreaInfo
request.
When having installed the packages above on the fresh image and logging again I get [app2.js] MapDataObject
shortly after start.
Maybe I am too stupid to test but that is what I get.
And as the app2.js output is not triggered, the same result I get with the node-red-package - no response with MapDataObject for GetMaps or MapSpotAreaInfo for GetSpotAreaInfo.
I it would help, I can provide the captured logs of both situations
These are the steps I made:
mkdir node-red-dev && cd node-red-dev/ && git clone https://github.com/mrbungle64/ecovacs-deebot.js.git
docker run -d -p 1880:1880 -v node_red_data:/data -v /home/<username>/node-red-dev:/usr/src/dev --name mynodered nodered/node-red:latest-12
[~/node-red-dev
contains the git clone of the github repo]docker exec -it mynodered /bin/bash
cd /usr/src/dev/ecovacs-deebot.js/
npm install
cd example
NODE_ENV=dev node app2.js > log.txt
for the second test with packages installed I added these steps after 1.:
docker exec -it --user=root mynodered /bin/bash
apk add --no-cache build-base g++ cairo-dev jpeg-dev pango-dev giflib-dev
exit
- continued with 2. from above
Please send me the ouptut of log.txt via mail.
I'll have a look at it later.
Confirmed - I am too stupid to test
!! As I used a mounted folder all the time there was a node_modules
folder existing. Tested without the mount and doing the git clone directly inside the container to /tmp it worked and I got the output of [app2.js] MapDataObject
I am so sorry for the confusion - I need to prepare my testing env more carefully.
So I guess we can close this.
So I guess we can close this.
ok, I will put the instructions for alpine based systems in the wiki
Installation for canvas on alpine based systems (e.g. Node-RED docker container):
apk add --no-cache build-base g++ cairo-dev jpeg-dev pango-dev giflib-dev