waaseyaa/notification 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

waaseyaa/notification

最新稳定版本:v0.1.0-alpha.202

Composer 安装命令:

composer require waaseyaa/notification

包简介

Multi-channel notification system for Waaseyaa

README 文档

README

Layer 3 — Services

Multi-channel notification system for Waaseyaa. A NotificationInterface declares which channels it targets (via()) and how it renders for each (toMail(), toDatabase(), …); a NotifiableInterface recipient supplies its per-channel routing (email address, database id). NotificationDispatcher fans a notification out across the matching ChannelInterface implementations — synchronously, or queued via the framework Job system so user-facing requests never wait on email or persistence. Channel delivery is best-effort: a single channel throwing is logged, not propagated.

Install

Ships as part of waaseyaa/framework — consumers on the core/cms/full metapackages already have it. To pull it on its own:

composer require waaseyaa/notification

The package self-registers NotificationServiceProvider (via extra.waaseyaa.providers), which binds NotificationDispatcher as a singleton and assembles the mail and database channels from whatever MailerInterface / DatabaseInterface are configured.

Key API

interface NotificationInterface
{
    /** @return list<string> channel names, e.g. ['mail', 'database'] */
    public function via(NotifiableInterface $notifiable): array;
    /** @return array<string, mixed> */
    public function toArray(NotifiableInterface $notifiable): array;
    // Optional, resolved by channels via method_exists():
    //   toMail(NotifiableInterface): \Waaseyaa\Mail\Envelope
    //   toDatabase(NotifiableInterface): array<string, mixed>
}

interface NotifiableInterface          // @api
{
    public function routeNotificationFor(string $channel): mixed; // 'mail' => email, 'database' => id
    public function getNotifiableId(): string;
    public function getNotifiableType(): string;
}

interface ChannelInterface
{
    public function send(NotifiableInterface $notifiable, NotificationInterface $notification): void;
}

final class NotificationDispatcher     // @api
{
    /** @param array<string, ChannelInterface> $channels */
    public function __construct(QueueInterface $queue, array $channels, ?LoggerInterface $logger = null);
    public function send(NotifiableInterface $notifiable, NotificationInterface $notification): void;       // sync
    public function sendAsync(NotifiableInterface $notifiable, NotificationInterface $notification): void;  // queued
    /** @param iterable<NotifiableInterface> $notifiables */
    public function sendToMany(iterable $notifiables, NotificationInterface $notification): void;
    /** @return array<string, ChannelInterface> */
    public function channels(): array;
}

Helpers: NotifiableTrait (@api) implements NotifiableInterface for any class exposing get()/id()/getEntityTypeId() (e.g. EntityBase subclasses); DefaultNotifiable is a standalone implementation for apps and tests. Built-in channels: Channel\MailChannel, Channel\DatabaseChannel (persists to waaseyaa_notifications). Async delivery uses Job\SendNotificationJob.

Usage

use Waaseyaa\Notification\{NotifiableInterface, NotificationInterface, NotificationDispatcher};
use Waaseyaa\Notification\Channel\MailChannel;
use Waaseyaa\Mail\{Envelope, Mailer};
use Waaseyaa\Queue\SyncQueue;

$notification = new class implements NotificationInterface {
    public function via(NotifiableInterface $n): array { return ['mail']; }
    public function toArray(NotifiableInterface $n): array { return ['message' => 'Welcome']; }
    public function toMail(NotifiableInterface $n): Envelope {
        return new Envelope(
            to: [$n->routeNotificationFor('mail')],
            from: 'noreply@example.com',
            subject: 'Welcome',
            textBody: 'Thanks for joining.',
        );
    }
};

$dispatcher = new NotificationDispatcher(
    new SyncQueue(),
    ['mail' => new MailChannel($mailer)],
);

$dispatcher->send($user, $notification);   // $user implements NotifiableInterface

Resolve NotificationDispatcher from the container instead of constructing it by hand once the service provider is booted; call sendAsync() to queue delivery for the worker.

统计信息

  • 总下载量: 148
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 10
  • 依赖项目数: 2
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: GPL-2.0-or-later
  • 更新时间: 2026-04-09

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固