Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

fix: internal links use /docs prefix #468

Merged
merged 1 commit into from
Jun 13, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
8 changes: 4 additions & 4 deletions docs/advanced-usage/replaying-events.md
Original file line number Diff line number Diff line change
Expand Up @@ -3,11 +3,11 @@ title: Replaying events
weight: 2
---

All [events](/laravel-event-sourcing/v7/advanced-usage/preparing-events/) that implement `Spatie\EventSourcing\ShouldBeStored` will be [serialized](/laravel-event-sourcing/v7/advanced-usage/using-your-own-event-serializer) and stored in the `stored_events` table. After your app has been doing its work for a while the `stored_events` table will probably contain some events.
All [events](/docs/laravel-event-sourcing/v7/advanced-usage/preparing-events/) that implement `Spatie\EventSourcing\ShouldBeStored` will be [serialized](/docs/laravel-event-sourcing/v7/advanced-usage/using-your-own-event-serializer) and stored in the `stored_events` table. After your app has been doing its work for a while the `stored_events` table will probably contain some events.

When creating a new [projector](/laravel-event-sourcing/v7/using-projectors/writing-your-first-projector/) you'll want to feed all stored events to that new projector. We call this process replaying events.
When creating a new [projector](/docs/laravel-event-sourcing/v7/using-projectors/writing-your-first-projector/) you'll want to feed all stored events to that new projector. We call this process replaying events.

Events can be replayed to [all projectors that were added to the projectionist](/laravel-event-sourcing/v7/using-projectors/creating-and-configuring-projectors/) with this artisan command:
Events can be replayed to [all projectors that were added to the projectionist](/docs/laravel-event-sourcing/v7/using-projectors/creating-and-configuring-projectors/) with this artisan command:

```bash
php artisan event-sourcing:replay
Expand Down Expand Up @@ -36,7 +36,7 @@ public function resetState(?string $aggregateUuid = null): void

If you want to replay events starting from a certain event you can use the `--from` option when executing `event-sourcing:replay`. If you use this option the `resetState` on projectors will not get called. This package does not track which events have already been processed by which projectors. Be sure not to replay events to projectors that already have handled them.

If you are [using your own event storage model](/laravel-event-sourcing/v7/advanced-usage/using-your-own-event-storage-model/) then you will need to use the `--stored-event-model` option when executing `event-sourcing:replay` to specify the model storing the events you want to replay.
If you are [using your own event storage model](/docs/laravel-event-sourcing/v7/advanced-usage/using-your-own-event-storage-model/) then you will need to use the `--stored-event-model` option when executing `event-sourcing:replay` to specify the model storing the events you want to replay.

```bash
php artisan event-sourcing:replay --stored-event-model=App\\Models\\AccountStoredEvent
Expand Down
2 changes: 1 addition & 1 deletion docs/advanced-usage/storing-metadata.md
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ You can add metadata, such as the `id` of the logged in user, to a stored event.

If you need to store metadata on all events you can leverage Laravel's native models events when using the `EloquentStoredEventRepository`.

You must configure the package to [use your own eloquent event storage model](/laravel-event-sourcing/v7/advanced-usage/using-your-own-event-storage-model) that extends the `EloquentStoredEvent` model. On that model you can hook into the model lifecycle hooks.
You must configure the package to [use your own eloquent event storage model](/docs/laravel-event-sourcing/v7/advanced-usage/using-your-own-event-storage-model) that extends the `EloquentStoredEvent` model. On that model you can hook into the model lifecycle hooks.

