Download the PHP package remotelyliving/php-query-bus without Composer

On this page you can find all versions of the php package remotelyliving/php-query-bus. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.

FAQ

After the download, you have to make one include require_once('vendor/autoload.php');. After that you have to import the classes with use statements.

Example:
If you use only one package a project is not needed. But if you use more then one package, without a project it is not possible to import the classes with use statements.

In general, it is recommended to use always a project to download your libraries. In an application normally there is more than one library needed.
Some PHP packages are not free to download and because of that hosted in private repositories. In this case some credentials are needed to access such packages. Please use the auth.json textarea to insert credentials, if a package is coming from a private repository. You can look here for more information.

  • Some hosting areas are not accessible by a terminal or SSH. Then it is not possible to use Composer.
  • To use Composer is sometimes complicated. Especially for beginners.
  • Composer needs much resources. Sometimes they are not available on a simple webspace.
  • If you are using private repositories you don't need to share your credentials. You can set up everything on our site and then you provide a simple download link to your team member.
  • Simplify your Composer build process. Use our own command line tool to download the vendor folder as binary. This makes your build process faster and you don't need to expose your credentials for private repositories.
Please rate this library. Is it a good library?

Informations about the package php-query-bus

Build Status Total Downloads Coverage Status License Scrutinizer Code Quality

php-query-bus: 🚍 A Query Bus Implementation For PHP 🚍

Use Cases

If you want a light weight compliment to your Command Bus for CQRS, hopefully this library helps out. It's very similar to a Command Bus, but it returns a Result.

I've used magical data loading solutions before, but good old fashioned set of specific Query, Result, and Handler objects for a given Use Case is generally more performant, predictable, and explicit than magic-based implementations.

Installation

Usage

Create the Query Resolver

The resolver can have handlers added manually or locate them in a PSR-11 Service Container Queries are mapped 1:1 with a handler and are mapped by the Query class name as the lookup key.

Create the Query Bus

The Query Bus takes in a Query Resolver and pushes whatever Middleware you want on the stack.

Middleware is any callable that returns a Result. Some base middleware is included: src/Middleware

That's really all there is to it!

Query

The Query for this library is left intentionally unimplemented. It is just an object. My suggestion for Query objects is to keep them as a DTO of what you need to query your data source by.

An example query might look like this:

As you can see, it's just a few getters and option builder.

Result

The Result is similarly unimplemented except for the provided AbstractResult. Results can have their own custom getters for your use case. An example Result for the GetUserQuery above might look like:

As you can see, it's not too hard to start building Result graphs for outputting a response or to feed another part of your app.

Handler

The handlers are where the magic happens. Inject what ever repository, API Client, or ORM you need to load data. It will ask the query for query parameters and return a result. You can also request other query results inside a handler from the bus. Going with our GetUserQuery example, a Handler could look like:

Middleware

There are a few Middleware that this library ships with. The default execution order is LIFO and the signature very simple.

A Middleware must return an instance of Result and be callable. That's it!

An example Middleware could be as simple as this:

QueryCacher

This middleware provides some interesting query caching by utilizing Probabilistic Early Cache Expiry to help prevent cache stampedes. To be cached, a Query must implement the CacheableQuery interface. To recompute cache simply fire off a Query with the value of CacheableQuery::shouldRecomputeResult() returning true.

QueryLogger

Helpful for debugging, but best left for dev and stage environments. Looks for the LoggableQuery marker interface on the query

ResultErrorLogger

Helpful for debugging and alerting based on your logging setup.

PerfBudgetLogger

Allows you to set certain rough performance thresholds and log with something has gone over that threshold.

Future Future Development


All versions of php-query-bus with dependencies

PHP Build Version
Package Version
Requires ext-json Version *
ext-filter Version *
ext-mbstring Version *
psr/log Version ^1.0
psr/container Version ^1.0
myclabs/php-enum Version ^1.7
psr/cache Version ^1.0
php Version >=7.4
Composer command for our command line client (download client) This client runs in each environment. You don't need a specific PHP version etc. The first 20 API calls are free. Standard composer command

The package remotelyliving/php-query-bus contains the following files

Loading the files please wait ....