Skip to content

Feat: Enhance service method retrieval and invocation features#1429

Merged
robocanic merged 38 commits into
apache:developfrom
Similarityoung:feature/generic
Mar 29, 2026
Merged

Feat: Enhance service method retrieval and invocation features#1429
robocanic merged 38 commits into
apache:developfrom
Similarityoung:feature/generic

Conversation

@Similarityoung
Copy link
Copy Markdown
Contributor

@Similarityoung Similarityoung commented Mar 8, 2026

Description

This PR adds structured service method introspection, provider instance discovery, and generic invoke capabilities to the Dubbo Admin console. It also tightens the generic invoke contract so that parameter types are resolved from provider metadata instead of being supplied by the client, and makes retry behavior safer for non-idempotent calls.

What changed

  • Added console APIs for service method and provider discovery:

    • GET /api/v1/service/provider-instances

    • GET /api/v1/service/methods

    • GET /api/v1/service/method/detail

    • POST /api/v1/service/generic/invoke


To help us figure out who should review this PR, please put an X in all the areas that this PR affects.

  • Docs
  • Installation
  • User Experience
  • Dubboctl
  • Console
  • Core Component

Copilot AI review requested due to automatic review settings March 8, 2026 09:44
Copy link
Copy Markdown
Contributor

Copilot AI left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Pull request overview

This PR adds service method introspection endpoints and a metadata-driven generic invocation flow to the Dubbo Admin console, shifting generic invoke parameter type resolution from client input to provider metadata.

Changes:

  • Added console APIs for listing service methods, fetching method details (including signature/types closure), and performing generic invoke.
  • Implemented provider-metadata-based overload resolution via methodName + signature and refactored generic invoke argument decoding using []json.RawMessage.
  • Updated ZK node creation flag usage and bumped/adjusted Go module dependencies to support the new generic invoke implementation.

Reviewed changes

Copilot reviewed 8 out of 9 changed files in this pull request and generated 4 comments.

Show a summary per file
File Description
pkg/governor/zk/governor.go Adjusts ZK node creation flags for compatibility.
pkg/console/service/service_generic_invoke_decode.go Adds typed argument decoding helpers for generic invoke based on resolved parameter types.
pkg/console/service/service_generic_invoke.go Implements generic invoke flow: metadata lookup, overload resolution, target selection, and RPC invocation.
pkg/console/service/service.go Adds provider-metadata-backed method discovery and method detail/type-closure building.
pkg/console/router/router.go Registers new service routes for methods, method detail, and generic invoke under /api/v1/service.
pkg/console/model/service.go Adds request/response models for method discovery, method detail, and generic invoke (including signature and raw args).
pkg/console/handler/service.go Adds handlers wiring the new endpoints to service layer functions.
go.mod Updates dubbo-go dependency and adds hessian2 + other indirects needed for new invoke path.
go.sum Updates dependency checksums accordingly.

💡 Add Copilot custom instructions for smarter, more guided reviews. Learn how to get started.

Comment thread pkg/console/service/service.go Outdated
Comment on lines +59 to +84
var invokeGenericServiceRPC = func(callCtx context.Context, invocation genericInvocation) (any, error) {
ins, err := dubbo.NewInstance(dubbo.WithName(genericInvokeInstanceName))
if err != nil {
return nil, err
}

cli, err := ins.NewClient(
client.WithClientProtocolTriple(),
client.WithClientSerialization(dubboconstant.Hessian2Serialization),
)
if err != nil {
return nil, err
}

svc, err := cli.NewGenericService(
invocation.ServiceName,
client.WithURL(invocation.URL),
client.WithVersion(invocation.Version),
client.WithGroup(invocation.Group),
)
if err != nil {
return nil, err
}

return svc.Invoke(callCtx, invocation.MethodName, invocation.ParameterTypes, invocation.Args)
}
Copy link

Copilot AI Mar 8, 2026

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

invokeGenericServiceRPC creates a new Dubbo instance + client + generic service on every invocation. This is likely expensive and may also accumulate background resources (connections, goroutines) depending on the dubbo-go implementation. Consider initializing and reusing a singleton instance/client (and, if possible, a cached generic service per service/version/group) with proper lifecycle management instead of rebuilding everything per request.

Copilot uses AI. Check for mistakes.
Copy link
Copy Markdown
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Optimization can be made in the future

