mirror of
https://github.com/astuto/astuto.git
synced 2025-12-15 03:07:52 +01:00
- Added Site settings > Authentication section - Create/edit/delete your custom oauth2 configurations - Login or signup with oauth2
98 lines
2.6 KiB
TypeScript
98 lines
2.6 KiB
TypeScript
import { Action } from "redux";
|
|
import { ThunkAction } from "redux-thunk";
|
|
import { ISiteSettingsOAuthForm } from "../../components/SiteSettings/Authentication/OAuthForm";
|
|
import HttpStatus from "../../constants/http_status";
|
|
import buildRequestHeaders from "../../helpers/buildRequestHeaders";
|
|
import { IOAuthJSON } from "../../interfaces/IOAuth";
|
|
import { State } from "../../reducers/rootReducer";
|
|
|
|
export const OAUTH_UPDATE_START = 'OAUTH_UPDATE_START';
|
|
interface OAuthUpdateStartAction {
|
|
type: typeof OAUTH_UPDATE_START;
|
|
}
|
|
|
|
export const OAUTH_UPDATE_SUCCESS = 'OAUTH_UPDATE_SUCCESS';
|
|
interface OAuthUpdateSuccessAction {
|
|
type: typeof OAUTH_UPDATE_SUCCESS;
|
|
oAuth: IOAuthJSON;
|
|
}
|
|
|
|
export const OAUTH_UPDATE_FAILURE = 'OAUTH_UPDATE_FAILURE';
|
|
interface OAuthUpdateFailureAction {
|
|
type: typeof OAUTH_UPDATE_FAILURE;
|
|
error: string;
|
|
}
|
|
|
|
export type OAuthUpdateActionTypes =
|
|
OAuthUpdateStartAction |
|
|
OAuthUpdateSuccessAction |
|
|
OAuthUpdateFailureAction;
|
|
|
|
const oAuthUpdateStart = (): OAuthUpdateStartAction => ({
|
|
type: OAUTH_UPDATE_START,
|
|
});
|
|
|
|
const oAuthUpdateSuccess = (
|
|
oAuthJSON: IOAuthJSON,
|
|
): OAuthUpdateSuccessAction => ({
|
|
type: OAUTH_UPDATE_SUCCESS,
|
|
oAuth: oAuthJSON,
|
|
});
|
|
|
|
const oAuthUpdateFailure = (error: string): OAuthUpdateFailureAction => ({
|
|
type: OAUTH_UPDATE_FAILURE,
|
|
error,
|
|
});
|
|
|
|
interface UpdateOAuthParams {
|
|
id: number;
|
|
form?: ISiteSettingsOAuthForm;
|
|
isEnabled?: boolean;
|
|
authenticityToken: string;
|
|
}
|
|
|
|
export const updateOAuth = ({
|
|
id,
|
|
form = null,
|
|
isEnabled = null,
|
|
authenticityToken,
|
|
}: UpdateOAuthParams): ThunkAction<void, State, null, Action<string>> => async (dispatch) => {
|
|
dispatch(oAuthUpdateStart());
|
|
|
|
const o_auth = Object.assign({},
|
|
form !== null ? {
|
|
name: form.name,
|
|
logo: form.logo,
|
|
client_id: form.clientId,
|
|
client_secret: form.clientSecret,
|
|
authorize_url: form.authorizeUrl,
|
|
token_url: form.tokenUrl,
|
|
profile_url: form.profileUrl,
|
|
scope: form.scope,
|
|
json_user_email_path: form.jsonUserEmailPath,
|
|
json_user_name_path: form.jsonUserNamePath,
|
|
} : null,
|
|
isEnabled !== null ? {is_enabled: isEnabled} : null,
|
|
);
|
|
|
|
try {
|
|
const res = await fetch(`/o_auths/${id}`, {
|
|
method: 'PATCH',
|
|
headers: buildRequestHeaders(authenticityToken),
|
|
body: JSON.stringify({o_auth}),
|
|
});
|
|
const json = await res.json();
|
|
|
|
if (res.status === HttpStatus.OK) {
|
|
dispatch(oAuthUpdateSuccess(json));
|
|
} else {
|
|
dispatch(oAuthUpdateFailure(json.error));
|
|
}
|
|
|
|
return Promise.resolve(res);
|
|
} catch (e) {
|
|
dispatch(oAuthUpdateFailure(e));
|
|
|
|
return Promise.resolve(null);
|
|
}
|
|
}; |