// Copyright 2021 The Casdoor 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 {Button, Col, Row} from "antd"; import i18next from "i18next"; import * as UserBackend from "../backend/UserBackend"; import * as Setting from "../Setting"; import * as Provider from "../auth/Provider"; import * as AuthBackend from "../auth/AuthBackend"; import {goToWeb3Url} from "../auth/ProviderButton"; import {delWeb3AuthToken} from "../auth/Web3Auth"; import AccountAvatar from "../account/AccountAvatar"; class OAuthWidget extends React.Component { constructor(props) { super(props); this.state = { classes: props, addressOptions: [], affiliationOptions: [], }; } UNSAFE_componentWillMount() { this.getAddressOptions(this.props.application); this.getAffiliationOptions(this.props.application, this.props.user); } getAddressOptions(application) { if (application.affiliationUrl === "") { return; } const addressUrl = application.affiliationUrl.split("|")[0]; UserBackend.getAddressOptions(addressUrl) .then((addressOptions) => { this.setState({ addressOptions: addressOptions, }); }); } getAffiliationOptions(application, user) { if (application.affiliationUrl === "") { return; } const affiliationUrl = application.affiliationUrl.split("|")[1]; const code = user.address[user.address.length - 1]; UserBackend.getAffiliationOptions(affiliationUrl, code) .then((affiliationOptions) => { this.setState({ affiliationOptions: affiliationOptions, }); }); } updateUserField(key, value) { this.props.onUpdateUserField(key, value); } unlinked() { this.props.onUnlinked(); } getProviderLink(user, provider) { if (provider.type === "GitHub") { return `https://github.com/${this.getUserProperty(user, provider.type, "username")}`; } else if (provider.type === "Google") { return "https://mail.google.com"; } else { return ""; } } getUserProperty(user, providerType, propertyName) { const key = `oauth_${providerType}_${propertyName}`; if (user.properties === null) {return "";} return user.properties[key]; } unlinkUser(providerType, linkedValue) { const body = { providerType: providerType, // should add the unlink user's info, cause the user may not be logged in, but a admin want to unlink the user. user: this.props.user, }; if (providerType === "MetaMask" || providerType === "Web3Onboard") { delWeb3AuthToken(linkedValue); } AuthBackend.unlink(body) .then((res) => { if (res.status === "ok") { Setting.showMessage("success", "Unlinked successfully"); this.unlinked(); } else { Setting.showMessage("error", `Failed to unlink: ${res.msg}`); } }); } renderIdp(user, application, providerItem) { const provider = providerItem.provider; const linkedValue = user[provider.type.toLowerCase()]; const profileUrl = this.getProviderLink(user, provider); const id = this.getUserProperty(user, provider.type, "id"); const username = this.getUserProperty(user, provider.type, "username"); const displayName = this.getUserProperty(user, provider.type, "displayName"); const email = this.getUserProperty(user, provider.type, "email"); let avatarUrl = this.getUserProperty(user, provider.type, "avatarUrl"); // the account user const account = this.props.account; if (avatarUrl === "" || avatarUrl === undefined) { avatarUrl = ""; } let name = (username === undefined) ? displayName : `${displayName} (${username})`; if (name === undefined) { if (id !== undefined) { name = id; } else if (email !== undefined) { name = email; } else { name = linkedValue; } } let linkButtonWidth = "110px"; if (Setting.getLanguage() === "id") { linkButtonWidth = "160px"; } return ( { Setting.getProviderLogo(provider) } { `${provider.type}:` } { linkedValue === "" ? ( `(${i18next.t("general:empty")})` ) : ( profileUrl === "" ? name : ( { name } ) ) } { linkedValue === "" ? ( provider.category === "Web3" ? ( ) : ( ) ) : ( ) } ); } render() { return this.renderIdp(this.props.user, this.props.application, this.props.providerItem); } } export default OAuthWidget;