Copy link
Copy Markdown
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

copilot这里说的有道理,这里可以在代码里记一个todo,加上client的缓存

Comment thread pkg/console/service/service_generic_invoke.go Outdated
Comment thread pkg/console/service/service_generic_invoke_decode.go
@Similarityoung
Copy link
Copy Markdown
Contributor Author


Code review

Found 1 issue:

  1. Generic invoke leaks raw upstream/internal RPC errors back to the client instead of following the console's usual stable InternalError pattern. The rest of pkg/console/service returns fixed user-facing messages and logs the cause server-side, but this new path returns err.Error() directly, which can expose transport/provider details and make API responses inconsistent.

if err != nil {
logger.Errorf("generic invoke failed, service=%s, method=%s, providerApp=%s, target=%s:%d, cause: %v",
req.ServiceName, req.MethodName, providerAppName, target.instance.Spec.Ip, target.port, err)
return nil, bizerror.New(bizerror.InternalError, err.Error())
}

🤖 Generated with Claude Code

- If this code review was useful, please react with 👍. Otherwise, react with 👎.


Copy link
Copy Markdown
Contributor

@robocanic robocanic left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Great Work! I left some comments and hope you can discuss them with me.

Comment thread pkg/console/model/service.go
Comment thread pkg/console/service/service.go Outdated
Comment thread pkg/console/service/service.go Outdated
Comment thread pkg/console/service/service_generic_invoke.go Outdated
Comment on lines +59 to +84
var invokeGenericServiceRPC = func(callCtx context.Context, invocation genericInvocation) (any, error) {
ins, err := dubbo.NewInstance(dubbo.WithName(genericInvokeInstanceName))
if err != nil {
return nil, err
}

cli, err := ins.NewClient(
client.WithClientProtocolTriple(),
client.WithClientSerialization(dubboconstant.Hessian2Serialization),
)
if err != nil {
return nil, err
}

svc, err := cli.NewGenericService(
invocation.ServiceName,
client.WithURL(invocation.URL),
client.WithVersion(invocation.Version),
client.WithGroup(invocation.Group),
)
if err != nil {
return nil, err
}

return svc.Invoke(callCtx, invocation.MethodName, invocation.ParameterTypes, invocation.Args)
}
Copy link
Copy Markdown
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

copilot这里说的有道理,这里可以在代码里记一个todo,加上client的缓存

Similarityoung and others added 16 commits March 8, 2026 22:37
- 添加环境变量 `VITE_MOCK_ENABLED` 用于启用 mock 数据模式
- 更新 `package.json` 脚本以添加 `dev:mock` 用于 mock 数据开发环境
- 新增 `mockLogin.ts` 文件,提供 mock 登录和登出接口
- 修改 `request.ts`,根据环境变量切换请求的 `baseURL`
- 优化 `main.ts`,根据 mock 模式自动导入 mock API 并更新认证状态
- 新增 axios 作为 HTTP 客户端依赖
- 优化 mock 数据接口,包括应用指标、流量权重、灰度配置等
- 更新 package.json 文件以添加 axios 依赖
- 修改多个 mock 接口以适应新的架构和数据结构
Copy link
Copy Markdown
Contributor

@robocanic robocanic left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Great work @Similarityoung @ikun-Lg , I left some comments and hope you can discuss them with me for better PR.

Comment thread pkg/console/model/service.go Outdated
<a-col :span="12">
<div class="section-title">响应:</div>
<div class="editor-wrapper">
<monaco-editor
Copy link
Copy Markdown
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggestion: 响应里面的rawResult json转义之后放到编辑器里面,elapasedMs可以放到编辑器外面提示用户耗时Image

Comment thread pkg/console/service/service.go Outdated
Comment thread pkg/console/service/service.go Outdated
Comment thread pkg/console/service/service.go Outdated
ikun-Lg and others added 10 commits March 28, 2026 00:26
Migrate from mockjs to Mock Service Worker (MSW) for a more realistic
mock setup that intercepts at the network level. This eliminates the
need for a separate mock baseURL and simplifies the mock architecture.