```php
use Spatie\EventSourcing\StoredEvents\Models\EloquentStoredEvent;
Expand Down
2 changes: 1 addition & 1 deletion docs/getting-familiar-with-event-sourcing/introduction.md
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ Event sourcing tries to solve this problem by storing all events that happen in

Here's a concrete example to make it more clear. Imagine you're a bank. Your clients have accounts. Storing the balance of the accounts wouldn't be enough; all the transactions should be remembered too. With event sourcing, the balance isn't a standalone database field, but a value calculated from the stored transactions.

After taking a look at [an example of traditional application](/laravel-event-sourcing/v7/getting-familiar-with-event-sourcing/the-traditional-application), we're going to discuss the two concepts that make up this package: [projectors](/laravel-event-sourcing/v7/getting-familiar-with-event-sourcing/using-projectors-to-transform-events) and [aggregates](/laravel-event-sourcing/v7/getting-familiar-with-event-sourcing/using-aggregates-to-make-decisions-based-on-the-past).
After taking a look at [an example of traditional application](/docs/laravel-event-sourcing/v7/getting-familiar-with-event-sourcing/the-traditional-application), we're going to discuss the two concepts that make up this package: [projectors](/docs/laravel-event-sourcing/v7/getting-familiar-with-event-sourcing/using-projectors-to-transform-events) and [aggregates](/docs/laravel-event-sourcing/v7/getting-familiar-with-event-sourcing/using-aggregates-to-make-decisions-based-on-the-past).

If you want to skip to reading code immediately, here are the Larabank example apps used in this section. In all of them, you can create accounts and deposit or withdraw money.

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -53,4 +53,4 @@ Whenever we retrieve an aggregate, all of the previously stored events will be f

In summary, aggregates are used to make decisions based on past events.

If you want to know how to create and use aggregates, head over to [the `using-aggregates` section](/laravel-event-sourcing/v7/using-aggregates/writing-your-first-aggregate).
If you want to know how to create and use aggregates, head over to [the `using-aggregates` section](/docs/laravel-event-sourcing/v7/using-aggregates/writing-your-first-aggregate).
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ title: Using projectors to transform events
weight: 3
---

Let's build a bit further on the [Larabank example](https://github.com/spatie/larabank-traditional) mentioned in [the previous section](/laravel-event-sourcing/v7/getting-familiar-with-event-sourcing/the-traditional-application). The main drawback highlighted that example is the fact that when updating a value, we lose the old value. Let's solve that problem.
Let's build a bit further on the [Larabank example](https://github.com/spatie/larabank-traditional) mentioned in [the previous section](/docs/laravel-event-sourcing/v7/getting-familiar-with-event-sourcing/the-traditional-application). The main drawback highlighted that example is the fact that when updating a value, we lose the old value. Let's solve that problem.

Instead of directly updating the value in the database, we could write every change we want to make as an event in our database.

Expand Down Expand Up @@ -37,4 +37,4 @@ This package can help you store native Laravel events in a `stored_events` table

Here's our example app [Larabank rebuild with projectors](https://github.com/spatie/larabank-projectors). In [the `AccountsController`](https://github.com/spatie/larabank-projectors/blob/677777c0cb7fd2584b54073ac82c91e25fd07d2b/app/Http/Controllers/AccountsController.php#L20-L36) we're not going to directly modify the database anymore. Instead, the controller will call methods which will in [their turn fire off events](https://github.com/spatie/larabank-projectors/blob/677777c0cb7fd2584b54073ac82c91e25fd07d2b/app/Account.php#L15-L41). Our package will listen for those events (which implement the empty `ShouldBeStored` interface) and store them in the `stored_events` table. Those events will also get passed to [all registered projectors](https://github.com/spatie/larabank-projectors/blob/677777c0cb7fd2584b54073ac82c91e25fd07d2b/config/event-sourcing.php#L18-L20). The [`AccountsProjector`](https://github.com/spatie/larabank-projectors/blob/677777c0cb7fd2584b54073ac82c91e25fd07d2b/app/Projectors/AccountsProjector.php) will build the `Accounts` table using [a couple of events it listens for](https://github.com/spatie/larabank-projectors/blob/677777c0cb7fd2584b54073ac82c91e25fd07d2b/app/Projectors/AccountsProjector.php#L17-L20).

If you want to know more about projectors and how to use them, head over to [the `using-projectors` section](/laravel-event-sourcing/v7/using-projectors/writing-your-first-projector).
If you want to know more about projectors and how to use them, head over to [the `using-projectors` section](/docs/laravel-event-sourcing/v7/using-projectors/writing-your-first-projector).
2 changes: 1 addition & 1 deletion docs/installation-setup.md
Original file line number Diff line number Diff line change
Expand Up @@ -112,7 +112,7 @@ use Spatie\EventSourcing\EventSerializers\JsonEventSerializer;use Spatie\EventSo
];
```

