2013-11-06 21:01:55 +00:00
|
|
|
#lang minimart
|
|
|
|
|
|
|
|
(require "../drivers/websocket.rkt")
|
|
|
|
(require "../demand-matcher.rkt")
|
|
|
|
|
|
|
|
(spawn-websocket-driver)
|
|
|
|
|
|
|
|
(define any-client (websocket-remote-client ?))
|
2014-01-14 00:33:48 +00:00
|
|
|
(define server-id (websocket-local-server 8081 (websocket-ssl-options "server-cert.pem"
|
|
|
|
"private-key.pem")))
|
2013-11-06 21:01:55 +00:00
|
|
|
|
|
|
|
(define (spawn-connection-handler c)
|
|
|
|
(log-info "spawn-connection-handler ~v" c)
|
|
|
|
(define (connection-handler e n)
|
|
|
|
(when e (log-info "connection-handler ~v: ~v /// ~v" c e n))
|
|
|
|
(match e
|
2014-05-22 03:22:21 +00:00
|
|
|
[(routing-update (? gestalt-empty?)) (transition n (quit))]
|
2013-11-06 21:01:55 +00:00
|
|
|
[_
|
|
|
|
(if (< n 20)
|
|
|
|
(transition (+ n 1) (send (websocket-message server-id c (format "msg ~v" n))))
|
|
|
|
#f)]))
|
|
|
|
(spawn connection-handler
|
|
|
|
0
|
2014-05-22 03:22:21 +00:00
|
|
|
(gestalt-union (sub (websocket-message c server-id ?))
|
|
|
|
(sub (websocket-message c server-id ?) #:level 1)
|
|
|
|
(pub (websocket-message server-id c ?)))))
|
|
|
|
|
|
|
|
(spawn-demand-matcher (websocket-message (?! any-client) server-id ?)
|
|
|
|
spawn-connection-handler
|
|
|
|
(lambda (c)
|
|
|
|
(log-info "Connection handler ~v decided to exit" c)
|
|
|
|
'()))
|