2025-11-19T14:52:05.689200263Z [migrations] started
2025-11-19T14:52:05.689245695Z [migrations] no migrations found
2025-11-19T14:52:05.718633343Z usermod: no changes
2025-11-19T14:52:05.727917576Z ───────────────────────────────────────
2025-11-19T14:52:05.727938288Z 
2025-11-19T14:52:05.727943208Z       ██╗     ███████╗██╗ ██████╗
2025-11-19T14:52:05.727947987Z       ██║     ██╔════╝██║██╔═══██╗
2025-11-19T14:52:05.727952877Z       ██║     ███████╗██║██║   ██║
2025-11-19T14:52:05.727957456Z       ██║     ╚════██║██║██║   ██║
2025-11-19T14:52:05.727961054Z       ███████╗███████║██║╚██████╔╝
2025-11-19T14:52:05.727964661Z       ╚══════╝╚══════╝╚═╝ ╚═════╝
2025-11-19T14:52:05.727968258Z 
2025-11-19T14:52:05.727971665Z    Brought to you by linuxserver.io
2025-11-19T14:52:05.727975192Z ───────────────────────────────────────
2025-11-19T14:52:05.728089081Z 
2025-11-19T14:52:05.728096717Z To support LSIO projects visit:
2025-11-19T14:52:05.728100464Z https://www.linuxserver.io/donate/
2025-11-19T14:52:05.728103941Z 
2025-11-19T14:52:05.728107649Z ───────────────────────────────────────
2025-11-19T14:52:05.728112238Z GID/UID
2025-11-19T14:52:05.728115765Z ───────────────────────────────────────
2025-11-19T14:52:05.731427283Z 
2025-11-19T14:52:05.731433936Z User UID:    911
2025-11-19T14:52:05.731437564Z User GID:    911
2025-11-19T14:52:05.731441271Z ───────────────────────────────────────
2025-11-19T14:52:05.732195389Z Linuxserver.io version: 1.4.40dfsgppa202509261331.r328d1747c.daa6d8c926ubuntu24.04.1-ls186
2025-11-19T14:52:05.732452858Z Build-date: 2025-11-19T14:42:54+00:00
2025-11-19T14:52:05.732459331Z ───────────────────────────────────────
2025-11-19T14:52:05.732463279Z     
2025-11-19T14:52:06.068611085Z .......+...+....+..+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*..............+..+...+......+...+......+......+.+.....+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*...+...+..+...+..................+...............+......+...+......+.......+........+......+......+.......+...+...+..+............+..........+......+........................+...+..+.+......+.....+..........+..............+.+.....+....+..+.........+...+.+..............+.......+........+..........+............+.........+.....+.......+..+.......+..............+....+...+.....+.........+......+...+.+......+.....+...+.+...+......+.....+................+......+.....+...+......+................+..+..........+.....+.......+...+.....+...+...+......+.+..+.............+...+......+......+..............+.+.....+............+.+.........+..+...+.+......+..............+..........+...........+......+...+....+........+...+..........+.....+....+...+............+.....+...+...+.......+.....+.......+...+..............+.+.....+...+.......................................+.+..+.......+..+....+......+.......................+......+............+...+.......+..+......+.......+...+.....+....+..+......+.........+....+..+.......+.....+............+.+.........+........+.+......+.....+.+..+......+....+..+....+..+..........+............+............+.........+..+...+....+...+..+.+.....+............+...+......+................+........+.......+..+...............+.+....................+....+..+...+.+...........+.........+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
2025-11-19T14:52:06.166500976Z .....+..+.+..+...+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*..+.+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*..+...+...........+......+.......+.....+.............+........+..............................+.+...+..+...+...+...+.+...+...+...+.........+..+.+.....+....+...+.....+.+......+...+...........+....+............+......+.....+.........+.+.........+...+......+..+...................+.....+.............+...........+......+...+......+.......+........+.+......+..+...+...+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
2025-11-19T14:52:06.169757372Z -----
2025-11-19T14:52:06.365203061Z [ls.io-init] Creating initial backup of menu.xml
2025-11-19T14:52:06.402601448Z [ls.io-init] Creating initial backup of system rc.xml
2025-11-19T14:52:06.498170666Z [custom-init] No custom files found, skipping...
2025-11-19T14:52:06.519063221Z xsettingsd: Loaded 1 setting from /config/.xsettingsd
2025-11-19T14:52:06.519080656Z _XSERVTransmkdir: ERROR: euid != 0,directory /tmp/.X11-unix will not be created.
2025-11-19T14:52:06.519762870Z screen 0 shmid 0
2025-11-19T14:52:06.520241443Z [ls.io-init] done.
2025-11-19T14:52:07.113279460Z The XKEYBOARD keymap compiler (xkbcomp) reports:
2025-11-19T14:52:07.113313649Z > Warning:          Could not resolve keysym XF86CameraAccessEnable
2025-11-19T14:52:07.113323549Z > Warning:          Could not resolve keysym XF86CameraAccessDisable
2025-11-19T14:52:07.113332046Z > Warning:          Could not resolve keysym XF86CameraAccessToggle
2025-11-19T14:52:07.113344691Z > Warning:          Could not resolve keysym XF86NextElement
2025-11-19T14:52:07.113353229Z > Warning:          Could not resolve keysym XF86PreviousElement
2025-11-19T14:52:07.113361595Z > Warning:          Could not resolve keysym XF86AutopilotEngageToggle
2025-11-19T14:52:07.113370052Z > Warning:          Could not resolve keysym XF86MarkWaypoint
2025-11-19T14:52:07.113378459Z > Warning:          Could not resolve keysym XF86Sos
2025-11-19T14:52:07.113386686Z > Warning:          Could not resolve keysym XF86NavChart
2025-11-19T14:52:07.113394752Z > Warning:          Could not resolve keysym XF86FishingChart
2025-11-19T14:52:07.113429652Z > Warning:          Could not resolve keysym XF86SingleRangeRadar
2025-11-19T14:52:07.113437879Z > Warning:          Could not resolve keysym XF86DualRangeRadar
2025-11-19T14:52:07.113445955Z > Warning:          Could not resolve keysym XF86RadarOverlay
2025-11-19T14:52:07.113454052Z > Warning:          Could not resolve keysym XF86TraditionalSonar
2025-11-19T14:52:07.113464473Z > Warning:          Could not resolve keysym XF86ClearvuSonar
2025-11-19T14:52:07.113472769Z > Warning:          Could not resolve keysym XF86SidevuSonar
2025-11-19T14:52:07.113480876Z > Warning:          Could not resolve keysym XF86NavInfo
2025-11-19T14:52:07.114832517Z Errors from xkbcomp are not fatal to the X server
2025-11-19T14:52:07.118839775Z xsettingsd: Created window 0x200001 on screen 0 with timestamp 1175511918
2025-11-19T14:52:07.119095640Z xsettingsd: Selection _XSETTINGS_S0 is owned by 0x0
2025-11-19T14:52:07.119105971Z xsettingsd: Took ownership of selection _XSETTINGS_S0
2025-11-19T14:52:07.134958829Z 19
2025-11-19T14:52:07.147338194Z 20
2025-11-19T14:52:07.431993316Z INFO:data_websocket:pcmflux library found. Audio capture is available.
2025-11-19T14:52:07.474736154Z INFO:data_websocket:pixelflux library found. Striped encoding modes available.
2025-11-19T14:52:07.522741727Z INFO:root:Expected C js_config_t size (from ctypes): 1354 bytes
2025-11-19T14:52:07.569230317Z INFO:main:Upload directory ensured: /config/Desktop
2025-11-19T14:52:07.569543768Z INFO:main:Legacy Mode ENABLED (SELKIES_MASTER_TOKEN is not set).
2025-11-19T14:52:07.569673770Z INFO:main:Starting Selkies (WebSocket Mode) with settings: {'audio_enabled': (True, False), 'microphone_enabled': (True, False), 'gamepad_enabled': (True, False), 'clipboard_enabled': (True, False), 'command_enabled': (True, False), 'file_transfers': ['upload', 'download'], 'encoder': 'x264enc', 'framerate': (8, 120), 'h264_crf': (5, 50), 'jpeg_quality': (1, 100), 'h264_fullcolor': (False, False), 'h264_streaming_mode': (False, False), 'use_cpu': (False, False), 'use_paint_over_quality': (True, False), 'paint_over_jpeg_quality': (1, 100), 'h264_paintover_crf': (5, 50), 'h264_paintover_burst_frames': (1, 30), 'second_screen': (True, False), 'audio_bitrate': '320000', 'is_manual_resolution_mode': (False, False), 'manual_width': 0, 'manual_height': 0, 'scaling_dpi': '96', 'enable_binary_clipboard': (False, False), 'use_browser_cursors': (False, False), 'use_css_scaling': (False, False), 'ui_title': 'Selkies', 'ui_show_logo': (True, False), 'ui_show_core_buttons': (True, False), 'ui_show_sidebar': (True, False), 'ui_sidebar_show_video_settings': (True, False), 'ui_sidebar_show_screen_settings': (True, False), 'ui_sidebar_show_audio_settings': (True, False), 'ui_sidebar_show_stats': (True, False), 'ui_sidebar_show_clipboard': (True, False), 'ui_sidebar_show_files': (True, False), 'ui_sidebar_show_apps': (True, False), 'ui_sidebar_show_sharing': (True, False), 'ui_sidebar_show_gamepads': (True, False), 'ui_sidebar_show_fullscreen': (True, False), 'ui_sidebar_show_gaming_mode': (True, False), 'ui_sidebar_show_trackpad': (True, False), 'ui_sidebar_show_keyboard_button': (True, False), 'ui_sidebar_show_soft_buttons': (True, False), 'port': 8082, 'control_port': 8083, 'master_token': '', 'dri_node': '', 'audio_device_name': 'output.monitor', 'watermark_path': '', 'watermark_location': -1, 'debug': (False, False), 'enable_sharing': (True, False), 'enable_collab': (True, False), 'enable_shared': (True, False), 'enable_player2': (True, False), 'enable_player3': (True, False), 'enable_player4': (True, False)}
2025-11-19T14:52:07.569721897Z INFO:main:Initial Encoder: x264enc, Framerate: 60
2025-11-19T14:52:07.569731947Z INFO:main:SelkiesStreamingApp initialized: encoder=x264enc, display=1024x768
2025-11-19T14:52:07.569793802Z INFO:main:All main components initialized. Running server...
2025-11-19T14:52:07.572544460Z INFO:webrtc_input:System DPI detected as ~96. Cursor size cap set to 32x32px.
2025-11-19T14:52:07.591007934Z INFO:webrtc_input:Resetting keyboard modifiers.
2025-11-19T14:52:07.592121406Z INFO:webrtc_input:Clipboard monitor running (binary mode: False)
2025-11-19T14:52:07.593206410Z INFO:webrtc_input:Found XFIXES version 4.0
2025-11-19T14:52:07.593232733Z INFO:webrtc_input:starting cursor monitor
2025-11-19T14:52:07.593245509Z INFO:webrtc_input:watching for cursor changes
2025-11-19T14:52:07.600341767Z WARNING:data_websocket:Cannot broadcast cursor data: no clients connected or server not ready.
2025-11-19T14:52:07.600819378Z INFO:data_websocket:Data WebSocket Server listening on port 8082
2025-11-19T14:52:07.727191294Z INFO:webrtc_input:Initializing 4 persistent gamepad instances...
2025-11-19T14:52:07.727344052Z INFO:root:Packed js_config payload for 'Microsoft X-Box 360 pad' (js0): len=1360 bytes. Name='Microsoft X-Box 360 pad', Vendor=0x045e, Product=0x028e, Version=0x0100, Reported Buttons=11 (Array capacity: 512), Reported Axes=8 (Array capacity: 64)
2025-11-19T14:52:07.727364763Z INFO:selkies_gamepad:Gamepad configured. JS socket: /tmp/selkies_js0.sock, EVDEV socket: /tmp/selkies_event1000.sock. Using fixed config: Microsoft X-Box 360 pad
2025-11-19T14:52:07.727400766Z INFO:webrtc_input:Initialized and started persistent gamepad instance for index 0 (Name: 'Microsoft X-Box 360 pad', JS: /tmp/selkies_js0.sock, EVDEV: /tmp/selkies_event1000.sock).
2025-11-19T14:52:07.727469264Z INFO:root:Packed js_config payload for 'Microsoft X-Box 360 pad' (js1): len=1360 bytes. Name='Microsoft X-Box 360 pad', Vendor=0x045e, Product=0x028e, Version=0x0100, Reported Buttons=11 (Array capacity: 512), Reported Axes=8 (Array capacity: 64)
2025-11-19T14:52:07.727476579Z INFO:selkies_gamepad:Gamepad configured. JS socket: /tmp/selkies_js1.sock, EVDEV socket: /tmp/selkies_event1001.sock. Using fixed config: Microsoft X-Box 360 pad
2025-11-19T14:52:07.727509525Z INFO:webrtc_input:Initialized and started persistent gamepad instance for index 1 (Name: 'Microsoft X-Box 360 pad', JS: /tmp/selkies_js1.sock, EVDEV: /tmp/selkies_event1001.sock).
2025-11-19T14:52:07.727555808Z INFO:root:Packed js_config payload for 'Microsoft X-Box 360 pad' (js2): len=1360 bytes. Name='Microsoft X-Box 360 pad', Vendor=0x045e, Product=0x028e, Version=0x0100, Reported Buttons=11 (Array capacity: 512), Reported Axes=8 (Array capacity: 64)
2025-11-19T14:52:07.727563383Z INFO:selkies_gamepad:Gamepad configured. JS socket: /tmp/selkies_js2.sock, EVDEV socket: /tmp/selkies_event1002.sock. Using fixed config: Microsoft X-Box 360 pad
2025-11-19T14:52:07.727604065Z INFO:webrtc_input:Initialized and started persistent gamepad instance for index 2 (Name: 'Microsoft X-Box 360 pad', JS: /tmp/selkies_js2.sock, EVDEV: /tmp/selkies_event1002.sock).
2025-11-19T14:52:07.727650689Z INFO:root:Packed js_config payload for 'Microsoft X-Box 360 pad' (js3): len=1360 bytes. Name='Microsoft X-Box 360 pad', Vendor=0x045e, Product=0x028e, Version=0x0100, Reported Buttons=11 (Array capacity: 512), Reported Axes=8 (Array capacity: 64)
2025-11-19T14:52:07.727681291Z INFO:selkies_gamepad:Gamepad configured. JS socket: /tmp/selkies_js3.sock, EVDEV socket: /tmp/selkies_event1003.sock. Using fixed config: Microsoft X-Box 360 pad
2025-11-19T14:52:07.727700059Z INFO:webrtc_input:Initialized and started persistent gamepad instance for index 3 (Name: 'Microsoft X-Box 360 pad', JS: /tmp/selkies_js3.sock, EVDEV: /tmp/selkies_event1003.sock).
2025-11-19T14:52:07.728124704Z INFO:selkies_gamepad:Gamepad /tmp/selkies_js0.sock: Event processor started.
2025-11-19T14:52:07.728159474Z INFO:selkies_gamepad:JS interposer server listening on /tmp/selkies_js0.sock
2025-11-19T14:52:07.728279405Z INFO:selkies_gamepad:Gamepad /tmp/selkies_js1.sock: Event processor started.
2025-11-19T14:52:07.728301700Z INFO:selkies_gamepad:JS interposer server listening on /tmp/selkies_js1.sock
2025-11-19T14:52:07.728411240Z INFO:selkies_gamepad:Gamepad /tmp/selkies_js2.sock: Event processor started.
2025-11-19T14:52:07.728420850Z INFO:selkies_gamepad:JS interposer server listening on /tmp/selkies_js2.sock
2025-11-19T14:52:07.728531092Z INFO:selkies_gamepad:Gamepad /tmp/selkies_js3.sock: Event processor started.
2025-11-19T14:52:07.728537525Z INFO:selkies_gamepad:JS interposer server listening on /tmp/selkies_js3.sock
2025-11-19T14:52:07.728695843Z INFO:selkies_gamepad:EVDEV interposer server listening on /tmp/selkies_event1000.sock
2025-11-19T14:52:07.728728690Z INFO:selkies_gamepad:EVDEV interposer server listening on /tmp/selkies_event1001.sock
2025-11-19T14:52:07.728741555Z INFO:selkies_gamepad:EVDEV interposer server listening on /tmp/selkies_event1002.sock
2025-11-19T14:52:07.728751686Z INFO:selkies_gamepad:EVDEV interposer server listening on /tmp/selkies_event1003.sock
2025-11-19T14:53:36.881629353Z INFO:data_websocket:Legacy client ('127.0.0.1', 57192) connected. Role: controller, Slot: None
2025-11-19T14:53:36.881656297Z INFO:data_websocket:Data WebSocket connected from ('127.0.0.1', 57192)
2025-11-19T14:53:36.881826620Z INFO:data_websocket:Sending last known cursor to new client ('127.0.0.1', 57192)
2025-11-19T14:53:36.883239134Z INFO:data_websocket:Attempting to establish PulseAudio connection...
2025-11-19T14:53:36.885784378Z INFO:data_websocket:PulseAudio connection established.
2025-11-19T14:53:36.901298875Z INFO:data_websocket:Registering new client for display: primary
2025-11-19T14:53:36.901383365Z INFO:data_websocket:Applying and sanitizing client settings for 'primary' (initial=True)
2025-11-19T14:53:36.901496813Z INFO:data_websocket:DPI changed from None to 96. Applying system-level change.
2025-11-19T14:53:36.902731018Z INFO:gst_app_resize:Openbox detected. Applying xrdb for DPI 96.
2025-11-19T14:53:36.903158980Z INFO:gst_app_resize:Wrote 'Xft.dpi:   96' to /config/.Xresources.
2025-11-19T14:53:36.940595815Z INFO:gst_app_resize:Successfully loaded /config/.Xresources using xrdb.
2025-11-19T14:53:36.940916801Z INFO:gst_app_resize:Wrote font and DPI settings to /config/.xsettingsd.
2025-11-19T14:53:36.955888144Z INFO:gst_app_resize:Found xsettingsd process with PID: 300.
2025-11-19T14:53:36.957744903Z xsettingsd: Reloading configuration
2025-11-19T14:53:36.957777308Z xsettingsd: Loaded 5 settings from /config/.xsettingsd
2025-11-19T14:53:36.958097633Z INFO:gst_app_resize:Sent SIGHUP to xsettingsd process 300 to reload config.
2025-11-19T14:53:36.983912789Z INFO:data_websocket:Initial setup or dimensional change detected for 'primary'. Performing full display reconfiguration.
2025-11-19T14:53:36.983938941Z INFO:data_websocket:Starting display reconfiguration...
2025-11-19T14:53:36.984191791Z INFO:data_websocket:Calculating new extended desktop layout from ALL clients...
2025-11-19T14:53:36.984228084Z INFO:data_websocket:Layout calculated: Total Size=1920x992. Layouts: {'primary': {'x': 0, 'y': 0, 'w': 1920, 'h': 992}}
2025-11-19T14:53:36.996548800Z INFO:data_websocket:Mode 1920x992 not found. Creating it.
2025-11-19T14:53:37.010416301Z INFO:data_websocket:Defining logical monitors for the window manager...
2025-11-19T14:53:37.017541677Z INFO:data_websocket:Starting separate capture instances for each ACTIVE display region...
2025-11-19T14:53:37.017567068Z INFO:data_websocket:Client 'primary' is active. Starting its capture.
2025-11-19T14:53:37.017602339Z INFO:data_websocket:Preparing to start capture for display='primary': Res=1920x992, Offset=0x0
2025-11-19T14:53:37.020080910Z INFO:data_websocket:Video chunk sender started for display 'primary'.
2025-11-19T14:53:37.020776450Z INFO:data_websocket:SUCCESS: Capture started for 'primary'.
2025-11-19T14:53:37.020821841Z INFO:data_websocket:New frame backpressure task started for display 'primary'.
2025-11-19T14:53:37.020887884Z INFO:data_websocket:Broadcasting primary stream resolution to all clients: {"type": "stream_resolution", "width": 1920, "height": 992}
2025-11-19T14:53:37.021034830Z INFO:data_websocket:Broadcasting display config update: DISPLAY_CONFIG_UPDATE,{"type": "display_config_update", "displays": ["primary"]}
2025-11-19T14:53:37.021126565Z INFO:data_websocket:Display reconfiguration finished successfully.
2025-11-19T14:53:37.021160633Z INFO:data_websocket:Reconfiguration process complete (state unlocked).
2025-11-19T14:53:37.021256687Z INFO:data_websocket:Initial client settings message processed by ws_handler.
2025-11-19T14:53:37.021313722Z INFO:data_websocket:Initial setup: Primary client connected, audio not active, attempting start.
2025-11-19T14:53:37.021350075Z INFO:data_websocket:Starting pcmflux audio pipeline...
2025-11-19T14:53:37.021387610Z INFO:data_websocket:pcmflux settings: device='output.monitor', bitrate=320000, channels=2
2025-11-19T14:53:37.021574928Z INFO:data_websocket:Frame-based backpressure logic task started for display 'primary'.
2025-11-19T14:53:37.021630409Z INFO:data_websocket:Client settings received, proceeding with backpressure loop for 'primary'.
2025-11-19T14:53:37.021925303Z INFO:data_websocket:pcmflux audio capture started successfully.
2025-11-19T14:53:37.022117871Z [pcmflux] Attempting to connect to PulseAudio device: output.monitor...
2025-11-19T14:53:37.022788170Z INFO:data_websocket:pcmflux audio chunk broadcasting task started.
2025-11-19T14:53:37.023605877Z X Shared Memory Extension available.
2025-11-19T14:53:37.023680948Z XShm setup complete for 1920x992.
2025-11-19T14:53:37.023707922Z CPU cores available: 64
2025-11-19T14:53:37.023843946Z Stream settings active -> Res: 1920x992 | FPS: 60.0 | Stripes: 1 | Mode: H264 (CPU) FullFrame | CRF: 25 | PaintOver CRF: 18 (Burst: 5f) | Colorspace: I420 (Limited Range) | Damage Thresh: 10f | Damage Dur: 20f
2025-11-19T14:53:37.024038347Z [pcmflux] SUCCESS: Connected to PulseAudio.
2025-11-19T14:53:37.024088017Z [pcmflux] SUCCESS: Opus encoder created.
2025-11-19T14:53:37.024097877Z [pcmflux] Capture loop started. Device: output.monitor, Rate: 48000, Channels: 2, Bitrate: 320 kbps, VBR: On, Silence Gate: Off, Debug Logging: Off, PCM Chunk: 3840 bytes
2025-11-19T14:53:37.026900991Z INFO:data_websocket:Received START_AUDIO command from client for server-to-client audio.
2025-11-19T14:53:37.026953256Z INFO:data_websocket:START_AUDIO: pcmflux audio pipeline already active.
2025-11-19T14:53:37.027179322Z INFO:data_websocket:Client is taking over existing display 'primary'. Updating state for new connection.
2025-11-19T14:53:37.027204542Z INFO:data_websocket:Applying and sanitizing client settings for 'primary' (initial=False)
2025-11-19T14:53:37.027412411Z INFO:data_websocket:Received redundant resize request for primary (1920x992). No action taken.
2025-11-19T14:53:39.024967942Z [pcmflux] First non-silent audio chunk detected! Encoding...
2025-11-19T14:53:47.085149631Z INFO:data_websocket:Cleaning up Data WS handler for ('127.0.0.1', 57192) (Display ID: primary)...
2025-11-19T14:53:47.085189782Z INFO:data_websocket:Client for 'primary' disconnected. Removing and triggering full display reconfiguration.
2025-11-19T14:53:47.085231266Z INFO:data_websocket:Starting display reconfiguration...
2025-11-19T14:53:47.085260755Z INFO:data_websocket:Stopping all existing capture and backpressure tasks...
2025-11-19T14:53:47.096222425Z Capture loop stopped. X resources released.
2025-11-19T14:53:47.096570256Z INFO:data_websocket:All capture instances, senders, and backpressure tasks stopped.
2025-11-19T14:53:47.096582641Z WARNING:data_websocket:No display clients connected. Video pipelines remain stopped.
2025-11-19T14:53:47.097643446Z INFO:data_websocket:Video chunk sender for 'primary' cancelled.
2025-11-19T14:53:47.097665130Z INFO:data_websocket:Video chunk sender for 'primary' finished.
2025-11-19T14:53:47.110576596Z INFO:data_websocket:Reconfiguration process complete (state unlocked).
2025-11-19T14:53:47.117019097Z INFO:data_websocket:Last client (('127.0.0.1', 57192)) disconnected. All pipelines should have been stopped by reconfigure_displays.
2025-11-19T14:53:47.117038035Z INFO:main:Initiating unified pipeline shutdown...
2025-11-19T14:53:47.117044789Z WARNING:data_websocket:Reconfiguration already in progress. Ignoring concurrent request.
2025-11-19T14:53:47.117051883Z INFO:data_websocket:Stopping pcmflux audio pipeline...
2025-11-19T14:53:47.117177857Z INFO:data_websocket:pcmflux audio chunk broadcasting task cancelled.
2025-11-19T14:53:47.117187997Z INFO:data_websocket:pcmflux audio chunk broadcasting task finished.