Giter Site home page Giter Site logo

twysto-forks / apnsphp Goto Github PK

View Code? Open in Web Editor NEW

This project forked from immobiliare/apnsphp

0.0 1.0 0.0 2.13 MB

ApnsPHP: Apple Push Notification & Feedback Provider

License: BSD 3-Clause "New" or "Revised" License

PHP 94.53% Shell 0.05% Objective-C 5.42%

apnsphp's Introduction

ApnsPHP: Apple Push Notification & Feedback Provider

A full set of open source PHP classes to interact with the Apple Push Notification service for the iPhone, iPad and the iPod Touch.

News

  • September 29, 2015, Some stats on this README.md, thanks Badge Poser.
  • May 12, 2015, ApnsPHP has been moved to the Immobiliare Labs organization on github.
  • May 07, 2015, ApnsPHP has increased the default payload size to 2048 and is now using the TLS protocol by default instead of the old SSL. News from Apple: https://developer.apple.com/news/?id=10222014a
  • October 26, 2012, Project source code has moved to github.
  • June 18, 2011, Please, use ApnsPHP Google Group for help requests or to discuss about this project. To report an issue use Issues. Thanks!
  • December 18, 2010, Full APNs message support: message body, localized action button, localized message with arguments substitution and custom launch images.
  • December 15, 2010, Committed the first version of the Objective-C Demo Project with not-running, running in foreground and running in background application state support.
  • December 14, 2010, Added the support for multiple Custom Property.
  • August 28, 2010, Added support for the new APNs enhanced format that addresses some of the issues with the simple format: Notification expiry and Error response.
  • February 28, 2010, ApnsPHP Source Code is now available.

Packagist

https://packagist.org/packages/duccio/apns-php

Thanks @jbender!

Architecture

  • Autoload system, explicitly include only Autoload.php and all classes are loaded on-demand.
  • Message class, to build a notification payload.
  • Push class, to push one or more messages to Apple Push Notification service.
  • Feedback class, to query the Apple Feedback service to get the list of broken device tokens.
  • Push Server class, to create a Push Server with one or more (forked) processes reading from a common message queue.
  • Log class/interface, to log to standard output or for custom logging purpose.
  • Objective-C Demo Project with not-running, running in foreground and running in background application state support.

Classes hierarchy

Details

In the Apple Push Notification Binary protocol there isn't a real-time feedback about the correctness of notifications pushed to the server. So, after each write to the server, the Push class waits for the "read stream" to change its status (or at least N microseconds); if it happened and the client socket receives an "end-of-file" from the server, the notification pushed to the server was broken, the Apple server has closed the connection and the client needs to reconnect to send other notifications still on the message queue.

To speed-up the sending activities the Push Server class can be used to create a Push Notification Server with many processes that reads a common message queue and sends parallel Push Notifications.

All client-server activities are based on the "on error, retry" pattern with customizable timeouts, retry times and retry intervals.

Requirements

PHP 5.3.0 or later with OpenSSL, PCNTL, System V shared memory and semaphore support.

./configure --with-openssl[=PATH] --enable-pcntl --enable-sysvshm --enable-sysvsem

If you plan to use only Push and Feedback provider without the Server part you need only OpenSSL (no PCNTL, System V shared memory or semaphore):

./configure --with-openssl[=PATH]

Usually OpenSSL is built-in in standard PHP Linux distributions packages. Standard PHP 5.3.0 shipped with Mac OS X Snow Leopard just works.

Please...

... drop a line if you use ApnsPHP for your published application on the App Store! Thanks :-)

apnsphp's People

Contributors

aporat avatar benpackard avatar duccio avatar edwardmp avatar integer avatar jbender avatar jetwitaussi avatar lucabrunox avatar spacedevin avatar twysto avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.