denis156/fcm-notification

Plugin NativePHP untuk integrasi Firebase Cloud Messaging (FCM) dan pengambilan token notifikasi perangkat.

Maintainers

Package info

github.com/denis156/fcm-notification

Type:nativephp-plugin

pkg:composer/denis156/fcm-notification

Statistics

Installs: 6

Dependents: 0

Suggesters: 0

Stars: 0

Open Issues: 0

v1.0.1 2026-05-06 17:21 UTC

This package is auto-updated.

Last update: 2026-05-06 17:25:19 UTC


README

PHP Version Laravel Version NativePHP Firebase FCM Platform Android Author License

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.

Fitur Unggulan

  • Manajemen Izin Real-time: Mengecek status 'saklar' notifikasi di semua versi Android secara akurat.
  • Auto-dialog (Android 13+): Memicu dialog permintaan izin POST_NOTIFICATIONS secara 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.

Instalasi

Tambahkan plugin ke proyek Laravel Anda melalui Composer:

composer require denis156/fcm-notification

Daftarkan plugin di proyek NativePHP Anda untuk mengaktifkan integrasi native:

php artisan native:plugin:register denis156/fcm-notification

Persiapan Firebase

1. File Konfigurasi

Plugin 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

2. Update Proyek

Pastikan Application ID di file .env sudah sama dengan yang terdaftar di Firebase Console:

NATIVEPHP_APP_ID=com.example.app

Jalankan build untuk memicu penyalinan file dan kompilasi plugin:

php artisan native:run android

Penggunaan

Sisi PHP (Laravel/Inertia/Livewire)

Gunakan 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();

Sisi JavaScript (Vue/React/Inertia)

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();

Panduan Debugging

Jika token tidak muncul atau status izin selalu denied:

  1. Pantau Log Native: Gunakan php artisan native:tail untuk melihat aktivitas bridge.
  2. Detail Log Android: Gunakan adb logcat -s FCM_PLUGIN untuk melihat debugging level native (Kotlin).
  3. 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]);'

Struktur Direktori (Standar v3)

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

Kontributor

Dikembangkan dengan penuh dedikasi oleh denis156.

Lisensi

MIT License