當前位置: 首頁>>代碼示例>>PHP>>正文


PHP Pusher::socket_auth方法代碼示例

本文整理匯總了PHP中Pusher::socket_auth方法的典型用法代碼示例。如果您正苦於以下問題:PHP Pusher::socket_auth方法的具體用法?PHP Pusher::socket_auth怎麽用?PHP Pusher::socket_auth使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在Pusher的用法示例。


在下文中一共展示了Pusher::socket_auth方法的9個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: validAuthenticationResponse

 /**
  * Return the valid authentication response.
  *
  * @param  \Illuminate\Http\Request  $request
  * @param  mixed  $result
  * @return mixed
  */
 public function validAuthenticationResponse($request, $result)
 {
     if (Str::startsWith($request->channel_name, 'private')) {
         return $this->decodePusherResponse($this->pusher->socket_auth($request->channel_name, $request->socket_id));
     } else {
         return $this->decodePusherResponse($this->pusher->presence_auth($request->channel_name, $request->socket_id, $request->user()->id, $result));
     }
 }
開發者ID:hannesvdvreken,項目名稱:framework,代碼行數:15,代碼來源:PusherBroadcaster.php

示例2: trim

<?php

// include Pusher PHP library
require_once 'lib/Pusher.php';
// Replace with auth information for your app
$auth_key = "";
$secret_key = "";
$app_id = "";
// read channel name and socket id from request
$channel_name = trim($_REQUEST['channel_name']);
$socket_id = trim($_REQUEST['socket_id']);
// use Pusher PHP library to generate auth signature and echo as response to client
$pusher = new Pusher($auth_key, $secret_key, $app_id);
$auth_sig = $pusher->socket_auth($channel_name, $socket_id);
echo $auth_sig;
開發者ID:jordanranson-archive,項目名稱:pusher-dotnet-unity-client,代碼行數:15,代碼來源:pusher-auth.php

示例3: getenv

require '../../vendor/autoload.php';
require '../_includes/config.php';
$appId = getenv('PUSHER_APP_ID');
$appKey = getenv('PUSHER_APP_KEY');
$appSecret = getenv('PUSHER_APP_SECRET');
$pusher = new Pusher($appKey, $appSecret, $appId);
/*
Uncomment this to have internal Pusher PHP library logging
information echoed in the response to the incoming request
*/
// class EchoLogger {
//   public function log($msg) {
//     echo($msg);
//   }
// }
//
// $pusher->set_logger(new EchoLogger());
$channelName = $_POST['channel_name'];
$socketId = $_POST['socket_id'];
/*
TODO: implement checks to determine if the user is:
1. Authenticated with the app
2. Allowed to subscribe to the $channelName
3. Sanitize any additional data that has been recieved and is to be used

If so, proceed...
*/
$auth = $pusher->socket_auth($channelName, $socketId);
header('Content-Type: application/json');
echo $auth;
開發者ID:pborreli,項目名稱:gs-pusher-php-no-framework,代碼行數:30,代碼來源:server.php

示例4: Pusher

<?php

require 'Pusher.php';
$app_id = '142419';
$app_key = '875a535db554ca357be9';
$app_secret = 'd97dd660cfe8f4e8a900';
$pusher = new Pusher($app_key, $app_secret, $app_id);
list(, $userId) = explode('.', $_POST['socket_id']);
$auth = $pusher->socket_auth($_POST['channel_name'], $userId);
//$presence_data = array('user_id' => $userId);
$presence_data = array();
echo $pusher->presence_auth($_POST['channel_name'], $_POST['socket_id'], $userId, $presence_data);
開發者ID:kgalanty,項目名稱:ships_statki,代碼行數:12,代碼來源:pusher_auth.php

示例5: pusherAuth

 /**
  * @param Request $request
  * @return string
  * @throws AuthenticationException
  */
 public function pusherAuth(Request $request)
 {
     //Verify the user has permission to connect to the chosen channel
     if ($request->get('channel_name') !== 'private-' . Auth::id()) {
         throw new AuthenticationException();
     }
     $pusher = new \Pusher(config('broadcasting.connections.pusher.key'), config('broadcasting.connections.pusher.secret'), config('broadcasting.connections.pusher.app_id'));
     return $pusher->socket_auth($request->get('channel_name'), $request->get('socket_id'));
 }
開發者ID:adamstrawson,項目名稱:BBMembershipSystem,代碼行數:14,代碼來源:SessionController.php

示例6: __construct

 public function __construct()
 {
     define('WP_USE_THEMES', false);
     include_once dirname(dirname(dirname(dirname(__FILE__)))) . '/wp-load.php';
     $this->options = get_option('wp_pusher', false);
     if ($this->options !== false && $this->options['key'] !== '' && $this->options['secret'] !== '' && $this->options['app_id'] !== '') {
         include_once 'pusher-php-server/lib/Pusher.php';
         $pusher = new Pusher($this->options['key'], $this->options['secret'], $this->options['app_id']);
         echo $pusher->socket_auth($_POST['channel_name'], $_POST['socket_id']);
     }
 }
開發者ID:sternt,項目名稱:WP-Pusher,代碼行數:11,代碼來源:wp-pusher-auth.php

示例7: Pusher

<?php