The package will scan all classes of your project to [automatically discover projectors and reactors](/laravel-event-sourcing/v7/advanced-usage/discovering-projectors-and-reactors#discovering-projectors-and-reactors). In a production environment you probably should [cache auto discovered projectors and reactors](/laravel-event-sourcing/v7/advanced-usage/discovering-projectors-and-reactors#caching-discovered-projectors-and-reactors).
The package will scan all classes of your project to [automatically discover projectors and reactors](/docs/laravel-event-sourcing/v7/advanced-usage/discovering-projectors-and-reactors#discovering-projectors-and-reactors). In a production environment you probably should [cache auto discovered projectors and reactors](/docs/laravel-event-sourcing/v7/advanced-usage/discovering-projectors-and-reactors#caching-discovered-projectors-and-reactors).

It's recommended that you set up a queue. Specify the connection name in the `queue` key of the `event-sourcing` config file. This queue will be used to guarantee that the events will be processed by all projectors in the right order. You should make sure that the queue will process only one job at a time. In a local environment, where events have a very low chance of getting fired concurrently, it's probably ok to just use the `sync` driver.

Expand Down
2 changes: 1 addition & 1 deletion docs/introduction.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ weight: 1

This package aims to be the entry point to get started with event sourcing in Laravel. It can help you setting up aggregates, projectors and reactors.

If you've never worked with event sourcing, or are uncertain about what projectors, reactors and aggregates are, head over to [the getting familiar with event sourcing section](/laravel-event-sourcing/v7/getting-familiar-with-event-sourcing/introduction).
If you've never worked with event sourcing, or are uncertain about what projectors, reactors and aggregates are, head over to [the getting familiar with event sourcing section](/docs/laravel-event-sourcing/v7/getting-familiar-with-event-sourcing/introduction).

Event sourcing might be a good choice for your project if:

Expand Down
2 changes: 1 addition & 1 deletion docs/using-aggregates/writing-your-first-aggregate.md
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ title: Writing your first aggregate
weight: 1
---

An aggregate is a class that decides to record events based on past events. To know more about their general purpose and the idea behind them, read this section on [using aggregates to make decisions-based-on-the-past](/laravel-event-sourcing/v7/getting-familiar-with-event-sourcing/using-aggregates-to-make-decisions-based-on-the-past).
An aggregate is a class that decides to record events based on past events. To know more about their general purpose and the idea behind them, read this section on [using aggregates to make decisions-based-on-the-past](/docs/laravel-event-sourcing/v7/getting-familiar-with-event-sourcing/using-aggregates-to-make-decisions-based-on-the-past).

## Creating an aggregate

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -66,7 +66,7 @@ Just by adding a typehint of the event you want to handle makes our package call

## Getting the uuid of an event

In most cases you want to have access to the event that was fired. When [using aggregates](/laravel-event-sourcing/v7/using-aggregates/writing-your-first-aggregate) your events probably won't contain the uuid associated with that event. To get to the uuid of an event simply call the `aggregateRootUuid()` method on the event object.
In most cases you want to have access to the event that was fired. When [using aggregates](/docs/laravel-event-sourcing/v7/using-aggregates/writing-your-first-aggregate) your events probably won't contain the uuid associated with that event. To get to the uuid of an event simply call the `aggregateRootUuid()` method on the event object.

```php
// ...
Expand Down
4 changes: 2 additions & 2 deletions docs/using-projectors/thinking-in-events.md
Original file line number Diff line number Diff line change
Expand Up @@ -3,9 +3,9 @@ title: Thinking in events
weight: 5
---

In this example we're going to try to send a mail whenever an account is broke (balance below zero). You can do this with projectors and reactors alone, but aggregates might be a better fit for this. Aggregates make it easy to make decisions based on past events. Check out the section on [how to use aggregates](/laravel-event-sourcing/v7/using-aggregates/writing-your-first-aggregate) to learn more about them, or keep reading on this page if you don't want to use aggregates.
In this example we're going to try to send a mail whenever an account is broke (balance below zero). You can do this with projectors and reactors alone, but aggregates might be a better fit for this. Aggregates make it easy to make decisions based on past events. Check out the section on [how to use aggregates](/docs/laravel-event-sourcing/v7/using-aggregates/writing-your-first-aggregate) to learn more about them, or keep reading on this page if you don't want to use aggregates.

Let's build upon the examples shown in the [writing your first projector](/laravel-event-sourcing/v7/using-projectors/writing-your-first-projector) and [handling side effects with reactors](/laravel-event-sourcing/v7/using-reactors/writing-your-first-reactor)' sections.
Let's build upon the examples shown in the [writing your first projector](/docs/laravel-event-sourcing/v7/using-projectors/writing-your-first-projector) and [handling side effects with reactors](/docs/laravel-event-sourcing/v7/using-reactors/writing-your-first-reactor)' sections.

Imagine you are tasked with sending a mail to an account holder whenever he or she is broke. You might think, that's easy, let's just check in a new reactor if the account balance is less than zero.

Expand Down
2 changes: 1 addition & 1 deletion docs/using-reactors/writing-your-first-reactor.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ weight: 1

## What is a reactor

Now that you've [written your first projector](/laravel-event-sourcing/v7/using-projectors/writing-your-first-projector), let's learn how to handle side effects. With side effects we mean things like sending a mail, sending a notification, ... You only want to perform these actions when the original event happens. You don't want to do this work when replaying events.
Now that you've [written your first projector](/docs/laravel-event-sourcing/v7/using-projectors/writing-your-first-projector), let's learn how to handle side effects. With side effects we mean things like sending a mail, sending a notification, ... You only want to perform these actions when the original event happens. You don't want to do this work when replaying events.

A reactor is a class, that much like a projector, listens for incoming events. Unlike projectors however, reactors will not get called when events are replayed. Reactors only will get called when the original event fires.

Expand Down