// Copyright 2022 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 {Card, Col, Divider, Progress, Row, Spin} from "antd"; import * as SystemBackend from "./backend/SystemInfo"; import React from "react"; import * as Setting from "./Setting"; import i18next from "i18next"; class SystemInfo extends React.Component { constructor(props) { super(props); this.state = { systemInfo: {cpuUsage: [], memoryUsed: 0, memoryTotal: 0}, versionInfo: {}, intervalId: null, loading: true, }; } UNSAFE_componentWillMount() { SystemBackend.getSystemInfo().then(res => { this.setState({ systemInfo: res.data, loading: false, }); const id = setInterval(() => { SystemBackend.getSystemInfo().then(res => { this.setState({ systemInfo: res.data, }); }).catch(error => { Setting.showMessage("error", `System info failed to get: ${error}`); }); }, 1000 * 3); this.setState({intervalId: id}); }).catch(error => { Setting.showMessage("error", `System info failed to get: ${error}`); }); SystemBackend.getVersionInfo().then(res => { this.setState({ versionInfo: res.data, }); }).catch(err => { Setting.showMessage("error", `Version info failed to get: ${err}`); }); } componentWillUnmount() { if (this.state.intervalId !== null) { clearInterval(this.state.intervalId); } } render() { const cpuUi = this.state.systemInfo.cpuUsage?.length <= 0 ? i18next.t("system:Get CPU Usage Failed") : this.state.systemInfo.cpuUsage.map((usage, i) => { return ( ); }); const memUi = this.state.systemInfo.memoryUsed && this.state.systemInfo.memoryTotal && this.state.systemInfo.memoryTotal <= 0 ? i18next.t("system:Get Memory Usage Failed") :
{Setting.getFriendlyFileSize(this.state.systemInfo.memoryUsed)} / {Setting.getFriendlyFileSize(this.state.systemInfo.memoryTotal)}

; const link = this.state.versionInfo?.version !== "" ? `https://github.com/casdoor/casdoor/releases/tag/${this.state.versionInfo?.version}` : ""; let versionText = this.state.versionInfo?.version !== "" ? this.state.versionInfo?.version : i18next.t("system:Unknown Version"); if (this.state.versionInfo?.commitOffset > 0) { versionText += ` (ahead+${this.state.versionInfo?.commitOffset})`; } if (!Setting.isMobile()) { return ( {this.state.loading ? : cpuUi} {this.state.loading ? : memUi}
{i18next.t("system:An Identity and Access Management (IAM) / Single-Sign-On (SSO) platform with web UI supporting OAuth 2.0, OIDC, SAML and CAS")}
GitHub: Casdoor
{i18next.t("system:Version")}: {versionText}
{i18next.t("system:Official Website")}: https://casdoor.org
{i18next.t("system:Community")}: Get in Touch!
); } else { return ( {this.state.loading ? : cpuUi} {this.state.loading ? : memUi}
{i18next.t("system:An Identity and Access Management (IAM) / Single-Sign-On (SSO) platform with web UI supporting OAuth 2.0, OIDC, SAML and CAS")}
GitHub: Casdoor
{i18next.t("system:Version")}: {versionText}
{i18next.t("system:Official Website")}: https://casdoor.org
{i18next.t("system:Community")}: Get in Touch!
); } } } export default SystemInfo;