syntech/syntechfcm 问题修复 & 功能扩展

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

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

syntech/syntechfcm

最新稳定版本:1.3.1

Composer 安装命令:

composer require syntech/syntechfcm

包简介

A Laravel package for FCM

README 文档

README

This guide provides step-by-step instructions to integrate Syntech\SyntechFcm for sending Firebase Cloud Messaging (FCM) notifications in a Laravel application.

Requirements

  • PHP >= 7.4
  • Laravel >= 8.0
  • Composer

Installation

  1. Install the package via Composer:

    composer require syntech/syntechfcm
  2. Publish the configuration file:

    php artisan vendor:publish --provider="Syntech\Syntechfcm\SyntechFcmServiceProvider"
  3. Configure your FCM credentials:

    Update the config/syntechfcm.php file with your FCM project credentials.

    return [
    'project_id'   => env('FCM_PROJECT_ID'),
    'client_email' => env('FCM_CLIENT_EMAIL'),
    'private_key'  => env('FCM_PRIVATE_KEY'),
    ];
  4. Add the FCM credentials to your .env file:

    FCM_PROJECT_ID=your-project-id
    FCM_CLIENT_EMAIL=your-client-email
    FCM_PRIVATE_KEY=your-private-key

Create and Send Notifications

  1. Create a notification:

    php artisan make:notification YourNotification
  2. Implement the notification class:

    <?php
    
    namespace App\Notifications;
    
    use Illuminate\Bus\Queueable;
    use Illuminate\Contracts\Queue\ShouldQueue;
    use Illuminate\Notifications\Notification;
    
    class YourNotification extends Notification
    {
        use Queueable;
    
        /**
         * Create a new notification instance.
         *
         * @return void
         */
        public function __construct()
        {
            //
        }
    
        /**
         * Get the notification's delivery channels.
         *
         * @param  mixed  $notifiable
         * @return array
         */
        public function via($notifiable)
        {
            return ['fcm'];
        }
    
        /**
         * Get the FCM representation of the notification.
         *
         * @param  mixed  $notifiable
         * @return array
         */
        public function toFcm($notifiable)
        {
            return [
                'to' => $notifiable->device_token,
                'notification' => [
                    'title'    => 'Notification Title',
                    'body'     => 'Notification Body',
                    'image'    => '', // Optional image URL
                ],
            ];
        }
    }
    <?php
    
    namespace App\Models;
    
    use Illuminate\Database\Eloquent\Model;
    use Illuminate\Notifications\Notifiable;
    
    class User extends Model
    {
        use Notifiable;
    
        /**
         * Route notifications for the FCM channel.
         *
         * @return string
         */
        public function routeNotificationForFcm()
        {
            return $this->device_token;
        }
    }
  3. Send the notification:

    Use the notification in your controller or wherever appropriate:

    use App\Notifications\YourNotification;
    use App\Models\User;
    
    // Assuming $user is an instance of the User model
    $user = User::find(1); // Find the user you want to notify
    $user->notify(new YourNotification($title, $body));

Example Usage

  1. Store FCM tokens:

    Ensure you have a way to store FCM tokens for each user, typically in your users table.

    Schema::table('users', function (Blueprint $table) {
        $table->string('device_token')->nullable();
    });
  2. Update FCM tokens:

    Update the user's FCM token when they log in or register.

    $user->update(['device_token' => $request->input('device_token')]);
  3. Send a test notification:

    In a controller method:

    public function sendTestNotification(User $user)
    {
        $user->notify(new YourNotification());
    }

License

This project is open-source and available under the MIT license.

Contributing

Contributions are welcome! Please read the contribution guidelines first.

Support

For support, open an issue or contact the maintainer.

Example Code Image

Below is an example of the toFcm method implementation in your notification class:

toFcm Method Example

统计信息

  • 总下载量: 3.25k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 53
  • 点击次数: 1
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 53
  • Watchers: 1
  • Forks: 6
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2024-05-31