2017 © Pedro Peláez
 

library pdo-event-store

Prooph PDO EventStore

image

prooph/pdo-event-store

Prooph PDO EventStore

  • Saturday, July 14, 2018
  • by prooph
  • Repository
  • 14 Watchers
  • 42 Stars
  • 60,831 Installations
  • PHP
  • 14 Dependents
  • 6 Suggesters
  • 31 Forks
  • 7 Open issues
  • 35 Versions
  • 30 % Grown

The README.md

pdo-event-store

Build Status Coverage Status Gitter, (*1)

PDO EventStore implementation for Prooph EventStore, (*2)

Requirements

  • PHP >= 7.3
  • PDO_MySQL Extension or PDO_PGSQL Extension

For MariaDB you need server version >= 10.2.11.
Performance Impact: see [MariaDB Indexes and Efficiency](docs/variants.md#MariaDB Indexes and Efficiency), (*3)

For MySQL you need server version >= 5.7.9., (*4)

For Postgres you need server version >= 9.4., (*5)

Attention: Since v1.6.0 MariaDB Server has to be at least 10.2.11 due to a bugfix in MariaDB, see https://jira.mariadb.org/browse/MDEV-14402., (*6)

Setup

For MariaDB run the script in scripts/mariadb/01_event_streams_table.sql on your server., (*7)

For MySQL run the script in scripts/mysql/01_event_streams_table.sql on your server., (*8)

For Postgres run the script in scripts/postgres/01_event_streams_table.sql on your server., (*9)

This will setup the required event streams table., (*10)

If you want to use the projections, run additionally the scripts scripts/mariadb/02_projections_table.sql (for MariaDB), scripts/mysql/02_projections_table.sql (for MySQL) or scripts/postgres/02_projections_table.sql (for Postgres) on your server., (*11)

Upgrade from 1.6 to 1.7

Starting from v1.7 the pdo-event-store uses optimized table schemas. The upgrade can be done in background with a script optimizing that process. A downtime for the database should not be needed. In order to upgrade your existing database, you have to execute:, (*12)

  • MariaDB
ALTER TABLE `event_streams` MODIFY `metadata` LONGTEXT NOT NULL;
ALTER TABLE `projections` MODIFY `position` LONGTEXT;
ALTER TABLE `projections` MODIFY `state` LONGTEXT;

Then for all event-streams (SELECT stream_name FROM event_streams), (*13)

ALTER TABLE <stream_name> MODIFY `payload` LONGTEXT NOT NULL;
ALTER TABLE <stream_name> MODIFY `metadata` LONGTEXT NOT NULL,
  • MySQL

nothing to upgrade, (*14)

  • Postgres

For all event-streams (SELECT stream_name FROM event_streams), (*15)

ALTER TABLE <stream_name> MODIFY event_id UUID NOT NULL;

Additional note:, (*16)

When using Postgres, the event_id has to be a valid uuid, so be careful when using a custom MetadataMatcher, as the event-store could throw an exception when passing a non-valid uuid (f.e. "foo") as uuid., (*17)

The migration is strongly recommended, but not required. It's fully backward-compatible. The change on Postgres is only a microoptimization, the change on MariaDB prevents errors, when the stored json gets too big., (*18)

Introduction

Prooph Event Store v7, (*19)

Tests

If you want to run the unit tests locally you need a runnging MySql server listening on port 3306 and a running Postgres server listening on port 5432. Both should contain an empty database event_store_tests., (*20)

Run Tests With Composer

MariaDb

$ vendor/bin/phpunit -c phpunit.xml.mariadb, (*21)

MySql

$ vendor/bin/phpunit -c phpunit.xml.mysql, (*22)

Postgres

$ vendor/bin/phpunit -c phpunit.xml.postgres, (*23)

Run Tests With Docker Compose

MariaDb

docker-compose -f docker-compose-tests.yml run composer run-script test-mariadb --timeout 0; \
docker-compose -f docker-compose-tests.yml stop

MySql

docker-compose -f docker-compose-tests.yml run composer run-script test-mysql --timeout 0; \
docker-compose -f docker-compose-tests.yml stop

Postgres

docker-compose -f docker-compose-tests.yml run composer run-script test-postgres --timeout 0; \
docker-compose -f docker-compose-tests.yml stop

Support

Contribute

Please feel free to fork and extend existing or add new plugins and send a pull request with your changes! To establish a consistent code quality, please provide unit tests for all your changes and may adapt the documentation., (*24)

License

Released under the New BSD License., (*25)

The Versions