- Remove mockjs dependency and all src/api/mock/* files
- Add msw with browser worker and handler-based mock definitions
- Move mock data to src/mocks/ with per-domain handler organization
- Add shared API type definitions in src/types/api.ts
- Simplify request.ts baseURL (always /api/v1, MSW handles interception)
- Update main.ts mock initialization to use MSW worker
@robocanic
Copy link
Copy Markdown
Contributor

robocanic commented Mar 29, 2026

pls merge the develop branch and resolve conflicts

Copy link
Copy Markdown
Contributor

@robocanic robocanic left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Great work! There are style enhancements of two components that I think is worth doing, hope @ikun-Lg can make it.

</a-tabs>
<a-card :bordered="false" :body-style="{ padding: '24px' }">
<div class="tabs-title">方法列表</div>
<a-spin :spinning="loadingMethods">
Copy link
Copy Markdown
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggestion: 方法列表的方法选中态的背景色能置为主体色或者区分得更明显一些吗,因为字体比较细,有点看不太清

Image

<a-col :span="8">
<div class="section-title">调用实例:</div>
<a-select
v-model:value="instanceName"
Copy link
Copy Markdown
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

instanceName直接用接口返回的name即可,不用自己拼PixPin_2026-03-29_09-39-56

Image

@sonarqubecloud
Copy link
Copy Markdown

Copy link
Copy Markdown
Contributor

@robocanic robocanic left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM.

@robocanic robocanic merged commit 5c94d18 into apache:develop Mar 29, 2026
5 checks passed
robocanic added a commit that referenced this pull request May 10, 2026
* feat: informer general framework and engine/discovery interface definition (#1314)

* feat: informer general framework and engine/discovery interface definition

* fix: ci problem; directory and dependency tidy (#1320)

* fix: ci probelm; diretory and dependency tidy

* fix: lack license header

* rm: remove redundant file

* ci(makefile): add makefile for ci (#1322)

* ci(makefile): add makefile for ci

* style(ci): rename dubbo-admin ci

* delete unused ci (#1326)

* fix: refractor web handler and service to fix compile error; (#1325)

* fix: refractor web handler and service to fix compile error;

* feat: support memory type of store (#1332)

* feat: support memory type of store

* fix: muilti indexes should use intersecection

* simplify code

Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>

* refractor: GetByKeys return a list instead of map

---------

Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>

* feat: support kubernetes as a backend engine (#1340)

* feat: implement runtime engine using kubernetes

* feat: Defined a unified error (#1353)

* feat: unified error code; separate application handler and service into parts

* fix: license header lack

* fix: copilot review err fix

* fix: simplify the if-else condition

* chore: rename Error() to String()

* chore: add extra String() in Error

* feat: 新增listMeshes接口

* fix: copilot review

* Implment Counter in local cache (#1345)

* fix: update response interceptor to handle success and error messages more accurately (#1355)

* feat(UI): Support multiple registries (#1356)

* feat(#1352): Support multiple registries: add registry select box and refresh main area on change

* doc(build): build ui

* fix(#1352): Set first available mesh after login when no mesh is set

* doc(build): build ui

* fix(conflict)

* doc(build): build ui

* feat: implement mysql and postgresql store for resources (#1360)

* feat: implement mysql and postgresql store for resources

* fix some issues

* ut: add some test cases

* fix: dynamic table name

* feat: implements discovery backend by nacos (#1367)

* feat: support nacos2 to do discovery

* refractor: abstract nacos and nacos service

* fix: unit test and license header

* fix: copilot review problem

* chore: remove redundant code

* fix counter bug (#1369)

* fix: add indexer before init cause npe (#1372)

* fix: add indexer before init cause npe

* fix: unit test

* Fix: Redirect to login page when receiving 401 unauthorized response from API (#1373)

* feat: enhance error handling for unauthorized access and improve toast messages

* feat: enhance error handling for unauthorized access and improve toast messages

* fix: correct syntax error in response interceptor for redirect handling

* Update ui-vue3/src/base/http/request.ts

Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>

* feat: add YAML and XML editor components, update index references, and enhance error logging

- Introduced new JavaScript files for YAML and XML syntax highlighting and editing capabilities.
- Added a new component for updating YAML configurations with a structured editor interface.
- Updated the index.html to reference the new JavaScript bundle for improved functionality.
- Enhanced the HTTP request module to log errors during redirection on 401 responses for better debugging.

---------

Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>

* feat: implement discovery backend by zk (#1371)

* feat: implements discovery backend by zk

* feat: support components to start in dependency order (#1370)

* feat: support components to start in dependency order

* imporve

* fix

* fix error import

* release changelog (#1376)

* changelog

* chore: rename refactor to enhancements

* refactor: 🎨 Optimize UI styles and search functionality (#1379)

* feat: enhance error handling for unauthorized access and improve toast messages

* feat: enhance error handling for unauthorized access and improve toast messages

* fix: correct syntax error in response interceptor for redirect handling

* Update ui-vue3/src/base/http/request.ts

Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>

* feat: add YAML and XML editor components, update index references, and enhance error logging

- Introduced new JavaScript files for YAML and XML syntax highlighting and editing capabilities.
- Added a new component for updating YAML configurations with a structured editor interface.
- Updated the index.html to reference the new JavaScript bundle for improved functionality.
- Enhanced the HTTP request module to log errors during redirection on 401 responses for better debugging.

* docs: Only supports exact matching; remove the "prefix search" function from the placeholder (background word)

* docs: All sorting indicators for lists are initially hidden, including but not limited to the list pages for applications, instances, services, and traffic management

* refactor: 🎨 Optimize the styles of some tables and adapt to backend changes

* docs: api baseurl

---------

Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>

* feat(ui): Enhance service metrics display and optimize table UI styles (#1383)

* build: Optimize the styles of some tables, adapt to backend changes, format the code, and package it

* chore: remove PR_DESCRIPTION.md file as it is no longer needed

* fix: update routing rule handling

updated routing rule handling to use constants for HTTP status codes in various components.

* build: build & format

* feat: enhance error handling and data loading in various components (#1385)

* build: Optimize the styles of some tables, adapt to backend changes, format the code, and package it

* chore: remove PR_DESCRIPTION.md file as it is no longer needed

* fix: update routing rule handling

updated routing rule handling to use constants for HTTP status codes in various components.

* build: build & format

* feat: enhance error handling and data loading in various components

- Added a silent error handling mechanism for specific URLs in the HTTP request module to suppress error messages.
- Refactored data loading logic in sceneConfig.vue to load configuration data based on the selected tab, improving user experience.
- Updated YAMLView.vue and other components to remove unused button code and optimize imports, enhancing code clarity and maintainability.
- Improved error handling in routingRule and dynamicConfig components to ensure better user feedback and debugging.

* feat: add new components and enhance YAML and XML editing capabilities

- Introduced new JavaScript files for YAML and XML syntax highlighting and editing.
- Added components for updating YAML configurations with structured editor interfaces.
- Updated index.html to reference new JavaScript bundles for improved functionality.
- Enhanced error handling and logging in various components for better debugging.
- Removed unused code and optimized imports in YAMLView and related components.

* feat: fix console bugs and makes console functions effective (#1378)

* fix: console interfaces;feat: implements governor using zk and nacos

* fix: instance subscriber

* fix: unit-test

* fix: rules search

* resolve conflicts

* fix: backend bugs

* fix: rule handler and service refactor

* fix: config error andd field mapping

* fix: rename msg to message

* fix: wrap prometheus error

* fix ci

* feat: add deploy manifests and fix metric and trace dashboard bugs (#1387)

* feat: add monitoring/dubbo-samples-shop/dubbo-system resources

* fix: metric, trace dashboard bug

* Fix: Address the admin issues before the release (#1391)

* build: Optimize the styles of some tables, adapt to backend changes, format the code, and package it

* chore: remove PR_DESCRIPTION.md file as it is no longer needed

* fix: update routing rule handling

updated routing rule handling to use constants for HTTP status codes in various components.

* build: build & format

* feat: enhance error handling and data loading in various components

- Added a silent error handling mechanism for specific URLs in the HTTP request module to suppress error messages.
- Refactored data loading logic in sceneConfig.vue to load configuration data based on the selected tab, improving user experience.
- Updated YAMLView.vue and other components to remove unused button code and optimize imports, enhancing code clarity and maintainability.
- Improved error handling in routingRule and dynamicConfig components to ensure better user feedback and debugging.

* feat: add new components and enhance YAML and XML editing capabilities

- Introduced new JavaScript files for YAML and XML syntax highlighting and editing.
- Added components for updating YAML configurations with structured editor interfaces.
- Updated index.html to reference new JavaScript bundles for improved functionality.
- Enhanced error handling and logging in various components for better debugging.
- Removed unused code and optimized imports in YAMLView and related components.

* feat: enhance UI components and improve error handling

- Added global styles for clickable links in tables to improve user interaction.
- Updated routing logic to utilize a dynamic header parameter key for better flexibility.
- Enhanced error handling in HTTP requests to suppress messages for specific URLs.
- Improved internationalization by adding new translation keys for 'Ready Time' in both English and Chinese.
- Refactored various components to optimize code structure and maintainability, including updates to YAML and form views.
- Adjusted table and form layouts for better responsiveness and user experience.

* refactor: streamline component code and enhance condition handling

- Simplified iframe rendering in GrafanaPage.vue for improved readability.
- Added checks in ConfigModel.ts to skip undefined keys in matches and parameters.
- Optimized YAMLView.vue by condensing MonacoEditor properties for better clarity.
- Cleared default request and address matching arrays in formView.vue for cleaner initialization.
- Enhanced condition parsing and merging logic in updateByFormView.vue to improve maintainability and readability.

* build: build admin

* fix: add Apache License headers to YAML files in release/kubernetes (#1393)

* feat: enhance UI components, improve error handling, and add routing rule management (#1394)

* build: Optimize the styles of some tables, adapt to backend changes, format the code, and package it

* chore: remove PR_DESCRIPTION.md file as it is no longer needed

* fix: update routing rule handling

updated routing rule handling to use constants for HTTP status codes in various components.

* build: build & format

* feat: enhance error handling and data loading in various components

- Added a silent error handling mechanism for specific URLs in the HTTP request module to suppress error messages.
- Refactored data loading logic in sceneConfig.vue to load configuration data based on the selected tab, improving user experience.
- Updated YAMLView.vue and other components to remove unused button code and optimize imports, enhancing code clarity and maintainability.
- Improved error handling in routingRule and dynamicConfig components to ensure better user feedback and debugging.

* feat: add new components and enhance YAML and XML editing capabilities

- Introduced new JavaScript files for YAML and XML syntax highlighting and editing.
- Added components for updating YAML configurations with structured editor interfaces.
- Updated index.html to reference new JavaScript bundles for improved functionality.
- Enhanced error handling and logging in various components for better debugging.
- Removed unused code and optimized imports in YAMLView and related components.

* feat: enhance UI components and improve error handling

- Added global styles for clickable links in tables to improve user interaction.
- Updated routing logic to utilize a dynamic header parameter key for better flexibility.
- Enhanced error handling in HTTP requests to suppress messages for specific URLs.
- Improved internationalization by adding new translation keys for 'Ready Time' in both English and Chinese.
- Refactored various components to optimize code structure and maintainability, including updates to YAML and form views.
- Adjusted table and form layouts for better responsiveness and user experience.

* refactor: streamline component code and enhance condition handling

- Simplified iframe rendering in GrafanaPage.vue for improved readability.
- Added checks in ConfigModel.ts to skip undefined keys in matches and parameters.
- Optimized YAMLView.vue by condensing MonacoEditor properties for better clarity.
- Cleared default request and address matching arrays in formView.vue for cleaner initialization.
- Enhanced condition parsing and merging logic in updateByFormView.vue to improve maintainability and readability.

* build: build admin

* fix: improve error handling and UI updates in GrafanaPage and sceneConfig components

- Added conditional checks in GrafanaPage.vue to ensure valid baseURL before constructing the Grafana URL.
- Enhanced iframe loading logic to prevent errors when accessing undefined elements.
- Updated service.vue to handle potential undefined values in versionGroups, ensuring robust data handling.
- Refactored sceneConfig.vue to improve the user experience by adding a conditional rendering for parameter routes, including a message for empty configurations and a button for adding new routes.

* refactor: Request to update the Grafana URL

* build: build

* ♻️ refactor: update route parameters to include name and make pathId/appName optional

Update routing structure across instance and traffic management views to:
- Add :name parameter to routes for better identification
- Make :pathId and :appName optional parameters (with ?)
- Affects instance detail, monitor, link tracking, and configuration tabs
- Updates dynamic config, routing rule, and tag rule views accordingly

This change provides more flexible routing and better resource identification.

Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>

* ✨ feat(routing): add routing rule list component and composable

Add new RoutingRuleList component and useRoutingRule composable to manage routing rule configurations. Updates addByFormView and updateByFormView to integrate with the new components.

Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>

* build: format & build

* ✨ feat(routing): enhance routing rule form with comprehensive i18n support

Enhance routing rule form functionality with improved internationalization,
user interface refinements, and better form handling.

- Add comprehensive i18n translations for routing rule fields
- Improve form layout and field descriptions
- Enhance routing rule list component with better UX
- Refactor routing rule composable for better maintainability
- Update tab header slots for improved navigation

Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>

* build: format & build

---------

Co-authored-by: Claude Sonnet 4.5 <noreply@anthropic.com>

* Fix/console (#1397)

* fix: create tag rule bug

* refactor: config refactor; fix: fix console bugs

* fix: instance disable traffic

* fix: CI promblems

* fix: typo

* fix(ui): update footer copyright year to 2026 (#1396)

* implement counter by key (#1390)

* implement counter by key

* chore: trigger CI

* Fix counter initialization errors and mesh change detection logic

---------

Co-authored-by: WyRainBow <your-email@example.com>

* feat: kubernetes deployment manifests and docker file (#1410)

* refactor: refactor dockerfile and implement dubbo-admin deployment

* fix: deploy manifests

* rm: remove useless files (#1416)

* feat: implement distributed lock by gorm (#1432)

* feat: add leader election for Discovery, Engine, Counter.(#1423)

* feat: add leader election for Discovery and Engine components

* fix: separate renew/acquire SQL and stop informers on demotion

* feat: add leader election for Counter component

* fix: resolve copilot review suggestion

* fix: GormStore.Pool return value

* Feat: Enhance service method retrieval and invocation features (#1429)

* feat: add endpoint to retrieve service method names and corresponding request model

* feat: add endpoint and logic to retrieve service method details

* feat: trim whitespace from service name, mesh, group, version, and provider app name in ServiceMethodsReq

* feat: enhance service method handling with overload support and signature retrieval

* feat: add generic service invocation support

* feat: refactor triple RPC instance selection to use a dedicated target struct

* feat: remove obsolete service methods test file

* feat: improve error handling in generic service invocation and add parameter count validation

* feat: remove unnecessary variable and directly call service.InvokeServiceGeneric in ServiceGenericInvoke

* feat: improve query validation by using strutil for blank checks and enhance service provider metadata indexing

* feat: add endpoint to retrieve service provider instances and enhance request validation

* feat: update service provider instance handling and improve request validation

* feat: enhance generic service invocation with protocol and serialization support

* feat: add normalization functions for JSON values in generic service invocation

* feat: add normalization functions for JSON values in generic service invocation

* feat: refine retry logic for service invocation failures

* feat(ui-vue3): 添加 mock 数据支持,优化请求配置

- 添加环境变量 `VITE_MOCK_ENABLED` 用于启用 mock 数据模式
- 更新 `package.json` 脚本以添加 `dev:mock` 用于 mock 数据开发环境
- 新增 `mockLogin.ts` 文件,提供 mock 登录和登出接口
- 修改 `request.ts`,根据环境变量切换请求的 `baseURL`
- 优化 `main.ts`,根据 mock 模式自动导入 mock API 并更新认证状态

* feat(ui-vue3): 新增 Axios 依赖和 mock 数据接口

- 新增 axios 作为 HTTP 客户端依赖
- 优化 mock 数据接口,包括应用指标、流量权重、灰度配置等
- 更新 package.json 文件以添加 axios 依赖
- 修改多个 mock 接口以适应新的架构和数据结构

* feat(api): 新增 mock 服务方法列表、详情及泛化调用接口

* feat(api): add front func

* feat(ui-vue3): improve func empty description

* feat(ui-vue3): code format

* feat(api): update mock interface

* feat(ui-vue3): add elapsed time display for service debug invoke

* refactor: replace mockjs with MSW for API mocking

Migrate from mockjs to Mock Service Worker (MSW) for a more realistic
mock setup that intercepts at the network level. This eliminates the
need for a separate mock baseURL and simplifies the mock architecture.

- Remove mockjs dependency and all src/api/mock/* files
- Add msw with browser worker and handler-based mock definitions
- Move mock data to src/mocks/ with per-domain handler organization
- Add shared API type definitions in src/types/api.ts
- Simplify request.ts baseURL (always /api/v1, MSW handles interception)
- Update main.ts mock initialization to use MSW worker

* feat(api): refactor service request handling to use BaseServiceReq

* feat(api): simplify service provider metadata lookup logic

* feat(api): streamline service method resolution and metadata handling

* feat(api): enhance ServiceGenericInvokeReq structure and streamline metadata handling

* style(debug): format icon imports for improved readability

* refactor(api): simplify splitGenericArrayType function by removing redundant checks

* chore(deps): downgrade msw and related dependencies to version 2.11.6

* style(debug): improve debug tab UI with typography components and refined styles

* style(debug): refine button and typography styles for improved consistency

---------

Co-authored-by: 劳资蜀道山 <1493170339@qq.com>

* feat: extend indexer with prefix matching and db persistence (#1422)

* feat: extend indexer with prefix matching and db persistence

* refactor: remove in-memory index from GormStore and add operator field

* fix: copilot review suggestion and service panic

* update

* feat: unify and enhance the lifecycle of an instance (#1440)

* feat: add lifecycle state management and color coding for instance statuses

* feat: enhance instance lifecycle management with state derivation and UI updates

* feat: improve resource handling in informer with enhanced error reporting

* feat: enhance instance lifecycle logging with detailed merge and delete events

* feat: implement ResourceKeyProvider interface for consistent key generation in informers

* refactor: refactor instance resource handling and key function resolution in informers

* refactor: remove unused deployState and registerState columns from instance table

* feat: enhance runtime instance retrieval with improved matching logic and fallback handling

* feat: improve runtime instance identification with enhanced error logging and filtering

* feat: add pod watch selector and RPC port identifiers for improved service configuration

* feat: add refresh button and localization support for improved user interaction

* fix: fix lint

* feat: enhance runtime instance retrieval with improved fallback handling and logging for ambiguous matches

* fix: enhance instance lifecycle and deployment state management with new types and improved data handling

* feat(eventbus): support per-subscriber async dispatch with graceful drain (#1455)

* feat(eventbus): support per-subscriber async dispatch with graceful drain

* refactor(config): unify AdminConfig method receivers as pointers

* refactor(eventbus): move AsyncEnabled into Subscriber with docs

* fix(config): keep read-only helpers on value receiver

* refactor(config): unify AdminConfig receiver style

* feat(mcp): add Model Context Protocol (MCP) server with HTTP transport and authentication

## Summary
Implement Model Context Protocol (MCP) server for Dubbo Admin to enable AI integration through standardized tool interfaces.

## Key Features
- **Modular Architecture**: Core components (server, registry, tools, transport, types)
- **Comprehensive Tool Support**: 11 tools covering cluster info, service discovery, instance management, metrics, and application details
- **Dual Transport Support**:
  - Stdio transport for local Claude Desktop integration
  - HTTP transport for remote connections with JSON-RPC 2.0
- **Security**: Optional Bearer Token authentication for HTTP endpoint

## Configuration

## Test plan
- [x] Unit tests for core components
- [x] Integration tests
- [x] Manual testing with Claude Desktop

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>

* Service/Application Dependency Graph Implement (#1460)

* feat(ui): Added application and service topology mapping feature

* style(ui-vue3): Add a minimum width to the login form and remove unnecessary blank lines

* Feat: Add service and application topology graph APIs based on discussion #1398

* feat(api): add GraphServices endpoint for service-level topology

Based on discussion #1398, use ServiceProviderMetadata and ServiceConsumerMetadata
to return provider/consumer application relations as graph nodes and edges for AntV G6.

* feat(api): add GraphApplications endpoint for application-level topology

Traverse provider/consumer service relations to build application-level graph.
Also add idx_service_consumer_service_key index to support efficient serviceKey queries.

* feat(api): add graph models (GraphNode, GraphEdge, GraphData) in pkg/console/model/graph.go

* feat(api): add ApplicationGraphReq, ServiceGraphReq and GetApplicationGraph, GetServiceGraph handlers

* feat(router): register /application/graph and /service/graph routes

* feat(api): fix error handling to use direct err pass-through instead of MeshNotFoundError

* Feat: Enhance service metadata derivation and detail retrieval ([#1430](#1430))

* feat(api): replace Service.{providers,consumers,features} with {methods} field

Simplify Service proto by removing providers, consumers, and features map,
keeping only the aggregated methods list derived from provider metadata.

* feat(api): derive Service resource from ServiceProviderMetadata on add/update/delete

ServiceProviderMetadataEventSubscriber now maintains Service resources by
aggregating methods from all provider instances sharing the same serviceKey.
Handles add, update, and delete events to keep Service spec in sync.

* feat(api): add language detection from provider metadata parameters

Detect provider language (golang/java) from metadata parameters and method
type signatures when explicit language field is absent.

* feat(api): add GetServiceDetail endpoint returning language and methods

Add GET /service/detail returning ServiceDetailResp with language and
aggregated method names from the derived Service resource.

* feat(api): add BuildServiceIdentityKey helper for {service}:{version}:{group}

* feat(api): add ByServiceName index for ServiceKind

* feat(api): refactor SearchServices to query ServiceResource directly

SearchServices and SearchServicesByKeywords now use ServiceResource instead
of ServiceProviderMetadataResource for service listing.

* feat(api): remove providerAppName from ServiceSearchResp and ServiceTabDistributionReq

* feat(api): add ServiceDetailReq and ServiceDetailResp models

* feat(router): register /service/detail and /service/interfaces routes

* feat(ui-vue3): remove providerAppName from grafana types and tab components

* chore: Add G6 chart library and its dependencies to the project

* chore(assets): Add Apache license and format code for iconfont file

* fix: Correct the naming errors in the application topology graph API parameters and improve the code comments

* chore: minor cleanup - fix comment language and import order

* chore: translate Chinese comment to English in GraphApplications error handling
* chore: reorder imports in service_provider_metadata.go

* fix:Fix parameter passing error when obtaining application details

* fix: fix type mismatch and index issues in service search and metadata sync

  1. pkg/console/service/service.go:132
     - fix generic type mismatch with resourceKind
     - generic ServiceResource should use ServiceKind, was incorrectly passing ServiceProviderMetadataKind
     - index changed from ByServiceProviderServiceName to ByServiceName (aligned with ServiceKind)

  2. pkg/core/discovery/subscriber/service_provider_metadata.go
     - processUpdate: remove redundant oldRes key check (oldKey always equals newKey in same resource update,
       else branch is unreachable dead code)
     - syncService: use ByServiceProviderServiceKey index instead of ByServiceProviderServiceName
       + manual version/group filtering, reduces data returned from DB and improves performance
       Ref: [1460](#1460 (comment))

* Feat: Add coding agent domain skills ([#1457](#1457))

* feat(skills): add backend domain skills for runtime, discovery, engine, events, store, and Console API

Document component lifecycle, ListAndWatch discovery, resource engine behavior, EventBus dispatching, storage indexes, and Web MVC flow for coding agents.

* feat(skills): add frontend domain skill for routing, components, and traffic rule forms

Document Vue frontend structure, API clients, Pinia state, route metadata, layout tabs, and traffic rule form design.

* feat(skills): add OpenAI skill metadata

Add agents/openai.yaml metadata for each dubbo-admin domain skill.

* fix(console): use ServiceKind for service list search

Query ServiceResource from ServiceKind instead of ServiceProviderMetadataKind so the non-keyword service list path uses the matching resource store and index set.

---------

Co-authored-by: sohandsomejie <3080955413@qq.com>
Co-authored-by: MoChengqian <2972013548@qq.com>

---------

Co-authored-by: robb <robocanic@gmail.com>
Co-authored-by: marsevilspirit <marsevilspirit@gmail.com>
Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
Co-authored-by: WyRainBow <weiyu9484@gmail.com>
Co-authored-by: LGgbond <1493170339@qq.com>
Co-authored-by: Helltab <939255879@qq.com>
Co-authored-by: Tew <finntew@outlook.com>
Co-authored-by: EVERFID <166227111+everfid-ever@users.noreply.github.com>
Co-authored-by: Claude Sonnet 4.5 <noreply@anthropic.com>
Co-authored-by: Akshit Vig <akshitvig48@gmail.com>
Co-authored-by: WyRainBow <your-email@example.com>
Co-authored-by: EVERFID <3085640487@qq.com>
Co-authored-by: ThunGuo <tew@apache.org>
Co-authored-by: Zerui Yang <zeruiyoung@gmail.com>
Co-authored-by: LunaRain_079 <2074730050@qq.com>
Co-authored-by: Comrade Yi <119987662+ambiguous-pointer@users.noreply.github.com>
Co-authored-by: sohandsomejie <3080955413@qq.com>
Co-authored-by: MoChengqian <2972013548@qq.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

4 participants