Skip to content
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

Custom wasm file not loading correctly in Nuxt apps #428

Open
joaomarcelofm opened this issue Apr 16, 2024 · 11 comments
Open

Custom wasm file not loading correctly in Nuxt apps #428

joaomarcelofm opened this issue Apr 16, 2024 · 11 comments

Comments

@joaomarcelofm
Copy link

joaomarcelofm commented Apr 16, 2024

Describe the bug

Based on the sample code provided in this issue #354 by @Sec-ant, providing the URL for a self-hosted file should work.
I've added the wasm file as a static file of a Nuxt project as our CSP rules are pretty strict.

The camera is active, but the reader fails to execute.
The implementation is what's provided in the minimal reproduction setup below. Is that incorrect?

To Reproduce
https://stackblitz.com/edit/github-ptbbrj?file=app.vue

Screenshots

Screenshot 2024-04-16 at 19 27 00

Desktop (please complete the following information):

  • OS: MacOS
  • Browser: Chrome
  • Version: 123.0.6312.107
@Sec-ant
Copy link
Contributor

Sec-ant commented Apr 16, 2024

Looks like there's a mismatch between the version of the WASM binary and the js code.

Each version of zxing-wasm (an indirect dependency of this lib) has an associated WASM binary file that is incompatible with other versions. You should make sure you use the correct version of the WASM binary when you want to serve it yourself.

The DX is not very good for users who want to host their WASM files themselves, I'm open to all kinds of suggestions to make this less an issue.

@dargmuesli
Copy link
Contributor

Ideally, a user of vue-qrcode-reader should be able to import zxing_reader.wasm from vue-qrcode-reader, I'd say. That way the correct version is used at all times.

@joaomarcelofm
Copy link
Author

joaomarcelofm commented Apr 16, 2024

Thanks both for the quick reply, I really appreciate it!

@Sec-ant suggestion fixed it! I really thought I had to correct the version 🙈
I'm not sure when it changed, though.

But I agree with @dargmuesli, it'd be good to have the file imported along with the lib so there's no mismatch. This setup creates some implicit knowledge in the team, and even if it's documented in code, someone might update the package and not realize they are breaking things.

@dargmuesli
Copy link
Contributor

Should we maybe keep this issue open to track adding an import for zxing_reader.wasm to vue-qrcode-reader?

@joaomarcelofm
Copy link
Author

Sure, I closed it as it wasn't a bug but feel free to reopen it 👍

From what I read in the original issue, one thing about this setup is that the reason to not include the wasm file in the lib is its size, which is fair. However, the end user will have to download it eventually, be it from the bundle or the CDN.

Would it be possible to include it in the package but defer the import so it doesn't take up the initial bundle weight and block critical resources? In our implementation, we already have QrcodeStream as a client-only component, so it'd be okay to have everything else only imported at that point. I think that shouldn't be a requirement, though. I think folks might need it for offline readers and whatnot, but perhaps that's not a main use case.

@gruhn gruhn reopened this Apr 17, 2024
Copy link

This issue has been marked as stale. If there is no further activity it will be closed.

@dargmuesli
Copy link
Contributor

@gruhn could we mark this tracking issue in a way that it isn't closed automatically?

@gruhn
Copy link
Owner

gruhn commented Jun 17, 2024

Not sure. I can remove the label but I think it will be re-added in awhile.

@dargmuesli
Copy link
Contributor

On the documentation page for the action you've added that manages stale items, there are various configuration options on how to exempt items from the automation: https://github.com/actions/stale?tab=readme-ov-file

For example, the exempt-issue-labels or exempt-issue-assignees option could be configured.

gruhn added a commit that referenced this issue Jun 23, 2024
gruhn added a commit that referenced this issue Jun 23, 2024
@gruhn
Copy link
Owner

gruhn commented Oct 19, 2024

Just discovered this stage 3 ESM proposal, which might help streamline WASM imports.

@Sec-ant
Copy link
Contributor

Sec-ant commented Dec 29, 2024

FYI I'm preparing a v2 release of zxing-wasm. I've updated its README documentation with more information on how to serve the .wasm file in a custom way: https://github.com/Sec-ant/zxing-wasm?tab=readme-ov-file#configuring-wasm-serving. Any suggestions on the writing of this part is welcome.

I also fixed the types of these subpath exports:

  • zxing-wasm/full/zxing_full.wasm
  • zxing-wasm/reader/zxing_reader.wasm
  • zxing-wasm/writer/zxing_writer.wasm.

[email protected] package now passes all the subpath exports checks in arethetypeswrong. However, these are only type fixes to satisfy TypeScript. It is currently a feature provided by the runtime or bundle tool (like esbuild/vite) to support direct wasm importing as a string type path, or an instantiated module. For now, you should always import the wasm as a string type path and use prepareZXingModule to instantiate it.

It should be noted that v2 will use a different API prepareZXingModule, and I'll wait for the official v2.3.0 release of zxing-cpp before making an official v2 release of zxing-wasm. After that, a new release of barcode-detector will follow (I haven't decided if I should update the major version of barcode-detector yet). Please stay tuned :)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

4 participants