-
Notifications
You must be signed in to change notification settings - Fork 550
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
Move to using common container for building WASM #3714
Comments
Why do we need to use your wasm-builder image? |
I'm +1 but the image needs to be hosted in the org. |
absolutely. I would move mhdawson/wasm-builder to nodejs/wasm-builder |
There are a number of benefits on using a common approach/container across the dependencies.
So while we could use a different approach and tools in each dependency and meet all of the same goals, it should be easier by re-using one common approach and build container. |
I'll also that in line with Matteo's comment it would be the "The Node.js project's" container not mine. |
Send the PR! |
@mcollina thanks, will start the process of moving over the repo for the container generation and then I'll do that. |
This would solve...
The security wg has been looking at auditing build dependencies for Node.js. nodejs/security-wg#1236
One area we thought that we could improve is how we build WASM. Today it's done differently, in some cases with different tools, different versions of tools and the versions used may or may not be known/captured in a way that would allow us to be sure we could reproduce a build.
I've looked at creating a common container that would be shared across the dependencies that build WASM and which captures the versions of tools etc. In addition in using a shared container that we store in the project we know we can build with the same tools because they are in the container stored within the registry.
The approach is based on how undici was building, with the main change being to use a pre-existing container. I've already talked to maintainers of amaro and cjs-module-lexer which are the other deps that build WASM blobs and they seem willing to adopt the approach.
I still have a bit of work in terms of how the container would be published (as I believe GitHub has a migration from ghcr of some sort) and the repo mhdawson/wasm-builder would need to move under the nodejs org.
The PR to adopt in undici would look like: main...mhdawson:undici:wasm-build-experiment
You can see what it looks like for the other deps from the links in - nodejs/security-wg#1236 (comment)
The reason for this issue is to ask if undici would be willing to adopt the approach as well.
The implementation should look like...
I have also considered...
Additional context
The text was updated successfully, but these errors were encountered: