docs/cli/qr.md
openclaw qrGenerate a mobile pairing QR and setup code from your current Gateway configuration.
openclaw qr
openclaw qr --setup-code-only
openclaw qr --json
openclaw qr --remote
openclaw qr --url wss://gateway.example/ws
--remote: prefer gateway.remote.url; if it is unset, gateway.tailscale.mode=serve|funnel can still provide the remote public URL--url <url>: override gateway URL used in payload--public-url <url>: override public URL used in payload--token <token>: override which gateway token the bootstrap flow authenticates against--password <password>: override which gateway password the bootstrap flow authenticates against--setup-code-only: print only setup code--no-ascii: skip ASCII QR rendering--json: emit JSON (setupCode, gatewayUrl, auth, urlSource)--token and --password are mutually exclusive.bootstrapToken, not the shared gateway token/password.scopes: [].operator.approvals, operator.read, operator.talk.secrets, operator.write.ws:// gateway URLs. Private LAN ws:// remains supported, but Tailscale/public mobile routes should use Tailscale Serve/Funnel or a wss:// gateway URL.--remote, OpenClaw requires either gateway.remote.url or
gateway.tailscale.mode=serve|funnel.--remote, if effectively active remote credentials are configured as SecretRefs and you do not pass --token or --password, the command resolves them from the active gateway snapshot. If gateway is unavailable, the command fails fast.--remote, local gateway auth SecretRefs are resolved when no CLI auth override is passed:
gateway.auth.token resolves when token auth can win (explicit gateway.auth.mode="token" or inferred mode where no password source wins).gateway.auth.password resolves when password auth can win (explicit gateway.auth.mode="password" or inferred mode with no winning token from auth/env).gateway.auth.token and gateway.auth.password are configured (including SecretRefs) and gateway.auth.mode is unset, setup-code resolution fails until mode is set explicitly.secrets.resolve; older gateways return an unknown-method error.openclaw devices listopenclaw devices approve <requestId>