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

Develop #12

Merged
merged 2 commits into from
Aug 13, 2024
Merged
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
114 changes: 111 additions & 3 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -42,9 +42,117 @@ aspects such as the SNS route and expected topics.

## Usage

Detailed usage instructions will be provided soon. This section will cover how to integrate the listener into your
Laravel application, including setting up the route for SNS notifications, handling subscription confirmations, and
registering event listeners.
This package provides a set of Laravel events that can be used to handle AWS SNS notifications in your application.
Below is an overview of the available events, their corresponding message types, and the methods you can use to access
the data they provide.

### Available Events

- **`NotificationReceived`**
This is the base event for general SNS notifications. It can be extended for specific types of notifications.

- **`CloudWatchNotificationReceived`**
This event is triggered when a CloudWatch alarm changes state. It extends `NotificationReceived`.

- **`S3NotificationReceived`**
This event is triggered when an S3 bucket sends a notification, such as when an object is created or deleted. It
extends `NotificationReceived`.

- **`SesNotificationReceived`**
This event is triggered when SES (Simple Email Service) sends a notification, such as a bounce or complaint. It
extends `NotificationReceived`.

- **`SubscriptionConfirmed`**
This event is triggered when a subscription to an SNS topic is confirmed.

### Handling Events

Each event provides a `Message` instance that implements the relevant interface for the notification type. These
interfaces allow you to access the specific data provided by the notification.

#### Base Message

The base `Message` provides the following methods, common to all notification types:

```php
public function getBaseMessage(): BaseMessage; // Aws\Sns\Message
public function getId(): string;
public function getType(): string;
public function getTopic(): string;
public function getTimestamp(): Carbon;
public function getMessage(): stdClass;
public function getSignatureVersion(): string;
public function getSignature(): string;
public function getSigningCertificateUrl(): string;
public function getAttributes(): ?array;
```

#### Subscription Confirmation

When listening for the `SubscriptionConfirmed` event, the message implements the `SubscriptionConfirmationInterface`. In
addition to the base methods, it also provides:

```php
public function getSubscribeUrl(): string;
```

This method returns the URL to confirm the subscription.

#### General Notification

For general notifications (handled by `NotificationReceived`), the message implements the `NotificationInterface`. In
addition to the base methods, it also provides:

```php
public function getUnsubscribeUrl(): ?string;
```

This method returns the URL to unsubscribe from the topic, if available.

#### CloudWatch Notification

The `CloudWatchNotificationReceived` event's message implements the `CloudWatchNotificationInterface`, providing the
following methods:

```php
public function getAlarmName(): string;
public function getAlarmDescription(): ?string;
public function getAwsAccountId(): string;
public function getNewStateValue(): string;
public function getNewStateReason(): string;
public function getOldStateValue(): string;
public function getStateChangeTime(): Carbon;
public function getRegion(): string;
```

These methods allow you to access specific details about the CloudWatch alarm that triggered the notification.

#### S3 Notification

The `S3NotificationReceived` event's message implements the `S3NotificationInterface`, providing the following method:

```php
public function getRecords(): array;
```

This method returns an array of records, each representing an S3 event (e.g., object creation or deletion) that
triggered the notification.

#### SES Notification

The `SesNotificationReceived` event's message implements the `SesNotificationInterface`, providing the following
methods:

```php
public function getNotificationType(): string;
public function getDelivery(): ?Delivery;
public function getBounce(): ?Bounce;
public function getComplaint(): ?Complaint;
public function getMail(): Mail;
```

These methods allow you to access specific details about the SES notification, such as the type of notification (e.g.,
delivery, bounce, or complaint) and additional details specific to that notification type.

## Contributing

Expand Down