--- name: netx-coding description: Use when implementing code changes in the netx repository across Rust crates, controller/core runtime, protocol DTOs, Admin Console, Desktop Core UI, build scripts, or verification flows. --- # netx 编码 ## 使用场景 在 `/root/Projects/Mine/netx` 中写代码、修 bug、改构建、改 API、改 UI 时使用。 ## 先读 按任务读取: - 通用编码:`docs/specs/coding-guide.md` - 架构边界:`docs/specs/architecture.md` - 协议字段:`docs/specs/protocol.md` - UI:`docs/specs/ui-design.md` - 需求状态:`docs/specs/traceability.md` ## 当前边界 只维护: - `netx-controller` - `netx-core` - `apps/netx-desktop` - `web/admin` 新增入口必须归入这些产品边界。 ## 修改位置 | 任务 | 位置 | | --- | --- | | 控制 API、状态投影、任务、controller state/bootstrap/metrics/API DTO 聚合 | `crates/netx-controller/src/state.rs`、`bootstrap_plan.rs`、`runtime_metrics.rs`、`control_api_models.rs`、其它 `control_api_*` 模块 | | Controller audit/session API、managed session 执行和 system metrics/diagnostics | `crates/netx-controller/src/sessions.rs`、`sessions_diagnostics.rs` | | Controller core plan、gateway assignment helper 和 service projection | `crates/netx-controller/src/core_planner.rs`、`core_planner_gateway.rs`、`core_planner_http.rs`、`core_planner_services.rs` | | Controller embedded gateway handler、bridge accept、hosted service supervisor、public/mixed entry、HTTP entry、HTTP3、HTTPS passthrough/terminate、routing/http/body/backend/connection 适配 | `crates/netx-controller/src/gateway_http_entry.rs`、`gateway_bridge_accept.rs`、`gateway_hosted_services.rs`、`gateway_public_entry.rs`、`gateway_mixed_entry.rs`、`gateway_http3.rs`、`gateway_https_passthrough.rs`、`gateway_https_terminate.rs`、`gateway_routing.rs`、`gateway_http.rs`、`gateway_body.rs`、`gateway_backend.rs`、`gateway_connection.rs` | | Core 运行编排、heartbeat loop state、DeliveredConfig managed client/service/proxy/overlay runtime config selection、initial service/proxy selection、NAT probe binding snapshot、peer engine tick/requested-attempt TTL state、punch ready/候选排序/端口扫描策略和 punch attempt 到 peer identity 映射 | `crates/netx-core-runtime` | | 共享路由、执行计划、path selection | `crates/netx-core-engine` | | 本机 Local API | `crates/netx-core-local` | | Core service 命令、低阶 CLI runtime、Controller API 命令、解析和报告 | `apps/netx-core/src/cli_service.rs`、`cli_local_runtime.rs`、`cli_controller_api.rs`、`cli_parse.rs`、`cli_reports.rs` | | Core app session 前置/attached/bootstrap/startup/overlay/loop | `apps/netx-core/src/client_session.rs`、`client_session_attached.rs`、`client_session_bootstrap.rs`、`client_session_startup.rs`、`client_session_overlay.rs`、`client_session_loop.rs` | | Core overlay hosts/DNS/resolved/NRPT 和 Linux transparent TCP intercept 执行胶水 | `apps/netx-core/src/overlay_integration.rs`、`overlay_transparent_proxy.rs` | | Core local proxy 监听、协议 helper、NETX path、上游 TLS 和 proxy chain helper | `apps/netx-core/src/local_proxy.rs`、`local_proxy_protocol.rs`、`local_proxy_netx.rs`、`local_proxy_tls.rs`、`local_proxy_chain.rs` | | Core NAT probe、punch poll、UDP/TCP punch 执行和直连/relay 隧道循环 | `apps/netx-core/src/punch_nat_probe.rs`、`punch.rs`、`punch_tunnel.rs` | | 配置 | `crates/netx-config` | | Wire DTO | `crates/netx-proto/src/wire.rs` | | UI DTO | `crates/netx-ui-api` | | 存储 service 注册/加载、service row mapping 和 overlay relay port 分配 | `crates/netx-control/src/service_store.rs` | | 存储 service validation、service parse/normalize helper 和 service auth JSON helper | `crates/netx-control/src/service_validation.rs` | | 存储控制面入口、overview、core state 聚合和剩余共享 validation/helper 方法 | `crates/netx-control/src/lib.rs` | | StoreExecutor async wrapper | `crates/netx-control/src/executor.rs` | | 存储 schema/open/migration/backfill | `crates/netx-control/src/schema.rs` | | 存储 kv/singleton JSON helper | `crates/netx-control/src/kv.rs` | | 存储 service token 生命周期 | `crates/netx-control/src/service_tokens.rs` | | 存储 task/audit 持久层 | `crates/netx-control/src/audit_tasks.rs` | | 存储 admin principal/token | `crates/netx-control/src/admin_store.rs` | | 存储节点接入、心跳、NAT/overlay probe、enrollment 和 blocked identity | `crates/netx-control/src/node_store.rs` | | 存储 Network/resource/membership、overlay subnet routes、node service capability 和 service gateway assignment KV store | `crates/netx-control/src/network_store.rs` | | 存储 service config、local proxy config、managed client config、overlay policy 和 setup draft | `crates/netx-control/src/config_store.rs` | | 存储公共记录/错误类型 | `crates/netx-control/src/models.rs` | | Admin API client | `web/admin/src/lib/api/*` | | Desktop 状态编排 | `apps/netx-desktop/src/composables/use-client-workbench.ts` | | Desktop Tauri 命令/DTO/IPC/local/profile/projection/runtime/service/remote 边界 | `apps/netx-desktop/src-tauri/src/core_control.rs`、`core_control_models.rs`、`core_control_ipc.rs`、`core_control_local.rs`、`core_control_profile.rs`、`core_control_projection.rs`、`core_control_runtime.rs`、`core_control_service.rs`、`core_control_remote.rs` | ## 实现规则 - Handler 做编排,不堆业务内核。 - SQLite 访问走 `StoreExecutor`。 - 协议新增先落 `netx-proto`。 - UI 不自己推导 runtime plan。 - 会话路径要同时看 Controller、Core、bridge executor、CLI/UI。 - 拆模块时同步修测试显式 import。 - 大验证分层跑,先轻后重。 ## 重构期间 本 skill 描述当前有效工程结构,不用于阻止已确认的重构。 当重构改变以下内容时,同步更新本 skill 和 `docs/specs/coding-guide.md`、`docs/specs/architecture.md`: - 产品边界。 - app / crate / module 责任。 - 前端目录归属。 - API 真相源。 - 构建命令。 - 验证命令。 - 运行入口。 若本 skill 与当前源码或已确认重构目标冲突,以当前源码和重构目标为准,并在同次修改中修正本 skill。 ## 验证 轻量: ```bash cargo check --workspace --all-targets pnpm -C web/admin exec vue-tsc --noEmit pnpm -C apps/netx-desktop exec vue-tsc --noEmit ``` 仓库: ```bash make verify-workspace make verify-linux make verify-windows ``` 前端: ```bash pnpm -C web/admin check:design-contracts pnpm -C web/admin test pnpm -C web/admin build pnpm -C apps/netx-desktop check:design-contracts pnpm -C apps/netx-desktop test pnpm -C apps/netx-desktop build ```