-
Notifications
You must be signed in to change notification settings - Fork 532
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
Proposal to swap deprecated request for node-fetch #754
Comments
This approach is going to introduce breaking changes for consumers of this client library (there were 151k downloads last week alone). We need to have a more careful plan for how we roll out this change. I would like to support existing users for at least a few versions (perhaps 3?) while we make this transition. Perhaps the right way to do this is to introduce a new major version to signify the new generator? e.g.
This will require introducing a new branch for the Please note that this is going to be a big change that will touch nearly the entire library, I think |
That phasing plan makes sense to me. It's in-line with the npm semantic versioning. It might make sense to deprecate the 0.x releases with a warning telling them that support for the old client api will no longer be supported after a certain version and encouraging them to upgrade. That should alert existing users of the changes. I'm prepared to take on the responsibility associated with this upgrade. |
Is using both generators and fetch/request in parallel not an option during the transition? I haven't thought through all implications or the workload of doing that, just thinking out loud, but it would be nice if you could do something like |
I agree it would be nice if we could keep the user experience that cohesive, but unfortunately these changes seem too broad and breaking for that to be doable. Given the extent of the proposed changes, it could introduce significant overhead and complexity to have two major versions bundled in a single release. I've taken a shot at incrementing
Another predictable area of major changes is the error interfaces since we are changing the network library, and the proposal includes incrementing typescript by a major version. This may be a config option that I've inadvertently changed, but IMO it does come across cleaner. This could be a concern if we had I'll keep checking it out. There could be an easier way tweaking the generator options that I'm not familiar with. |
One other option would be to package the old generated code and the new generated code into different directories and effectively have:
or
e.g. keep everything in one place from a release perspective, but introduce a fork in the imports that you can use. |
That could definitely work if we introduce a named export for Another possibility would be to have
or
to retain existing import compatibility for
|
I think there are different kinds of breaking changes. I feel like changing an import statement is a much lower cost breaking change vs changing the entire API surface area. So I would be ok to require
or
And I think that is feasible... |
I don't think putting both the new api and old api in the same package / directory makes sense to me. The fact that it's a breaking change between them means that someone can't just swap out API's when making the change. // switching from this
import { api_new as api } from @kubernetes/node-client
// to this would still require code changes in lots of places where the api is used
import { api_old as api } from @kubernetes/node-client Someone migrating to the new api would have to change every single node-client import statement in their repo which would be time consuming and tedious. It's simpler from a user-standpoint to simply upgrade their version then fix any errors in the code. By having both the old and new api in the same package we also wouldn't be able to take advantage of a npm deprecation warning which would help warn users of the upcoming drop of support for the old api. Users wouldn't be upgraded to the breaking api without doing it manually (or changing their From a user-standpoint I don't think it's easier to change the import and I believe one of our goals should be gently pushing consumers to migrate when they get the chance (or at least be aware of upcoming drops in support). From our standpoint it's more difficult to work with a directory layout that has two apis rather than just different branches. Storing the new and old api in the in the same package would make more sense to me if there was some reason why a user would want to use both the old and new api but I can't think of one. |
The major version suggestion seems be the cleanest way. Putting the changes in a new major version would make upgrading a clear decision without interfering with existing code. That way we don't mix code from two generators in a single package. |
Completely supporting the major version upgrade. Our team doesn't mind spending some time adjusting code to the new API, as long as we can stop using deprecated or regularly vulnerable packages! 😄 |
Ok, sounds like the consensus is for a major version upgrade. I have created a We can start sending PRs to the |
We should also probably turn this discussion into a markdown document that describes our approach and links off of the main README.md |
Quick update: @davidgamero and I have been working on this for the last two weeks. We're having to make some changes to open-api generator to support the way we need to do auth. @davidgamero has been working on identifying the exact improvements necessary. |
Update 2: Two PRs have been completed against OpenAPITools/openapi-generator (the typescript generator template in specific), and a third is in progress. Complete (PR)
In Progress (Issue) [REQ][typescript] Enable passing custom SecurityAuthentication to API With this last PR, the ability to pass certificates to the |
Update 3: Custom Authentication is now complete in the typescript generator. Currently migrating the |
fetch
https://nodejs.org/en/blog/release/v17.5.0/
node 17's fetch is using undici |
Hopefully the TypeScript generator swaps over to this way. |
This will be great! It should be simpler to switch from node-fetch to the included fetch in the future (since their syntax is very similar) |
Hello, If I understand correctly - Here: Line 62 in b4ccd6e
The latest status is: Is this something I can help with? Is there a branch with source I can help to get compiling, I'm happy to try to help. Thanks, Chad |
Hi @chadbr , the current working branch is https://github.com/kubernetes-client/javascript/tree/release-1.x and the next step is migrating all the auth providers and their unit tests. It's mostly mapping headers and query params to use the new Any help migrating those would be very appreciated! I'm finishing up the |
The Kubernetes project currently lacks enough contributors to adequately respond to all issues and PRs. This bot triages issues and PRs according to the following rules:
You can:
Please send feedback to sig-contributor-experience at kubernetes/community. /lifecycle stale |
the middleware workaround seems reasonable while we develop a cleaner long-term solution, so im in favor of a new rc with that code included. just made a pr for the changes @joshperry |
Bumping up the priority on this item, since the deprecated |
Any update on this? Very interested in closing out the CVE referenced above |
@kberkos-public @efenner-cambia there is a pre-release of the library based on fetch that you can start consuming: Note that the API has changed somewhat, so it is not a drop-in replacement. |
Thank you so much @brendandburns ! |
I can see there's a later pre-release library https://www.npmjs.com/package/@kubernetes/client-node/v/1.0.0-rc4?activeTab=versions made available on 2023-12-23. @brendandburns do you know when v1.0.0 is going to be released and in which kubernetes version it will be included, to remediate CVE-2023-28155? PSIRTRef_fup_3P_kubernetes PVR0429050 |
@brendandburns any update on this? |
This client is not released as part of the Kubernetes release. There is no current eta for a non RC 1.0.0 release, we need more mileage and reports from people that they have migrated successfully to have confidence in the release. |
@brendandburns can you confirm that when kuberenetes/client-node/v/1.0.0 is available as well as remediating CVE-2023-28155, it will also remediate CVE-2023-26136; where it seems the required upgrade to PSIRTRef_fup_3P_kubernetes PVR0452658 |
I forgot to report that I migrated a private repository to rc2 with no issues. I didn’t realize that there was an rc3; I’ll add that to my todo list. |
@briandealwis There is even an rc4 by now: https://www.npmjs.com/package/@kubernetes/client-node/v/1.0.0-rc4 |
Migrated 14 microservices to rc4 with no issues other than one TS type that needed to change (we had cast the watch result |
The latest pre-release library https://www.npmjs.com/package/@kubernetes/client-node/v/1.0.0-rc4?activeTab=versions remains rc4 made available on 2023-12-23, which appears to be receiving positive feedback for migrating microservices. Is there any further thought when v1.0.0 maybe released and in which kubernetes version it will be included? I believe this is blocking the remediation of CVE-2023-28155 as well as CVE-2023-26136, where it seems the required upgrade to tough-cookie-4.1.3 is dependent on the replacement of the request package. PSIRTRef_fup_3P_kubernetes PVR0429050 PVR0452658 PVR0473928 PVR0473931 |
I wouldn't say that rc4 feedback is positive. Yes, code works properly but it is a pain to use middleware. For example when you need to add a header when patching pod:
I think you agree that we need quite much code to patch a pod, it should be simpler... |
I'm not sure where the best place to return feedback on RC4 is, but I'll assume from the thread maybe here. The errors being returned appear to have a body of a string or undefined, and not an object as they were in 0.2.0:
|
Also not sure where the 1.x feedback should go, but on top of the few already reported issues above here are few pain points from my migration to 1.x:
|
Just pointing out that fetch is implemented natively in Node.js, and it's been available since Node 18 (so it includes current and previous LTS, so strictly there's no need to use |
Node 16 went EOL in September of 2023, so it's doesn't really feel valuable supporting it—especially since the standard k8s support window is only 14 months. Is there interest from the team in going straight to the node implementation of fetch or is the plan to stick with node-fetch? Edit: It's worth noting that while native fetch was pulled out from behind the |
I would think we should start with finishing the |
@mstruebing do you think this issue can be closed since v1.0.0 was released with node-fetch? |
@dastrobu we have had an issue with our GitHub action so the release did not get tagged on GitHub. |
Thanks for the patience, added the tag at the appropriate commit: https://github.com/kubernetes-client/javascript/releases/tag/1.0.0 As determined by the logs from the GH Action that pushed to NPM: https://github.com/kubernetes-client/javascript/actions/runs/12395838409/job/34602484401#step:2:67 |
Proposal to swap deprecated request for node-fetch
Request is fully deprecated requiring us to switch libraries (see #414 for more information).
@brendanburns outlined some of the clear options forward. This change should ideally be a long-term solution leaving us with the option of either modifying the node-typescript open-api-generator to use a different request library or migrate to one of the other generator options.
Modifying an outdated node-typescript library does not seem like the right path forward. It would require us to still use a new library which would likely change the api and still be a breaking change. We might as well migrate to a newer version of openapi-generator while we do that and acquire the advantages of a more up-to-date version.
Choosing a new library
@d-cs posted a nice summary of the different choices. We narrowed it down to Axios or Fetch. The other libraries didn't match how widely adopted and focused these libraries are.
Fetch is simply the standard JavaScript as a whole is moving to, which brings more longterm support aligning us better with our goal of migrating to a long-term solution. node-fetch has significantly more weekly downloads than axios. The package size of node-fetch is also noticeably smaller than axios.
Additionally, future improvements could likely be done to allow us to also support the browser #165 since Fetch is native to the browser.
Node-fetch
Fetch is a native browser API that is not implemented in Node.js by default. Node-fetch is the natural choice for the Node implementation because it is the most widely adopted.
The openapi-generator uses the browser implementation of Fetch so we must substitute node-fetch in manually.
Implementation steps
@davidgamero and I will work to implement the following changes.
Other repositories
typescriptThreePlus
config option 1 2Kubernetes-client repository
OPENAPI_GENERATOR_COMMIT
to be version 5.3.0npm install node-fetch
to install node-fetchsrc/api.ts
with the followingnpm run generate
The text was updated successfully, but these errors were encountered: