granam/safari-push-notifications

Creates push package for Apple / Safari web push notifications

1.0.6 2018-01-11 14:42 UTC

This package is auto-updated.

Last update: 2024-04-26 23:31:17 UTC


README

Heavily inspired by connorlacombe/Safari-Push-Notifications/.

Flow

On your Javascript command, by calling pushSafariNotification(webServiceId, webServiceUrl, serverPushUrl, userId, title, text, buttonText)

  • browser will check if is Safari of sufficient version (OS X v10.9 and later)
  • if user already allowed push notifications
    • then push notification is send
  • else if user already denied push notifications
    • then push notification is not sent (to find out if push notifications can be sent, call JS function hasUserAllowedPushNotifications)
  • if user does not YET decided to add or deny permissions to your side to send a push notification, it will
    • trigger JS event safariPushNotificationsPermissionsRequestStart on window JS object
    • then asks user for permissions to accept push notifications from your side via Safari build-in layout
      • then, if user agreed, Apple will send POST request to \Granam\Safari\PushPackageController::pushPackages by calling an URL you set via Apple developer console
      • then Apple will send user decision to \Granam\Safari\PushPackageController::devicesRegistrations by calling an URL you set via Apple developer console
      • then - if user agreed - thenJS event safariPushNotificationsPermissionsJustGranted is triggered on window object - then push notification is send
        • else if user declined, then JS event safariPushNotificationsPermissionsJustDenied is triggered on window object and push notification is not sent
    • then JS event safariPushNotificationsPermissionsRequestEnd is triggered on window object