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

request has gone into maintenance mode. Maybe replace it. #2047

Closed
Tchiller opened this issue Feb 15, 2020 · 19 comments · Fixed by #2220
Closed

request has gone into maintenance mode. Maybe replace it. #2047

Tchiller opened this issue Feb 15, 2020 · 19 comments · Fixed by #2220

Comments

@Tchiller
Copy link

Dear team,

thanks for your work!

I would like to report that the package request which you are loading has went into maintenance mode request/request#3142

Therefore, yarn is currently giving me:

warning node-gyp > [email protected]: request has been deprecated, see request/request#3142

Maybe you find time (and a good replacement) to replace it.
Thanks!

@rvagg
Copy link
Member

rvagg commented Feb 17, 2020

Yeah, thanks @Tchiller, it got deprecated last week after a long warning period (mind you, I didn't pick up on the fact that it would be properly deprecated in npm so this was a bit of a surprise).

We don't have a plan to deal with this, maybe we'll follow what npm does (or is doing, I don't know status). This will take someone doing the work and making sure it's maximally compatible back to Node 10.x at least (yes 10 is going away soon but node-gyp can't be as aggessive as a lot of software since it's a piece of core infra).

@rvagg
Copy link
Member

rvagg commented Feb 17, 2020

Yeah, maybe not, npm uses its own library that's a wrapper around a fork of node-fetch, not an ideal tangle to get involved in https://github.com/npm/make-fetch-happen

We could consider bent but we have yet to embrace async/await in node-gyp. We're either going to have to do an awkward piece-wise migration or go whole-hog at some point.

Too hard to think about right now! Proposals are welcome!

@imatlopez
Copy link
Contributor

@rvagg are you saying that for node-gyp v7.x Node 6-9 are getting dropped? You could cage any calls to request in v6.x, then swap the underlying api for v7.x

@rvagg
Copy link
Member

rvagg commented Feb 24, 2020

What version of Node we support is partly informed by npm. I don't have much insight into their current strategy but recent years suggest that they're being more aggressive with dropping older versions of Node from support as those versions get dropped upstream.

I don't think there's any reason to consider supporting Node 6, it's roughly 1 year out of support.
Node 8 was dropped at the beginning of this year. There's an argument to be made that we should consider continuing to make node-gyp compatible with Node 8. I wouldn't want npm to decide to ship an older node-gyp because they wanted to be more compatible than us. But, at this point, the kinds of features we want to start adopting are in Node 8 anyway - async/await being the main one, so it probably wouldn't be hard.

After my last post here I thought of a possible interim solution, switching to hyperquest. I still use it in many of my Node libraries and it still works great. It's much simpler than request but has a very similar API so doesn't suffer from many of the costs that request had with its bloated feature set and dependency tree. The challenge we'll have is that some of those missing features are required by our users, such as proper proxy detection. But we've already adopted a big chunk of request's proxy code here to do some custom work with it so that should be fairly simple to insert to hyperquest to bring parity. We're going to have this feature problem with whatever we switch to I think; there'll be some weird edges where request has certain behaviour that our users are relying on that we will no longer support when we switch http clients.

@imatlopez
Copy link
Contributor

hyperquest seems dated, though that means support for older Node versions would be a given.

The challenge we'll have is that some of those missing features are required by our users, such as proper proxy detection.

What are the features that are needed? I can think of 2 (mostly due to my ignorance) streams and proxies

@rvagg
Copy link
Member

rvagg commented Feb 25, 2020

hyperquest seems dated, though that means support for older Node versions would be a given.

I'm thinking more about the amount of change required on our end to adopt something new. We're still working on a thoroughily old-style Node codebase. Modernising is an option but a costly one that I don't see happening in the short term. Hence, hyperquest might be a good short-term fix, in many cases it's a drop-in replacement for request.

@imatlopez
Copy link
Contributor

Is it for visuals? I'd think request was updated last sometime since hyperquest has

@rvagg
Copy link
Member

rvagg commented Feb 25, 2020

hyperquest is still "supported", it has many users who rely on it. It's not recently updated because it just works and is simple enough that it doesn't need constant curation. substack would consider it "finished" although he's handed over maintenance to others (Julian Gruber among others I believe). request is a beast of a codebase with a lot of dependencies, hyperquest is much more focused.

also, npm install node-gyp won't give a deprecation notice if we switch to hyperquest! that's the top-level concern here, there's no real problems with request (yet), but the deprecation notice is going to get severely annoying and I expect this issue to get busier as people encounter it more and more.

@imatlopez
Copy link
Contributor

request is a beast of a codebase with a lot of dependencies, hyperquest is much more focused.

agreed :)

I think your logic is sound, so what has to be feature matched on top of hyperquest?

@rvagg
Copy link
Member

rvagg commented Feb 25, 2020

The main one I can think of is proxy detection, but we've done the heavy lifting now (recent addition) in proxy.js, which is mostly copied out of request, so we should be able to leverage that for free! I can't think of anything else off the top of my head, I'm just a little afraid that there are some because of the wide variety of ways people are using node-gyp (behind weird firewalls, proxies, redirecting to alternate source locations - like for electron...).

@SampsonCrowley
Copy link

would it work to pin request to the version before it was deprecated?

@targos
Copy link
Member

targos commented Mar 18, 2020

The package is entirely deprecated. npm prints a warning for any version.

@ghost
Copy link

ghost commented May 2, 2020

Just got it myself now, any update or... ? Thanks

@xPaw
Copy link

xPaw commented Aug 21, 2020

This would be great to be done, because other packages being required by request are also being deprecated:

npm WARN deprecated [email protected]: request has been deprecated, see https://github.com/request/request/issues/3142
npm WARN deprecated [email protected]: this library is no longer supported

Hoisted from "sqlite3#node-gyp#request#har-validator"

got is almost a drop in replacement for request: https://github.com/sindresorhus/got/blob/master/documentation/migration-guides.md

@aqan213
Copy link

aqan213 commented Feb 2, 2021

As described in issue #RuntimeTools/appmetrics#647. The customer is supposed to fix the security in Feb. Is there any plan to replace the request package? thanks,

@Zekfad
Copy link

Zekfad commented Mar 18, 2021

It;s closed...
image

@crystalfp
Copy link

The error is still present after upgrading node to 16.0.0 and upgrading all my packages.

The @xPaw error is elicited for me running npm i -g npm-check-updates

"The future is now, old man" but the messages are still here. No fix?

@gengjiawen
Copy link
Member

npm i -g node-gyp. Latest npm not bundled node-gyp version 8 yet.

@crystalfp
Copy link

Well, following your suggestion and then installing again npm-check-updates changed nothing. Maybe I'm doing something wrong.

> npm i -g node-gyp

added 91 packages, and audited 92 packages in 3s

3 packages are looking for funding
  run `npm fund` for details

found 0 vulnerabilities
> npm -g install npm-check-updates
npm WARN deprecated [email protected]: this library is no longer supported
npm WARN deprecated [email protected]: request has been deprecated, see https://github.com/request/request/issues/3142

changed 314 packages, and audited 315 packages in 12s

29 packages are looking for funding
  run `npm fund` for details

found 0 vulnerabilities
>

Maybe the node-gyp I should update is the one under npm-check-updates/node_modules, tried but received a lot of errors.

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