-
Notifications
You must be signed in to change notification settings - Fork 694
/
Copy pathwebsockets_echo.ru
65 lines (55 loc) · 1.81 KB
/
websockets_echo.ru
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
#!./uwsgi --plugins http,0:rack,fiber --https :443,foobar.crt,foobar.key --http-websockets --fiber --rack tests/websockets_echo.ru --async 100
class WebsocketEcho
def call(env)
ws_scheme = 'ws'
if env.has_key?('HTTPS') or env['rack.url_scheme'] == 'https'
ws_scheme = 'wss'
end
if env['PATH_INFO'] == '/'
body = <<EOF
<html>
<head>
<script language="Javascript">
var s = new WebSocket("#{ws_scheme}://#{env['HTTP_HOST']}/foobar/");
s.onopen = function() {
alert("connected !!!");
s.send("ciao");
};
s.onmessage = function(e) {
var bb = document.getElementById('blackboard')
var html = bb.innerHTML;
bb.innerHTML = html + '<br/>' + e.data;
};
s.onerror = function(e) {
alert(e);
}
s.onclose = function(e) {
alert("connection closed");
}
function invia() {
var value = document.getElementById('testo').value;
s.send(value);
}
</script>
</head>
<body>
<h1>WebSocket</h1>
<input type="text" id="testo"/>
<input type="button" value="invia" onClick="invia();"/>
<div id="blackboard" style="width:640px;height:480px;background-color:black;color:white;border: solid 2px red;overflow:auto">
</div>
</body>
</html>
EOF
return [200, { 'Content-Type' => 'text/html'}, [body]]
elsif env['PATH_INFO'] == '/foobar/'
UWSGI::websocket_handshake(env['HTTP_SEC_WEBSOCKET_KEY'], env['HTTP_ORIGIN'])
puts "websockets..."
loop do
msg = UWSGI::websocket_recv
UWSGI::websocket_send("[#{Time.now}] #{msg}")
end
end
end
end
run WebsocketEcho.new