Commit Graph

78 Commits

Author SHA1 Message Date
Fabian @ Blax Software be3c7400fe feat: enhance websocket attribute handling with prefix and suffix support; add HTTP controller fallback for event resolution; implement comprehensive tests for dispatcher and event registry 2026-04-29 08:29:49 +02:00
Fabian @ Blax Software fb84abb464 feat: websocket attribute 2026-04-28 20:17:37 +02:00
Fabian @ Blax Software dd6be893a6 BF cache-key slug drift on ws_socket_auth_*; resilient User column in watch -v
Handler::cacheAuthenticatedUser() and ::cleanupChannelConnections() were
writing/forgetting ws_socket_auth_<rawSocketId> while
WebsocketService::getAuth() and ::setUserAuthed() have always slugged
("123.456" → "123-456"). Result: the cache write was reachable from the
package's own writer path but not from the service-layer reader, so the
admin tooling (websockets:watch -v) saw cache misses and rendered #<id>
instead of the configured IdentityFormatter output.

Also: WatchStats now batch-loads missing users via the configured auth
provider model in one query per render, so the User column still renders
the full formatter shape even when the per-socket cache blob predates
the writer or got evicted.

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
2026-04-27 13:56:07 +02:00
Fabian @ Blax Software e45d8dff20 F websockets:watch -v — per-connection rows (socket id, user, duration)
Verbose mode reuses Symfony's built-in -v flag (the short option is
reserved, so a custom one can't be added). Each channel summary is
followed by sub-rows showing the socket id, the authed user (falling
back to "Guest" or the user id if the user blob expired), and how long
the connection has been open.

