https://github.com/lyrixx/async-messenger-mercure
Demo for Symfony Messenger + Mercure
https://github.com/lyrixx/async-messenger-mercure
async mercure messenger php
Last synced: 6 months ago
JSON representation
Demo for Symfony Messenger + Mercure
- Host: GitHub
- URL: https://github.com/lyrixx/async-messenger-mercure
- Owner: lyrixx
- Created: 2020-04-27T13:57:22.000Z (over 5 years ago)
- Default Branch: main
- Last Pushed: 2025-03-28T18:01:56.000Z (7 months ago)
- Last Synced: 2025-03-29T23:22:14.312Z (7 months ago)
- Topics: async, mercure, messenger, php
- Language: PHP
- Homepage: https://s.lyrixx.info/async
- Size: 3.87 MB
- Stars: 34
- Watchers: 2
- Forks: 4
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Async with Messenger & Mercure
[light.webm](https://github.com/user-attachments/assets/a7c46f6b-101b-4a81-9ed2-2ff60af4c92b)
This project is a demo for [a talk I'll give at SymfonyLive Paris 2025](https://s.lyrixx.info/async).
It's all about async processing with Symfony Messenger and Mercure.
## Running the application locally
### Requirements
A Docker environment is provided and requires you to have these tools available:
* Docker
* Bash
* [Castor](https://github.com/jolicode/castor#installation)#### Castor
Once `castor` is installed, in order to improve your usage of `castor` scripts, you
can install console autocompletion script.If you are using bash:
```bash
castor completion | sudo tee /etc/bash_completion.d/castor
```If you are using something else, please refer to your shell documentation. You
may need to use `castor completion > /to/somewhere`.`castor` supports completion for `bash`, `zsh` & `fish` shells.
### Docker environment
The Docker infrastructure provides a web stack with:
- FrankenPHP (+Mercure)
- PostgreSQL
- Traefik
- A container with some tooling:
- Composer
- Node
- Yarn / NPM### Domain configuration (first time only)
Before running the application for the first time, ensure your domain names
point the IP of your Docker daemon by editing your `/etc/hosts` file.This IP is probably `127.0.0.1` unless you run Docker in a special VM (like docker-machine for example).
> [!NOTE]
> The router binds port 80 and 443, that's why it will work with `127.0.0.1````
echo '127.0.0.1 async-messenger-mercure.test' | sudo tee -a /etc/hosts
```### Starting the stack
Launch the stack by running this command:
```bash
castor start
```> [!NOTE]
> the first start of the stack should take a few minutes.The site is now accessible at the hostnames you have configured over HTTPS
(you may need to accept self-signed SSL certificate if you do not have `mkcert`
installed on your computer - see below).### SSL certificates
HTTPS is supported out of the box. SSL certificates are not versioned and will
be generated the first time you start the infrastructure (`castor start`) or if
you run `castor docker:generate-certificates`.If you have `mkcert` installed on your computer, it will be used to generate
locally trusted certificates. See [`mkcert` documentation](https://github.com/FiloSottile/mkcert#installation)
to understand how to install it. Do not forget to install CA root from `mkcert`
by running `mkcert -install`.If you don't have `mkcert`, then self-signed certificates will instead be
generated with `openssl`. You can configure [infrastructure/docker/services/router/openssl.cnf](infrastructure/docker/services/router/openssl.cnf)
to tweak certificates.You can run `castor docker:generate-certificates --force` to recreate new certificates
if some were already generated. Remember to restart the infrastructure to make
use of the new certificates with `castor up` or `castor start`.### Builder
Having some composer, yarn or other modifications to make on the project?
Start the builder which will give you access to a container with all these
tools available:```bash
castor builder
```### Other tasks
Checkout `castor` to have the list of available tasks.