123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242 |
- // 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 {Link} from "react-router-dom";
- import {Button, Table} from "antd";
- import moment from "moment";
- import * as Setting from "./Setting";
- import * as CertBackend from "./backend/CertBackend";
- import i18next from "i18next";
- import BaseListPage from "./BaseListPage";
- import PopconfirmModal from "./common/modal/PopconfirmModal";
- class CertListPage extends BaseListPage {
- newCert() {
- const randomName = Setting.getRandomName();
- return {
- owner: "admin", // this.props.account.certname,
- name: `cert_${randomName}`,
- createdTime: moment().format(),
- displayName: `New Cert - ${randomName}`,
- scope: "JWT",
- type: "x509",
- cryptoAlgorithm: "RS256",
- bitSize: 4096,
- expireInYears: 20,
- certificate: "",
- privateKey: "",
- };
- }
- addCert() {
- const newCert = this.newCert();
- CertBackend.addCert(newCert)
- .then((res) => {
- if (res.status === "ok") {
- this.props.history.push({pathname: `/certs/${newCert.name}`, mode: "add"});
- Setting.showMessage("success", i18next.t("general:Successfully added"));
- } else {
- Setting.showMessage("error", `${i18next.t("general:Failed to add")}: ${res.msg}`);
- }
- })
- .catch(error => {
- Setting.showMessage("error", `${i18next.t("general:Failed to connect to server")}: ${error}`);
- });
- }
- deleteCert(i) {
- CertBackend.deleteCert(this.state.data[i])
- .then((res) => {
- if (res.status === "ok") {
- Setting.showMessage("success", i18next.t("general:Successfully deleted"));
- this.setState({
- data: Setting.deleteRow(this.state.data, i),
- pagination: {total: this.state.pagination.total - 1},
- });
- } else {
- Setting.showMessage("error", `${i18next.t("general:Failed to delete")}: ${res.msg}`);
- }
- })
- .catch(error => {
- Setting.showMessage("error", `${i18next.t("general:Failed to connect to server")}: ${error}`);
- });
- }
- renderTable(certs) {
- const columns = [
- {
- title: i18next.t("general:Name"),
- dataIndex: "name",
- key: "name",
- width: "120px",
- fixed: "left",
- sorter: true,
- ...this.getColumnSearchProps("name"),
- render: (text, record, index) => {
- return (
- <Link to={`/certs/${text}`}>
- {text}
- </Link>
- );
- },
- },
- {
- title: i18next.t("general:Created time"),
- dataIndex: "createdTime",
- key: "createdTime",
- width: "180px",
- sorter: true,
- render: (text, record, index) => {
- return Setting.getFormattedDate(text);
- },
- },
- {
- title: i18next.t("general:Display name"),
- dataIndex: "displayName",
- key: "displayName",
- // width: '100px',
- sorter: true,
- ...this.getColumnSearchProps("displayName"),
- },
- {
- title: i18next.t("provider:Scope"),
- dataIndex: "scope",
- key: "scope",
- filterMultiple: false,
- filters: [
- {text: "JWT", value: "JWT"},
- ],
- width: "110px",
- sorter: true,
- },
- {
- title: i18next.t("provider:Type"),
- dataIndex: "type",
- key: "type",
- filterMultiple: false,
- filters: [
- {text: "x509", value: "x509"},
- ],
- width: "110px",
- sorter: true,
- },
- {
- title: i18next.t("cert:Crypto algorithm"),
- dataIndex: "cryptoAlgorithm",
- key: "cryptoAlgorithm",
- filterMultiple: false,
- filters: [
- {text: "RS256", value: "RS256"},
- ],
- width: "190px",
- sorter: true,
- },
- {
- title: i18next.t("cert:Bit size"),
- dataIndex: "bitSize",
- key: "bitSize",
- width: "130px",
- sorter: true,
- ...this.getColumnSearchProps("bitSize"),
- },
- {
- title: i18next.t("cert:Expire in years"),
- dataIndex: "expireInYears",
- key: "expireInYears",
- width: "170px",
- sorter: true,
- ...this.getColumnSearchProps("expireInYears"),
- },
- {
- title: i18next.t("general:Action"),
- dataIndex: "",
- key: "op",
- width: "170px",
- fixed: (Setting.isMobile()) ? "false" : "right",
- render: (text, record, index) => {
- return (
- <div>
- <Button style={{marginTop: "10px", marginBottom: "10px", marginRight: "10px"}} type="primary" onClick={() => this.props.history.push(`/certs/${record.name}`)}>{i18next.t("general:Edit")}</Button>
- <PopconfirmModal
- title={i18next.t("general:Sure to delete") + `: ${record.name} ?`}
- onConfirm={() => this.deleteCert(index)}
- >
- </PopconfirmModal>
- </div>
- );
- },
- },
- ];
- const paginationProps = {
- total: this.state.pagination.total,
- showQuickJumper: true,
- showSizeChanger: true,
- showTotal: () => i18next.t("general:{total} in total").replace("{total}", this.state.pagination.total),
- };
- return (
- <div>
- <Table scroll={{x: "max-content"}} columns={columns} dataSource={certs} rowKey="name" size="middle" bordered pagination={paginationProps}
- title={() => (
- <div>
- {i18next.t("general:Certs")}
- <Button type="primary" size="small" onClick={this.addCert.bind(this)}>{i18next.t("general:Add")}</Button>
- </div>
- )}
- loading={this.state.loading}
- onChange={this.handleTableChange}
- />
- </div>
- );
- }
- fetch = (params = {}) => {
- let field = params.searchedColumn, value = params.searchText;
- const sortField = params.sortField, sortOrder = params.sortOrder;
- if (params.category !== undefined && params.category !== null) {
- field = "category";
- value = params.category;
- } else if (params.type !== undefined && params.type !== null) {
- field = "type";
- value = params.type;
- }
- this.setState({loading: true});
- CertBackend.getCerts("admin", params.pagination.current, params.pagination.pageSize, field, value, sortField, sortOrder)
- .then((res) => {
- if (res.status === "ok") {
- this.setState({
- loading: false,
- data: res.data,
- pagination: {
- ...params.pagination,
- total: res.data2,
- },
- searchText: params.searchText,
- searchedColumn: params.searchedColumn,
- });
- } else {
- if (Setting.isResponseDenied(res)) {
- this.setState({
- loading: false,
- isAuthorized: false,
- });
- }
- }
- });
- };
- }
- export default CertListPage;
|