Standalone Composer/CMake project under examples/todo/ derived from the
skeleton, demonstrating every Phase 3 architectural primitive in a
non-trivial app. All cross-side wiring is maker-generated; no
handwritten bridge glue.
Generated and customised:
- src/Entity/Todo.php — make:bridge:resource Todo (UUIDv7 id)
- src/Controller/TodoController.php — make:bridge:resource Todo (CRUD)
- src/Controller/MarkAllDoneController.php — make:bridge:command
MarkAllDone, body filled in to flip done=true on every row
- qml/TodoList.qml — make:bridge:resource Todo (starter ListView)
- qml/TodoWindow.qml — make:bridge:window Todo, body customised to
embed a read-only mirror of the same ReactiveListModel
The Phase 1 ping demo is dropped from this app — it doesn't fit the
todo flow and nothing in Main.qml references it.
Main.qml is the real list UI:
- Add input + button (POST /api/todos with optimistic-friendly key).
- Per-row CheckBox + delete button (PATCH/DELETE via
todoModel.invoke() with `pending` role driving opacity).
- "Mark all done" button (POST /api/mark-all-done).
- "Open second window" button (Component { TodoWindow {} } pattern).
Build / run delegated to the same Makefile shape as the skeleton, with
SCRIPT_DIR/QT_BIN updated for the renamed binary (build/qml/todo).
composer.json's path repo points at ../../../framework/php (one level
deeper than the skeleton's path repo).
Verified end-to-end with offscreen QPA: POST/PATCH/DELETE on /api/todos
all round-trip, /api/mark-all-done flips every row, Mercure dual-
publishes on every change. Clean shutdown.
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
22 lines
1.0 KiB
Bash
22 lines
1.0 KiB
Bash
APP_ENV=dev
|
|
APP_DEBUG=1
|
|
APP_SECRET=dev-secret-not-for-production-use
|
|
|
|
# Mercure hub (FrankenPHP-built-in). Both URLs are typically the same in
|
|
# dev mode where the hub and the app are colocated.
|
|
MERCURE_URL=http://127.0.0.1:8765/.well-known/mercure
|
|
MERCURE_PUBLIC_URL=http://127.0.0.1:8765/.well-known/mercure
|
|
# Used by mercure-bundle to mint publisher JWTs. Must match the
|
|
# publisher_jwt secret in ../Caddyfile. lcobucci/jwt requires HMAC
|
|
# secrets to be at least 256 bits, so the dev value here is 64 chars.
|
|
MERCURE_JWT_SECRET=dev_php_qml_bridge_jwt_secret_at_least_256_bits_long_for_lcobucci
|
|
MERCURE_PUBLISHER_JWT_KEY=dev_php_qml_bridge_jwt_secret_at_least_256_bits_long_for_lcobucci
|
|
MERCURE_SUBSCRIBER_JWT_KEY=dev_php_qml_bridge_jwt_secret_at_least_256_bits_long_for_lcobucci
|
|
|
|
# Bearer token the Qt host sends on /api/* requests.
|
|
BRIDGE_TOKEN=devtoken
|
|
|
|
# SQLite database for dev. Apps move to Postgres / MySQL by overriding
|
|
# DATABASE_URL in .env.local once they outgrow it.
|
|
DATABASE_URL="sqlite:///%kernel.project_dir%/var/data.sqlite"
|