Improvements and fixes

This commit is contained in:
2026-03-19 12:42:29 +09:00
parent 891b1941bd
commit 4e0ee51a33
14 changed files with 420 additions and 225 deletions

89
desktop_proxy.py Normal file → Executable file
View File

@@ -1,47 +1,15 @@
#!/usr/bin/env python3
import os
#!/opt/homebrew/bin/python3
import socket
import struct
import sys
import threading
from pathlib import Path
MAX_MSG = 1024 * 1024
def ipc_socket_path() -> str:
return str(Path.home() / ".librewolf" / "s.bw")
def read_stdin_message() -> bytes | None:
header = sys.stdin.buffer.read(4)
if len(header) < 4:
return None
length = struct.unpack("=I", header)[0]
if length == 0 or length > 1024 * 1024:
return None
data = sys.stdin.buffer.read(length)
if len(data) < length:
return None
return data
def write_stdout_message(data: bytes):
header = struct.pack("=I", len(data))
sys.stdout.buffer.write(header + data)
sys.stdout.buffer.flush()
def read_ipc_message(sock: socket.socket) -> bytes | None:
header = recv_exact(sock, 4)
if header is None:
return None
length = struct.unpack("=I", header)[0]
if length == 0 or length > 1024 * 1024:
return None
return recv_exact(sock, length)
def send_ipc_message(sock: socket.socket, data: bytes):
sock.sendall(struct.pack("=I", len(data)) + data)
return str(Path.home() / ".cache" / "com.bitwarden.desktop" / "s.bw")
def recv_exact(sock: socket.socket, n: int) -> bytes | None:
@@ -54,41 +22,68 @@ def recv_exact(sock: socket.socket, n: int) -> bytes | None:
return buf
def read_stdin() -> bytes | None:
header = sys.stdin.buffer.read(4)
if len(header) < 4:
return None
length = struct.unpack("=I", header)[0]
if length == 0 or length > MAX_MSG:
return None
data = sys.stdin.buffer.read(length)
return data if len(data) == length else None
def write_stdout(data: bytes):
sys.stdout.buffer.write(struct.pack("=I", len(data)) + data)
sys.stdout.buffer.flush()
def read_ipc(sock: socket.socket) -> bytes | None:
header = recv_exact(sock, 4)
if header is None:
return None
length = struct.unpack("=I", header)[0]
if length == 0 or length > MAX_MSG:
return None
return recv_exact(sock, length)
def send_ipc(sock: socket.socket, data: bytes):
sock.sendall(struct.pack("=I", len(data)) + data)
def ipc_to_stdout(sock: socket.socket):
try:
while True:
msg = read_ipc_message(sock)
msg = read_ipc(sock)
if msg is None:
break
write_stdout_message(msg)
write_stdout(msg)
except (ConnectionResetError, BrokenPipeError, OSError):
pass
def main():
path = ipc_socket_path()
sock = socket.socket(socket.AF_UNIX, socket.SOCK_STREAM)
try:
sock.connect(path)
sock.connect(ipc_socket_path())
except (FileNotFoundError, ConnectionRefusedError):
sys.exit(1)
send_ipc_message(sock, b'{"command":"connected"}')
reader = threading.Thread(target=ipc_to_stdout, args=(sock,), daemon=True)
reader.start()
send_ipc(sock, b'{"command":"connected"}')
threading.Thread(target=ipc_to_stdout, args=(sock,), daemon=True).start()
try:
while True:
msg = read_stdin_message()
msg = read_stdin()
if msg is None:
break
send_ipc_message(sock, msg)
send_ipc(sock, msg)
except (BrokenPipeError, OSError):
pass
finally:
try:
send_ipc_message(sock, b'{"command":"disconnected"}')
send_ipc(sock, b'{"command":"disconnected"}')
except OSError:
pass
sock.close()