Connection start times are written by Handler::establishConnection() into
ws_connection_<slug(socketId)> on open and forgotten on close. Also
fixed a latent bug in finalizeConnectionClose() where the forget key was
missing the slug() call that the reader has always used — previously
invisible because nothing wrote the key, now load-bearing.

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
2026-04-27 13:42:26 +02:00
Fabian @ Blax Software a3194247c4 BF nullable deprecations 2026-04-23 11:56:50 +02:00
Fabian @ Blax Software 2ad8d490b7 fix: harden IPC callbacks and decouple auth lookup via configurable resolver 2026-04-17 11:03:02 +02:00
Fabian @ Blax Software ed371ac051 fix: catch Throwable in fork child, protect class_exists in scanning 2026-04-16 09:24:11 +02:00
Fabian @ Blax Software 9e7c2575f6 feat: WS introspection - list controllers and methods for debugging
- Send 'websocket' to list all controllers with methods and metadata
- Send 'auth' to list all methods on AuthController
- Shows need_auth, lifecycle hooks (boot/booted/unboot) per controller
- Only enabled in local env or via WEBSOCKET_INTROSPECTION=true
- Never active in production unless explicitly enabled
2026-04-16 09:02:25 +02:00
Fabian @ Blax Software 093bbe3a44 A tests, documentation for helpers and lifecycle
- Introduced `helpers-and-testing.md` to document global helpers and WebsocketService class usage.
- Created `HandlerLifecycleTest.php` to test the full WebSocket handler lifecycle, including connection management, channel subscriptions, and message routing.
- Added `WebsocketServiceTest.php` to validate state tracking methods in WebsocketService, covering user authentication, channel tracking, and broadcast functionality.
2026-04-02 12:44:16 +02:00
Fabian @ Blax Software 77e12db729 BF long lasting subscription 2026-03-27 09:38:07 +01:00
Fabian @ Blax Software 7dd2df48d1 I DB connecting & auth handling 2026-03-23 14:13:30 +01:00
Fabian @ Blax Software c77eec57c1 I sentry reporting 2026-03-23 10:15:45 +01:00
Fabian @ Blax Software 0757e6d9f9 I stability 2026-03-21 12:56:50 +01:00
Fabian @ Blax Software f191c44634 BF pong 2026-03-21 10:27:03 +01:00
Fabian @ Blax Software d091ebbd82 I last ponged timestamp 2026-03-21 10:01:10 +01:00
Fabian @ Blax Software 35b2731349 I max concurrency handling, BF restart 2026-03-20 13:44:51 +01:00
Fabian @ Blax Software 636d9eccb8 I parent connection states 2026-03-05 12:26:56 +01:00
Fabian @ Blax Software 463e633713 BF error 2026-02-10 14:05:36 +01:00
Fabian @ Blax Software 2a47591907 R cache, connection session, performance 2026-02-09 13:50:42 +01:00
Fabian @ Blax Software 7c1fca5c38 R performance improvements 2026-02-09 13:19:09 +01:00
Fabian @ Blax Software 1eafa237a0 R removed polling, transitioned to kernel events 2026-02-09 13:04:22 +01:00
Fabian @ Blax Software 986ce76fb7 IA hotreloads 2026-02-02 13:20:39 +01:00
Fabian @ Blax Software f7e08a337b BF whisper, broadcast 2026-02-02 11:24:54 +01:00
Fabian @ Blax Software 935bfb28d3 A hotreload 2026-01-26 10:51:13 +01:00
Fabian @ Blax Software c76e6ae111 RI websocket performance 2026-01-24 14:49:51 +01:00
Fabian @ Blax Software 2849f0fe5f RI websocket performance 2026-01-24 14:42:35 +01:00
Fabian @ Blax Software 5b8a2a8112 I performance, A testing & event-driven 2026-01-24 13:34:29 +01:00
Fabian @ Blax Software 6ce8573fed RI websocket performance, BF race condition 2026-01-24 12:17:46 +01:00
Fabian @ Blax Software ddbca89cf7 I boot/booted 2025-12-18 09:29:34 +01:00
a6a2f5842 72c8bf4ac8 A boot/booted/unplug options 2025-12-17 21:34:20 +01:00
a6a2f5842 ae22264aea R controller 2025-12-05 22:08:47 +01:00
a6a2f5842 ad0e8d556f I cache latency 2025-12-05 21:48:23 +01:00
a6a2f5842 21037b617b R handler 2025-12-05 20:53:52 +01:00
a6a2f5842 55c819700b A default broadcasting route, I ip on close 2025-12-05 19:56:44 +01:00
a6a2f5842 6776d3c5c2 A sentry capture 2025-12-02 18:33:52 +01:00
a6a2f5842 f5df27f96a BF auth state 2025-10-15 10:32:35 +02:00
a6a2f5842 5eba7e19ff BF type 2025-10-15 09:45:04 +02:00
a6a2f5842 447cc71256 I auth state 2025-10-15 09:35:07 +02:00
a6a2f5842 dcf8315290 I auth state 2025-10-15 09:27:37 +02:00
a6a2f5842 76d6b30fdf BF prevent bool beeing sent 2025-10-03 08:10:16 +02:00
a6a2f5842 2aa264eb34 BF queue dispatch 2025-09-19 12:18:40 +02:00
a6a2f5842 2960c3a3f3 BF edgecase 2025-09-18 18:07:15 +02:00
a6a2f5842 4155e05d76 BF has connection on null 2025-09-18 17:55:52 +02:00
a6a2f5842 5284e7fd2f I presence subscription 2025-09-18 15:56:13 +02:00
a6a2f5842 c4937dc0c5 A app to mockconnection 2025-09-17 16:43:42 +02:00
a6a2f5842 5607969ae1 BF unsubscribing 2025-09-16 13:39:48 +02:00
a6a2f5842 741cffe03a BF unsubscribe 2025-09-16 11:20:48 +02:00
a6a2f5842 c38e8fc082 BF broadcast 2025-09-16 10:58:54 +02:00
a6a2f5842 df349aabf7 BF subscribe & I logging 2025-09-16 08:54:13 +02:00
a6a2f5842 a6ff330e57 BF pinging 2025-09-15 16:31:02 +02:00