NEWS
js-controller 3.2 jetzt im STABLE!
-
Hallo,
gerade wollte ich den iobroker updaten nach dieser Anleitung, aber bei mir kommt nachiobroker update
diese Fehlermeldung
internal/modules/cjs/loader.js:818 throw err; ^ Error: Cannot find module 'require-main-filename' Require stack: - /opt/iobroker/node_modules/iobroker.js-controller/node_modules/yargs/build/lib/yargs.js - /opt/iobroker/node_modules/iobroker.js-controller/node_modules/yargs/yargs.js - /opt/iobroker/node_modules/iobroker.js-controller/node_modules/yargs/index.js - /opt/iobroker/node_modules/iobroker.js-controller/lib/setup.js - /opt/iobroker/node_modules/iobroker.js-controller/iobroker.js at Function.Module._resolveFilename (internal/modules/cjs/loader.js:815:15) at Function.Module._load (internal/modules/cjs/loader.js:667:27) at Module.require (internal/modules/cjs/loader.js:887:19) at require (internal/modules/cjs/helpers.js:74:18) at Object.<anonymous> (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/yargs/build/lib/yargs.js:22:29) at Module._compile (internal/modules/cjs/loader.js:999:30) at Object.Module._extensions..js (internal/modules/cjs/loader.js:1027:10) at Module.load (internal/modules/cjs/loader.js:863:32) at Function.Module._load (internal/modules/cjs/loader.js:708:14) at Module.require (internal/modules/cjs/loader.js:887:19) { code: 'MODULE_NOT_FOUND', requireStack: [ '/opt/iobroker/node_modules/iobroker.js-controller/node_modules/yargs/build/lib/yargs.js', '/opt/iobroker/node_modules/iobroker.js-controller/node_modules/yargs/yargs.js', '/opt/iobroker/node_modules/iobroker.js-controller/node_modules/yargs/index.js', '/opt/iobroker/node_modules/iobroker.js-controller/lib/setup.js', '/opt/iobroker/node_modules/iobroker.js-controller/iobroker.js' ] }
Was mache ich falsch?
-
@mailtimzenker-de erstmal
iobroker fix
Dann nochmal testen
-
Ich denke das wird nicht soo viel bringen. Da scheint irgendwie ein File verschwunden zu sein ... am besten installiere den controller manuell drber wie oben im Initialpost geschrieben ggf die "bisherige alte Version"
-
@apollon77
Das hat leider auch nicht zum Erfolg geführt:pi@raspberrypi:~ $ iobroker stop pi@raspberrypi:~ $ npm install iobroker.js-controller@2.2.8 > iobroker.js-controller@2.2.8 preinstall /home/pi/node_modules/iobroker.js-controller > node lib/preinstallCheck.js NPM version: 6.14.11 > iobroker.js-controller@2.2.8 install /home/pi/node_modules/iobroker.js-controller > node iobroker.js setup first npm WARN saveError ENOENT: no such file or directory, open '/home/pi/package.json' npm WARN enoent ENOENT: no such file or directory, open '/home/pi/package.json' npm WARN pi No description npm WARN pi No repository field. npm WARN pi No README data npm WARN pi No license field. npm WARN optional SKIPPING OPTIONAL DEPENDENCY: fsevents@2.3.2 (node_modules/fsevents): npm WARN notsup SKIPPING OPTIONAL DEPENDENCY: Unsupported platform for fsevents@2.3.2: wanted {"os":"darwin","arch":"any"} (current: {"os":"linux","arch":"arm"}) + iobroker.js-controller@2.2.8 updated 1 package and audited 427 packages in 10.278s 11 packages are looking for funding run `npm fund` for details found 4 high severity vulnerabilities run `npm audit fix` to fix them, or `npm audit` for details
-
@wendy2702
Das hatte ich in meiner Verzweiflung auch schon ausprobiert. Und jetzt sogar nochmal, aber ohne Erfolg. -
@schnipsel71 sagte in js-controller 3.2 jetzt im STABLE!:
npm install iobroker.js-controller@2.2.8
bist im falschen Ordner.
cd /opt/iobroker
Willst du wirklich so eine alte JS-Controller Version installieren?
-
@apollon77 Dachte der fixer würde auch die benötigten Module glatt ziehen.
-
@wendy2702 Nope. Der Fixer bereitet nur die Grundlage. An Npm oder nodejs kram macht der gar nichts
-
@schnipsel71 Kannst auch versuchen das Modul nach zu installieren
entweder in der Javascript Instanz eintragen oder
cd /opt/iobroker npm install require-main-filename
-
@wendy2702
Stimmt. Vielen Dank.
Jetzt hat es funktioniert! -
@apollon77
Vielen Dank.
Das hat funktioniert! -
@wendy2702 Sowas an sich "Ungern" weil npm ggf manuell installierte Pakete anders behandelt als die die aus deps kamen auch für "später".
-
@apollon77 Du meinst das manuelle nach installieren?
Hm.... wenn ich aber doch zusätzlich benötigte module über den Javascript eintrage macht er auch nichts anderes und die sind dann voll verfügbar.
-
@wendy2702 Das Modul landet so aber nicht im dependency tree sondern 'daneben'.
-
@thomas-braun Wenn ich wie installiere?
Über "npm install" oder als zusätzliches Modul in der Javascript instanz oder bei beiden?
-
@wendy2702 Beim npm install in dem Verzeichnis in dem man gerade steht. Beim Javascript Adapter weiß ich gerade nicht wo die landen. Vermutlich aber auch nicht in der ersten Ebene.
Und das Handling von manuell nachinstallierten Modulen ist u. U. anders.
-
@thomas-braun Hm,
musste letztlich Serialport neu installieren. Jetzt sieht das auf einem meiner PI's so aus:
pi@pi-iobroker:/opt/iobroker $ npm list serialport iobroker.core@0.1.0 /opt/iobroker ├─┬ iobroker.modbus@3.2.4 │ └── serialport@9.0.6 ├─┬ iobroker.smartmeter@3.2.0 │ ├── serialport@9.0.6 │ └─┬ smartmeter-obis@2.3.0 │ └── serialport@9.0.6 deduped └── serialport@9.0.6
Steht doch drin oder übersehe ich was?
-
@wendy2702
Das Modul in Zeile 9 ist wohl nicht notwendig. -
@thomas-braun OK.
-
@wendy2702
Bei mir ist jedenfalls jedes serialport-Modul unterhalb des übergeordneten Moduls:pi@raspberrypi:/opt/iobroker $ npm list serialport iobroker.inst@2.0.3 /opt/iobroker └─┬ iobroker.zigbee@1.4.4 ├─┬ zigbee-herdsman@0.13.70 │ └── serialport@9.0.6 └─┬ zigbee-herdsman-converters@14.0.57 └─┬ zigbee-herdsman@0.13.68 └── serialport@9.0.6