Skip to content

xrdebug/xrdebug

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

xrDebug

xrDebug is a lightweight web-based debug software. Play video

Get it on macOSGet it on LinuxGet it on WindowsGet it on FreeBSD

xrDebug

Build Code size Apache-2.0

Installation

xrDebug is available for Windows, macOS, Linux and FreeBSD. Download the latest xrdebug binary from the releases page.

From binary

  1. Go to the releases page.
  2. Download the appropriate binary for your operating system.
  3. Extract the downloaded file.
  4. Move the binary to a directory included in your PATH.

Optionally, you can run this command to install the latest version:

bash <(curl -sL xrdebug.com/bin.sh)

From source

Ensure you have Go installed.

go install github.com/xrdebug/xrdebug@latest

Docker

Container images are available at ghcr.io/xrdebug/xrdebug.

Run the following command to start the server at port 27420:

docker run -t --init --rm --pull=always -p 27420:27420 ghcr.io/xrdebug/xrdebug:latest

Usage

Run the server with the following command. Use a client library or the HTTP API to send messages to the server.

xrdebug <options>

See the run documentation for examples.

Options

  • -a: IP address to listen on (default: ``)
  • -p: Port to listen on (use 0 for random, default: 27420)
  • -c: Path to TLS certificate file
  • -z: Path to TLS private key
  • -e: Enable end-to-end encryption (default: false)
  • -k: (for -e option) Path to symmetric key (AES-GCM AE)
  • -s: Enable sign verification (default: false)
  • -x: (for -s option) Path to private key (ed25519)
  • -n: Session name (default: xrDebug)
  • -i: Editor to use (default: vscode, options: atom, bracket, emacs, espresso, fleet, idea, macvim, netbeans, nova, phpstorm, sublime, textmate, vscode, zed)

Client libraries

The following clients are available:

(Contributions for other clients are welcome!)

Screens

xrDebug light

xrDebug dark

xrDebug light demo

xrDebug dark demo

Documentation

Documentation available at docs.xrdebug.com.

Features

Security & privacy

  • Zero-persistence architecture - no data storage or logging
  • Ed25519 signed requests
  • End-to-end encryption using AES-GCM AE

Real-time collaboration

  • Automatic broadcast of debug messages to all connected peers
  • Multiple developers can watch the same debug session simultaneously
  • Real-time updates without page refresh
  • Share debugging sessions across your team

Advanced debugging

  • Message filtering by Topics and Emotes
  • Interactive debugging controls (Resume, Pause, Stop, Clear)
  • Code execution flow control with pause/resume capabilities
  • Customizable session naming for multiple debug instances

Developer experience

  • Intuitive keyboard shortcuts for rapid debugging (R, P, S, C)
  • One-click export to clipboard or PNG format
  • Seamless integration with popular code editors
  • FiraCode font rendering

Modern interface

  • System-aware dark/light theme switching
  • Fully responsive design for any screen size
  • Portable HTML-based interface
  • Clean, distraction-free debugging environment

System architecture

xrDebug follows a modular architecture with the following key components:

graph TD
    A[Client Application] -->|Debug Messages| B[xrDebug Server]
    B -->|SSE| C[Web Browser]
    B -->|Console Output| D[Terminal]

    subgraph Server Components
        B --> E[SSE Controller]
        B --> F[Message Handler]
        B --> G[Security Layer]
    end

    G -->|Optional| H[TLS Encryption]
    G -->|Optional| I[Message Encryption]
    G -->|Optional| J[Signature Verification]
Loading

Core Components

The system consists of these main components:

  1. Server

    • Handles incoming debug messages
    • Manages SSE connections
    • Implements security measures
    • Provides HTTP endpoints
  2. Message Handler

    • Processes incoming debug data
    • Sanitizes content
    • Manages message queuing
    • Handles message broadcasting
  3. Security Layer

    • TLS encryption for HTTPS
    • End-to-end message encryption
    • Request signature verification
  4. Client Interface

    • Real-time updates via SSE
    • Message decryption
    • Interactive debugging tools (pause, resume, stop)
    • Editor integration (jump to file, line)

Data flow

sequenceDiagram
    participant C as Client App
    participant S as xrDebug Server
    participant B as Browser/Terminal

    C->>+S: Send Debug Message
    Note over S: Sanitize & Process
    S->>S: Apply Security Measures
    S->>B: Broadcast via SSE
    B->>B: Display Debug Info
