All the endpoints of the API I'm working on, require the same set of query parameters. The user must select these parameters before making requests to endpoints.
Examples of endpoints
/api/resource-1?param1=valueA¶m2=valueB¶m3=valueC
/api/resource-2?param1=valueA¶m2=valueB¶m3=valueC
Selected values are saved on the Redux Store. I'd like to customize my baseQuery to append these query params to API URL automatically. I'm searching something in fetchBaseQuery
that works similar to prepareHeaders
allowing to customize the query URL.
hypothetical code
const baseQuery = fetchBaseQuery({
baseUrl: baseUrl,
// THIS PROPERTY DOES NOT EXISTS
prepareUrl: (url, { getState }) => {
const param1 = (getState() as AppState).config.param;
if (param1) {
url.searchParams.append('param1', param1);
}
return url;
},
prepareHeaders: (headers, { getState }) => {
const token = (getState() as AppState).auth.token;
if (token) {
headers.set('authorization', `Bearer ${token}`);
}
return headers;
},
});
I read how to implement a custom base query but I don't want to lose the behavior provided by fetchBaseQuery
.
Is there something like the prepareUrl
property that allows to customize the request URL? Should I implement a custom base query? What's the best way to do that?
CodePudding user response:
You were already on the right page in the docs. The trick is to not write a completely new baseQuery, but to wrap a custom baseQuery "around" the existing implementation. This examples shows how to do that to get a dynamic baseUrl, which should be very close to what you want to do here.