2021-08-22 08:52:02 -07:00
|
|
|
/**
|
|
|
|
* OAuth: create and revoke tokens.
|
|
|
|
* Tokens can be used by users and apps.
|
|
|
|
* https://docs.joinmastodon.org/methods/apps/oauth/
|
|
|
|
* @module soapbox/actions/oauth
|
|
|
|
* @see module:soapbox/actions/auth
|
|
|
|
*/
|
|
|
|
|
2021-08-21 17:37:28 -07:00
|
|
|
import { baseClient } from '../api';
|
|
|
|
|
2022-06-10 10:56:22 -07:00
|
|
|
import type { AppDispatch } from 'soapbox/store';
|
|
|
|
|
2021-08-21 17:37:28 -07:00
|
|
|
export const OAUTH_TOKEN_CREATE_REQUEST = 'OAUTH_TOKEN_CREATE_REQUEST';
|
|
|
|
export const OAUTH_TOKEN_CREATE_SUCCESS = 'OAUTH_TOKEN_CREATE_SUCCESS';
|
|
|
|
export const OAUTH_TOKEN_CREATE_FAIL = 'OAUTH_TOKEN_CREATE_FAIL';
|
|
|
|
|
|
|
|
export const OAUTH_TOKEN_REVOKE_REQUEST = 'OAUTH_TOKEN_REVOKE_REQUEST';
|
|
|
|
export const OAUTH_TOKEN_REVOKE_SUCCESS = 'OAUTH_TOKEN_REVOKE_SUCCESS';
|
|
|
|
export const OAUTH_TOKEN_REVOKE_FAIL = 'OAUTH_TOKEN_REVOKE_FAIL';
|
|
|
|
|
2022-07-11 09:34:14 -07:00
|
|
|
export const obtainOAuthToken = (params: Record<string, string | undefined>, baseURL?: string) =>
|
2022-06-10 10:56:22 -07:00
|
|
|
(dispatch: AppDispatch) => {
|
2021-08-21 17:37:28 -07:00
|
|
|
dispatch({ type: OAUTH_TOKEN_CREATE_REQUEST, params });
|
2021-08-22 12:34:58 -07:00
|
|
|
return baseClient(null, baseURL).post('/oauth/token', params).then(({ data: token }) => {
|
2021-08-21 17:37:28 -07:00
|
|
|
dispatch({ type: OAUTH_TOKEN_CREATE_SUCCESS, params, token });
|
|
|
|
return token;
|
|
|
|
}).catch(error => {
|
2021-09-08 09:08:22 -07:00
|
|
|
dispatch({ type: OAUTH_TOKEN_CREATE_FAIL, params, error, skipAlert: true });
|
2021-08-21 17:37:28 -07:00
|
|
|
throw error;
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
2022-06-10 10:56:22 -07:00
|
|
|
export const revokeOAuthToken = (params: Record<string, string>) =>
|
|
|
|
(dispatch: AppDispatch) => {
|
2021-08-21 17:37:28 -07:00
|
|
|
dispatch({ type: OAUTH_TOKEN_REVOKE_REQUEST, params });
|
|
|
|
return baseClient().post('/oauth/revoke', params).then(({ data }) => {
|
|
|
|
dispatch({ type: OAUTH_TOKEN_REVOKE_SUCCESS, params, data });
|
|
|
|
return data;
|
|
|
|
}).catch(error => {
|
|
|
|
dispatch({ type: OAUTH_TOKEN_REVOKE_FAIL, params, error });
|
|
|
|
throw error;
|
|
|
|
});
|
|
|
|
};
|