Loading

HTTP API

Learn more about the HTTP API at the documentation.

GET /

To access the web interface, open a web browser and navigate to the server's root URL. The server will serve the web interface.

open http://localhost:27420

POST /messages

Sends a message to the server.

Parameters:

All parameters are optional, but at least one is required.

  • body: The message body.
  • emote: The message type (default: info).
  • file_line: The line number.
  • file_path: The file path.
  • id: The message ID.
  • topic: The message topic.

Responses:

  • 200 OK: Message sent.
  • 400 Bad Request: Invalid request.
curl --fail -X POST \
    --data "body=My message" \
    --data "file_path=file" \
    --data "file_line=1" \
    http://localhost:27420/messages

POST /pauses

Creates a pause lock.

Parameters:

  • id: The ID of the pause lock.

The following parameters are optional:

  • body: The message body.
  • emote: The message type (default: info).
  • file_line: The line number.
  • file_path: The file path.
  • topic: The message topic

Responses:

  • 201 Created: Lock created Location: /pauses/{id}.
  • 409 Conflict: Lock already exists.
curl --fail -X POST --data "id=123" http://localhost:27420/pauses

GET /pauses/{id}

Retrieves the status of an existing pause lock.

Parameters:

  • id (path): The ID of the pause lock.

Responses:

  • 200 OK: Returns the pause lock (JSON).
  • 404 Not Found: Lock not found.
curl --fail -X GET http://localhost:27420/pauses/123

DELETE /pauses/{id}

Deletes a pause lock.

Parameters:

  • id (path): The ID of the pause lock.

Responses:

  • 204 No Content: Lock deleted.
  • 404 Not Found: Lock not found.
curl --fail -X DELETE http://localhost:27420/pauses/123

PATCH /pauses/{id}

Updates a pause lock status to stop: true.

Parameters:

  • id (path): The ID of the pause lock.

Responses:

  • 200 OK: Lock updated, returns the pause lock (JSON).
  • 404 Not Found: Lock not found.
curl --fail -X PATCH http://localhost:27420/pauses/123

GET /stream

Establishes a Server-Sent Events (SSE) connection.

Responses:

  • 200 OK: Returns the SSE stream.
curl --fail -X GET http://localhost:27420/stream

Signed requests

Request signing using Ed25519 digital signatures to verify message origin authenticity. To use signed requests pass the -s flag to the xrdebug command. Optionally, you can pass the private key using the -x flag.

To sign a request, the client must include the X-Signature header on requests made to the xrDebug server. The signature is a base64 encoded string generated by signing the serialized post fields with the private key. If there's no fields sign an empty string.

Sign workflow

To sign a request server expect the following data workflow:

  1. Sort the post fields by key
  2. Concatenate the key-value pairs
  3. Sign the concatenated string
  4. Base64 encode the signature at X-Signature header

Example in PHP:

function serialize(array $data): string
{
    $result = '';
    ksort($data);
    foreach ($data as $key => $value) {
        $result .= $key . $value;
    }

    return $result;
}

$serialized = serialize($data);
$signature = $privateKey->sign($serialized);
$signHeader = base64_encode($signature);

Example in Python:

def serialize(data: dict) -> str:
    return ''.join(f'{k}{v}' for k, v in sorted(data.items()))

serialized = serialize(data)
signature = private_key.sign(serialized)
signHeader = base64.b64encode(signature).decode()

The X-Signature header should contain the base64 encoded signature generated by the client.

curl --fail -X POST \
    --data "body=My signed message" \
    --data "file_path=file" \
    --data "file_line=1" \
    -H "X-Signature: <signHeader>" \
    http://127.0.0.1:27420/messages

End-to-End encryption

End-to-end encryption (AES-GCM AE) between xrDebug server and the debugger web user interface client. To enable end-to-end encryption pass the -e flag. Optionally, you can pass the symmetric key using the -k flag.

The SSE stream at /stream will be encrypted using the symmetric key. Decryption happens on the client-side (web browser).

License

Copyright Rodolfo Berrios A.

xrDebug is licensed under the Apache License, Version 2.0. See LICENSE for the full license text.

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.