bigbuffet-rw/src/actions/me.ts

151 lines
3.8 KiB
TypeScript
Raw Normal View History

2023-07-20 13:03:23 -07:00
import { selectAccount } from 'soapbox/selectors';
2023-10-12 18:07:48 -07:00
import { setSentryAccount } from 'soapbox/sentry';
import KVStore from 'soapbox/storage/kv-store';
import { getAuthUserId, getAuthUserUrl } from 'soapbox/utils/auth';
import { getClient } from '../api';
import { loadCredentials } from './auth';
import { importFetchedAccount } from './importer';
import type { CredentialAccount } from 'pl-api';
import type { AppDispatch, RootState } from 'soapbox/store';
2023-06-28 15:53:17 -07:00
const ME_FETCH_REQUEST = 'ME_FETCH_REQUEST' as const;
const ME_FETCH_SUCCESS = 'ME_FETCH_SUCCESS' as const;
const ME_FETCH_FAIL = 'ME_FETCH_FAIL' as const;
const ME_FETCH_SKIP = 'ME_FETCH_SKIP' as const;
2023-06-28 15:53:17 -07:00
const ME_PATCH_REQUEST = 'ME_PATCH_REQUEST' as const;
const ME_PATCH_SUCCESS = 'ME_PATCH_SUCCESS' as const;
const ME_PATCH_FAIL = 'ME_PATCH_FAIL' as const;
const noOp = () => new Promise(f => f(undefined));
const getMeId = (state: RootState) => state.me || getAuthUserId(state);
const getMeUrl = (state: RootState) => {
const accountId = getMeId(state);
2023-07-20 13:03:23 -07:00
if (accountId) {
return selectAccount(state, accountId)?.url || getAuthUserUrl(state);
}
};
const getMeToken = (state: RootState) => {
// Fallback for upgrading IDs to URLs
const accountUrl = getMeUrl(state) || state.auth.me;
return state.auth.users.get(accountUrl!)?.access_token;
};
const fetchMe = () =>
(dispatch: AppDispatch, getState: () => RootState) => {
const state = getState();
const token = getMeToken(state);
const accountUrl = getMeUrl(state);
if (!token) {
2022-07-18 09:50:18 -07:00
dispatch({ type: ME_FETCH_SKIP });
return noOp();
}
dispatch(fetchMeRequest());
return dispatch(loadCredentials(token, accountUrl!))
2022-07-18 09:50:18 -07:00
.catch(error => dispatch(fetchMeFail(error)));
};
/** Update the auth account in IndexedDB for Mastodon, etc. */
const persistAuthAccount = (account: CredentialAccount, params: Record<string, any>) => {
if (account && account.url) {
if (!account.settings_store) {
account.settings_store = params.pleroma_settings_store || {};
}
KVStore.setItem(`authAccount:${account.url}`, account).catch(console.error);
}
};
const patchMe = (params: Record<string, any>) =>
(dispatch: AppDispatch, getState: () => RootState) => {
dispatch(patchMeRequest());
return getClient(getState).settings.updateCredentials(params)
.then(response => {
persistAuthAccount(response, params);
dispatch(patchMeSuccess(response));
}).catch(error => {
dispatch(patchMeFail(error));
throw error;
});
};
const fetchMeRequest = () => ({
type: ME_FETCH_REQUEST,
});
const fetchMeSuccess = (account: CredentialAccount) => {
2023-10-12 18:07:48 -07:00
setSentryAccount(account);
return {
type: ME_FETCH_SUCCESS,
me: account,
};
};
const fetchMeFail = (error: unknown) => ({
type: ME_FETCH_FAIL,
error,
skipAlert: true,
});
const patchMeRequest = () => ({
type: ME_PATCH_REQUEST,
});
2023-06-28 15:53:17 -07:00
interface MePatchSuccessAction {
type: typeof ME_PATCH_SUCCESS;
me: CredentialAccount;
2023-06-28 15:53:17 -07:00
}
const patchMeSuccess = (me: CredentialAccount) =>
(dispatch: AppDispatch) => {
2023-06-28 15:53:17 -07:00
const action: MePatchSuccessAction = {
type: ME_PATCH_SUCCESS,
me,
2023-06-28 15:53:17 -07:00
};
dispatch(importFetchedAccount(me));
dispatch(action);
};
2023-10-23 15:22:10 -07:00
const patchMeFail = (error: unknown) => ({
type: ME_PATCH_FAIL,
error,
skipAlert: true,
});
2023-06-28 15:53:17 -07:00
type MeAction =
| ReturnType<typeof fetchMeRequest>
| ReturnType<typeof fetchMeSuccess>
| ReturnType<typeof fetchMeFail>
| ReturnType<typeof patchMeRequest>
| MePatchSuccessAction
| ReturnType<typeof patchMeFail>;
export {
ME_FETCH_REQUEST,
ME_FETCH_SUCCESS,
ME_FETCH_FAIL,
ME_FETCH_SKIP,
ME_PATCH_REQUEST,
ME_PATCH_SUCCESS,
ME_PATCH_FAIL,
fetchMe,
patchMe,
fetchMeRequest,
fetchMeSuccess,
fetchMeFail,
patchMeRequest,
patchMeSuccess,
patchMeFail,
2023-06-28 15:53:17 -07:00
type MeAction,
};