/** * Send the given notification with Apple Push Notification Service Server. * * @param Notification $notification the notification to send * @return boolean true on success, false if there was an error. */ public function send($notification) { $config = Config::getInstance(); $appRoot = $config->getString('appRootDir'); // Instanciate a new ApnsPHP_Push object, with the provider certificate $push = new ApnsPHP_Push(ApnsPHP_Abstract::ENVIRONMENT_PRODUCTION, $appRoot . $config->getString('monitoring/notification/push/providerCertificateDir')); // Set custom logger $push->setLogger(new ApnsPHP_Log_Fruition()); // Set the Provider Certificate passphrase $push->setProviderCertificatePassphrase($config->getString('monitoring/notification/push/passphrase')); // Set the Root Certificate Autority to verify the Apple remote peer $push->setRootCertificationAuthority($appRoot . $config->getString('monitoring/notification/push/rootCertificateAuthorityDir')); // Get recipient list. If no registration id (user did not connect to the // mobile app, we stop the process $stringRecipients = $notification->getRecipient(); if (empty($stringRecipients)) { Logger::info("No registration id was found. The notification is not sent."); return false; } // Connect to the Apple Push Notification Service $push->connect(); // Create a message for each device $message = new ApnsPHP_Message(); $message->setText($notification->getContent()); $message->setSound(); $message->setExpiry(30); // 60 seconds $recipientList = explode(",", $notification->getRecipient()); foreach ($recipientList as $registrationId) { $message->addRecipient($registrationId); } // Add the message to the message queue $push->add($message); // Send all messages in the message queue $push->send(); // Disconnect from the Apple Push Notification Service $push->disconnect(); // Examine the error message container. $aErrorQueue = $push->getErrors(); if (!empty($aErrorQueue)) { foreach ($aErrorQueue as $error) { foreach ($error['ERRORS'] as $err) { //For statusCode = 8, which is Invalid Token, we delete the token. if ($err['statusCode'] == self::INVALID_TOKEN) { if ($this->handlerErrorCallBack) { $token = $error['MESSAGE']->getRecipient(); call_user_func($this->handlerErrorCallBack, $token); } } Logger::error("Sending push notification failed. Error code: " . $err['statusCode'] . ". Message: " . $err['statusMessage']); } } return false; } //If success Logger::info("Notification sent with device token " . $notification->getRecipient()); return true; }
/** * Adds a device to the system, after sending a test notification to it * @param {array} $device * @param {string} $device.userId * @param {string} $device.deviceId * @param {string} [$device.formFactor] * @param {string} [$device.platform] * @param {string} [$device.version] * @param {string} [$device.sessionId] * @param {boolean} [$device.sandbox] * @param {string} [$device.passphrase] * @param {boolean} [$skipNotification=false] if true, skips sending notification * @return {Users_Device} */ static function add($device, $skipNotification = false) { Q_Valid::requireFields(array('userId', 'deviceId'), $device, true); $userId = $device['userId']; $deviceId = $device['deviceId']; if (!$skipNotification) { $app = Q::app(); $sandbox = Q::ifset($device, 'sandbox', null); if (!isset($sandbox)) { $sandbox = Q_Config::get($app, "cordova", "ios", "sandbox", false); } $env = $sandbox ? ApnsPHP_Abstract::ENVIRONMENT_SANDBOX : ApnsPHP_Abstract::ENVIRONMENT_PRODUCTION; $s = $sandbox ? 'sandbox' : 'production'; $cert = APP_LOCAL_DIR . DS . 'Users' . DS . 'certs' . DS . $app . DS . $s . DS . 'bundle.pem'; $authority = USERS_PLUGIN_FILES_DIR . DS . 'Users' . DS . 'certs' . DS . 'EntrustRootCA.pem'; $logger = new Users_ApnsPHP_Logger(); $push = new ApnsPHP_Push($env, $cert); $push->setLogger($logger); $push->setRootCertificationAuthority($authority); if (isset($device['passphrase'])) { $push->setProviderCertificatePassphrase($device['passphrase']); } $push->connect(); $message = new ApnsPHP_Message($deviceId); $message->setCustomIdentifier('Users_Device-adding'); $message->setBadge(0); $message->setText(Q_Config::get($app, "cordova", "ios", "device", "text", "Notifications have been enabled")); $message->setCustomProperty('userId', $userId); $message->setExpiry(5); $push->add($message); $push->send(); $push->disconnect(); $errors = $push->getErrors(); if (!empty($errors)) { $result = reset($errors); throw new Users_Exception_DeviceNotification($result['ERRORS'][0]); } } $sessionId = Q_Session::id(); $user = Users::loggedInUser(); $info = array_merge(Q_Request::userAgentInfo(), array('sessionId' => $sessionId, 'userId' => $user ? $user->id : null, 'deviceId' => null)); $device2 = Q::take($device, $info); $d = new Users_Device($device2); $d->save(true); if ($sessionId) { $s = new Users_Session(); $s->id = $sessionId; if (!$s->retrieve()) { $s->deviceId = $deviceId; } } $_SESSION['Users']['deviceId'] = $deviceId; $device2['Q/method'] = 'Users/device'; Q_Utils::sendToNode($device2); return $d; }
public static function pushIos($environment, $certFile, $devices, $message, $extra = array()) { $extra = (object) $extra; $environment = $environment == self::ENVIRONMENT_PROD ? \ApnsPHP_Abstract::ENVIRONMENT_PRODUCTION : \ApnsPHP_Abstract::ENVIRONMENT_SANDBOX; $push = new \ApnsPHP_Push($environment, $certFile); $push->setLogger(new VoidLogger()); $push->setRootCertificationAuthority(dirname(__FILE__) . '/../../data/entrust_root_certification_authority.pem'); $push->connect(); $result = array(); foreach ($devices as $device) { try { $m = new \ApnsPHP_Message($device); $m->setText($message); if (isset($extra->badge)) { $m->setBadge($extra->badge); } if (isset($extra->sound)) { $m->setSound($extra->sound); } $push->add($m); } catch (\Exception $e) { self::logError("iOS", $device, $e->getMessage(), $certFile, $environment == \ApnsPHP_Abstract::ENVIRONMENT_PRODUCTION); $result[$device] = false; } } $push->send(); $push->disconnect(); $errors = $push->getErrors(); if (!empty($errors)) { foreach ($errors as $error) { $m = $error["MESSAGE"]; foreach ($m->getRecipients() as $device) { self::logError("iOS", $device, $error["ERRORS"][0]["statusMessage"], $certFile, $environment == \ApnsPHP_Abstract::ENVIRONMENT_PRODUCTION); $result[$device] = false; } } } foreach ($devices as $device) { if (!isset($result[$device])) { $result[$device] = true; } } return $result; }
private static function sendToIOS($token, $message) { /*$push = new ApnsPHP_Push(ApnsPHP_Abstract::ENVIRONMENT_PRODUCTION, 'com.appkode.yol');*/ $push = new ApnsPHP_Push(ApnsPHP_Abstract::ENVIRONMENT_SANDBOX, ROOT . '/app/config/apns-dev.pem'); $disabledLogger = new DisabledLogger(); $push->setProviderCertificatePassphrase('test123'); $push->setLogger($disabledLogger); // $push->setRootCertificationAuthority(ROOT . '/app/config/apns-dev.pem'); $push->connect(); $apnsMessage = new ApnsPHP_Message(); $apnsMessage->setText($message); $apnsMessage->addRecipient($token); $push->add($apnsMessage); $push->send(); $push->disconnect(); $error = $push->getErrors(); if (is_array($error) && count($error) > 0) { self::log('iOS error: ' . "\n" . json_encode($error)); } else { self::log('Push is sent'); } }
/** * @inheritdoc */ public function sendPush() { $failedMessages = []; if (!isset($this->registrationTokens) || !count($this->registrationTokens)) { $failedMessages = $this->registrationTokens; return $this->returnResult($failedMessages, $this->registrationTokens); } // Instanciate a new ApnsPHP_Push object $push = new \ApnsPHP_Push($this->parameters['environment'], $this->certificate); // Set the Root Certificate Autority to verify the Apple remote peer $push->setRootCertificationAuthority($this->parameters['ca_cert']); $push->setLogger($this->logger); // Connect to the Apple Push Notification Service $push->connect(); foreach ($this->registrationTokens as $index => $token) { try { $message = new \ApnsPHP_Message($token); } catch (\Exception $e) { $this->logger->log("ERROR: Device token " . $token . " has problem : " . $e->getMessage()); $failedMessages[] = $token; continue; } $badge = $this->badges[$index]; $category = $this->pushData->getApnsCategory(); $expiry = $this->pushData->getApnsExpiry(); $text = $this->pushData->getApnsText(); $sound = $this->pushData->getApnsSound(); $customProperties = $this->pushData->getApnsCustomProperties(); $contentAvailable = $this->pushData->getContentAvailable(); if (!$this->pushData->isSilent()) { // DEFAULT PUSH if (isset($badge)) { $message->setBadge($badge); } if (isset($category)) { $message->setCategory($category); } if (isset($expiry)) { $message->setExpiry($expiry); } if (isset($text)) { $message->setText($text); } if (isset($sound)) { $message->setSound($sound); } else { $message->setSound(); } if ($contentAvailable) { $message->setContentAvailable(true); } } else { // SILENT PUSH $message->setContentAvailable(true); // Set push information to custom payload if (isset($text)) { $customProperties['alert'] = $text; } if (isset($category)) { $customProperties['category'] = $category; } } if (isset($customProperties) && is_array($customProperties)) { foreach ($customProperties as $name => $value) { $message->setCustomProperty($name, is_scalar($value) ? $value : json_encode($value)); } } // Add the message to the message queue $push->add($message); } // Send all messages in the message queue try { $push->send(); // Disconnect from the Apple Push Notification Service $push->disconnect(); // Examine the error message container $aErrorQueue = $push->getErrors(); if (!empty($aErrorQueue)) { foreach ($aErrorQueue as $error) { // On récupère la liste des token qui ont généré une erreur $var = $error['MESSAGE']; $failedMessages = array_merge($failedMessages, $var->getRecipients()); } } return $this->returnResult($failedMessages, $this->registrationTokens); } catch (\Exception $e) { return $this->returnResult($this->registrationTokens, $this->registrationTokens); } }
protected function sendPushToDevice($cert, $deviceId, $message, $sn = '') { if (strlen($deviceId) < 64) { return; } $env = APPLICATION_ENV == 'development' ? ApnsPHP_Abstract::ENVIRONMENT_SANDBOX : ApnsPHP_Abstract::ENVIRONMENT_PRODUCTION; $env = ApnsPHP_Abstract::ENVIRONMENT_SANDBOX; $push = new ApnsPHP_Push($env, $cert); $push->setLogger(new ApnsPHP_Log_Null()); $push->setConnectTimeout(4000); $push->setRootCertificationAuthority(APPLICATION_PATH . '/data/entrust_root_certification_authority.pem'); $push->connect(); $apnsMessage = new ApnsPHP_Message($deviceId); $apnsMessage->setBadge(1); $apnsMessage->setText($message); $apnsMessage->setSound(); $apnsMessage->setCustomProperty('sn', $sn); $push->add($apnsMessage); $push->send(); //$push->disconnect(); $aErrorQueue = $push->getErrors(); if (!empty($aErrorQueue)) { var_dump($aErrorQueue); } }
protected function raw_send($tokens, $title, $user_info) { // No devices, do nothing if (empty($tokens)) { return 0; } require_once dirname(__FILE__) . '/../../libs/ApnsPHP/Abstract.php'; require_once dirname(__FILE__) . '/../../libs/ApnsPHP/Exception.php'; require_once dirname(__FILE__) . '/../../libs/ApnsPHP/Feedback.php'; require_once dirname(__FILE__) . '/../../libs/ApnsPHP/Message.php'; require_once dirname(__FILE__) . '/../../libs/ApnsPHP/Log/Interface.php'; require_once dirname(__FILE__) . '/../../libs/ApnsPHP/Log/Embedded.php'; require_once dirname(__FILE__) . '/../../libs/ApnsPHP/Message/Custom.php'; require_once dirname(__FILE__) . '/../../libs/ApnsPHP/Message/Exception.php'; require_once dirname(__FILE__) . '/../../libs/ApnsPHP/Push.php'; require_once dirname(__FILE__) . '/../../libs/ApnsPHP/Push/Exception.php'; require_once dirname(__FILE__) . '/../../libs/ApnsPHP/Push/Server.php'; require_once dirname(__FILE__) . '/../../libs/ApnsPHP/Push/Server/Exception.php'; require_once dirname(__FILE__) . '/../class-pnfw-apnsphp-logger.php'; $certificate = get_attached_file(get_option("pnfw_production_ssl_certificate_media_id")); $passphrase = get_option("pnfw_production_ssl_certificate_password"); $environment = ApnsPHP_Abstract::ENVIRONMENT_PRODUCTION; if (get_option("pnfw_ios_use_sandbox")) { $certificate = get_attached_file(get_option("pnfw_sandbox_ssl_certificate_media_id")); $passphrase = get_option("pnfw_sandbox_ssl_certificate_password"); $environment = ApnsPHP_Abstract::ENVIRONMENT_SANDBOX; } if (empty($certificate)) { pnfw_log(PNFW_IOS_LOG, __("iOS SSL certificate is not correctly set.", 'pnfw')); return 0; } if (empty($passphrase)) { pnfw_log(PNFW_IOS_LOG, __("iOS SSL certificate password is not correctly set.", 'pnfw')); return 0; } if (!file_exists($certificate)) { pnfw_log(PNFW_IOS_LOG, __("iOS SSL Certificate does not exists.", 'pnfw')); return 0; } $pnfw_ios_payload_sound = get_option('pnfw_ios_payload_sound', 'default'); try { $push = new ApnsPHP_Push($environment, $certificate); $push->setLogger(new PNFW_ApnsPHP_Logger()); $push->setProviderCertificatePassphrase($passphrase); foreach ($tokens as &$token) { try { $this->notification_sent($token); $message = new ApnsPHP_Message($token); foreach (array_keys($user_info) as $key) { $message->setCustomProperty($key, strval($user_info[$key])); } $message->setText($title); $message->setSound($pnfw_ios_payload_sound); $message->setBadge($this->get_badge_count($token)); $push->add($message); } catch (Exception $e) { // The only exception here is the invalid token, so delete it $this->delete_token($token); } } unset($token); $queued = count($push->getQueue(false)); // Empty queue, do nothing if ($queued == 0) { return 0; } // Connect to the Apple Push Notification Service $push->connect(); // Send all messages in the message queue $push->send(); // Disconnect from the Apple Push Notification Service $push->disconnect(); return $queued; } catch (Exception $e) { pnfw_log(PNFW_IOS_LOG, strip_tags($e->getMessage())); return 0; } }
<?php // PUSH sender via CLI if (PHP_SAPI != 'cli') { die('this script must be run in cli mode'); } require_once 'init.php'; require_once 'classes/ApnsPHP/Autoload.php'; // Instanciate a new ApnsPHP_Push object $push = new ApnsPHP_Push(ApnsPHP_Abstract::ENVIRONMENT_SANDBOX, 'push_certs/sandbox.pem'); $logger = new ApnsPHP_Log_Null(); $push->setLogger($logger); // Set the Provider Certificate passphrase // $push->setProviderCertificatePassphrase('test'); // Set the Root Certificate Autority to verify the Apple remote peer //$push->setRootCertificationAuthority('push_certs/entrust_root_sandbox.cer'); // Connect to the Apple Push Notification Service $push->connect(); $notification_type = $argv[5]; $devices = $API->DB->query_return("SELECT push.*, accounts.push_notifications FROM push LEFT JOIN accounts ON push.account_id=accounts.id WHERE udid IN(" . implode(',', array_map(array($API->DB, 'sqlesc'), explode(',', $argv[6]))) . ")"); foreach ($devices as $d) { $push_notificaions = explode(',', $d['push_notifications']); if ($push_notificaions[0] != 'none' || !$push_notificaions[0] || in_array($notification_type, $push_notificaions)) { // Instantiate a new Message with a single recipient $message = new ApnsPHP_Message($d['token']); // Set a custom identifier. To get back this identifier use the getCustomIdentifier() method // over a ApnsPHP_Message object retrieved with the getErrors() message. $message->setCustomIdentifier(uniqid()); // Set badge icon to "3" $newbadge = $d['badge'] + 1; $badges[$newbadge][] = $d['udid'];
public function openStream() { $this->service = new \ApnsPHP_Push($this->devMode === true ? \ApnsPHP_Abstract::ENVIRONMENT_SANDBOX : \ApnsPHP_Abstract::ENVIRONMENT_PRODUCTION, $this->certPath); $this->service->setLogger(new \Nnmer\PushNotificationBundle\Service\Logger($this->logger)); $this->service->connect(); }
/** * push * @param mixed $registrations * @param mixed $data */ public function push($registrations, $data) { $apns_environment = Config::get('push.apns.environment', 'sandbox'); $apns_certificate_file = Config::get('push.apns.cert.file', false); $apns_certificate_pass = Config::get('push.apns.cert.pass', false); if (!$apns_certificate_file) { throw new \Exception("APNS config error: 'push.apns.cert.file' not set."); } $total_failure = 0; // Instantiate a new ApnsPHP_Push object $push = new \ApnsPHP_Push($apns_environment == 'sandbox' ? \ApnsPHP_Abstract::ENVIRONMENT_SANDBOX : \ApnsPHP_Abstract::ENVIRONMENT_PRODUCTION, $this->getCertificateFile($apns_certificate_file)); // set custom logger $push->setLogger(new APNSLogger()); // Set the Provider Certificate passphrase if ($apns_certificate_pass) { $push->setProviderCertificatePassphrase($apns_certificate_pass); } // Set the Root Certificate Autority to verify the Apple remote peer $push->setRootCertificationAuthority($this->getRootCertificationAuthority()); // Connect to the Apple Push Notification Service $push->connect(); $message = new \ApnsPHP_Message(); // Add all registrations as message recipient foreach ($registrations as $registration) { try { $message->addRecipient($registration->device_id); } catch (\ApnsPHP_Message_Exception $e) { Logger::error($e->getMessage()); $total_failure += 1; } } Logger::debug("Recipients => " . json_encode($message->getRecipients())); // Set a custom identifier. To get back this identifier use the getCustomIdentifier() method // over a ApnsPHP_Message object retrieved with the getErrors() message. if (isset($data['custom_identifier'])) { $message->setCustomIdentifier($data['custom_identifier']); } // Set badge icon to "3" if (isset($data['badge']) && is_int($data['badge'])) { $message->setBadge((int) $data['badge']); } // Set text $message->setText($data['message']); // Play the default sound if (!isset($data['sound']) || empty($data['sound'])) { $data['sound'] = 'default'; } $message->setSound($data['sound']); // Set the expiry value to 30 seconds if (isset($data['expiry']) && $data['expiry'] > 0) { $message->setExpiry($data['expiry']); } // Set custom properties $invalid_properties = array('_id', 'app_id', 'created_at', 'updated_at', 'sound', 'text', 'badge', 'expiry', 'custom_identifier'); $custom_properties = array_diff_key($data, array_flip($invalid_properties)); foreach ($custom_properties as $property => $value) { $message->setCustomProperty($property, $value); } // Add the message to the message queue $push->add($message); // Send all messages in the message queue $stats = $push->send(); // Disconnect from the Apple Push Notification Service $push->disconnect(); // Examine the error message container $error_list = $push->getErrors(); // Log delivery status $errors = $push->getErrors(); $total_failure += count($errors); if ($total_failure > 0) { foreach ($errors as $error) { Logger::error($error); } } return array('success' => $registrations->count() - $total_failure, 'failure' => $total_failure); }