- Refactor bridge configuration to resolve co-existing Manual and Cloud sources into a single persistent 'effective' state - Implement deterministic priority resolution: Manual Bridge > Cloud Sync > Default Fallback - Fix login issues by preserving account base URL and identifier during sync and session restoration - Streamline config/settings.yaml by removing redundant fields and adopting YAML format - Update documentation with new architecture guide for bridge-cloud coexistence and priority logic - Verify functional connectivity for codex, gemini, opencode, and openclaw bridge services
3.0 KiB
3.0 KiB
Bridge Server Configuration Coexistence & Priority Resolution
Date: 2026-04-19
Overview
The xworkmate-app utilizes a "Single Source of Truth" pattern for its Bridge Server configuration. While multiple configuration sources (Cloud Sync from svc.plus and Manual Bridge settings) can coexist, the system deterministically resolves them into a single Effective Configuration that the runtime consumes.
Key Principles
- Sources as Inputs: Cloud and Bridge configurations are treated as sources, not mutually exclusive modes.
- Deterministic Priority:
Manual Bridge (Self-Hosted)>Cloud Sync (Managed). - Single Source of Truth: The runtime exclusively uses the
AcpBridgeServerEffectiveConfigobject. - Explainability: Each effective configuration includes a
sourcetag and areasonexplaining why it was selected.
Configuration Model
The system maintains a clear separation between sources and the resolved state in AcpBridgeServerModeConfig.
class AcpBridgeServerModeConfig {
final AcpBridgeServerEffectiveConfig effective; // Single Source of Truth
final AcpBridgeServerCloudSyncConfig cloudSynced; // Source: svc.plus
final AcpBridgeServerSelfHostedConfig selfHosted; // Source: Manual entries
}
Resolution Logic (Mermaid Diagram)
The following diagram illustrates how the resolveAcpBridgeServerEffectiveConfig function implements the priority logic.
flowchart TD
Start([Resolve Effective Config]) --> CheckManual{Is Manual Source\nconfigured?}
CheckManual -->|Yes| UseManual[<b>Effective Source: bridge</b>\nEndpoint: selfHosted.serverUrl\nTokenRef: selfHosted.passwordRef]
CheckManual -->|No| CheckCloud{Is Cloud Source\nsynced & valid?}
CheckCloud -->|Yes| UseCloud[<b>Effective Source: cloud</b>\nEndpoint: cloudSynced.bridgeServerUrl\nTokenRef: bridge.auth_token]
CheckCloud -->|No| UseDefault[<b>Effective Source: default</b>\nEndpoint: kManagedBridgeServerUrl\nTokenRef: None]
UseManual --> End([Persist Effective State])
UseCloud --> End
UseDefault --> End
style UseManual fill:#e1f5fe,stroke:#1e88e5,stroke-width:2px
style UseCloud fill:#f3e5f5,stroke:#039be5,stroke-width:2px
style UseDefault fill:#fff3e0,stroke:#8e24aa,stroke-width:2px
Traceability & explaining the source
The effective configuration stores metadata that can be used for diagnostics or displayed in the UI:
source: One ofbridge,cloud, ordefault.reason: A human-readable string explaining the selection (e.g., "Manual Bridge configuration is present and valid").
State Lifecycle
- On Save: Whenever the user updates Manual Bridge settings in the UI, the effective config is recalculated.
- On Sync: Whenever a successful Cloud Sync occurs, the effective config is recalculated.
- At Runtime: Components like
resolveBridgeAcpEndpointInternalsimply read fromeffective.endpointwithout needing to know about the underlying priority rules.