Skip to content

oraoto/pony-websocket

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

53 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

pony-websocket

CircleCI stability

WebSocket server for pony

It's RFC6455 conformant, see test report.

Installation

  • Install corral
  • corral add github github.com/ponylang/net_ssl.git
  • corral fetch to fetch your dependencies
  • use "websocket" to include this package
  • corral run -- ponyc to compile your applicatpion

Select OpenSSL Version

You must select an SSL version to use.

Using OpenSSL 0.9.0

corral run -- ponyc -Dopenssl_0.9.0

Using OpenSSL 1.1.x:

corral run -- ponyc -Dopenssl_1.1.x

Usage

The API is model after the net package and much simplified.

Here is a simple echo server:

use "websocket"

actor Main
  new create(env: Env) =>
    try
      let listener = WebSocketListener(
        env.root as AmbientAuth, EchoListenNotify, "127.0.0.1","8989")
    end

class EchoListenNotify is WebSocketListenNotify
  // A tcp connection connected, return a WebsocketConnectionNotify instance
  fun ref connected(): EchoConnectionNotify iso^ =>
    EchoConnectionNotify

class EchoConnectionNotify is WebSocketConnectionNotify
  // A websocket connection enters the OPEN state
  fun ref opened(conn: WebSocketConnection ref) =>
    @printf[I32]("New client connected\n".cstring())

  // UTF-8 text data received
  fun ref text_received(conn: WebSocketConnection ref, text: String) =>
    // Send the text back
    conn.send_text(text)

  // Binary data received
  fun ref binary_received(conn: WebSocketConnection ref, data: Array[U8] val) =>
    conn.send_binary(data)

  // A websocket connection enters the CLOSED state
  fun ref closed(conn: WebSocketConnection ref) =>
    @printf[I32]("Connection closed\n".cstring())

An simplified API is also provided: example.

See more examples.

About

WebSocket server for Ponylang🐴

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published