petitpress / gps-messenger-bundle
Google Pub/Sub transport for Symfony Messenger
Installs: 305 970
Dependents: 2
Suggesters: 0
Security: 0
Stars: 22
Watchers: 6
Forks: 19
Open Issues: 7
Type:symfony-bundle
Requires
- php: >=8.2
- ext-json: *
- google/cloud-pubsub: ^2.0
- psr/cache: ^1.0|^2.0|^3.0
- symfony/config: ^5.4|^6.0|^7.0
- symfony/dependency-injection: ^5.4|^6.0|^7.0
- symfony/http-kernel: ^5.4|^6.0|^7.0
- symfony/messenger: ^5.4|^6.0|^7.0
- symfony/options-resolver: ^5.4|^6.0|^7.0
Requires (Dev)
- phpstan/phpstan: ^2.1
- phpstan/phpstan-deprecation-rules: ^2.0
- phpstan/phpstan-phpunit: ^2.0
- phpstan/phpstan-strict-rules: ^2.0
- phpstan/phpstan-symfony: ^2.0
- phpunit/phpunit: ^9.5
- symfony/yaml: ^5.4|^6.0|^7.0
- symplify/easy-coding-standard: ^11.1
- vimeo/psalm: ^6.0
This package is auto-updated.
Last update: 2025-04-11 09:35:23 UTC
README
This bundle provides a simple implementation of Google Pub/Sub transport for Symfony Messenger.
The bundle requires only symfony/messenger
, google/cloud-pubsub
and symfony/options-resolver
packages.
In contrast with Enqueue GPS transport,
it doesn't require Enqueue
and some bridge.
Features
- Compatible with the latest
google/cloud-pubsub
2.*. - Zero extra dependencies beyond core Symfony (e.g.
Symfony Messenger
) and Pub/Sub libraries. - Flexible and extensive configuration, available via options or DSN (Data Source Name), including
deadLetterPolicy
,enableMessageOrdering
,ackDeadlineSeconds
). - Automatic Pub/Sub Topic and Subscription creation, with the ability to disable it if needed.
- Message ordering support using the
OrderingKeyStamp
. - Keep-alive support for long-running Messenger workers.
Support
Version | Status | Symfony Versions |
---|---|---|
3.x | Actively Supported | >= 5.4 |
4.x | In development | >= 7.2 |
Installation
Step 1: Install the Bundle
From within container execute the following command to download the latest version of the bundle:
$ composer require petitpress/gps-messenger-bundle --no-scripts
Step 2: Configure environment variables
Official Google Cloud PubSub SDK requires some globally accessible environment variables.
You might need to change default Symfony DotEnv instance to use putenv
as Google needs to access some variables through getenv
. To do so, use putenv method in config/bootstrap.php
:
(new Dotenv())->usePutenv()->...
List of Google Pub/Sub configurable variables :
# use these for production environment: GOOGLE_APPLICATION_CREDENTIALS='google-pubsub-credentials.json' GCLOUD_PROJECT='project-id' # use these for development environment (if you have installed Pub/Sub emulator): PUBSUB_EMULATOR_HOST=http://localhost:8538
or if you have credentials in a base64 encoded env variable:
# config/packages/messenger.yaml framework: messenger: transports: gps_transport: dsn: 'gps://default' options: client_config: credentials: '%env(json:base64:GOOGLE_PUBSUB_KEY)%'
Step 3: Configure Symfony Messenger
# config/packages/messenger.yaml framework: messenger: transports: gps_transport: dsn: 'gps://default' options: client_config: # optional (default: []) apiEndpoint: 'https://europe-west3-pubsub.googleapis.com' topic: # optional (default name: messages) name: 'messages' options: # optional create options if not exists (default: []), for all options take at look at https://cloud.google.com/php/docs/reference/cloud-pubsub/latest/Topic#_Google_Cloud_PubSub_Topic__create__ labels: - label1 - label2 subscription: # optional (default the same as topic.name) name: 'messages' options: # optional create options if not exists (default: []), for all options take a look at https://cloud.google.com/php/docs/reference/cloud-pubsub/latest/Subscription#_Google_Cloud_PubSub_Subscription__create__ enableExactlyOnceDelivery: true labels: - label1 - label2 pull: maxMessages: 10 # optional (default: 10)
or:
# config/packages/messenger.yaml framework: messenger: transports: gps_transport: dsn: 'gps://default/messages?client_config[apiEndpoint]=https://europe-west3-pubsub.googleapis.com&subscription[pull][maxMessages]=10'
to use emulator in local:
# config/packages/dev/messenger.yaml framework: messenger: transports: gps_transport: options: client_config: hasEmulator: true emulatorHost: '%env(PUBSUB_EMULATOR_HOST)%'
Step 4: Configure PetitPressGpsMessengerBundle (optional)
Configure the cache service where authentication tokens are stored. The default is cache.app
.
# config/packages/petit_press_gps_messenger.yaml petit_press_gps_messenger: auth_cache: 'cache.app'
Step 5: Use available stamps if needed
-
OrderingKeyStamp
: use for keeping messages of the same context in order. For more information, read an official documentation. -
AttributesStamp
: use to add contextual metadata to serialized messages. For more information, read an official documentation. Can be very useful when used together with subscription filters.
Step 6: Create topics from config
bin/console messenger:setup-transports
License
This bundle is released under the MIT License.