// Copyright 2021 The casbin Authors. All Rights Reserved. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. import React from "react"; import {Spin} from "antd"; import {withRouter} from "react-router-dom"; import * as AuthBackend from "./AuthBackend"; import * as Util from "./Util"; import {authConfig} from "./Auth"; import * as Setting from "../Setting"; class AuthCallback extends React.Component { constructor(props) { super(props); this.state = { classes: props, msg: null, }; } getInnerParams() { // For example, for Casbin-OA, realRedirectUri = "http://localhost:9000/login" // realRedirectUrl = "http://localhost:9000" const params = new URLSearchParams(this.props.location.search); const state = params.get("state"); return new URLSearchParams(Util.stateToGetQueryParams(state)); } getResponseType() { // "http://localhost:8000" const authServerUrl = authConfig.serverUrl; const innerParams = this.getInnerParams(); const realRedirectUri = innerParams.get("redirect_uri"); const realRedirectUrl = new URL(realRedirectUri).origin; // For Casdoor itself, we use "login" directly if (authServerUrl === realRedirectUrl) { return "login"; } else { return "code"; } } UNSAFE_componentWillMount() { const params = new URLSearchParams(this.props.location.search); const innerParams = this.getInnerParams(); const applicationName = innerParams.get("application"); const providerName = innerParams.get("provider"); const method = innerParams.get("method"); let redirectUri = `${window.location.origin}/callback`; const body = { type: this.getResponseType(), application: applicationName, provider: providerName, code: params.get("code"), state: innerParams.get("state"), redirectUri: redirectUri, method: method, }; const oAuthParams = Util.getOAuthGetParameters(innerParams); AuthBackend.login(body, oAuthParams) .then((res) => { if (res.status === 'ok') { const responseType = this.getResponseType(); if (responseType === "login") { Util.showMessage("success", `Logged in successfully`); Setting.goToLinkSoft(this, "/"); } else if (responseType === "code") { const code = res.data; Setting.goToLink(`${oAuthParams.redirectUri}?code=${code}&state=${oAuthParams.state}`); // Util.showMessage("success", `Authorization code: ${res.data}`); } } else { this.setState({ msg: res.msg, }); } }); } render() { return (