From 0b96f6ae134b197fea2bfb2628b839f6748787ae Mon Sep 17 00:00:00 2001 From: YoungHypo Date: Mon, 7 Oct 2024 23:42:47 -0700 Subject: [PATCH 1/3] fix the bug of path-to-regexp upgrade Signed-off-by: YoungHypo --- src/dashboard/lambda/mock/matchMock.js | 12 ++++++------ src/dashboard/package.json | 2 +- .../src/components/PageHeaderWrapper/breadcrumb.js | 5 +++-- .../src/components/SiderMenu/SiderMenuUtils.js | 5 +++-- src/dashboard/src/pages/Authorized.js | 5 +++-- src/dashboard/src/utils/getPageTitle.js | 8 ++++++-- 6 files changed, 22 insertions(+), 15 deletions(-) diff --git a/src/dashboard/lambda/mock/matchMock.js b/src/dashboard/lambda/mock/matchMock.js index d74236126..e8db02eb0 100644 --- a/src/dashboard/lambda/mock/matchMock.js +++ b/src/dashboard/lambda/mock/matchMock.js @@ -1,4 +1,4 @@ -const pathToRegexp = require('path-to-regexp'); +const { pathToRegexp } = require('path-to-regexp'); const bodyParser = require('body-parser'); const mockFile = require('./index'); @@ -47,11 +47,11 @@ function normalizeConfig(config) { const handler = config[key]; const { method, path } = parseKey(key); const keys = []; - const re = pathToRegexp(path, keys); + const { regexp } = pathToRegexp(path, keys); memo.push({ method, path, - re, + regexp, keys, handler: createHandler(method, path, handler), }); @@ -83,9 +83,9 @@ function matchMock(req) { } // eslint-disable-next-line no-restricted-syntax for (const mock of mockData) { - const { method, re, keys } = mock; + const { method, regexp, keys } = mock; if (method === exceptMethod) { - const match = re.exec(req.path); + const match = regexp.exec(req.path); if (match) { const params = {}; @@ -104,7 +104,7 @@ function matchMock(req) { } } - return mockData.filter(({ method, re }) => method === exceptMethod && re.test(exceptPath))[0]; + return mockData.filter(({ method, regexp }) => method === exceptMethod && regexp.test(exceptPath))[0]; } module.exports = (req, res, next) => { const match = matchMock(req); diff --git a/src/dashboard/package.json b/src/dashboard/package.json index 26d22ada9..071854fdc 100644 --- a/src/dashboard/package.json +++ b/src/dashboard/package.json @@ -71,7 +71,7 @@ "numeral": "^2.0.6", "nzh": "^1.0.4", "omit.js": "^1.0.0", - "path-to-regexp": "^8.1.0", + "path-to-regexp": "^8.2.0", "prop-types": "^15.6.2", "qs": "^6.6.0", "rc-animate": "^2.6.0", diff --git a/src/dashboard/src/components/PageHeaderWrapper/breadcrumb.js b/src/dashboard/src/components/PageHeaderWrapper/breadcrumb.js index 3685759d1..d704d21f5 100644 --- a/src/dashboard/src/components/PageHeaderWrapper/breadcrumb.js +++ b/src/dashboard/src/components/PageHeaderWrapper/breadcrumb.js @@ -1,5 +1,5 @@ import React from 'react'; -import pathToRegexp from 'path-to-regexp'; +import { pathToRegexp } from 'path-to-regexp'; import { Link, formatMessage } from 'umi'; import { urlToList } from '../_utils/pathTools'; import { menu } from '../../defaultSettings'; @@ -33,7 +33,8 @@ export const getBreadcrumb = (breadcrumbNameMap, url) => { let breadcrumb = breadcrumbNameMap[url]; if (!breadcrumb) { Object.keys(breadcrumbNameMap).forEach(item => { - if (pathToRegexp(item).test(url)) { + const { regexp } = pathToRegexp(item); + if (regexp.test(url)) { breadcrumb = breadcrumbNameMap[item]; } }); diff --git a/src/dashboard/src/components/SiderMenu/SiderMenuUtils.js b/src/dashboard/src/components/SiderMenu/SiderMenuUtils.js index 6e04ec134..9353d135f 100644 --- a/src/dashboard/src/components/SiderMenu/SiderMenuUtils.js +++ b/src/dashboard/src/components/SiderMenu/SiderMenuUtils.js @@ -1,4 +1,4 @@ -import pathToRegexp from 'path-to-regexp'; +import { pathToRegexp } from 'path-to-regexp'; import { urlToList } from '../_utils/pathTools'; /** @@ -20,7 +20,8 @@ export const getFlatMenuKeys = menuData => { export const getMenuMatches = (flatMenuKeys, path) => flatMenuKeys.filter(item => { if (item) { - return pathToRegexp(item).test(path); + const { regexp } = pathToRegexp(item); + return regexp.test(path); } return false; }); diff --git a/src/dashboard/src/pages/Authorized.js b/src/dashboard/src/pages/Authorized.js index c6b85c1a7..bfa747a73 100644 --- a/src/dashboard/src/pages/Authorized.js +++ b/src/dashboard/src/pages/Authorized.js @@ -1,5 +1,5 @@ import React from 'react'; -import pathToRegexp from 'path-to-regexp'; +import { pathToRegexp } from 'path-to-regexp'; import { connect, Redirect } from 'umi'; import Authorized from '@/utils/Authorized'; import { getAuthority } from '@/utils/authority'; @@ -12,7 +12,8 @@ function AuthComponent({ children, location, routerData }) { let authorities; routeData.forEach(route => { // match prefix - if (pathToRegexp(`${route.path}(.*)`).test(path)) { + const { regexp } = pathToRegexp(`${route.path}(.*)`); + if (regexp.test(path)) { authorities = route.authority || authorities; // get children authority recursively diff --git a/src/dashboard/src/utils/getPageTitle.js b/src/dashboard/src/utils/getPageTitle.js index 7e507d00d..0192c734e 100644 --- a/src/dashboard/src/utils/getPageTitle.js +++ b/src/dashboard/src/utils/getPageTitle.js @@ -1,11 +1,15 @@ import { formatMessage } from 'umi'; -import pathToRegexp from 'path-to-regexp'; +import { pathToRegexp } from 'path-to-regexp'; import isEqual from 'lodash/isEqual'; import memoizeOne from 'memoize-one'; import { menu, title } from '../defaultSettings'; export const matchParamsPath = (pathname, breadcrumbNameMap) => { - const pathKey = Object.keys(breadcrumbNameMap).find(key => pathToRegexp(key).test(pathname)); + const pathKey = Object.keys(breadcrumbNameMap).find(key => { + const { regexp } = pathToRegexp(key); + return regexp.test(pathname); + }); + return breadcrumbNameMap[pathKey]; }; From 789373db62a7e9fa6c34b49523dc1cbe1f999d27 Mon Sep 17 00:00:00 2001 From: YoungHypo Date: Tue, 8 Oct 2024 00:06:17 -0700 Subject: [PATCH 2/3] delete the blankspace in getPageTitle Signed-off-by: YoungHypo --- src/dashboard/src/utils/getPageTitle.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/dashboard/src/utils/getPageTitle.js b/src/dashboard/src/utils/getPageTitle.js index 0192c734e..299cd31a2 100644 --- a/src/dashboard/src/utils/getPageTitle.js +++ b/src/dashboard/src/utils/getPageTitle.js @@ -9,7 +9,7 @@ export const matchParamsPath = (pathname, breadcrumbNameMap) => { const { regexp } = pathToRegexp(key); return regexp.test(pathname); }); - + return breadcrumbNameMap[pathKey]; }; From d86f5a90c8d043138c629fb4e84f52d45cf28e42 Mon Sep 17 00:00:00 2001 From: YoungHypo <92037433+YoungHypo@users.noreply.github.com> Date: Thu, 10 Oct 2024 23:21:39 -0700 Subject: [PATCH 3/3] Update Dockerfile of golang 1.23.1 Signed-off-by: YoungHypo <92037433+YoungHypo@users.noreply.github.com> --- build_image/docker/cello-hlf/Dockerfile | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/build_image/docker/cello-hlf/Dockerfile b/build_image/docker/cello-hlf/Dockerfile index a7eb7929b..382b4bfb6 100644 --- a/build_image/docker/cello-hlf/Dockerfile +++ b/build_image/docker/cello-hlf/Dockerfile @@ -21,7 +21,7 @@ # Workdir is set to $GOPATH/src/github.com/hyperledger/fabric # Data is stored under /var/hyperledger/production -FROM golang:1.22 +FROM golang:1.23.1 LABEL maintainer="Baohua Yang " # Orderer, peer, ca, operation api