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

Specifying http proxy changed in Node@18 and 20 #1103

Open
waldekmastykarz opened this issue Mar 11, 2024 · 5 comments
Open

Specifying http proxy changed in Node@18 and 20 #1103

waldekmastykarz opened this issue Mar 11, 2024 · 5 comments
Assignees
Milestone

Comments

@waldekmastykarz
Copy link

Since v18, Node ships with a native fetch client. This client requires a different way to specify an HTTP proxy than what we've been supporting in our SDKs so far.

To specify an HTTP proxy for Node's fetch, you need to use the following code (tested on Node v18.19 and v20.11):

import { ProxyAgent } from 'undici';
import { Client } from '@microsoft/microsoft-graph-client';

const dispatcher = new ProxyAgent(process.env.https_proxy);
const fetchOptions = {
  dispatcher
};

Client.initWithMiddleware({
  middleware,
  fetchOptions
});

What's noteworthy:

  • we specify HTTP proxy using dispatcher instead of agent (agent is ignored on requests, which makes it hard to debug)
  • the ProxyAgent dispatcher comes from undici which seems to be maintained by Node folks. The ProxyAgent is incompatible with other agents that we used to use in the past.

We should update our FetchOptions interface to support specifying dispatcher.

@baywet
Copy link
Member

baywet commented Mar 11, 2024

Thanks for reaching out.

@sebastienlevert and I were chatting about that earlier and he mentioned he made it work. I'll let him provide the specifics when he has time (as you know I'm traveling right now and don't have time to dig into this)

@baywet baywet added this to the Backlog milestone Mar 11, 2024
@sebastienlevert
Copy link

Just to confirm... This is for Graph JS v3, right? We donc have the middleware initialization anymore IIRC.

As we won't be adding new features over there, I highly doubt we'll get to this.

@waldekmastykarz
Copy link
Author

This change affects any code that relies on Node's fetch. I noticed it in Graph JS SDK v3 but if the new TypeScript SDK also uses Node.js fetch, then it would also have the same issue.

@fey101 fey101 removed the question label Jul 4, 2024
@baywet baywet modified the milestones: Backlog, Kiota-TS-GA Nov 28, 2024
@baywet
Copy link
Member

baywet commented Jan 20, 2025

Since this initial post, our plans have changed multiple times.

We now planning a full depreciation of the "old" JS SDK, which means the "new" TypeScript SDK and kiota dependencies won't have any dependencies on it.

The client factory now supports providing a fetch callback

Consumers should simply need to do something like this:

const proxy = new HttpsProxyAgent('http://168.63.76.32:3128');
const customFetch  = (request: string, init: RequestInit) => fetch(request, {...init, agent: proxy});
const httpClient = KiotaClientFactory.create(customFetch); // additional middleware configuration here
const requestAdapter = new DefaultRequestAdapter(authenticationProvider, undefined, undefined, httpClient);
const apiClient = new APIClient(requestAdapter);

Of course, we can add shorthands in graph core and service libraries to reduce the number of calls here, the important thing is the capability is available natively.

We might also want to advise customers to take an additional dependency on https-proxy-agent, more context

Assuming this tab gets updated (it should really say JavaScript to be consistent with generated doc snippets), does that address your concern @waldekmastykarz ?

@waldekmastykarz
Copy link
Author

Yes it does! I appreciate you being mindful of this requirement, that many large organization need for their apps.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
Status: New📃
Development

No branches or pull requests

4 participants