Merge branch 'master' of github.com:beyondcode/laravel-websockets

This commit is contained in:
freek 2018-11-26 00:42:56 +01:00
commit 9fde33d683
5 changed files with 113 additions and 6 deletions

View File

@ -60,7 +60,7 @@
"extra": { "extra": {
"laravel": { "laravel": {
"providers": [ "providers": [
"BeyondCode\\LaravelWebSockets\\LaravelWebSocketsServiceProvider" "BeyondCode\\LaravelWebSockets\\WebSocketsServiceProvider"
], ],
"aliases": { "aliases": {
"WebSocketRouter": "BeyondCode\\LaravelWebSockets\\Facades\\WebSocketRouter" "WebSocketRouter": "BeyondCode\\LaravelWebSockets\\Facades\\WebSocketRouter"

View File

@ -11,7 +11,6 @@ class WebSocketController implements MessageComponentInterface
{ {
function onOpen(ConnectionInterface $connection) function onOpen(ConnectionInterface $connection)
{ {
dump("Client connected");
} }
public function onMessage(ConnectionInterface $connection, MessageInterface $message) public function onMessage(ConnectionInterface $connection, MessageInterface $message)

View File

@ -8,7 +8,7 @@ use BeyondCode\LaravelWebSockets\ClientProviders\ClientProvider;
use Illuminate\Support\ServiceProvider; use Illuminate\Support\ServiceProvider;
use BeyondCode\LaravelWebSockets\LaravelEcho\Pusher\Channels\ChannelManager; use BeyondCode\LaravelWebSockets\LaravelEcho\Pusher\Channels\ChannelManager;
class LaravelWebSocketsServiceProvider extends ServiceProvider class WebSocketsServiceProvider extends ServiceProvider
{ {
public function boot() public function boot()
{ {

View File

@ -3,10 +3,10 @@
namespace BeyondCode\LaravelWebSockets\Tests; namespace BeyondCode\LaravelWebSockets\Tests;
use BeyondCode\LaravelWebSockets\ClientProviders\Client; use BeyondCode\LaravelWebSockets\ClientProviders\Client;
use BeyondCode\LaravelWebSockets\LaravelEcho\Pusher\Exceptions\InvalidSignatureException;
use BeyondCode\LaravelWebSockets\LaravelEcho\Pusher\Exceptions\UnknownAppKeyException; use BeyondCode\LaravelWebSockets\LaravelEcho\Pusher\Exceptions\UnknownAppKeyException;
use BeyondCode\LaravelWebSockets\LaravelEcho\WebSocket\PusherServer; use BeyondCode\LaravelWebSockets\LaravelEcho\WebSocket\PusherServer;
use BeyondCode\LaravelWebSockets\Tests\Mocks\Message; use BeyondCode\LaravelWebSockets\Tests\Mocks\Message;
use Ratchet\RFC6455\Messaging\MessageInterface;
class ConnectionTest extends TestCase class ConnectionTest extends TestCase
{ {
@ -91,4 +91,112 @@ class ConnectionTest extends TestCase
'channel' => 'basic-channel' 'channel' => 'basic-channel'
]); ]);
} }
/** @test */
public function clients_need_valid_auth_signatures_for_private_channels()
{
$this->expectException(InvalidSignatureException::class);
/** @var PusherServer $server */
$server = app(PusherServer::class);
$connection = $this->getWebSocketConnection();
$message = new Message(json_encode([
'event' => 'pusher:subscribe',
'data' => [
'auth' => 'invalid',
'channel' => 'private-channel'
],
]));
$server->onOpen($connection);
$server->onMessage($connection, $message);
}
/** @test */
public function clients_can_subscribe_to_private_channels()
{
/** @var PusherServer $server */
$server = app(PusherServer::class);
$connection = $this->getWebSocketConnection();
$server->onOpen($connection);
$signature = "{$connection->socketId}:private-channel";
$message = new Message(json_encode([
'event' => 'pusher:subscribe',
'data' => [
'auth' => $connection->client->appKey.':'.hash_hmac('sha256', $signature, $connection->client->appSecret),
'channel' => 'private-channel'
],
]));
$server->onMessage($connection, $message);
$connection->assertSentEvent('pusher_internal:subscription_succeeded', [
'channel' => 'private-channel'
]);
}
/** @test */
public function clients_need_valid_auth_signatures_for_presence_channels()
{
$this->expectException(InvalidSignatureException::class);
/** @var PusherServer $server */
$server = app(PusherServer::class);
$connection = $this->getWebSocketConnection();
$message = new Message(json_encode([
'event' => 'pusher:subscribe',
'data' => [
'auth' => 'invalid',
'channel' => 'presence-channel'
],
]));
$server->onOpen($connection);
$server->onMessage($connection, $message);
}
/** @test */
public function clients_can_subscribe_to_presence_channels()
{
/** @var PusherServer $server */
$server = app(PusherServer::class);
$connection = $this->getWebSocketConnection();
$server->onOpen($connection);
$channelData = [
'user_id' => 1,
'user_info' => [
'name' => 'Marcel'
]
];
$signature = "{$connection->socketId}:presence-channel:".json_encode($channelData);
$message = new Message(json_encode([
'event' => 'pusher:subscribe',
'data' => [
'auth' => $connection->client->appKey.':'.hash_hmac('sha256', $signature, $connection->client->appSecret),
'channel' => 'presence-channel',
'channel_data' => json_encode($channelData)
],
]));
$server->onMessage($connection, $message);
$connection->assertSentEvent('pusher_internal:subscription_succeeded', [
'channel' => 'presence-channel',
]);
}
} }

View File

@ -4,13 +4,13 @@ namespace BeyondCode\LaravelWebSockets\Tests;
use GuzzleHttp\Psr7\Request; use GuzzleHttp\Psr7\Request;
use BeyondCode\LaravelWebSockets\Tests\Mocks\Connection; use BeyondCode\LaravelWebSockets\Tests\Mocks\Connection;
use BeyondCode\LaravelWebSockets\LaravelWebSocketsServiceProvider; use BeyondCode\LaravelWebSockets\WebSocketsServiceProvider;
abstract class TestCase extends \Orchestra\Testbench\TestCase abstract class TestCase extends \Orchestra\Testbench\TestCase
{ {
protected function getPackageProviders($app) protected function getPackageProviders($app)
{ {
return [LaravelWebSocketsServiceProvider::class]; return [WebSocketsServiceProvider::class];
} }
protected function getEnvironmentSetUp($app) protected function getEnvironmentSetUp($app)