Commit Graph

131 Commits

  • Revert "fix: improve Service connection method and permissions for Windows and Unix"
    This reverts commit 601e99f0b5.
    
    Revert "refactor: clash-verge-rev-service-ipc (#4841)"
    
    This reverts commit 5370bd45ed.
  • refactor: clash-verge-rev-service-ipc (#4841)
    * feat: update service installation scripts and IPC integration
    
    - Updated `Cargo.toml` to use version 2.0.8 of `clash_verge_service_ipc` with "client" feature.
    - Renamed service installation and uninstallation scripts in `post-install.sh` and `pre-remove.sh`.
    - Removed `service_ipc` module and refactored IPC handling in `service.rs` to use the new `clash_verge_service_ipc` directly.
    - Adjusted service version checking and core management to align with the new IPC structure.
    - Simplified directory checks in `dirs.rs` and updated logging configurations in `init.rs`.
    - Updated Linux configuration file to reflect new script names.
    - Enhanced service installer hook to manage state more effectively.
    
    * refactor: simplify ClashConfig instantiation and remove unused service log file function
    
    * feat: update clash_verge_service_ipc to version 2.0.9 and enhance service initialization logging
    
    * chore: update clash_verge_service_ipc to version 2.0.10 and refactor async service manager initialization
    
    * fix: update clash_verge_service_ipc to version 2.0.11 and improve service manager initialization
    
    * fix: increase sleep duration for socket readiness check to improve stability
    
    * fix: update clash_verge_service_ipc to version 2.0.12 and kode-bridge to version 0.3.4; refactor service management and IPC path checks
    
    * fix: update clash_verge_service_ipc to version 2.0.13; refactor service connection and initialization logic
  • Refactor logging macros to remove print control parameter
    - Updated logging macros to eliminate the boolean parameter for print control, simplifying the logging calls throughout the codebase.
    - Adjusted all logging calls in various modules (lib.rs, lightweight.rs, help.rs, init.rs, logging.rs, resolve/mod.rs, resolve/scheme.rs, resolve/ui.rs, resolve/window.rs, server.rs, singleton.rs, window_manager.rs) to reflect the new macro structure.
    - Ensured consistent logging behavior across the application by standardizing the logging format.
  • refactor(sidecar): inline Record construction for safer logging
    - Build Record inline so fmt::Arguments temporary only lives through writer.write, avoiding dropped-temporary borrow.
    - Add explicit 'static annotation on leaked string before reboxing for clarity.
  • refactor(core): stabilize 'static backing for sidecar logging
    Introduced `write_sidecar_log` to prevent temporary `format_args!` values
    from dropping early.
    
    - src-tauri/src/core/core.rs:60 — adds `write_sidecar_log`, which temporarily
      leaks the message into a `Box<str>`, builds the `Record`, writes it, then
      immediately reclaims the boxed string. The `unsafe` block is limited to
      `Box::from_raw` needed to undo `Box::leak`.
    - src-tauri/src/core/core.rs:794, 802, 806 — all three sidecar events now route
      through this helper, reusing the returned string for the in-memory log and
      avoiding extra UTF-8 decoding.
  • refactor: invock mihomo api by use tauri-plugin-mihomo (#4926)
    * feat: add tauri-plugin-mihomo
    
    * refactor: invock mihomo api by use tauri-plugin-mihomo
    
    * chore: todo
    
    * chore: update
    
    * chore: update
    
    * chore: update
    
    * chore: update
    
    * fix: incorrect delay status and update pretty config
    
    * chore: update
    
    * chore: remove cache
    
    * chore: update
    
    * chore: update
    
    * fix: app freezed when change group proxy
    
    * chore: update
    
    * chore: update
    
    * chore: add rustfmt.toml to tauri-plugin-mihomo
    
    * chore: happy clippy
    
    * refactor: connect mihomo websocket
    
    * chore: update
    
    * chore: update
    
    * fix: parse bigint to number
    
    * chore: update
    
    * Revert "fix: parse bigint to number"
    
    This reverts commit 74c006522e.
    
    * chore: use number instead of bigint
    
    * chore: cleanup
    
    * fix: rule data not refresh when switch profile
    
    * chore: update
    
    * chore: cleanup
    
    * chore: update
    
    * fix: traffic graph data display
    
    * feat: add ipc connection pool
    
    * chore: update
    
    * chore: clippy
    
    * fix: incorrect delay status
    
    * fix: typo
    
    * fix: empty proxies tray menu
    
    * chore: clippy
    
    * chore: import tauri-plugin-mihomo by using git repo
    
    * chore: cleanup
    
    * fix: mihomo api
    
    * fix: incorrect delay status
    
    * chore: update tauri-plugin-mihomo dep
    
    chore: update
  • fix: main thread block by sidecar launching. (#4795)
    * fix: main thread block by sidecar launching.
    
    #4791
    
    * Refactor async runtime spawn to use AsyncHandler::spawn
    
    for unify debugging.
    
    * Fix compile error on non-windows platform
    
    by remove Windows-specific configuration import.
  • refactor: clash-verge-service management (#4674)
    * refactor: clash-verge-service management
    
    * fix: correct service state checks in ProxyControlSwitches component
    refactor: improve logging in service state update functions
    
    * fix: add missing async handler for Windows and adjust logging import for macOS
    
    * fix: streamline logging imports and add missing async handler for Windows
    
    * refactor: remove unused useServiceStateSync hook and update imports in _layout
    
    * refactor: remove unused useServiceStateSync import and clean up code in ProxyControlSwitches and _layout
    
    * refactor: simplify service status checks and reduce wait time in useServiceInstaller hook
    
    * refactor: remove unnecessary logging statements in service checks and IPC connection
    
    * refactor: extract SwitchRow component for better code organization and readability
    
    * refactor: enhance service state management and update related mutations in layout
    
    * refactor: streamline core stopping logic and improve IPC connection logging
    
    * refactor: consolidate service uninstallation logic and improve error handling
    
    * fix: simplify conditional statements in CoreManager and service functions
    
    * feat: add backoff dependency and implement retry strategy for IPC requests
    
    * refactor: remove redundant Windows conditional and improve error handling in IPC tests
    
    * test: improve error handling in IPC tests for message signing and verification
    
    * fix: adjust IPC backoff retry parameters
    
    * refactor: Remove service state tracking and related logic from service management
    
    * feat: Enhance service status handling with logging and running mode updates
    
    * fix: Improve service status handling with enhanced error logging
    
    * fix: Ensure proper handling of service operations with error propagation
    
    * refactor: Simplify service operation execution and enhance service status handling
    
    * fix: Improve error message formatting in service operation execution and simplify service status retrieval
    
    * refactor: Replace Cache with CacheProxy in multiple modules and update CacheEntry to be generic
    
    * fix: Remove unnecessary success message from config validation
    
    * refactor: Comment out logging statements in service version check and IPC request handling
  • edition 2024 (#4702)
    * feat: update Cargo.toml for 2024 edition and optimize release profiles
    
    * feat: refactor environment variable settings for Linux and improve code organization
    
    * Refactor conditional statements to use `&&` for improved readability
    
    - Updated multiple files to combine nested `if let` statements using `&&` for better clarity and conciseness.
    - This change enhances the readability of the code by reducing indentation levels and making the conditions more straightforward.
    - Affected files include: media_unlock_checker.rs, profile.rs, clash.rs, profiles.rs, async_proxy_query.rs, core.rs, handle.rs, hotkey.rs, service.rs, timer.rs, tray/mod.rs, merge.rs, seq.rs, config.rs, proxy.rs, window.rs, general.rs, dirs.rs, i18n.rs, init.rs, network.rs, and window.rs in the resolve module.
    
    * refactor: streamline conditional checks using `&&` for improved readability
    
    * fix: update release profile settings for panic behavior and optimization
    
    * fix: adjust optimization level in Cargo.toml and reorder imports in lightweight.rs
  • feat: update Cargo.toml for 2024 edition and optimize release profiles (#4681)
    * feat: update Cargo.toml for 2024 edition and optimize release profiles
    
    * feat: refactor environment variable settings for Linux and improve code organization
    
    * Refactor conditional statements to use `&&` for improved readability
    
    - Updated multiple files to combine nested `if let` statements using `&&` for better clarity and conciseness.
    - This change enhances the readability of the code by reducing indentation levels and making the conditions more straightforward.
    - Affected files include: media_unlock_checker.rs, profile.rs, clash.rs, profiles.rs, async_proxy_query.rs, core.rs, handle.rs, hotkey.rs, service.rs, timer.rs, tray/mod.rs, merge.rs, seq.rs, config.rs, proxy.rs, window.rs, general.rs, dirs.rs, i18n.rs, init.rs, network.rs, and window.rs in the resolve module.
    
    * refactor: streamline conditional checks using `&&` for improved readability
  • refactor: migrate from serde_yaml to serde_yaml_ng for improved YAML handling (#4568)
    * refactor: migrate from serde_yaml to serde_yaml_ng for improved YAML handling
    
    * refactor: format code for better readability in DNS configuration
  • refactor(async): migrate from sync-blocking async execution to true async with unified AsyncHandler::spawn (#4502)
    * feat: replace all tokio::spawn with unified AsyncHandler::spawn
    
    - 🚀 Core Improvements:
      * Replace all tokio::spawn calls with AsyncHandler::spawn for unified Tauri async task management
      * Prioritize converting sync functions to async functions to reduce spawn usage
      * Use .await directly in async contexts instead of spawn
    
    - 🔧 Major Changes:
      * core/hotkey.rs: Use AsyncHandler::spawn for hotkey callback functions
      * module/lightweight.rs: Async lightweight mode switching
      * feat/window.rs: Convert window operation functions to async, use .await internally
      * feat/proxy.rs, feat/clash.rs: Async proxy and mode switching functions
      * lib.rs: Window focus handling with AsyncHandler::spawn
      * core/tray/mod.rs: Complete async tray event handling
    
    -  Technical Advantages:
      * Unified task tracking and debugging capabilities (via tokio-trace feature)
      * Better error handling and task management
      * Consistency with Tauri runtime
      * Reduced async boundaries for better performance
    
    - 🧪 Verification:
      * Compilation successful with 0 errors, 0 warnings
      * Maintains complete original functionality
      * Optimized async execution flow
    
    * feat: complete tokio fs migration and replace tokio::spawn with AsyncHandler
    
    🚀 Major achievements:
    - Migrate 8 core modules from std::fs to tokio::fs
    - Create 6 Send-safe wrapper functions using spawn_blocking pattern
    - Replace all tokio::spawn calls with AsyncHandler::spawn for unified async task management
    - Solve all 19 Send trait compilation errors through innovative spawn_blocking architecture
    
    🔧 Core changes:
    - config/profiles.rs: Add profiles_*_safe functions to handle Send trait constraints
    - cmd/profile.rs: Update all Tauri commands to use Send-safe operations
    - config/prfitem.rs: Replace append_item calls with profiles_append_item_safe
    - utils/help.rs: Convert YAML operations to async (read_yaml, save_yaml)
    - Multiple modules: Replace tokio::task::spawn_blocking with AsyncHandler::spawn_blocking
    
     Technical innovations:
    - spawn_blocking wrapper pattern resolves parking_lot RwLock Send trait conflicts
    - Maintain parking_lot performance while achieving Tauri async command compatibility
    - Preserve backwards compatibility with gradual migration strategy
    
    🎯 Results:
    - Zero compilation errors
    - Zero warnings
    - All async file operations working correctly
    - Complete Send trait compliance for Tauri commands
    
    * feat: refactor app handle and command functions to use async/await for improved performance
    
    * feat: update async handling in profiles and logging functions for improved error handling and performance
    
    * fix: update TRACE_MINI_SIZE constant to improve task logging threshold
    
    * fix(windows): convert service management functions to async for improved performance
    
    * fix: convert service management functions to async for improved responsiveness
    
    * fix(ubuntu): convert install and reinstall service functions to async for improved performance
    
    * fix(linux): convert uninstall_service function to async for improved performance
    
    * fix: convert uninstall_service call to async for improved performance
    
    * fix: convert file and directory creation calls to async for improved performance
    
    * fix: convert hotkey functions to async for improved responsiveness
    
    * chore: update UPDATELOG.md for v2.4.1 with major improvements and performance optimizations
  • refactor: Replace tokio::spawn with AsyncHandler::spawn for better task management
    - Replace direct tokio::spawn calls with AsyncHandler::spawn across multiple modules
    - Improves task lifecycle management and error handling consistency
    - Affected files:
      - src-tauri/src/cmd/network.rs
      - src-tauri/src/core/core.rs
      - src-tauri/src/core/event_driven_proxy.rs
      - src-tauri/src/enhance/tun.rs
      - src-tauri/src/ipc/logs.rs
      - src-tauri/src/ipc/memory.rs
      - src-tauri/src/ipc/monitor.rs
      - src-tauri/src/ipc/traffic.rs
      - src-tauri/src/utils/network.rs
      - src-tauri/src/utils/resolve.rs
    
    This change provides better control over async task spawning and helps prevent
    potential issues with unmanaged background tasks.
  • fix: clippy errors with new config (#4428)
    * refactor: improve code quality with clippy fixes and standardized logging
    
    - Replace dangerous unwrap()/expect() calls with proper error handling
    - Standardize logging from log:: to logging\! macro with Type:: classifications
    - Fix app handle panics with graceful fallback patterns
    - Improve error resilience across 35+ modules without breaking functionality
    - Reduce clippy warnings from 300+ to 0 in main library code
    
    * chore: update Cargo.toml configuration
    
    * refactor: resolve all clippy warnings
    - Fix Arc clone warnings using explicit Arc::clone syntax across 9 files
    - Add #[allow(clippy::expect_used)] to test functions for appropriate expect usage
    - Remove no-effect statements from debug code cleanup
    - Apply clippy auto-fixes for dbg\! macro removals and path statements
    - Achieve zero clippy warnings on all targets with -D warnings flag
    
    * chore: update Cargo.toml clippy configuration
    
    * refactor: simplify macOS job configuration and improve caching
    
    * refactor: remove unnecessary async/await from service and proxy functions
    
    * refactor: streamline pnpm installation in CI configuration
    
    * refactor: simplify error handling and remove unnecessary else statements
    
    * refactor: replace async/await with synchronous locks for core management
    
    * refactor: add workflow_dispatch trigger to clippy job
    
    * refactor: convert async functions to synchronous for service management
    
    * refactor: convert async functions to synchronous for UWP tool invocation
    
    * fix: change wrong logging
    
    * refactor: convert proxy restoration functions to async
    
    * Revert "refactor: convert proxy restoration functions to async"
    
    This reverts commit b82f5d250b.
    
    * refactor: update proxy restoration functions to return Result types
    
    * fix: handle errors during proxy restoration and update async function signatures
    
    * fix: handle errors during proxy restoration and update async function signatures
    
    * refactor: update restore_pac_proxy and restore_sys_proxy functions to async
    
    * fix: convert restore_pac_proxy and restore_sys_proxy functions to async
    
    * fix: await restore_sys_proxy calls in proxy restoration logic
    
    * fix: suppress clippy warnings for unused async functions in proxy restoration
    
    * fix: suppress clippy warnings for unused async functions in proxy restoration
  • refactor: optimize singleton macro usage with Default trait implementations (#4279)
    * refactor: implement DRY principle improvements across backend
    
    Major DRY violations identified and addressed:
    
    1. **IPC Stream Monitor Pattern**:
       - Created `utils/ipc_monitor.rs` with generic `IpcStreamMonitor` trait
       - Added `IpcMonitorManager` for common async task management patterns
       - Eliminates duplication across traffic.rs, memory.rs, and logs.rs
    
    2. **Singleton Pattern Duplication**:
       - Created `utils/singleton.rs` with `singleton\!` and `singleton_with_logging\!` macros
       - Replaces 16+ duplicate singleton implementations across codebase
       - Provides consistent, tested patterns for global instances
    
    3. **macOS Activation Policy Refactoring**:
       - Consolidated 3 duplicate methods into single parameterized `set_activation_policy()`
       - Eliminated code duplication while maintaining backward compatibility
       - Reduced maintenance burden for macOS-specific functionality
    
    These improvements enhance maintainability, reduce bug potential, and ensure consistent patterns across the backend codebase.
    
    * fix: resolve test failures and clippy warnings
    
    - Fix doctest in singleton.rs by using rust,ignore syntax and proper code examples
    - Remove unused time::Instant import from ipc_monitor.rs
    - Add #[allow(dead_code)] attributes to future-use utility modules
    - All 11 unit tests now pass successfully
    - All clippy checks pass with -D warnings strict mode
    - Documentation tests properly ignore example code that requires full context
    
    * refactor: migrate code to use new utility tools (partial)
    
    Progress on systematic migration to use created utility tools:
    
    1. **Reorganized IPC Monitor**:
       - Moved ipc_monitor.rs to src-tauri/src/ipc/monitor.rs for better organization
       - Updated module structure to emphasize IPC relationship
    
    2. **IpcManager Singleton Migration**:
       - Replaced manual OnceLock singleton pattern with singleton_with_logging\! macro
       - Simplified initialization code and added consistent logging
       - Removed unused imports (OnceLock, logging::Type)
    
    3. **ProxyRequestCache Singleton Migration**:
       - Migrated from once_cell::sync::OnceCell to singleton\! macro
       - Cleaner, more maintainable singleton pattern
       - Consistent with project-wide singleton approach
    
    These migrations demonstrate the utility and effectiveness of the created tools:
    - Less boilerplate code
    - Consistent patterns across codebase
    - Easier maintenance and debugging
    
    * feat: complete migration to new utility tools - phase 1
    
    Successfully migrated core components to use the created utility tools:
    
    - Moved `ipc_monitor.rs` to `src-tauri/src/ipc/monitor.rs`
    - Better organization emphasizing IPC relationship
    - Updated module exports and imports
    
    - **IpcManager**: Migrated to `singleton_with_logging\!` macro
    - **ProxyRequestCache**: Migrated to `singleton\!` macro
    - Eliminated ~30 lines of boilerplate singleton code
    - Consistent logging and initialization patterns
    
    - Removed unused imports (OnceLock, once_cell, logging::Type)
    - Cleaner, more maintainable code structure
    - All 11 unit tests pass successfully
    - Zero compilation warnings
    
    - **Lines of code reduced**: ~50+ lines of boilerplate
    - **Consistency improved**: Unified singleton patterns
    - **Maintainability enhanced**: Centralized utility functions
    - **Test coverage maintained**: 100% test pass rate
    
    Remaining complex monitors (traffic, memory, logs) will be migrated to use the shared IPC monitoring patterns in the next phase, which requires careful refactoring of their streaming logic.
    
    * refactor: complete singleton pattern migration to utility macros
    
    Migrate remaining singleton patterns across the backend to use standardized
    utility macros, achieving significant code reduction and consistency improvements.
    
    - **LogsMonitor** (ipc/logs.rs): `OnceLock` → `singleton_with_logging\!`
    - **Sysopt** (core/sysopt.rs): `OnceCell` → `singleton_lazy\!`
    - **Tray** (core/tray/mod.rs): Complex `OnceCell` → `singleton_lazy\!`
    - **Handle** (core/handle.rs): `OnceCell` → `singleton\!`
    - **CoreManager** (core/core.rs): `OnceCell` → `singleton_lazy\!`
    - **TrafficMonitor** (ipc/traffic.rs): `OnceLock` → `singleton_lazy_with_logging\!`
    - **MemoryMonitor** (ipc/memory.rs): `OnceLock` → `singleton_lazy_with_logging\!`
    
    - `singleton_lazy\!` - For complex initialization patterns
    - `singleton_lazy_with_logging\!` - For complex initialization with logging
    
    - **Code Reduction**: -33 lines of boilerplate singleton code
    - **DRY Compliance**: Eliminated duplicate initialization patterns
    - **Consistency**: Unified singleton approach across codebase
    - **Maintainability**: Centralized singleton logic in utility macros
    - **Zero Breaking Changes**: All existing APIs remain compatible
    
    All tests pass and clippy warnings resolved.
    
    * refactor: optimize singleton macros using Default trait implementation
    
    Simplify singleton macro usage by implementing Default trait for complex
    initialization patterns, significantly improving code readability and maintainability.
    
    - **MemoryMonitor**: Move IPC client initialization to Default impl
    - **TrafficMonitor**: Move IPC client initialization to Default impl
    - **Sysopt**: Move Arc<Mutex> initialization to Default impl
    - **Tray**: Move struct field initialization to Default impl
    - **CoreManager**: Move Arc<Mutex> initialization to Default impl
    
    ```rust
    singleton_lazy_with_logging\!(MemoryMonitor, INSTANCE, "MemoryMonitor", || {
        let ipc_path_buf = ipc_path().unwrap();
        let ipc_path = ipc_path_buf.to_str().unwrap_or_default();
        let client = IpcStreamClient::new(ipc_path).unwrap();
        MemoryMonitor::new(client)
    });
    ```
    
    ```rust
    impl Default for MemoryMonitor { /* initialization logic */ }
    singleton_lazy_with_logging\!(MemoryMonitor, INSTANCE, "MemoryMonitor", MemoryMonitor::default);
    ```
    
    - **Code Reduction**: -17 lines of macro closure code (80%+ simplification)
    - **Separation of Concerns**: Initialization logic moved to proper Default impl
    - **Readability**: Single-line macro calls vs multi-line closures
    - **Testability**: Default implementations can be tested independently
    - **Rust Idioms**: Using standard Default trait pattern
    - **Performance**: Function calls more efficient than closures
    
    All tests pass and clippy warnings resolved.
    
    * refactor: implement MonitorData and StreamingParser traits for IPC monitors
    
    * refactor: add timeout and retry_interval fields to IpcStreamMonitor; update TrafficMonitorState to derive Default
    
    * refactor: migrate AppHandleManager to unified singleton control
    
    - Replace manual singleton implementation with singleton_with_logging\! macro
    - Remove std::sync::Once dependency in favor of OnceLock-based pattern
    - Improve error handling for macOS activation policy methods
    - Maintain thread safety with parking_lot::Mutex for AppHandle storage
    - Add proper initialization check to prevent duplicate handle assignment
    - Enhance logging consistency across AppHandleManager operations
    
    * refactor: improve hotkey management with enum-based operations
    
    - Add HotkeyFunction enum for type-safe function selection
    - Add SystemHotkey enum for predefined system shortcuts
    - Implement Display and FromStr traits for type conversions
    - Replace string-based hotkey registration with enum methods
    - Add register_system_hotkey() and unregister_system_hotkey() methods
    - Maintain backward compatibility with string-based register() method
    - Migrate singleton pattern to use singleton_with_logging\! macro
    - Extract hotkey function execution logic into centralized execute_function()
    - Update lib.rs to use new enum-based SystemHotkey operations
    - Improve type safety and reduce string manipulation errors
    
    Benefits:
    - Type safety prevents invalid hotkey function names
    - Centralized function execution reduces code duplication
    - Enum-based API provides better IDE autocomplete support
    - Maintains full backward compatibility with existing configurations
    
    * fix: resolve LightWeightState initialization order panic
    
    - Modify with_lightweight_status() to safely handle unmanaged state using try_state()
    - Return Option<R> instead of R to gracefully handle state unavailability
    - Update is_in_lightweight_mode() to use unwrap_or(false) for safe defaults
    - Add state availability check in auto_lightweight_mode_init() before access
    - Maintain singleton check priority while preventing early state access panics
    - Fix clippy warnings for redundant pattern matching
    
    Resolves runtime panic: "state() called before manage() for LightWeightState"
    
    * refactor: add unreachable patterns for non-macOS in hotkey handling
    
    * refactor: simplify SystemHotkey enum by removing redundant cfg attributes
    
    * refactor: add macOS conditional compilation for system hotkey registration methods
    
    * refactor: streamline hotkey unregistration and error logging for macOS
  • feat: migrate mihomo to use kode-bridge IPC on Windows and Unix (#4051)
    * Refactor Mihomo API integration and remove crate_mihomo_api
    
    - Removed the `mihomo_api` crate and its dependencies from the project.
    - Introduced `IpcManager` for handling IPC communication with Mihomo.
    - Implemented IPC methods for managing proxies, connections, and configurations.
    - Updated `MihomoManager` to utilize `IpcManager` instead of the removed crate.
    - Added platform-specific IPC socket path handling for macOS, Linux, and Windows.
    - Cleaned up related tests and configuration files.
    
    * fix: remove duplicate permission entry in desktop capabilities
    
    * refactor: replace MihomoManager with IpcManager and remove Mihomo module
    
    * fix: restore tempfile dependency in dev-dependencies
    
    * fix: update kode-bridge dependency to use git source from the dev branch
    
    * feat: migrate mihomo to use kode-bridge IPC on Windows
    
    This commit implements a comprehensive migration from legacy service IPC to the kode-bridge library for Windows IPC communication. Key changes include:
    
    Replace service_ipc with kode-bridge IpcManager for all mihomo communications
    Simplify proxy commands using new caching mechanism with ProxyRequestCache
    Add Windows named pipe (\.\pipe\mihomo) and Unix socket IPC endpoint configuration
    Update Tauri permissions and dependencies (dashmap, tauri-plugin-notification)
    Add IPC logging support and improve error handling
    Fix Windows IPC path handling in directory utilities
    This migration enables better cross-platform IPC support and improved performance for mihomo proxy core communication.
    
    * doc: add IPC communication with Mihomo kernel, removing Restful API dependency
    
    * fix: standardize logging type naming from IPC to Ipc for consistency
    
    * refactor: clean up and optimize code structure across multiple components and services
    
    - Removed unnecessary comments and whitespace in various files.
    - Improved code readability and maintainability by restructuring functions and components.
    - Updated localization files for consistency and accuracy.
    - Enhanced performance by optimizing hooks and utility functions.
    - General code cleanup in settings, pages, and services to adhere to best practices.
    
    * fix: simplify URL formatting in test_proxy_delay method
    
    * fix: update kode-bridge dependency to version 0.1.3 and change source to crates.io
    
    * fix: update macOS target versions in development workflow
    
    * Revert "fix: update macOS target versions in development workflow"
    
    This reverts commit b9831357e4.
    
    * feat: enhance IPC path handling for Unix systems and improve directory safety checks
    
    * feat: add conditional compilation for Unix-specific IPC path handling
    
    * chore: update cagro.lock
    
    * feat: add external controller configuration and UI support
    
    * Refactor proxy and connection management to use IPC-based commands
    
    - Updated `get_proxies` function in `proxy.rs` to call the new IPC command.
    - Renamed `get_refresh_proxies` to `get_proxies` in `ipc/general.rs` for consistency.
    - Added new IPC commands for managing proxies, connections, and configurations in `cmds.ts`.
    - Refactored API calls in various components to use the new IPC commands instead of HTTP requests.
    - Improved error handling and response management in the new IPC functions.
    - Cleaned up unused API functions in `api.ts` and redirected relevant calls to `cmds.ts`.
    - Enhanced connection management features including health checks and updates for proxy providers.
    
    * chore: update dependencies and improve error handling in IPC manager
    
    * fix: downgrade zip dependency from 4.3.0 to 4.2.0
    
    * feat: Implement traffic and memory data monitoring service
    
    - Added `TrafficService` and `TrafficManager` to manage traffic and memory data collection.
    - Introduced commands to get traffic and memory data, start and stop the traffic service.
    - Integrated IPC calls for traffic and memory data retrieval in the frontend.
    - Updated `AppDataProvider` and `EnhancedTrafficStats` components to utilize new data fetching methods.
    - Removed WebSocket connections for traffic and memory data, replaced with IPC polling.
    - Added logging for better traceability of data fetching and service status.
    
    * refactor: unify external controller handling and improve IPC path resolution
    
    * fix: replace direct IPC path retrieval with guard function for external controller
    
    * fix: convert external controller IPC path to string for proper insertion in config map
    
    * fix: update dependencies and improve IPC response handling
    
    * fix: remove unnecessary unix conditional for ipc path import
    
    * Refactor traffic and memory monitoring to use IPC stream; remove TrafficService and TrafficManager. Introduce new IPC-based data retrieval methods for traffic and memory, including formatted data and system overview. Update frontend components to utilize new APIs for enhanced data display and management.
    
    * chore: bump crate rand version to 0.9.2
    
    * feat: Implement enhanced traffic monitoring system with data compression and sampling
    
    - Introduced `useTrafficMonitorEnhanced` hook for advanced traffic data management.
    - Added `TrafficDataSampler` class for handling raw and compressed traffic data.
    - Implemented reference counting to manage data collection based on component usage.
    - Enhanced data validation with `SystemMonitorValidator` for API responses.
    - Created diagnostic tools for monitoring performance and error tracking.
    - Updated existing hooks to utilize the new enhanced monitoring features.
    - Added utility functions for generating and formatting diagnostic reports.
    
    * feat(ipc): improve URL encoding and error handling for IPC requests
    
    - Add percent-encoding for URL paths to handle special characters properly
    - Enhance error handling in update_proxy with proper logging
    - Remove excessive debug logging to reduce noise
    - Update kode-bridge dependency to v0.1.5
    - Fix JSON parsing error handling in PUT requests
    
    Changes include:
    - Proper URL encoding for connection IDs, proxy names, and test URLs
    - Enhanced error handling with fallback responses in updateProxy
    - Comment out verbose debug logs in traffic monitoring and data validation
    - Update dependency version for improved IPC functionality
    
    * feat: major improvements in architecture, traffic monitoring, and data validation
    
    * Refactor traffic graph components: Replace EnhancedTrafficGraph with EnhancedCanvasTrafficGraph, improve rendering performance, and enhance visual elements. Remove deprecated code and ensure compatibility with global data management.
    
    * chore: update UPDATELOG.md for v2.4.0 release, refine traffic monitoring system details, and enhance IPC functionality
    
    * chore: update UPDATELOG.md to reflect removal of deprecated MihomoManager and unify IPC control
    
    * refactor: remove global traffic service testing method from cmds.ts
    
    * Update src/components/home/enhanced-canvas-traffic-graph.tsx
    
    * Update src/hooks/use-traffic-monitor-enhanced.ts
    
    * Update src/components/layout/layout-traffic.tsx
    
    * refactor: remove debug state management from LayoutTraffic component
    
    ---------
  • refactor(Draft): Replace latest() with latest_ref() and data() with data_mut() in multiple files for improved mutability handling and consistency across the codebase (#3987)
    * feat: add benchmarking for draft operations and new draft management structure
    
    * Refactor Config Access: Replace `latest()` with `latest_ref()` and `data()` with `data_mut()` in multiple files for improved mutability handling and consistency across the codebase.
    
    * refactor: remove DraftNew implementation and related benchmarks for cleaner codebase
  • refactor: remove unused macOS tray speed display and improve tray icon handling (#3862)
    * refactor: remove unused macOS tray speed display and improve tray icon handling
    
    * refactor: disable macOS specific logging during core initialization
    
    * feat: add linux elevator function to determine privilege escalation command
  • refactor: use Box to store large config objects and add memory usage tests
    - Refactored config-related structs to use Box for storing large objects (e.g., IRuntime, IProfiles, PrfItem) to reduce stack memory usage and improve performance.
    - Updated related methods and assignments to handle Boxed types correctly.
    - Added and improved unit tests to compare memory usage between Boxed and non-Boxed config objects, demonstrating the memory efficiency of Box.
    - Test output now shows the size difference between stack-allocated and heap-allocated (Box) config objects.