Ejemplo n.º 1
0
 public function send(ServiceInterface $service, MessageInterface $message)
 {
     $option = array_merge(['host' => 'https://gcm-http.googleapis.com/gcm/send', 'key' => ''], $service->getOption());
     $payload = array_merge(['alert' => '', 'sound' => 'default.wav', 'badge' => 1, 'expire_in' => 60 * 60 * 24 * 7], $message->getPayload());
     // Fetch all device belong to this service_id.
     $deviceTokens = $this->getDeviceTokens($service->getServiceId(), $message->getUsername(), $message->getScope());
     foreach ($deviceTokens as $deviceToken) {
         $client = new \GuzzleHttp\Client();
         $crawler = $client->post($option['host'], ['headers' => ['Authorization' => 'key=' . $option['key'], 'Content-Type' => 'application/json'], 'body' => json_encode(['to' => $deviceToken, 'data' => ['alert' => $payload['alert'], 'sound' => $payload['sound'], 'badge' => $payload['badge']], 'time_to_live' => $payload['expire_in']])]);
         if ($crawler->getStatusCode() !== 200) {
             throw new ServerErrorException(['error_description' => sprintf("GCM: Message ID %d can't send to Device Token %s, error message: %s", $message->getMessageId(), $deviceToken, $crawler->getBody())]);
         }
     }
 }
Ejemplo n.º 2
0
 public function send(ServiceInterface $service, MessageInterface $message)
 {
     $option = array_merge(['host' => 'ssl://gateway.sandbox.push.apple.com:2195', 'local_cert' => '', 'passphrase' => ''], $service->getOption());
     $payload = array_merge(['alert' => '', 'sound' => 'default.wav', 'badge' => 1, 'expire_in' => 60 * 60 * 24 * 7], $message->getPayload());
     // Fetch all device belong to this service_id.
     $deviceTokens = $this->getDeviceTokens($service->getServiceId(), $message->getUsername(), $message->getScope());
     // PHP SSL implementation need local_cert as physical file.
     // @see http://stackoverflow.com/a/11403788
     $local_cert = tempnam(sys_get_temp_dir(), 'PEM');
     register_shutdown_function('unlink', $local_cert);
     $handler = fopen($local_cert, 'w');
     fwrite($handler, $option['local_cert']);
     fclose($handler);
     // Create the stream socket client.
     $_context = stream_context_create();
     stream_context_set_option($_context, 'ssl', 'local_cert', $local_cert);
     stream_context_set_option($_context, 'ssl', 'passphrase', $option['passphrase']);
     $_handler = stream_socket_client($option['host'], $error, $errorString, 10, STREAM_CLIENT_ASYNC_CONNECT, $_context);
     if ($_handler === false) {
         throw new ServerErrorException(['error_description' => sprintf("APNS: Can't connect to server, error message: %d %s", $error, $errorString)]);
     }
     // Send multiple messages within single SSL connection.
     foreach ($deviceTokens as $deviceToken) {
         // Prepare the payload in JSON format.
         $_payload = json_encode(['aps' => ['alert' => $payload['alert'], 'badge' => $payload['badge'], 'sound' => $payload['sound']]]);
         // Build the message.
         $_message = pack('CnH*', 1, 32, $deviceToken);
         $_message .= pack('Cn', 2, strlen($_payload)) . $_payload;
         $_message .= pack('CnN', 3, 4, $message->getMessageId());
         $_message .= pack('CnN', 4, 4, $payload['expire_in']);
         $_message .= pack('CnC', 5, 1, 10);
         $_message = pack('CN', 2, strlen($_message)) . $_message;
         // Write the message to stream socket client.
         $response = fwrite($_handler, $_message);
         if ($response === false) {
             throw new ServerErrorException(['error_description' => sprintf("APNS: Message ID %d can't send to Device Token %s, error message: %s", $message->getMessageId(), $deviceToken, json_encode(error_get_last()))]);
         }
     }
     // Close the stream socket client.
     fclose($_handler);
 }