Юзаю laravel-websockets, без HTTPS всё отлично работает как на локалке, так и на сервере. На сервер ставлю SSL сертификат, подключаю всё по FAQ из их доки (отсюда:
https://beyondco.de/docs/laravel-websockets/basic-...), только я вообще не понимаю что значит вот эта фраза:
* Path to local certificate file on filesystem. It must be a PEM encoded file which
* contains your certificate and private key. It can optionally contain the
* certificate chain of issuers. The private key also may be contained
* in a separate file specified by local_pk.
Это вообще что за идея такая? То есть если я в том же апаче разбиваю промежуточные файлы, то здесь мне нужно как-то собрать их в один? А как группировать? Какое расширение? У всех же разное расширение :/
Конфиг следующий:
websockets.php
'ssl' => [
/*
* Path to local certificate file on filesystem. It must be a PEM encoded file which
* contains your certificate and private key. It can optionally contain the
* certificate chain of issuers. The private key also may be contained
* in a separate file specified by local_pk.
*/
'local_cert' => '/etc/ssl/domain_name.crt',
/*
* Path to local private key file on filesystem in case of separate files for
* certificate (local_cert) and private key.
*/
'local_pk' => '/etc/ssl/private.key',
/*
* Passphrase for your local_cert file.
*/
'passphrase' => env('LARAVEL_WEBSOCKETS_SSL_PASSPHRASE', null),
],
broadcasting.php
'pusher' => [
'driver' => 'pusher',
'key' => env('PUSHER_APP_KEY'),
'secret' => env('PUSHER_APP_SECRET'),
'app_id' => env('PUSHER_APP_ID'),
'options' => [
'cluster' => env('PUSHER_APP_CLUSTER'),
'encrypted' => true,
'host' => 'https://mydomain.ru/',
'port' => 6001,
'scheme' => 'https',
'useTLS' => true
],
'client_options' => [
// Guzzle client options: https://docs.guzzlephp.org/en/stable/request-options.html
],
],
Клиент
window.Echo = new Echo({
broadcaster: 'pusher',
key: process.env.MIX_PUSHER_APP_KEY,
cluster: process.env.MIX_PUSHER_APP_CLUSTER,
wsHost: window.location.hostname,
wsPort: 6001,
wssPort: 6001,
encrypted: true,
disableStats: true,
forceTLS: true,
enabledTransports: ['ws','wss']
});
Результаты возникают следующие:
1) Поскольку у меня подключение к сокету происходит сразу при коннекте на любую из страниц, то я сходу вижу ошибку в консоли: WebSocket connection to '
wss://mydomain.ru:6001/app/myapp?protocol=7&client...' failed
Понятия не имею, что её триггерит, зато в гайде с 20 просмотрами на просторах интернета нашёл решение, что, оказывается, можно перейти по этой ссылке, заменить wss на https, перезагрузить страницу и конкретно в этой итерации браузера соединение будет устанавливаться (видно по логам самого websocket:serve), но при этом если запустить браузер в инкогнито, то снова та же самая ошибка.
2) Дальше больше, даже если запустить методом из первого пункта и отправить через сокет запрос на сервак, то вылетит 60 cURL, пытался пофиксить через вот этот гайд -> Увы, не помогает, так же выключал верификацию SSL через websocket.php, всё такая же ситуация. Естесвенно, после каждой правки чистил кэш и перезагружал апач.
Даже не знаю в какую сторону думать, есть у кого-нибудь какие-нибудь идеи?