-
Notifications
You must be signed in to change notification settings - Fork 933
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
Update optimizer webpack config to support ReactFlow dependency #4882
Conversation
Signed-off-by: Tyler Ohlsen <ohltyler@amazon.com>
Signed-off-by: Tyler Ohlsen <ohltyler@amazon.com>
Codecov Report
@@ Coverage Diff @@
## main #4882 +/- ##
=======================================
Coverage 66.50% 66.50%
=======================================
Files 3403 3403
Lines 65026 65026
Branches 10401 10401
=======================================
Hits 43245 43245
Misses 19213 19213
Partials 2568 2568
Flags with carried forward coverage won't be shown. Click here to find out more. |
Signed-off-by: Tyler Ohlsen <ohltyler@amazon.com>
This is a personal opinion, but i'd avoid adding dependencies to core unless core requires it too. Yes this requires updates to multiple plugins separately, but i'd rather not introduce anti patterns instead of solving the underlying problem, which is the dependency hell that we have. And doing it this way makes us less inclined to solve that. That being said, since the core problem here is that webpack need to transpile the source code because it does not have native es5 builds, i'm okay making an exception here. But before doing so i'd really like to know if just adding the same webpack changes to plugins would work. A quick exploration into this might be worth it since i dont expect this to be the last time we do something like this. This PR adds a lot of transitive dependencies to the repo because of this npm module. That means that we also have a lot of potential security vulnerabilities that we have to watch out for and maintain. Id love to minimize that if possible since dependencies added here affect every plugin. @AMoo-Miki @joshuarrrr what are your thoughts? |
Signed-off-by: Tyler Ohlsen <ohltyler@amazon.com>
I'll start with the provided reasons (thanks @ohltyler for the helpful summary):
I don't find 1-3 to be compelling for adding many new core dependencies. 3 hints at the idea that, eventually, multiple different plugins will need to build on top of ReactFlow, but the RFC as of today seems to call for just a single plugin to start. I also think it philosophically goes against the spirit of a minimal OpenSearch Dashboards distribution that's further extended via plugins. So I'm in agreement with @ashwin-pc's concerns above. However, reason 4 definitely resonates with me - I can see why this might be a pain at the plugin level, where there's much less visibility and control over OpenSearch Dashboards' complex loading and bundling infrastructure. I agree with Ashwin that I'd like to see if webpack configuration at the plugin level is sufficient. If not, I'd be OK with this in |
note also that React Flow will soon have a naming change: https://wbkd.notion.site/Upcoming-Changes-at-React-Flow-1a443641891a4069927c0a115e915251 |
@joshuarrrr @ashwin-pc thanks both for the feedback, that all makes sense to me. Regarding the webpack 5 migration, is that going to be something prioritized? And if not, if we want to release the plugin in the |
@ohltyler Here are a few options:
@joshuarrrr why cant this be backported? |
Right now, the plugin isn't taking on any build/compile-related package dependencies, like webpack or babel. Any build or bootstrap commands ( |
In addition to the great points others brought up, for me it all boils down to one thing: OSD is not using it so it is not a dep of OSD and needn't be added as such; OSD cannot afford to maintain a package that it doesn't depend on. I understand where you are coming from and I see how that could simplify things for "some" plugins but with the same logic, it would make it challenging (and even blocking) for other plugins. Keep in mind that OSD will not be able to bump that package without incurring a breaking change that requires a major version bump. Is there something that your plugin is unable to achieve on its own without this being a dep of OSD? |
Our plugin does not maintain any build/compile-related packages like I've mentioned in the previous comment. If this is a supported pattern, or if there is any existing plugin that is doing such, that would be helpful. I'm very worried in the complexity we would need to build some things some way from core OSD, and build other things other ways using a plugin-customized webpack & babel configuration, as well as an entirely new set of build scripts in package.json to build both simultaneously when bootstrapping the plugin inside of core OSD. |
To me it seems the much bigger issue is that OSD is not on webpack 5 so it will become more and more common where packages will start to cause more issues when they don't support es5 builds. If that was resolved we could much more easily add the package in our plugin since the OSD build packages would support it out of the box. |
If a plugin, made by OpenSearch or someone else, needs a specific build system or has specific dependencies, they are responsible for creating and maintaining it. For example, ISM until recently provided their own Additionally, I can support the change to
Plugins are free to build themselves however they wish to. OSD has provided some tools to ease the burden but if a plugin finds those tools inadequate for their unique use case, they are more than welcome to build and package on their own or include config files stored in their codebase that get picked up by OSD's tools.
That is indeed a problem and we are focused on solving it for the next major version (since it would be a breaking change). |
@AMoo-Miki thanks a lot for those details. I've POC'd where if the webpack.config changes are done here, but ReactFlow is added as a dep in the plugin, it works as expected. I think this will be the simplest approach as it avoids having to take on a plugin-standalone build environment, and once webpack 5 is available, even that extra config in here can be removed. |
Signed-off-by: Tyler Ohlsen <ohltyler@amazon.com>
Just curious as I have not tried this myself: did you experiment with adding the webpack.config to the plugin? I would love to learn from your experience with that. |
* Add reactflow with compiler fix Signed-off-by: Tyler Ohlsen <ohltyler@amazon.com> * Update CHANGELOG Signed-off-by: Tyler Ohlsen <ohltyler@amazon.com> * Update comment Signed-off-by: Tyler Ohlsen <ohltyler@amazon.com> * Revert adding reactflow dep Signed-off-by: Tyler Ohlsen <ohltyler@amazon.com> --------- Signed-off-by: Tyler Ohlsen <ohltyler@amazon.com> Co-authored-by: Miki <miki@amazon.com> (cherry picked from commit eec3ed7) Signed-off-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>
I tried a bit with some custom build configurations but I couldn't get things to work. I'm not familiar enough with the combination of nested projects with webpack & babel, or how to integrate with the OSD build system enough. |
… (#5094) * Add reactflow with compiler fix * Update CHANGELOG * Update comment * Revert adding reactflow dep --------- (cherry picked from commit eec3ed7) Signed-off-by: Tyler Ohlsen <ohltyler@amazon.com> Signed-off-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com> Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com> Co-authored-by: Miki <miki@amazon.com>
Description
This PR adds MIT-licensed ReactFlow 11.8.3 as a dependency. It also updates the webpack configuration to use the proper babel loader, very similarly to what was needed with the vega v5 dependency.
We want to add this dependency into core OSD for a few reasons:
Testing the changes
I've tested out using ReactFlow in an external plugin to ensure it works as expected, and the dependency is pulled correctly.
Check List