Merge branch 'instance-fetch-fix' into 'develop'

Catch instance/fetch error, only set instance_fetch_failed on 404

See merge request soapbox-pub/soapbox-fe!1296
This commit is contained in:
Alex Gleason 2022-05-02 17:06:33 +00:00
commit 9fc79c942e
2 changed files with 13 additions and 6 deletions

View file

@ -39,12 +39,16 @@ const needsNodeinfo = (instance: Record<string, any>): boolean => {
export const fetchInstance = createAsyncThunk<void, void, { state: RootState }>(
'instance/fetch',
async(_arg, { dispatch, getState }) => {
const { data: instance } = await api(getState).get('/api/v1/instance');
if (needsNodeinfo(instance)) {
dispatch(fetchNodeinfo());
async(_arg, { dispatch, getState, rejectWithValue }) => {
try {
const { data: instance } = await api(getState).get('/api/v1/instance');
if (needsNodeinfo(instance)) {
dispatch(fetchNodeinfo());
}
return instance;
} catch(e) {
return rejectWithValue(e);
}
return instance;
},
);

View file

@ -13,7 +13,10 @@ const ReducerRecord = ImmutableRecord({
export default function meta(state = ReducerRecord(), action: AnyAction) {
switch(action.type) {
case fetchInstance.rejected.type:
return state.set('instance_fetch_failed', true);
if (action.payload.response?.status === 404) {
return state.set('instance_fetch_failed', true);
}
return state;
default:
return state;
}