-
Notifications
You must be signed in to change notification settings - Fork 40
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Trouble importing meshtastic with node #58
Comments
I'm not an expert on this, but it looks like the generated files are not adding the .js extension to the relative imports. |
running node with the option --experimental-specifier-resolution=node seems to be a quick fix for this issue. I suppose in the long run it would be best for the protobuf-ts code generator be modified to generate the proper extensions. |
Yeah, as you've observed, this is the undesirable behavior exhibited by protobuf-ts, I've opened an issue about it before but the developer did not want to invest time into the feature, he was open to PR's though. |
How does the web client get around this issue when consuming this package? I'm trying to import the JS library in Electron and I'm getting the same error. To my knowledge I'm not able to perform the |
There's an open PR, I might fork the project and sort this out tonight |
Sounds good! Happy to help with this if at all possible, this issue is a current blocker for me |
I'm contemplating switching to https://pbkit.dev/ a much more maintainable project, Although I prefer the code generated by protobuf-ts, the project is in shambles and not moving to ESM |
Interesting, I'll take a look at that. What kind of refactoring would this require? |
Also looks like this uses Deno. Would there be the possibility for issues running this on Node-based projects? Edit: the maintainers claim it runs in Node.js or browser here |
Yeah, so the pbkit project is made for deno but: |
Issue that I'm talking with the devs about right now is distributing the |
Interesting, is there no package for the |
Yeah that's correct, so it's not a massive issue, it's just nice to have it work out of the box for devs |
There will be a few things that are different, string union's instead of enums, imports will be seperated by message not file anymore and a few more |
Gotcha, so there will have to be some internal rewrites in that case. Would this require API changes and/or a breaking version change? |
The meshtastic.js version will likely be breaking for apps, but the api will be very similar. as for interacting with devices, no change there. |
Sounds good! Happy to help out with the refactor if this ends up being the best way to move forward |
Update on api: Current: Protobuf.AdminMessage.toBinary({
payloadVariant: {
confirmSetRadio: true,
oneofKind: "confirmSetRadio"
}
}); New: AdminMessage.encodeBinary({
payloadVariant: {
field: 'confirmSetRadio',
value: true
}
}); |
Is there a public branch for the potential changes? |
Not yet, I'll push some wip changes tonight |
@ajmcquilkin @gtnoble please check latest release |
Seems to be working for me! Just ran tests in a CRA and a Node.js app and both seem to be working. On a side note, is |
Yeah, need to dig a little deeper into the reasons behind requiring Talib, not sure right now |
Update to this, I've done away with |
I have installed meshtasticjs using npm and there were no errors.
When I tried to import in node v16.17.0 using this line:
import { IHTTPConnection } from "@meshtastic/meshtasticjs";
I get an error:
Error [ERR_MODULE_NOT_FOUND]: Cannot find module '/home/gtnoble/Documents/Projects/meshtastic-test/node_modules/@meshtastic/meshtasticjs/dist/generated/module_config' imported from /home/gtnoble/Documents/Projects/meshtastic-test/node_modules/@meshtastic/meshtasticjs/dist/generated/mesh.js at new NodeError (node:internal/errors:387:5) at finalizeResolution (node:internal/modules/esm/resolve:429:11) at moduleResolve (node:internal/modules/esm/resolve:1006:10) at defaultResolve (node:internal/modules/esm/resolve:1214:11) at nextResolve (node:internal/modules/esm/loader:165:28) at ESMLoader.resolve (node:internal/modules/esm/loader:844:30) at ESMLoader.getModuleJob (node:internal/modules/esm/loader:431:18) at ModuleWrap.<anonymous> (node:internal/modules/esm/module_job:76:40) at link (node:internal/modules/esm/module_job:75:36) { code: 'ERR_MODULE_NOT_FOUND' }
This could be a mistake on my part, but I thought I would reach out in case it was a deeper problem.
The text was updated successfully, but these errors were encountered: