|
|
@@ -1,3 +1,5 @@
|
|
|
+import fetch from 'dva/fetch';
|
|
|
+
|
|
|
export const dva = {
|
|
|
config: {
|
|
|
onError(err) {
|
|
|
@@ -6,6 +8,37 @@ export const dva = {
|
|
|
},
|
|
|
};
|
|
|
|
|
|
+let authRoutes = {};
|
|
|
+
|
|
|
+function ergodicRoutes(routes, authKey, authority) {
|
|
|
+ routes.forEach(element => {
|
|
|
+ if (element.path === authKey) {
|
|
|
+ if (!element.authority) element.authority = []; // eslint-disable-line
|
|
|
+ Object.assign(element.authority, authority || []);
|
|
|
+ } else if (element.routes) {
|
|
|
+ ergodicRoutes(element.routes, authKey, authority);
|
|
|
+ }
|
|
|
+ return element;
|
|
|
+ });
|
|
|
+}
|
|
|
+
|
|
|
+export function patchRoutes(routes) {
|
|
|
+ Object.keys(authRoutes).map(authKey =>
|
|
|
+ ergodicRoutes(routes, authKey, authRoutes[authKey].authority)
|
|
|
+ );
|
|
|
+ window.g_routes = routes;
|
|
|
+}
|
|
|
+
|
|
|
export function render(oldRender) {
|
|
|
- oldRender();
|
|
|
+ fetch('/api/auth_routes')
|
|
|
+ .then(res => res.json())
|
|
|
+ .then(
|
|
|
+ ret => {
|
|
|
+ authRoutes = ret;
|
|
|
+ oldRender();
|
|
|
+ },
|
|
|
+ () => {
|
|
|
+ oldRender();
|
|
|
+ }
|
|
|
+ );
|
|
|
}
|