Plugin open-source untuk mengintegrasikan Firebase Cloud Messaging (FCM) ke dalam aplikasi mobile NativePHP khusus untuk Android. Memungkinkan pengambilan token perangkat secara unik dan penanganan izin notifikasi secara otomatis mengikuti standar arsitektur NativePHP Mobile v3.
- Manajemen Izin Real-time: Mengecek status 'saklar' notifikasi di semua versi Android secara akurat.
- Auto-dialog (Android 13+): Memicu dialog permintaan izin
POST_NOTIFICATIONSsecara runtime sesuai kebijakan Google terbaru. - Pengambilan Token FCM: Mengambil registrasi token unik dengan penanganan error yang kuat.
- Otomatisasi Aset: Hook bawaan untuk menyalin file kredensial (
google-services.json) ke folder build native. - V3 Bridge Standards: Menggunakan struktur direktori
resources/yang kompatibel dengan NativePHP Plugin Kit.
Tambahkan plugin ke proyek Laravel Anda melalui Composer:
composer require denis156/fcm-notificationDaftarkan plugin di proyek NativePHP Anda untuk mengaktifkan integrasi native:
php artisan native:plugin:register denis156/fcm-notificationPlugin ini menggunakan hook copy_assets untuk menyalin file konfigurasi Firebase Anda ke target native secara otomatis. Letakkan file kredensial Anda di folder firebase/ pada root proyek:
- Android:
firebase/google-services.json
Pastikan Application ID di file .env sudah sama dengan yang terdaftar di Firebase Console:
NATIVEPHP_APP_ID=com.example.appJalankan build untuk memicu penyalinan file dan kompilasi plugin:
php artisan native:run androidGunakan facade FcmNotification untuk berinteraksi dengan layanan native:
use Denis156\FcmNotification\Facades\FcmNotification;
// 1. Cek status izin saat ini ('granted' atau 'denied')
$status = FcmNotification::getStatus();
// 2. Minta izin notifikasi (Dialog popup pada Android 13+)
if ($status !== 'granted') {
FcmNotification::requestPermission();
}
// 3. Mengambil Token FCM untuk dikirim ke backend
$token = FcmNotification::getToken();Anda juga bisa memanggil fungsi native langsung dari frontend:
import { fcmNotification } from '@denis156/fcm-notification';
// Ambil status izin
const status = await fcmNotification.getStatus();
// Ambil token
const token = await fcmNotification.getToken();Jika token tidak muncul atau status izin selalu denied:
- Pantau Log Native: Gunakan
php artisan native:tailuntuk melihat aktivitas bridge. - Detail Log Android: Gunakan
adb logcat -s FCM_PLUGINuntuk melihat debugging level native (Kotlin). - Reset Token Lokal: Gunakan Tinker untuk menghapus token lama agar plugin memicu pengambilan ulang:
php artisan tinker --execute 'App\Models\AppSession::query()->update(["fcm_token" => null]);'
packages/denis156/fcm-notification/
├── nativephp.json # Manifest Plugin & Bridge Functions
├── src/ # Kode PHP (Service Provider, Facade, Command)
└── resources/
├── android/src/ # Kode Kotlin (Bridge Implementation)
└── boost/guidelines/ # Instruksi spesifik untuk AI assistants
Dikembangkan dengan penuh dedikasi oleh denis156.