require __DIR__ . '/vendor/autoload.php';
$app_id = '134441';
$app_key = '599cb5ed77cd5efb659a';
$app_secret = '76a57ea82e311bcbbb1f';
error_log('post ' . var_export($_SERVER, true));
$channel_name = $_POST['channel_name'];
$socket_id = $_POST['socket_id'];
error_log($app_id);
error_log($app_key);
error_log($app_secret);
error_log('channel name: ' . $channel_name);
error_log('socket id: ' . $socket_id);
$pusher = new Pusher($app_key, $app_secret, $app_id);
echo $pusher->socket_auth($channel_name, $socket_id);
開發者ID:schemon,項目名稱:PusherAuthEndpointPHP,代碼行數:16,代碼來源:index.php

示例8: Pusher

<?php

use app\config\Config;
// Initialize the app
require_once '../../app/init.php';
// Include the pusher library
require_once '../../lib/pusher/Pusher.php';
// Gather the pusher key, secret and application ID
$authKey = Config::getValue('pusher', 'auth_key', '');
$secret = Config::getValue('pusher', 'secret', '');
$appId = Config::getValue('pusher', 'app_id', '0');
// Create a pusher instance with the proper key, secret and application ID
$pusher = new Pusher($authKey, $secret, $appId);
// Authenticate the request
echo $pusher->socket_auth($_POST['channel_name'], $_POST['socket_id']);
開發者ID:timvisee,項目名稱:MohicanenPieGuesser,代碼行數:15,代碼來源:auth.php

示例9: Process


//.........這裏部分代碼省略.........
     if (!empty($oc_logged_in) && in_array($oc_logged_in, $available_logins)) {
         $session_var_name = 'oc_user_id_' . $oc_logged_in;
         if (isset($_COOKIE[$session_var_name]) && $session->has($session_var_name)) {
             $actor = $session->get($session_var_name);
             if ($actor['userid'] == $_COOKIE[$session_var_name]) {
                 $this->logged_in = true;
                 $this->actor = $actor;
             }
         }
         if (!$this->logged_in) {
             if ($oc_logged_in == 'googleplus') {
                 $this->googleplusLogin();
             } else {
                 if ($oc_logged_in == 'facebook') {
                     $this->facebookLogin();
                 } else {
                     if ($oc_logged_in == 'joomla') {
                         $this->joomlaLogin();
                     } else {
                         if ($oc_logged_in == 'twitter') {
                             $this->twitterLogin();
                         } else {
                             if ($oc_logged_in == 'anonymous') {
                                 $this->anonymousLogin($_COOKIE['oc_anon_name'], $_COOKIE['oc_anon_email']);
                             }
                         }
                     }
                 }
             }
             if ($this->logged_in) {
                 $session->set($session_var_name, $this->actor);
             }
         }
     }
     if (isset($_POST['loginonly'])) {
         if ($this->logged_in) {
             header('Cache-Control: no-cache, must-revalidate');
             header('Content-type: application/json');
             echo json_encode(array('OK'));
             //die();
             JFactory::getApplication()->close();
             return;
         } else {
             $this->returnError("Not logged in");
         }
     }
     if (isset($_POST['channel_name']) && isset($_POST['socket_id'])) {
         //authendpoint private or presence
         $verify_channel = $_POST['channel_name'];
         //private- presence-
         $verify_socketid = $_POST['socket_id'];
         $parts = explode('-', $verify_channel);
         $channel_type = $parts[0];
         if (!in_array($channel_type, array('private', 'presence'))) {
             $this->returnError('invalid private or presence channel');
         }
         if ($this->logged_in) {
             $pusher = new Pusher($app_key, $app_secret, $app_id);
             $presence_data = $this->actor;
             if ($channel_type == 'presence') {
                 echo $pusher->presence_auth($verify_channel, $verify_socketid, $this->actor['userid'], $presence_data);
             } else {
                 echo $pusher->socket_auth($verify_channel, $verify_socketid);
             }
             JFactory::getApplication()->close();
         } else {
             $this->returnError("Forbidden");
         }
         return;
     }
     if (isset($_POST['chat_info'])) {
         //send message
         $channel_name = "private-" . $this->get_channel_name($this->Params->get("pusher_channel_name", "channel1"));
         $result = array();
         //'activity' => $data, 'pusherResponse' => $response);
         //if (isset($_POST['chat_info']['logout']) && isset($_POST['chat_info']['logout']['logout_from'])){
         //non devo fare nulla
         //	$this->logged_in=false;
         //}
         if ($this->logged_in && isset($_POST['chat_info']['text']) && !empty($_POST['chat_info']['text'])) {
             //creo il messaggio
             date_default_timezone_set('UTC');
             $data = array('id' => uniqid(), 'body' => mb_substr($_POST['chat_info']['text'], 0, 300), 'published' => date('r'), 'type' => 'chat-message', 'actor' => $this->actor);
             $data['actor']['displayName'] = mb_substr($data['actor']['displayName'], 0, 30);
             //invio del messaggio
             $pusher = new Pusher($app_key, $app_secret, $app_id);
             $response = $pusher->trigger($channel_name, 'chat_message', $data);
             $result = array('activity' => $data, 'pusherResponse' => $response);
         }
         //output result
         header('Cache-Control: no-cache, must-revalidate');
         header('Content-type: application/json');
         echo json_encode($result);
         //die();
         JFactory::getApplication()->close();
         return;
     }
     //se arrivo qui non è ne una presence ne una send
     $this->returnError('invalid data', 400);
 }
開發者ID:AlexRed,項目名稱:Ozio-Chat,代碼行數:101,代碼來源:chat.php


注:本文中的Pusher::socket_auth方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。