NAME
MojoX::Transaction::WebSocket76 - WebSocket version hixie-76 transaction container
SYNOPSIS
use MojoX::Transaction::WebSocket76;
my $ws = MojoX::Transaction::WebSocket76->new;
DESCRIPTION
MojoX::Transaction::WebSocket76 is a container for WebSocket transactions as described in hixie-76 draft. Support for this version of the protocol was removed in Mojolicious 1.17. However, only old versions of the Safari browser (5.0.1) support only it.
NOTICE: This code tested with Mojolicious 4.xx and below and might not works with higher versions. This code not works with Mojolicious 6.40 and above.
To add support for both versions of the protocol (last and hixie-76 draft) in your Mojolicious application, add:
# In application module.
package MyApp;
# Override Mojolicious::build_tx().
sub build_tx {
my ($self) = @_;
# Use your own transaction module.
my $tx = MyApp::Transaction->new;
$self->plugins->emit_hook(after_build_tx => $tx, $self);
return $tx;
}
# In transaction module.
package MyApp::Transaction;
use Mojo::Transaction::WebSocket;
use MojoX::Transaction::WebSocket76;
use Mojo::Base 'Mojo::Transaction::HTTP';
# Override Mojo::Transaction::HTTP::server_read().
sub server_read {
# ...
# Need to change only this piece of code.
if (lc($req->headers->upgrade || '') eq 'websocket') {
# Upgrade to WebSocket of needed version.
$self->emit(upgrade =>
($req->headers->header('Sec-WebSocket-Key1')
&& $req->headers->header('Sec-WebSocket-Key2'))
? MojoX::Transaction::WebSocket76->new(handshake => $self)
: Mojo::Transaction::WebSocket->new(handshake => $self)
);
}
# ...
}
EVENTS
MojoX::Transaction::WebSocket76 inherits all events from Mojo::Transaction::WebSocket.
ATTRIBUTES
MojoX::Transaction::WebSocket76 inherits all attributes from Mojo::Transaction::WebSocket.
METHODS
MojoX::Transaction::WebSocket76 inherits all methods from Mojo::Transaction::WebSocket.
Mojo::Transaction::WebSocket76 overrides the following methods from Mojo::Transaction::WebSocket:
build_frame
my $bytes = $ws->build_frame($fin, $rsv1, $rsv2, $rsv3, $op, $payload);
Build WebSocket frame.
parse_frame
my $frame = $ws->parse_frame(\$bytes);
Parse WebSocket frame.
server_handshake
$ws->server_handshake;
Perform WebSocket handshake server-side, used to implement web servers.
DEBUGGING
You can set the MOJO_WEBSOCKET_DEBUG
environment variable to get some advanced diagnostics information printed to STDERR.
MOJO_WEBSOCKET_DEBUG=1
SEE ALSO
Mojolicious, Mojo::Transaction::WebSocket.
SUPPORT
- Repository
- Bug tracker
-
http://github.com/dionys/mojox-transaction-websocket76/issues
AUTHOR
Denis Ibaev, dionys@cpan.org
.
CONTRIBUTORS
Paul Cochrane, cpan:PTC, paul@liekut.de
.
COPYRIGHT AND LICENSE
Copyright (C) 2012-2016, Denis Ibaev.
This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.
See http://dev.perl.org/licenses/ for more information.