Notifire + FCM مع Laravel

سبتمبر 13, 2025

لو محتاج تبعت إشعارات Push من تطبيق Laravel سواء للموبايل أو للويب، فالحل الأسرع والأبسط هو إنك تستخدم Notifire اللي بيربط Laravel مباشرةً مع Firebase Cloud Messaging (FCM). الميزة الأساسية إنك مش محتاج تخرج بره نظام الـ Notifications الأصلي في لارافيل، وبتشتغل بكل الأدوات اللي إنت متعود عليها.

إيه هي Notifire وليه نستخدمها؟

Notifire عبارة عن باكدج مخصص للربط مع خدمة FCM. تقدر تبعت رسائل تنبيه بمحتوى بسيط أو متقدّم (عنوان، نص، صورة، أيقونة، صوت، أكشن…). كمان بيوفرلك إدارة للتوكنز الخاصة بالأجهزة المختلفة، وبيسهل موضوع تسجيلها وتخزينها في قاعدة البيانات.

المتطلبات الأساسية

قبل ما تبدأ، لازم يكون عندك Project على Firebase مفعّل، وتحمّل ملف Service Account وتخزّنه في مكان آمن زي storage/firebase.json. كمان محتاج Laravel Sanctum لأن عملية تسجيل التوكنات مربوطة بيه.

خطوات التثبيت

التثبيت بيتم في 3 أوامر رئيسية:

composer require devkandil/notifire
php artisan vendor:publish --provider="DevKandil\NotiFire\FcmServiceProvider"
php artisan migrate

إدارة التوكنات

الحزمة بتديك Trait تقدر تضيفه على موديل المستخدم علشان تدير الـ FCM Tokens. ودي نقطة مهمة جدًا لأن كل إشعار محتاج يروح لتوكن جهاز معين. الأفضل كمان تعمل جدول للأجهزة لو عندك يوزر بيدخل من أكتر من مكان.

تسجيل التوكن من الفرونت

Notifire بيضيفلك Endpoint جاهز اسمه POST /fcm/token، ومربوط بـ Sanctum بشكل مباشر. أي جهاز (ويب أو موبايل) هيولّد توكن من Firebase، هيبعت التوكن للسيرفر عندك علشان يتخزن ويرتبط بالمستخدم.

إرسال الإشعارات

عندك طريقتين: يا إمّا تستخدم الـ Facade مباشرة، أو تشتغل بالطريقة الرسمية بتاعة Laravel Notifications. في الحالتين بتقدر تضيف عنوان، نص، صورة، بيانات إضافية (data) وكمان تحدد الأولوية.

$ok = Fcm::withTitle('تنبيه جديد')
    ->withBody('فيه تحديث في حسابك')
    ->sendNotification($token);

أفضل الممارسات

- شغّل الإرسال دايمًا عن طريق queues علشان متبطّأش التطبيق.
- خزّن بيانات Firebase في مكان آمن بعيد عن Git.
- اعمل Rotation للتوكنات البايظة أو بعد الـ Logout.
- خطط لاستخدام Topics لو عندك Segments كبيرة من المستخدمين.

أخطاء شائعة

- لو الإشعارات مش بتوصل: راجع صلاحيات Service Worker على الويب أو جرّب إعادة تسجيل التوكن.
- لو فيه خطأ 401/403 على /fcm/token: يبقى غالبًا مشكلة في Sanctum أو التوكن ناقص.
- بطء في الإرسال: لازم تستخدم Workers وتفصل عملية الإرسال عن الـ UI.

الخلاصة

Notifire بتخلّي تكامل Laravel مع FCM عملية منظمة وبسيطة. بمجرد ما تظبط التوكنات وتربطها مع المستخدمين، وتستخدم الـQueues بشكل صح، هتقدر تبني نظام إشعارات قوي وموثوق للتطبيق بتاعك سواء على الموبايل أو الويب.

المدونة

البرمجة الكائنية (OOP) – المفاهيم الأساسية

أغسطس 09, 2025

البرمجة الكائنية التوجه (Object Oriented Programming - OOP) هي أسلوب حديث في تطوير البرمجيات يُقسّم التطبيق إلى وحدات تسمى كائنات (Objects) تتفاعل م...

شرح مفصل لكل هوك في React

يوليو 01, 2025

🎣 شرح React Hooks وبأمثلة عملية 🧠 useState بيعمل إيه: بيضيف حالة داخلية (state) جوا أي مكون شغال بوظيفة. مثال عملي: import React, { useSta...

مقارنة CSS: طبقات vs BEM vs Utility Classes

يونيو 26, 2025

مقارنة CSS: Cascade Layers و BEM و Utility Classes المقالة بتتكلّم عن ٣ طرق لإدارة الـ specificity في CSS – BEM والـ utility‑first classes وك...

تعزيز PHP Enums باستخدام archtechx/enums

يوليو 01, 2025

تعزيز PHP enums باستخدام حزمة archtechx/enums من PHP 8.1، ظهر نوع جديد اسمه “enums” بيخليك تعرف قيم ثابتة بأسماء مرمّزة زي statuses...

مكونات واجهة المستخدم والتفاعل الأساسية في React Native

يوليو 01, 2025

مكونات واجهة المستخدم والتفاعل الأساسية في React Native React Native بتوفرلك مجموعة قوية من المكونات الجاهزة اللي تقدر تستخدمها لبناء تطبيقات موباي...

لارافيل 12: كل جديد من 12.0 لـ 12.19 – دليل شامل

يوليو 20, 2025

🔧 1. لارافيل 12.0 – ستارتر كيتس وتعديلات أساسية إصدار 12.0 جاب Starter Kits جاهزة للـ React، Vue، Livewire، وكمان دمج مع WorkOS AuthKit،...