pleroma/app/soapbox/actions/instance.ts

94 lines
3.3 KiB
TypeScript
Raw Normal View History

import { get } from 'lodash';
import KVStore from 'soapbox/storage/kv_store';
2022-03-15 06:48:18 -07:00
import { AppDispatch, RootState } from 'soapbox/store';
import { getAuthUserUrl } from 'soapbox/utils/auth';
import { parseVersion } from 'soapbox/utils/features';
2022-03-18 14:04:08 -07:00
2022-01-10 14:01:24 -08:00
import api from '../api';
export const INSTANCE_FETCH_REQUEST = 'INSTANCE_FETCH_REQUEST';
export const INSTANCE_FETCH_SUCCESS = 'INSTANCE_FETCH_SUCCESS';
export const INSTANCE_FETCH_FAIL = 'INSTANCE_FETCH_FAIL';
export const INSTANCE_REMEMBER_REQUEST = 'INSTANCE_REMEMBER_REQUEST';
export const INSTANCE_REMEMBER_SUCCESS = 'INSTANCE_REMEMBER_SUCCESS';
export const INSTANCE_REMEMBER_FAIL = 'INSTANCE_REMEMBER_FAIL';
2020-04-01 13:05:52 -07:00
export const NODEINFO_FETCH_REQUEST = 'NODEINFO_FETCH_REQUEST';
export const NODEINFO_FETCH_SUCCESS = 'NODEINFO_FETCH_SUCCESS';
export const NODEINFO_FETCH_FAIL = 'NODEINFO_FETCH_FAIL';
2020-04-01 13:05:52 -07:00
2022-03-15 06:48:18 -07:00
const getMeUrl = (state: RootState) => {
const me = state.me;
return state.accounts.getIn([me, 'url']);
};
// Figure out the appropriate instance to fetch depending on the state
2022-03-15 06:48:18 -07:00
export const getHost = (state: RootState) => {
const accountUrl = getMeUrl(state) || getAuthUserUrl(state);
try {
return new URL(accountUrl).host;
} catch {
return null;
}
};
2022-03-15 06:48:18 -07:00
export function rememberInstance(host: string) {
2022-03-18 14:23:14 -07:00
return (dispatch: AppDispatch, _getState: () => RootState) => {
dispatch({ type: INSTANCE_REMEMBER_REQUEST, host });
2022-03-15 06:48:18 -07:00
return KVStore.getItemOrError(`instance:${host}`).then((instance: Record<string, any>) => {
dispatch({ type: INSTANCE_REMEMBER_SUCCESS, host, instance });
return instance;
2022-03-15 06:48:18 -07:00
}).catch((error: Error) => {
dispatch({ type: INSTANCE_REMEMBER_FAIL, host, error, skipAlert: true });
});
};
}
// We may need to fetch nodeinfo on Pleroma < 2.1
2022-03-15 06:48:18 -07:00
const needsNodeinfo = (instance: Record<string, any>): boolean => {
const v = parseVersion(get(instance, 'version'));
return v.software === 'Pleroma' && !get(instance, ['pleroma', 'metadata']);
};
2022-03-18 14:04:08 -07:00
export function fetchInstance() {
return (dispatch: AppDispatch, getState: () => RootState) => {
dispatch({ type: INSTANCE_FETCH_REQUEST });
2022-03-15 06:48:18 -07:00
return api(getState).get('/api/v1/instance').then(({ data: instance }: { data: Record<string, any> }) => {
dispatch({ type: INSTANCE_FETCH_SUCCESS, instance });
if (needsNodeinfo(instance)) {
dispatch(fetchNodeinfo() as any); // Pleroma < 2.1 backwards compatibility
}
2020-04-01 13:05:52 -07:00
}).catch(error => {
2022-02-06 18:46:06 -08:00
console.error(error);
dispatch({ type: INSTANCE_FETCH_FAIL, error, skipAlert: true });
2020-04-01 13:05:52 -07:00
});
};
}
// Tries to remember the instance from browser storage before fetching it
export function loadInstance() {
2022-03-15 06:48:18 -07:00
return (dispatch: AppDispatch, getState: () => RootState) => {
const host = getHost(getState());
if (!host) return new Promise(r => r(null));
return dispatch(rememberInstance(host) as any).finally(() => {
return dispatch(fetchInstance() as any);
});
};
}
export function fetchNodeinfo() {
2022-03-15 06:48:18 -07:00
return (dispatch: AppDispatch, getState: () => RootState) => {
dispatch({ type: NODEINFO_FETCH_REQUEST });
2022-03-15 06:48:18 -07:00
return api(getState).get('/nodeinfo/2.1.json').then(({ data: nodeinfo }) => {
return dispatch({ type: NODEINFO_FETCH_SUCCESS, nodeinfo });
}).catch((error: Error) => {
return dispatch({ type: NODEINFO_FETCH_FAIL, error, skipAlert: true });
});
};
}