mirror of
https://github.com/casdoor/casdoor.git
synced 2025-06-08 14:50:41 +08:00
110 lines
3.0 KiB
JavaScript
110 lines
3.0 KiB
JavaScript
// 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 {Alert, Button, message, Result} from "antd";
|
|
|
|
export function showMessage(type, text) {
|
|
if (type === "success") {
|
|
message.success(text);
|
|
} else if (type === "error") {
|
|
message.error(text);
|
|
}
|
|
}
|
|
|
|
export function renderMessage(msg) {
|
|
if (msg !== null) {
|
|
return (
|
|
<div style={{display: "inline"}}>
|
|
<Alert
|
|
message="Login Error"
|
|
showIcon
|
|
description={msg}
|
|
type="error"
|
|
action={
|
|
<Button size="small" danger>
|
|
Detail
|
|
</Button>
|
|
}
|
|
/>
|
|
</div>
|
|
)
|
|
} else {
|
|
return null;
|
|
}
|
|
}
|
|
|
|
export function renderMessageLarge(ths, msg) {
|
|
if (msg !== null) {
|
|
return (
|
|
<div style={{display: "inline"}}>
|
|
<Result
|
|
status="error"
|
|
title="There was a problem signing you in.."
|
|
subTitle={msg}
|
|
extra={[
|
|
<Button type="primary" key="back" onClick={() => {
|
|
window.history.go(-2);
|
|
}}>
|
|
Back
|
|
</Button>,
|
|
// <Button key="home" onClick={() => Setting.goToLinkSoft(ths, "/")}>
|
|
// Home
|
|
// </Button>,
|
|
// <Button type="primary" key="signup" onClick={() => Setting.goToLinkSoft(ths, "/signup")}>
|
|
// Sign Up
|
|
// </Button>,
|
|
]}
|
|
>
|
|
</Result>
|
|
</div>
|
|
)
|
|
} else {
|
|
return null;
|
|
}
|
|
}
|
|
|
|
export function getOAuthGetParameters(params) {
|
|
const queries = (params !== undefined) ? params : new URLSearchParams(window.location.search);
|
|
const clientId = queries.get("client_id");
|
|
const responseType = queries.get("response_type");
|
|
const redirectUri = queries.get("redirect_uri");
|
|
const scope = queries.get("scope");
|
|
const state = queries.get("state");
|
|
if (clientId === undefined) {
|
|
return null;
|
|
} else {
|
|
return {
|
|
clientId: clientId,
|
|
responseType: responseType,
|
|
redirectUri: redirectUri,
|
|
scope: scope,
|
|
state: state,
|
|
};
|
|
}
|
|
}
|
|
|
|
export function getQueryParamsToState(applicationName, providerName, method) {
|
|
let query = window.location.search;
|
|
query = `${query}&application=${applicationName}&provider=${providerName}&method=${method}`;
|
|
if (method === "link") {
|
|
query = `${query}&from=${window.location.pathname}`;
|
|
}
|
|
return btoa(query);
|
|
}
|
|
|
|
export function stateToGetQueryParams(state) {
|
|
return atob(state);
|
|
}
|