syndicate-rkt/syndicate/distributed/protocol.rkt

23 lines
776 B
Racket
Raw Normal View History

2019-03-18 15:34:14 +00:00
#lang imperative-syndicate
(provide (all-defined-out))
;; Addressing
(assertion-struct server-tcp-connection (host port scope))
(assertion-struct server-loopback-connection (scope))
(define (standard-localhost-server/tcp [scope "broker"])
(server-tcp-connection "localhost" 8001 scope))
2019-03-18 15:34:14 +00:00
;; Client protocol
(assertion-struct to-server (address assertion))
(assertion-struct from-server (address assertion))
(assertion-struct server-connection (address))
(assertion-struct server-connected (address))
(message-struct force-server-disconnect (address))
;; Federation configuration
2019-05-16 19:14:19 +00:00
;; e.g. (federated-uplink "scope1" (server-tcp-connection "peer.example" 8001 "scope2"))
(assertion-struct federated-uplink (scope peer))
(assertion-struct federated-uplink-connected (link))