// 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"; class AuthCallback extends React.Component { constructor(props) { super(props); const params = new URLSearchParams(this.props.location.search); this.state = { classes: props, applicationName: props.match.params.applicationName, providerName: props.match.params.providerName, method: props.match.params.method, state: params.get("state"), code: params.get("code"), isAuthenticated: false, isSignedUp: false, email: "" }; } componentWillMount() { let redirectUri; redirectUri = `${window.location.origin}/callback/${this.state.applicationName}/${this.state.providerName}/${this.state.method}`; const body = { application: this.state.applicationName, provider: this.state.providerName, code: this.state.code, state: this.state.state, redirectUri: redirectUri, method: this.state.method, }; AuthBackend.login(body) .then((res) => { if (res.status === "ok") { window.location.href = '/'; } else { Util.showMessage("error", res?.msg); } }); } render() { return (
) } } export default withRouter(AuthCallback);