Exemple #1
3
function send_push($device)
{
    $deviceToken = unpack('H*', base64_decode($device["deviceToken"]));
    $deviceToken = $deviceToken[1];
    date_default_timezone_set('Europe/London');
    $push = new ApnsPHP_Push(ApnsPHP_Abstract::ENVIRONMENT_PRODUCTION, '/home/jimbob/final_aps_prod.pem');
    $push->setProviderCertificatePassphrase('FunCrate321');
    $push->connect();
    $message = new ApnsPHP_Message($deviceToken);
    // Set a custom property
    $message->setCustomProperty('mdm', $device['pushMagic']);
    // Set the expiry value to 30 seconds
    $message->setExpiry(30);
    $push->add($message);
    var_dump($message->getPayload());
    // 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)) {
        var_dump($aErrorQueue);
    }
}
 /**
  * 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;
 }
Exemple #3
0
 /**
  * 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;
 }
Exemple #4
0
 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');
     }
 }
Exemple #5
0
 /**
  * Send a push notification using ApnsPHP Library
  * @param string $deviceToken the push token for the mobile device
  * @param string $message the message to display
  * @param string $alertSound the audio file to play, otherwise use the default sound
  * @param string $unlockText if the device is locked, show "Slide to XXX" where XXX is the unlockText
  * @param int $badgeCount the number that should be shown on the springboard badge
  */
 public function SendWithApns($deviceToken, $messageText, $alertSound = 'default', $unlockText = '', $badgeCount = 0)
 {
     $output = new stdClass();
     $output->date = date('Y-m-d H:i:s');
     $output->success = false;
     $output->message = '';
     $push = new ApnsPHP_Push($this->sandboxMode ? ApnsPHP_Abstract::ENVIRONMENT_SANDBOX : ApnsPHP_Abstract::ENVIRONMENT_PRODUCTION, $this->certFilePath);
     $push->setProviderCertificatePassphrase($this->certPassphrase);
     $push->connect();
     $message = new ApnsPHP_Message_Custom($deviceToken);
     $message->setCustomIdentifier("message-1");
     // used to get error details if multiple messages are being sent
     $message->setText($messageText);
     $message->setSound($alertSound);
     $message->setExpiry(10);
     // timeout for connecting to push service
     $message->setActionLocKey($unlockText);
     // appended to "slide to " in the main unlock bar
     // $message->setLocKey(''); // override the text on the app lockscreen message
     $message->setBadge($badgeCount);
     $push->add($message);
     $push->send();
     $push->disconnect();
     // Examine the error message container
     $errors = $push->getErrors();
     $output->success = !empty($errors);
     if (!$output->success) {
         $output->message = print_r($errors, 1);
     }
     return $output;
 }
Exemple #6
0
 function ios_push($device_array, $push_title, $message_id)
 {
     // ТаймЗона;
     date_default_timezone_set('Europe/Rome');
     // Подключаем внешнюю библеотеку для работы с Apple свервером;
     require_once $_SERVER['DOCUMENT_ROOT'] . '/systems/api/ApnsPHP/Autoload.php';
     // Создаем объект для сообщения и работы с сервером;
     $push = new ApnsPHP_Push(ApnsPHP_Abstract::ENVIRONMENT_SANDBOX, $_SERVER['DOCUMENT_ROOT'] . '/systems/api/appDistr.pem');
     // Пароль разработчика;
     $push->setProviderCertificatePassphrase('fdu4v9f123');
     // Соединяемся с Яблочным сервером;
     $push->connect();
     foreach ($device_array as $token_temp) {
         // Преобразуем передаваемый IOS токен в человеческий вид;
         // Убираем <> краям;
         $token_temp = substr($token_temp, 1, -1);
         // Убираем пробелы;
         $token_temp_array = explode(' ', $token_temp);
         $token = '';
         for ($i = 0; $i <= count($token_temp_array); $i++) {
             $token = $token . $token_temp_array[$i];
         }
         // Создаем объект сообщения;
         $message = new ApnsPHP_Message($token);
         // Задаем какой-то неведомый параметр;
         $message->setCustomIdentifier("Message-Badge-1");
         // Тип значка?
         $message->setBadge(1);
         // "Я видел некоторое дерьмо" (с);
         $message->setText($push_title);
         // Звук уведомления?
         $message->setSound();
         // Передаем заголовок и ID сообщения;
         $service_message = explode('=', $push_title);
         if ($service_message[0] == 'service') {
             $message->setCustomProperty('service', $service_message[1]);
         } else {
             $message->setCustomProperty('title', $push_title);
             $message->setCustomProperty('message_id', $message_id);
         }
         // сервисное сообщение про обновление бейджей в меню
         //$message->setCustomProperty('service','refresh_badge');
         // Таймаут? Что блин за таймаут?
         $message->setExpiry(30);
         // Добавляем сообщение в сессию;
         $push->add($message);
     }
     // Отправляем сообщение;
     $push->send();
     // Отключаемся от Яблочного сервера;
     $push->disconnect();
 }
 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;
     }
 }
