2017-02-23 4 views
1

Ich habe eine kleine Laravel Echo Server-Setup mit diesem Paket (https://github.com/tlaverdure/laravel-echo-server). Ich habe folgendes Setup:Laravel Echo-Server-Client empfängt kein Ereignis

// app.js 

import Echo from "laravel-echo"; 

window.Echo = new Echo({ 
    broadcaster: 'socket.io', 
    host: 'http://vaprobash.dev:6001' 
}); 

window.Echo.channel('documents-sharing') 
    .listen("Api\\DocumentShared", (event) => { 
    console.log(event); 
}); 

.

// server.js 
var app = require('express')(); 
var http = require('http').Server(app); 
var io = require('socket.io')(http); 
var Redis = require('ioredis'); 
var redis = new Redis(); 

http.listen(3000, function(){ 
    console.log('Listening on Port 3000'); 
}); 

redis.subscribe('documents-sharing', function(err, count) { 
    console.log("subscribed " + count); 
}); 

redis.on('message', function(channel, message) { 
    message = JSON.parse(message); 

    console.log('Message Received: ', channel, message); 

    console.log(io.to(channel).emit(message.event, message.data)); 
}); 

.

// laravel-echo-server.json 
{ 
    "authHost": "http://localhost", 
    "clients": [ 
     { 
      "appId": "986bb8954bb1e2e9", 
      "key": "58ca6a205718590ad5fd88a1afc1877c" 
     } 
    ], 
    "database": "redis", 
    "databaseConfig": { 
     "redis": { 
      "port": "6379", 
      "host": "localhost" 
     }, 
     "sqlite": { 
      "databasePath": "/database/laravel-echo-server.sqlite" 
     } 
    }, 
    "devMode": true, 
    "host": "localhost", 
    "port": "6001", 
    "protocol": "http", 
    "socketio": {}, 
    "sslCertPath": "", 
    "sslKeyPath": "" 
} 

.

// DocumentShared.php 
class DocumentShared implements ShouldBroadcast, ShouldBroadcastNow 
{ 
    use SerializesModels, InteractsWithSockets; 
    /** 
    * @var User 
    */ 
    public $user; 
    /** 
    * @var Resource 
    */ 
    public $resource; 
    /** 
    * @var Share 
    */ 
    public $share; 

    /** 
    * Create a new event instance. 
    * 
    * @param User $user 
    * @param Resource $resource 
    * @param Share $share 
    */ 
    public function __construct(User $user, Resource $resource, Share $share) 
    { 
     $this->user = $user; 
     $this->resource = $resource; 
     $this->share = $share; 
    } 

    public function broadcastOn() 
    { 
     return new Channel("documents-sharing"); 
    } 
} 

.

// app.blade.php 
<script src="{{ asset('js/socket.io.min.js') }}"></script> 
<script src="{{ asset('js/home.js') }}"></script> 

Danach laufe ich:

gulp watch 
redis-server 
node server.js 
laravel-echo-server start 
php artisan queue:listen 

Wenn die /notify Route getroffen wird, ich das Ereignis ausgelöst.

Route::get('notify', function() { 
    $user = User::first(); 
    $resource = Resource::first(); 
    $share = Share::first(); 

    event(new DocumentShared($user, $resource, $share)); 

    return 'done'; 
}); 

Ich kann sehen, der Server hat das Ereignis empfangen und es wurde nicht in der Warteschlange angezeigt.

terminal output

+0

Sehen Sie etwas Redis mit dem 'Monitor' Befehl? – Robert

+0

Ja, das Ereignis wurde korrekt empfangen. Ich denke das ist etwas am Front-End oder ich vermisse etwas! –

+0

Wie ändert sich 'window.Echo.channel()' in 'Echo.channel()'? – Robert

Antwort

0

Das Problem ist, dass die Client-Seite nicht mit dem Server verbinden konnte, weil die Port nicht reagiert. Ironischerweise habe ich nur den Schlüssel host aus der Konfigurationsdatei laravel-echo-server.json entfernt und den Server erneut ausgeführt. Alles hat funktioniert wie ein Zauber!

Verwandte Themen