-
Notifications
You must be signed in to change notification settings - Fork 28
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
Allow string names in exports that aren't valid JavaScript variable names #37
Conversation
30cff9c
to
1b6dc4a
Compare
Took a stab at writing a real test for this and getting some failures on the setter bits. I'll revisit, but if any maintainers are looking at this and can provide an up or down on whether this might be accepted I can save myself some time fiddling with it. |
c3b281a
to
2083b55
Compare
Actually: test completed and pushed, and removed dependency on |
2578386
to
9411dd0
Compare
@khanayan123 This will likely conflict with your AST parsing rewrite so should see if this can be adapted somehow. 🤔 |
@khanayan123 how imminent is that rewrite? This issue is currently blocking me from using |
Hopefully in a couple of weeks. Going to discuss with @bengl to see if we can merge in your changes first. |
Thanks — feel free to co-opt the work in this PR if you like; if I get a moment I'll try to figure out how / if Node 12 and 14 can be supported. |
@khanayan123 I slept on this and I actually don't think that it's pressing enough for me to want you to spend any time on this PR if the rewrite is a few weeks out. |
Node.js 12 and 14 cannot be supported since on those versions, exports do need to be valid variable names. We can merge this PR as-is if we do a major release that drops support for Node.js v14 and lower, but we don't currently have plans for that, so for now, in order to land this, we'll need to see this code gated by a version check. |
// const modName = `v${Buffer.from(n, 'utf-8').toString('hex')}` | ||
const modName = normalizeModName(n) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Not sure what the appropriate / preferred method of normalization is here. I'll update this given some guidance.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Does prefixing this test with v15 mean that it only runs on node >= 15? If not, how should this test be applied only to that subset of node versions?
@bengl I'm resurrecting this PR because it seems like the larger refactor is still in the works? I left a few comments above, but can drive this work to conclusion with a bit of guidance if you think that it's still valuable. |
I recently opened an issue (#94) but missed this PR. I think the simplest solution to fix this without a breaking change is to not wrap modules that have exports that aren't valid identifiers. This means that users won't be able to |
I've opened #115 which skips wrapping CJS files with exports that aren't valid identifiers. Since libraries with exports like this are rare, I suspect it's highly unlikely that anyone will want to hook them with iitm. |
I ran into an issue with a package in the wild when using the ESM loader with the
node-machine-id
library.Minimal repro:
The
node-machine-id
package apparently uses an export from a UMD module that includes-
. This causes an issue in the code generated byimport-in-the-middle
, as it assumes the export uses a name that is also a valid variable name.Naming an export using an arbitrary string appears to be valid syntax according to the documentation on MDN: https://developer.mozilla.org/en-US/docs/web/javascript/reference/statements/export#syntax
The proposed proof-of-concept change uses
a base64hexadecimal encoding to create a valid variable name, and then re-exports using the original name. Open to other ideas about how to create valid variable names.Some syntax in the generated module is also updated to use string object access instead of dot access to allow access based on arbitrary string names.
Note that I haven't included a meaningful test here without knowing how to best extend the existing test coverage. I have included an example export that fails under the current implementation.Test added.