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

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

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

nawasara/notification

最新稳定版本:v0.1.1

Composer 安装命令:

composer require nawasara/notification

包简介

Unified outbound notification for the Nawasara superapp framework — multi-channel routing, Blade templates, queue dispatch, and an audit log of every send.

README 文档

README

Unified outbound notification for the Nawasara superapp framework. Build a Blade template once, then send it to anyone over any registered channel via a single fluent API. Every send is queued, retried with backoff on failure, and recorded in an audit log.

Features

  • Notify facade — fluent, chainable: Notify::to($user)->template('ssl.expiry')->data([...])->send()
  • Email channel (MVP) — sends via Laravel's Mail facade. Credentials read from the smtp Vault group with a fallback to .env (MAIL_*)
  • Template manager — Blade-rendered subject and body, multi-channel bodies (HTML / text / WhatsApp / Telegram / in-app), priority and active flag
  • Live preview — render any template against arbitrary JSON variables in an iframe before saving
  • Test send — kick off a real send to your own email from the template list to verify rendering and delivery end-to-end
  • Audit log — every send is one row in nawasara_notification_logs with status (queued / sending / sent / delivered / failed / bounced), error trace, attempts, and rendered body
  • Retry from UI — failed and bounced logs can be re-dispatched in one click
  • Future channels — WhatsApp, Telegram, and in-app are stubbed in the schema and contract; only EmailChannel is implemented in the MVP

Installation

composer require nawasara/notification
php artisan migrate
php artisan db:seed --class="Nawasara\Notification\Database\Seeders\PermissionSeeder" --force

Auto-discovered. The Notify facade is registered as an alias.

SMTP credentials

The package reads SMTP credentials from the smtp Vault group at send time. Open /nawasara-vault/credentials → SMTP Email → fill in:

Field Example
Host smtp.gmail.com
Port 587
Encryption tls
Username noreply@kominfo.go.id
Password (Gmail app password if 2FA is on)
From Address noreply@kominfo.go.id
From Name Nawasara Kominfo

Use Test Connection in the dropdown to verify the host is reachable. If Vault is empty, the channel falls back to whatever Laravel resolves from .env — useful in local where MAIL_MAILER=log writes the rendered email to storage/logs/laravel.log.

Sending notifications

Template-driven

use Nawasara\Notification\Facades\Notify;

Notify::to($user)
    ->template('ssl.expiry.warning')
    ->data(['domain' => 'dinkes.ponorogo.go.id', 'days' => 7])
    ->send();

Ad-hoc

Notify::to('admin@kominfo.go.id')
    ->channel('email')
    ->subject('Test')
    ->body('<p>Hello world</p>')
    ->send();

Synchronous (skip queue)

Useful for tests and admin actions that need immediate feedback:

Notify::to($user)->template('welcome')->data([...])->sync()->send();

Pages

Route Permission
/nawasara-notification/templates notification.template.view
/nawasara-notification/logs notification.log.view

Permissions

Permission Description
notification.template.view View template list
notification.template.create Create template
notification.template.update Update template
notification.template.delete Delete template
notification.log.view View notification log
notification.log.retry Retry a failed/bounced notification
notification.test.send Trigger a Test Send from the template UI
notification.broadcast.send Broadcast (planned for future)

Roadmap

  • WhatsApp channel via nawasara/whatsapp-forwarder
  • Telegram bot channel
  • In-app notification bell in topbar
  • Webhook delivery callbacks (open/click tracking, bounce handling)
  • User notification preferences (per-channel, quiet hours)
  • Template broadcast (blast to role / OPD / custom audience)

See docs/todo-notification.md for the full plan.

Author

Pringgo J. Saputro <odyinggo@gmail.com>

License

MIT

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-05-09

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固