Merge branch 'nostr-cors-fix' into 'develop'
api: don't send the X-Nostr-Sign header unless the backend supports it Closes #1505 See merge request soapbox-pub/soapbox!2651
This commit is contained in:
commit
85ddc7729a
1 changed files with 21 additions and 6 deletions
|
@ -60,14 +60,25 @@ const getAuthBaseURL = createSelector([
|
||||||
* @param {string} baseURL
|
* @param {string} baseURL
|
||||||
* @returns {object} Axios instance
|
* @returns {object} Axios instance
|
||||||
*/
|
*/
|
||||||
export const baseClient = (accessToken?: string | null, baseURL: string = ''): AxiosInstance => {
|
export const baseClient = (
|
||||||
|
accessToken?: string | null,
|
||||||
|
baseURL: string = '',
|
||||||
|
nostrSign = false,
|
||||||
|
): AxiosInstance => {
|
||||||
|
const headers: Record<string, string> = {};
|
||||||
|
|
||||||
|
if (accessToken) {
|
||||||
|
headers.Authorization = `Bearer ${accessToken}`;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (nostrSign) {
|
||||||
|
headers['X-Nostr-Sign'] = 'true';
|
||||||
|
}
|
||||||
|
|
||||||
return axios.create({
|
return axios.create({
|
||||||
// When BACKEND_URL is set, always use it.
|
// When BACKEND_URL is set, always use it.
|
||||||
baseURL: isURL(BuildConfig.BACKEND_URL) ? BuildConfig.BACKEND_URL : baseURL,
|
baseURL: isURL(BuildConfig.BACKEND_URL) ? BuildConfig.BACKEND_URL : baseURL,
|
||||||
headers: Object.assign(accessToken ? {
|
headers,
|
||||||
'Authorization': `Bearer ${accessToken}`,
|
|
||||||
'X-Nostr-Sign': 'true',
|
|
||||||
} : {}),
|
|
||||||
transformResponse: [maybeParseJSON],
|
transformResponse: [maybeParseJSON],
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
@ -95,7 +106,11 @@ export default (getState: () => RootState, authType: string = 'user'): AxiosInst
|
||||||
const me = state.me;
|
const me = state.me;
|
||||||
const baseURL = me ? getAuthBaseURL(state, me) : '';
|
const baseURL = me ? getAuthBaseURL(state, me) : '';
|
||||||
|
|
||||||
return baseClient(accessToken, baseURL);
|
const relayUrl = state.getIn(['instance', 'nostr', 'relay']) as string | undefined;
|
||||||
|
const pubkey = state.getIn(['instance', 'nostr', 'pubkey']) as string | undefined;
|
||||||
|
const nostrSign = Boolean(relayUrl && pubkey);
|
||||||
|
|
||||||
|
return baseClient(accessToken, baseURL, nostrSign);
|
||||||
};
|
};
|
||||||
|
|
||||||
// The Jest mock exports these, so they're needed for TypeScript.
|
// The Jest mock exports these, so they're needed for TypeScript.
|
||||||
|
|
Loading…
Reference in a new issue