Exemple #8
0
function SendIOS($tokens, $text, $config)
{
    # Создаём экземпляр Push. Необходимо указывать параметр ENVIRONMENT_PRODUCTION или
    # ENVIRONMENT_SANDBOX в соответствии с сертификатом.
    $push = new ApnsPHP_Push($config['apn']['production'] ? 0 : 1, $config['apn']['production'] ? $config['apn']['sert_prod'] : $config['apn']['sert']);
    # Указываем пароль сертификата если он имеется
    if ($config['apn']['sertPass'] != '') {
        $push->setProviderCertificatePassphrase($config['apn']['sertPass']);
    }
    # Указываем корневой сертификат
    $push->setRootCertificationAuthority($config['apn']['RootCertificat']);
    # Создаём сообщение
    $message = new ApnsPHP_Message();
    # Перебираем массив токенов и добавляем получателей
    $listTokens = array();
    foreach ($tokens as $token) {
        $message->addRecipient($token);
        $listTokens[] = $token;
    }
    # Соединяемся с сервером
    $push->connect();
    # Устанавливаем параметры отправки сообщения
    $message->setSound();
    //$message->setBadge(0)
    $message->setText($text);
    # Устанавливаем сообщение для отправки
    $push->add($message);
    # Отправляем сообщение
    $push->send();
    # Отключаемся от сервера
    $push->disconnect();
    # Проверяем возникшие ошибки во время отправки
    $aErrorQueue = $push->getErrors();
    # Если имеются ошибки
    if (!empty($aErrorQueue)) {
        echo 'Ошибка отправки ios  -  ' . print_r($aErrorQueue, true);
        if (is_array($aErrorQueue)) {
            foreach ($aErrorQueue as $error) {
                if (isset($error['ERRORS']) && is_array($error['ERRORS'])) {
                    foreach ($error['ERRORS'] as $m) {
                        if (isset($m['statusMessage']) && $m['statusMessage'] == 'Invalid token') {
                            $arrayID = $m['identifier'] - 1;
                            if (isset($listTokens[$arrayID])) {
                                # Если найден недействительный токен, удатяем его из БД
                                //echo 'Удаление ошибочного токена';
                                DeleteToken($listTokens[$arrayID]);
                            }
                        }
                    }
                }
            }
        }
    }
}
Exemple #9
0
 /**
  * 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);
 }
Exemple #10
0
 /**
  * Gestiona el envio de las notificaciones con la libreria "ApnsPHP"
  */
 public function send()
 {
     if ($this->getEnvironment() === 1) {
         $push = new \ApnsPHP_Push($this->getEnvironment(), $this->getPemDev());
         $push->setProviderCertificatePassphrase($this->getPassphraseDev());
     } else {
         $push = new \ApnsPHP_Push($this->getEnvironment(), $this->getPem());
         $push->setProviderCertificatePassphrase($this->getPassphrase());
     }
     $push->setWriteInterval($this->getWriteInterval());
     $push->setSendRetryTimes($this->getSendRetryTimes());
     $push->setConnectTimeout($this->getConnectTimeout());
     $push->connect();
     try {
         $message = new \ApnsPHP_Message($this->getDeviceToken());
         $message->setText($this->getMessage());
         $message->setSound();
         if (!empty($this->getExtraData())) {
             foreach ($this->getExtraData() as $key => $value) {
                 $message->setCustomProperty($key, $value);
             }
         }
         $message->setExpiry($this->getExpiry());
         $push->add($message);
         $push->send();
         $push->disconnect();
         $aErrorQueue = $push->getErrors();
     } catch (\Exception $e) {
         $aErrorQueue = array($e->getMessage());
     }
     if (!empty($aErrorQueue)) {
         return $aErrorQueue;
     }
     return true;
 }