2022-04-29 21:10:59 -07:00
|
|
|
import KVStore from 'soapbox/storage/kv_store';
|
2022-01-10 14:01:24 -08:00
|
|
|
import { getAuthUserId, getAuthUserUrl } from 'soapbox/utils/auth';
|
2022-01-10 14:25:06 -08:00
|
|
|
|
2020-04-01 19:20:47 -07:00
|
|
|
import api from '../api';
|
2022-01-10 14:25:06 -08:00
|
|
|
|
2021-10-20 14:27:36 -07:00
|
|
|
import { loadCredentials } from './auth';
|
2022-01-10 14:17:52 -08:00
|
|
|
import { importFetchedAccount } from './importer';
|
2020-04-01 19:20:47 -07:00
|
|
|
|
|
|
|
export const ME_FETCH_REQUEST = 'ME_FETCH_REQUEST';
|
|
|
|
export const ME_FETCH_SUCCESS = 'ME_FETCH_SUCCESS';
|
|
|
|
export const ME_FETCH_FAIL = 'ME_FETCH_FAIL';
|
2020-04-11 16:55:07 -07:00
|
|
|
export const ME_FETCH_SKIP = 'ME_FETCH_SKIP';
|
2020-04-01 19:20:47 -07:00
|
|
|
|
2020-04-21 13:53:32 -07:00
|
|
|
export const ME_PATCH_REQUEST = 'ME_PATCH_REQUEST';
|
2020-06-16 15:36:49 -07:00
|
|
|
export const ME_PATCH_SUCCESS = 'ME_PATCH_SUCCESS';
|
2020-04-21 13:53:32 -07:00
|
|
|
export const ME_PATCH_FAIL = 'ME_PATCH_FAIL';
|
|
|
|
|
2020-05-17 14:31:54 -07:00
|
|
|
const noOp = () => new Promise(f => f());
|
2020-04-17 14:08:07 -07:00
|
|
|
|
2021-08-21 14:54:53 -07:00
|
|
|
const getMeId = state => state.get('me') || getAuthUserId(state);
|
|
|
|
|
|
|
|
const getMeUrl = state => {
|
|
|
|
const accountId = getMeId(state);
|
|
|
|
return state.getIn(['accounts', accountId, 'url']) || getAuthUserUrl(state);
|
|
|
|
};
|
|
|
|
|
|
|
|
const getMeToken = state => {
|
|
|
|
// Fallback for upgrading IDs to URLs
|
|
|
|
const accountUrl = getMeUrl(state) || state.getIn(['auth', 'me']);
|
|
|
|
return state.getIn(['auth', 'users', accountUrl, 'access_token']);
|
|
|
|
};
|
|
|
|
|
2020-04-01 19:20:47 -07:00
|
|
|
export function fetchMe() {
|
|
|
|
return (dispatch, getState) => {
|
2021-08-21 18:41:29 -07:00
|
|
|
const state = getState();
|
|
|
|
const token = getMeToken(state);
|
|
|
|
const accountUrl = getMeUrl(state);
|
2021-03-23 17:06:55 -07:00
|
|
|
|
|
|
|
if (!token) {
|
2020-05-17 14:31:54 -07:00
|
|
|
dispatch({ type: ME_FETCH_SKIP }); return noOp();
|
2021-08-03 12:22:51 -07:00
|
|
|
}
|
2020-04-17 14:08:07 -07:00
|
|
|
|
2020-05-17 14:31:54 -07:00
|
|
|
dispatch(fetchMeRequest());
|
2021-10-20 14:27:36 -07:00
|
|
|
return dispatch(loadCredentials(token, accountUrl)).catch(error => {
|
2020-04-01 19:20:47 -07:00
|
|
|
dispatch(fetchMeFail(error));
|
2021-08-03 12:22:51 -07:00
|
|
|
});
|
2020-04-01 19:20:47 -07:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2022-04-29 21:10:59 -07:00
|
|
|
/** Update the auth account in IndexedDB for Mastodon, etc. */
|
|
|
|
const persistAuthAccount = (account, params) => {
|
|
|
|
if (account && account.url) {
|
|
|
|
if (!account.pleroma) account.pleroma = {};
|
|
|
|
|
|
|
|
if (!account.pleroma.settings_store) {
|
|
|
|
account.pleroma.settings_store = params.pleroma_settings_store || {};
|
|
|
|
}
|
|
|
|
KVStore.setItem(`authAccount:${account.url}`, account).catch(console.error);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2022-04-29 14:01:46 -07:00
|
|
|
export function patchMe(params, formData = false) {
|
2020-04-21 13:53:32 -07:00
|
|
|
return (dispatch, getState) => {
|
2020-04-21 16:00:05 -07:00
|
|
|
dispatch(patchMeRequest());
|
2022-04-29 14:01:46 -07:00
|
|
|
|
2022-04-29 19:41:41 -07:00
|
|
|
const options = formData ? {
|
|
|
|
headers: {
|
|
|
|
'Content-Type': 'multipart/form-data',
|
|
|
|
},
|
|
|
|
} : {};
|
2022-04-29 14:01:46 -07:00
|
|
|
|
2020-04-21 13:53:32 -07:00
|
|
|
return api(getState)
|
2022-04-29 14:01:46 -07:00
|
|
|
.patch('/api/v1/accounts/update_credentials', params, options)
|
2020-04-21 13:53:32 -07:00
|
|
|
.then(response => {
|
2022-04-29 21:10:59 -07:00
|
|
|
persistAuthAccount(response.data, params);
|
2020-06-16 15:36:49 -07:00
|
|
|
dispatch(patchMeSuccess(response.data));
|
2020-04-21 13:53:32 -07:00
|
|
|
}).catch(error => {
|
|
|
|
dispatch(patchMeFail(error));
|
2021-10-19 10:03:04 -07:00
|
|
|
throw error;
|
2020-04-21 13:53:32 -07:00
|
|
|
});
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2020-04-01 19:20:47 -07:00
|
|
|
export function fetchMeRequest() {
|
|
|
|
return {
|
|
|
|
type: ME_FETCH_REQUEST,
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
export function fetchMeSuccess(me) {
|
2020-04-21 16:00:05 -07:00
|
|
|
return (dispatch, getState) => {
|
|
|
|
dispatch({
|
|
|
|
type: ME_FETCH_SUCCESS,
|
|
|
|
me,
|
|
|
|
});
|
2020-04-01 19:20:47 -07:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
export function fetchMeFail(error) {
|
|
|
|
return {
|
|
|
|
type: ME_FETCH_FAIL,
|
|
|
|
error,
|
2020-06-07 15:18:26 -07:00
|
|
|
skipAlert: true,
|
2020-04-01 19:20:47 -07:00
|
|
|
};
|
2021-08-03 12:22:51 -07:00
|
|
|
}
|
2020-04-21 13:53:32 -07:00
|
|
|
|
|
|
|
export function patchMeRequest() {
|
|
|
|
return {
|
|
|
|
type: ME_PATCH_REQUEST,
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2020-06-16 15:36:49 -07:00
|
|
|
export function patchMeSuccess(me) {
|
|
|
|
return (dispatch, getState) => {
|
|
|
|
dispatch(importFetchedAccount(me));
|
|
|
|
dispatch({
|
|
|
|
type: ME_PATCH_SUCCESS,
|
|
|
|
me,
|
|
|
|
});
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2020-04-21 13:53:32 -07:00
|
|
|
export function patchMeFail(error) {
|
|
|
|
return {
|
|
|
|
type: ME_PATCH_FAIL,
|
|
|
|
error,
|
2021-10-19 10:03:04 -07:00
|
|
|
skipAlert: true,
|
2020-04-21 13:53:32 -07:00
|
|
|
};
|
2021-08-03 12:22:51 -07:00
|
|
|
}
|