默认权限设置为空

feature/pivot
YCC 2 years ago
parent 21e70b9dfb
commit 23de7481bd

12
package-lock.json generated

@ -7283,9 +7283,9 @@
} }
}, },
"node_modules/caniuse-lite": { "node_modules/caniuse-lite": {
"version": "1.0.30001458", "version": "1.0.30001553",
"resolved": "https://registry.npmmirror.com/caniuse-lite/-/caniuse-lite-1.0.30001458.tgz", "resolved": "https://registry.npmmirror.com/caniuse-lite/-/caniuse-lite-1.0.30001553.tgz",
"integrity": "sha512-lQ1VlUUq5q9ro9X+5gOEyH7i3vm+AYVT1WDCVB69XOZ17KZRhnZ9J0Sqz7wTHQaLBJccNCHq8/Ww5LlOIZbB0w==" "integrity": "sha512-N0ttd6TrFfuqKNi+pMgWJTb9qrdJu4JSpgPFLe/lrD19ugC6fZgF0pUewRowDwzdDnb9V41mFcdlYgl/PyKf4A=="
}, },
"node_modules/case-sensitive-paths-webpack-plugin": { "node_modules/case-sensitive-paths-webpack-plugin": {
"version": "2.4.0", "version": "2.4.0",
@ -26806,9 +26806,9 @@
} }
}, },
"caniuse-lite": { "caniuse-lite": {
"version": "1.0.30001458", "version": "1.0.30001553",
"resolved": "https://registry.npmmirror.com/caniuse-lite/-/caniuse-lite-1.0.30001458.tgz", "resolved": "https://registry.npmmirror.com/caniuse-lite/-/caniuse-lite-1.0.30001553.tgz",
"integrity": "sha512-lQ1VlUUq5q9ro9X+5gOEyH7i3vm+AYVT1WDCVB69XOZ17KZRhnZ9J0Sqz7wTHQaLBJccNCHq8/Ww5LlOIZbB0w==" "integrity": "sha512-N0ttd6TrFfuqKNi+pMgWJTb9qrdJu4JSpgPFLe/lrD19ugC6fZgF0pUewRowDwzdDnb9V41mFcdlYgl/PyKf4A=="
}, },
"case-sensitive-paths-webpack-plugin": { "case-sensitive-paths-webpack-plugin": {
"version": "2.4.0", "version": "2.4.0",

@ -1,25 +1,25 @@
import { makeAutoObservable, runInAction } from "mobx"; import { makeAutoObservable, runInAction } from 'mobx';
import * as dd from "dingtalk-jsapi"; import * as dd from 'dingtalk-jsapi';
import * as config from "../config"; import * as config from '../config';
// 权限管理 // 权限管理
class AuthStore { class AuthStore {
constructor(rootStore) { constructor(rootStore) {
this.rootStore = rootStore; this.rootStore = rootStore;
makeAutoObservable(this); makeAutoObservable(this);
if (process.env.NODE_ENV == "production") { if (process.env.NODE_ENV === 'production') {
this.get_auth(); // 放到钉钉环境才能开启 this.get_auth(); // 放到钉钉环境才能开启
} }
} }
auth = ["admin"]; // 开发时候用,正式环境留空 auth = process.env.NODE_ENV === 'production' ? [] : ['admin']; // 开发时候用,正式环境留空
user = { name: "loading", userid: "..." }; // 开发时候用,正式环境留空 user = { name: 'loading', userid: '...' }; // 开发时候用,正式环境留空
has_permission(requireds) { has_permission(requireds) {
if (Object.keys(requireds).length == 0) { if (Object.keys(requireds).length === 0) {
return true; return true;
} }
const has_permission = requireds.filter(item => this.auth.includes(item)); const has_permission = requireds.filter((item) => this.auth.includes(item));
if (Object.keys(has_permission).length !== 0) { if (Object.keys(has_permission).length !== 0) {
return true; return true;
} }
@ -29,24 +29,24 @@ class AuthStore {
// 请求权限 // 请求权限
get_auth() { get_auth() {
const _this = this; const _this = this;
const CORPID = "ding48bce8fd3957c96b"; // 企业的id const CORPID = 'ding48bce8fd3957c96b'; // 企业的id
dd.runtime.permission.requestAuthCode({ dd.runtime.permission.requestAuthCode({
corpId: CORPID, corpId: CORPID,
onSuccess: function (res) { onSuccess: function (res) {
console.log(res); console.log(res);
const code = res.code; const code = res.code;
const url = "/dingtalk/dingtalkwork/Getusers_auth?code=" + code; const url = '/dingtalk/dingtalkwork/Getusers_auth?code=' + code;
// 请求获取HT接口获取用户权限和用户信息 // 请求获取HT接口获取用户权限和用户信息
fetch(config.HT_HOST + url) fetch(config.HT_HOST + url)
.then(response => response.json()) .then((response) => response.json())
.then(json => { .then((json) => {
runInAction(() => { runInAction(() => {
_this.user = json.result; _this.user = json.result;
_this.auth = json.result.authlist; _this.auth = json.result.authlist;
}); });
}) })
.catch(error => { .catch((error) => {
console.log("fetch data failed", error); console.log('fetch data failed', error);
}); });
}, },
onFail: function (err) { onFail: function (err) {

@ -1,36 +1,25 @@
import React, {useContext, useEffect} from 'react'; import React, { useContext, useEffect } from 'react';
import {Row, Col, Button, Tabs, Spin, Result, Space} from 'antd'; import { Row, Col, Button, Tabs, Spin, Result, Space } from 'antd';
import { import { ContainerOutlined, SearchOutlined } from '@ant-design/icons';
ContainerOutlined, import { stores_Context } from '../config';
SearchOutlined, import { Line } from '@ant-design/charts';
} from '@ant-design/icons'; import { observer } from 'mobx-react';
import {stores_Context} from '../config';
import {Line} from "@ant-design/charts";
import {observer} from 'mobx-react';
import DatePickerCharts from '../components/search/DatePickerCharts'; import DatePickerCharts from '../components/search/DatePickerCharts';
import {NavLink, useParams,Outlet, useOutlet, useLocation, useNavigate} from "react-router-dom"; import { NavLink, useParams, Outlet, useOutlet, useLocation, useNavigate } from 'react-router-dom';
import * as comm from "../utils/commons"; import * as comm from '../utils/commons';
import * as config from "../config"; import * as config from '../config';
const ProtectedRoute = ({auth}) => { const ProtectedRoute = ({ auth }) => {
const {auth_store} = useContext(stores_Context); const { auth_store } = useContext(stores_Context);
if (auth_store.has_permission(auth)) { if (auth_store.has_permission(auth)) {
return <Outlet/>; return <Outlet />;
} }
return ( return (
<div> <div>
<Result <Result status="403" title="403 权限不足" subTitle={'试着联系一下技术,所需权限: ' + auth.toString()} extra={auth_store.user.name + '(' + auth_store.user.userid + ')'} />
status="403"
title="403 权限不足"
subTitle={"试着联系一下技术,所需权限: "+auth.toString()}
extra=''
/>
</div> </div>
); );
}; };
export default observer(ProtectedRoute); export default observer(ProtectedRoute);

Loading…
Cancel
Save