wails/v3/examples/server
Lea Anthony 9a363d7be5
feat(v3): add server mode for headless HTTP deployment (#4903)
* feat(v3): add server mode for headless HTTP deployment

Server mode allows Wails applications to run as pure HTTP servers
without native GUI dependencies. Enable with `-tags server` build tag.

Features:
- HTTP server with configurable host/port via ServerOptions
- WAILS_SERVER_HOST and WAILS_SERVER_PORT env var overrides
- WebSocket event broadcasting to connected browsers
- Browser clients represented as BrowserWindow (Window interface)
- Health check endpoint at /health
- Graceful shutdown with configurable timeout
- Docker support with Dockerfile.server template and tasks

Build and run:
  wails3 task build:server
  wails3 task run:server
  wails3 task build:docker
  wails3 task run:docker

Documentation at docs/guides/server-build.mdx

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

* feat(v3): add server mode for headless HTTP deployment

Server mode allows Wails applications to run as pure HTTP servers
without native GUI dependencies. Enable with `-tags server` build tag.

Features:
- HTTP server with configurable host/port via ServerOptions
- WAILS_SERVER_HOST and WAILS_SERVER_PORT env var overrides
- WebSocket event broadcasting to connected browsers
- Browser clients represented as BrowserWindow (Window interface)
- Health check endpoint at /health
- Graceful shutdown with configurable timeout
- Docker support with Dockerfile.server template and tasks

Build and run:
  wails3 task build:server
  wails3 task run:server
  wails3 task build:docker
  wails3 task run:docker

Documentation at docs/guides/server-build.mdx

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

* fix: address CodeRabbit review comments

- Fix corrupted test file with embedded terminal output
- Fix module name mismatch in gin-routing (was gin-example)
- Fix replace directive version mismatch in gin-service
- Fix placeholder module name in ios example (was changeme)
- Fix Dockerfile COPY path to work from both build contexts
- Fix bare URL in README (MD034 compliance)
- Fix comment accuracy in getScreens (returns error, not empty slice)
- Remove deprecated docker-compose version field
- Add port documentation in Taskfile template

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

* fix: address CodeRabbit review comments

- Add note about healthcheck wget not being available in distroless images
- Add !server build constraint to menu_windows.go and menu_darwin.go
- Downgrade window-visibility-test go.mod from 1.25 to 1.24 to match CI

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

---------

Co-authored-by: Claude Opus 4.5 <noreply@anthropic.com>
2026-01-25 14:33:44 +11:00
..
frontend/dist feat(v3): add server mode for headless HTTP deployment (#4903) 2026-01-25 14:33:44 +11:00
Dockerfile feat(v3): add server mode for headless HTTP deployment (#4903) 2026-01-25 14:33:44 +11:00
go.mod feat(v3): add server mode for headless HTTP deployment (#4903) 2026-01-25 14:33:44 +11:00
go.sum feat(v3): add server mode for headless HTTP deployment (#4903) 2026-01-25 14:33:44 +11:00
main.go feat(v3): add server mode for headless HTTP deployment (#4903) 2026-01-25 14:33:44 +11:00
README.md feat(v3): add server mode for headless HTTP deployment (#4903) 2026-01-25 14:33:44 +11:00
Taskfile.yml feat(v3): add server mode for headless HTTP deployment (#4903) 2026-01-25 14:33:44 +11:00

Server Mode Example

Experimental - This feature is experimental and may change in future releases.

This example demonstrates running a Wails application in server mode - without a native GUI window.

What is Server Mode?

Server mode allows you to run your Wails application as a pure HTTP server. This enables:

  • Docker/Container deployments - Deploy your Wails app without X11/Wayland dependencies
  • Server-side rendering - Use your Wails app as a web server
  • Web-only access - Share the same codebase between desktop and web deployments
  • CI/CD testing - Run integration tests without a display server

Building and Running

The recommended way to build server mode applications is using the Taskfile:

# Build for server mode
wails3 task build:server

# Build and run
wails3 task run:server

Or using Go directly:

# Build with server tag
go build -tags server -o myapp-server .

# Run
go run -tags server .

Then open http://localhost:8080 in your browser.

Key Differences from Desktop Mode

  1. No native window - The app runs as an HTTP server only
  2. Browser access - Users access the app via their web browser
  3. No CGO required - Can build without CGO dependencies
  4. Window APIs are no-ops - Calls to window-related APIs are safely ignored
  5. Browser windows - Each browser tab is represented as a "window" named browser-1, browser-2, etc.

Events

Events work bidirectionally in server mode:

  • Frontend to Backend: Events emitted from the browser are sent via HTTP and received by your Go event handlers
  • Backend to Frontend: Events emitted from Go are broadcast to all connected browsers via WebSocket
// Listen for events from browsers
app.Event.On("user-action", func(event *application.CustomEvent) {
    log.Printf("Event from %s: %v", event.Sender, event.Data)
    // event.Sender will be "browser-1", "browser-2", etc.
})

// Emit events to all browsers
app.Event.Emit("server-update", data)

Configuration

Server mode is enabled by building with the server build tag. Configure the HTTP server options:

app := application.New(application.Options{
    // Configure the HTTP server (used when built with -tags server)
    Server: application.ServerOptions{
        Host: "localhost",  // Use "0.0.0.0" for all interfaces
        Port: 8080,
    },

    // ... other options work the same as desktop mode
})

Health Check

A health check endpoint is automatically available at /health:

curl http://localhost:8080/health
# {"status":"ok"}

Building for Production

# Using Taskfile (recommended)
wails3 task build:server

# Or using Go directly
go build -tags server -o myapp-server .

Docker

Build and run with Docker using the built-in tasks:

# Build Docker image
task build:docker

# Build and run
task run:docker

# Run on a different port
task run:docker PORT=3000

Or build manually:

docker build -t server-example .
docker run --rm -p 8080:8080 server-example

Limitations

Since server mode runs without a native GUI, the following features are not available:

  • Native dialogs (file open/save, message boxes)
  • System tray
  • Native menus
  • Window manipulation (resize, move, minimize, etc.)
  • Clipboard access (use browser clipboard APIs instead)
  • Screen information

These APIs are safe to call but will have no effect or return default values.