heyjorgedev / qstash-php
QStash SDK for PHP - QStash is an HTTP based messaging and scheduling solution for serverless and edge runtimes
Fund package maintenance!
heyjorgedev
Requires
- php: ^8.2
- ext-json: *
- ext-mbstring: *
- php-http/discovery: ^1.19.4
- psr/http-client: ^1.0.3
- psr/http-client-implementation: ^1.0.1
- psr/http-factory-implementation: *
- psr/http-message: ^1.1.0|^2.0.0
- web-token/jwt-library: ^4.0
Requires (Dev)
- guzzlehttp/guzzle: ^7.8.1
- laravel/pint: ^1.0
- mockery/mockery: ^1.6
- nunomaduro/collision: ^8.1.1
- pestphp/pest: ^3.0
- spatie/ray: ^1.28
This package is auto-updated.
Last update: 2025-01-09 14:12:35 UTC
README
This project is still in early stages of development. I am still writing most of the API endpoints and the API is under constant change so I do not recommend to use it on production yet.
QStash Client SDK for PHP
QStash is an HTTP based messaging and scheduling solution for serverless and edge runtimes.
How does QStash work?
QStash is the message broker between your serverless apps. You send an HTTP request to QStash, that includes a destination, a payload and optional settings. We durably store your message and will deliver it to the destination API via HTTP. In case the destination is not ready to receive the message, we will retry the message later, to guarantee at-least-once delivery.
Installation
You can install the package via composer:
composer require heyjorgedev/qstash-php
Get your authorization token
Go to Upstash Console and copy the QSTASH_TOKEN.
Basic Usage
use HeyJorgeDev\QStash\QStash; use HeyJorgeDev\QStash\ValueObjects\Message; use HeyJorgeDev\QStash\ValueObjects\Url; $client = QStash::client('QSTASH_TOKEN'); $message = $client->publish( Message::to(new Url('https://my-api...')) ->withBody([ 'hello' => 'world', ]) ]); // to know if the request was successful: echo $message->isSuccessful() // to get the message echo $message->getData(); // to get the message id echo $message->getData()->id;
Receiver
When receiving a message from QStash, you should verify the signature. We have a class to help you with that:
use HeyJorgeDev\QStash\QStash; $receiver = QStash::receiver([ 'QSTASH_CURRENT_SIGNING_KEY', 'QSTASH_NEXT_SIGNING_KEY', ]); $result = $receiver->verify( body: $request->getBody(), signature: $request->getHeader('Upstash-Signature'), url: $request->getUri(), ); echo $result; // true or false
Testing
composer test
Changelog
Please see CHANGELOG for more information on what has changed recently.
Contributing
Please see CONTRIBUTING for details.
Security Vulnerabilities
Please review our security policy on how to report security vulnerabilities.
Credits
License
The MIT License (MIT). Please see License File for more information.