kriss / yii2-web-msg-sender
Yii2 web msg sender with workerman
Installs: 261
Dependents: 0
Suggesters: 0
Security: 0
Stars: 3
Watchers: 2
Forks: 1
Open Issues: 1
Type:yii2-extension
Requires
- workerman/gatewayclient: ^3.0
- workerman/phpsocket.io: ^1.1
- yiisoft/yii2: ~2.0.0
README
Yii2 web msg sender with workerman
Installation
The preferred way to install this extension is through composer.
Either run
composer require --prefer-dist kriss/yii2-web-msg-sender "*"
or add
"kriss/yii2-web-msg-sender": "*"
to the require section of your composer.json
file.
Usage
1. Config
in web.php
or main-local.php
<?php use kriss\webMsgSender\WebMsgSender; return [ 'components' => [ // others WebMsgSender::COMPONENT_NAME => [ 'class' => WebMsgSender::class, // config see WebMsgSender public attributes // change like this //'socketPort' => 2123 ], ], ];
Don't forget to open the port on the server, default port is 2120 for socketIO client and 2121 for PushApi from system. 2120 must open for client connect, 2121 must open for current system (or other system) to curl to push message.
2. Console Server
config in console/config
<?php return [ 'controllerMap' => [ 'web-msg-sender-service' => [ 'class' => \kriss\webMsgSender\ServiceController::class, ], ], ];
then start server by
php yii web-msg-sender-service/start
3. View Client
in views/layout
or other view file
<?= \kriss\webMsgSender\ClientReceiveWidget::widget(['uid' => Yii::$app->user->id]) ?>
open browser and open the view
4. Send One Msg For Test
<?php use kriss\webMsgSender\WebMsgSender; use yii\helpers\Html; WebMsgSender::getComponent()->getSender()->sendInfo('You Have A Message,' . Html::a('[clickMe]', 'http://www.baidu.com'));
5. Preview
FAQ
How to use https or wss with socket (config ssl)
two way:
- SocketIO origin ssl config
add config
use kriss\webMsgSender\WebMsgSender; return [ 'components' => [ // others WebMsgSender::COMPONENT_NAME => [ 'class' => WebMsgSender::class, // others 'socketOpts' => [ 'ssl' => [ 'local_cert' => __DIR__ . '/local-ssl.test.pem', // absolute path 'local_pk' => __DIR__ . '/local-ssl.test.key', 'verify_peer' => false, ], ], 'receiveSocketUrl' => 'https://local-ssl.test:{port}', // domain must match ssl cert ], ], ];
- Use Nginx to proxy forward ssl
server {
listen 443;
ssl on;
ssl_certificate /etc/ssl/local-ssl.test.pem;
ssl_certificate_key /etc/ssl/local-ssl.test.key;
ssl_session_timeout 5m;
ssl_session_cache shared:SSL:50m;
ssl_protocols SSLv3 SSLv2 TLSv1 TLSv1.1 TLSv1.2;
ssl_ciphers ALL:!ADH:!EXPORT56:RC4+RSA:+HIGH:+MEDIUM:+LOW:+SSLv2:+EXP;
location /socket.io
{
proxy_pass http://127.0.0.1:2120;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "Upgrade";
proxy_set_header X-Real-IP $remote_addr;
}
}