0d5c49c19a
Testing / test (push) Failing after 10m21s
- compat.py → compat/ package: auth.py (auth-field normalizers), commands.py (command-format shims), __init__.py (re-exports) - Add _auth_0_9_3 transformer: normalizes pubkey to lowercase before auth so clients < 0.9.3 sending uppercase hex are accepted - adapt_auth() now called before auth check in serve.py; command extracted after adapt_auth so future transformers can rename commands safely - serve.py: deduplicate _recv_exact (import from client), unify resp/resp_payload across Windows/Unix branches, require lowercase hex pubkey (re.fullmatch), reorganize imports, drop unused os import - client.py: move payload/framed construction inside branches (remote path no longer serializes JSON it never uses); fix _is_valid_key_spec operator precedence; import MAX_MSG_BYTES from version_manager - auth.py: narrow except clause (ValueError instead of bare Exception) - Bump version 0.9.2 → 0.9.3 Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
81 lines
2.7 KiB
Python
81 lines
2.7 KiB
Python
import click
|
|
from browser_cli.commands import _handle, _handle_multi, _multi_browser_targets
|
|
from rich.console import Console
|
|
from rich.table import Table
|
|
|
|
console = Console()
|
|
|
|
|
|
def _print_windows(windows: list[dict], *, show_browser: bool = False) -> None:
|
|
if not windows:
|
|
console.print("[yellow]No windows found[/yellow]")
|
|
return
|
|
table = Table(show_header=True, header_style="bold cyan")
|
|
if show_browser:
|
|
table.add_column("Browser")
|
|
table.add_column("ID", style="dim", no_wrap=True)
|
|
table.add_column("Alias", width=20)
|
|
table.add_column("Tabs", width=6)
|
|
table.add_column("State", width=12)
|
|
for w in windows:
|
|
row = [
|
|
w.get("browser", "") if show_browser else None,
|
|
str(w.get("id", "")),
|
|
w.get("alias") or "",
|
|
str(w.get("tabCount", "")),
|
|
w.get("state") or "",
|
|
]
|
|
table.add_row(*[value for value in row if value is not None])
|
|
console.print(table)
|
|
|
|
|
|
@click.group("windows")
|
|
def windows_group():
|
|
"""Manage browser windows."""
|
|
|
|
|
|
@windows_group.command("list")
|
|
def windows_list():
|
|
"""List all browser windows."""
|
|
targets = _multi_browser_targets()
|
|
if targets:
|
|
windows = []
|
|
for target in targets:
|
|
result = _handle_multi("windows.list", profile=target.profile, remote=target.remote)
|
|
if result is None:
|
|
continue
|
|
windows.extend({**window, "browser": target.display_name} for window in result)
|
|
if not windows:
|
|
console.print("[red]Error:[/red] Cannot resolve a browser socket automatically.")
|
|
raise SystemExit(1)
|
|
_print_windows(windows, show_browser=True)
|
|
return
|
|
windows = _handle("windows.list")
|
|
_print_windows(windows or [])
|
|
|
|
|
|
@windows_group.command("rename")
|
|
@click.argument("window_id", type=int)
|
|
@click.argument("name")
|
|
def windows_rename(window_id, name):
|
|
"""Give a window a local alias NAME (stored in native host)."""
|
|
_handle("windows.rename", {"windowId": window_id, "name": name})
|
|
console.print(f"[green]Window {window_id} aliased as '{name}'[/green]")
|
|
|
|
|
|
@windows_group.command("close")
|
|
@click.argument("window_id", type=int)
|
|
def windows_close(window_id):
|
|
"""Close a browser window."""
|
|
_handle("windows.close", {"windowId": window_id})
|
|
console.print(f"[green]Window {window_id} closed[/green]")
|
|
|
|
|
|
@windows_group.command("open")
|
|
@click.argument("url", required=False)
|
|
def windows_open(url):
|
|
"""Open a new browser window."""
|
|
result = _handle("windows.open", {"url": url})
|
|
wid = result.get("id") if isinstance(result, dict) else result
|
|
console.print(f"[green]Opened new window[/green] (id: {wid})" + (f" with {url}" if url else ""))
|